#[derive(Debug)]
pub(crate) struct Handle {
pub(crate) conf: crate::Config,
#[allow(dead_code)] pub(crate) runtime_plugins: ::aws_smithy_runtime_api::client::runtime_plugin::RuntimePlugins,
}
#[derive(::std::clone::Clone, ::std::fmt::Debug)]
pub struct Client {
handle: ::std::sync::Arc<Handle>,
}
impl Client {
#[track_caller]
pub fn from_conf(conf: crate::Config) -> Self {
let handle = Handle {
conf: conf.clone(),
runtime_plugins: crate::config::base_client_runtime_plugins(conf),
};
if let Err(err) = Self::validate_config(&handle) {
panic!("Invalid client configuration: {err}");
}
Self {
handle: ::std::sync::Arc::new(handle),
}
}
pub fn config(&self) -> &crate::Config {
&self.handle.conf
}
fn validate_config(handle: &Handle) -> ::std::result::Result<(), ::aws_smithy_runtime_api::box_error::BoxError> {
let mut cfg = ::aws_smithy_types::config_bag::ConfigBag::base();
handle
.runtime_plugins
.apply_client_configuration(&mut cfg)?
.validate_base_client_config(&cfg)?;
Ok(())
}
}
pub trait Waiters {
fn wait_until_cache_cluster_available(&self) -> crate::waiters::cache_cluster_available::CacheClusterAvailableFluentBuilder;
fn wait_until_cache_cluster_deleted(&self) -> crate::waiters::cache_cluster_deleted::CacheClusterDeletedFluentBuilder;
fn wait_until_replication_group_available(&self) -> crate::waiters::replication_group_available::ReplicationGroupAvailableFluentBuilder;
fn wait_until_replication_group_deleted(&self) -> crate::waiters::replication_group_deleted::ReplicationGroupDeletedFluentBuilder;
}
impl Waiters for Client {
fn wait_until_cache_cluster_available(&self) -> crate::waiters::cache_cluster_available::CacheClusterAvailableFluentBuilder {
crate::waiters::cache_cluster_available::CacheClusterAvailableFluentBuilder::new(self.handle.clone())
}
fn wait_until_cache_cluster_deleted(&self) -> crate::waiters::cache_cluster_deleted::CacheClusterDeletedFluentBuilder {
crate::waiters::cache_cluster_deleted::CacheClusterDeletedFluentBuilder::new(self.handle.clone())
}
fn wait_until_replication_group_available(&self) -> crate::waiters::replication_group_available::ReplicationGroupAvailableFluentBuilder {
crate::waiters::replication_group_available::ReplicationGroupAvailableFluentBuilder::new(self.handle.clone())
}
fn wait_until_replication_group_deleted(&self) -> crate::waiters::replication_group_deleted::ReplicationGroupDeletedFluentBuilder {
crate::waiters::replication_group_deleted::ReplicationGroupDeletedFluentBuilder::new(self.handle.clone())
}
}
impl Client {
#[track_caller]
pub fn new(sdk_config: &::aws_types::sdk_config::SdkConfig) -> Self {
Self::from_conf(sdk_config.into())
}
}
mod add_tags_to_resource;
mod authorize_cache_security_group_ingress;
mod batch_apply_update_action;
mod batch_stop_update_action;
mod complete_migration;
mod copy_serverless_cache_snapshot;
mod copy_snapshot;
mod create_cache_cluster;
mod create_cache_parameter_group;
mod create_cache_security_group;
mod create_cache_subnet_group;
mod create_global_replication_group;
mod create_replication_group;
mod create_serverless_cache;
mod create_serverless_cache_snapshot;
mod create_snapshot;
mod create_user;
mod create_user_group;
pub mod customize;
mod decrease_node_groups_in_global_replication_group;
mod decrease_replica_count;
mod delete_cache_cluster;
mod delete_cache_parameter_group;
mod delete_cache_security_group;
mod delete_cache_subnet_group;
mod delete_global_replication_group;
mod delete_replication_group;
mod delete_serverless_cache;
mod delete_serverless_cache_snapshot;
mod delete_snapshot;
mod delete_user;
mod delete_user_group;
mod describe_cache_clusters;
mod describe_cache_engine_versions;
mod describe_cache_parameter_groups;
mod describe_cache_parameters;
mod describe_cache_security_groups;
mod describe_cache_subnet_groups;
mod describe_engine_default_parameters;
mod describe_events;
mod describe_global_replication_groups;
mod describe_replication_groups;
mod describe_reserved_cache_nodes;
mod describe_reserved_cache_nodes_offerings;
mod describe_serverless_cache_snapshots;
mod describe_serverless_caches;
mod describe_service_updates;
mod describe_snapshots;
mod describe_update_actions;
mod describe_user_groups;
mod describe_users;
mod disassociate_global_replication_group;
mod export_serverless_cache_snapshot;
mod failover_global_replication_group;
mod increase_node_groups_in_global_replication_group;
mod increase_replica_count;
mod list_allowed_node_type_modifications;
mod list_tags_for_resource;
mod modify_cache_cluster;
mod modify_cache_parameter_group;
mod modify_cache_subnet_group;
mod modify_global_replication_group;
mod modify_replication_group;
mod modify_replication_group_shard_configuration;
mod modify_serverless_cache;
mod modify_user;
mod modify_user_group;
mod purchase_reserved_cache_nodes_offering;
mod rebalance_slots_in_global_replication_group;
mod reboot_cache_cluster;
mod remove_tags_from_resource;
mod reset_cache_parameter_group;
mod revoke_cache_security_group_ingress;
mod start_migration;
mod test_failover;
mod test_migration;