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
// 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 ModifyDocumentPermissionInput {
/// <p>The name of the document that you want to share.</p>
pub name: ::std::option::Option<::std::string::String>,
/// <p>The permission type for the document. The permission type can be <i>Share</i>.</p>
pub permission_type: ::std::option::Option<crate::types::DocumentPermissionType>,
/// <p>The Amazon Web Services users that should have access to the document. The account IDs can either be a group of account IDs or <i>All</i>. You must specify a value for this parameter or the <code>AccountIdsToRemove</code> parameter.</p>
pub account_ids_to_add: ::std::option::Option<::std::vec::Vec<::std::string::String>>,
/// <p>The Amazon Web Services users that should no longer have access to the document. The Amazon Web Services user can either be a group of account IDs or <i>All</i>. This action has a higher priority than <code>AccountIdsToAdd</code>. If you specify an ID to add and the same ID to remove, the system removes access to the document. You must specify a value for this parameter or the <code>AccountIdsToAdd</code> parameter.</p>
pub account_ids_to_remove: ::std::option::Option<::std::vec::Vec<::std::string::String>>,
/// <p>(Optional) The version of the document to share. If it isn't specified, the system choose the <code>Default</code> version to share.</p>
pub shared_document_version: ::std::option::Option<::std::string::String>,
}
impl ModifyDocumentPermissionInput {
/// <p>The name of the document that you want to share.</p>
pub fn name(&self) -> ::std::option::Option<&str> {
self.name.as_deref()
}
/// <p>The permission type for the document. The permission type can be <i>Share</i>.</p>
pub fn permission_type(&self) -> ::std::option::Option<&crate::types::DocumentPermissionType> {
self.permission_type.as_ref()
}
/// <p>The Amazon Web Services users that should have access to the document. The account IDs can either be a group of account IDs or <i>All</i>. You must specify a value for this parameter or the <code>AccountIdsToRemove</code> parameter.</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 `.account_ids_to_add.is_none()`.
pub fn account_ids_to_add(&self) -> &[::std::string::String] {
self.account_ids_to_add.as_deref().unwrap_or_default()
}
/// <p>The Amazon Web Services users that should no longer have access to the document. The Amazon Web Services user can either be a group of account IDs or <i>All</i>. This action has a higher priority than <code>AccountIdsToAdd</code>. If you specify an ID to add and the same ID to remove, the system removes access to the document. You must specify a value for this parameter or the <code>AccountIdsToAdd</code> parameter.</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 `.account_ids_to_remove.is_none()`.
pub fn account_ids_to_remove(&self) -> &[::std::string::String] {
self.account_ids_to_remove.as_deref().unwrap_or_default()
}
/// <p>(Optional) The version of the document to share. If it isn't specified, the system choose the <code>Default</code> version to share.</p>
pub fn shared_document_version(&self) -> ::std::option::Option<&str> {
self.shared_document_version.as_deref()
}
}
impl ModifyDocumentPermissionInput {
/// Creates a new builder-style object to manufacture [`ModifyDocumentPermissionInput`](crate::operation::modify_document_permission::ModifyDocumentPermissionInput).
pub fn builder() -> crate::operation::modify_document_permission::builders::ModifyDocumentPermissionInputBuilder {
crate::operation::modify_document_permission::builders::ModifyDocumentPermissionInputBuilder::default()
}
}
/// A builder for [`ModifyDocumentPermissionInput`](crate::operation::modify_document_permission::ModifyDocumentPermissionInput).
#[derive(::std::clone::Clone, ::std::cmp::PartialEq, ::std::default::Default, ::std::fmt::Debug)]
#[non_exhaustive]
pub struct ModifyDocumentPermissionInputBuilder {
pub(crate) name: ::std::option::Option<::std::string::String>,
pub(crate) permission_type: ::std::option::Option<crate::types::DocumentPermissionType>,
pub(crate) account_ids_to_add: ::std::option::Option<::std::vec::Vec<::std::string::String>>,
pub(crate) account_ids_to_remove: ::std::option::Option<::std::vec::Vec<::std::string::String>>,
pub(crate) shared_document_version: ::std::option::Option<::std::string::String>,
}
impl ModifyDocumentPermissionInputBuilder {
/// <p>The name of the document that you want to share.</p>
/// This field is required.
pub fn name(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
self.name = ::std::option::Option::Some(input.into());
self
}
/// <p>The name of the document that you want to share.</p>
pub fn set_name(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
self.name = input;
self
}
/// <p>The name of the document that you want to share.</p>
pub fn get_name(&self) -> &::std::option::Option<::std::string::String> {
&self.name
}
/// <p>The permission type for the document. The permission type can be <i>Share</i>.</p>
/// This field is required.
pub fn permission_type(mut self, input: crate::types::DocumentPermissionType) -> Self {
self.permission_type = ::std::option::Option::Some(input);
self
}
/// <p>The permission type for the document. The permission type can be <i>Share</i>.</p>
pub fn set_permission_type(mut self, input: ::std::option::Option<crate::types::DocumentPermissionType>) -> Self {
self.permission_type = input;
self
}
/// <p>The permission type for the document. The permission type can be <i>Share</i>.</p>
pub fn get_permission_type(&self) -> &::std::option::Option<crate::types::DocumentPermissionType> {
&self.permission_type
}
/// Appends an item to `account_ids_to_add`.
///
/// To override the contents of this collection use [`set_account_ids_to_add`](Self::set_account_ids_to_add).
///
/// <p>The Amazon Web Services users that should have access to the document. The account IDs can either be a group of account IDs or <i>All</i>. You must specify a value for this parameter or the <code>AccountIdsToRemove</code> parameter.</p>
pub fn account_ids_to_add(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
let mut v = self.account_ids_to_add.unwrap_or_default();
v.push(input.into());
self.account_ids_to_add = ::std::option::Option::Some(v);
self
}
/// <p>The Amazon Web Services users that should have access to the document. The account IDs can either be a group of account IDs or <i>All</i>. You must specify a value for this parameter or the <code>AccountIdsToRemove</code> parameter.</p>
pub fn set_account_ids_to_add(mut self, input: ::std::option::Option<::std::vec::Vec<::std::string::String>>) -> Self {
self.account_ids_to_add = input;
self
}
/// <p>The Amazon Web Services users that should have access to the document. The account IDs can either be a group of account IDs or <i>All</i>. You must specify a value for this parameter or the <code>AccountIdsToRemove</code> parameter.</p>
pub fn get_account_ids_to_add(&self) -> &::std::option::Option<::std::vec::Vec<::std::string::String>> {
&self.account_ids_to_add
}
/// Appends an item to `account_ids_to_remove`.
///
/// To override the contents of this collection use [`set_account_ids_to_remove`](Self::set_account_ids_to_remove).
///
/// <p>The Amazon Web Services users that should no longer have access to the document. The Amazon Web Services user can either be a group of account IDs or <i>All</i>. This action has a higher priority than <code>AccountIdsToAdd</code>. If you specify an ID to add and the same ID to remove, the system removes access to the document. You must specify a value for this parameter or the <code>AccountIdsToAdd</code> parameter.</p>
pub fn account_ids_to_remove(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
let mut v = self.account_ids_to_remove.unwrap_or_default();
v.push(input.into());
self.account_ids_to_remove = ::std::option::Option::Some(v);
self
}
/// <p>The Amazon Web Services users that should no longer have access to the document. The Amazon Web Services user can either be a group of account IDs or <i>All</i>. This action has a higher priority than <code>AccountIdsToAdd</code>. If you specify an ID to add and the same ID to remove, the system removes access to the document. You must specify a value for this parameter or the <code>AccountIdsToAdd</code> parameter.</p>
pub fn set_account_ids_to_remove(mut self, input: ::std::option::Option<::std::vec::Vec<::std::string::String>>) -> Self {
self.account_ids_to_remove = input;
self
}
/// <p>The Amazon Web Services users that should no longer have access to the document. The Amazon Web Services user can either be a group of account IDs or <i>All</i>. This action has a higher priority than <code>AccountIdsToAdd</code>. If you specify an ID to add and the same ID to remove, the system removes access to the document. You must specify a value for this parameter or the <code>AccountIdsToAdd</code> parameter.</p>
pub fn get_account_ids_to_remove(&self) -> &::std::option::Option<::std::vec::Vec<::std::string::String>> {
&self.account_ids_to_remove
}
/// <p>(Optional) The version of the document to share. If it isn't specified, the system choose the <code>Default</code> version to share.</p>
pub fn shared_document_version(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
self.shared_document_version = ::std::option::Option::Some(input.into());
self
}
/// <p>(Optional) The version of the document to share. If it isn't specified, the system choose the <code>Default</code> version to share.</p>
pub fn set_shared_document_version(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
self.shared_document_version = input;
self
}
/// <p>(Optional) The version of the document to share. If it isn't specified, the system choose the <code>Default</code> version to share.</p>
pub fn get_shared_document_version(&self) -> &::std::option::Option<::std::string::String> {
&self.shared_document_version
}
/// Consumes the builder and constructs a [`ModifyDocumentPermissionInput`](crate::operation::modify_document_permission::ModifyDocumentPermissionInput).
pub fn build(
self,
) -> ::std::result::Result<
crate::operation::modify_document_permission::ModifyDocumentPermissionInput,
::aws_smithy_types::error::operation::BuildError,
> {
::std::result::Result::Ok(crate::operation::modify_document_permission::ModifyDocumentPermissionInput {
name: self.name,
permission_type: self.permission_type,
account_ids_to_add: self.account_ids_to_add,
account_ids_to_remove: self.account_ids_to_remove,
shared_document_version: self.shared_document_version,
})
}
}