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
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
#[allow(missing_docs)] // documentation missing in model
#[non_exhaustive]
#[derive(::std::clone::Clone, ::std::cmp::PartialEq, ::std::fmt::Debug)]
pub struct HeadBucketOutput {
    /// <p>The type of location where the bucket is created.</p><note>
    /// <p>This functionality is only supported by directory buckets.</p>
    /// </note>
    pub bucket_location_type: ::std::option::Option<crate::types::LocationType>,
    /// <p>The name of the location where the bucket will be created.</p>
    /// <p>For directory buckets, the AZ ID of the Availability Zone where the bucket is created. An example AZ ID value is <code>usw2-az1</code>.</p><note>
    /// <p>This functionality is only supported by directory buckets.</p>
    /// </note>
    pub bucket_location_name: ::std::option::Option<::std::string::String>,
    /// <p>The Region that the bucket is located.</p><note>
    /// <p>This functionality is not supported for directory buckets.</p>
    /// </note>
    pub bucket_region: ::std::option::Option<::std::string::String>,
    /// <p>Indicates whether the bucket name used in the request is an access point alias.</p><note>
    /// <p>This functionality is not supported for directory buckets.</p>
    /// </note>
    pub access_point_alias: ::std::option::Option<bool>,
    _extended_request_id: Option<String>,
    _request_id: Option<String>,
}
impl HeadBucketOutput {
    /// <p>The type of location where the bucket is created.</p><note>
    /// <p>This functionality is only supported by directory buckets.</p>
    /// </note>
    pub fn bucket_location_type(&self) -> ::std::option::Option<&crate::types::LocationType> {
        self.bucket_location_type.as_ref()
    }
    /// <p>The name of the location where the bucket will be created.</p>
    /// <p>For directory buckets, the AZ ID of the Availability Zone where the bucket is created. An example AZ ID value is <code>usw2-az1</code>.</p><note>
    /// <p>This functionality is only supported by directory buckets.</p>
    /// </note>
    pub fn bucket_location_name(&self) -> ::std::option::Option<&str> {
        self.bucket_location_name.as_deref()
    }
    /// <p>The Region that the bucket is located.</p><note>
    /// <p>This functionality is not supported for directory buckets.</p>
    /// </note>
    pub fn bucket_region(&self) -> ::std::option::Option<&str> {
        self.bucket_region.as_deref()
    }
    /// <p>Indicates whether the bucket name used in the request is an access point alias.</p><note>
    /// <p>This functionality is not supported for directory buckets.</p>
    /// </note>
    pub fn access_point_alias(&self) -> ::std::option::Option<bool> {
        self.access_point_alias
    }
}
impl crate::s3_request_id::RequestIdExt for HeadBucketOutput {
    fn extended_request_id(&self) -> Option<&str> {
        self._extended_request_id.as_deref()
    }
}
impl ::aws_types::request_id::RequestId for HeadBucketOutput {
    fn request_id(&self) -> Option<&str> {
        self._request_id.as_deref()
    }
}
impl HeadBucketOutput {
    /// Creates a new builder-style object to manufacture [`HeadBucketOutput`](crate::operation::head_bucket::HeadBucketOutput).
    pub fn builder() -> crate::operation::head_bucket::builders::HeadBucketOutputBuilder {
        crate::operation::head_bucket::builders::HeadBucketOutputBuilder::default()
    }
}

