#[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_policy_preview_configuration_active(
&self,
) -> crate::waiters::policy_preview_configuration_active::PolicyPreviewConfigurationActiveFluentBuilder;
fn wait_until_policy_preview_job_completed(&self) -> crate::waiters::policy_preview_job_completed::PolicyPreviewJobCompletedFluentBuilder;
}
impl Waiters for Client {
fn wait_until_policy_preview_configuration_active(
&self,
) -> crate::waiters::policy_preview_configuration_active::PolicyPreviewConfigurationActiveFluentBuilder {
crate::waiters::policy_preview_configuration_active::PolicyPreviewConfigurationActiveFluentBuilder::new(self.handle.clone())
}
fn wait_until_policy_preview_job_completed(&self) -> crate::waiters::policy_preview_job_completed::PolicyPreviewJobCompletedFluentBuilder {
crate::waiters::policy_preview_job_completed::PolicyPreviewJobCompletedFluentBuilder::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 apply_archive_rule;
mod cancel_policy_generation;
mod cancel_policy_preview_job;
mod check_access_not_granted;
mod check_no_new_access;
mod check_no_public_access;
mod create_access_preview;
mod create_analyzer;
mod create_archive_rule;
mod create_policy_preview_configuration;
pub mod customize;
mod delete_analyzer;
mod delete_archive_rule;
mod delete_policy_preview_configuration;
mod generate_finding_recommendation;
mod get_access_preview;
mod get_analyzed_resource;
mod get_analyzer;
mod get_archive_rule;
mod get_finding;
mod get_finding_recommendation;
mod get_finding_v2;
mod get_findings_statistics;
mod get_generated_policy;
mod get_policy_preview_configuration;
mod get_policy_preview_job;
mod list_access_preview_findings;
mod list_access_previews;
mod list_analyzed_resources;
mod list_analyzers;
mod list_archive_rules;
mod list_findings;
mod list_findings_v2;
mod list_policy_generations;
mod list_policy_preview_jobs;
mod list_tags_for_resource;
mod start_policy_generation;
mod start_policy_preview_job;
mod start_resource_scan;
mod tag_resource;
mod untag_resource;
mod update_analyzer;
mod update_archive_rule;
mod update_findings;
mod validate_policy;