#[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 accept_network_firewall_transit_gateway_attachment;
mod associate_availability_zones;
mod associate_firewall_policy;
mod associate_subnets;
mod attach_rule_groups_to_proxy_configuration;
mod create_firewall;
mod create_firewall_policy;
mod create_proxy;
mod create_proxy_configuration;
mod create_proxy_rule_group;
mod create_proxy_rules;
mod create_rule_group;
mod create_tls_inspection_configuration;
mod create_vpc_endpoint_association;
pub mod customize;
mod delete_firewall;
mod delete_firewall_policy;
mod delete_network_firewall_transit_gateway_attachment;
mod delete_proxy;
mod delete_proxy_configuration;
mod delete_proxy_rule_group;
mod delete_proxy_rules;
mod delete_resource_policy;
mod delete_rule_group;
mod delete_tls_inspection_configuration;
mod delete_vpc_endpoint_association;
mod describe_firewall;
mod describe_firewall_metadata;
mod describe_firewall_policy;
mod describe_flow_operation;
mod describe_logging_configuration;
mod describe_proxy;
mod describe_proxy_configuration;
mod describe_proxy_rule;
mod describe_proxy_rule_group;
mod describe_resource_policy;
mod describe_rule_group;
mod describe_rule_group_metadata;
mod describe_rule_group_summary;
mod describe_tls_inspection_configuration;
mod describe_vpc_endpoint_association;
mod detach_rule_groups_from_proxy_configuration;
mod disassociate_availability_zones;
mod disassociate_subnets;
mod get_analysis_report_results;
mod list_analysis_reports;
mod list_firewall_policies;
mod list_firewalls;
mod list_flow_operation_results;
mod list_flow_operations;
mod list_proxies;
mod list_proxy_configurations;
mod list_proxy_rule_groups;
mod list_rule_groups;
mod list_tags_for_resource;
mod list_tls_inspection_configurations;
mod list_vpc_endpoint_associations;
mod put_resource_policy;
mod reject_network_firewall_transit_gateway_attachment;
mod start_analysis_report;
mod start_flow_capture;
mod start_flow_flush;
mod tag_resource;
mod untag_resource;
mod update_availability_zone_change_protection;
mod update_firewall_analysis_settings;
mod update_firewall_delete_protection;
mod update_firewall_description;
mod update_firewall_encryption_configuration;
mod update_firewall_policy;
mod update_firewall_policy_change_protection;
mod update_logging_configuration;
mod update_proxy;
mod update_proxy_configuration;
mod update_proxy_rule;
mod update_proxy_rule_group_priorities;
mod update_proxy_rule_priorities;
mod update_rule_group;
mod update_subnet_change_protection;
mod update_tls_inspection_configuration;