verifier.go 2.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768
  1. package jws
  2. import (
  3. "github.com/lestrrat-go/jwx/jwa"
  4. "github.com/pkg/errors"
  5. )
  6. type VerifierFactory interface {
  7. Create() (Verifier, error)
  8. }
  9. type VerifierFactoryFn func() (Verifier, error)
  10. func (fn VerifierFactoryFn) Create() (Verifier, error) {
  11. return fn()
  12. }
  13. var verifierDB map[jwa.SignatureAlgorithm]VerifierFactory
  14. // RegisterVerifier is used to register a factory object that creates
  15. // Verifier objects based on the given algorithm.
  16. //
  17. // For example, if you would like to provide a custom verifier for
  18. // jwa.EdDSA, use this function to register a `VerifierFactory`
  19. // (probably in your `init()`)
  20. func RegisterVerifier(alg jwa.SignatureAlgorithm, f VerifierFactory) {
  21. verifierDB[alg] = f
  22. }
  23. func init() {
  24. verifierDB = make(map[jwa.SignatureAlgorithm]VerifierFactory)
  25. for _, alg := range []jwa.SignatureAlgorithm{jwa.RS256, jwa.RS384, jwa.RS512, jwa.PS256, jwa.PS384, jwa.PS512} {
  26. RegisterVerifier(alg, func(alg jwa.SignatureAlgorithm) VerifierFactory {
  27. return VerifierFactoryFn(func() (Verifier, error) {
  28. return newRSAVerifier(alg), nil
  29. })
  30. }(alg))
  31. }
  32. for _, alg := range []jwa.SignatureAlgorithm{jwa.ES256, jwa.ES384, jwa.ES512, jwa.ES256K} {
  33. RegisterVerifier(alg, func(alg jwa.SignatureAlgorithm) VerifierFactory {
  34. return VerifierFactoryFn(func() (Verifier, error) {
  35. return newECDSAVerifier(alg), nil
  36. })
  37. }(alg))
  38. }
  39. for _, alg := range []jwa.SignatureAlgorithm{jwa.HS256, jwa.HS384, jwa.HS512} {
  40. RegisterVerifier(alg, func(alg jwa.SignatureAlgorithm) VerifierFactory {
  41. return VerifierFactoryFn(func() (Verifier, error) {
  42. return newHMACVerifier(alg), nil
  43. })
  44. }(alg))
  45. }
  46. RegisterVerifier(jwa.EdDSA, VerifierFactoryFn(func() (Verifier, error) {
  47. return newEdDSAVerifier(), nil
  48. }))
  49. }
  50. // NewVerifier creates a verifier that signs payloads using the given signature algorithm.
  51. func NewVerifier(alg jwa.SignatureAlgorithm) (Verifier, error) {
  52. f, ok := verifierDB[alg]
  53. if ok {
  54. return f.Create()
  55. }
  56. return nil, errors.Errorf(`unsupported signature algorithm "%s"`, alg)
  57. }