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

com.pulumi.gcp.activedirectory.kotlin.PeeringArgs.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.activedirectory.kotlin

import com.pulumi.core.Output
import com.pulumi.core.Output.of
import com.pulumi.gcp.activedirectory.PeeringArgs.builder
import com.pulumi.kotlin.ConvertibleToJava
import com.pulumi.kotlin.PulumiTagMarker
import kotlin.Pair
import kotlin.String
import kotlin.Suppress
import kotlin.collections.Map
import kotlin.jvm.JvmName

/**
 * ## Example Usage
 * ### Active Directory Peering Basic
 * 
 * ```yaml
 * resources:
 *   ad-domain-peering:
 *     type: gcp:activedirectory:Peering
 *     properties:
 *       domainResource: ${["ad-domain"].name}
 *       peeringId: ad-domain-peering
 *       authorizedNetwork: ${["peered-network"].id}
 *       deletionProtection: false
 *       labels:
 *         foo: bar
 *   ad-domain:
 *     type: gcp:activedirectory:Domain
 *     properties:
 *       domainName: ad.test.hashicorptest.com
 *       locations:
 *         - us-central1
 *       reservedIpRange: 192.168.255.0/24
 *       authorizedNetworks:
 *         - ${["source-network"].id}
 *       deletionProtection: false
 *   peered-network:
 *     type: gcp:compute:Network
 *     properties:
 *       project: ${compute.project}
 *       name: ad-peered-network
 *   source-network:
 *     type: gcp:compute:Network
 *     properties:
 *       name: ad-network
 *   compute:
 *     type: gcp:projects:Service
 *     properties:
 *       project: ${["peered-project"].projectId}
 *       service: compute.googleapis.com
 *   peered-project:
 *     type: gcp:organizations:Project
 *     properties:
 *       name: my-peered-project
 *       projectId: my-peered-project
 *       orgId: '123456789'
 *       billingAccount: 000000-0000000-0000000-000000
 *       deletionPolicy: DELETE
 * ```
 * 
 * ## Import
 * This resource does not support import.
 * @property authorizedNetwork The full names of the Google Compute Engine networks to which the instance is connected. Caller needs to make sure that CIDR subnets do not overlap between networks, else peering creation will fail.
 * @property domainResource Full domain resource path for the Managed AD Domain involved in peering. The resource path should be in the form projects/{projectId}/locations/global/domains/{domainName}
 * @property labels Resource labels that can contain user-provided metadata
 * **Note**: This field is non-authoritative, and will only manage the labels present in your configuration.
 * Please refer to the field `effective_labels` for all of the labels present on the resource.
 * @property peeringId - - -
 * @property project The ID of the project in which the resource belongs.
 * If it is not provided, the provider project is used.
 * @property status The current state of this Peering.
 * @property statusMessage Additional information about the current status of this peering, if available.
 */
public data class PeeringArgs(
    public val authorizedNetwork: Output? = null,
    public val domainResource: Output? = null,
    public val labels: Output>? = null,
    public val peeringId: Output? = null,
    public val project: Output? = null,
    public val status: Output? = null,
    public val statusMessage: Output? = null,
) : ConvertibleToJava {
    override fun toJava(): com.pulumi.gcp.activedirectory.PeeringArgs =
        com.pulumi.gcp.activedirectory.PeeringArgs.builder()
            .authorizedNetwork(authorizedNetwork?.applyValue({ args0 -> args0 }))
            .domainResource(domainResource?.applyValue({ args0 -> args0 }))
            .labels(labels?.applyValue({ args0 -> args0.map({ args0 -> args0.key.to(args0.value) }).toMap() }))
            .peeringId(peeringId?.applyValue({ args0 -> args0 }))
            .project(project?.applyValue({ args0 -> args0 }))
            .status(status?.applyValue({ args0 -> args0 }))
            .statusMessage(statusMessage?.applyValue({ args0 -> args0 })).build()
}

/**
 * Builder for [PeeringArgs].
 */
@PulumiTagMarker
public class PeeringArgsBuilder internal constructor() {
    private var authorizedNetwork: Output? = null

    private var domainResource: Output? = null

    private var labels: Output>? = null

    private var peeringId: Output? = null

    private var project: Output? = null

    private var status: Output? = null

    private var statusMessage: Output? = null

