Documentation ¶
Overview ¶
Package httpopa provides an implementation of the az.Authorizer interface for HTTP-based authorization using OPA (Open Policy Agent).
Index ¶
- Variables
- func NewHttpAuthorizer(application string, opts ...Option) az.Authorizer
- func NewServerAuthzMiddleware(application string, opts ...Option) func(http.Handler) http.Handler
- type AcctEntitlementsApiInput
- type AcctEntitlementsApiResult
- type Config
- type ContextKey
- type CurrentUserCompartmentsResult
- type DefaultModifyConfig
- type EndpointModifier
- type FilterCompartmentFeaturesInput
- type FilterCompartmentFeaturesResult
- type FilterCompartmentPermissionsInput
- type FilterCompartmentPermissionsResult
- type Option
- func WithAcctEntitlementsApiPath(acctEntitlementsApi string) Option
- func WithAddress(address string) Option
- func WithAuthorizer(auther ...az.Authorizer) Option
- func WithClaimsVerifier(claimsVerifier az.ClaimsVerifier) Option
- func WithCurrentUserCompartmentsPath(currUserCompartmentsApi string) Option
- func WithDecisionInputHandler(decisionHandler az.DecisionInputHandler) Option
- func WithEndpointModifier(modifier *EndpointModifier) Option
- func WithEntitledServices(entitledServices ...string) Option
- func WithFilterComparmentFeaturesApiPath(filterCompartmentFeatsApi string) Option
- func WithFilterComparmentPermissionsApiPath(filterCompartmentPermsApi string) Option
- func WithHTTPClient(client *http.Client) Option
- func WithOpaClienter(clienter opa_client.Clienter) Option
- func WithOpaEvaluator(opaEvaluator az.OpaEvaluator) Option
Constants ¶
This section is empty.
Variables ¶
var (
EndPointKey = ContextKey("endpoint")
)
var SERVICENAME = "opa"
SERVICENAME is the name of the OPA service.
Functions ¶
func NewHttpAuthorizer ¶
func NewHttpAuthorizer(application string, opts ...Option) az.Authorizer
NewHttpAuthorizer creates a new instance of httpAuthorizer with the given application name and options.
Types ¶
type AcctEntitlementsApiInput ¶ added in v2.1.0
type AcctEntitlementsApiInput struct { AccountIDs []string `json:"acct_entitlements_acct_ids"` ServiceNames []string `json:"acct_entitlements_services"` }
AcctEntitlementsApiInput is the input payload for acct_entitlements_api
type AcctEntitlementsApiResult ¶ added in v2.1.0
type AcctEntitlementsApiResult struct {
Result *az.AcctEntitlementsType `json:"result"`
}
AcctEntitlementsApiResult is the data type json.Unmarshaled from OPA RESTAPI query to acct_entitlements_api
type Config ¶
type Config struct {
// contains filtered or unexported fields
}
func NewDefaultConfig ¶
NewDefaultConfig returns a new default Config for Http Authorizer.
func (Config) GetAuthorizer ¶
func (c Config) GetAuthorizer() []az.Authorizer
type ContextKey ¶
type ContextKey string
type CurrentUserCompartmentsResult ¶ added in v2.1.0
type CurrentUserCompartmentsResult struct {
Result []string `json:"result"`
}
CurrentUserCompartmentsResult is the data type json.Unmarshaled from OPA RESTAPI query to current_user_compartments rego rule
type DefaultModifyConfig ¶
type EndpointModifier ¶
type EndpointModifier struct { DefaultModifyConfig Modify func(string) string }
type FilterCompartmentFeaturesInput ¶ added in v2.3.0
type FilterCompartmentFeaturesInput struct { JWT string `json:"jwt"` ApplicationFeatures az.FilterCompartmentFeaturesType `json:"application_features"` }
FilterCompartmentFeaturesInput is the input payload for filter_compartment_features_api
type FilterCompartmentFeaturesResult ¶ added in v2.3.0
type FilterCompartmentFeaturesResult struct {
Result az.FilterCompartmentFeaturesType `json:"result"`
}
FilterCompartmentFeaturesResult is the data type json.Unmarshaled from OPA RESTAPI query to filter_compartment_features_api rego rule
type FilterCompartmentPermissionsInput ¶ added in v2.3.0
type FilterCompartmentPermissionsInput struct { JWT string `json:"jwt"` Permissions az.FilterCompartmentPermissionsType `json:"permissions"` }
FilterCompartmentPermissionsInput is the input payload for filter_compartment_permissions_api
type FilterCompartmentPermissionsResult ¶ added in v2.3.0
type FilterCompartmentPermissionsResult struct {
Result az.FilterCompartmentPermissionsType `json:"result"`
}
FilterCompartmentPermissionsResult is the data type json.Unmarshaled from OPA RESTAPI query to filter_compartment_permissions_api rego rule
type Option ¶
type Option func(c *Config)
func WithAcctEntitlementsApiPath ¶
WithAcctEntitlementsApiPath overrides default AcctEntitlementsApiPath
func WithAuthorizer ¶
func WithAuthorizer(auther ...az.Authorizer) Option
WithAuthorizer overrides the request/response processing of OPA. Multiple authorizers can be passed
func WithClaimsVerifier ¶
func WithClaimsVerifier(claimsVerifier az.ClaimsVerifier) Option
WithClaimsVerifier overrides default ClaimsVerifier
func WithCurrentUserCompartmentsPath ¶ added in v2.1.0
WithCurrentUserCompartmentsPath overrides default CurrentUserCompartmentsApiPath
func WithDecisionInputHandler ¶
func WithDecisionInputHandler(decisionHandler az.DecisionInputHandler) Option
WithDecisionInputHandler supplies optional DecisionInputHandler for DefaultAuthorizer to obtain additional input for OPA ABAC decision processing.
func WithEndpointModifier ¶
func WithEndpointModifier(modifier *EndpointModifier) Option
WithAcctSegmentsNeeded overrides default 0
func WithEntitledServices ¶
WithEntitledServices overrides default EntitledServices
func WithFilterComparmentFeaturesApiPath ¶ added in v2.3.0
WithFilterComparmentFeaturesApiPath overrides default CurrentUserCompartmentsApiPath
func WithFilterComparmentPermissionsApiPath ¶ added in v2.3.0
WithFilterComparmentPermissionsApiPath overrides default CurrentUserCompartmentsApiPath
func WithHTTPClient ¶
WithHTTPClient overrides the http.Client used to call Opa
func WithOpaClienter ¶
func WithOpaClienter(clienter opa_client.Clienter) Option
WithOpaClienter overrides the Clienter used to call Opa. This option takes precedence over WithHTTPClient.
func WithOpaEvaluator ¶
func WithOpaEvaluator(opaEvaluator az.OpaEvaluator) Option
WithOpaEvaluator overrides the OpaEvaluator use to evaluate authorization against OPA.