#[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(())
}
}
impl Client {
#[track_caller]
pub fn new(sdk_config: &::aws_types::sdk_config::SdkConfig) -> Self {
Self::from_conf(sdk_config.into())
}
}
mod add_region;
mod attach_customer_managed_policy_reference_to_permission_set;
mod attach_managed_policy_to_permission_set;
mod create_account_assignment;
mod create_application;
mod create_application_assignment;
mod create_instance;
mod create_instance_access_control_attribute_configuration;
mod create_permission_set;
mod create_trusted_token_issuer;
pub mod customize;
mod delete_account_assignment;
mod delete_application;
mod delete_application_access_scope;
mod delete_application_assignment;
mod delete_application_authentication_method;
mod delete_application_grant;
mod delete_inline_policy_from_permission_set;
mod delete_instance;
mod delete_instance_access_control_attribute_configuration;
mod delete_permission_set;
mod delete_permissions_boundary_from_permission_set;
mod delete_trusted_token_issuer;
mod describe_account_assignment_creation_status;
mod describe_account_assignment_deletion_status;
mod describe_application;
mod describe_application_assignment;
mod describe_application_provider;
mod describe_instance;
mod describe_instance_access_control_attribute_configuration;
mod describe_permission_set;
mod describe_permission_set_provisioning_status;
mod describe_region;
mod describe_trusted_token_issuer;
mod detach_customer_managed_policy_reference_from_permission_set;
mod detach_managed_policy_from_permission_set;
mod get_application_access_scope;
mod get_application_assignment_configuration;
mod get_application_authentication_method;
mod get_application_grant;
mod get_application_session_configuration;
mod get_inline_policy_for_permission_set;
mod get_permissions_boundary_for_permission_set;
mod list_account_assignment_creation_status;
mod list_account_assignment_deletion_status;
mod list_account_assignments;
mod list_account_assignments_for_principal;
mod list_accounts_for_provisioned_permission_set;
mod list_application_access_scopes;
mod list_application_assignments;
mod list_application_assignments_for_principal;
mod list_application_authentication_methods;
mod list_application_grants;
mod list_application_providers;
mod list_applications;
mod list_customer_managed_policy_references_in_permission_set;
mod list_instances;
mod list_managed_policies_in_permission_set;
mod list_permission_set_provisioning_status;
mod list_permission_sets;
mod list_permission_sets_provisioned_to_account;
mod list_regions;
mod list_tags_for_resource;
mod list_trusted_token_issuers;
mod provision_permission_set;
mod put_application_access_scope;
mod put_application_assignment_configuration;
mod put_application_authentication_method;
mod put_application_grant;
mod put_application_session_configuration;
mod put_inline_policy_to_permission_set;
mod put_permissions_boundary_to_permission_set;
mod remove_region;
mod tag_resource;
mod untag_resource;
mod update_application;
mod update_instance;
mod update_instance_access_control_attribute_configuration;
mod update_permission_set;
mod update_trusted_token_issuer;