Documentation ¶
Overview ¶
Package customizations provides customizations for the Amazon S3-Control API client.
This package provides support for following S3-Control customizations
BackfillInput Middleware: validates and backfills data from an ARN resource into a copy of operation input. ProcessOutpostID Middleware: applied on CreateBucket, ListRegionalBuckets operation, triggers a custom endpoint generation flow. ProcessARN Middleware: processes an ARN if provided as input and updates the endpoint as per the arn type. UpdateEndpoint Middleware: resolves a custom endpoint as per s3-control config options.
Dualstack support ¶
By default dualstack support for s3-control client is disabled. By enabling `UseDualstack` option on s3-control client, you can enable dualstack endpoint support.
Endpoint customizations ¶
Customizations to lookup ARN, backfill input, process outpost id, process ARN needs to happen before request serialization. UpdateEndpoint middleware which mutates resources based on Options such as UseDualstack for modifying resolved endpoint are executed after request serialization.
Middleware layering: Initialize : HTTP Request -> ARN Lookup -> BackfillInput -> Input-Validation -> Serialize step Serialize : HTTP Request -> Process-OutpostID -> Process ARN -> operation serializer -> Update-Endpoint customization -> next middleware
Customization option:
UseARNRegion (Disabled by Default) UseDualstack (Disabled by Default)
Index ¶
- func AddDisableHostPrefixMiddleware(s *middleware.Stack) error
- func AddUpdateOutpostARN(stack *middleware.Stack) error
- func UpdateEndpoint(stack *middleware.Stack, options UpdateEndpointOptions) (err error)
- type BackfillInput
- type DisableHostPrefixMiddleware
- type EndpointResolver
- type EndpointResolverOptions
- type UpdateEndpointOptions
- type UpdateEndpointParameterAccessor
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func AddDisableHostPrefixMiddleware ¶
func AddDisableHostPrefixMiddleware(s *middleware.Stack) error
AddDisableHostPrefixMiddleware adds the middleware to the stack.
func AddUpdateOutpostARN ¶
func AddUpdateOutpostARN(stack *middleware.Stack) error
AddUpdateOutpostARN is used by operation runtimes to add this middleware to their middleware stack.
func UpdateEndpoint ¶
func UpdateEndpoint(stack *middleware.Stack, options UpdateEndpointOptions) (err error)
UpdateEndpoint adds the middleware to the middleware stack based on the UpdateEndpointOptions.
Types ¶
type BackfillInput ¶
type BackfillInput struct { // CopyInput creates a copy of input to be modified, this ensures the original input is not modified. CopyInput func(interface{}) (interface{}, error) // BackfillAccountID points to a function that validates the input for accountID. If absent, it populates the // accountID and returns a copy. If present, but different than passed in accountID value throws an error BackfillAccountID func(interface{}, string) error }
BackfillInput validates and backfill's values from ARN into request serializable input. This middleware must be executed after `ARNLookup` and before `inputValidationMiddleware`.
func (*BackfillInput) HandleInitialize ¶
func (m *BackfillInput) HandleInitialize(ctx context.Context, in middleware.InitializeInput, next middleware.InitializeHandler) ( out middleware.InitializeOutput, metadata middleware.Metadata, err error, )
HandleInitialize handles the middleware behavior in an Initialize step.
type DisableHostPrefixMiddleware ¶
type DisableHostPrefixMiddleware struct{}
DisableHostPrefixMiddleware disables host prefix serialization when v2 endpoint resolution was used.
func (*DisableHostPrefixMiddleware) HandleFinalize ¶
func (m *DisableHostPrefixMiddleware) HandleFinalize(ctx context.Context, in middleware.FinalizeInput, next middleware.FinalizeHandler) ( out middleware.FinalizeOutput, md middleware.Metadata, err error, )
HandleFinalize controls whether to serialize modeled host prefixes based on the type of endpoint resolution used.
func (*DisableHostPrefixMiddleware) ID ¶
func (*DisableHostPrefixMiddleware) ID() string
ID identifies the middleware.
type EndpointResolver ¶
type EndpointResolver interface {
ResolveEndpoint(region string, options EndpointResolverOptions) (aws.Endpoint, error)
}
EndpointResolver interface for resolving service endpoints.
type EndpointResolverOptions ¶
type EndpointResolverOptions = internalendpoints.Options
EndpointResolverOptions is the service endpoint resolver options
type UpdateEndpointOptions ¶
type UpdateEndpointOptions struct { // Accessor are parameter accessors used by the middleware Accessor UpdateEndpointParameterAccessor // UseARNRegion indicates if region parsed from an ARN should be used. UseARNRegion bool // EndpointResolver used to resolve endpoints. This may be a custom endpoint resolver EndpointResolver EndpointResolver // EndpointResolverOptions used by endpoint resolver EndpointResolverOptions EndpointResolverOptions }
UpdateEndpointOptions provides the options for the UpdateEndpoint middleware setup.
type UpdateEndpointParameterAccessor ¶
type UpdateEndpointParameterAccessor struct { // GetARNInput points to a function that processes an input and returns ARN as string ptr, // and bool indicating if ARN is supported or set. GetARNInput func(interface{}) (*string, bool) // GetOutpostIDInput points to a function that processes an input and returns a outpostID as string ptr, // and bool indicating if outpostID is supported or set. GetOutpostIDInput func(interface{}) (*string, bool) // CopyInput creates a copy of input to be modified, this ensures the original input is not modified. CopyInput func(interface{}) (interface{}, error) // BackfillAccountID points to a function that validates the input for accountID. If absent, it populates the // accountID. If present, but different than passed in accountID value throws an error BackfillAccountID func(interface{}, string) error // UpdateARNField points to a function that takes in a copy of input, updates the ARN field with // the provided value and returns any error UpdateARNField func(interface{}, string) error }
UpdateEndpointParameterAccessor represents accessor functions used by the middleware