aws_sdk_s3/operation/head_bucket/_head_bucket_output.rs
1// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
2#[allow(missing_docs)] // documentation missing in model
3#[non_exhaustive]
4#[derive(::std::clone::Clone, ::std::cmp::PartialEq, ::std::fmt::Debug)]
5pub struct HeadBucketOutput {
6 /// <p>The type of location where the bucket is created.</p><note>
7 /// <p>This functionality is only supported by directory buckets.</p>
8 /// </note>
9 pub bucket_location_type: ::std::option::Option<crate::types::LocationType>,
10 /// <p>The name of the location where the bucket will be created.</p>
11 /// <p>For directory buckets, the Zone ID of the Availability Zone or the Local Zone where the bucket is created. An example Zone ID value for an Availability Zone is <code>usw2-az1</code>.</p><note>
12 /// <p>This functionality is only supported by directory buckets.</p>
13 /// </note>
14 pub bucket_location_name: ::std::option::Option<::std::string::String>,
15 /// <p>The Region that the bucket is located.</p>
16 pub bucket_region: ::std::option::Option<::std::string::String>,
17 /// <p>Indicates whether the bucket name used in the request is an access point alias.</p><note>
18 /// <p>For directory buckets, the value of this field is <code>false</code>.</p>
19 /// </note>
20 pub access_point_alias: ::std::option::Option<bool>,
21 _extended_request_id: Option<String>,
22 _request_id: Option<String>,
23}
24impl HeadBucketOutput {
25 /// <p>The type of location where the bucket is created.</p><note>
26 /// <p>This functionality is only supported by directory buckets.</p>
27 /// </note>
28 pub fn bucket_location_type(&self) -> ::std::option::Option<&crate::types::LocationType> {
29 self.bucket_location_type.as_ref()
30 }
31 /// <p>The name of the location where the bucket will be created.</p>
32 /// <p>For directory buckets, the Zone ID of the Availability Zone or the Local Zone where the bucket is created. An example Zone ID value for an Availability Zone is <code>usw2-az1</code>.</p><note>
33 /// <p>This functionality is only supported by directory buckets.</p>
34 /// </note>
35 pub fn bucket_location_name(&self) -> ::std::option::Option<&str> {
36 self.bucket_location_name.as_deref()
37 }
38 /// <p>The Region that the bucket is located.</p>
39 pub fn bucket_region(&self) -> ::std::option::Option<&str> {
40 self.bucket_region.as_deref()
41 }
42 /// <p>Indicates whether the bucket name used in the request is an access point alias.</p><note>
43 /// <p>For directory buckets, the value of this field is <code>false</code>.</p>
44 /// </note>
45 pub fn access_point_alias(&self) -> ::std::option::Option<bool> {
46 self.access_point_alias
47 }
48}
49impl crate::s3_request_id::RequestIdExt for HeadBucketOutput {
50 fn extended_request_id(&self) -> Option<&str> {
51 self._extended_request_id.as_deref()
52 }
53}
54impl ::aws_types::request_id::RequestId for HeadBucketOutput {
55 fn request_id(&self) -> Option<&str> {
56 self._request_id.as_deref()
57 }
58}
59impl HeadBucketOutput {
60 /// Creates a new builder-style object to manufacture [`HeadBucketOutput`](crate::operation::head_bucket::HeadBucketOutput).
61 pub fn builder() -> crate::operation::head_bucket::builders::HeadBucketOutputBuilder {
62 crate::operation::head_bucket::builders::HeadBucketOutputBuilder::default()
63 }
64}
65
66/// A builder for [`HeadBucketOutput`](crate::operation::head_bucket::HeadBucketOutput).
67#[derive(::std::clone::Clone, ::std::cmp::PartialEq, ::std::default::Default, ::std::fmt::Debug)]
68#[non_exhaustive]
69pub struct HeadBucketOutputBuilder {
70 pub(crate) bucket_location_type: ::std::option::Option<crate::types::LocationType>,
71 pub(crate) bucket_location_name: ::std::option::Option<::std::string::String>,
72 pub(crate) bucket_region: ::std::option::Option<::std::string::String>,
73 pub(crate) access_point_alias: ::std::option::Option<bool>,
74 _extended_request_id: Option<String>,
75 _request_id: Option<String>,
76}
77impl HeadBucketOutputBuilder {
78 /// <p>The type of location where the bucket is created.</p><note>
79 /// <p>This functionality is only supported by directory buckets.</p>
80 /// </note>
81 pub fn bucket_location_type(mut self, input: crate::types::LocationType) -> Self {
82 self.bucket_location_type = ::std::option::Option::Some(input);
83 self
84 }
85 /// <p>The type of location where the bucket is created.</p><note>
86 /// <p>This functionality is only supported by directory buckets.</p>
87 /// </note>
88 pub fn set_bucket_location_type(mut self, input: ::std::option::Option<crate::types::LocationType>) -> Self {
89 self.bucket_location_type = input;
90 self
91 }
92 /// <p>The type of location where the bucket is created.</p><note>
93 /// <p>This functionality is only supported by directory buckets.</p>
94 /// </note>
95 pub fn get_bucket_location_type(&self) -> &::std::option::Option<crate::types::LocationType> {
96 &self.bucket_location_type
97 }
98 /// <p>The name of the location where the bucket will be created.</p>
99 /// <p>For directory buckets, the Zone ID of the Availability Zone or the Local Zone where the bucket is created. An example Zone ID value for an Availability Zone is <code>usw2-az1</code>.</p><note>
100 /// <p>This functionality is only supported by directory buckets.</p>
101 /// </note>
102 pub fn bucket_location_name(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
103 self.bucket_location_name = ::std::option::Option::Some(input.into());
104 self
105 }
106 /// <p>The name of the location where the bucket will be created.</p>
107 /// <p>For directory buckets, the Zone ID of the Availability Zone or the Local Zone where the bucket is created. An example Zone ID value for an Availability Zone is <code>usw2-az1</code>.</p><note>
108 /// <p>This functionality is only supported by directory buckets.</p>
109 /// </note>
110 pub fn set_bucket_location_name(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
111 self.bucket_location_name = input;
112 self
113 }
114 /// <p>The name of the location where the bucket will be created.</p>
115 /// <p>For directory buckets, the Zone ID of the Availability Zone or the Local Zone where the bucket is created. An example Zone ID value for an Availability Zone is <code>usw2-az1</code>.</p><note>
116 /// <p>This functionality is only supported by directory buckets.</p>
117 /// </note>
118 pub fn get_bucket_location_name(&self) -> &::std::option::Option<::std::string::String> {
119 &self.bucket_location_name
120 }
121 /// <p>The Region that the bucket is located.</p>
122 pub fn bucket_region(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
123 self.bucket_region = ::std::option::Option::Some(input.into());
124 self
125 }
126 /// <p>The Region that the bucket is located.</p>
127 pub fn set_bucket_region(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
128 self.bucket_region = input;
129 self
130 }
131 /// <p>The Region that the bucket is located.</p>
132 pub fn get_bucket_region(&self) -> &::std::option::Option<::std::string::String> {
133 &self.bucket_region
134 }
135 /// <p>Indicates whether the bucket name used in the request is an access point alias.</p><note>
136 /// <p>For directory buckets, the value of this field is <code>false</code>.</p>
137 /// </note>
138 pub fn access_point_alias(mut self, input: bool) -> Self {
139 self.access_point_alias = ::std::option::Option::Some(input);
140 self
141 }
142 /// <p>Indicates whether the bucket name used in the request is an access point alias.</p><note>
143 /// <p>For directory buckets, the value of this field is <code>false</code>.</p>
144 /// </note>
145 pub fn set_access_point_alias(mut self, input: ::std::option::Option<bool>) -> Self {
146 self.access_point_alias = input;
147 self
148 }
149 /// <p>Indicates whether the bucket name used in the request is an access point alias.</p><note>
150 /// <p>For directory buckets, the value of this field is <code>false</code>.</p>
151 /// </note>
152 pub fn get_access_point_alias(&self) -> &::std::option::Option<bool> {
153 &self.access_point_alias
154 }
155 pub(crate) fn _extended_request_id(mut self, extended_request_id: impl Into<String>) -> Self {
156 self._extended_request_id = Some(extended_request_id.into());
157 self
158 }
159
160 pub(crate) fn _set_extended_request_id(&mut self, extended_request_id: Option<String>) -> &mut Self {
161 self._extended_request_id = extended_request_id;
162 self
163 }
164 pub(crate) fn _request_id(mut self, request_id: impl Into<String>) -> Self {
165 self._request_id = Some(request_id.into());
166 self
167 }
168
169 pub(crate) fn _set_request_id(&mut self, request_id: Option<String>) -> &mut Self {
170 self._request_id = request_id;
171 self
172 }
173 /// Consumes the builder and constructs a [`HeadBucketOutput`](crate::operation::head_bucket::HeadBucketOutput).
174 pub fn build(self) -> crate::operation::head_bucket::HeadBucketOutput {
175 crate::operation::head_bucket::HeadBucketOutput {
176 bucket_location_type: self.bucket_location_type,
177 bucket_location_name: self.bucket_location_name,
178 bucket_region: self.bucket_region,
179 access_point_alias: self.access_point_alias,
180 _extended_request_id: self._extended_request_id,
181 _request_id: self._request_id,
182 }
183 }
184}