aws_sdk_mediapackagev2/operation/create_channel_group/
builders.rs

1// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
2pub use crate::operation::create_channel_group::_create_channel_group_output::CreateChannelGroupOutputBuilder;
3
4pub use crate::operation::create_channel_group::_create_channel_group_input::CreateChannelGroupInputBuilder;
5
6impl crate::operation::create_channel_group::builders::CreateChannelGroupInputBuilder {
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::create_channel_group::CreateChannelGroupOutput,
13        ::aws_smithy_runtime_api::client::result::SdkError<
14            crate::operation::create_channel_group::CreateChannelGroupError,
15            ::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
16        >,
17    > {
18        let mut fluent_builder = client.create_channel_group();
19        fluent_builder.inner = self;
20        fluent_builder.send().await
21    }
22}
23/// Fluent builder constructing a request to `CreateChannelGroup`.
24///
25/// <p>Create a channel group to group your channels and origin endpoints. A channel group is the top-level resource that consists of channels and origin endpoints that are associated with it and that provides predictable URLs for stream delivery. All channels and origin endpoints within the channel group are guaranteed to share the DNS. You can create only one channel group with each request.</p>
26#[derive(::std::clone::Clone, ::std::fmt::Debug)]
27pub struct CreateChannelGroupFluentBuilder {
28    handle: ::std::sync::Arc<crate::client::Handle>,
29    inner: crate::operation::create_channel_group::builders::CreateChannelGroupInputBuilder,
30    config_override: ::std::option::Option<crate::config::Builder>,
31}
32impl
33    crate::client::customize::internal::CustomizableSend<
34        crate::operation::create_channel_group::CreateChannelGroupOutput,
35        crate::operation::create_channel_group::CreateChannelGroupError,
36    > for CreateChannelGroupFluentBuilder
37{
38    fn send(
39        self,
40        config_override: crate::config::Builder,
41    ) -> crate::client::customize::internal::BoxFuture<
42        crate::client::customize::internal::SendResult<
43            crate::operation::create_channel_group::CreateChannelGroupOutput,
44            crate::operation::create_channel_group::CreateChannelGroupError,
45        >,
46    > {
47        ::std::boxed::Box::pin(async move { self.config_override(config_override).send().await })
48    }
49}
50impl CreateChannelGroupFluentBuilder {
51    /// Creates a new `CreateChannelGroupFluentBuilder`.
52    pub(crate) fn new(handle: ::std::sync::Arc<crate::client::Handle>) -> Self {
53        Self {
54            handle,
55            inner: ::std::default::Default::default(),
56            config_override: ::std::option::Option::None,
57        }
58    }
59    /// Access the CreateChannelGroup as a reference.
60    pub fn as_input(&self) -> &crate::operation::create_channel_group::builders::CreateChannelGroupInputBuilder {
61        &self.inner
62    }
63    /// Sends the request and returns the response.
64    ///
65    /// If an error occurs, an `SdkError` will be returned with additional details that
66    /// can be matched against.
67    ///
68    /// By default, any retryable failures will be retried twice. Retry behavior
69    /// is configurable with the [RetryConfig](aws_smithy_types::retry::RetryConfig), which can be
70    /// set when configuring the client.
71    pub async fn send(
72        self,
73    ) -> ::std::result::Result<
74        crate::operation::create_channel_group::CreateChannelGroupOutput,
75        ::aws_smithy_runtime_api::client::result::SdkError<
76            crate::operation::create_channel_group::CreateChannelGroupError,
77            ::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
78        >,
79    > {
80        let input = self
81            .inner
82            .build()
83            .map_err(::aws_smithy_runtime_api::client::result::SdkError::construction_failure)?;
84        let runtime_plugins = crate::operation::create_channel_group::CreateChannelGroup::operation_runtime_plugins(
85            self.handle.runtime_plugins.clone(),
86            &self.handle.conf,
87            self.config_override,
88        );
89        crate::operation::create_channel_group::CreateChannelGroup::orchestrate(&runtime_plugins, input).await
90    }
91
92    /// Consumes this builder, creating a customizable operation that can be modified before being sent.
93    pub fn customize(
94        self,
95    ) -> crate::client::customize::CustomizableOperation<
96        crate::operation::create_channel_group::CreateChannelGroupOutput,
97        crate::operation::create_channel_group::CreateChannelGroupError,
98        Self,
99    > {
100        crate::client::customize::CustomizableOperation::new(self)
101    }
102    pub(crate) fn config_override(mut self, config_override: impl ::std::convert::Into<crate::config::Builder>) -> Self {
103        self.set_config_override(::std::option::Option::Some(config_override.into()));
104        self
105    }
106
107    pub(crate) fn set_config_override(&mut self, config_override: ::std::option::Option<crate::config::Builder>) -> &mut Self {
108        self.config_override = config_override;
109        self
110    }
111    /// <p>The name that describes the channel group. The name is the primary identifier for the channel group, and must be unique for your account in the AWS Region. You can't use spaces in the name. You can't change the name after you create the channel group.</p>
112    pub fn channel_group_name(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
113        self.inner = self.inner.channel_group_name(input.into());
114        self
115    }
116    /// <p>The name that describes the channel group. The name is the primary identifier for the channel group, and must be unique for your account in the AWS Region. You can't use spaces in the name. You can't change the name after you create the channel group.</p>
117    pub fn set_channel_group_name(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
118        self.inner = self.inner.set_channel_group_name(input);
119        self
120    }
121    /// <p>The name that describes the channel group. The name is the primary identifier for the channel group, and must be unique for your account in the AWS Region. You can't use spaces in the name. You can't change the name after you create the channel group.</p>
122    pub fn get_channel_group_name(&self) -> &::std::option::Option<::std::string::String> {
123        self.inner.get_channel_group_name()
124    }
125    /// <p>A unique, case-sensitive token that you provide to ensure the idempotency of the request.</p>
126    pub fn client_token(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
127        self.inner = self.inner.client_token(input.into());
128        self
129    }
130    /// <p>A unique, case-sensitive token that you provide to ensure the idempotency of the request.</p>
131    pub fn set_client_token(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
132        self.inner = self.inner.set_client_token(input);
133        self
134    }
135    /// <p>A unique, case-sensitive token that you provide to ensure the idempotency of the request.</p>
136    pub fn get_client_token(&self) -> &::std::option::Option<::std::string::String> {
137        self.inner.get_client_token()
138    }
139    /// <p>Enter any descriptive text that helps you to identify the channel group.</p>
140    pub fn description(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
141        self.inner = self.inner.description(input.into());
142        self
143    }
144    /// <p>Enter any descriptive text that helps you to identify the channel group.</p>
145    pub fn set_description(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
146        self.inner = self.inner.set_description(input);
147        self
148    }
149    /// <p>Enter any descriptive text that helps you to identify the channel group.</p>
150    pub fn get_description(&self) -> &::std::option::Option<::std::string::String> {
151        self.inner.get_description()
152    }
153    ///
154    /// Adds a key-value pair to `Tags`.
155    ///
156    /// To override the contents of this collection use [`set_tags`](Self::set_tags).
157    ///
158    /// <p>A comma-separated list of tag key:value pairs that you define. For example:</p>
159    /// <p><code>"Key1": "Value1",</code></p>
160    /// <p><code>"Key2": "Value2"</code></p>
161    pub fn tags(mut self, k: impl ::std::convert::Into<::std::string::String>, v: impl ::std::convert::Into<::std::string::String>) -> Self {
162        self.inner = self.inner.tags(k.into(), v.into());
163        self
164    }
165    /// <p>A comma-separated list of tag key:value pairs that you define. For example:</p>
166    /// <p><code>"Key1": "Value1",</code></p>
167    /// <p><code>"Key2": "Value2"</code></p>
168    pub fn set_tags(mut self, input: ::std::option::Option<::std::collections::HashMap<::std::string::String, ::std::string::String>>) -> Self {
169        self.inner = self.inner.set_tags(input);
170        self
171    }
172    /// <p>A comma-separated list of tag key:value pairs that you define. For example:</p>
173    /// <p><code>"Key1": "Value1",</code></p>
174    /// <p><code>"Key2": "Value2"</code></p>
175    pub fn get_tags(&self) -> &::std::option::Option<::std::collections::HashMap<::std::string::String, ::std::string::String>> {
176        self.inner.get_tags()
177    }
178}