
com.pulumi.gcp.developerconnect.kotlin.GitRepositoryLink.kt Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of pulumi-gcp-kotlin Show documentation
Show all versions of pulumi-gcp-kotlin Show documentation
Build cloud applications and infrastructure by combining the safety and reliability of infrastructure as code with the power of the Kotlin programming language.
@file:Suppress("NAME_SHADOWING", "DEPRECATION")
package com.pulumi.gcp.developerconnect.kotlin
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.Map
/**
* Builder for [GitRepositoryLink].
*/
@PulumiTagMarker
public class GitRepositoryLinkResourceBuilder internal constructor() {
public var name: String? = null
public var args: GitRepositoryLinkArgs = GitRepositoryLinkArgs()
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 GitRepositoryLinkArgsBuilder.() -> Unit) {
val builder = GitRepositoryLinkArgsBuilder()
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(): GitRepositoryLink {
val builtJavaResource =
com.pulumi.gcp.developerconnect.GitRepositoryLink(
this.name,
this.args.toJava(),
this.opts.toJava(),
)
return GitRepositoryLink(builtJavaResource)
}
}
/**
* ## Example Usage
* ### Developer Connect Git Repository Link Github Doc
*
* ```yaml
* resources:
* github-token-secret:
* type: gcp:secretmanager:Secret
* properties:
* secretId: github-token-secret
* replication:
* auto: {}
* github-token-secret-version:
* type: gcp:secretmanager:SecretVersion
* properties:
* secret: ${["github-token-secret"].id}
* secretData:
* fn::invoke:
* function: std:file
* arguments:
* input: my-github-token.txt
* return: result
* policy:
* type: gcp:secretmanager:SecretIamPolicy
* properties:
* secretId: ${["github-token-secret"].secretId}
* policyData: ${["p4sa-secretAccessor"].policyData}
* my-connection:
* type: gcp:developerconnect:Connection
* properties:
* location: us-central1
* connectionId: my-connection
* githubConfig:
* githubApp: DEVELOPER_CONNECT
* appInstallationId: 123123
* authorizerCredential:
* oauthTokenSecretVersion: ${["github-token-secret-version"].id}
* my-repository:
* type: gcp:developerconnect:GitRepositoryLink
* properties:
* location: us-central1
* gitRepositoryLinkId: my-repo
* parentConnection: ${["my-connection"].connectionId}
* remoteUri: https://github.com/myuser/myrepo.git
* variables:
* p4sa-secretAccessor:
* fn::invoke:
* function: gcp:organizations:getIAMPolicy
* arguments:
* bindings:
* - role: roles/secretmanager.secretAccessor
* members:
* - serviceAccount:[email protected]
* ```
*
* ## Import
* GitRepositoryLink can be imported using any of these accepted formats:
* * `projects/{{project}}/locations/{{location}}/connections/{{parent_connection}}/gitRepositoryLinks/{{git_repository_link_id}}`
* * `{{project}}/{{location}}/{{parent_connection}}/{{git_repository_link_id}}`
* * `{{location}}/{{parent_connection}}/{{git_repository_link_id}}`
* When using the `pulumi import` command, GitRepositoryLink can be imported using one of the formats above. For example:
* ```sh
* $ pulumi import gcp:developerconnect/gitRepositoryLink:GitRepositoryLink default projects/{{project}}/locations/{{location}}/connections/{{parent_connection}}/gitRepositoryLinks/{{git_repository_link_id}}
* ```
* ```sh
* $ pulumi import gcp:developerconnect/gitRepositoryLink:GitRepositoryLink default {{project}}/{{location}}/{{parent_connection}}/{{git_repository_link_id}}
* ```
* ```sh
* $ pulumi import gcp:developerconnect/gitRepositoryLink:GitRepositoryLink default {{location}}/{{parent_connection}}/{{git_repository_link_id}}
* ```
*/
public class GitRepositoryLink internal constructor(
override val javaResource: com.pulumi.gcp.developerconnect.GitRepositoryLink,
) : KotlinCustomResource(javaResource, GitRepositoryLinkMapper) {
/**
* Optional. Allows clients to store small amounts of arbitrary data.
* **Note**: This field is non-authoritative, and will only manage the annotations present in your configuration.
* Please refer to the field `effective_annotations` for all of the annotations present on the resource.
*/
public val annotations: Output
© 2015 - 2025 Weber Informatics LLC | Privacy Policy