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
// 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 CreateTrackerOutput {
/// <p>The name of the tracker resource.</p>
pub tracker_name: ::std::string::String,
/// <p>The Amazon Resource Name (ARN) for the tracker 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:tracker/ExampleTracker</code> </p> </li>
/// </ul>
pub tracker_arn: ::std::string::String,
/// <p>The timestamp for when the tracker 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 CreateTrackerOutput {
/// <p>The name of the tracker resource.</p>
pub fn tracker_name(&self) -> &str {
use std::ops::Deref;
self.tracker_name.deref()
}
/// <p>The Amazon Resource Name (ARN) for the tracker 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:tracker/ExampleTracker</code> </p> </li>
/// </ul>
pub fn tracker_arn(&self) -> &str {
use std::ops::Deref;
self.tracker_arn.deref()
}
/// <p>The timestamp for when the tracker 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 ::aws_http::request_id::RequestId for CreateTrackerOutput {
fn request_id(&self) -> Option<&str> {
self._request_id.as_deref()
}
}
impl CreateTrackerOutput {
/// Creates a new builder-style object to manufacture [`CreateTrackerOutput`](crate::operation::create_tracker::CreateTrackerOutput).
pub fn builder() -> crate::operation::create_tracker::builders::CreateTrackerOutputBuilder {
crate::operation::create_tracker::builders::CreateTrackerOutputBuilder::default()
}
}
/// A builder for [`CreateTrackerOutput`](crate::operation::create_tracker::CreateTrackerOutput).
#[non_exhaustive]
#[derive(::std::clone::Clone, ::std::cmp::PartialEq, ::std::default::Default, ::std::fmt::Debug)]
pub struct CreateTrackerOutputBuilder {
pub(crate) tracker_name: ::std::option::Option<::std::string::String>,
pub(crate) tracker_arn: ::std::option::Option<::std::string::String>,
pub(crate) create_time: ::std::option::Option<::aws_smithy_types::DateTime>,
_request_id: Option<String>,
}
impl CreateTrackerOutputBuilder {
/// <p>The name of the tracker resource.</p>
/// This field is required.
pub fn tracker_name(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
self.tracker_name = ::std::option::Option::Some(input.into());
self
}
/// <p>The name of the tracker resource.</p>
pub fn set_tracker_name(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
self.tracker_name = input;
self
}
/// <p>The name of the tracker resource.</p>
pub fn get_tracker_name(&self) -> &::std::option::Option<::std::string::String> {
&self.tracker_name
}
/// <p>The Amazon Resource Name (ARN) for the tracker 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:tracker/ExampleTracker</code> </p> </li>
/// </ul>
/// This field is required.
pub fn tracker_arn(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
self.tracker_arn = ::std::option::Option::Some(input.into());
self
}
/// <p>The Amazon Resource Name (ARN) for the tracker 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:tracker/ExampleTracker</code> </p> </li>
/// </ul>
pub fn set_tracker_arn(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
self.tracker_arn = input;
self
}
/// <p>The Amazon Resource Name (ARN) for the tracker 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:tracker/ExampleTracker</code> </p> </li>
/// </ul>
pub fn get_tracker_arn(&self) -> &::std::option::Option<::std::string::String> {
&self.tracker_arn
}
/// <p>The timestamp for when the tracker 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 tracker 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 tracker 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 [`CreateTrackerOutput`](crate::operation::create_tracker::CreateTrackerOutput).
/// This method will fail if any of the following fields are not set:
/// - [`tracker_name`](crate::operation::create_tracker::builders::CreateTrackerOutputBuilder::tracker_name)
/// - [`tracker_arn`](crate::operation::create_tracker::builders::CreateTrackerOutputBuilder::tracker_arn)
/// - [`create_time`](crate::operation::create_tracker::builders::CreateTrackerOutputBuilder::create_time)
pub fn build(
self,
) -> ::std::result::Result<crate::operation::create_tracker::CreateTrackerOutput, ::aws_smithy_types::error::operation::BuildError> {
::std::result::Result::Ok(crate::operation::create_tracker::CreateTrackerOutput {
tracker_name: self.tracker_name.ok_or_else(|| {
::aws_smithy_types::error::operation::BuildError::missing_field(
"tracker_name",
"tracker_name was not specified but it is required when building CreateTrackerOutput",
)
})?,
tracker_arn: self.tracker_arn.ok_or_else(|| {
::aws_smithy_types::error::operation::BuildError::missing_field(
"tracker_arn",
"tracker_arn was not specified but it is required when building CreateTrackerOutput",
)
})?,
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 CreateTrackerOutput",
)
})?,
_request_id: self._request_id,
})
}
}