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
// 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 CreateDiskSnapshotInput {
/// <p>The unique name of the source disk (<code>Disk-Virginia-1</code>).</p><note>
/// <p>This parameter cannot be defined together with the <code>instance name</code> parameter. The <code>disk name</code> and <code>instance name</code> parameters are mutually exclusive.</p>
/// </note>
pub disk_name: ::std::option::Option<::std::string::String>,
/// <p>The name of the destination disk snapshot (<code>my-disk-snapshot</code>) based on the source disk.</p>
pub disk_snapshot_name: ::std::option::Option<::std::string::String>,
/// <p>The unique name of the source instance (<code>Amazon_Linux-512MB-Virginia-1</code>). When this is defined, a snapshot of the instance's system volume is created.</p><note>
/// <p>This parameter cannot be defined together with the <code>disk name</code> parameter. The <code>instance name</code> and <code>disk name</code> parameters are mutually exclusive.</p>
/// </note>
pub instance_name: ::std::option::Option<::std::string::String>,
/// <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>>,
}
impl CreateDiskSnapshotInput {
/// <p>The unique name of the source disk (<code>Disk-Virginia-1</code>).</p><note>
/// <p>This parameter cannot be defined together with the <code>instance name</code> parameter. The <code>disk name</code> and <code>instance name</code> parameters are mutually exclusive.</p>
/// </note>
pub fn disk_name(&self) -> ::std::option::Option<&str> {
self.disk_name.as_deref()
}
/// <p>The name of the destination disk snapshot (<code>my-disk-snapshot</code>) based on the source disk.</p>
pub fn disk_snapshot_name(&self) -> ::std::option::Option<&str> {
self.disk_snapshot_name.as_deref()
}
/// <p>The unique name of the source instance (<code>Amazon_Linux-512MB-Virginia-1</code>). When this is defined, a snapshot of the instance's system volume is created.</p><note>
/// <p>This parameter cannot be defined together with the <code>disk name</code> parameter. The <code>instance name</code> and <code>disk name</code> parameters are mutually exclusive.</p>
/// </note>
pub fn instance_name(&self) -> ::std::option::Option<&str> {
self.instance_name.as_deref()
}
/// <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()
}
}
impl CreateDiskSnapshotInput {
/// Creates a new builder-style object to manufacture [`CreateDiskSnapshotInput`](crate::operation::create_disk_snapshot::CreateDiskSnapshotInput).
pub fn builder() -> crate::operation::create_disk_snapshot::builders::CreateDiskSnapshotInputBuilder {
crate::operation::create_disk_snapshot::builders::CreateDiskSnapshotInputBuilder::default()
}
}
/// A builder for [`CreateDiskSnapshotInput`](crate::operation::create_disk_snapshot::CreateDiskSnapshotInput).
#[derive(::std::clone::Clone, ::std::cmp::PartialEq, ::std::default::Default, ::std::fmt::Debug)]
#[non_exhaustive]
pub struct CreateDiskSnapshotInputBuilder {
pub(crate) disk_name: ::std::option::Option<::std::string::String>,
pub(crate) disk_snapshot_name: ::std::option::Option<::std::string::String>,
pub(crate) instance_name: ::std::option::Option<::std::string::String>,
pub(crate) tags: ::std::option::Option<::std::vec::Vec<crate::types::Tag>>,
}
impl CreateDiskSnapshotInputBuilder {
/// <p>The unique name of the source disk (<code>Disk-Virginia-1</code>).</p><note>
/// <p>This parameter cannot be defined together with the <code>instance name</code> parameter. The <code>disk name</code> and <code>instance name</code> parameters are mutually exclusive.</p>
/// </note>
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 name of the source disk (<code>Disk-Virginia-1</code>).</p><note>
/// <p>This parameter cannot be defined together with the <code>instance name</code> parameter. The <code>disk name</code> and <code>instance name</code> parameters are mutually exclusive.</p>
/// </note>
pub fn set_disk_name(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
self.disk_name = input;
self
}
/// <p>The unique name of the source disk (<code>Disk-Virginia-1</code>).</p><note>
/// <p>This parameter cannot be defined together with the <code>instance name</code> parameter. The <code>disk name</code> and <code>instance name</code> parameters are mutually exclusive.</p>
/// </note>
pub fn get_disk_name(&self) -> &::std::option::Option<::std::string::String> {
&self.disk_name
}
/// <p>The name of the destination disk snapshot (<code>my-disk-snapshot</code>) based on the source disk.</p>
/// This field is required.
pub fn disk_snapshot_name(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
self.disk_snapshot_name = ::std::option::Option::Some(input.into());
self
}
/// <p>The name of the destination disk snapshot (<code>my-disk-snapshot</code>) based on the source disk.</p>
pub fn set_disk_snapshot_name(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
self.disk_snapshot_name = input;
self
}
/// <p>The name of the destination disk snapshot (<code>my-disk-snapshot</code>) based on the source disk.</p>
pub fn get_disk_snapshot_name(&self) -> &::std::option::Option<::std::string::String> {
&self.disk_snapshot_name
}
/// <p>The unique name of the source instance (<code>Amazon_Linux-512MB-Virginia-1</code>). When this is defined, a snapshot of the instance's system volume is created.</p><note>
/// <p>This parameter cannot be defined together with the <code>disk name</code> parameter. The <code>instance name</code> and <code>disk name</code> parameters are mutually exclusive.</p>
/// </note>
pub fn instance_name(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
self.instance_name = ::std::option::Option::Some(input.into());
self
}
/// <p>The unique name of the source instance (<code>Amazon_Linux-512MB-Virginia-1</code>). When this is defined, a snapshot of the instance's system volume is created.</p><note>
/// <p>This parameter cannot be defined together with the <code>disk name</code> parameter. The <code>instance name</code> and <code>disk name</code> parameters are mutually exclusive.</p>
/// </note>
pub fn set_instance_name(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
self.instance_name = input;
self
}
/// <p>The unique name of the source instance (<code>Amazon_Linux-512MB-Virginia-1</code>). When this is defined, a snapshot of the instance's system volume is created.</p><note>
/// <p>This parameter cannot be defined together with the <code>disk name</code> parameter. The <code>instance name</code> and <code>disk name</code> parameters are mutually exclusive.</p>
/// </note>
pub fn get_instance_name(&self) -> &::std::option::Option<::std::string::String> {
&self.instance_name
}
/// 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
}
/// Consumes the builder and constructs a [`CreateDiskSnapshotInput`](crate::operation::create_disk_snapshot::CreateDiskSnapshotInput).
pub fn build(
self,
) -> ::std::result::Result<crate::operation::create_disk_snapshot::CreateDiskSnapshotInput, ::aws_smithy_types::error::operation::BuildError>
{
::std::result::Result::Ok(crate::operation::create_disk_snapshot::CreateDiskSnapshotInput {
disk_name: self.disk_name,
disk_snapshot_name: self.disk_snapshot_name,
instance_name: self.instance_name,
tags: self.tags,
})
}
}