You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

ssh_key_verify.go 1.2KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849
  1. // Copyright 2021 The Gitea Authors. All rights reserved.
  2. // SPDX-License-Identifier: MIT
  3. package asymkey
  4. import (
  5. "bytes"
  6. "code.gitea.io/gitea/models/db"
  7. "code.gitea.io/gitea/modules/log"
  8. "github.com/42wim/sshsig"
  9. )
  10. // VerifySSHKey marks a SSH key as verified
  11. func VerifySSHKey(ownerID int64, fingerprint, token, signature string) (string, error) {
  12. ctx, committer, err := db.TxContext(db.DefaultContext)
  13. if err != nil {
  14. return "", err
  15. }
  16. defer committer.Close()
  17. key := new(PublicKey)
  18. has, err := db.GetEngine(ctx).Where("owner_id = ? AND fingerprint = ?", ownerID, fingerprint).Get(key)
  19. if err != nil {
  20. return "", err
  21. } else if !has {
  22. return "", ErrKeyNotExist{}
  23. }
  24. if err := sshsig.Verify(bytes.NewBuffer([]byte(token)), []byte(signature), []byte(key.Content), "gitea"); err != nil {
  25. log.Error("Unable to validate token signature. Error: %v", err)
  26. return "", ErrSSHInvalidTokenSignature{
  27. Fingerprint: key.Fingerprint,
  28. }
  29. }
  30. key.Verified = true
  31. if _, err := db.GetEngine(ctx).ID(key.ID).Cols("verified").Update(key); err != nil {
  32. return "", err
  33. }
  34. if err := committer.Commit(); err != nil {
  35. return "", err
  36. }
  37. return key.Fingerprint, nil
  38. }