com.pulumi.gitlab.kotlin.ProjectHookArgs.kt Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of pulumi-gitlab-kotlin Show documentation
Show all versions of pulumi-gitlab-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.gitlab.kotlin
import com.pulumi.core.Output
import com.pulumi.core.Output.of
import com.pulumi.gitlab.ProjectHookArgs.builder
import com.pulumi.kotlin.ConvertibleToJava
import com.pulumi.kotlin.PulumiTagMarker
import kotlin.Boolean
import kotlin.String
import kotlin.Suppress
import kotlin.jvm.JvmName
/**
* The `gitlab.ProjectHook` resource allows to manage the lifecycle of a project hook.
* **Upstream API**: [GitLab REST API docs](https://docs.gitlab.com/ee/api/projects.html#hooks)
* ## Example Usage
*
* ```typescript
* import * as pulumi from "@pulumi/pulumi";
* import * as gitlab from "@pulumi/gitlab";
* const example = new gitlab.ProjectHook("example", {
* project: "example/hooked",
* url: "https://example.com/hook/example",
* mergeRequestsEvents: true,
* });
* ```
* ```python
* import pulumi
* import pulumi_gitlab as gitlab
* example = gitlab.ProjectHook("example",
* project="example/hooked",
* url="https://example.com/hook/example",
* merge_requests_events=True)
* ```
* ```csharp
* using System.Collections.Generic;
* using System.Linq;
* using Pulumi;
* using GitLab = Pulumi.GitLab;
* return await Deployment.RunAsync(() =>
* {
* var example = new GitLab.ProjectHook("example", new()
* {
* Project = "example/hooked",
* Url = "https://example.com/hook/example",
* MergeRequestsEvents = true,
* });
* });
* ```
* ```go
* package main
* import (
* "github.com/pulumi/pulumi-gitlab/sdk/v8/go/gitlab"
* "github.com/pulumi/pulumi/sdk/v3/go/pulumi"
* )
* func main() {
* pulumi.Run(func(ctx *pulumi.Context) error {
* _, err := gitlab.NewProjectHook(ctx, "example", &gitlab.ProjectHookArgs{
* Project: pulumi.String("example/hooked"),
* Url: pulumi.String("https://example.com/hook/example"),
* MergeRequestsEvents: pulumi.Bool(true),
* })
* if err != nil {
* return err
* }
* return nil
* })
* }
* ```
* ```java
* package generated_program;
* import com.pulumi.Context;
* import com.pulumi.Pulumi;
* import com.pulumi.core.Output;
* import com.pulumi.gitlab.ProjectHook;
* import com.pulumi.gitlab.ProjectHookArgs;
* import java.util.List;
* import java.util.ArrayList;
* import java.util.Map;
* import java.io.File;
* import java.nio.file.Files;
* import java.nio.file.Paths;
* public class App {
* public static void main(String[] args) {
* Pulumi.run(App::stack);
* }
* public static void stack(Context ctx) {
* var example = new ProjectHook("example", ProjectHookArgs.builder()
* .project("example/hooked")
* .url("https://example.com/hook/example")
* .mergeRequestsEvents(true)
* .build());
* }
* }
* ```
* ```yaml
* resources:
* example:
* type: gitlab:ProjectHook
* properties:
* project: example/hooked
* url: https://example.com/hook/example
* mergeRequestsEvents: true
* ```
*
* ## Import
* A GitLab Project Hook can be imported using a key composed of `:`, e.g.
* ```sh
* $ pulumi import gitlab:index/projectHook:ProjectHook example "12345:1"
* ```
* NOTE: the `token` resource attribute is not available for imported resources as this information cannot be read from the GitLab API.
* @property confidentialIssuesEvents Invoke the hook for confidential issues events.
* @property confidentialNoteEvents Invoke the hook for confidential notes events.
* @property customWebhookTemplate Set a custom webhook template.
* @property deploymentEvents Invoke the hook for deployment events.
* @property enableSslVerification Enable ssl verification when invoking the hook.
* @property issuesEvents Invoke the hook for issues events.
* @property jobEvents Invoke the hook for job events.
* @property mergeRequestsEvents Invoke the hook for merge requests.
* @property noteEvents Invoke the hook for notes events.
* @property pipelineEvents Invoke the hook for pipeline events.
* @property project The name or id of the project to add the hook to.
* @property pushEvents Invoke the hook for push events.
* @property pushEventsBranchFilter Invoke the hook for push events on matching branches only.
* @property releasesEvents Invoke the hook for releases events.
* @property tagPushEvents Invoke the hook for tag push events.
* @property token A token to present when invoking the hook. The token is not available for imported resources.
* @property url The url of the hook to invoke. Forces re-creation to preserve `token`.
* @property wikiPageEvents Invoke the hook for wiki page events.
*/
public data class ProjectHookArgs(
public val confidentialIssuesEvents: Output? = null,
public val confidentialNoteEvents: Output? = null,
public val customWebhookTemplate: Output? = null,
public val deploymentEvents: Output? = null,
public val enableSslVerification: Output? = null,
public val issuesEvents: Output? = null,
public val jobEvents: Output? = null,
public val mergeRequestsEvents: Output? = null,
public val noteEvents: Output? = null,
public val pipelineEvents: Output? = null,
public val project: Output? = null,
public val pushEvents: Output? = null,
public val pushEventsBranchFilter: Output? = null,
public val releasesEvents: Output? = null,
public val tagPushEvents: Output? = null,
public val token: Output? = null,
public val url: Output? = null,
public val wikiPageEvents: Output? = null,
) : ConvertibleToJava {
override fun toJava(): com.pulumi.gitlab.ProjectHookArgs =
com.pulumi.gitlab.ProjectHookArgs.builder()
.confidentialIssuesEvents(confidentialIssuesEvents?.applyValue({ args0 -> args0 }))
.confidentialNoteEvents(confidentialNoteEvents?.applyValue({ args0 -> args0 }))
.customWebhookTemplate(customWebhookTemplate?.applyValue({ args0 -> args0 }))
.deploymentEvents(deploymentEvents?.applyValue({ args0 -> args0 }))
.enableSslVerification(enableSslVerification?.applyValue({ args0 -> args0 }))
.issuesEvents(issuesEvents?.applyValue({ args0 -> args0 }))
.jobEvents(jobEvents?.applyValue({ args0 -> args0 }))
.mergeRequestsEvents(mergeRequestsEvents?.applyValue({ args0 -> args0 }))
.noteEvents(noteEvents?.applyValue({ args0 -> args0 }))
.pipelineEvents(pipelineEvents?.applyValue({ args0 -> args0 }))
.project(project?.applyValue({ args0 -> args0 }))
.pushEvents(pushEvents?.applyValue({ args0 -> args0 }))
.pushEventsBranchFilter(pushEventsBranchFilter?.applyValue({ args0 -> args0 }))
.releasesEvents(releasesEvents?.applyValue({ args0 -> args0 }))
.tagPushEvents(tagPushEvents?.applyValue({ args0 -> args0 }))
.token(token?.applyValue({ args0 -> args0 }))
.url(url?.applyValue({ args0 -> args0 }))
.wikiPageEvents(wikiPageEvents?.applyValue({ args0 -> args0 })).build()
}
/**
* Builder for [ProjectHookArgs].
*/
@PulumiTagMarker
public class ProjectHookArgsBuilder internal constructor() {
private var confidentialIssuesEvents: Output? = null
private var confidentialNoteEvents: Output? = null
private var customWebhookTemplate: Output? = null
private var deploymentEvents: Output? = null
private var enableSslVerification: Output? = null
private var issuesEvents: Output? = null
private var jobEvents: Output? = null
private var mergeRequestsEvents: Output? = null
private var noteEvents: Output? = null
private var pipelineEvents: Output? = null
private var project: Output? = null
private var pushEvents: Output? = null
private var pushEventsBranchFilter: Output? = null
private var releasesEvents: Output? = null
private var tagPushEvents: Output? = null
private var token: Output? = null
private var url: Output? = null
private var wikiPageEvents: Output? = null
/**
* @param value Invoke the hook for confidential issues events.
*/
@JvmName("cdwabtyvwtunsdca")
public suspend fun confidentialIssuesEvents(`value`: Output) {
this.confidentialIssuesEvents = value
}
/**
* @param value Invoke the hook for confidential notes events.
*/
@JvmName("uckhjmdhfdhygfsj")
public suspend fun confidentialNoteEvents(`value`: Output) {
this.confidentialNoteEvents = value
}
/**
* @param value Set a custom webhook template.
*/
@JvmName("jadsoolvgvoqfmlb")
public suspend fun customWebhookTemplate(`value`: Output) {
this.customWebhookTemplate = value
}
/**
* @param value Invoke the hook for deployment events.
*/
@JvmName("xtuwpsxqwtatcswl")
public suspend fun deploymentEvents(`value`: Output) {
this.deploymentEvents = value
}
/**
* @param value Enable ssl verification when invoking the hook.
*/
@JvmName("hltdqgspfsexijxl")
public suspend fun enableSslVerification(`value`: Output) {
this.enableSslVerification = value
}
/**
* @param value Invoke the hook for issues events.
*/
@JvmName("yvibiwniuamnmqqr")
public suspend fun issuesEvents(`value`: Output) {
this.issuesEvents = value
}
/**
* @param value Invoke the hook for job events.
*/
@JvmName("spyyltkbxoankhdx")
public suspend fun jobEvents(`value`: Output) {
this.jobEvents = value
}
/**
* @param value Invoke the hook for merge requests.
*/
@JvmName("ibnsfnvhbjrogjhk")
public suspend fun mergeRequestsEvents(`value`: Output) {
this.mergeRequestsEvents = value
}
/**
* @param value Invoke the hook for notes events.
*/
@JvmName("vudmtaghkyfcqbot")
public suspend fun noteEvents(`value`: Output) {
this.noteEvents = value
}
/**
* @param value Invoke the hook for pipeline events.
*/
@JvmName("rpkusraqbvhpqcht")
public suspend fun pipelineEvents(`value`: Output) {
this.pipelineEvents = value
}
/**
* @param value The name or id of the project to add the hook to.
*/
@JvmName("lwrsnmonvaobptxr")
public suspend fun project(`value`: Output) {
this.project = value
}
/**
* @param value Invoke the hook for push events.
*/
@JvmName("dvxdmmfxcpxpkyuc")
public suspend fun pushEvents(`value`: Output) {
this.pushEvents = value
}
/**
* @param value Invoke the hook for push events on matching branches only.
*/
@JvmName("sqrsmcmloxxibuxq")
public suspend fun pushEventsBranchFilter(`value`: Output) {
this.pushEventsBranchFilter = value
}
/**
* @param value Invoke the hook for releases events.
*/
@JvmName("oixeujjdxycxoyrs")
public suspend fun releasesEvents(`value`: Output) {
this.releasesEvents = value
}
/**
* @param value Invoke the hook for tag push events.
*/
@JvmName("rckefjhnqvrdfaxc")
public suspend fun tagPushEvents(`value`: Output) {
this.tagPushEvents = value
}
/**
* @param value A token to present when invoking the hook. The token is not available for imported resources.
*/
@JvmName("qymtvmldgnvinygv")
public suspend fun token(`value`: Output) {
this.token = value
}
/**
* @param value The url of the hook to invoke. Forces re-creation to preserve `token`.
*/
@JvmName("dthfimicrtdwksuk")
public suspend fun url(`value`: Output) {
this.url = value
}
/**
* @param value Invoke the hook for wiki page events.
*/
@JvmName("qxuuswdanjeyejpe")
public suspend fun wikiPageEvents(`value`: Output) {
this.wikiPageEvents = value
}
/**
* @param value Invoke the hook for confidential issues events.
*/
@JvmName("mtimlqxrbrltnnfl")
public suspend fun confidentialIssuesEvents(`value`: Boolean?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.confidentialIssuesEvents = mapped
}
/**
* @param value Invoke the hook for confidential notes events.
*/
@JvmName("kalrujgdooueynow")
public suspend fun confidentialNoteEvents(`value`: Boolean?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.confidentialNoteEvents = mapped
}
/**
* @param value Set a custom webhook template.
*/
@JvmName("yfqkbopplxbimqmq")
public suspend fun customWebhookTemplate(`value`: String?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.customWebhookTemplate = mapped
}
/**
* @param value Invoke the hook for deployment events.
*/
@JvmName("jmuhyjjtivssmtqa")
public suspend fun deploymentEvents(`value`: Boolean?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.deploymentEvents = mapped
}
/**
* @param value Enable ssl verification when invoking the hook.
*/
@JvmName("pryhljtohralqyso")
public suspend fun enableSslVerification(`value`: Boolean?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.enableSslVerification = mapped
}
/**
* @param value Invoke the hook for issues events.
*/
@JvmName("xqmlrupjgmxtwcyt")
public suspend fun issuesEvents(`value`: Boolean?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.issuesEvents = mapped
}
/**
* @param value Invoke the hook for job events.
*/
@JvmName("ymvicqirwebskqwq")
public suspend fun jobEvents(`value`: Boolean?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.jobEvents = mapped
}
/**
* @param value Invoke the hook for merge requests.
*/
@JvmName("retyljgrvngynvbl")
public suspend fun mergeRequestsEvents(`value`: Boolean?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.mergeRequestsEvents = mapped
}
/**
* @param value Invoke the hook for notes events.
*/
@JvmName("fdamreoqpjwjuvxp")
public suspend fun noteEvents(`value`: Boolean?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.noteEvents = mapped
}
/**
* @param value Invoke the hook for pipeline events.
*/
@JvmName("mbrgpitrwafmxewf")
public suspend fun pipelineEvents(`value`: Boolean?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.pipelineEvents = mapped
}
/**
* @param value The name or id of the project to add the hook to.
*/
@JvmName("onijejgkkpuvnqwa")
public suspend fun project(`value`: String?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.project = mapped
}
/**
* @param value Invoke the hook for push events.
*/
@JvmName("reypoatlfukhweyg")
public suspend fun pushEvents(`value`: Boolean?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.pushEvents = mapped
}
/**
* @param value Invoke the hook for push events on matching branches only.
*/
@JvmName("lgjlyckegwuorhrl")
public suspend fun pushEventsBranchFilter(`value`: String?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.pushEventsBranchFilter = mapped
}
/**
* @param value Invoke the hook for releases events.
*/
@JvmName("tyebdseuldkahsek")
public suspend fun releasesEvents(`value`: Boolean?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.releasesEvents = mapped
}
/**
* @param value Invoke the hook for tag push events.
*/
@JvmName("pcwbfwvvextlcxhv")
public suspend fun tagPushEvents(`value`: Boolean?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.tagPushEvents = mapped
}
/**
* @param value A token to present when invoking the hook. The token is not available for imported resources.
*/
@JvmName("eekdjwnxrrqnjrra")
public suspend fun token(`value`: String?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.token = mapped
}
/**
* @param value The url of the hook to invoke. Forces re-creation to preserve `token`.
*/
@JvmName("yapoxplymkwfcqby")
public suspend fun url(`value`: String?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.url = mapped
}
/**
* @param value Invoke the hook for wiki page events.
*/
@JvmName("sxdhacurlstfrnrv")
public suspend fun wikiPageEvents(`value`: Boolean?) {
val toBeMapped = value
val mapped = toBeMapped?.let({ args0 -> of(args0) })
this.wikiPageEvents = mapped
}
internal fun build(): ProjectHookArgs = ProjectHookArgs(
confidentialIssuesEvents = confidentialIssuesEvents,
confidentialNoteEvents = confidentialNoteEvents,
customWebhookTemplate = customWebhookTemplate,
deploymentEvents = deploymentEvents,
enableSslVerification = enableSslVerification,
issuesEvents = issuesEvents,
jobEvents = jobEvents,
mergeRequestsEvents = mergeRequestsEvents,
noteEvents = noteEvents,
pipelineEvents = pipelineEvents,
project = project,
pushEvents = pushEvents,
pushEventsBranchFilter = pushEventsBranchFilter,
releasesEvents = releasesEvents,
tagPushEvents = tagPushEvents,
token = token,
url = url,
wikiPageEvents = wikiPageEvents,
)
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy