All Downloads are FREE. Search and download functionalities are using the official Maven repository.

io.cloudshiftdev.awscdk.services.kinesisanalytics.CfnApplicationProps.kt Maven / Gradle / Ivy

There is a newer version: 0.10.0
Show newest version
@file:Suppress("RedundantVisibilityModifier","RedundantUnitReturnType","RemoveRedundantQualifierName","unused","UnusedImport","ClassName","REDUNDANT_PROJECTION","DEPRECATION")

package io.cloudshiftdev.awscdk.services.kinesisanalytics

import io.cloudshiftdev.awscdk.IResolvable
import io.cloudshiftdev.awscdk.common.CdkDslMarker
import io.cloudshiftdev.awscdk.common.CdkObject
import io.cloudshiftdev.awscdk.common.CdkObjectWrappers
import kotlin.Any
import kotlin.String
import kotlin.Unit
import kotlin.collections.List

/**
 * Properties for defining a `CfnApplication`.
 *
 * Example:
 *
 * ```
 * // The code below shows an example of how to instantiate this type.
 * // The values are placeholders you should change.
 * import io.cloudshiftdev.awscdk.services.kinesisanalytics.*;
 * CfnApplicationProps cfnApplicationProps = CfnApplicationProps.builder()
 * .inputs(List.of(InputProperty.builder()
 * .inputSchema(InputSchemaProperty.builder()
 * .recordColumns(List.of(RecordColumnProperty.builder()
 * .name("name")
 * .sqlType("sqlType")
 * // the properties below are optional
 * .mapping("mapping")
 * .build()))
 * .recordFormat(RecordFormatProperty.builder()
 * .recordFormatType("recordFormatType")
 * // the properties below are optional
 * .mappingParameters(MappingParametersProperty.builder()
 * .csvMappingParameters(CSVMappingParametersProperty.builder()
 * .recordColumnDelimiter("recordColumnDelimiter")
 * .recordRowDelimiter("recordRowDelimiter")
 * .build())
 * .jsonMappingParameters(JSONMappingParametersProperty.builder()
 * .recordRowPath("recordRowPath")
 * .build())
 * .build())
 * .build())
 * // the properties below are optional
 * .recordEncoding("recordEncoding")
 * .build())
 * .namePrefix("namePrefix")
 * // the properties below are optional
 * .inputParallelism(InputParallelismProperty.builder()
 * .count(123)
 * .build())
 * .inputProcessingConfiguration(InputProcessingConfigurationProperty.builder()
 * .inputLambdaProcessor(InputLambdaProcessorProperty.builder()
 * .resourceArn("resourceArn")
 * .roleArn("roleArn")
 * .build())
 * .build())
 * .kinesisFirehoseInput(KinesisFirehoseInputProperty.builder()
 * .resourceArn("resourceArn")
 * .roleArn("roleArn")
 * .build())
 * .kinesisStreamsInput(KinesisStreamsInputProperty.builder()
 * .resourceArn("resourceArn")
 * .roleArn("roleArn")
 * .build())
 * .build()))
 * // the properties below are optional
 * .applicationCode("applicationCode")
 * .applicationDescription("applicationDescription")
 * .applicationName("applicationName")
 * .build();
 * ```
 *
 * [Documentation](http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-kinesisanalytics-application.html)
 */
public interface CfnApplicationProps {
  /**
   * One or more SQL statements that read input data, transform it, and generate output.
   *
   * For example, you can write a SQL statement that reads data from one in-application stream,
   * generates a running average of the number of advertisement clicks by vendor, and insert resulting
   * rows in another in-application stream using pumps. For more information about the typical pattern,
   * see [Application
   * Code](https://docs.aws.amazon.com/kinesisanalytics/latest/dev/how-it-works-app-code.html) .
   *
   * You can provide such series of SQL statements, where output of one statement can be used as the
   * input for the next statement. You store intermediate results by creating in-application streams
   * and pumps.
   *
   * Note that the application code must create the streams with names specified in the `Outputs` .
   * For example, if your `Outputs` defines output streams named `ExampleOutputStream1` and
   * `ExampleOutputStream2` , then your application code must create these streams.
   *
   * [Documentation](http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-kinesisanalytics-application.html#cfn-kinesisanalytics-application-applicationcode)
   */
  public fun applicationCode(): String? = unwrap(this).getApplicationCode()

