http-signature.go 602 B

12345678910111213141516171819202122232425262728
  1. package signature
  2. import (
  3. "fmt"
  4. "net/http"
  5. "github.com/go-fed/httpsig"
  6. "github.com/ncarlier/webhookd/pkg/truststore"
  7. )
  8. // HTTPSignatureHandler validate request HTTP signature
  9. func HTTPSignatureHandler(r *http.Request, ts truststore.TrustStore) error {
  10. verifier, err := httpsig.NewVerifier(r)
  11. if err != nil {
  12. return err
  13. }
  14. pubkeyID := verifier.KeyId()
  15. pubkey := ts.GetPublicKey(pubkeyID)
  16. if pubkey == nil {
  17. return fmt.Errorf("public key not found: %s", pubkeyID)
  18. }
  19. // TODO dynamic algo
  20. err = verifier.Verify(pubkey, httpsig.RSA_SHA256)
  21. if err != nil {
  22. return err
  23. }
  24. return nil
  25. }