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
195
196
197
198
199
200
201
202
203
204
205
206
// 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)]
pub struct CreateKeyOutput {
/// <p>The key value/string of an API key. This value is used when making API calls to authorize the call. For example, see <a href="https://docs.aws.amazon.com/location/latest/APIReference/API_GetMapGlyphs.html">GetMapGlyphs</a>.</p>
pub key: ::std::string::String,
/// <p>The Amazon Resource Name (ARN) for the API key resource. Used when you need to specify a resource across all Amazon Web Services.</p>
/// <ul>
/// <li>
/// <p>Format example: <code>arn:aws:geo:region:account-id:key/ExampleKey</code></p></li>
/// </ul>
pub key_arn: ::std::string::String,
/// <p>The name of the API key resource.</p>
pub key_name: ::std::string::String,
/// <p>The timestamp for when the API key resource was created in <a href="https://www.iso.org/iso-8601-date-and-time-format.html"> ISO 8601</a> format: <code>YYYY-MM-DDThh:mm:ss.sssZ</code>.</p>
pub create_time: ::aws_smithy_types::DateTime,
_request_id: Option<String>,
}
impl CreateKeyOutput {
/// <p>The key value/string of an API key. This value is used when making API calls to authorize the call. For example, see <a href="https://docs.aws.amazon.com/location/latest/APIReference/API_GetMapGlyphs.html">GetMapGlyphs</a>.</p>
pub fn key(&self) -> &str {
use std::ops::Deref;
self.key.deref()
}
/// <p>The Amazon Resource Name (ARN) for the API key resource. Used when you need to specify a resource across all Amazon Web Services.</p>
/// <ul>
/// <li>
/// <p>Format example: <code>arn:aws:geo:region:account-id:key/ExampleKey</code></p></li>
/// </ul>
pub fn key_arn(&self) -> &str {
use std::ops::Deref;
self.key_arn.deref()
}
/// <p>The name of the API key resource.</p>
pub fn key_name(&self) -> &str {
use std::ops::Deref;
self.key_name.deref()
}
/// <p>The timestamp for when the API key resource was created in <a href="https://www.iso.org/iso-8601-date-and-time-format.html"> ISO 8601</a> format: <code>YYYY-MM-DDThh:mm:ss.sssZ</code>.</p>
pub fn create_time(&self) -> &::aws_smithy_types::DateTime {
&self.create_time
}
}
impl ::std::fmt::Debug for CreateKeyOutput {
fn fmt(&self, f: &mut ::std::fmt::Formatter<'_>) -> ::std::fmt::Result {
let mut formatter = f.debug_struct("CreateKeyOutput");
formatter.field("key", &"*** Sensitive Data Redacted ***");
formatter.field("key_arn", &self.key_arn);
formatter.field("key_name", &self.key_name);
formatter.field("create_time", &self.create_time);
formatter.field("_request_id", &self._request_id);
formatter.finish()
}
}
impl ::aws_types::request_id::RequestId for CreateKeyOutput {
fn request_id(&self) -> Option<&str> {
self._request_id.as_deref()
}
}
impl CreateKeyOutput {
/// Creates a new builder-style object to manufacture [`CreateKeyOutput`](crate::operation::create_key::CreateKeyOutput).
pub fn builder() -> crate::operation::create_key::builders::CreateKeyOutputBuilder {
crate::operation::create_key::builders::CreateKeyOutputBuilder::default()
}
}
/// A builder for [`CreateKeyOutput`](crate::operation::create_key::CreateKeyOutput).
#[derive(::std::clone::Clone, ::std::cmp::PartialEq, ::std::default::Default)]
#[non_exhaustive]
pub struct CreateKeyOutputBuilder {
pub(crate) key: ::std::option::Option<::std::string::String>,
pub(crate) key_arn: ::std::option::Option<::std::string::String>,
pub(crate) key_name: ::std::option::Option<::std::string::String>,
pub(crate) create_time: ::std::option::Option<::aws_smithy_types::DateTime>,
_request_id: Option<String>,
}
impl CreateKeyOutputBuilder {
/// <p>The key value/string of an API key. This value is used when making API calls to authorize the call. For example, see <a href="https://docs.aws.amazon.com/location/latest/APIReference/API_GetMapGlyphs.html">GetMapGlyphs</a>.</p>
/// This field is required.
pub fn key(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
self.key = ::std::option::Option::Some(input.into());
self
}
/// <p>The key value/string of an API key. This value is used when making API calls to authorize the call. For example, see <a href="https://docs.aws.amazon.com/location/latest/APIReference/API_GetMapGlyphs.html">GetMapGlyphs</a>.</p>
pub fn set_key(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
self.key = input;
self
}
/// <p>The key value/string of an API key. This value is used when making API calls to authorize the call. For example, see <a href="https://docs.aws.amazon.com/location/latest/APIReference/API_GetMapGlyphs.html">GetMapGlyphs</a>.</p>
pub fn get_key(&self) -> &::std::option::Option<::std::string::String> {
&self.key
}
/// <p>The Amazon Resource Name (ARN) for the API key resource. Used when you need to specify a resource across all Amazon Web Services.</p>
/// <ul>
/// <li>
/// <p>Format example: <code>arn:aws:geo:region:account-id:key/ExampleKey</code></p></li>
/// </ul>
/// This field is required.
pub fn key_arn(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
self.key_arn = ::std::option::Option::Some(input.into());
self
}
/// <p>The Amazon Resource Name (ARN) for the API key resource. Used when you need to specify a resource across all Amazon Web Services.</p>
/// <ul>
/// <li>
/// <p>Format example: <code>arn:aws:geo:region:account-id:key/ExampleKey</code></p></li>
/// </ul>
pub fn set_key_arn(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
self.key_arn = input;
self
}
/// <p>The Amazon Resource Name (ARN) for the API key resource. Used when you need to specify a resource across all Amazon Web Services.</p>
/// <ul>
/// <li>
/// <p>Format example: <code>arn:aws:geo:region:account-id:key/ExampleKey</code></p></li>
/// </ul>
pub fn get_key_arn(&self) -> &::std::option::Option<::std::string::String> {
&self.key_arn
}
/// <p>The name of the API key resource.</p>
/// This field is required.
pub fn key_name(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
self.key_name = ::std::option::Option::Some(input.into());
self
}
/// <p>The name of the API key resource.</p>
pub fn set_key_name(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
self.key_name = input;
self
}
/// <p>The name of the API key resource.</p>
pub fn get_key_name(&self) -> &::std::option::Option<::std::string::String> {
&self.key_name
}
/// <p>The timestamp for when the API key resource was created in <a href="https://www.iso.org/iso-8601-date-and-time-format.html"> ISO 8601</a> format: <code>YYYY-MM-DDThh:mm:ss.sssZ</code>.</p>
/// This field is required.
pub fn create_time(mut self, input: ::aws_smithy_types::DateTime) -> Self {
self.create_time = ::std::option::Option::Some(input);
self
}
/// <p>The timestamp for when the API key resource was created in <a href="https://www.iso.org/iso-8601-date-and-time-format.html"> ISO 8601</a> format: <code>YYYY-MM-DDThh:mm:ss.sssZ</code>.</p>
pub fn set_create_time(mut self, input: ::std::option::Option<::aws_smithy_types::DateTime>) -> Self {
self.create_time = input;
self
}
/// <p>The timestamp for when the API key resource was created in <a href="https://www.iso.org/iso-8601-date-and-time-format.html"> ISO 8601</a> format: <code>YYYY-MM-DDThh:mm:ss.sssZ</code>.</p>
pub fn get_create_time(&self) -> &::std::option::Option<::aws_smithy_types::DateTime> {
&self.create_time
}
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 [`CreateKeyOutput`](crate::operation::create_key::CreateKeyOutput).
/// This method will fail if any of the following fields are not set:
/// - [`key`](crate::operation::create_key::builders::CreateKeyOutputBuilder::key)
/// - [`key_arn`](crate::operation::create_key::builders::CreateKeyOutputBuilder::key_arn)
/// - [`key_name`](crate::operation::create_key::builders::CreateKeyOutputBuilder::key_name)
/// - [`create_time`](crate::operation::create_key::builders::CreateKeyOutputBuilder::create_time)
pub fn build(self) -> ::std::result::Result<crate::operation::create_key::CreateKeyOutput, ::aws_smithy_types::error::operation::BuildError> {
::std::result::Result::Ok(crate::operation::create_key::CreateKeyOutput {
key: self.key.ok_or_else(|| {
::aws_smithy_types::error::operation::BuildError::missing_field(
"key",
"key was not specified but it is required when building CreateKeyOutput",
)
})?,
key_arn: self.key_arn.ok_or_else(|| {
::aws_smithy_types::error::operation::BuildError::missing_field(
"key_arn",
"key_arn was not specified but it is required when building CreateKeyOutput",
)
})?,
key_name: self.key_name.ok_or_else(|| {
::aws_smithy_types::error::operation::BuildError::missing_field(
"key_name",
"key_name was not specified but it is required when building CreateKeyOutput",
)
})?,
create_time: self.create_time.ok_or_else(|| {
::aws_smithy_types::error::operation::BuildError::missing_field(
"create_time",
"create_time was not specified but it is required when building CreateKeyOutput",
)
})?,
_request_id: self._request_id,
})
}
}
impl ::std::fmt::Debug for CreateKeyOutputBuilder {
fn fmt(&self, f: &mut ::std::fmt::Formatter<'_>) -> ::std::fmt::Result {
let mut formatter = f.debug_struct("CreateKeyOutputBuilder");
formatter.field("key", &"*** Sensitive Data Redacted ***");
formatter.field("key_arn", &self.key_arn);
formatter.field("key_name", &self.key_name);
formatter.field("create_time", &self.create_time);
formatter.field("_request_id", &self._request_id);
formatter.finish()
}
}