1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
/// <p>Contains information about where to publish the analytics results.</p>
#[non_exhaustive]
#[derive(::std::clone::Clone, ::std::cmp::PartialEq, ::std::fmt::Debug)]
pub struct AnalyticsS3BucketDestination {
/// <p>Specifies the file format used when exporting data to Amazon S3.</p>
pub format: crate::types::AnalyticsS3ExportFileFormat,
/// <p>The account ID that owns the destination S3 bucket. If no account ID is provided, the owner is not validated before exporting data.</p><note>
/// <p>Although this value is optional, we strongly recommend that you set it to help prevent problems if the destination bucket ownership changes.</p>
/// </note>
pub bucket_account_id: ::std::option::Option<::std::string::String>,
/// <p>The Amazon Resource Name (ARN) of the bucket to which data is exported.</p>
pub bucket: ::std::string::String,
/// <p>The prefix to use when exporting data. The prefix is prepended to all results.</p>
pub prefix: ::std::option::Option<::std::string::String>,
}
impl AnalyticsS3BucketDestination {
/// <p>Specifies the file format used when exporting data to Amazon S3.</p>
pub fn format(&self) -> &crate::types::AnalyticsS3ExportFileFormat {
&self.format
}
/// <p>The account ID that owns the destination S3 bucket. If no account ID is provided, the owner is not validated before exporting data.</p><note>
/// <p>Although this value is optional, we strongly recommend that you set it to help prevent problems if the destination bucket ownership changes.</p>
/// </note>
pub fn bucket_account_id(&self) -> ::std::option::Option<&str> {
self.bucket_account_id.as_deref()
}
/// <p>The Amazon Resource Name (ARN) of the bucket to which data is exported.</p>
pub fn bucket(&self) -> &str {
use std::ops::Deref;
self.bucket.deref()
}
/// <p>The prefix to use when exporting data. The prefix is prepended to all results.</p>
pub fn prefix(&self) -> ::std::option::Option<&str> {
self.prefix.as_deref()
}
}
impl AnalyticsS3BucketDestination {
/// Creates a new builder-style object to manufacture [`AnalyticsS3BucketDestination`](crate::types::AnalyticsS3BucketDestination).
pub fn builder() -> crate::types::builders::AnalyticsS3BucketDestinationBuilder {
crate::types::builders::AnalyticsS3BucketDestinationBuilder::default()
}
}
/// A builder for [`AnalyticsS3BucketDestination`](crate::types::AnalyticsS3BucketDestination).
#[non_exhaustive]
#[derive(::std::clone::Clone, ::std::cmp::PartialEq, ::std::default::Default, ::std::fmt::Debug)]
pub struct AnalyticsS3BucketDestinationBuilder {
pub(crate) format: ::std::option::Option<crate::types::AnalyticsS3ExportFileFormat>,
pub(crate) bucket_account_id: ::std::option::Option<::std::string::String>,
pub(crate) bucket: ::std::option::Option<::std::string::String>,
pub(crate) prefix: ::std::option::Option<::std::string::String>,
}
impl AnalyticsS3BucketDestinationBuilder {
/// <p>Specifies the file format used when exporting data to Amazon S3.</p>
/// This field is required.
pub fn format(mut self, input: crate::types::AnalyticsS3ExportFileFormat) -> Self {
self.format = ::std::option::Option::Some(input);
self
}
/// <p>Specifies the file format used when exporting data to Amazon S3.</p>
pub fn set_format(mut self, input: ::std::option::Option<crate::types::AnalyticsS3ExportFileFormat>) -> Self {
self.format = input;
self
}
/// <p>Specifies the file format used when exporting data to Amazon S3.</p>
pub fn get_format(&self) -> &::std::option::Option<crate::types::AnalyticsS3ExportFileFormat> {
&self.format
}
/// <p>The account ID that owns the destination S3 bucket. If no account ID is provided, the owner is not validated before exporting data.</p><note>
/// <p>Although this value is optional, we strongly recommend that you set it to help prevent problems if the destination bucket ownership changes.</p>
/// </note>
pub fn bucket_account_id(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
self.bucket_account_id = ::std::option::Option::Some(input.into());
self
}
/// <p>The account ID that owns the destination S3 bucket. If no account ID is provided, the owner is not validated before exporting data.</p><note>
/// <p>Although this value is optional, we strongly recommend that you set it to help prevent problems if the destination bucket ownership changes.</p>
/// </note>
pub fn set_bucket_account_id(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
self.bucket_account_id = input;
self
}
/// <p>The account ID that owns the destination S3 bucket. If no account ID is provided, the owner is not validated before exporting data.</p><note>
/// <p>Although this value is optional, we strongly recommend that you set it to help prevent problems if the destination bucket ownership changes.</p>
/// </note>
pub fn get_bucket_account_id(&self) -> &::std::option::Option<::std::string::String> {
&self.bucket_account_id
}
/// <p>The Amazon Resource Name (ARN) of the bucket to which data is exported.</p>
/// This field is required.
pub fn bucket(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
self.bucket = ::std::option::Option::Some(input.into());
self
}
/// <p>The Amazon Resource Name (ARN) of the bucket to which data is exported.</p>
pub fn set_bucket(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
self.bucket = input;
self
}
/// <p>The Amazon Resource Name (ARN) of the bucket to which data is exported.</p>
pub fn get_bucket(&self) -> &::std::option::Option<::std::string::String> {
&self.bucket
}
/// <p>The prefix to use when exporting data. The prefix is prepended to all results.</p>
pub fn prefix(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
self.prefix = ::std::option::Option::Some(input.into());
self
}
/// <p>The prefix to use when exporting data. The prefix is prepended to all results.</p>
pub fn set_prefix(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
self.prefix = input;
self
}
/// <p>The prefix to use when exporting data. The prefix is prepended to all results.</p>
pub fn get_prefix(&self) -> &::std::option::Option<::std::string::String> {
&self.prefix
}
/// Consumes the builder and constructs a [`AnalyticsS3BucketDestination`](crate::types::AnalyticsS3BucketDestination).
/// This method will fail if any of the following fields are not set:
/// - [`format`](crate::types::builders::AnalyticsS3BucketDestinationBuilder::format)
/// - [`bucket`](crate::types::builders::AnalyticsS3BucketDestinationBuilder::bucket)
pub fn build(self) -> ::std::result::Result<crate::types::AnalyticsS3BucketDestination, ::aws_smithy_types::error::operation::BuildError> {
::std::result::Result::Ok(crate::types::AnalyticsS3BucketDestination {
format: self.format.ok_or_else(|| {
::aws_smithy_types::error::operation::BuildError::missing_field(
"format",
"format was not specified but it is required when building AnalyticsS3BucketDestination",
)
})?,
bucket_account_id: self.bucket_account_id,
bucket: self.bucket.ok_or_else(|| {
::aws_smithy_types::error::operation::BuildError::missing_field(
"bucket",
"bucket was not specified but it is required when building AnalyticsS3BucketDestination",
)
})?,
prefix: self.prefix,
})
}
}