#[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 associate_delegate_to_resource;
mod associate_member_to_group;
mod assume_impersonation_role;
mod cancel_mailbox_export_job;
mod create_alias;
mod create_availability_configuration;
mod create_group;
mod create_identity_center_application;
mod create_impersonation_role;
mod create_mobile_device_access_rule;
mod create_organization;
mod create_resource;
mod create_user;
pub mod customize;
mod delete_access_control_rule;
mod delete_alias;
mod delete_availability_configuration;
mod delete_email_monitoring_configuration;
mod delete_group;
mod delete_identity_center_application;
mod delete_identity_provider_configuration;
mod delete_impersonation_role;
mod delete_mailbox_permissions;
mod delete_mobile_device_access_override;
mod delete_mobile_device_access_rule;
mod delete_organization;
mod delete_personal_access_token;
mod delete_resource;
mod delete_retention_policy;
mod delete_user;
mod deregister_from_work_mail;
mod deregister_mail_domain;
mod describe_email_monitoring_configuration;
mod describe_entity;
mod describe_group;
mod describe_identity_provider_configuration;
mod describe_inbound_dmarc_settings;
mod describe_mailbox_export_job;
mod describe_organization;
mod describe_resource;
mod describe_user;
mod disassociate_delegate_from_resource;
mod disassociate_member_from_group;
mod get_access_control_effect;
mod get_default_retention_policy;
mod get_impersonation_role;
mod get_impersonation_role_effect;
mod get_mail_domain;
mod get_mailbox_details;
mod get_mobile_device_access_effect;
mod get_mobile_device_access_override;
mod get_personal_access_token_metadata;
mod list_access_control_rules;
mod list_aliases;
mod list_availability_configurations;
mod list_group_members;
mod list_groups;
mod list_groups_for_entity;
mod list_impersonation_roles;
mod list_mail_domains;
mod list_mailbox_export_jobs;
mod list_mailbox_permissions;
mod list_mobile_device_access_overrides;
mod list_mobile_device_access_rules;
mod list_organizations;
mod list_personal_access_tokens;
mod list_resource_delegates;
mod list_resources;
mod list_tags_for_resource;
mod list_users;
mod put_access_control_rule;
mod put_email_monitoring_configuration;
mod put_identity_provider_configuration;
mod put_inbound_dmarc_settings;
mod put_mailbox_permissions;
mod put_mobile_device_access_override;
mod put_retention_policy;
mod register_mail_domain;
mod register_to_work_mail;
mod reset_password;
mod start_mailbox_export_job;
mod tag_resource;
mod test_availability_configuration;
mod untag_resource;
mod update_availability_configuration;
mod update_default_mail_domain;
mod update_group;
mod update_impersonation_role;
mod update_mailbox_quota;
mod update_mobile_device_access_rule;
mod update_primary_email_address;
mod update_resource;
mod update_user;