    /**
     * @param value The full names of the Google Compute Engine networks to which the instance is connected. Caller needs to make sure that CIDR subnets do not overlap between networks, else peering creation will fail.
     */
    @JvmName("olrvyokoctsknkuf")
    public suspend fun authorizedNetwork(`value`: Output) {
        this.authorizedNetwork = value
    }

    /**
     * @param value Full domain resource path for the Managed AD Domain involved in peering. The resource path should be in the form projects/{projectId}/locations/global/domains/{domainName}
     */
    @JvmName("onskqliqqecmfftm")
    public suspend fun domainResource(`value`: Output) {
        this.domainResource = value
    }

    /**
     * @param value Resource labels that can contain user-provided metadata
     * **Note**: This field is non-authoritative, and will only manage the labels present in your configuration.
     * Please refer to the field `effective_labels` for all of the labels present on the resource.
     */
    @JvmName("kkvtbjouivvtiqws")
    public suspend fun labels(`value`: Output>) {
        this.labels = value
    }

    /**
     * @param value - - -
     */
    @JvmName("ikrydqnqclqdfcco")
    public suspend fun peeringId(`value`: Output) {
        this.peeringId = value
    }

    /**
     * @param value The ID of the project in which the resource belongs.
     * If it is not provided, the provider project is used.
     */
    @JvmName("xrhtkhqgqteydpvw")
    public suspend fun project(`value`: Output) {
        this.project = value
    }

    /**
     * @param value The current state of this Peering.
     */
    @JvmName("rossxfjowknjkgxy")
    public suspend fun status(`value`: Output) {
        this.status = value
    }

    /**
     * @param value Additional information about the current status of this peering, if available.
     */
    @JvmName("xhrusotvtduspiea")
    public suspend fun statusMessage(`value`: Output) {
        this.statusMessage = value
    }

    /**
     * @param value The full names of the Google Compute Engine networks to which the instance is connected. Caller needs to make sure that CIDR subnets do not overlap between networks, else peering creation will fail.
     */
    @JvmName("budmdbybpvjlaies")
    public suspend fun authorizedNetwork(`value`: String?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.authorizedNetwork = mapped
    }

    /**
     * @param value Full domain resource path for the Managed AD Domain involved in peering. The resource path should be in the form projects/{projectId}/locations/global/domains/{domainName}
     */
    @JvmName("rrmljxksuqggoqte")
    public suspend fun domainResource(`value`: String?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.domainResource = mapped
    }

    /**
     * @param value Resource labels that can contain user-provided metadata
     * **Note**: This field is non-authoritative, and will only manage the labels present in your configuration.
     * Please refer to the field `effective_labels` for all of the labels present on the resource.
     */
    @JvmName("fwxfcoikhvesvxnk")
    public suspend fun labels(`value`: Map?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.labels = mapped
    }

    /**
     * @param values Resource labels that can contain user-provided metadata
     * **Note**: This field is non-authoritative, and will only manage the labels present in your configuration.
     * Please refer to the field `effective_labels` for all of the labels present on the resource.
     */
    @JvmName("jxygkmdusirpsvyk")
    public fun labels(vararg values: Pair) {
        val toBeMapped = values.toMap()
        val mapped = toBeMapped.let({ args0 -> of(args0) })
        this.labels = mapped
    }

    /**
     * @param value - - -
     */
    @JvmName("qovmsraobobupnuk")
    public suspend fun peeringId(`value`: String?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.peeringId = mapped
    }

    /**
     * @param value The ID of the project in which the resource belongs.
     * If it is not provided, the provider project is used.
     */
    @JvmName("msyferlsvmnhybio")
    public suspend fun project(`value`: String?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.project = mapped
    }

    /**
     * @param value The current state of this Peering.
     */
    @JvmName("fwjprvowmgcslopd")
    public suspend fun status(`value`: String?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.status = mapped
    }

    /**
     * @param value Additional information about the current status of this peering, if available.
     */
    @JvmName("gvlwcwhyavtjljtq")
    public suspend fun statusMessage(`value`: String?) {
        val toBeMapped = value
        val mapped = toBeMapped?.let({ args0 -> of(args0) })
        this.statusMessage = mapped
    }

    internal fun build(): PeeringArgs = PeeringArgs(
        authorizedNetwork = authorizedNetwork,
        domainResource = domainResource,
        labels = labels,
        peeringId = peeringId,
        project = project,
        status = status,
        statusMessage = statusMessage,
    )
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy