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
// 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 CreateDiskInput {
/// <p>The unique Lightsail disk name (<code>my-disk</code>).</p>
pub disk_name: ::std::option::Option<::std::string::String>,
/// <p>The Availability Zone where you want to create the disk (<code>us-east-2a</code>). Use the same Availability Zone as the Lightsail instance to which you want to attach the disk.</p>
/// <p>Use the <code>get regions</code> operation to list the Availability Zones where Lightsail is currently available.</p>
pub availability_zone: ::std::option::Option<::std::string::String>,
/// <p>The size of the disk in GB (<code>32</code>).</p>
pub size_in_gb: ::std::option::Option<i32>,
/// <p>The tag keys and optional values to add to the resource during create.</p>
/// <p>Use the <code>TagResource</code> action to tag a resource after it's created.</p>
pub tags: ::std::option::Option<::std::vec::Vec<crate::types::Tag>>,
/// <p>An array of objects that represent the add-ons to enable for the new disk.</p>
pub add_ons: ::std::option::Option<::std::vec::Vec<crate::types::AddOnRequest>>,
}
impl CreateDiskInput {
/// <p>The unique Lightsail disk name (<code>my-disk</code>).</p>
pub fn disk_name(&self) -> ::std::option::Option<&str> {
self.disk_name.as_deref()
}
/// <p>The Availability Zone where you want to create the disk (<code>us-east-2a</code>). Use the same Availability Zone as the Lightsail instance to which you want to attach the disk.</p>
/// <p>Use the <code>get regions</code> operation to list the Availability Zones where Lightsail is currently available.</p>
pub fn availability_zone(&self) -> ::std::option::Option<&str> {
self.availability_zone.as_deref()
}
/// <p>The size of the disk in GB (<code>32</code>).</p>
pub fn size_in_gb(&self) -> ::std::option::Option<i32> {
self.size_in_gb
}
/// <p>The tag keys and optional values to add to the resource during create.</p>
/// <p>Use the <code>TagResource</code> action to tag a resource after it's created.</p>
///
/// If no value was sent for this field, a default will be set. If you want to determine if no value was sent, use `.tags.is_none()`.
pub fn tags(&self) -> &[crate::types::Tag] {
self.tags.as_deref().unwrap_or_default()
}
/// <p>An array of objects that represent the add-ons to enable for the new disk.</p>
///
/// If no value was sent for this field, a default will be set. If you want to determine if no value was sent, use `.add_ons.is_none()`.
pub fn add_ons(&self) -> &[crate::types::AddOnRequest] {
self.add_ons.as_deref().unwrap_or_default()
}
}
impl CreateDiskInput {
/// Creates a new builder-style object to manufacture [`CreateDiskInput`](crate::operation::create_disk::CreateDiskInput).
pub fn builder() -> crate::operation::create_disk::builders::CreateDiskInputBuilder {
crate::operation::create_disk::builders::CreateDiskInputBuilder::default()
}
}
/// A builder for [`CreateDiskInput`](crate::operation::create_disk::CreateDiskInput).
#[derive(::std::clone::Clone, ::std::cmp::PartialEq, ::std::default::Default, ::std::fmt::Debug)]
#[non_exhaustive]
pub struct CreateDiskInputBuilder {
pub(crate) disk_name: ::std::option::Option<::std::string::String>,
pub(crate) availability_zone: ::std::option::Option<::std::string::String>,
pub(crate) size_in_gb: ::std::option::Option<i32>,
pub(crate) tags: ::std::option::Option<::std::vec::Vec<crate::types::Tag>>,
pub(crate) add_ons: ::std::option::Option<::std::vec::Vec<crate::types::AddOnRequest>>,
}
impl CreateDiskInputBuilder {
/// <p>The unique Lightsail disk name (<code>my-disk</code>).</p>
/// This field is required.
pub fn disk_name(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
self.disk_name = ::std::option::Option::Some(input.into());
self
}
/// <p>The unique Lightsail disk name (<code>my-disk</code>).</p>
pub fn set_disk_name(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
self.disk_name = input;
self
}
/// <p>The unique Lightsail disk name (<code>my-disk</code>).</p>
pub fn get_disk_name(&self) -> &::std::option::Option<::std::string::String> {
&self.disk_name
}
/// <p>The Availability Zone where you want to create the disk (<code>us-east-2a</code>). Use the same Availability Zone as the Lightsail instance to which you want to attach the disk.</p>
/// <p>Use the <code>get regions</code> operation to list the Availability Zones where Lightsail is currently available.</p>
/// This field is required.
pub fn availability_zone(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
self.availability_zone = ::std::option::Option::Some(input.into());
self
}
/// <p>The Availability Zone where you want to create the disk (<code>us-east-2a</code>). Use the same Availability Zone as the Lightsail instance to which you want to attach the disk.</p>
/// <p>Use the <code>get regions</code> operation to list the Availability Zones where Lightsail is currently available.</p>
pub fn set_availability_zone(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
self.availability_zone = input;
self
}
/// <p>The Availability Zone where you want to create the disk (<code>us-east-2a</code>). Use the same Availability Zone as the Lightsail instance to which you want to attach the disk.</p>
/// <p>Use the <code>get regions</code> operation to list the Availability Zones where Lightsail is currently available.</p>
pub fn get_availability_zone(&self) -> &::std::option::Option<::std::string::String> {
&self.availability_zone
}
/// <p>The size of the disk in GB (<code>32</code>).</p>
/// This field is required.
pub fn size_in_gb(mut self, input: i32) -> Self {
self.size_in_gb = ::std::option::Option::Some(input);
self
}
/// <p>The size of the disk in GB (<code>32</code>).</p>
pub fn set_size_in_gb(mut self, input: ::std::option::Option<i32>) -> Self {
self.size_in_gb = input;
self
}
/// <p>The size of the disk in GB (<code>32</code>).</p>
pub fn get_size_in_gb(&self) -> &::std::option::Option<i32> {
&self.size_in_gb
}
/// Appends an item to `tags`.
///
/// To override the contents of this collection use [`set_tags`](Self::set_tags).
///
/// <p>The tag keys and optional values to add to the resource during create.</p>
/// <p>Use the <code>TagResource</code> action to tag a resource after it's created.</p>
pub fn tags(mut self, input: crate::types::Tag) -> Self {
let mut v = self.tags.unwrap_or_default();
v.push(input);
self.tags = ::std::option::Option::Some(v);
self
}
/// <p>The tag keys and optional values to add to the resource during create.</p>
/// <p>Use the <code>TagResource</code> action to tag a resource after it's created.</p>
pub fn set_tags(mut self, input: ::std::option::Option<::std::vec::Vec<crate::types::Tag>>) -> Self {
self.tags = input;
self
}
/// <p>The tag keys and optional values to add to the resource during create.</p>
/// <p>Use the <code>TagResource</code> action to tag a resource after it's created.</p>
pub fn get_tags(&self) -> &::std::option::Option<::std::vec::Vec<crate::types::Tag>> {
&self.tags
}
/// Appends an item to `add_ons`.
///
/// To override the contents of this collection use [`set_add_ons`](Self::set_add_ons).
///
/// <p>An array of objects that represent the add-ons to enable for the new disk.</p>
pub fn add_ons(mut self, input: crate::types::AddOnRequest) -> Self {
let mut v = self.add_ons.unwrap_or_default();
v.push(input);
self.add_ons = ::std::option::Option::Some(v);
self
}
/// <p>An array of objects that represent the add-ons to enable for the new disk.</p>
pub fn set_add_ons(mut self, input: ::std::option::Option<::std::vec::Vec<crate::types::AddOnRequest>>) -> Self {
self.add_ons = input;
self
}
/// <p>An array of objects that represent the add-ons to enable for the new disk.</p>
pub fn get_add_ons(&self) -> &::std::option::Option<::std::vec::Vec<crate::types::AddOnRequest>> {
&self.add_ons
}
/// Consumes the builder and constructs a [`CreateDiskInput`](crate::operation::create_disk::CreateDiskInput).
pub fn build(self) -> ::std::result::Result<crate::operation::create_disk::CreateDiskInput, ::aws_smithy_types::error::operation::BuildError> {
::std::result::Result::Ok(crate::operation::create_disk::CreateDiskInput {
disk_name: self.disk_name,
availability_zone: self.availability_zone,
size_in_gb: self.size_in_gb,
tags: self.tags,
add_ons: self.add_ons,
})
}
}