mirror of
https://github.com/ergochat/ergo.git
synced 2024-11-22 11:59:40 +01:00
ee7f818674
* implement SASL OAUTHBEARER and draft/bearer * Upgrade JWT lib * Fix an edge case in SASL EXTERNAL * Accept longer SASL responses * review fix: allow multiple token definitions * enhance tests * use SASL utilities from irc-go * test expired tokens
50 lines
1.8 KiB
Go
50 lines
1.8 KiB
Go
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.
|
|
type joinedError struct {
|
|
errs []error
|
|
}
|
|
|
|
func (je joinedError) Error() string {
|
|
msg := []string{}
|
|
for _, err := range je.errs {
|
|
msg = append(msg, err.Error())
|
|
}
|
|
|
|
return strings.Join(msg, ", ")
|
|
}
|
|
|
|
// joinErrors joins together multiple errors. Useful for scenarios where
|
|
// multiple errors next to each other occur, e.g., in claims validation.
|
|
func joinErrors(errs ...error) error {
|
|
return &joinedError{
|
|
errs: errs,
|
|
}
|
|
}
|