2018-06-04 21:49:06 +00:00
|
|
|
package http
|
|
|
|
|
|
|
|
import (
|
|
|
|
"errors"
|
2018-08-27 19:18:11 +00:00
|
|
|
"fmt"
|
2018-06-04 21:49:06 +00:00
|
|
|
"net/http"
|
|
|
|
"strings"
|
|
|
|
)
|
|
|
|
|
2018-08-27 19:18:11 +00:00
|
|
|
const tokenScheme = "Token " // TODO(goller): I'd like this to be Bearer
|
2018-06-04 21:49:06 +00:00
|
|
|
|
|
|
|
// errors
|
|
|
|
var (
|
2018-11-21 14:22:35 +00:00
|
|
|
ErrAuthHeaderMissing = errors.New("authorization Header is missing")
|
|
|
|
ErrAuthBadScheme = errors.New("authorization Header Scheme is invalid")
|
2018-06-04 21:49:06 +00:00
|
|
|
)
|
|
|
|
|
2018-08-27 19:18:11 +00:00
|
|
|
// GetToken will parse the token from http Authorization Header.
|
|
|
|
func GetToken(r *http.Request) (string, error) {
|
2018-06-04 21:49:06 +00:00
|
|
|
header := r.Header.Get("Authorization")
|
|
|
|
if header == "" {
|
|
|
|
return "", ErrAuthHeaderMissing
|
|
|
|
}
|
|
|
|
if !strings.HasPrefix(header, tokenScheme) {
|
|
|
|
return "", ErrAuthBadScheme
|
|
|
|
}
|
|
|
|
return header[len(tokenScheme):], nil
|
|
|
|
}
|
2018-08-27 19:18:11 +00:00
|
|
|
|
|
|
|
// SetToken adds the token to the request.
|
|
|
|
func SetToken(token string, req *http.Request) {
|
|
|
|
req.Header.Set("Authorization", fmt.Sprintf("%s%s", tokenScheme, token))
|
|
|
|
}
|