/// A builder for [`HeadBucketOutput`](crate::operation::head_bucket::HeadBucketOutput).
#[non_exhaustive]
#[derive(::std::clone::Clone, ::std::cmp::PartialEq, ::std::default::Default, ::std::fmt::Debug)]
pub struct HeadBucketOutputBuilder {
    pub(crate) bucket_location_type: ::std::option::Option<crate::types::LocationType>,
    pub(crate) bucket_location_name: ::std::option::Option<::std::string::String>,
    pub(crate) bucket_region: ::std::option::Option<::std::string::String>,
    pub(crate) access_point_alias: ::std::option::Option<bool>,
    _extended_request_id: Option<String>,
    _request_id: Option<String>,
}
impl HeadBucketOutputBuilder {
    /// <p>The type of location where the bucket is created.</p><note>
    /// <p>This functionality is only supported by directory buckets.</p>
    /// </note>
    pub fn bucket_location_type(mut self, input: crate::types::LocationType) -> Self {
        self.bucket_location_type = ::std::option::Option::Some(input);
        self
    }
    /// <p>The type of location where the bucket is created.</p><note>
    /// <p>This functionality is only supported by directory buckets.</p>
    /// </note>
    pub fn set_bucket_location_type(mut self, input: ::std::option::Option<crate::types::LocationType>) -> Self {
        self.bucket_location_type = input;
        self
    }
    /// <p>The type of location where the bucket is created.</p><note>
    /// <p>This functionality is only supported by directory buckets.</p>
    /// </note>
    pub fn get_bucket_location_type(&self) -> &::std::option::Option<crate::types::LocationType> {
        &self.bucket_location_type
    }
    /// <p>The name of the location where the bucket will be created.</p>
    /// <p>For directory buckets, the AZ ID of the Availability Zone where the bucket is created. An example AZ ID value is <code>usw2-az1</code>.</p><note>
    /// <p>This functionality is only supported by directory buckets.</p>
    /// </note>
    pub fn bucket_location_name(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
        self.bucket_location_name = ::std::option::Option::Some(input.into());
        self
    }
    /// <p>The name of the location where the bucket will be created.</p>
    /// <p>For directory buckets, the AZ ID of the Availability Zone where the bucket is created. An example AZ ID value is <code>usw2-az1</code>.</p><note>
    /// <p>This functionality is only supported by directory buckets.</p>
    /// </note>
    pub fn set_bucket_location_name(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
        self.bucket_location_name = input;
        self
    }
    /// <p>The name of the location where the bucket will be created.</p>
    /// <p>For directory buckets, the AZ ID of the Availability Zone where the bucket is created. An example AZ ID value is <code>usw2-az1</code>.</p><note>
    /// <p>This functionality is only supported by directory buckets.</p>
    /// </note>
    pub fn get_bucket_location_name(&self) -> &::std::option::Option<::std::string::String> {
        &self.bucket_location_name
    }
    /// <p>The Region that the bucket is located.</p><note>
    /// <p>This functionality is not supported for directory buckets.</p>
    /// </note>
    pub fn bucket_region(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
        self.bucket_region = ::std::option::Option::Some(input.into());
        self
    }
    /// <p>The Region that the bucket is located.</p><note>
    /// <p>This functionality is not supported for directory buckets.</p>
    /// </note>
    pub fn set_bucket_region(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
        self.bucket_region = input;
        self
    }
    /// <p>The Region that the bucket is located.</p><note>
    /// <p>This functionality is not supported for directory buckets.</p>
    /// </note>
    pub fn get_bucket_region(&self) -> &::std::option::Option<::std::string::String> {
        &self.bucket_region
    }
    /// <p>Indicates whether the bucket name used in the request is an access point alias.</p><note>
    /// <p>This functionality is not supported for directory buckets.</p>
    /// </note>
    pub fn access_point_alias(mut self, input: bool) -> Self {
        self.access_point_alias = ::std::option::Option::Some(input);
        self
    }
    /// <p>Indicates whether the bucket name used in the request is an access point alias.</p><note>
    /// <p>This functionality is not supported for directory buckets.</p>
    /// </note>
    pub fn set_access_point_alias(mut self, input: ::std::option::Option<bool>) -> Self {
        self.access_point_alias = input;
        self
    }
    /// <p>Indicates whether the bucket name used in the request is an access point alias.</p><note>
    /// <p>This functionality is not supported for directory buckets.</p>
    /// </note>
    pub fn get_access_point_alias(&self) -> &::std::option::Option<bool> {
        &self.access_point_alias
    }
    pub(crate) fn _extended_request_id(mut self, extended_request_id: impl Into<String>) -> Self {
        self._extended_request_id = Some(extended_request_id.into());
        self
    }

    pub(crate) fn _set_extended_request_id(&mut self, extended_request_id: Option<String>) -> &mut Self {
        self._extended_request_id = extended_request_id;
        self
    }
    pub(crate) fn _request_id(mut self, request_id: impl Into<String>) -> Self {
        self._request_id = Some(request_id.into());
        self
    }

    pub(crate) fn _set_request_id(&mut self, request_id: Option<String>) -> &mut Self {
        self._request_id = request_id;
        self
    }
    /// Consumes the builder and constructs a [`HeadBucketOutput`](crate::operation::head_bucket::HeadBucketOutput).
    pub fn build(self) -> crate::operation::head_bucket::HeadBucketOutput {
        crate::operation::head_bucket::HeadBucketOutput {
            bucket_location_type: self.bucket_location_type,
            bucket_location_name: self.bucket_location_name,
            bucket_region: self.bucket_region,
            access_point_alias: self.access_point_alias,
            _extended_request_id: self._extended_request_id,
            _request_id: self._request_id,
        }
    }
}