grpcz

package module
v0.0.0-...-39e3662 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Dec 19, 2024 License: MIT Imports: 19 Imported by: 0

Documentation

Overview

Package grpc provides authorization middleware for gRPC servers.

The middleware intercepts incoming requests/streams and calls the Aserto authorizer service to determine if access should be granted or denied.

Index

Constants

View Source
const MaxPermissionLen = 64

Variables

This section is empty.

Functions

This section is empty.

Types

type AuthorizerClient

type AuthorizerClient = authz.AuthorizerClient

type CheckClient

type CheckClient interface {
	Check(ctx context.Context, in *ds3.CheckRequest, opts ...grpc.CallOption) (*ds3.CheckResponse, error)
}

type CheckMiddleware

type CheckMiddleware struct {
	// contains filtered or unexported fields
}

func NewCheckMiddleware

func NewCheckMiddleware(client CheckClient, options ...CheckOption) *CheckMiddleware

func (*CheckMiddleware) Stream

Stream returns a grpc.StreamServerInterceptor that authorizes incoming messages.

func (*CheckMiddleware) Unary

Unary returns a grpc.UnaryServiceInterceptor that authorizes incoming messages.

type CheckOption

type CheckOption func(*CheckOptions)

func WithContextValueFilter

func WithContextValueFilter(ctxKey any, values ...string) CheckOption

func WithFilter

func WithFilter(filter Filter) CheckOption

func WithMethodFilter

func WithMethodFilter(methods ...string) CheckOption

func WithObjectID

func WithObjectID(id string) CheckOption

WithObjectID set the id of the object to check.

func WithObjectIDFromContextValue

func WithObjectIDFromContextValue(ctxKey any) CheckOption

WithObjectIDFromContextValue takes the specified context value from the incoming request context and uses it as the object id to check.

func WithObjectIDMapper

func WithObjectIDMapper(mapper StringMapper) CheckOption

WithObjectIDMapper takes a function that is used to determine the object id to check from the incoming request.

func WithObjectMapper

func WithObjectMapper(mapper ObjectMapper) CheckOption

WithObjectMapper takes a function that is used to determine the object type and id to check from the incoming request.

func WithObjectType

func WithObjectType(objType string) CheckOption

WithObjectType sets the object type to check.

func WithRelation

func WithRelation(name string) CheckOption

WithRelation sets the relation/permission to check. If not specified, the relation is determined from the incoming request.

func WithRelationMapper

func WithRelationMapper(mapper StringMapper) CheckOption

WithRelation takes a function that is used to determine the relation/permission to check from the incoming request.

func WithSubjectID

func WithSubjectID(id string) CheckOption

WithSubjectID set the id of the subject to check.

func WithSubjectIDFromContextValue

func WithSubjectIDFromContextValue(ctxKey any) CheckOption

WithSubjectIDFromContextValue takes the specified context value from the incoming request context and uses it as the subject id to check.

func WithSubjectIDMapper

func WithSubjectIDMapper(mapper StringMapper) CheckOption

WithSubjectIDMapper takes a function that is used to determine the subject id to check from the incoming request.

func WithSubjectMapper

func WithSubjectMapper(mapper ObjectMapper) CheckOption

WithSubjectMapper takes a function that is used to determine the subject type and id to check from the incoming request.

func WithSubjectType

func WithSubjectType(subjType string) CheckOption

WithSubjectType sets the subject type to check. Default is "user".

type CheckOptions

type CheckOptions struct {
	// contains filtered or unexported fields
}

CheckOptions is used to configure the check middleware.

type Filter

type Filter func(ctx context.Context, req any) bool

type IdentityBuilder

type IdentityBuilder struct {
	// contains filtered or unexported fields
}

IdentityBuilder is used to configure what information about caller identity is sent in authorization calls.

func (*IdentityBuilder) FromContextValue

func (b *IdentityBuilder) FromContextValue(key interface{}) *IdentityBuilder

WithIdentityFromContextValue extracts caller identity from a context value in the incoming message.

func (*IdentityBuilder) FromMetadata

func (b *IdentityBuilder) FromMetadata(field string) *IdentityBuilder

FromMetadata extracts caller identity from a grpc/metadata field in the incoming message.

func (*IdentityBuilder) ID

func (b *IdentityBuilder) ID(identity string) *IdentityBuilder

