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

com.pulumi.awsnative.kinesisanalyticsv2.kotlin.Application.kt Maven / Gradle / Ivy

Go to download

Build cloud applications and infrastructure by combining the safety and reliability of infrastructure as code with the power of the Kotlin programming language.

There is a newer version: 1.24.0.0
Show newest version
@file:Suppress("NAME_SHADOWING", "DEPRECATION")

package com.pulumi.awsnative.kinesisanalyticsv2.kotlin

import com.pulumi.awsnative.kinesisanalyticsv2.kotlin.enums.ApplicationMode
import com.pulumi.awsnative.kinesisanalyticsv2.kotlin.outputs.ApplicationConfiguration
import com.pulumi.awsnative.kinesisanalyticsv2.kotlin.outputs.ApplicationMaintenanceConfiguration
import com.pulumi.awsnative.kinesisanalyticsv2.kotlin.outputs.ApplicationRunConfiguration
import com.pulumi.awsnative.kotlin.outputs.Tag
import com.pulumi.core.Output
import com.pulumi.kotlin.KotlinCustomResource
import com.pulumi.kotlin.PulumiTagMarker
import com.pulumi.kotlin.ResourceMapper
import com.pulumi.kotlin.options.CustomResourceOptions
import com.pulumi.kotlin.options.CustomResourceOptionsBuilder
import com.pulumi.resources.Resource
import kotlin.Boolean
import kotlin.String
import kotlin.Suppress
import kotlin.Unit
import kotlin.collections.List
import com.pulumi.awsnative.kinesisanalyticsv2.kotlin.enums.ApplicationMode.Companion.toKotlin as applicationModeToKotlin
import com.pulumi.awsnative.kinesisanalyticsv2.kotlin.outputs.ApplicationConfiguration.Companion.toKotlin as applicationConfigurationToKotlin
import com.pulumi.awsnative.kinesisanalyticsv2.kotlin.outputs.ApplicationMaintenanceConfiguration.Companion.toKotlin as applicationMaintenanceConfigurationToKotlin
import com.pulumi.awsnative.kinesisanalyticsv2.kotlin.outputs.ApplicationRunConfiguration.Companion.toKotlin as applicationRunConfigurationToKotlin
import com.pulumi.awsnative.kotlin.outputs.Tag.Companion.toKotlin as tagToKotlin

/**
 * Builder for [Application].
 */
@PulumiTagMarker
public class ApplicationResourceBuilder internal constructor() {
    public var name: String? = null

    public var args: ApplicationArgs = ApplicationArgs()

    public var opts: CustomResourceOptions = CustomResourceOptions()

    /**
     * @param name The _unique_ name of the resulting resource.
     */
    public fun name(`value`: String) {
        this.name = value
    }

    /**
     * @param block The arguments to use to populate this resource's properties.
     */
    public suspend fun args(block: suspend ApplicationArgsBuilder.() -> Unit) {
        val builder = ApplicationArgsBuilder()
        block(builder)
        this.args = builder.build()
    }

    /**
     * @param block A bag of options that control this resource's behavior.
     */
    public suspend fun opts(block: suspend CustomResourceOptionsBuilder.() -> Unit) {
        this.opts = com.pulumi.kotlin.options.CustomResourceOptions.opts(block)
    }

    internal fun build(): Application {
        val builtJavaResource =
            com.pulumi.awsnative.kinesisanalyticsv2.Application(
                this.name,
                this.args.toJava(),
                this.opts.toJava(),
            )
        return Application(builtJavaResource)
    }
}

/**
 * Creates an Amazon Kinesis Data Analytics application. For information about creating a Kinesis Data Analytics application, see [Creating an Application](https://docs.aws.amazon.com/kinesisanalytics/latest/java/getting-started.html).
 */
public class Application internal constructor(
    override val javaResource: com.pulumi.awsnative.kinesisanalyticsv2.Application,
) : KotlinCustomResource(javaResource, ApplicationMapper) {
    /**
     * Use this parameter to configure the application.
     */
    public val applicationConfiguration: Output?
        get() = javaResource.applicationConfiguration().applyValue({ args0 ->
            args0.map({ args0 ->
                args0.let({ args0 -> applicationConfigurationToKotlin(args0) })
            }).orElse(null)
        })

    /**
     * The description of the application.
     */
    public val applicationDescription: Output?
        get() = javaResource.applicationDescription().applyValue({ args0 ->
            args0.map({ args0 ->
                args0
            }).orElse(null)
        })

    /**
     * Used to configure start of maintenance window.
     */
    public val applicationMaintenanceConfiguration: Output?
        get() = javaResource.applicationMaintenanceConfiguration().applyValue({ args0 ->
            args0.map({ args0 ->
                args0.let({ args0 ->
                    applicationMaintenanceConfigurationToKotlin(args0)
                })
            }).orElse(null)
        })

    /**
     * To create a Kinesis Data Analytics Studio notebook, you must set the mode to `INTERACTIVE`. However, for a Kinesis Data Analytics for Apache Flink application, the mode is optional.
     */
    public val applicationMode: Output?
        get() = javaResource.applicationMode().applyValue({ args0 ->
            args0.map({ args0 ->
                args0.let({ args0 -> applicationModeToKotlin(args0) })
            }).orElse(null)
        })

    /**
     * The name of the application.
     */
    public val applicationName: Output?
        get() = javaResource.applicationName().applyValue({ args0 ->
            args0.map({ args0 ->
                args0
            }).orElse(null)
        })

    /**
     * Specifies run configuration (start parameters) of a Kinesis Data Analytics application. Evaluated on update for RUNNING applications an only.
     */
    public val runConfiguration: Output?
        get() = javaResource.runConfiguration().applyValue({ args0 ->
            args0.map({ args0 ->
                args0.let({ args0 -> applicationRunConfigurationToKotlin(args0) })
            }).orElse(null)
        })

    /**
     * The runtime environment for the application.
     */
    public val runtimeEnvironment: Output
        get() = javaResource.runtimeEnvironment().applyValue({ args0 -> args0 })

    /**
     * Specifies the IAM role that the application uses to access external resources.
     */
    public val serviceExecutionRole: Output
        get() = javaResource.serviceExecutionRole().applyValue({ args0 -> args0 })

    /**
     * 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.
     */
    public val tags: Output>?
        get() = javaResource.tags().applyValue({ args0 ->
            args0.map({ args0 ->
                args0.map({ args0 ->
                    args0.let({ args0 -> tagToKotlin(args0) })
                })
            }).orElse(null)
        })
}

public object ApplicationMapper : ResourceMapper {
    override fun supportsMappingOfType(javaResource: Resource): Boolean =
        com.pulumi.awsnative.kinesisanalyticsv2.Application::class == javaResource::class

    override fun map(javaResource: Resource): Application = Application(
        javaResource as
            com.pulumi.awsnative.kinesisanalyticsv2.Application,
    )
}

/**
 * @see [Application].
 * @param name The _unique_ name of the resulting resource.
 * @param block Builder for [Application].
 */
public suspend fun application(name: String, block: suspend ApplicationResourceBuilder.() -> Unit): Application {
    val builder = ApplicationResourceBuilder()
    builder.name(name)
    block(builder)
    return builder.build()
}

/**
 * @see [Application].
 * @param name The _unique_ name of the resulting resource.
 */
public fun application(name: String): Application {
    val builder = ApplicationResourceBuilder()
    builder.name(name)
    return builder.build()
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy