1. Packages
  2. Gitlab Provider
  3. API Docs
  4. ProjectHook
GitLab v8.10.0 published on Friday, Mar 21, 2025 by Pulumi

gitlab.ProjectHook

Explore with Pulumi AI

gitlab logo
GitLab v8.10.0 published on Friday, Mar 21, 2025 by Pulumi

    The gitlab.ProjectHook resource allows to manage the lifecycle of a project hook.

    Upstream API: GitLab REST API docs

    Example Usage

    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",
        name: "example",
        description: "Example hook",
        mergeRequestsEvents: true,
    });
    // Using Custom Headers
    // Values of headers can't be imported
    const customHeaders = new gitlab.ProjectHook("custom_headers", {
        project: "example/hooked",
        url: "https://example.com/hook/example",
        mergeRequestsEvents: true,
        customHeaders: [
            {
                key: "X-Custom-Header",
                value: "example",
            },
            {
                key: "X-Custom-Header-Second",
                value: "example-second",
            },
        ],
    });
    
    import pulumi
    import pulumi_gitlab as gitlab
    
    example = gitlab.ProjectHook("example",
        project="example/hooked",
        url="https://example.com/hook/example",
        name="example",
        description="Example hook",
        merge_requests_events=True)
    # Using Custom Headers
    # Values of headers can't be imported
    custom_headers = gitlab.ProjectHook("custom_headers",
        project="example/hooked",
        url="https://example.com/hook/example",
        merge_requests_events=True,
        custom_headers=[
            {
                "key": "X-Custom-Header",
                "value": "example",
            },
            {
                "key": "X-Custom-Header-Second",
                "value": "example-second",
            },
        ])
    
    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"),
    			Name:                pulumi.String("example"),
    			Description:         pulumi.String("Example hook"),
    			MergeRequestsEvents: pulumi.Bool(true),
    		})
    		if err != nil {
    			return err
    		}
    		// Using Custom Headers
    		// Values of headers can't be imported
    		_, err = gitlab.NewProjectHook(ctx, "custom_headers", &gitlab.ProjectHookArgs{
    			Project:             pulumi.String("example/hooked"),
    			Url:                 pulumi.String("https://example.com/hook/example"),
    			MergeRequestsEvents: pulumi.Bool(true),
    			CustomHeaders: gitlab.ProjectHookCustomHeaderArray{
    				&gitlab.ProjectHookCustomHeaderArgs{
    					Key:   pulumi.String("X-Custom-Header"),
    					Value: pulumi.String("example"),
    				},
    				&gitlab.ProjectHookCustomHeaderArgs{
    					Key:   pulumi.String("X-Custom-Header-Second"),
    					Value: pulumi.String("example-second"),
    				},
    			},
    		})
    		if err != nil {
    			return err
    		}
    		return nil
    	})
    }
    
    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",
            Name = "example",
            Description = "Example hook",
            MergeRequestsEvents = true,
        });
    
        // Using Custom Headers
        // Values of headers can't be imported
        var customHeaders = new GitLab.ProjectHook("custom_headers", new()
        {
            Project = "example/hooked",
            Url = "https://example.com/hook/example",
            MergeRequestsEvents = true,
            CustomHeaders = new[]
            {
                new GitLab.Inputs.ProjectHookCustomHeaderArgs
                {
                    Key = "X-Custom-Header",
                    Value = "example",
                },
                new GitLab.Inputs.ProjectHookCustomHeaderArgs
                {
                    Key = "X-Custom-Header-Second",
                    Value = "example-second",
                },
            },
        });
    
    });
    
    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 com.pulumi.gitlab.inputs.ProjectHookCustomHeaderArgs;
    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")
                .name("example")
                .description("Example hook")
                .mergeRequestsEvents(true)
                .build());
    
            // Using Custom Headers
            // Values of headers can't be imported
            var customHeaders = new ProjectHook("customHeaders", ProjectHookArgs.builder()
                .project("example/hooked")
                .url("https://example.com/hook/example")
                .mergeRequestsEvents(true)
                .customHeaders(            
                    ProjectHookCustomHeaderArgs.builder()
                        .key("X-Custom-Header")
                        .value("example")
                        .build(),
                    ProjectHookCustomHeaderArgs.builder()
                        .key("X-Custom-Header-Second")
                        .value("example-second")
                        .build())
                .build());
    
        }
    }
    
    resources:
      example:
        type: gitlab:ProjectHook
        properties:
          project: example/hooked
          url: https://example.com/hook/example
          name: example
          description: Example hook
          mergeRequestsEvents: true
      # Using Custom Headers
      # Values of headers can't be imported
      customHeaders:
        type: gitlab:ProjectHook
        name: custom_headers
        properties:
          project: example/hooked
          url: https://example.com/hook/example
          mergeRequestsEvents: true
          customHeaders:
            - key: X-Custom-Header
              value: example
            - key: X-Custom-Header-Second
              value: example-second
    

    Create ProjectHook Resource

    Resources are created with functions called constructors. To learn more about declaring and configuring resources, see Resources.

    Constructor syntax

    new ProjectHook(name: string, args: ProjectHookArgs, opts?: CustomResourceOptions);
    @overload
    def ProjectHook(resource_name: str,
                    args: ProjectHookArgs,
                    opts: Optional[ResourceOptions] = None)
    
    @overload
    def ProjectHook(resource_name: str,
                    opts: Optional[ResourceOptions] = None,
                    project: Optional[str] = None,
                    url: Optional[str] = None,
                    name: Optional[str] = None,
                    note_events: Optional[bool] = None,
                    deployment_events: Optional[bool] = None,
                    description: Optional[str] = None,
                    enable_ssl_verification: Optional[bool] = None,
                    issues_events: Optional[bool] = None,
                    job_events: Optional[bool] = None,
                    merge_requests_events: Optional[bool] = None,
                    confidential_issues_events: Optional[bool] = None,
                    custom_webhook_template: Optional[str] = None,
                    pipeline_events: Optional[bool] = None,
                    custom_headers: Optional[Sequence[ProjectHookCustomHeaderArgs]] = None,
                    push_events: Optional[bool] = None,
                    push_events_branch_filter: Optional[str] = None,
                    releases_events: Optional[bool] = None,
                    resource_access_token_events: Optional[bool] = None,
                    tag_push_events: Optional[bool] = None,
                    token: Optional[str] = None,
                    confidential_note_events: Optional[bool] = None,
                    wiki_page_events: Optional[bool] = None)
    func NewProjectHook(ctx *Context, name string, args ProjectHookArgs, opts ...ResourceOption) (*ProjectHook, error)
    public ProjectHook(string name, ProjectHookArgs args, CustomResourceOptions? opts = null)
    public ProjectHook(String name, ProjectHookArgs args)
    public ProjectHook(String name, ProjectHookArgs args, CustomResourceOptions options)
    
    type: gitlab:ProjectHook
    properties: # The arguments to resource properties.
    options: # Bag of options to control resource's behavior.
    
    

    Parameters

    name string
    The unique name of the resource.
    args ProjectHookArgs
    The arguments to resource properties.
    opts CustomResourceOptions
    Bag of options to control resource's behavior.
    resource_name str
    The unique name of the resource.
    args ProjectHookArgs
    The arguments to resource properties.
    opts ResourceOptions
    Bag of options to control resource's behavior.
    ctx Context
    Context object for the current deployment.
    name string
    The unique name of the resource.
    args ProjectHookArgs
    The arguments to resource properties.
    opts ResourceOption
    Bag of options to control resource's behavior.
    name string
    The unique name of the resource.
    args ProjectHookArgs
    The arguments to resource properties.
    opts CustomResourceOptions
    Bag of options to control resource's behavior.
    name String
    The unique name of the resource.
    args ProjectHookArgs
    The arguments to resource properties.
    options CustomResourceOptions
    Bag of options to control resource's behavior.

    Constructor example

    The following reference example uses placeholder values for all input properties.

    var projectHookResource = new GitLab.ProjectHook("projectHookResource", new()
    {
        Project = "string",
        Url = "string",
        Name = "string",
        NoteEvents = false,
        DeploymentEvents = false,
        Description = "string",
        EnableSslVerification = false,
        IssuesEvents = false,
        JobEvents = false,
        MergeRequestsEvents = false,
        ConfidentialIssuesEvents = false,
        CustomWebhookTemplate = "string",
        PipelineEvents = false,
        CustomHeaders = new[]
        {
            new GitLab.Inputs.ProjectHookCustomHeaderArgs
            {
                Key = "string",
                Value = "string",
            },
        },
        PushEvents = false,
        PushEventsBranchFilter = "string",
        ReleasesEvents = false,
        ResourceAccessTokenEvents = false,
        TagPushEvents = false,
        Token = "string",
        ConfidentialNoteEvents = false,
        WikiPageEvents = false,
    });
    
    example, err := gitlab.NewProjectHook(ctx, "projectHookResource", &gitlab.ProjectHookArgs{
    	Project:                  pulumi.String("string"),
    	Url:                      pulumi.String("string"),
    	Name:                     pulumi.String("string"),
    	NoteEvents:               pulumi.Bool(false),
    	DeploymentEvents:         pulumi.Bool(false),
    	Description:              pulumi.String("string"),
    	EnableSslVerification:    pulumi.Bool(false),
    	IssuesEvents:             pulumi.Bool(false),
    	JobEvents:                pulumi.Bool(false),
    	MergeRequestsEvents:      pulumi.Bool(false),
    	ConfidentialIssuesEvents: pulumi.Bool(false),
    	CustomWebhookTemplate:    pulumi.String("string"),
    	PipelineEvents:           pulumi.Bool(false),
    	CustomHeaders: gitlab.ProjectHookCustomHeaderArray{
    		&gitlab.ProjectHookCustomHeaderArgs{
    			Key:   pulumi.String("string"),
    			Value: pulumi.String("string"),
    		},
    	},
    	PushEvents:                pulumi.Bool(false),
    	PushEventsBranchFilter:    pulumi.String("string"),
    	ReleasesEvents:            pulumi.Bool(false),
    	ResourceAccessTokenEvents: pulumi.Bool(false),
    	TagPushEvents:             pulumi.Bool(false),
    	Token:                     pulumi.String("string"),
    	ConfidentialNoteEvents:    pulumi.Bool(false),
    	WikiPageEvents:            pulumi.Bool(false),
    })
    
    var projectHookResource = new ProjectHook("projectHookResource", ProjectHookArgs.builder()
        .project("string")
        .url("string")
        .name("string")
        .noteEvents(false)
        .deploymentEvents(false)
        .description("string")
        .enableSslVerification(false)
        .issuesEvents(false)
        .jobEvents(false)
        .mergeRequestsEvents(false)
        .confidentialIssuesEvents(false)
        .customWebhookTemplate("string")
        .pipelineEvents(false)
        .customHeaders(ProjectHookCustomHeaderArgs.builder()
            .key("string")
            .value("string")
            .build())
        .pushEvents(false)
        .pushEventsBranchFilter("string")
        .releasesEvents(false)
        .resourceAccessTokenEvents(false)
        .tagPushEvents(false)
        .token("string")
        .confidentialNoteEvents(false)
        .wikiPageEvents(false)
        .build());
    
    project_hook_resource = gitlab.ProjectHook("projectHookResource",
        project="string",
        url="string",
        name="string",
        note_events=False,
        deployment_events=False,
        description="string",
        enable_ssl_verification=False,
        issues_events=False,
        job_events=False,
        merge_requests_events=False,
        confidential_issues_events=False,
        custom_webhook_template="string",
        pipeline_events=False,
        custom_headers=[{
            "key": "string",
            "value": "string",
        }],
        push_events=False,
        push_events_branch_filter="string",
        releases_events=False,
        resource_access_token_events=False,
        tag_push_events=False,
        token="string",
        confidential_note_events=False,
        wiki_page_events=False)
    
    const projectHookResource = new gitlab.ProjectHook("projectHookResource", {
        project: "string",
        url: "string",
        name: "string",
        noteEvents: false,
        deploymentEvents: false,
        description: "string",
        enableSslVerification: false,
        issuesEvents: false,
        jobEvents: false,
        mergeRequestsEvents: false,
        confidentialIssuesEvents: false,
        customWebhookTemplate: "string",
        pipelineEvents: false,
        customHeaders: [{
            key: "string",
            value: "string",
        }],
        pushEvents: false,
        pushEventsBranchFilter: "string",
        releasesEvents: false,
        resourceAccessTokenEvents: false,
        tagPushEvents: false,
        token: "string",
        confidentialNoteEvents: false,
        wikiPageEvents: false,
    });
    
    type: gitlab:ProjectHook
    properties:
        confidentialIssuesEvents: false
        confidentialNoteEvents: false
        customHeaders:
            - key: string
              value: string
        customWebhookTemplate: string
        deploymentEvents: false
        description: string
        enableSslVerification: false
        issuesEvents: false
        jobEvents: false
        mergeRequestsEvents: false
        name: string
        noteEvents: false
        pipelineEvents: false
        project: string
        pushEvents: false
        pushEventsBranchFilter: string
        releasesEvents: false
        resourceAccessTokenEvents: false
        tagPushEvents: false
        token: string
        url: string
        wikiPageEvents: false
    

    ProjectHook Resource Properties

    To learn more about resource properties and how to use them, see Inputs and Outputs in the Architecture and Concepts docs.

    Inputs

    In Python, inputs that are objects can be passed either as argument classes or as dictionary literals.

    The ProjectHook resource accepts the following input properties:

    Project string
    The name or id of the project to add the hook to.
    Url string
    The url of the hook to invoke. Forces re-creation to preserve token.
    ConfidentialIssuesEvents bool
    Invoke the hook for confidential issues events.
    ConfidentialNoteEvents bool
    Invoke the hook for confidential note events.
    CustomHeaders List<Pulumi.GitLab.Inputs.ProjectHookCustomHeader>
    Custom headers for the project webhook.
    CustomWebhookTemplate string
    Custom webhook template.
    DeploymentEvents bool
    Invoke the hook for deployment events.
    Description string
    Description of the webhook.
    EnableSslVerification bool
    Enable SSL verification when invoking the hook.
    IssuesEvents bool
    Invoke the hook for issues events.
    JobEvents bool
    Invoke the hook for job events.
    MergeRequestsEvents bool
    Invoke the hook for merge requests events.
    Name string
    Name of the project webhook.
    NoteEvents bool
    Invoke the hook for note events.
    PipelineEvents bool
    Invoke the hook for pipeline events.
    PushEvents bool
    Invoke the hook for push events.
    PushEventsBranchFilter string
    Invoke the hook for push events on matching branches only.
    ReleasesEvents bool
    Invoke the hook for release events.
    ResourceAccessTokenEvents bool
    Invoke the hook for project access token expiry events.
    TagPushEvents bool
    Invoke the hook for tag push events.
    Token string
    A token to present when invoking the hook. The token is not available for imported resources.
    WikiPageEvents bool
    Invoke the hook for wiki page events.
    Project string
    The name or id of the project to add the hook to.
    Url string
    The url of the hook to invoke. Forces re-creation to preserve token.
    ConfidentialIssuesEvents bool
    Invoke the hook for confidential issues events.
    ConfidentialNoteEvents bool
    Invoke the hook for confidential note events.
    CustomHeaders []ProjectHookCustomHeaderArgs
    Custom headers for the project webhook.
    CustomWebhookTemplate string
    Custom webhook template.
    DeploymentEvents bool
    Invoke the hook for deployment events.
    Description string
    Description of the webhook.
    EnableSslVerification bool
    Enable SSL verification when invoking the hook.
    IssuesEvents bool
    Invoke the hook for issues events.
    JobEvents bool
    Invoke the hook for job events.
    MergeRequestsEvents bool
    Invoke the hook for merge requests events.
    Name string
    Name of the project webhook.
    NoteEvents bool
    Invoke the hook for note events.
    PipelineEvents bool
    Invoke the hook for pipeline events.
    PushEvents bool
    Invoke the hook for push events.
    PushEventsBranchFilter string
    Invoke the hook for push events on matching branches only.
    ReleasesEvents bool
    Invoke the hook for release events.
    ResourceAccessTokenEvents bool
    Invoke the hook for project access token expiry events.
    TagPushEvents bool
    Invoke the hook for tag push events.
    Token string
    A token to present when invoking the hook. The token is not available for imported resources.
    WikiPageEvents bool
    Invoke the hook for wiki page events.
    project String
    The name or id of the project to add the hook to.
    url String
    The url of the hook to invoke. Forces re-creation to preserve token.
    confidentialIssuesEvents Boolean
    Invoke the hook for confidential issues events.
    confidentialNoteEvents Boolean
    Invoke the hook for confidential note events.
    customHeaders List<ProjectHookCustomHeader>
    Custom headers for the project webhook.
    customWebhookTemplate String
    Custom webhook template.
    deploymentEvents Boolean
    Invoke the hook for deployment events.
    description String
    Description of the webhook.
    enableSslVerification Boolean
    Enable SSL verification when invoking the hook.
    issuesEvents Boolean
    Invoke the hook for issues events.
    jobEvents Boolean
    Invoke the hook for job events.
    mergeRequestsEvents Boolean
    Invoke the hook for merge requests events.
    name String
    Name of the project webhook.
    noteEvents Boolean
    Invoke the hook for note events.
    pipelineEvents Boolean
    Invoke the hook for pipeline events.
    pushEvents Boolean
    Invoke the hook for push events.
    pushEventsBranchFilter String
    Invoke the hook for push events on matching branches only.
    releasesEvents Boolean
    Invoke the hook for release events.
    resourceAccessTokenEvents Boolean
    Invoke the hook for project access token expiry events.
    tagPushEvents Boolean
    Invoke the hook for tag push events.
    token String
    A token to present when invoking the hook. The token is not available for imported resources.
    wikiPageEvents Boolean
    Invoke the hook for wiki page events.
    project string
    The name or id of the project to add the hook to.
    url string
    The url of the hook to invoke. Forces re-creation to preserve token.
    confidentialIssuesEvents boolean
    Invoke the hook for confidential issues events.
    confidentialNoteEvents boolean
    Invoke the hook for confidential note events.
    customHeaders ProjectHookCustomHeader[]
    Custom headers for the project webhook.
    customWebhookTemplate string
    Custom webhook template.
    deploymentEvents boolean
    Invoke the hook for deployment events.
    description string
    Description of the webhook.
    enableSslVerification boolean
    Enable SSL verification when invoking the hook.
    issuesEvents boolean
    Invoke the hook for issues events.
    jobEvents boolean
    Invoke the hook for job events.
    mergeRequestsEvents boolean
    Invoke the hook for merge requests events.
    name string
    Name of the project webhook.
    noteEvents boolean
    Invoke the hook for note events.
    pipelineEvents boolean
    Invoke the hook for pipeline events.
    pushEvents boolean
    Invoke the hook for push events.
    pushEventsBranchFilter string
    Invoke the hook for push events on matching branches only.
    releasesEvents boolean
    Invoke the hook for release events.
    resourceAccessTokenEvents boolean
    Invoke the hook for project access token expiry events.
    tagPushEvents boolean
    Invoke the hook for tag push events.
    token string
    A token to present when invoking the hook. The token is not available for imported resources.
    wikiPageEvents boolean
    Invoke the hook for wiki page events.
    project str
    The name or id of the project to add the hook to.
    url str
    The url of the hook to invoke. Forces re-creation to preserve token.
    confidential_issues_events bool
    Invoke the hook for confidential issues events.
    confidential_note_events bool
    Invoke the hook for confidential note events.
    custom_headers Sequence[ProjectHookCustomHeaderArgs]
    Custom headers for the project webhook.
    custom_webhook_template str
    Custom webhook template.
    deployment_events bool
    Invoke the hook for deployment events.
    description str
    Description of the webhook.
    enable_ssl_verification bool
    Enable SSL verification when invoking the hook.
    issues_events bool
    Invoke the hook for issues events.
    job_events bool
    Invoke the hook for job events.
    merge_requests_events bool
    Invoke the hook for merge requests events.
    name str
    Name of the project webhook.
    note_events bool
    Invoke the hook for note events.
    pipeline_events bool
    Invoke the hook for pipeline events.
    push_events bool
    Invoke the hook for push events.
    push_events_branch_filter str
    Invoke the hook for push events on matching branches only.
    releases_events bool
    Invoke the hook for release events.
    resource_access_token_events bool
    Invoke the hook for project access token expiry events.
    tag_push_events bool
    Invoke the hook for tag push events.
    token str
    A token to present when invoking the hook. The token is not available for imported resources.
    wiki_page_events bool
    Invoke the hook for wiki page events.
    project String
    The name or id of the project to add the hook to.
    url String
    The url of the hook to invoke. Forces re-creation to preserve token.
    confidentialIssuesEvents Boolean
    Invoke the hook for confidential issues events.
    confidentialNoteEvents Boolean
    Invoke the hook for confidential note events.
    customHeaders List<Property Map>
    Custom headers for the project webhook.
    customWebhookTemplate String
    Custom webhook template.
    deploymentEvents Boolean
    Invoke the hook for deployment events.
    description String
    Description of the webhook.
    enableSslVerification Boolean
    Enable SSL verification when invoking the hook.
    issuesEvents Boolean
    Invoke the hook for issues events.
    jobEvents Boolean
    Invoke the hook for job events.
    mergeRequestsEvents Boolean
    Invoke the hook for merge requests events.
    name String
    Name of the project webhook.
    noteEvents Boolean
    Invoke the hook for note events.
    pipelineEvents Boolean
    Invoke the hook for pipeline events.
    pushEvents Boolean
    Invoke the hook for push events.
    pushEventsBranchFilter String
    Invoke the hook for push events on matching branches only.
    releasesEvents Boolean
    Invoke the hook for release events.
    resourceAccessTokenEvents Boolean
    Invoke the hook for project access token expiry events.
    tagPushEvents Boolean
    Invoke the hook for tag push events.
    token String
    A token to present when invoking the hook. The token is not available for imported resources.
    wikiPageEvents Boolean
    Invoke the hook for wiki page events.

    Outputs

    All input properties are implicitly available as output properties. Additionally, the ProjectHook resource produces the following output properties:

    HookId int
    The id of the project hook.
    Id string
    The provider-assigned unique ID for this managed resource.
    ProjectId int
    The id of the project for the hook.
    HookId int
    The id of the project hook.
    Id string
    The provider-assigned unique ID for this managed resource.
    ProjectId int
    The id of the project for the hook.
    hookId Integer
    The id of the project hook.
    id String
    The provider-assigned unique ID for this managed resource.
    projectId Integer
    The id of the project for the hook.
    hookId number
    The id of the project hook.
    id string
    The provider-assigned unique ID for this managed resource.
    projectId number
    The id of the project for the hook.
    hook_id int
    The id of the project hook.
    id str
    The provider-assigned unique ID for this managed resource.
    project_id int
    The id of the project for the hook.
    hookId Number
    The id of the project hook.
    id String
    The provider-assigned unique ID for this managed resource.
    projectId Number
    The id of the project for the hook.

    Look up Existing ProjectHook Resource

    Get an existing ProjectHook resource’s state with the given name, ID, and optional extra properties used to qualify the lookup.

    public static get(name: string, id: Input<ID>, state?: ProjectHookState, opts?: CustomResourceOptions): ProjectHook
    @staticmethod
    def get(resource_name: str,
            id: str,
            opts: Optional[ResourceOptions] = None,
            confidential_issues_events: Optional[bool] = None,
            confidential_note_events: Optional[bool] = None,
            custom_headers: Optional[Sequence[ProjectHookCustomHeaderArgs]] = None,
            custom_webhook_template: Optional[str] = None,
            deployment_events: Optional[bool] = None,
            description: Optional[str] = None,
            enable_ssl_verification: Optional[bool] = None,
            hook_id: Optional[int] = None,
            issues_events: Optional[bool] = None,
            job_events: Optional[bool] = None,
            merge_requests_events: Optional[bool] = None,
            name: Optional[str] = None,
            note_events: Optional[bool] = None,
            pipeline_events: Optional[bool] = None,
            project: Optional[str] = None,
            project_id: Optional[int] = None,
            push_events: Optional[bool] = None,
            push_events_branch_filter: Optional[str] = None,
            releases_events: Optional[bool] = None,
            resource_access_token_events: Optional[bool] = None,
            tag_push_events: Optional[bool] = None,
            token: Optional[str] = None,
            url: Optional[str] = None,
            wiki_page_events: Optional[bool] = None) -> ProjectHook
    func GetProjectHook(ctx *Context, name string, id IDInput, state *ProjectHookState, opts ...ResourceOption) (*ProjectHook, error)
    public static ProjectHook Get(string name, Input<string> id, ProjectHookState? state, CustomResourceOptions? opts = null)
    public static ProjectHook get(String name, Output<String> id, ProjectHookState state, CustomResourceOptions options)
    resources:  _:    type: gitlab:ProjectHook    get:      id: ${id}
    name
    The unique name of the resulting resource.
    id
    The unique provider ID of the resource to lookup.
    state
    Any extra arguments used during the lookup.
    opts
    A bag of options that control this resource's behavior.
    resource_name
    The unique name of the resulting resource.
    id
    The unique provider ID of the resource to lookup.
    name
    The unique name of the resulting resource.
    id
    The unique provider ID of the resource to lookup.
    state
    Any extra arguments used during the lookup.
    opts
    A bag of options that control this resource's behavior.
    name
    The unique name of the resulting resource.
    id
    The unique provider ID of the resource to lookup.
    state
    Any extra arguments used during the lookup.
    opts
    A bag of options that control this resource's behavior.
    name
    The unique name of the resulting resource.
    id
    The unique provider ID of the resource to lookup.
    state
    Any extra arguments used during the lookup.
    opts
    A bag of options that control this resource's behavior.
    The following state arguments are supported:
    ConfidentialIssuesEvents bool
    Invoke the hook for confidential issues events.
    ConfidentialNoteEvents bool
    Invoke the hook for confidential note events.
    CustomHeaders List<Pulumi.GitLab.Inputs.ProjectHookCustomHeader>
    Custom headers for the project webhook.
    CustomWebhookTemplate string
    Custom webhook template.
    DeploymentEvents bool
    Invoke the hook for deployment events.
    Description string
    Description of the webhook.
    EnableSslVerification bool
    Enable SSL verification when invoking the hook.
    HookId int
    The id of the project hook.
    IssuesEvents bool
    Invoke the hook for issues events.
    JobEvents bool
    Invoke the hook for job events.
    MergeRequestsEvents bool
    Invoke the hook for merge requests events.
    Name string
    Name of the project webhook.
    NoteEvents bool
    Invoke the hook for note events.
    PipelineEvents bool
    Invoke the hook for pipeline events.
    Project string
    The name or id of the project to add the hook to.
    ProjectId int
    The id of the project for the hook.
    PushEvents bool
    Invoke the hook for push events.
    PushEventsBranchFilter string
    Invoke the hook for push events on matching branches only.
    ReleasesEvents bool
    Invoke the hook for release events.
    ResourceAccessTokenEvents bool
    Invoke the hook for project access token expiry events.
    TagPushEvents bool
    Invoke the hook for tag push events.
    Token string
    A token to present when invoking the hook. The token is not available for imported resources.
    Url string
    The url of the hook to invoke. Forces re-creation to preserve token.
    WikiPageEvents bool
    Invoke the hook for wiki page events.
    ConfidentialIssuesEvents bool
    Invoke the hook for confidential issues events.
    ConfidentialNoteEvents bool
    Invoke the hook for confidential note events.
    CustomHeaders []ProjectHookCustomHeaderArgs
    Custom headers for the project webhook.
    CustomWebhookTemplate string
    Custom webhook template.
    DeploymentEvents bool
    Invoke the hook for deployment events.
    Description string
    Description of the webhook.
    EnableSslVerification bool
    Enable SSL verification when invoking the hook.
    HookId int
    The id of the project hook.
    IssuesEvents bool
    Invoke the hook for issues events.
    JobEvents bool
    Invoke the hook for job events.
    MergeRequestsEvents bool
    Invoke the hook for merge requests events.
    Name string
    Name of the project webhook.
    NoteEvents bool
    Invoke the hook for note events.
    PipelineEvents bool
    Invoke the hook for pipeline events.
    Project string
    The name or id of the project to add the hook to.
    ProjectId int
    The id of the project for the hook.
    PushEvents bool
    Invoke the hook for push events.
    PushEventsBranchFilter string
    Invoke the hook for push events on matching branches only.
    ReleasesEvents bool
    Invoke the hook for release events.
    ResourceAccessTokenEvents bool
    Invoke the hook for project access token expiry events.
    TagPushEvents bool
    Invoke the hook for tag push events.
    Token string
    A token to present when invoking the hook. The token is not available for imported resources.
    Url string
    The url of the hook to invoke. Forces re-creation to preserve token.
    WikiPageEvents bool
    Invoke the hook for wiki page events.
    confidentialIssuesEvents Boolean
    Invoke the hook for confidential issues events.
    confidentialNoteEvents Boolean
    Invoke the hook for confidential note events.
    customHeaders List<ProjectHookCustomHeader>
    Custom headers for the project webhook.
    customWebhookTemplate String
    Custom webhook template.
    deploymentEvents Boolean
    Invoke the hook for deployment events.
    description String
    Description of the webhook.
    enableSslVerification Boolean
    Enable SSL verification when invoking the hook.
    hookId Integer
    The id of the project hook.
    issuesEvents Boolean
    Invoke the hook for issues events.
    jobEvents Boolean
    Invoke the hook for job events.
    mergeRequestsEvents Boolean
    Invoke the hook for merge requests events.
    name String
    Name of the project webhook.
    noteEvents Boolean
    Invoke the hook for note events.
    pipelineEvents Boolean
    Invoke the hook for pipeline events.
    project String
    The name or id of the project to add the hook to.
    projectId Integer
    The id of the project for the hook.
    pushEvents Boolean
    Invoke the hook for push events.
    pushEventsBranchFilter String
    Invoke the hook for push events on matching branches only.
    releasesEvents Boolean
    Invoke the hook for release events.
    resourceAccessTokenEvents Boolean
    Invoke the hook for project access token expiry events.
    tagPushEvents Boolean
    Invoke the hook for tag push events.
    token String
    A token to present when invoking the hook. The token is not available for imported resources.
    url String
    The url of the hook to invoke. Forces re-creation to preserve token.
    wikiPageEvents Boolean
    Invoke the hook for wiki page events.
    confidentialIssuesEvents boolean
    Invoke the hook for confidential issues events.
    confidentialNoteEvents boolean
    Invoke the hook for confidential note events.
    customHeaders ProjectHookCustomHeader[]
    Custom headers for the project webhook.
    customWebhookTemplate string
    Custom webhook template.
    deploymentEvents boolean
    Invoke the hook for deployment events.
    description string
    Description of the webhook.
    enableSslVerification boolean
    Enable SSL verification when invoking the hook.
    hookId number
    The id of the project hook.
    issuesEvents boolean
    Invoke the hook for issues events.
    jobEvents boolean
    Invoke the hook for job events.
    mergeRequestsEvents boolean
    Invoke the hook for merge requests events.
    name string
    Name of the project webhook.
    noteEvents boolean
    Invoke the hook for note events.
    pipelineEvents boolean
    Invoke the hook for pipeline events.
    project string
    The name or id of the project to add the hook to.
    projectId number
    The id of the project for the hook.
    pushEvents boolean
    Invoke the hook for push events.
    pushEventsBranchFilter string
    Invoke the hook for push events on matching branches only.
    releasesEvents boolean
    Invoke the hook for release events.
    resourceAccessTokenEvents boolean
    Invoke the hook for project access token expiry events.
    tagPushEvents boolean
    Invoke the hook for tag push events.
    token string
    A token to present when invoking the hook. The token is not available for imported resources.
    url string
    The url of the hook to invoke. Forces re-creation to preserve token.
    wikiPageEvents boolean
    Invoke the hook for wiki page events.
    confidential_issues_events bool
    Invoke the hook for confidential issues events.
    confidential_note_events bool
    Invoke the hook for confidential note events.
    custom_headers Sequence[ProjectHookCustomHeaderArgs]
    Custom headers for the project webhook.
    custom_webhook_template str
    Custom webhook template.
    deployment_events bool
    Invoke the hook for deployment events.
    description str
    Description of the webhook.
    enable_ssl_verification bool
    Enable SSL verification when invoking the hook.
    hook_id int
    The id of the project hook.
    issues_events bool
    Invoke the hook for issues events.
    job_events bool
    Invoke the hook for job events.
    merge_requests_events bool
    Invoke the hook for merge requests events.
    name str
    Name of the project webhook.
    note_events bool
    Invoke the hook for note events.
    pipeline_events bool
    Invoke the hook for pipeline events.
    project str
    The name or id of the project to add the hook to.
    project_id int
    The id of the project for the hook.
    push_events bool
    Invoke the hook for push events.
    push_events_branch_filter str
    Invoke the hook for push events on matching branches only.
    releases_events bool
    Invoke the hook for release events.
    resource_access_token_events bool
    Invoke the hook for project access token expiry events.
    tag_push_events bool
    Invoke the hook for tag push events.
    token str
    A token to present when invoking the hook. The token is not available for imported resources.
    url str
    The url of the hook to invoke. Forces re-creation to preserve token.
    wiki_page_events bool
    Invoke the hook for wiki page events.
    confidentialIssuesEvents Boolean
    Invoke the hook for confidential issues events.
    confidentialNoteEvents Boolean
    Invoke the hook for confidential note events.
    customHeaders List<Property Map>
    Custom headers for the project webhook.
    customWebhookTemplate String
    Custom webhook template.
    deploymentEvents Boolean
    Invoke the hook for deployment events.
    description String
    Description of the webhook.
    enableSslVerification Boolean
    Enable SSL verification when invoking the hook.
    hookId Number
    The id of the project hook.
    issuesEvents Boolean
    Invoke the hook for issues events.
    jobEvents Boolean
    Invoke the hook for job events.
    mergeRequestsEvents Boolean
    Invoke the hook for merge requests events.
    name String
    Name of the project webhook.
    noteEvents Boolean
    Invoke the hook for note events.
    pipelineEvents Boolean
    Invoke the hook for pipeline events.
    project String
    The name or id of the project to add the hook to.
    projectId Number
    The id of the project for the hook.
    pushEvents Boolean
    Invoke the hook for push events.
    pushEventsBranchFilter String
    Invoke the hook for push events on matching branches only.
    releasesEvents Boolean
    Invoke the hook for release events.
    resourceAccessTokenEvents Boolean
    Invoke the hook for project access token expiry events.
    tagPushEvents Boolean
    Invoke the hook for tag push events.
    token String
    A token to present when invoking the hook. The token is not available for imported resources.
    url String
    The url of the hook to invoke. Forces re-creation to preserve token.
    wikiPageEvents Boolean
    Invoke the hook for wiki page events.

    Supporting Types

    ProjectHookCustomHeader, ProjectHookCustomHeaderArgs

    Key string
    Key of the custom header.
    Value string
    Value of the custom header. This value cannot be imported.
    Key string
    Key of the custom header.
    Value string
    Value of the custom header. This value cannot be imported.
    key String
    Key of the custom header.
    value String
    Value of the custom header. This value cannot be imported.
    key string
    Key of the custom header.
    value string
    Value of the custom header. This value cannot be imported.
    key str
    Key of the custom header.
    value str
    Value of the custom header. This value cannot be imported.
    key String
    Key of the custom header.
    value String
    Value of the custom header. This value cannot be imported.

    Import

    Starting in Terraform v1.5.0 you can use an import block to import gitlab_project_hook. For example:

    terraform

    import {

    to = gitlab_project_hook.example

    id = “see CLI command below for ID”

    }

    Import using the CLI is supported using the following syntax:

    A GitLab Project Hook can be imported using a key composed of <project-id>:<hook-id>, e.g.

    $ 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.

    To learn more about importing existing cloud resources, see Importing resources.

    Package Details

    Repository
    GitLab pulumi/pulumi-gitlab
    License
    Apache-2.0
    Notes
    This Pulumi package is based on the gitlab Terraform Provider.
    gitlab logo
    GitLab v8.10.0 published on Friday, Mar 21, 2025 by Pulumi