auth: add token issuer option (#1835)

This commit is contained in:
ben-toogood 2020-07-14 12:44:51 +01:00 committed by GitHub
parent 9f9c748f9b
commit a2bb0bea2d
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 12 additions and 1 deletions

View File

@ -196,6 +196,8 @@ type TokenOptions struct {
RefreshToken string RefreshToken string
// Expiry is the time the token should live for // Expiry is the time the token should live for
Expiry time.Duration Expiry time.Duration
// Issuer of the account
Issuer string
} }
type TokenOption func(o *TokenOptions) type TokenOption func(o *TokenOptions)
@ -220,6 +222,12 @@ func WithToken(rt string) TokenOption {
} }
} }
func WithTokenIssuer(iss string) TokenOption {
return func(o *TokenOptions) {
o.Issuer = iss
}
}
// NewTokenOptions from a slice of options // NewTokenOptions from a slice of options
func NewTokenOptions(opts ...TokenOption) TokenOptions { func NewTokenOptions(opts ...TokenOption) TokenOptions {
var options TokenOptions var options TokenOptions

View File

@ -193,6 +193,9 @@ func (s *svc) Inspect(token string) (*auth.Account, error) {
// Token generation using an account ID and secret // Token generation using an account ID and secret
func (s *svc) Token(opts ...auth.TokenOption) (*auth.Token, error) { func (s *svc) Token(opts ...auth.TokenOption) (*auth.Token, error) {
options := auth.NewTokenOptions(opts...) options := auth.NewTokenOptions(opts...)
if len(options.Issuer) == 0 {
options.Issuer = s.options.Issuer
}
// we have the JWT private key and refresh accounts locally // we have the JWT private key and refresh accounts locally
if len(s.options.PrivateKey) > 0 { if len(s.options.PrivateKey) > 0 {
@ -224,7 +227,7 @@ func (s *svc) Token(opts ...auth.TokenOption) (*auth.Token, error) {
RefreshToken: options.RefreshToken, RefreshToken: options.RefreshToken,
TokenExpiry: int64(options.Expiry.Seconds()), TokenExpiry: int64(options.Expiry.Seconds()),
Options: &pb.Options{ Options: &pb.Options{
Namespace: s.Options().Issuer, Namespace: options.Issuer,
}, },
}, s.callOpts()...) }, s.callOpts()...)
if err != nil { if err != nil {