1
0
mirror of https://github.com/go-micro/go-micro.git synced 2025-01-17 17:44:30 +02:00
go-micro/auth/options.go

223 lines
4.2 KiB
Go
Raw Normal View History

package auth
import (
2020-05-26 16:52:21 +02:00
"context"
"time"
"go-micro.dev/v4/logger"
)
2020-04-14 10:14:07 +02:00
func NewOptions(opts ...Option) Options {
options := Options{
Logger: logger.DefaultLogger,
}
2020-04-14 10:14:07 +02:00
for _, o := range opts {
o(&options)
}
2020-04-14 10:14:07 +02:00
return options
}
type Options struct {
2023-04-26 02:16:34 +02:00
// Logger is the underline logger
Logger logger.Logger
// Token is the services token used to authenticate itself
Token *Token
2020-04-07 13:46:44 +02:00
// Namespace the service belongs to
Namespace string
2020-03-31 13:44:34 +02:00
// ID is the services auth ID
ID string
2020-04-01 15:25:00 +02:00
// Secret is used to authenticate the service
Secret string
// PublicKey for decoding JWTs
PublicKey string
2020-04-01 18:17:40 +02:00
// PrivateKey for encoding JWTs
PrivateKey string
2020-05-13 18:54:47 +02:00
// Addrs sets the addresses of auth
Addrs []string
}
type Option func(o *Options)
2022-09-30 16:27:07 +02:00
// Addrs is the auth addresses to use.
2020-05-13 18:54:47 +02:00
func Addrs(addrs ...string) Option {
return func(o *Options) {
o.Addrs = addrs
}
}
2022-09-30 16:27:07 +02:00
// Namespace the service belongs to.
2020-04-07 13:46:44 +02:00
func Namespace(n string) Option {
return func(o *Options) {
o.Namespace = n
}
}
2022-09-30 16:27:07 +02:00
// PublicKey is the JWT public key.
func PublicKey(key string) Option {
return func(o *Options) {
o.PublicKey = key
}
}
2022-09-30 16:27:07 +02:00
// PrivateKey is the JWT private key.
2020-04-01 18:17:40 +02:00
func PrivateKey(key string) Option {
return func(o *Options) {
o.PrivateKey = key
}
}
2022-09-30 16:27:07 +02:00
// WithLogger sets the underline logger.
func WithLogger(l logger.Logger) Option {
return func(o *Options) {
o.Logger = l
}
}
2022-09-30 16:27:07 +02:00
// Credentials sets the auth credentials.
2020-04-01 15:25:00 +02:00
func Credentials(id, secret string) Option {
return func(o *Options) {
2020-03-31 13:44:34 +02:00
o.ID = id
2020-04-01 15:25:00 +02:00
o.Secret = secret
}
}
2022-09-30 16:27:07 +02:00
// ClientToken sets the auth token to use when making requests.
2020-04-29 16:11:06 +02:00
func ClientToken(token *Token) Option {
return func(o *Options) {
o.Token = token
}
}
type GenerateOptions struct {
// Metadata associated with the account
Metadata map[string]string
// Provider of the account, e.g. oauth
Provider string
// Type of the account, e.g. user
Type string
2020-04-01 18:20:02 +02:00
// Secret used to authenticate the account
Secret string
2023-04-26 02:16:34 +02:00
// Scopes the account has access too
Scopes []string
}
type GenerateOption func(o *GenerateOptions)
2022-09-30 16:27:07 +02:00
// WithSecret for the generated account.
2020-04-01 18:20:02 +02:00
func WithSecret(s string) GenerateOption {
return func(o *GenerateOptions) {
o.Secret = s
}
}
2022-09-30 16:27:07 +02:00
// WithType for the generated account.
func WithType(t string) GenerateOption {
return func(o *GenerateOptions) {
o.Type = t
}
}
2022-09-30 16:27:07 +02:00
// WithMetadata for the generated account.
func WithMetadata(md map[string]string) GenerateOption {
return func(o *GenerateOptions) {
o.Metadata = md
}
}
2022-09-30 16:27:07 +02:00
// WithProvider for the generated account.
2020-05-21 17:41:55 +02:00
func WithProvider(p string) GenerateOption {
return func(o *GenerateOptions) {
2020-05-21 17:41:55 +02:00
o.Provider = p
}
}
2022-09-30 16:27:07 +02:00
// WithScopes for the generated account.
2020-05-21 17:41:55 +02:00
func WithScopes(s ...string) GenerateOption {
return func(o *GenerateOptions) {
2020-05-21 17:41:55 +02:00
o.Scopes = s
}
}
2022-09-30 16:27:07 +02:00
// NewGenerateOptions from a slice of options.
func NewGenerateOptions(opts ...GenerateOption) GenerateOptions {
var options GenerateOptions
for _, o := range opts {
o(&options)
}
return options
}
type TokenOptions struct {
2020-04-01 15:25:00 +02:00
// ID for the account
ID string
// Secret for the account
Secret string
// RefreshToken is used to refesh a token
RefreshToken string
// Expiry is the time the token should live for
Expiry time.Duration
}
type TokenOption func(o *TokenOptions)
2022-09-30 16:27:07 +02:00
// WithExpiry for the token.
2020-04-01 15:25:00 +02:00
func WithExpiry(ex time.Duration) TokenOption {
return func(o *TokenOptions) {
o.Expiry = ex
}
}
func WithCredentials(id, secret string) TokenOption {
return func(o *TokenOptions) {
o.ID = id
o.Secret = secret
}
}
func WithToken(rt string) TokenOption {
return func(o *TokenOptions) {
2020-04-01 15:25:00 +02:00
o.RefreshToken = rt
}
}
2022-09-30 16:27:07 +02:00
// NewTokenOptions from a slice of options.
func NewTokenOptions(opts ...TokenOption) TokenOptions {
var options TokenOptions
for _, o := range opts {
o(&options)
}
2022-09-30 16:27:07 +02:00
// set default expiry of token
2020-04-01 15:25:00 +02:00
if options.Expiry == 0 {
options.Expiry = time.Minute
}
return options
}
2020-05-20 17:49:52 +02:00
2020-05-21 19:11:35 +02:00
type VerifyOptions struct {
2020-05-26 16:52:21 +02:00
Context context.Context
2020-05-21 19:11:35 +02:00
}
2020-05-20 17:49:52 +02:00
type VerifyOption func(o *VerifyOptions)
2020-05-21 19:11:35 +02:00
2020-05-26 16:52:21 +02:00
func VerifyContext(ctx context.Context) VerifyOption {
2020-05-21 19:11:35 +02:00
return func(o *VerifyOptions) {
2020-05-26 16:52:21 +02:00
o.Context = ctx
}
}
2020-12-12 22:08:39 +02:00
type ListOptions struct {
2020-05-26 16:52:21 +02:00
Context context.Context
}
2020-12-12 22:08:39 +02:00
type ListOption func(o *ListOptions)
2020-05-26 16:52:21 +02:00
2020-12-12 22:08:39 +02:00
func RulesContext(ctx context.Context) ListOption {
return func(o *ListOptions) {
2020-05-26 16:52:21 +02:00
o.Context = ctx
2020-05-21 19:11:35 +02:00
}
}