#[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_firewall_rule_group;
mod associate_resolver_endpoint_ip_address;
mod associate_resolver_query_log_config;
mod associate_resolver_rule;
mod batch_create_firewall_rule;
mod batch_delete_firewall_rule;
mod batch_update_firewall_rule;
mod create_firewall_domain_list;
mod create_firewall_rule;
mod create_firewall_rule_group;
mod create_outpost_resolver;
mod create_resolver_endpoint;
mod create_resolver_query_log_config;
mod create_resolver_rule;
pub mod customize;
mod delete_firewall_domain_list;
mod delete_firewall_rule;
mod delete_firewall_rule_group;
mod delete_outpost_resolver;
mod delete_resolver_endpoint;
mod delete_resolver_query_log_config;
mod delete_resolver_rule;
mod disassociate_firewall_rule_group;
mod disassociate_resolver_endpoint_ip_address;
mod disassociate_resolver_query_log_config;
mod disassociate_resolver_rule;
mod get_firewall_config;
mod get_firewall_domain_list;
mod get_firewall_rule_group;
mod get_firewall_rule_group_association;
mod get_firewall_rule_group_policy;
mod get_outpost_resolver;
mod get_resolver_config;
mod get_resolver_dnssec_config;
mod get_resolver_endpoint;
mod get_resolver_query_log_config;
mod get_resolver_query_log_config_association;
mod get_resolver_query_log_config_policy;
mod get_resolver_rule;
mod get_resolver_rule_association;
mod get_resolver_rule_policy;
mod import_firewall_domains;
mod list_firewall_configs;
mod list_firewall_domain_lists;
mod list_firewall_domains;
mod list_firewall_rule_group_associations;
mod list_firewall_rule_groups;
mod list_firewall_rule_types;
mod list_firewall_rules;
mod list_outpost_resolvers;
mod list_resolver_configs;
mod list_resolver_dnssec_configs;
mod list_resolver_endpoint_ip_addresses;
mod list_resolver_endpoints;
mod list_resolver_query_log_config_associations;
mod list_resolver_query_log_configs;
mod list_resolver_rule_associations;
mod list_resolver_rules;
mod list_tags_for_resource;
mod put_firewall_rule_group_policy;
mod put_resolver_query_log_config_policy;
mod put_resolver_rule_policy;
mod tag_resource;
mod untag_resource;
mod update_firewall_config;
mod update_firewall_domains;
mod update_firewall_rule;
mod update_firewall_rule_group_association;
mod update_outpost_resolver;
mod update_resolver_config;
mod update_resolver_dnssec_config;
mod update_resolver_endpoint;
mod update_resolver_rule;