  /**
   * Summary description of the application.
   *
   * [Documentation](http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-kinesisanalytics-application.html#cfn-kinesisanalytics-application-applicationdescription)
   */
  public fun applicationDescription(): String? = unwrap(this).getApplicationDescription()

  /**
   * Name of your Amazon Kinesis Analytics application (for example, `sample-app` ).
   *
   * [Documentation](http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-kinesisanalytics-application.html#cfn-kinesisanalytics-application-applicationname)
   */
  public fun applicationName(): String? = unwrap(this).getApplicationName()

  /**
   * Use this parameter to configure the application input.
   *
   * You can configure your application to receive input from a single streaming source. In this
   * configuration, you map this streaming source to an in-application stream that is created. Your
   * application code can then query the in-application stream like a table (you can think of it as a
   * constantly updating table).
   *
   * For the streaming source, you provide its Amazon Resource Name (ARN) and format of data on the
   * stream (for example, JSON, CSV, etc.). You also must provide an IAM role that Amazon Kinesis
   * Analytics can assume to read this stream on your behalf.
   *
   * To create the in-application stream, you need to specify a schema to transform your data into a
   * schematized version used in SQL. In the schema, you provide the necessary mapping of the data
   * elements in the streaming source to record columns in the in-app stream.
   *
   * [Documentation](http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-kinesisanalytics-application.html#cfn-kinesisanalytics-application-inputs)
   */
  public fun inputs(): Any

  /**
   * A builder for [CfnApplicationProps]
   */
  @CdkDslMarker
  public interface Builder {
    /**
     * @param applicationCode One or more SQL statements that read input data, transform it, and
     * generate output.
     * For example, you can write a SQL statement that reads data from one in-application stream,
     * generates a running average of the number of advertisement clicks by vendor, and insert
     * resulting rows in another in-application stream using pumps. For more information about the
     * typical pattern, see [Application
     * Code](https://docs.aws.amazon.com/kinesisanalytics/latest/dev/how-it-works-app-code.html) .
     *
     * You can provide such series of SQL statements, where output of one statement can be used as
     * the input for the next statement. You store intermediate results by creating in-application
     * streams and pumps.
     *
     * Note that the application code must create the streams with names specified in the `Outputs`
     * . For example, if your `Outputs` defines output streams named `ExampleOutputStream1` and
     * `ExampleOutputStream2` , then your application code must create these streams.
     */
    public fun applicationCode(applicationCode: String)

    /**
     * @param applicationDescription Summary description of the application.
     */
    public fun applicationDescription(applicationDescription: String)

    /**
     * @param applicationName Name of your Amazon Kinesis Analytics application (for example,
     * `sample-app` ).
     */
    public fun applicationName(applicationName: String)

    /**
     * @param inputs Use this parameter to configure the application input. 
     * You can configure your application to receive input from a single streaming source. In this
     * configuration, you map this streaming source to an in-application stream that is created. Your
     * application code can then query the in-application stream like a table (you can think of it as a
     * constantly updating table).
     *
     * For the streaming source, you provide its Amazon Resource Name (ARN) and format of data on
     * the stream (for example, JSON, CSV, etc.). You also must provide an IAM role that Amazon Kinesis
     * Analytics can assume to read this stream on your behalf.
     *
     * To create the in-application stream, you need to specify a schema to transform your data into
     * a schematized version used in SQL. In the schema, you provide the necessary mapping of the data
     * elements in the streaming source to record columns in the in-app stream.
     */
    public fun inputs(inputs: IResolvable)

    /**
     * @param inputs Use this parameter to configure the application input. 
     * You can configure your application to receive input from a single streaming source. In this
     * configuration, you map this streaming source to an in-application stream that is created. Your
     * application code can then query the in-application stream like a table (you can think of it as a
     * constantly updating table).
     *
     * For the streaming source, you provide its Amazon Resource Name (ARN) and format of data on
     * the stream (for example, JSON, CSV, etc.). You also must provide an IAM role that Amazon Kinesis
     * Analytics can assume to read this stream on your behalf.
     *
     * To create the in-application stream, you need to specify a schema to transform your data into
     * a schematized version used in SQL. In the schema, you provide the necessary mapping of the data
     * elements in the streaming source to record columns in the in-app stream.
     */
    public fun inputs(inputs: List)

