1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
impl super::Client {
    /// Constructs a fluent builder for the [`CreateApplication`](crate::operation::create_application::builders::CreateApplicationFluentBuilder) operation.
    ///
    /// - The fluent builder is configurable:
    ///   - [`name(impl Into<String>)`](crate::operation::create_application::builders::CreateApplicationFluentBuilder::name) / [`set_name(Option<String>)`](crate::operation::create_application::builders::CreateApplicationFluentBuilder::set_name):<br>required: **false**<br><p>The name of the application.</p><br>
    ///   - [`release_label(impl Into<String>)`](crate::operation::create_application::builders::CreateApplicationFluentBuilder::release_label) / [`set_release_label(Option<String>)`](crate::operation::create_application::builders::CreateApplicationFluentBuilder::set_release_label):<br>required: **true**<br><p>The Amazon EMR release associated with the application.</p><br>
    ///   - [`r#type(impl Into<String>)`](crate::operation::create_application::builders::CreateApplicationFluentBuilder::type) / [`set_type(Option<String>)`](crate::operation::create_application::builders::CreateApplicationFluentBuilder::set_type):<br>required: **true**<br><p>The type of application you want to start, such as Spark or Hive.</p><br>
    ///   - [`client_token(impl Into<String>)`](crate::operation::create_application::builders::CreateApplicationFluentBuilder::client_token) / [`set_client_token(Option<String>)`](crate::operation::create_application::builders::CreateApplicationFluentBuilder::set_client_token):<br>required: **true**<br><p>The client idempotency token of the application to create. Its value must be unique for each request.</p><br>
    ///   - [`initial_capacity(impl Into<String>, InitialCapacityConfig)`](crate::operation::create_application::builders::CreateApplicationFluentBuilder::initial_capacity) / [`set_initial_capacity(Option<HashMap::<String, InitialCapacityConfig>>)`](crate::operation::create_application::builders::CreateApplicationFluentBuilder::set_initial_capacity):<br>required: **false**<br><p>The capacity to initialize when the application is created.</p><br>
    ///   - [`maximum_capacity(MaximumAllowedResources)`](crate::operation::create_application::builders::CreateApplicationFluentBuilder::maximum_capacity) / [`set_maximum_capacity(Option<MaximumAllowedResources>)`](crate::operation::create_application::builders::CreateApplicationFluentBuilder::set_maximum_capacity):<br>required: **false**<br><p>The maximum capacity to allocate when the application is created. This is cumulative across all workers at any given point in time, not just when an application is created. No new resources will be created once any one of the defined limits is hit.</p><br>
    ///   - [`tags(impl Into<String>, impl Into<String>)`](crate::operation::create_application::builders::CreateApplicationFluentBuilder::tags) / [`set_tags(Option<HashMap::<String, String>>)`](crate::operation::create_application::builders::CreateApplicationFluentBuilder::set_tags):<br>required: **false**<br><p>The tags assigned to the application.</p><br>
    ///   - [`auto_start_configuration(AutoStartConfig)`](crate::operation::create_application::builders::CreateApplicationFluentBuilder::auto_start_configuration) / [`set_auto_start_configuration(Option<AutoStartConfig>)`](crate::operation::create_application::builders::CreateApplicationFluentBuilder::set_auto_start_configuration):<br>required: **false**<br><p>The configuration for an application to automatically start on job submission.</p><br>
    ///   - [`auto_stop_configuration(AutoStopConfig)`](crate::operation::create_application::builders::CreateApplicationFluentBuilder::auto_stop_configuration) / [`set_auto_stop_configuration(Option<AutoStopConfig>)`](crate::operation::create_application::builders::CreateApplicationFluentBuilder::set_auto_stop_configuration):<br>required: **false**<br><p>The configuration for an application to automatically stop after a certain amount of time being idle.</p><br>
    ///   - [`network_configuration(NetworkConfiguration)`](crate::operation::create_application::builders::CreateApplicationFluentBuilder::network_configuration) / [`set_network_configuration(Option<NetworkConfiguration>)`](crate::operation::create_application::builders::CreateApplicationFluentBuilder::set_network_configuration):<br>required: **false**<br><p>The network configuration for customer VPC connectivity.</p><br>
    ///   - [`architecture(Architecture)`](crate::operation::create_application::builders::CreateApplicationFluentBuilder::architecture) / [`set_architecture(Option<Architecture>)`](crate::operation::create_application::builders::CreateApplicationFluentBuilder::set_architecture):<br>required: **false**<br><p>The CPU architecture of an application.</p><br>
    ///   - [`image_configuration(ImageConfigurationInput)`](crate::operation::create_application::builders::CreateApplicationFluentBuilder::image_configuration) / [`set_image_configuration(Option<ImageConfigurationInput>)`](crate::operation::create_application::builders::CreateApplicationFluentBuilder::set_image_configuration):<br>required: **false**<br><p>The image configuration for all worker types. You can either set this parameter or <code>imageConfiguration</code> for each worker type in <code>workerTypeSpecifications</code>.</p><br>
    ///   - [`worker_type_specifications(impl Into<String>, WorkerTypeSpecificationInput)`](crate::operation::create_application::builders::CreateApplicationFluentBuilder::worker_type_specifications) / [`set_worker_type_specifications(Option<HashMap::<String, WorkerTypeSpecificationInput>>)`](crate::operation::create_application::builders::CreateApplicationFluentBuilder::set_worker_type_specifications):<br>required: **false**<br><p>The key-value pairs that specify worker type to <code>WorkerTypeSpecificationInput</code>. This parameter must contain all valid worker types for a Spark or Hive application. Valid worker types include <code>Driver</code> and <code>Executor</code> for Spark applications and <code>HiveDriver</code> and <code>TezTask</code> for Hive applications. You can either set image details in this parameter for each worker type, or in <code>imageConfiguration</code> for all worker types.</p><br>
    ///   - [`runtime_configuration(Configuration)`](crate::operation::create_application::builders::CreateApplicationFluentBuilder::runtime_configuration) / [`set_runtime_configuration(Option<Vec::<Configuration>>)`](crate::operation::create_application::builders::CreateApplicationFluentBuilder::set_runtime_configuration):<br>required: **false**<br><p>The <a href="https://docs.aws.amazon.com/emr-serverless/latest/APIReference/API_Configuration.html">Configuration</a> specifications to use when creating an application. Each configuration consists of a classification and properties. This configuration is applied to all the job runs submitted under the application.</p><br>
    ///   - [`monitoring_configuration(MonitoringConfiguration)`](crate::operation::create_application::builders::CreateApplicationFluentBuilder::monitoring_configuration) / [`set_monitoring_configuration(Option<MonitoringConfiguration>)`](crate::operation::create_application::builders::CreateApplicationFluentBuilder::set_monitoring_configuration):<br>required: **false**<br><p>The configuration setting for monitoring.</p><br>
    ///   - [`interactive_configuration(InteractiveConfiguration)`](crate::operation::create_application::builders::CreateApplicationFluentBuilder::interactive_configuration) / [`set_interactive_configuration(Option<InteractiveConfiguration>)`](crate::operation::create_application::builders::CreateApplicationFluentBuilder::set_interactive_configuration):<br>required: **false**<br><p>The interactive configuration object that enables the interactive use cases to use when running an application.</p><br>
    /// - On success, responds with [`CreateApplicationOutput`](crate::operation::create_application::CreateApplicationOutput) with field(s):
    ///   - [`application_id(String)`](crate::operation::create_application::CreateApplicationOutput::application_id): <p>The output contains the application ID.</p>
    ///   - [`name(Option<String>)`](crate::operation::create_application::CreateApplicationOutput::name): <p>The output contains the name of the application.</p>
    ///   - [`arn(String)`](crate::operation::create_application::CreateApplicationOutput::arn): <p>The output contains the ARN of the application.</p>
    /// - On failure, responds with [`SdkError<CreateApplicationError>`](crate::operation::create_application::CreateApplicationError)
    pub fn create_application(&self) -> crate::operation::create_application::builders::CreateApplicationFluentBuilder {
        crate::operation::create_application::builders::CreateApplicationFluentBuilder::new(self.handle.clone())
    }
}