aws_sdk_codebuild/operation/list_shared_projects/
builders.rs

1// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
2pub use crate::operation::list_shared_projects::_list_shared_projects_output::ListSharedProjectsOutputBuilder;
3
4pub use crate::operation::list_shared_projects::_list_shared_projects_input::ListSharedProjectsInputBuilder;
5
6impl crate::operation::list_shared_projects::builders::ListSharedProjectsInputBuilder {
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::list_shared_projects::ListSharedProjectsOutput,
13        ::aws_smithy_runtime_api::client::result::SdkError<
14            crate::operation::list_shared_projects::ListSharedProjectsError,
15            ::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
16        >,
17    > {
18        let mut fluent_builder = client.list_shared_projects();
19        fluent_builder.inner = self;
20        fluent_builder.send().await
21    }
22}
23/// Fluent builder constructing a request to `ListSharedProjects`.
24///
25/// <p>Gets a list of projects that are shared with other Amazon Web Services accounts or users.</p>
26#[derive(::std::clone::Clone, ::std::fmt::Debug)]
27pub struct ListSharedProjectsFluentBuilder {
28    handle: ::std::sync::Arc<crate::client::Handle>,
29    inner: crate::operation::list_shared_projects::builders::ListSharedProjectsInputBuilder,
30    config_override: ::std::option::Option<crate::config::Builder>,
31}
32impl
33    crate::client::customize::internal::CustomizableSend<
34        crate::operation::list_shared_projects::ListSharedProjectsOutput,
35        crate::operation::list_shared_projects::ListSharedProjectsError,
36    > for ListSharedProjectsFluentBuilder
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::list_shared_projects::ListSharedProjectsOutput,
44            crate::operation::list_shared_projects::ListSharedProjectsError,
45        >,
46    > {
47        ::std::boxed::Box::pin(async move { self.config_override(config_override).send().await })
48    }
49}
50impl ListSharedProjectsFluentBuilder {
51    /// Creates a new `ListSharedProjectsFluentBuilder`.
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 ListSharedProjects as a reference.
60    pub fn as_input(&self) -> &crate::operation::list_shared_projects::builders::ListSharedProjectsInputBuilder {
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::list_shared_projects::ListSharedProjectsOutput,
75        ::aws_smithy_runtime_api::client::result::SdkError<
76            crate::operation::list_shared_projects::ListSharedProjectsError,
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::list_shared_projects::ListSharedProjects::operation_runtime_plugins(
85            self.handle.runtime_plugins.clone(),
86            &self.handle.conf,
87            self.config_override,
88        );
89        crate::operation::list_shared_projects::ListSharedProjects::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::list_shared_projects::ListSharedProjectsOutput,
97        crate::operation::list_shared_projects::ListSharedProjectsError,
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    /// Create a paginator for this request
112    ///
113    /// Paginators are used by calling [`send().await`](crate::operation::list_shared_projects::paginator::ListSharedProjectsPaginator::send) which returns a [`PaginationStream`](aws_smithy_async::future::pagination_stream::PaginationStream).
114    pub fn into_paginator(self) -> crate::operation::list_shared_projects::paginator::ListSharedProjectsPaginator {
115        crate::operation::list_shared_projects::paginator::ListSharedProjectsPaginator::new(self.handle, self.inner)
116    }
117    /// <p>The criterion to be used to list build projects shared with the current Amazon Web Services account or user. Valid values include:</p>
118    /// <ul>
119    /// <li>
120    /// <p><code>ARN</code>: List based on the ARN.</p></li>
121    /// <li>
122    /// <p><code>MODIFIED_TIME</code>: List based on when information about the shared project was last changed.</p></li>
123    /// </ul>
124    pub fn sort_by(mut self, input: crate::types::SharedResourceSortByType) -> Self {
125        self.inner = self.inner.sort_by(input);
126        self
127    }
128    /// <p>The criterion to be used to list build projects shared with the current Amazon Web Services account or user. Valid values include:</p>
129    /// <ul>
130    /// <li>
131    /// <p><code>ARN</code>: List based on the ARN.</p></li>
132    /// <li>
133    /// <p><code>MODIFIED_TIME</code>: List based on when information about the shared project was last changed.</p></li>
134    /// </ul>
135    pub fn set_sort_by(mut self, input: ::std::option::Option<crate::types::SharedResourceSortByType>) -> Self {
136        self.inner = self.inner.set_sort_by(input);
137        self
138    }
139    /// <p>The criterion to be used to list build projects shared with the current Amazon Web Services account or user. Valid values include:</p>
140    /// <ul>
141    /// <li>
142    /// <p><code>ARN</code>: List based on the ARN.</p></li>
143    /// <li>
144    /// <p><code>MODIFIED_TIME</code>: List based on when information about the shared project was last changed.</p></li>
145    /// </ul>
146    pub fn get_sort_by(&self) -> &::std::option::Option<crate::types::SharedResourceSortByType> {
147        self.inner.get_sort_by()
148    }
149    /// <p>The order in which to list shared build projects. Valid values include:</p>
150    /// <ul>
151    /// <li>
152    /// <p><code>ASCENDING</code>: List in ascending order.</p></li>
153    /// <li>
154    /// <p><code>DESCENDING</code>: List in descending order.</p></li>
155    /// </ul>
156    pub fn sort_order(mut self, input: crate::types::SortOrderType) -> Self {
157        self.inner = self.inner.sort_order(input);
158        self
159    }
160    /// <p>The order in which to list shared build projects. Valid values include:</p>
161    /// <ul>
162    /// <li>
163    /// <p><code>ASCENDING</code>: List in ascending order.</p></li>
164    /// <li>
165    /// <p><code>DESCENDING</code>: List in descending order.</p></li>
166    /// </ul>
167    pub fn set_sort_order(mut self, input: ::std::option::Option<crate::types::SortOrderType>) -> Self {
168        self.inner = self.inner.set_sort_order(input);
169        self
170    }
171    /// <p>The order in which to list shared build projects. Valid values include:</p>
172    /// <ul>
173    /// <li>
174    /// <p><code>ASCENDING</code>: List in ascending order.</p></li>
175    /// <li>
176    /// <p><code>DESCENDING</code>: List in descending order.</p></li>
177    /// </ul>
178    pub fn get_sort_order(&self) -> &::std::option::Option<crate::types::SortOrderType> {
179        self.inner.get_sort_order()
180    }
181    /// <p>The maximum number of paginated shared build projects returned per response. Use <code>nextToken</code> to iterate pages in the list of returned <code>Project</code> objects. The default value is 100.</p>
182    pub fn max_results(mut self, input: i32) -> Self {
183        self.inner = self.inner.max_results(input);
184        self
185    }
186    /// <p>The maximum number of paginated shared build projects returned per response. Use <code>nextToken</code> to iterate pages in the list of returned <code>Project</code> objects. The default value is 100.</p>
187    pub fn set_max_results(mut self, input: ::std::option::Option<i32>) -> Self {
188        self.inner = self.inner.set_max_results(input);
189        self
190    }
191    /// <p>The maximum number of paginated shared build projects returned per response. Use <code>nextToken</code> to iterate pages in the list of returned <code>Project</code> objects. The default value is 100.</p>
192    pub fn get_max_results(&self) -> &::std::option::Option<i32> {
193        self.inner.get_max_results()
194    }
195    /// <p>During a previous call, the maximum number of items that can be returned is the value specified in <code>maxResults</code>. If there more items in the list, then a unique string called a <i>nextToken</i> is returned. To get the next batch of items in the list, call this operation again, adding the next token to the call. To get all of the items in the list, keep calling this operation with each subsequent next token that is returned, until no more next tokens are returned.</p>
196    pub fn next_token(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
197        self.inner = self.inner.next_token(input.into());
198        self
199    }
200    /// <p>During a previous call, the maximum number of items that can be returned is the value specified in <code>maxResults</code>. If there more items in the list, then a unique string called a <i>nextToken</i> is returned. To get the next batch of items in the list, call this operation again, adding the next token to the call. To get all of the items in the list, keep calling this operation with each subsequent next token that is returned, until no more next tokens are returned.</p>
201    pub fn set_next_token(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
202        self.inner = self.inner.set_next_token(input);
203        self
204    }
205    /// <p>During a previous call, the maximum number of items that can be returned is the value specified in <code>maxResults</code>. If there more items in the list, then a unique string called a <i>nextToken</i> is returned. To get the next batch of items in the list, call this operation again, adding the next token to the call. To get all of the items in the list, keep calling this operation with each subsequent next token that is returned, until no more next tokens are returned.</p>
206    pub fn get_next_token(&self) -> &::std::option::Option<::std::string::String> {
207        self.inner.get_next_token()
208    }
209}