aws_sdk_batch/operation/list_jobs/
builders.rs

1// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
2pub use crate::operation::list_jobs::_list_jobs_output::ListJobsOutputBuilder;
3
4pub use crate::operation::list_jobs::_list_jobs_input::ListJobsInputBuilder;
5
6impl crate::operation::list_jobs::builders::ListJobsInputBuilder {
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_jobs::ListJobsOutput,
13        ::aws_smithy_runtime_api::client::result::SdkError<
14            crate::operation::list_jobs::ListJobsError,
15            ::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
16        >,
17    > {
18        let mut fluent_builder = client.list_jobs();
19        fluent_builder.inner = self;
20        fluent_builder.send().await
21    }
22}
23/// Fluent builder constructing a request to `ListJobs`.
24///
25/// <p>Returns a list of Batch jobs.</p>
26/// <p>You must specify only one of the following items:</p>
27/// <ul>
28/// <li>
29/// <p>A job queue ID to return a list of jobs in that job queue</p></li>
30/// <li>
31/// <p>A multi-node parallel job ID to return a list of nodes for that job</p></li>
32/// <li>
33/// <p>An array job ID to return a list of the children for that job</p></li>
34/// </ul>
35/// <p>You can filter the results by job status with the <code>jobStatus</code> parameter. If you don't specify a status, only <code>RUNNING</code> jobs are returned.</p>
36#[derive(::std::clone::Clone, ::std::fmt::Debug)]
37pub struct ListJobsFluentBuilder {
38    handle: ::std::sync::Arc<crate::client::Handle>,
39    inner: crate::operation::list_jobs::builders::ListJobsInputBuilder,
40    config_override: ::std::option::Option<crate::config::Builder>,
41}
42impl crate::client::customize::internal::CustomizableSend<crate::operation::list_jobs::ListJobsOutput, crate::operation::list_jobs::ListJobsError>
43    for ListJobsFluentBuilder
44{
45    fn send(
46        self,
47        config_override: crate::config::Builder,
48    ) -> crate::client::customize::internal::BoxFuture<
49        crate::client::customize::internal::SendResult<crate::operation::list_jobs::ListJobsOutput, crate::operation::list_jobs::ListJobsError>,
50    > {
51        ::std::boxed::Box::pin(async move { self.config_override(config_override).send().await })
52    }
53}
54impl ListJobsFluentBuilder {
55    /// Creates a new `ListJobsFluentBuilder`.
56    pub(crate) fn new(handle: ::std::sync::Arc<crate::client::Handle>) -> Self {
57        Self {
58            handle,
59            inner: ::std::default::Default::default(),
60            config_override: ::std::option::Option::None,
61        }
62    }
63    /// Access the ListJobs as a reference.
64    pub fn as_input(&self) -> &crate::operation::list_jobs::builders::ListJobsInputBuilder {
65        &self.inner
66    }
67    /// Sends the request and returns the response.
68    ///
69    /// If an error occurs, an `SdkError` will be returned with additional details that
70    /// can be matched against.
71    ///
72    /// By default, any retryable failures will be retried twice. Retry behavior
73    /// is configurable with the [RetryConfig](aws_smithy_types::retry::RetryConfig), which can be
74    /// set when configuring the client.
75    pub async fn send(
76        self,
77    ) -> ::std::result::Result<
78        crate::operation::list_jobs::ListJobsOutput,
79        ::aws_smithy_runtime_api::client::result::SdkError<
80            crate::operation::list_jobs::ListJobsError,
81            ::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
82        >,
83    > {
84        let input = self
85            .inner
86            .build()
87            .map_err(::aws_smithy_runtime_api::client::result::SdkError::construction_failure)?;
88        let runtime_plugins = crate::operation::list_jobs::ListJobs::operation_runtime_plugins(
89            self.handle.runtime_plugins.clone(),
90            &self.handle.conf,
91            self.config_override,
92        );
93        crate::operation::list_jobs::ListJobs::orchestrate(&runtime_plugins, input).await
94    }
95
96    /// Consumes this builder, creating a customizable operation that can be modified before being sent.
97    pub fn customize(
98        self,
99    ) -> crate::client::customize::CustomizableOperation<crate::operation::list_jobs::ListJobsOutput, crate::operation::list_jobs::ListJobsError, Self>
100    {
101        crate::client::customize::CustomizableOperation::new(self)
102    }
103    pub(crate) fn config_override(mut self, config_override: impl ::std::convert::Into<crate::config::Builder>) -> Self {
104        self.set_config_override(::std::option::Option::Some(config_override.into()));
105        self
106    }
107
108    pub(crate) fn set_config_override(&mut self, config_override: ::std::option::Option<crate::config::Builder>) -> &mut Self {
109        self.config_override = config_override;
110        self
111    }
112    /// Create a paginator for this request
113    ///
114    /// Paginators are used by calling [`send().await`](crate::operation::list_jobs::paginator::ListJobsPaginator::send) which returns a [`PaginationStream`](aws_smithy_async::future::pagination_stream::PaginationStream).
115    pub fn into_paginator(self) -> crate::operation::list_jobs::paginator::ListJobsPaginator {
116        crate::operation::list_jobs::paginator::ListJobsPaginator::new(self.handle, self.inner)
117    }
118    /// <p>The name or full Amazon Resource Name (ARN) of the job queue used to list jobs.</p>
119    pub fn job_queue(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
120        self.inner = self.inner.job_queue(input.into());
121        self
122    }
123    /// <p>The name or full Amazon Resource Name (ARN) of the job queue used to list jobs.</p>
124    pub fn set_job_queue(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
125        self.inner = self.inner.set_job_queue(input);
126        self
127    }
128    /// <p>The name or full Amazon Resource Name (ARN) of the job queue used to list jobs.</p>
129    pub fn get_job_queue(&self) -> &::std::option::Option<::std::string::String> {
130        self.inner.get_job_queue()
131    }
132    /// <p>The job ID for an array job. Specifying an array job ID with this parameter lists all child jobs from within the specified array.</p>
133    pub fn array_job_id(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
134        self.inner = self.inner.array_job_id(input.into());
135        self
136    }
137    /// <p>The job ID for an array job. Specifying an array job ID with this parameter lists all child jobs from within the specified array.</p>
138    pub fn set_array_job_id(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
139        self.inner = self.inner.set_array_job_id(input);
140        self
141    }
142    /// <p>The job ID for an array job. Specifying an array job ID with this parameter lists all child jobs from within the specified array.</p>
143    pub fn get_array_job_id(&self) -> &::std::option::Option<::std::string::String> {
144        self.inner.get_array_job_id()
145    }
146    /// <p>The job ID for a multi-node parallel job. Specifying a multi-node parallel job ID with this parameter lists all nodes that are associated with the specified job.</p>
147    pub fn multi_node_job_id(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
148        self.inner = self.inner.multi_node_job_id(input.into());
149        self
150    }
151    /// <p>The job ID for a multi-node parallel job. Specifying a multi-node parallel job ID with this parameter lists all nodes that are associated with the specified job.</p>
152    pub fn set_multi_node_job_id(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
153        self.inner = self.inner.set_multi_node_job_id(input);
154        self
155    }
156    /// <p>The job ID for a multi-node parallel job. Specifying a multi-node parallel job ID with this parameter lists all nodes that are associated with the specified job.</p>
157    pub fn get_multi_node_job_id(&self) -> &::std::option::Option<::std::string::String> {
158        self.inner.get_multi_node_job_id()
159    }
160    /// <p>The job status used to filter jobs in the specified queue. If the <code>filters</code> parameter is specified, the <code>jobStatus</code> parameter is ignored and jobs with any status are returned. If you don't specify a status, only <code>RUNNING</code> jobs are returned.</p>
161    pub fn job_status(mut self, input: crate::types::JobStatus) -> Self {
162        self.inner = self.inner.job_status(input);
163        self
164    }
165    /// <p>The job status used to filter jobs in the specified queue. If the <code>filters</code> parameter is specified, the <code>jobStatus</code> parameter is ignored and jobs with any status are returned. If you don't specify a status, only <code>RUNNING</code> jobs are returned.</p>
166    pub fn set_job_status(mut self, input: ::std::option::Option<crate::types::JobStatus>) -> Self {
167        self.inner = self.inner.set_job_status(input);
168        self
169    }
170    /// <p>The job status used to filter jobs in the specified queue. If the <code>filters</code> parameter is specified, the <code>jobStatus</code> parameter is ignored and jobs with any status are returned. If you don't specify a status, only <code>RUNNING</code> jobs are returned.</p>
171    pub fn get_job_status(&self) -> &::std::option::Option<crate::types::JobStatus> {
172        self.inner.get_job_status()
173    }
174    /// <p>The maximum number of results returned by <code>ListJobs</code> in a paginated output. When this parameter is used, <code>ListJobs</code> returns up to <code>maxResults</code> results in a single page and a <code>nextToken</code> response element, if applicable. The remaining results of the initial request can be seen by sending another <code>ListJobs</code> request with the returned <code>nextToken</code> value.</p>
175    /// <p>The following outlines key parameters and limitations:</p>
176    /// <ul>
177    /// <li>
178    /// <p>The minimum value is 1.</p></li>
179    /// <li>
180    /// <p>When <code>--job-status</code> is used, Batch returns up to 1000 values.</p></li>
181    /// <li>
182    /// <p>When <code>--filters</code> is used, Batch returns up to 100 values.</p></li>
183    /// <li>
184    /// <p>If neither parameter is used, then <code>ListJobs</code> returns up to 1000 results (jobs that are in the <code>RUNNING</code> status) and a <code>nextToken</code> value, if applicable.</p></li>
185    /// </ul>
186    pub fn max_results(mut self, input: i32) -> Self {
187        self.inner = self.inner.max_results(input);
188        self
189    }
190    /// <p>The maximum number of results returned by <code>ListJobs</code> in a paginated output. When this parameter is used, <code>ListJobs</code> returns up to <code>maxResults</code> results in a single page and a <code>nextToken</code> response element, if applicable. The remaining results of the initial request can be seen by sending another <code>ListJobs</code> request with the returned <code>nextToken</code> value.</p>
191    /// <p>The following outlines key parameters and limitations:</p>
192    /// <ul>
193    /// <li>
194    /// <p>The minimum value is 1.</p></li>
195    /// <li>
196    /// <p>When <code>--job-status</code> is used, Batch returns up to 1000 values.</p></li>
197    /// <li>
198    /// <p>When <code>--filters</code> is used, Batch returns up to 100 values.</p></li>
199    /// <li>
200    /// <p>If neither parameter is used, then <code>ListJobs</code> returns up to 1000 results (jobs that are in the <code>RUNNING</code> status) and a <code>nextToken</code> value, if applicable.</p></li>
201    /// </ul>
202    pub fn set_max_results(mut self, input: ::std::option::Option<i32>) -> Self {
203        self.inner = self.inner.set_max_results(input);
204        self
205    }
206    /// <p>The maximum number of results returned by <code>ListJobs</code> in a paginated output. When this parameter is used, <code>ListJobs</code> returns up to <code>maxResults</code> results in a single page and a <code>nextToken</code> response element, if applicable. The remaining results of the initial request can be seen by sending another <code>ListJobs</code> request with the returned <code>nextToken</code> value.</p>
207    /// <p>The following outlines key parameters and limitations:</p>
208    /// <ul>
209    /// <li>
210    /// <p>The minimum value is 1.</p></li>
211    /// <li>
212    /// <p>When <code>--job-status</code> is used, Batch returns up to 1000 values.</p></li>
213    /// <li>
214    /// <p>When <code>--filters</code> is used, Batch returns up to 100 values.</p></li>
215    /// <li>
216    /// <p>If neither parameter is used, then <code>ListJobs</code> returns up to 1000 results (jobs that are in the <code>RUNNING</code> status) and a <code>nextToken</code> value, if applicable.</p></li>
217    /// </ul>
218    pub fn get_max_results(&self) -> &::std::option::Option<i32> {
219        self.inner.get_max_results()
220    }
221    /// <p>The <code>nextToken</code> value returned from a previous paginated <code>ListJobs</code> request where <code>maxResults</code> was used and the results exceeded the value of that parameter. Pagination continues from the end of the previous results that returned the <code>nextToken</code> value. This value is <code>null</code> when there are no more results to return.</p><note>
222    /// <p>Treat this token as an opaque identifier that's only used to retrieve the next items in a list and not for other programmatic purposes.</p>
223    /// </note>
224    pub fn next_token(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
225        self.inner = self.inner.next_token(input.into());
226        self
227    }
228    /// <p>The <code>nextToken</code> value returned from a previous paginated <code>ListJobs</code> request where <code>maxResults</code> was used and the results exceeded the value of that parameter. Pagination continues from the end of the previous results that returned the <code>nextToken</code> value. This value is <code>null</code> when there are no more results to return.</p><note>
229    /// <p>Treat this token as an opaque identifier that's only used to retrieve the next items in a list and not for other programmatic purposes.</p>
230    /// </note>
231    pub fn set_next_token(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
232        self.inner = self.inner.set_next_token(input);
233        self
234    }
235    /// <p>The <code>nextToken</code> value returned from a previous paginated <code>ListJobs</code> request where <code>maxResults</code> was used and the results exceeded the value of that parameter. Pagination continues from the end of the previous results that returned the <code>nextToken</code> value. This value is <code>null</code> when there are no more results to return.</p><note>
236    /// <p>Treat this token as an opaque identifier that's only used to retrieve the next items in a list and not for other programmatic purposes.</p>
237    /// </note>
238    pub fn get_next_token(&self) -> &::std::option::Option<::std::string::String> {
239        self.inner.get_next_token()
240    }
241    ///
242    /// Appends an item to `filters`.
243    ///
244    /// To override the contents of this collection use [`set_filters`](Self::set_filters).
245    ///
246    /// <p>The filter to apply to the query. Only one filter can be used at a time. When the filter is used, <code>jobStatus</code> is ignored. The filter doesn't apply to child jobs in an array or multi-node parallel (MNP) jobs. The results are sorted by the <code>createdAt</code> field, with the most recent jobs being first.</p>
247    /// <dl>
248    /// <dt>
249    /// JOB_NAME
250    /// </dt>
251    /// <dd>
252    /// <p>The value of the filter is a case-insensitive match for the job name. If the value ends with an asterisk (*), the filter matches any job name that begins with the string before the '*'. This corresponds to the <code>jobName</code> value. For example, <code>test1</code> matches both <code>Test1</code> and <code>test1</code>, and <code>test1*</code> matches both <code>test1</code> and <code>Test10</code>. When the <code>JOB_NAME</code> filter is used, the results are grouped by the job name and version.</p>
253    /// </dd>
254    /// <dt>
255    /// JOB_DEFINITION
256    /// </dt>
257    /// <dd>
258    /// <p>The value for the filter is the name or Amazon Resource Name (ARN) of the job definition. This corresponds to the <code>jobDefinition</code> value. The value is case sensitive. When the value for the filter is the job definition name, the results include all the jobs that used any revision of that job definition name. If the value ends with an asterisk (*), the filter matches any job definition name that begins with the string before the '*'. For example, <code>jd1</code> matches only <code>jd1</code>, and <code>jd1*</code> matches both <code>jd1</code> and <code>jd1A</code>. The version of the job definition that's used doesn't affect the sort order. When the <code>JOB_DEFINITION</code> filter is used and the ARN is used (which is in the form <code>arn:${Partition}:batch:${Region}:${Account}:job-definition/${JobDefinitionName}:${Revision}</code>), the results include jobs that used the specified revision of the job definition. Asterisk (*) isn't supported when the ARN is used.</p>
259    /// </dd>
260    /// <dt>
261    /// BEFORE_CREATED_AT
262    /// </dt>
263    /// <dd>
264    /// <p>The value for the filter is the time that's before the job was created. This corresponds to the <code>createdAt</code> value. The value is a string representation of the number of milliseconds since 00:00:00 UTC (midnight) on January 1, 1970.</p>
265    /// </dd>
266    /// <dt>
267    /// AFTER_CREATED_AT
268    /// </dt>
269    /// <dd>
270    /// <p>The value for the filter is the time that's after the job was created. This corresponds to the <code>createdAt</code> value. The value is a string representation of the number of milliseconds since 00:00:00 UTC (midnight) on January 1, 1970.</p>
271    /// </dd>
272    /// </dl>
273    pub fn filters(mut self, input: crate::types::KeyValuesPair) -> Self {
274        self.inner = self.inner.filters(input);
275        self
276    }
277    /// <p>The filter to apply to the query. Only one filter can be used at a time. When the filter is used, <code>jobStatus</code> is ignored. The filter doesn't apply to child jobs in an array or multi-node parallel (MNP) jobs. The results are sorted by the <code>createdAt</code> field, with the most recent jobs being first.</p>
278    /// <dl>
279    /// <dt>
280    /// JOB_NAME
281    /// </dt>
282    /// <dd>
283    /// <p>The value of the filter is a case-insensitive match for the job name. If the value ends with an asterisk (*), the filter matches any job name that begins with the string before the '*'. This corresponds to the <code>jobName</code> value. For example, <code>test1</code> matches both <code>Test1</code> and <code>test1</code>, and <code>test1*</code> matches both <code>test1</code> and <code>Test10</code>. When the <code>JOB_NAME</code> filter is used, the results are grouped by the job name and version.</p>
284    /// </dd>
285    /// <dt>
286    /// JOB_DEFINITION
287    /// </dt>
288    /// <dd>
289    /// <p>The value for the filter is the name or Amazon Resource Name (ARN) of the job definition. This corresponds to the <code>jobDefinition</code> value. The value is case sensitive. When the value for the filter is the job definition name, the results include all the jobs that used any revision of that job definition name. If the value ends with an asterisk (*), the filter matches any job definition name that begins with the string before the '*'. For example, <code>jd1</code> matches only <code>jd1</code>, and <code>jd1*</code> matches both <code>jd1</code> and <code>jd1A</code>. The version of the job definition that's used doesn't affect the sort order. When the <code>JOB_DEFINITION</code> filter is used and the ARN is used (which is in the form <code>arn:${Partition}:batch:${Region}:${Account}:job-definition/${JobDefinitionName}:${Revision}</code>), the results include jobs that used the specified revision of the job definition. Asterisk (*) isn't supported when the ARN is used.</p>
290    /// </dd>
291    /// <dt>
292    /// BEFORE_CREATED_AT
293    /// </dt>
294    /// <dd>
295    /// <p>The value for the filter is the time that's before the job was created. This corresponds to the <code>createdAt</code> value. The value is a string representation of the number of milliseconds since 00:00:00 UTC (midnight) on January 1, 1970.</p>
296    /// </dd>
297    /// <dt>
298    /// AFTER_CREATED_AT
299    /// </dt>
300    /// <dd>
301    /// <p>The value for the filter is the time that's after the job was created. This corresponds to the <code>createdAt</code> value. The value is a string representation of the number of milliseconds since 00:00:00 UTC (midnight) on January 1, 1970.</p>
302    /// </dd>
303    /// </dl>
304    pub fn set_filters(mut self, input: ::std::option::Option<::std::vec::Vec<crate::types::KeyValuesPair>>) -> Self {
305        self.inner = self.inner.set_filters(input);
306        self
307    }
308    /// <p>The filter to apply to the query. Only one filter can be used at a time. When the filter is used, <code>jobStatus</code> is ignored. The filter doesn't apply to child jobs in an array or multi-node parallel (MNP) jobs. The results are sorted by the <code>createdAt</code> field, with the most recent jobs being first.</p>
309    /// <dl>
310    /// <dt>
311    /// JOB_NAME
312    /// </dt>
313    /// <dd>
314    /// <p>The value of the filter is a case-insensitive match for the job name. If the value ends with an asterisk (*), the filter matches any job name that begins with the string before the '*'. This corresponds to the <code>jobName</code> value. For example, <code>test1</code> matches both <code>Test1</code> and <code>test1</code>, and <code>test1*</code> matches both <code>test1</code> and <code>Test10</code>. When the <code>JOB_NAME</code> filter is used, the results are grouped by the job name and version.</p>
315    /// </dd>
316    /// <dt>
317    /// JOB_DEFINITION
318    /// </dt>
319    /// <dd>
320    /// <p>The value for the filter is the name or Amazon Resource Name (ARN) of the job definition. This corresponds to the <code>jobDefinition</code> value. The value is case sensitive. When the value for the filter is the job definition name, the results include all the jobs that used any revision of that job definition name. If the value ends with an asterisk (*), the filter matches any job definition name that begins with the string before the '*'. For example, <code>jd1</code> matches only <code>jd1</code>, and <code>jd1*</code> matches both <code>jd1</code> and <code>jd1A</code>. The version of the job definition that's used doesn't affect the sort order. When the <code>JOB_DEFINITION</code> filter is used and the ARN is used (which is in the form <code>arn:${Partition}:batch:${Region}:${Account}:job-definition/${JobDefinitionName}:${Revision}</code>), the results include jobs that used the specified revision of the job definition. Asterisk (*) isn't supported when the ARN is used.</p>
321    /// </dd>
322    /// <dt>
323    /// BEFORE_CREATED_AT
324    /// </dt>
325    /// <dd>
326    /// <p>The value for the filter is the time that's before the job was created. This corresponds to the <code>createdAt</code> value. The value is a string representation of the number of milliseconds since 00:00:00 UTC (midnight) on January 1, 1970.</p>
327    /// </dd>
328    /// <dt>
329    /// AFTER_CREATED_AT
330    /// </dt>
331    /// <dd>
332    /// <p>The value for the filter is the time that's after the job was created. This corresponds to the <code>createdAt</code> value. The value is a string representation of the number of milliseconds since 00:00:00 UTC (midnight) on January 1, 1970.</p>
333    /// </dd>
334    /// </dl>
335    pub fn get_filters(&self) -> &::std::option::Option<::std::vec::Vec<crate::types::KeyValuesPair>> {
336        self.inner.get_filters()
337    }
338}