-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathjwt.go
86 lines (74 loc) · 1.61 KB
/
jwt.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
package auth
import (
"errors"
"time"
"github.com/golang-jwt/jwt"
)
// JwtStore :
type JwtStore struct {
tokenKey []byte
expireAfter time.Duration
}
// JwtToken :
type JwtToken struct {
tokenKey []byte
jwt.Token
}
// Claims :
func (t *JwtToken) Claims(key string) interface{} {
claims := t.Token.Claims.(jwt.MapClaims)
return claims[key]
}
// SetClaim :
func (t *JwtToken) SetClaim(key string, value interface{}) ClaimSetter {
claims := t.Token.Claims.(jwt.MapClaims)
claims[key] = value
return t
}
// Expiry :
func (t *JwtToken) Expiry() time.Time {
expt := t.Claims("exp")
return time.Unix(0, int64(expt.(float64)))
}
// IsExpired :
func (t *JwtToken) IsExpired() bool {
exp := t.Expiry()
return time.Now().After(exp)
}
// String :
func (t *JwtToken) String() string {
tokenStr, _ := t.Token.SignedString(t.tokenKey)
return tokenStr
}
// NewToken :
func (s *JwtStore) NewToken() *JwtToken {
token := jwt.New(jwt.GetSigningMethod("HS256"))
claims := token.Claims.(jwt.MapClaims)
claims["exp"] = time.Now().Add(s.expireAfter).UnixNano()
t := &JwtToken{
tokenKey: s.tokenKey,
Token: *token,
}
return t
}
// CheckToken :
func (s *JwtStore) CheckToken(token string) (Token, error) {
t, err := jwt.Parse(token, func(token *jwt.Token) (interface{}, error) {
return s.tokenKey, nil
})
if err != nil {
return nil, err
}
jtoken := &JwtToken{s.tokenKey, *t}
if jtoken.IsExpired() {
return jtoken, errors.New("token expired")
}
return jtoken, nil
}
// NewJwtStore :
func NewJwtStore(tokenKey string, expireAfter time.Duration) *JwtStore {
return &JwtStore{
[]byte(tokenKey),
expireAfter,
}
}