...
1 package jwt
2
3 import (
4 "crypto"
5 "crypto/hmac"
6 "errors"
7 )
8
9
10
11 type SigningMethodHMAC struct {
12 Name string
13 Hash crypto.Hash
14 }
15
16
17 var (
18 SigningMethodHS256 *SigningMethodHMAC
19 SigningMethodHS384 *SigningMethodHMAC
20 SigningMethodHS512 *SigningMethodHMAC
21 ErrSignatureInvalid = errors.New("signature is invalid")
22 )
23
24 func init() {
25
26 SigningMethodHS256 = &SigningMethodHMAC{"HS256", crypto.SHA256}
27 RegisterSigningMethod(SigningMethodHS256.Alg(), func() SigningMethod {
28 return SigningMethodHS256
29 })
30
31
32 SigningMethodHS384 = &SigningMethodHMAC{"HS384", crypto.SHA384}
33 RegisterSigningMethod(SigningMethodHS384.Alg(), func() SigningMethod {
34 return SigningMethodHS384
35 })
36
37
38 SigningMethodHS512 = &SigningMethodHMAC{"HS512", crypto.SHA512}
39 RegisterSigningMethod(SigningMethodHS512.Alg(), func() SigningMethod {
40 return SigningMethodHS512
41 })
42 }
43
44 func (m *SigningMethodHMAC) Alg() string {
45 return m.Name
46 }
47
48
49
50
51
52
53
54
55
56
57
58 func (m *SigningMethodHMAC) Verify(signingString string, sig []byte, key interface{}) error {
59
60 keyBytes, ok := key.([]byte)
61 if !ok {
62 return newError("HMAC verify expects []byte", ErrInvalidKeyType)
63 }
64
65
66 if !m.Hash.Available() {
67 return ErrHashUnavailable
68 }
69
70
71
72
73 hasher := hmac.New(m.Hash.New, keyBytes)
74 hasher.Write([]byte(signingString))
75 if !hmac.Equal(sig, hasher.Sum(nil)) {
76 return ErrSignatureInvalid
77 }
78
79
80 return nil
81 }
82
83
84
85
86
87
88
89
90
91 func (m *SigningMethodHMAC) Sign(signingString string, key interface{}) ([]byte, error) {
92 if keyBytes, ok := key.([]byte); ok {
93 if !m.Hash.Available() {
94 return nil, ErrHashUnavailable
95 }
96
97 hasher := hmac.New(m.Hash.New, keyBytes)
98 hasher.Write([]byte(signingString))
99
100 return hasher.Sum(nil), nil
101 }
102
103 return nil, newError("HMAC sign expects []byte", ErrInvalidKeyType)
104 }
105
View as plain text