    /**
     * @param inputs Use this parameter to configure the application input. 
     * You can configure your application to receive input from a single streaming source. In this
     * configuration, you map this streaming source to an in-application stream that is created. Your
     * application code can then query the in-application stream like a table (you can think of it as a
     * constantly updating table).
     *
     * For the streaming source, you provide its Amazon Resource Name (ARN) and format of data on
     * the stream (for example, JSON, CSV, etc.). You also must provide an IAM role that Amazon Kinesis
     * Analytics can assume to read this stream on your behalf.
     *
     * To create the in-application stream, you need to specify a schema to transform your data into
     * a schematized version used in SQL. In the schema, you provide the necessary mapping of the data
     * elements in the streaming source to record columns in the in-app stream.
     */
    public fun inputs(vararg inputs: Any)
  }

  private class BuilderImpl : Builder {
    private val cdkBuilder:
        software.amazon.awscdk.services.kinesisanalytics.CfnApplicationProps.Builder =
        software.amazon.awscdk.services.kinesisanalytics.CfnApplicationProps.builder()

    /**
     * @param applicationCode One or more SQL statements that read input data, transform it, and
     * generate output.
     * For example, you can write a SQL statement that reads data from one in-application stream,
     * generates a running average of the number of advertisement clicks by vendor, and insert
     * resulting rows in another in-application stream using pumps. For more information about the
     * typical pattern, see [Application
     * Code](https://docs.aws.amazon.com/kinesisanalytics/latest/dev/how-it-works-app-code.html) .
     *
     * You can provide such series of SQL statements, where output of one statement can be used as
     * the input for the next statement. You store intermediate results by creating in-application
     * streams and pumps.
     *
     * Note that the application code must create the streams with names specified in the `Outputs`
     * . For example, if your `Outputs` defines output streams named `ExampleOutputStream1` and
     * `ExampleOutputStream2` , then your application code must create these streams.
     */
    override fun applicationCode(applicationCode: String) {
      cdkBuilder.applicationCode(applicationCode)
    }

    /**
     * @param applicationDescription Summary description of the application.
     */
    override fun applicationDescription(applicationDescription: String) {
      cdkBuilder.applicationDescription(applicationDescription)
    }

    /**
     * @param applicationName Name of your Amazon Kinesis Analytics application (for example,
     * `sample-app` ).
     */
    override fun applicationName(applicationName: String) {
      cdkBuilder.applicationName(applicationName)
    }

    /**
     * @param inputs Use this parameter to configure the application input. 
     * You can configure your application to receive input from a single streaming source. In this
     * configuration, you map this streaming source to an in-application stream that is created. Your
     * application code can then query the in-application stream like a table (you can think of it as a
     * constantly updating table).
     *
     * For the streaming source, you provide its Amazon Resource Name (ARN) and format of data on
     * the stream (for example, JSON, CSV, etc.). You also must provide an IAM role that Amazon Kinesis
     * Analytics can assume to read this stream on your behalf.
     *
     * To create the in-application stream, you need to specify a schema to transform your data into
     * a schematized version used in SQL. In the schema, you provide the necessary mapping of the data
     * elements in the streaming source to record columns in the in-app stream.
     */
    override fun inputs(inputs: IResolvable) {
      cdkBuilder.inputs(inputs.let(IResolvable.Companion::unwrap))
    }

    /**
     * @param inputs Use this parameter to configure the application input. 
     * You can configure your application to receive input from a single streaming source. In this
     * configuration, you map this streaming source to an in-application stream that is created. Your
     * application code can then query the in-application stream like a table (you can think of it as a
     * constantly updating table).
     *
     * For the streaming source, you provide its Amazon Resource Name (ARN) and format of data on
     * the stream (for example, JSON, CSV, etc.). You also must provide an IAM role that Amazon Kinesis
     * Analytics can assume to read this stream on your behalf.
     *
     * To create the in-application stream, you need to specify a schema to transform your data into
     * a schematized version used in SQL. In the schema, you provide the necessary mapping of the data
     * elements in the streaming source to record columns in the in-app stream.
     */
    override fun inputs(inputs: List) {
      cdkBuilder.inputs(inputs.map{CdkObjectWrappers.unwrap(it)})
    }

