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}