1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
// 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:
    ///   - [`application_name(impl Into<String>)`](crate::operation::create_application::builders::CreateApplicationFluentBuilder::application_name) / [`set_application_name(Option<String>)`](crate::operation::create_application::builders::CreateApplicationFluentBuilder::set_application_name):<br>required: **true**<br><p>The name of your application (for example, <code>sample-app</code>).</p><br>
    ///   - [`application_description(impl Into<String>)`](crate::operation::create_application::builders::CreateApplicationFluentBuilder::application_description) / [`set_application_description(Option<String>)`](crate::operation::create_application::builders::CreateApplicationFluentBuilder::set_application_description):<br>required: **false**<br><p>A summary description of the application.</p><br>
    ///   - [`runtime_environment(RuntimeEnvironment)`](crate::operation::create_application::builders::CreateApplicationFluentBuilder::runtime_environment) / [`set_runtime_environment(Option<RuntimeEnvironment>)`](crate::operation::create_application::builders::CreateApplicationFluentBuilder::set_runtime_environment):<br>required: **true**<br><p>The runtime environment for the application.</p><br>
    ///   - [`service_execution_role(impl Into<String>)`](crate::operation::create_application::builders::CreateApplicationFluentBuilder::service_execution_role) / [`set_service_execution_role(Option<String>)`](crate::operation::create_application::builders::CreateApplicationFluentBuilder::set_service_execution_role):<br>required: **true**<br><p>The IAM role used by the application to access Kinesis data streams, Kinesis Data Firehose delivery streams, Amazon S3 objects, and other external resources.</p><br>
    ///   - [`application_configuration(ApplicationConfiguration)`](crate::operation::create_application::builders::CreateApplicationFluentBuilder::application_configuration) / [`set_application_configuration(Option<ApplicationConfiguration>)`](crate::operation::create_application::builders::CreateApplicationFluentBuilder::set_application_configuration):<br>required: **false**<br><p>Use this parameter to configure the application.</p><br>
    ///   - [`cloud_watch_logging_options(CloudWatchLoggingOption)`](crate::operation::create_application::builders::CreateApplicationFluentBuilder::cloud_watch_logging_options) / [`set_cloud_watch_logging_options(Option<Vec::<CloudWatchLoggingOption>>)`](crate::operation::create_application::builders::CreateApplicationFluentBuilder::set_cloud_watch_logging_options):<br>required: **false**<br><p>Use this parameter to configure an Amazon CloudWatch log stream to monitor application configuration errors.</p><br>
    ///   - [`tags(Tag)`](crate::operation::create_application::builders::CreateApplicationFluentBuilder::tags) / [`set_tags(Option<Vec::<Tag>>)`](crate::operation::create_application::builders::CreateApplicationFluentBuilder::set_tags):<br>required: **false**<br><p>A list of one or more tags to assign to the application. A tag is a key-value pair that identifies an application. Note that the maximum number of application tags includes system tags. The maximum number of user-defined application tags is 50. For more information, see <a href="https://docs.aws.amazon.com/kinesisanalytics/latest/java/how-tagging.html">Using Tagging</a>.</p><br>
    ///   - [`application_mode(ApplicationMode)`](crate::operation::create_application::builders::CreateApplicationFluentBuilder::application_mode) / [`set_application_mode(Option<ApplicationMode>)`](crate::operation::create_application::builders::CreateApplicationFluentBuilder::set_application_mode):<br>required: **false**<br><p>Use the <code>STREAMING</code> mode to create a Managed Service for Apache Flink application. To create a Managed Service for Apache Flink Studio notebook, use the <code>INTERACTIVE</code> mode.</p><br>
    /// - On success, responds with [`CreateApplicationOutput`](crate::operation::create_application::CreateApplicationOutput) with field(s):
    ///   - [`application_detail(Option<ApplicationDetail>)`](crate::operation::create_application::CreateApplicationOutput::application_detail): <p>In response to your <code>CreateApplication</code> request, Managed Service for Apache Flink returns a response with details of the application it created.</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())
    }
}