pub trait RuntimePlugin: Debug + Send + Sync {
    // Provided methods
    fn order(&self) -> Order { ... }
    fn config(&self) -> Option<FrozenLayer> { ... }
    fn runtime_components(
        &self,
        current_components: &RuntimeComponentsBuilder
    ) -> Cow<'_, RuntimeComponentsBuilder> { ... }
}
Expand description

Runtime plugin trait

A RuntimePlugin is the unit of configuration for augmenting the client with new behavior.

Runtime plugins can register interceptors, set runtime components, and modify configuration.

Provided Methods§

source

fn order(&self) -> Order

Runtime plugin ordering.

There are two runtime plugin “levels” that run in the following order:

  1. Service runtime plugins - runtime plugins that pertain to the entire service.
  2. Operation runtime plugins - runtime plugins relevant only to a single operation.

This function is used to determine runtime plugin order within those levels. So regardless of this Order value, service runtime plugins will still always execute before operation runtime plugins. However, Defaults service runtime plugins will run before Overrides service runtime plugins.

source

fn config(&self) -> Option<FrozenLayer>

Optionally returns additional config that should be added to the ConfigBag.

As a best practice, a frozen layer should be stored on the runtime plugin instance as a member, and then cloned upon return since that clone is cheap. Constructing a new Layer and freezing it will require a lot of allocations.

source

fn runtime_components( &self, current_components: &RuntimeComponentsBuilder ) -> Cow<'_, RuntimeComponentsBuilder>

Returns a RuntimeComponentsBuilder to incorporate into the final runtime components.

The order of runtime plugins determines which runtime components “win”. Components set by later runtime plugins will override those set by earlier runtime plugins.

If no runtime component changes are desired, just return an empty builder.

This method returns a Cow for flexibility. Some implementers may want to store the components builder as a member and return a reference to it, while others may need to create the builder every call. If possible, returning a reference is preferred for performance.

Components configured by previous runtime plugins are in the current_components argument, and can be used to create nested/wrapped components, such as a connector calling into an inner (customer provided) connector.

Implementations on Foreign Types§

source§

impl RuntimePlugin for NoAuthRuntimePlugin

source§

impl RuntimePlugin for CannedResponseDeserializer

source§

impl RuntimePlugin for CannedRequestSerializer

Implementors§

source§

impl RuntimePlugin for BatchExecuteStatement

source§

impl RuntimePlugin for BatchGetItem

source§

impl RuntimePlugin for BatchWriteItem

source§

impl RuntimePlugin for CreateBackup

source§

impl RuntimePlugin for CreateGlobalTable

source§

impl RuntimePlugin for CreateTable

source§

impl RuntimePlugin for DeleteBackup

source§

impl RuntimePlugin for DeleteItem

source§

impl RuntimePlugin for DeleteTable

source§

impl RuntimePlugin for DescribeBackup

source§

impl RuntimePlugin for DescribeContinuousBackups

source§

impl RuntimePlugin for DescribeContributorInsights

source§

impl RuntimePlugin for DescribeEndpoints

source§

impl RuntimePlugin for DescribeExport

source§

impl RuntimePlugin for DescribeGlobalTable

source§

impl RuntimePlugin for DescribeGlobalTableSettings

source§

impl RuntimePlugin for DescribeImport

source§

impl RuntimePlugin for DescribeKinesisStreamingDestination

source§

impl RuntimePlugin for DescribeLimits

source§

impl RuntimePlugin for DescribeTable

source§

impl RuntimePlugin for DescribeTableReplicaAutoScaling

source§

impl RuntimePlugin for DescribeTimeToLive

source§

impl RuntimePlugin for DisableKinesisStreamingDestination

source§

impl RuntimePlugin for EnableKinesisStreamingDestination

source§

impl RuntimePlugin for ExecuteStatement

source§

impl RuntimePlugin for ExecuteTransaction

source§

impl RuntimePlugin for ExportTableToPointInTime

source§

impl RuntimePlugin for GetItem

source§

impl RuntimePlugin for ImportTable

source§

impl RuntimePlugin for ListBackups

source§

impl RuntimePlugin for ListContributorInsights

source§

impl RuntimePlugin for ListExports

source§

impl RuntimePlugin for ListGlobalTables

source§

impl RuntimePlugin for ListImports

source§

impl RuntimePlugin for ListTables

source§

impl RuntimePlugin for ListTagsOfResource

source§

impl RuntimePlugin for PutItem

source§

impl RuntimePlugin for Query

source§

impl RuntimePlugin for RestoreTableFromBackup

source§

impl RuntimePlugin for RestoreTableToPointInTime

source§

impl RuntimePlugin for Scan

source§

impl RuntimePlugin for TagResource

source§

impl RuntimePlugin for TransactGetItems

source§

impl RuntimePlugin for TransactWriteItems

source§

impl RuntimePlugin for UntagResource

source§

impl RuntimePlugin for UpdateContinuousBackups

source§

impl RuntimePlugin for UpdateContributorInsights

source§

impl RuntimePlugin for UpdateGlobalTable

source§

impl RuntimePlugin for UpdateGlobalTableSettings

source§

impl RuntimePlugin for UpdateItem

source§

impl RuntimePlugin for UpdateKinesisStreamingDestination

source§

impl RuntimePlugin for UpdateTable

source§

impl RuntimePlugin for UpdateTableReplicaAutoScaling

source§

impl RuntimePlugin for UpdateTimeToLive

source§

impl RuntimePlugin for StaticRuntimePlugin

source§

impl RuntimePlugin for SharedRuntimePlugin