Call ID(...) to set the user's identity. If neither JWT() or Subject() are called too, IdentityMapper tries to infer whether the specified identity is a JWT or not. Passing an empty string is the same as calling .None() and results in an authorization check for anonymous access.

func (*IdentityBuilder) JWT

func (b *IdentityBuilder) JWT() *IdentityBuilder

Call JWT() to indicate that the user's identity is expressed as a string-encoded JWT.

JWT() is always called in conjunction with another method that provides the user ID itself. For example:

idBuilder.JWT().FromHeader("Authorization")

func (*IdentityBuilder) Manual

func (b *IdentityBuilder) Manual() *IdentityBuilder

Call Manual() to indicate that the user's identity is set manually and isn't resolved to a user by the authorizer.

Manually set identities are available in the authorizer's policy language through the "input.identity" variable.

func (*IdentityBuilder) Mapper

func (b *IdentityBuilder) Mapper(mapper IdentityMapper) *IdentityBuilder

Mapper takes a custom IdentityMapper to be used for extracting identity information from incoming RPCs.

func (*IdentityBuilder) None

func (b *IdentityBuilder) None() *IdentityBuilder

Call None() to indicate that requests are unauthenticated.

func (*IdentityBuilder) Subject

func (b *IdentityBuilder) Subject() *IdentityBuilder

Call Subject() to indicate that the user's identity is a subject name (email, userid, etc.).

Subject() is always used in conjunction with another method that provides the user ID itself. For example:

idBuilder.Subject().FromContextValue("username")

type IdentityMapper

type IdentityMapper func(context.Context, interface{}, middleware.Identity)

IdentityMapper is the type of callback functions that can inspect incoming RPCs and set the caller's identity.

type Middleware

type Middleware struct {
	// Identity determines the caller identity used in authorization calls.
	Identity *IdentityBuilder
	// contains filtered or unexported fields
}

Middleware implements unary and stream server interceptors that can be attached to gRPC servers.

To authorize incoming RPC calls, the middleware needs information about:

1. The user making the request.

2. The Aserto authorization policy to evaluate.

3. Optional, additional input data to the authorization policy.

The values for these parameters can be set globally or extracted dynamically from incoming messages.

func New

func New(authzClient AuthorizerClient, policy *Policy) *Middleware

New creates middleware for the specified policy.

The new middleware is created with default identity and policy path mapper. Those can be overridden using `Middleware.Identity` to specify the caller's identity, or using the middleware's ".With...()" functions to set policy path and resource mappers.

func (*Middleware) Stream

Stream returns a grpc.StreamServerInterceptor that authorizes incoming messages.

func (*Middleware) Unary

Unary returns a grpc.UnaryServiceInterceptor that authorizes incoming messages.

func (*Middleware) WithAllowedMethods

func (m *Middleware) WithAllowedMethods(methods ...string) *Middleware

WithAllowedMethods takes a list of gRPC methods that are allowed to proceed without authorization. Method paths are in the format "/package.Service/Method". For example: "/grpc.reflection.v1.ServerReflection/ServerReflectionInfo".

func (*Middleware) WithIgnoredMethods deprecated

func (m *Middleware) WithIgnoredMethods(paths []string) *Middleware

Deprecated: Use WithAllowedMethods instead. WithIgnoredMethods takes as its input a list of policy paths in Rego dot notation (e.g. "myservice.GET.user.__id") that are ignored by the middleware. Requests that would normally evaluate one of these paths will be allowed to proceed without authorization.

func (*Middleware) WithPolicyPathMapper

func (m *Middleware) WithPolicyPathMapper(mapper StringMapper) *Middleware

WithPolicyPathMapper takes a custom StringMapper for extracting the authorization policy path form incoming message.

func (*Middleware) WithResourceFromContextValue

func (m *Middleware) WithResourceFromContextValue(ctxKey interface{}, field string) *Middleware

WithResourceFromContextValue instructs the middleware to read the specified value from the incoming request context and add it to the authorization resource context.

Example:

middleware.WithResourceFromContextValue("account_id", "account")

In each incoming request, the middleware reads the value of the "account_id" key from the request context and adds its value to the "account" field in the authorization resource context.

func (*Middleware) WithResourceFromFields

func (m *Middleware) WithResourceFromFields(fields ...string) *Middleware

