#[non_exhaustive]pub struct AWSAuthConfigKeys {
pub access_key_id: String,
pub secret_access_key: Option<String>,
pub additional_properties: BTreeMap<String, Value>,
/* private fields */
}
Expand description
AWS Authentication config to integrate your account using an access key pair.
Fields (Non-exhaustive)§
This struct is marked as non-exhaustive
Non-exhaustive structs could have additional fields added in future. Therefore, non-exhaustive structs cannot be constructed in external crates using the traditional
Struct { .. }
syntax; cannot be matched against without a wildcard ..
; and struct update syntax will not work.access_key_id: String
AWS Access Key ID.
secret_access_key: Option<String>
AWS Secret Access Key.
additional_properties: BTreeMap<String, Value>
Implementations§
Source§impl AWSAuthConfigKeys
impl AWSAuthConfigKeys
Sourcepub fn new(access_key_id: String) -> AWSAuthConfigKeys
pub fn new(access_key_id: String) -> AWSAuthConfigKeys
Examples found in repository?
examples/v2_aws-integration_CreateAWSAccount.rs (line 23)
19async fn main() {
20 let body = AWSAccountCreateRequest::new(AWSAccountCreateRequestData::new(
21 AWSAccountCreateRequestAttributes::new(
22 AWSAuthConfig::AWSAuthConfigKeys(Box::new(
23 AWSAuthConfigKeys::new("AKIAIOSFODNN7EXAMPLE".to_string())
24 .secret_access_key("wJalrXUtnFEMI/K7MDENG/bPxRfiCYEXAMPLEKEY".to_string()),
25 )),
26 "123456789012".to_string(),
27 AWSAccountPartition::AWS,
28 )
29 .account_tags(Some(vec!["key:value".to_string()]))
30 .logs_config(
31 AWSLogsConfig::new().lambda_forwarder(
32 AWSLambdaForwarderConfig::new()
33 .lambdas(vec![
34 "arn:aws:lambda:us-east-1:123456789012:function:DatadogLambdaLogForwarder"
35 .to_string(),
36 ])
37 .sources(vec!["s3".to_string()]),
38 ),
39 )
40 .metrics_config(
41 AWSMetricsConfig::new()
42 .automute_enabled(true)
43 .collect_cloudwatch_alarms(true)
44 .collect_custom_metrics(true)
45 .enabled(true)
46 .tag_filters(vec![AWSNamespaceTagFilter::new()
47 .namespace("AWS/EC2".to_string())
48 .tags(Some(vec!["key:value".to_string()]))]),
49 )
50 .resources_config(
51 AWSResourcesConfig::new()
52 .cloud_security_posture_management_collection(false)
53 .extended_collection(false),
54 )
55 .traces_config(AWSTracesConfig::new()),
56 AWSAccountType::ACCOUNT,
57 ));
58 let mut configuration = datadog::Configuration::new();
59 configuration.set_unstable_operation_enabled("v2.CreateAWSAccount", true);
60 let api = AWSIntegrationAPI::with_config(configuration);
61 let resp = api.create_aws_account(body).await;
62 if let Ok(value) = resp {
63 println!("{:#?}", value);
64 } else {
65 println!("{:#?}", resp.unwrap_err());
66 }
67}
Sourcepub fn secret_access_key(self, value: String) -> Self
pub fn secret_access_key(self, value: String) -> Self
Examples found in repository?
examples/v2_aws-integration_CreateAWSAccount.rs (line 24)
19async fn main() {
20 let body = AWSAccountCreateRequest::new(AWSAccountCreateRequestData::new(
21 AWSAccountCreateRequestAttributes::new(
22 AWSAuthConfig::AWSAuthConfigKeys(Box::new(
23 AWSAuthConfigKeys::new("AKIAIOSFODNN7EXAMPLE".to_string())
24 .secret_access_key("wJalrXUtnFEMI/K7MDENG/bPxRfiCYEXAMPLEKEY".to_string()),
25 )),
26 "123456789012".to_string(),
27 AWSAccountPartition::AWS,
28 )
29 .account_tags(Some(vec!["key:value".to_string()]))
30 .logs_config(
31 AWSLogsConfig::new().lambda_forwarder(
32 AWSLambdaForwarderConfig::new()
33 .lambdas(vec![
34 "arn:aws:lambda:us-east-1:123456789012:function:DatadogLambdaLogForwarder"
35 .to_string(),
36 ])
37 .sources(vec!["s3".to_string()]),
38 ),
39 )
40 .metrics_config(
41 AWSMetricsConfig::new()
42 .automute_enabled(true)
43 .collect_cloudwatch_alarms(true)
44 .collect_custom_metrics(true)
45 .enabled(true)
46 .tag_filters(vec![AWSNamespaceTagFilter::new()
47 .namespace("AWS/EC2".to_string())
48 .tags(Some(vec!["key:value".to_string()]))]),
49 )
50 .resources_config(
51 AWSResourcesConfig::new()
52 .cloud_security_posture_management_collection(false)
53 .extended_collection(false),
54 )
55 .traces_config(AWSTracesConfig::new()),
56 AWSAccountType::ACCOUNT,
57 ));
58 let mut configuration = datadog::Configuration::new();
59 configuration.set_unstable_operation_enabled("v2.CreateAWSAccount", true);
60 let api = AWSIntegrationAPI::with_config(configuration);
61 let resp = api.create_aws_account(body).await;
62 if let Ok(value) = resp {
63 println!("{:#?}", value);
64 } else {
65 println!("{:#?}", resp.unwrap_err());
66 }
67}
pub fn additional_properties(self, value: BTreeMap<String, Value>) -> Self
Trait Implementations§
Source§impl Clone for AWSAuthConfigKeys
impl Clone for AWSAuthConfigKeys
Source§fn clone(&self) -> AWSAuthConfigKeys
fn clone(&self) -> AWSAuthConfigKeys
Returns a duplicate of the value. Read more
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source
. Read moreSource§impl Debug for AWSAuthConfigKeys
impl Debug for AWSAuthConfigKeys
Source§impl<'de> Deserialize<'de> for AWSAuthConfigKeys
impl<'de> Deserialize<'de> for AWSAuthConfigKeys
Source§fn deserialize<D>(deserializer: D) -> Result<Self, D::Error>where
D: Deserializer<'de>,
fn deserialize<D>(deserializer: D) -> Result<Self, D::Error>where
D: Deserializer<'de>,
Deserialize this value from the given Serde deserializer. Read more
Source§impl PartialEq for AWSAuthConfigKeys
impl PartialEq for AWSAuthConfigKeys
Source§impl Serialize for AWSAuthConfigKeys
impl Serialize for AWSAuthConfigKeys
impl StructuralPartialEq for AWSAuthConfigKeys
Auto Trait Implementations§
impl Freeze for AWSAuthConfigKeys
impl RefUnwindSafe for AWSAuthConfigKeys
impl Send for AWSAuthConfigKeys
impl Sync for AWSAuthConfigKeys
impl Unpin for AWSAuthConfigKeys
impl UnwindSafe for AWSAuthConfigKeys
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more