package auth import ( "github.com/google/uuid" ) func newAuth(opts ...Option) Auth { var options Options for _, o := range opts { o(&options) } return &noop{ opts: options, } } type noop struct { opts Options } // String returns the name of the implementation func (n *noop) String() string { return "noop" } // Init the auth func (n *noop) Init(opts ...Option) { for _, o := range opts { o(&n.opts) } } // Options set for auth func (n *noop) Options() Options { return n.opts } // Generate a new account func (n *noop) Generate(id string, opts ...GenerateOption) (*Account, error) { options := NewGenerateOptions(opts...) return &Account{ ID: id, Secret: options.Secret, Metadata: options.Metadata, Scopes: options.Scopes, Issuer: n.Options().Issuer, }, nil } // Grant access to a resource func (n *noop) Grant(rule *Rule) error { return nil } // Revoke access to a resource func (n *noop) Revoke(rule *Rule) error { return nil } // Rules used to verify requests func (n *noop) Rules(opts ...RulesOption) ([]*Rule, error) { return []*Rule{}, nil } // Verify an account has access to a resource func (n *noop) Verify(acc *Account, res *Resource, opts ...VerifyOption) error { return nil } // Inspect a token func (n *noop) Inspect(token string) (*Account, error) { uid, err := uuid.NewRandom() if err != nil { return nil, err } return &Account{ID: uid.String(), Issuer: n.Options().Issuer}, nil } // Token generation using an account id and secret func (n *noop) Token(opts ...TokenOption) (*Token, error) { return &Token{}, nil }