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
// 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 UpdateArtifactInput {
    /// <p>The Amazon Resource Name (ARN) of the artifact to update.</p>
    pub artifact_arn: ::std::option::Option<::std::string::String>,
    /// <p>The new name for the artifact.</p>
    pub artifact_name: ::std::option::Option<::std::string::String>,
    /// <p>The new list of properties. Overwrites the current property list.</p>
    pub properties: ::std::option::Option<::std::collections::HashMap<::std::string::String, ::std::string::String>>,
    /// <p>A list of properties to remove.</p>
    pub properties_to_remove: ::std::option::Option<::std::vec::Vec<::std::string::String>>,
}
impl UpdateArtifactInput {
    /// <p>The Amazon Resource Name (ARN) of the artifact to update.</p>
    pub fn artifact_arn(&self) -> ::std::option::Option<&str> {
        self.artifact_arn.as_deref()
    }
    /// <p>The new name for the artifact.</p>
    pub fn artifact_name(&self) -> ::std::option::Option<&str> {
        self.artifact_name.as_deref()
    }
    /// <p>The new list of properties. Overwrites the current property list.</p>
    pub fn properties(&self) -> ::std::option::Option<&::std::collections::HashMap<::std::string::String, ::std::string::String>> {
        self.properties.as_ref()
    }
    /// <p>A list of properties to remove.</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 `.properties_to_remove.is_none()`.
    pub fn properties_to_remove(&self) -> &[::std::string::String] {
        self.properties_to_remove.as_deref().unwrap_or_default()
    }
}
impl UpdateArtifactInput {
    /// Creates a new builder-style object to manufacture [`UpdateArtifactInput`](crate::operation::update_artifact::UpdateArtifactInput).
    pub fn builder() -> crate::operation::update_artifact::builders::UpdateArtifactInputBuilder {
        crate::operation::update_artifact::builders::UpdateArtifactInputBuilder::default()
    }
}

/// A builder for [`UpdateArtifactInput`](crate::operation::update_artifact::UpdateArtifactInput).
#[derive(::std::clone::Clone, ::std::cmp::PartialEq, ::std::default::Default, ::std::fmt::Debug)]
#[non_exhaustive]
pub struct UpdateArtifactInputBuilder {
    pub(crate) artifact_arn: ::std::option::Option<::std::string::String>,
    pub(crate) artifact_name: ::std::option::Option<::std::string::String>,
    pub(crate) properties: ::std::option::Option<::std::collections::HashMap<::std::string::String, ::std::string::String>>,
    pub(crate) properties_to_remove: ::std::option::Option<::std::vec::Vec<::std::string::String>>,
}
impl UpdateArtifactInputBuilder {
    /// <p>The Amazon Resource Name (ARN) of the artifact to update.</p>
    /// This field is required.
    pub fn artifact_arn(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
        self.artifact_arn = ::std::option::Option::Some(input.into());
        self
    }
    /// <p>The Amazon Resource Name (ARN) of the artifact to update.</p>
    pub fn set_artifact_arn(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
        self.artifact_arn = input;
        self
    }
    /// <p>The Amazon Resource Name (ARN) of the artifact to update.</p>
    pub fn get_artifact_arn(&self) -> &::std::option::Option<::std::string::String> {
        &self.artifact_arn
    }
    /// <p>The new name for the artifact.</p>
    pub fn artifact_name(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
        self.artifact_name = ::std::option::Option::Some(input.into());
        self
    }
    /// <p>The new name for the artifact.</p>
    pub fn set_artifact_name(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
        self.artifact_name = input;
        self
    }
    /// <p>The new name for the artifact.</p>
    pub fn get_artifact_name(&self) -> &::std::option::Option<::std::string::String> {
        &self.artifact_name
    }
    /// Adds a key-value pair to `properties`.
    ///
    /// To override the contents of this collection use [`set_properties`](Self::set_properties).
    ///
    /// <p>The new list of properties. Overwrites the current property list.</p>
    pub fn properties(mut self, k: impl ::std::convert::Into<::std::string::String>, v: impl ::std::convert::Into<::std::string::String>) -> Self {
        let mut hash_map = self.properties.unwrap_or_default();
        hash_map.insert(k.into(), v.into());
        self.properties = ::std::option::Option::Some(hash_map);
        self
    }
    /// <p>The new list of properties. Overwrites the current property list.</p>
    pub fn set_properties(mut self, input: ::std::option::Option<::std::collections::HashMap<::std::string::String, ::std::string::String>>) -> Self {
        self.properties = input;
        self
    }
    /// <p>The new list of properties. Overwrites the current property list.</p>
    pub fn get_properties(&self) -> &::std::option::Option<::std::collections::HashMap<::std::string::String, ::std::string::String>> {
        &self.properties
    }
    /// Appends an item to `properties_to_remove`.
    ///
    /// To override the contents of this collection use [`set_properties_to_remove`](Self::set_properties_to_remove).
    ///
    /// <p>A list of properties to remove.</p>
    pub fn properties_to_remove(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
        let mut v = self.properties_to_remove.unwrap_or_default();
        v.push(input.into());
        self.properties_to_remove = ::std::option::Option::Some(v);
        self
    }
    /// <p>A list of properties to remove.</p>
    pub fn set_properties_to_remove(mut self, input: ::std::option::Option<::std::vec::Vec<::std::string::String>>) -> Self {
        self.properties_to_remove = input;
        self
    }
    /// <p>A list of properties to remove.</p>
    pub fn get_properties_to_remove(&self) -> &::std::option::Option<::std::vec::Vec<::std::string::String>> {
        &self.properties_to_remove
    }
    /// Consumes the builder and constructs a [`UpdateArtifactInput`](crate::operation::update_artifact::UpdateArtifactInput).
    pub fn build(
        self,
    ) -> ::std::result::Result<crate::operation::update_artifact::UpdateArtifactInput, ::aws_smithy_types::error::operation::BuildError> {
        ::std::result::Result::Ok(crate::operation::update_artifact::UpdateArtifactInput {
            artifact_arn: self.artifact_arn,
            artifact_name: self.artifact_name,
            properties: self.properties,
            properties_to_remove: self.properties_to_remove,
        })
    }
}