gitea源码

ssh_key_verify.go 1.4KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748
  1. // Copyright 2021 The Gitea Authors. All rights reserved.
  2. // SPDX-License-Identifier: MIT
  3. package asymkey
  4. import (
  5. "context"
  6. "strings"
  7. "code.gitea.io/gitea/models/db"
  8. "code.gitea.io/gitea/modules/log"
  9. "github.com/42wim/sshsig"
  10. )
  11. // VerifySSHKey marks a SSH key as verified
  12. func VerifySSHKey(ctx context.Context, ownerID int64, fingerprint, token, signature string) (string, error) {
  13. return db.WithTx2(ctx, func(ctx context.Context) (string, error) {
  14. key := new(PublicKey)
  15. has, err := db.GetEngine(ctx).Where("owner_id = ? AND fingerprint = ?", ownerID, fingerprint).Get(key)
  16. if err != nil {
  17. return "", err
  18. } else if !has {
  19. return "", ErrKeyNotExist{}
  20. }
  21. err = sshsig.Verify(strings.NewReader(token), []byte(signature), []byte(key.Content), "gitea")
  22. if err != nil {
  23. // edge case for Windows based shells that will add CR LF if piped to ssh-keygen command
  24. // see https://github.com/PowerShell/PowerShell/issues/5974
  25. if sshsig.Verify(strings.NewReader(token+"\r\n"), []byte(signature), []byte(key.Content), "gitea") != nil {
  26. log.Debug("VerifySSHKey sshsig.Verify failed: %v", err)
  27. return "", ErrSSHInvalidTokenSignature{
  28. Fingerprint: key.Fingerprint,
  29. }
  30. }
  31. }
  32. key.Verified = true
  33. if _, err := db.GetEngine(ctx).ID(key.ID).Cols("verified").Update(key); err != nil {
  34. return "", err
  35. }
  36. return key.Fingerprint, nil
  37. })
  38. }