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

com.pulumi.gcp.diagflow.kotlin.inputs.CxFlowTransitionRouteArgs.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: 8.13.1.0
Show newest version
@file:Suppress("NAME_SHADOWING", "DEPRECATION")

package com.pulumi.gcp.diagflow.kotlin.inputs

import com.pulumi.core.Output
import com.pulumi.core.Output.of
import com.pulumi.gcp.diagflow.inputs.CxFlowTransitionRouteArgs.builder
import com.pulumi.kotlin.ConvertibleToJava
import com.pulumi.kotlin.PulumiTagMarker
import com.pulumi.kotlin.applySuspend
import kotlin.String
import kotlin.Suppress
import kotlin.Unit
import kotlin.jvm.JvmName

/**
 *
 * @property condition The condition to evaluate against form parameters or session parameters.
 * At least one of intent or condition must be specified. When both intent and condition are specified, the transition can only happen when both are fulfilled.
 * @property intent The unique identifier of an Intent.
 * Format: projects//locations//agents//intents/. Indicates that the transition can only happen when the given intent is matched. At least one of intent or condition must be specified. When both intent and condition are specified, the transition can only happen when both are fulfilled.
 * @property name (Output)
 * The unique identifier of this transition route.
 * @property targetFlow The target flow to transition to.
 * Format: projects//locations//agents//flows/.
 * @property targetPage The target page to transition to.
 * Format: projects//locations//agents//flows//pages/.
 * @property triggerFulfillment The fulfillment to call when the condition is satisfied. At least one of triggerFulfillment and target must be specified. When both are defined, triggerFulfillment is executed first.
 * Structure is documented below.
 */
public data class CxFlowTransitionRouteArgs(
    public val condition: Output? = null,
    public val intent: Output? = null,
    public val name: Output? = null,
    public val targetFlow: Output? = null,
    public val targetPage: Output? = null,
    public val triggerFulfillment: Output? = null,
) : ConvertibleToJava {
    override fun toJava(): com.pulumi.gcp.diagflow.inputs.CxFlowTransitionRouteArgs =
        com.pulumi.gcp.diagflow.inputs.CxFlowTransitionRouteArgs.builder()
            .condition(condition?.applyValue({ args0 -> args0 }))
            .intent(intent?.applyValue({ args0 -> args0 }))
            .name(name?.applyValue({ args0 -> args0 }))
            .targetFlow(targetFlow?.applyValue({ args0 -> args0 }))
            .targetPage(targetPage?.applyValue({ args0 -> args0 }))
            .triggerFulfillment(
                triggerFulfillment?.applyValue({ args0 ->
                    args0.let({ args0 ->
                        args0.toJava()
                    })
                }),
            ).build()
}

/**
 * Builder for [CxFlowTransitionRouteArgs].
 */
@PulumiTagMarker
public class CxFlowTransitionRouteArgsBuilder internal constructor() {
    private var condition: Output? = null

    private var intent: Output? = null

    private var name: Output? = null

    private var targetFlow: Output? = null

    private var targetPage: Output? = null

    private var triggerFulfillment: Output? = null

    /**
     * @param value The condition to evaluate against form parameters or session parameters.
     * At least one of intent or condition must be specified. When both intent and condition are specified, the transition can only happen when both are fulfilled.
     */
    @JvmName("lfecvgeckqybnoun")
    public suspend fun condition(`value`: Output) {
        this.condition = value
    }

    /**
     * @param value The unique identifier of an Intent.
     * Format: projects//locations//agents//intents/. Indicates that the transition can only happen when the given intent is matched. At least one of intent or condition must be specified. When both intent and condition are specified, the transition can only happen when both are fulfilled.
     */
    @JvmName("wjukdqigmicvrdks")
    public suspend fun intent(`value`: Output) {
        this.intent = value
    }

    /**
     * @param value (Output)
     * The unique identifier of this transition route.
     */
    @JvmName("tbyehrctifwhoqrw")
    public suspend fun name(`value`: Output) {
        this.name = value
    }

    /**
     * @param value The target flow to transition to.
     * Format: projects//locations//agents//flows/.
     */
    @JvmName("xspjrdwuprbfbkna")
    public suspend fun targetFlow(`value`: Output) {
        this.targetFlow = value
    }

    /**
     * @param value The target page to transition to.
     * Format: projects//locations//agents//flows//pages/.
     */
    @JvmName("efebrikoejilxqtj")
    public suspend fun targetPage(`value`: Output) {
        this.targetPage = value
    }

    /**
     * @param value The fulfillment to call when the condition is satisfied. At least one of triggerFulfillment and target must be specified. When both are defined, triggerFulfillment is executed first.
     * Structure is documented below.
     */
    @JvmName("dlalmqqiarcylvcm")
    public suspend fun triggerFulfillment(`value`: Output) {
        this.triggerFulfillment = value
    }

    /**
     * @param value The condition to evaluate against form parameters or session parameters.
     * At least one of intent or condition must be specified. When both intent and condition are specified, the transition can only happen when both are fulfilled.
     */
    @JvmName("jdqmrlfdlcutboyp")
    public suspend fun condition(`value`: String?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.condition = mapped
    }

    /**
     * @param value The unique identifier of an Intent.
     * Format: projects//locations//agents//intents/. Indicates that the transition can only happen when the given intent is matched. At least one of intent or condition must be specified. When both intent and condition are specified, the transition can only happen when both are fulfilled.
     */
    @JvmName("outcmbugwlcchgwc")
    public suspend fun intent(`value`: String?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.intent = mapped
    }

    /**
     * @param value (Output)
     * The unique identifier of this transition route.
     */
    @JvmName("qebsnkqelqirwyju")
    public suspend fun name(`value`: String?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.name = mapped
    }

    /**
     * @param value The target flow to transition to.
     * Format: projects//locations//agents//flows/.
     */
    @JvmName("nvxhovapujpjrwqs")
    public suspend fun targetFlow(`value`: String?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.targetFlow = mapped
    }

    /**
     * @param value The target page to transition to.
     * Format: projects//locations//agents//flows//pages/.
     */
    @JvmName("lrowutowdteilddp")
    public suspend fun targetPage(`value`: String?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.targetPage = mapped
    }

    /**
     * @param value The fulfillment to call when the condition is satisfied. At least one of triggerFulfillment and target must be specified. When both are defined, triggerFulfillment is executed first.
     * Structure is documented below.
     */
    @JvmName("vugukdcouiroqqip")
    public suspend fun triggerFulfillment(`value`: CxFlowTransitionRouteTriggerFulfillmentArgs?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.triggerFulfillment = mapped
    }

    /**
     * @param argument The fulfillment to call when the condition is satisfied. At least one of triggerFulfillment and target must be specified. When both are defined, triggerFulfillment is executed first.
     * Structure is documented below.
     */
    @JvmName("ncjmauxjylwtywyo")
    public suspend fun triggerFulfillment(argument: suspend CxFlowTransitionRouteTriggerFulfillmentArgsBuilder.() -> Unit) {
        val toBeMapped = CxFlowTransitionRouteTriggerFulfillmentArgsBuilder().applySuspend {
            argument()
        }.build()
        val mapped = of(toBeMapped)
        this.triggerFulfillment = mapped
    }

    internal fun build(): CxFlowTransitionRouteArgs = CxFlowTransitionRouteArgs(
        condition = condition,
        intent = intent,
        name = name,
        targetFlow = targetFlow,
        targetPage = targetPage,
        triggerFulfillment = triggerFulfillment,
    )
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy