kessel

package
v0.0.0-...-feb181f Latest Latest
Warning

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

Go to latest
Published: Dec 13, 2024 License: Apache-2.0 Imports: 22 Imported by: 0

README

Authorizer Using the Kessel Relations API

Configure the impl as Kessel

authz:
  impl: kessel
  kessel:
    insecure-client: true
    url: localhost:9000
    enable-oidc-auth: true
    sa-client-id: "svc-test"
    sa-client-secret: "<secret>"
    sso-token-endpoint: "http://localhost:8084/realms/redhat-external/protocol/openid-connect/token"

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

func IsJWTTokenExpired

func IsJWTTokenExpired(accessToken string) (bool, time.Time)

func NewTokenClient

func NewTokenClient(config *tokenClientConfig) *tokenClient

NewTokenClient creates and returns a new tokenClient client.

func WithBearerToken

func WithBearerToken(token string) grpc.CallOption

WithBearerToken returns a grpc.CallOption that adds a standard HTTP Bearer token to all requests sent from a client.

func WithInsecureBearerToken

func WithInsecureBearerToken(token string) grpc.CallOption

WithInsecureBearerToken returns a grpc.CallOption that adds a standard HTTP Bearer token to all requests sent from an insecure client.

Must be used in conjunction with `insecure.NewCredentials()`.

Types

type CompletedConfig

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

type Config

type Config struct {
	*Options
}

func NewConfig

func NewConfig(o *Options) *Config

func (*Config) Complete

func (c *Config) Complete(ctx context.Context) (CompletedConfig, []error)

type KesselAuthz

type KesselAuthz struct {
	HealthService kesselv1.KesselRelationsHealthServiceClient
	CheckService  kessel.KesselCheckServiceClient
	TupleService  kessel.KesselTupleServiceClient

	Logger *log.Helper
	// contains filtered or unexported fields
}

func New

func New(ctx context.Context, config CompletedConfig, logger *log.Helper) (*KesselAuthz, error)

func (*KesselAuthz) Check

func (*KesselAuthz) CreateTuples

func (*KesselAuthz) DeleteTuples

func (*KesselAuthz) Health

func (*KesselAuthz) SetWorkspace

func (a *KesselAuthz) SetWorkspace(ctx context.Context, local_resource_id, workspace, namespace, name string) (*kessel.CreateTuplesResponse, error)

type Options

type Options struct {
	URL            string `mapstructure:"url"`
	Insecure       bool   `mapstructure:"insecure-client"`
	EnableOidcAuth bool   `mapstructure:"enable-oidc-auth"`
	ClientId       string `mapstructure:"sa-client-id"`
	ClientSecret   string `mapstructure:"sa-client-secret"`
	TokenEndpoint  string `mapstructure:"sso-token-endpoint"`
}

TODO: presumably more will go here to authenticate Common Inventory as a service to call Kessel.

func NewOptions

func NewOptions() *Options

func (*Options) AddFlags

func (o *Options) AddFlags(fs *pflag.FlagSet, prefix string)

func (*Options) Complete

func (o *Options) Complete() []error

func (*Options) Validate

func (o *Options) Validate() []error

type TokenResponse

type TokenResponse struct {
	AccessToken  string `json:"access_token"`
	ExpiresIn    int    `json:"expires_in"`
	RefreshToken string `json:"refresh_token"`
}

Jump to

Keyboard shortcuts

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