    /**
     * @param inputs Use this parameter to configure the application input. 
     * You can configure your application to receive input from a single streaming source. In this
     * configuration, you map this streaming source to an in-application stream that is created. Your
     * application code can then query the in-application stream like a table (you can think of it as a
     * constantly updating table).
     *
     * For the streaming source, you provide its Amazon Resource Name (ARN) and format of data on
     * the stream (for example, JSON, CSV, etc.). You also must provide an IAM role that Amazon Kinesis
     * Analytics can assume to read this stream on your behalf.
     *
     * To create the in-application stream, you need to specify a schema to transform your data into
     * a schematized version used in SQL. In the schema, you provide the necessary mapping of the data
     * elements in the streaming source to record columns in the in-app stream.
     */
    override fun inputs(vararg inputs: Any): Unit = inputs(inputs.toList())

    public fun build(): software.amazon.awscdk.services.kinesisanalytics.CfnApplicationProps =
        cdkBuilder.build()
  }

  private class Wrapper(
    cdkObject: software.amazon.awscdk.services.kinesisanalytics.CfnApplicationProps,
  ) : CdkObject(cdkObject),
      CfnApplicationProps {
    /**
     * One or more SQL statements that read input data, transform it, and generate output.
     *
     * For example, you can write a SQL statement that reads data from one in-application stream,
     * generates a running average of the number of advertisement clicks by vendor, and insert
     * resulting rows in another in-application stream using pumps. For more information about the
     * typical pattern, see [Application
     * Code](https://docs.aws.amazon.com/kinesisanalytics/latest/dev/how-it-works-app-code.html) .
     *
     * You can provide such series of SQL statements, where output of one statement can be used as
     * the input for the next statement. You store intermediate results by creating in-application
     * streams and pumps.
     *
     * Note that the application code must create the streams with names specified in the `Outputs`
     * . For example, if your `Outputs` defines output streams named `ExampleOutputStream1` and
     * `ExampleOutputStream2` , then your application code must create these streams.
     *
     * [Documentation](http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-kinesisanalytics-application.html#cfn-kinesisanalytics-application-applicationcode)
     */
    override fun applicationCode(): String? = unwrap(this).getApplicationCode()

    /**
     * Summary description of the application.
     *
     * [Documentation](http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-kinesisanalytics-application.html#cfn-kinesisanalytics-application-applicationdescription)
     */
    override fun applicationDescription(): String? = unwrap(this).getApplicationDescription()

    /**
     * Name of your Amazon Kinesis Analytics application (for example, `sample-app` ).
     *
     * [Documentation](http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-kinesisanalytics-application.html#cfn-kinesisanalytics-application-applicationname)
     */
    override fun applicationName(): String? = unwrap(this).getApplicationName()

    /**
     * Use this parameter to configure the application input.
     *
     * You can configure your application to receive input from a single streaming source. In this
     * configuration, you map this streaming source to an in-application stream that is created. Your
     * application code can then query the in-application stream like a table (you can think of it as a
     * constantly updating table).
     *
     * For the streaming source, you provide its Amazon Resource Name (ARN) and format of data on
     * the stream (for example, JSON, CSV, etc.). You also must provide an IAM role that Amazon Kinesis
     * Analytics can assume to read this stream on your behalf.
     *
     * To create the in-application stream, you need to specify a schema to transform your data into
     * a schematized version used in SQL. In the schema, you provide the necessary mapping of the data
     * elements in the streaming source to record columns in the in-app stream.
     *
     * [Documentation](http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-kinesisanalytics-application.html#cfn-kinesisanalytics-application-inputs)
     */
    override fun inputs(): Any = unwrap(this).getInputs()
  }

  public companion object {
    public operator fun invoke(block: Builder.() -> Unit = {}): CfnApplicationProps {
      val builderImpl = BuilderImpl()
      return Wrapper(builderImpl.apply(block).build())
    }

    internal
        fun wrap(cdkObject: software.amazon.awscdk.services.kinesisanalytics.CfnApplicationProps):
        CfnApplicationProps = CdkObjectWrappers.wrap(cdkObject) as? CfnApplicationProps ?:
        Wrapper(cdkObject)

    internal fun unwrap(wrapped: CfnApplicationProps):
        software.amazon.awscdk.services.kinesisanalytics.CfnApplicationProps = (wrapped as
        CdkObject).cdkObject as software.amazon.awscdk.services.kinesisanalytics.CfnApplicationProps
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy