- Notifications
You must be signed in to change notification settings - Fork 371
/
Copy patherrors.go
49 lines (43 loc) · 1.79 KB
/
errors.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
package jwt
import (
"errors"
"strings"
)
var (
ErrInvalidKey=errors.New("key is invalid")
ErrInvalidKeyType=errors.New("key is of invalid type")
ErrHashUnavailable=errors.New("the requested hash function is unavailable")
ErrTokenMalformed=errors.New("token is malformed")
ErrTokenUnverifiable=errors.New("token is unverifiable")
ErrTokenSignatureInvalid=errors.New("token signature is invalid")
ErrTokenRequiredClaimMissing=errors.New("token is missing required claim")
ErrTokenInvalidAudience=errors.New("token has invalid audience")
ErrTokenExpired=errors.New("token is expired")
ErrTokenUsedBeforeIssued=errors.New("token used before issued")
ErrTokenInvalidIssuer=errors.New("token has invalid issuer")
ErrTokenInvalidSubject=errors.New("token has invalid subject")
ErrTokenNotValidYet=errors.New("token is not valid yet")
ErrTokenInvalidId=errors.New("token has invalid id")
ErrTokenInvalidClaims=errors.New("token has invalid claims")
ErrInvalidType=errors.New("invalid type for claim")
)
// joinedError is an error type that works similar to what [errors.Join]
// produces, with the exception that it has a nice error string; mainly its
// error messages are concatenated using a comma, rather than a newline.
typejoinedErrorstruct {
errs []error
}
func (jejoinedError) Error() string {
msg:= []string{}
for_, err:=rangeje.errs {
msg=append(msg, err.Error())
}
returnstrings.Join(msg, ", ")
}
// joinErrors joins together multiple errors. Useful for scenarios where
// multiple errors next to each other occur, e.g., in claims validation.
funcjoinErrors(errs...error) error {
return&joinedError{
errs: errs,
}
}