aws_sdk_codestarnotifications/operation/update_notification_rule/
builders.rs

1// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
2pub use crate::operation::update_notification_rule::_update_notification_rule_output::UpdateNotificationRuleOutputBuilder;
3
4pub use crate::operation::update_notification_rule::_update_notification_rule_input::UpdateNotificationRuleInputBuilder;
5
6impl crate::operation::update_notification_rule::builders::UpdateNotificationRuleInputBuilder {
7    /// Sends a request with this input using the given client.
8    pub async fn send_with(
9        self,
10        client: &crate::Client,
11    ) -> ::std::result::Result<
12        crate::operation::update_notification_rule::UpdateNotificationRuleOutput,
13        ::aws_smithy_runtime_api::client::result::SdkError<
14            crate::operation::update_notification_rule::UpdateNotificationRuleError,
15            ::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
16        >,
17    > {
18        let mut fluent_builder = client.update_notification_rule();
19        fluent_builder.inner = self;
20        fluent_builder.send().await
21    }
22}
23/// Fluent builder constructing a request to `UpdateNotificationRule`.
24///
25/// <p>Updates a notification rule for a resource. You can change the events that trigger the notification rule, the status of the rule, and the targets that receive the notifications.</p><note>
26/// <p>To add or remove tags for a notification rule, you must use <code>TagResource</code> and <code>UntagResource</code>.</p>
27/// </note>
28#[derive(::std::clone::Clone, ::std::fmt::Debug)]
29pub struct UpdateNotificationRuleFluentBuilder {
30    handle: ::std::sync::Arc<crate::client::Handle>,
31    inner: crate::operation::update_notification_rule::builders::UpdateNotificationRuleInputBuilder,
32    config_override: ::std::option::Option<crate::config::Builder>,
33}
34impl
35    crate::client::customize::internal::CustomizableSend<
36        crate::operation::update_notification_rule::UpdateNotificationRuleOutput,
37        crate::operation::update_notification_rule::UpdateNotificationRuleError,
38    > for UpdateNotificationRuleFluentBuilder
39{
40    fn send(
41        self,
42        config_override: crate::config::Builder,
43    ) -> crate::client::customize::internal::BoxFuture<
44        crate::client::customize::internal::SendResult<
45            crate::operation::update_notification_rule::UpdateNotificationRuleOutput,
46            crate::operation::update_notification_rule::UpdateNotificationRuleError,
47        >,
48    > {
49        ::std::boxed::Box::pin(async move { self.config_override(config_override).send().await })
50    }
51}
52impl UpdateNotificationRuleFluentBuilder {
53    /// Creates a new `UpdateNotificationRuleFluentBuilder`.
54    pub(crate) fn new(handle: ::std::sync::Arc<crate::client::Handle>) -> Self {
55        Self {
56            handle,
57            inner: ::std::default::Default::default(),
58            config_override: ::std::option::Option::None,
59        }
60    }
61    /// Access the UpdateNotificationRule as a reference.
62    pub fn as_input(&self) -> &crate::operation::update_notification_rule::builders::UpdateNotificationRuleInputBuilder {
63        &self.inner
64    }
65    /// Sends the request and returns the response.
66    ///
67    /// If an error occurs, an `SdkError` will be returned with additional details that
68    /// can be matched against.
69    ///
70    /// By default, any retryable failures will be retried twice. Retry behavior
71    /// is configurable with the [RetryConfig](aws_smithy_types::retry::RetryConfig), which can be
72    /// set when configuring the client.
73    pub async fn send(
74        self,
75    ) -> ::std::result::Result<
76        crate::operation::update_notification_rule::UpdateNotificationRuleOutput,
77        ::aws_smithy_runtime_api::client::result::SdkError<
78            crate::operation::update_notification_rule::UpdateNotificationRuleError,
79            ::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
80        >,
81    > {
82        let input = self
83            .inner
84            .build()
85            .map_err(::aws_smithy_runtime_api::client::result::SdkError::construction_failure)?;
86        let runtime_plugins = crate::operation::update_notification_rule::UpdateNotificationRule::operation_runtime_plugins(
87            self.handle.runtime_plugins.clone(),
88            &self.handle.conf,
89            self.config_override,
90        );
91        crate::operation::update_notification_rule::UpdateNotificationRule::orchestrate(&runtime_plugins, input).await
92    }
93
94    /// Consumes this builder, creating a customizable operation that can be modified before being sent.
95    pub fn customize(
96        self,
97    ) -> crate::client::customize::CustomizableOperation<
98        crate::operation::update_notification_rule::UpdateNotificationRuleOutput,
99        crate::operation::update_notification_rule::UpdateNotificationRuleError,
100        Self,
101    > {
102        crate::client::customize::CustomizableOperation::new(self)
103    }
104    pub(crate) fn config_override(mut self, config_override: impl ::std::convert::Into<crate::config::Builder>) -> Self {
105        self.set_config_override(::std::option::Option::Some(config_override.into()));
106        self
107    }
108
109    pub(crate) fn set_config_override(&mut self, config_override: ::std::option::Option<crate::config::Builder>) -> &mut Self {
110        self.config_override = config_override;
111        self
112    }
113    /// <p>The Amazon Resource Name (ARN) of the notification rule.</p>
114    pub fn arn(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
115        self.inner = self.inner.arn(input.into());
116        self
117    }
118    /// <p>The Amazon Resource Name (ARN) of the notification rule.</p>
119    pub fn set_arn(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
120        self.inner = self.inner.set_arn(input);
121        self
122    }
123    /// <p>The Amazon Resource Name (ARN) of the notification rule.</p>
124    pub fn get_arn(&self) -> &::std::option::Option<::std::string::String> {
125        self.inner.get_arn()
126    }
127    /// <p>The name of the notification rule.</p>
128    pub fn name(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
129        self.inner = self.inner.name(input.into());
130        self
131    }
132    /// <p>The name of the notification rule.</p>
133    pub fn set_name(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
134        self.inner = self.inner.set_name(input);
135        self
136    }
137    /// <p>The name of the notification rule.</p>
138    pub fn get_name(&self) -> &::std::option::Option<::std::string::String> {
139        self.inner.get_name()
140    }
141    /// <p>The status of the notification rule. Valid statuses include enabled (sending notifications) or disabled (not sending notifications).</p>
142    pub fn status(mut self, input: crate::types::NotificationRuleStatus) -> Self {
143        self.inner = self.inner.status(input);
144        self
145    }
146    /// <p>The status of the notification rule. Valid statuses include enabled (sending notifications) or disabled (not sending notifications).</p>
147    pub fn set_status(mut self, input: ::std::option::Option<crate::types::NotificationRuleStatus>) -> Self {
148        self.inner = self.inner.set_status(input);
149        self
150    }
151    /// <p>The status of the notification rule. Valid statuses include enabled (sending notifications) or disabled (not sending notifications).</p>
152    pub fn get_status(&self) -> &::std::option::Option<crate::types::NotificationRuleStatus> {
153        self.inner.get_status()
154    }
155    ///
156    /// Appends an item to `EventTypeIds`.
157    ///
158    /// To override the contents of this collection use [`set_event_type_ids`](Self::set_event_type_ids).
159    ///
160    /// <p>A list of event types associated with this notification rule. For a complete list of event types and IDs, see <a href="https://docs.aws.amazon.com/codestar-notifications/latest/userguide/concepts.html#concepts-api">Notification concepts</a> in the <i>Developer Tools Console User Guide</i>.</p>
161    pub fn event_type_ids(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
162        self.inner = self.inner.event_type_ids(input.into());
163        self
164    }
165    /// <p>A list of event types associated with this notification rule. For a complete list of event types and IDs, see <a href="https://docs.aws.amazon.com/codestar-notifications/latest/userguide/concepts.html#concepts-api">Notification concepts</a> in the <i>Developer Tools Console User Guide</i>.</p>
166    pub fn set_event_type_ids(mut self, input: ::std::option::Option<::std::vec::Vec<::std::string::String>>) -> Self {
167        self.inner = self.inner.set_event_type_ids(input);
168        self
169    }
170    /// <p>A list of event types associated with this notification rule. For a complete list of event types and IDs, see <a href="https://docs.aws.amazon.com/codestar-notifications/latest/userguide/concepts.html#concepts-api">Notification concepts</a> in the <i>Developer Tools Console User Guide</i>.</p>
171    pub fn get_event_type_ids(&self) -> &::std::option::Option<::std::vec::Vec<::std::string::String>> {
172        self.inner.get_event_type_ids()
173    }
174    ///
175    /// Appends an item to `Targets`.
176    ///
177    /// To override the contents of this collection use [`set_targets`](Self::set_targets).
178    ///
179    /// <p>The address and type of the targets to receive notifications from this notification rule.</p>
180    pub fn targets(mut self, input: crate::types::Target) -> Self {
181        self.inner = self.inner.targets(input);
182        self
183    }
184    /// <p>The address and type of the targets to receive notifications from this notification rule.</p>
185    pub fn set_targets(mut self, input: ::std::option::Option<::std::vec::Vec<crate::types::Target>>) -> Self {
186        self.inner = self.inner.set_targets(input);
187        self
188    }
189    /// <p>The address and type of the targets to receive notifications from this notification rule.</p>
190    pub fn get_targets(&self) -> &::std::option::Option<::std::vec::Vec<crate::types::Target>> {
191        self.inner.get_targets()
192    }
193    /// <p>The level of detail to include in the notifications for this resource. BASIC will include only the contents of the event as it would appear in Amazon CloudWatch. FULL will include any supplemental information provided by AWS CodeStar Notifications and/or the service for the resource for which the notification is created.</p>
194    pub fn detail_type(mut self, input: crate::types::DetailType) -> Self {
195        self.inner = self.inner.detail_type(input);
196        self
197    }
198    /// <p>The level of detail to include in the notifications for this resource. BASIC will include only the contents of the event as it would appear in Amazon CloudWatch. FULL will include any supplemental information provided by AWS CodeStar Notifications and/or the service for the resource for which the notification is created.</p>
199    pub fn set_detail_type(mut self, input: ::std::option::Option<crate::types::DetailType>) -> Self {
200        self.inner = self.inner.set_detail_type(input);
201        self
202    }
203    /// <p>The level of detail to include in the notifications for this resource. BASIC will include only the contents of the event as it would appear in Amazon CloudWatch. FULL will include any supplemental information provided by AWS CodeStar Notifications and/or the service for the resource for which the notification is created.</p>
204    pub fn get_detail_type(&self) -> &::std::option::Option<crate::types::DetailType> {
205        self.inner.get_detail_type()
206    }
207}