WithResourceFromFields instructs the middleware to select the specified fields from incoming messages and use them as the resource in authorization calls. Fields are expressed as a field mask.

Note: Protobuf message fields are identified using their JSON names.

Example:

middleware.WithResourceFromFields("product.type", "address")

This call would result in an authorization resource with the following structure:

  {
	  "product": {
		  "type": <value from message>
	  },
	  "address": <value from message>
  }

If the value of "address" is itself a message, all of its fields are included.

func (*Middleware) WithResourceFromMessageByPath

func (m *Middleware) WithResourceFromMessageByPath(fieldsByPath map[string][]string, defaults ...string) *Middleware

WithResourceFromMessageByPath behaves similarly to `WithResourceFromFields` but allows specifying different sets of fields for different method paths.

Example:

  middleware.WithResourceFromMessageByPath(
	  "/example.ExampleService/Method1": []string{"field1", "field2"},
	  "/example.ExampleService/Method2": []string{"field1", "field2"},
	  "id", "name",
  )

When Method1 or Method2 are called, the middleware constructs in a authorization resource with the following structure:

  {
	  "field1": <value from message>,
	  "field2": <value from message>
  }

For all other methods, the middleware constructs in a authorization resource with the following structure:

  {
	  "id": <value from message>,
	  "name": <value from message>
  }

func (*Middleware) WithResourceMapper

func (m *Middleware) WithResourceMapper(mapper ResourceMapper) *Middleware

WithResourceMapper takes a custom StructMapper for extracting the authorization resource context from incoming messages.

type ObjectMapper

type ObjectMapper func(ctx context.Context, req any) (objType, id string)

type Policy

type Policy = middleware.Policy

type RebacMiddleware

type RebacMiddleware struct {
	Identity *IdentityBuilder
	// contains filtered or unexported fields
}

func NewRebacMiddleware

func NewRebacMiddleware(authzClient AuthorizerClient, policy *Policy) *RebacMiddleware

func (*RebacMiddleware) Stream

Stream returns a grpc.StreamServerInterceptor that authorizes incoming messages.

func (*RebacMiddleware) Unary

Unary returns a grpc.UnaryServiceInterceptor that authorizes incoming messages.

func (*RebacMiddleware) WithAllowedMethods

func (c *RebacMiddleware) WithAllowedMethods(methods ...string) *RebacMiddleware

WithAllowedMethods takes a list of gRPC methods that are allowed to proceed without authorization. Method paths are in the format "/package.Service/Method". For example: "/grpc.reflection.v1.ServerReflection/ServerReflectionInfo".

func (*RebacMiddleware) WithIgnoredMethods deprecated

func (c *RebacMiddleware) WithIgnoredMethods(methods []string) *RebacMiddleware

Deprecated: Use WithAllowedMethods instead. WithIgnoredMethods takes as its input a list of policy paths in Rego dot notation (e.g. "myservice.GET.user.__id") that are ignored by the middleware. Requests that would normally evaluate one of these paths will be allowed to proceed without authorization.

func (*RebacMiddleware) WithObjectType

func (c *RebacMiddleware) WithObjectType(value string) *RebacMiddleware

WithObjectType instructs the middleware to read the specified value for the object type in the resource context.

Example:

checkMiddleware.WithSubjectType("tenant")

func (*RebacMiddleware) WithResourceFromContextValue

func (c *RebacMiddleware) WithResourceFromContextValue(ctxKey interface{}, field string) *RebacMiddleware

WithResourceFromContextValue instructs the middleware to read the specified value from the incoming request context and add it to the authorization resource context.

Example:

checkMiddleware.WithResourceFromContextValue("account_id", "account")

In each incoming request, the middleware reads the value of the "account_id" key from the request context and adds its value to the "account" field in the authorization resource context.

func (*RebacMiddleware) WithSubjectType

func (c *RebacMiddleware) WithSubjectType(value string) *RebacMiddleware

WithSubjectType instructs the middleware to read the specified value for the subject type in the resource context.

Example:

checkMiddleware.WithSubjectType("user")

type ResourceMapper

type ResourceMapper func(context.Context, interface{}, map[string]interface{})

ResourceMapper functions are used to extract structured data from incoming message.

type StringMapper

type StringMapper func(context.Context, interface{}) string

StringMapper functions are used to extract string values from incoming messages. They are used to define identity and policy mappers.

Directories

Path Synopsis
internal

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL