 Documentation
      ¶
      Documentation
      ¶
    
    
  
    
  
    Overview ¶
Package stdcrpcaccess implements access control for our RPC.
Index ¶
- func FixedKeyServer() *httptest.Server
- func PermissionsFromContext(ctx context.Context) []string
- func RoleFromContext(ctx context.Context) string
- func SignToken(tok openid.Token) (string, error)
- func WithFixedAuthBackend() fx.Option
- func WithProcedurePermissions(ctx context.Context, procs []string) context.Context
- func WithRole(ctx context.Context, role string) context.Context
- func WithSignedToken(base connect.HTTPClient, createToken func(r *http.Request) openid.Token) connect.HTTPClient
- type AccessControl
- type AuthBackend
- type FixedAuthBackend
- type PermissionToProcedure
- type RealAuthBackend
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func FixedKeyServer ¶ added in v0.0.83
FixedKeyServer starts a server for testing that serves the key set.
func PermissionsFromContext ¶
PermissionsFromContext returns permissions from the context.
func RoleFromContext ¶ added in v0.0.92
RoleFromContext returns permissions from the context.
func SignToken ¶ added in v0.0.83
SignToken signs a valid JWT against a well-known private key for testing.
func WithFixedAuthBackend ¶ added in v0.0.83
WithFixedAuthBackend injects dependencies for allowing tests to sign and validate access tokens.
func WithProcedurePermissions ¶
WithProcedurePermissions returns a context with permission strings.
func WithSignedToken ¶ added in v0.0.83
func WithSignedToken(base connect.HTTPClient, createToken func(r *http.Request) openid.Token) connect.HTTPClient
WithSignedToken is a http client middleware that always adds a valid (self signed) token for testing.
Types ¶
type AccessControl ¶
type AccessControl struct {
	// contains filtered or unexported fields
}
    AccessControl implements a simple access control scheme.
func New ¶
func New(jwkEndpoint string, permMapFn PermissionToProcedure) *AccessControl
New inits the access control.
type AuthBackend ¶
type AuthBackend interface {
	JWKSEndpoint() string
}
    AuthBackend represents what is required of an auth backend.
type FixedAuthBackend ¶ added in v0.0.83
type FixedAuthBackend struct {
	// contains filtered or unexported fields
}
    FixedAuthBackend is an auth backend that is run locally and we control the signing process for.
func (FixedAuthBackend) JWKSEndpoint ¶ added in v0.0.83
func (ap FixedAuthBackend) JWKSEndpoint() string
type PermissionToProcedure ¶
PermissionToProcedure is used for an authorization scheme were some permission string is compared to a procedure name.
type RealAuthBackend ¶
type RealAuthBackend string
RealAuthBackend is used when actually deploying.
func (RealAuthBackend) JWKSEndpoint ¶
func (ap RealAuthBackend) JWKSEndpoint() string