Package request
Overview ▹
Index ▹
Variables
Extract bearer token from Authorization header Uses PostExtractionFilter to strip "Bearer " prefix from header
var AuthorizationHeaderExtractor = &PostExtractionFilter{ HeaderExtractor{"Authorization"}, stripBearerPrefixFromTokenString, }
Errors
var ( ErrNoTokenInRequest = errors.New("no token present in request") )
Extractor for OAuth2 access tokens. Looks in 'Authorization' header then 'access_token' argument for a token.
var OAuth2Extractor = &MultiExtractor{ AuthorizationHeaderExtractor, ArgumentExtractor{"access_token"}, }
func ParseFromRequest ¶
func ParseFromRequest(req *http.Request, extractor Extractor, keyFunc jwt.Keyfunc) (token *jwt.Token, err error)
Extract and parse a JWT token from an HTTP request. This behaves the same as Parse, but accepts a request and an extractor instead of a token string. The Extractor interface allows you to define the logic for extracting a token. Several useful implementations are provided.
func ParseFromRequestWithClaims ¶
func ParseFromRequestWithClaims(req *http.Request, extractor Extractor, claims jwt.Claims, keyFunc jwt.Keyfunc) (token *jwt.Token, err error)
ParseFromRequest but with custom Claims type
type ArgumentExtractor ¶
Extract token from request arguments. This includes a POSTed form or GET URL arguments. Argument names are tried in order until there's a match. This extractor calls `ParseMultipartForm` on the request
type ArgumentExtractor []string
▹ Example
func (ArgumentExtractor) ExtractToken ¶
func (e ArgumentExtractor) ExtractToken(req *http.Request) (string, error)
type Extractor ¶
Interface for extracting a token from an HTTP request. The ExtractToken method should return a token string or an error. If no token is present, you must return ErrNoTokenInRequest.
type Extractor interface { ExtractToken(*http.Request) (string, error) }
type HeaderExtractor ¶
Extractor for finding a token in a header. Looks at each specified header in order until there's a match
type HeaderExtractor []string
▹ Example
func (HeaderExtractor) ExtractToken ¶
func (e HeaderExtractor) ExtractToken(req *http.Request) (string, error)
type MultiExtractor ¶
Tries Extractors in order until one returns a token string or an error occurs
type MultiExtractor []Extractor
func (MultiExtractor) ExtractToken ¶
func (e MultiExtractor) ExtractToken(req *http.Request) (string, error)
type PostExtractionFilter ¶
Wrap an Extractor in this to post-process the value before it's handed off. See AuthorizationHeaderExtractor for an example
type PostExtractionFilter struct { Extractor Filter func(string) (string, error) }
func (*PostExtractionFilter) ExtractToken ¶
func (e *PostExtractionFilter) ExtractToken(req *http.Request) (string, error)