RegistryWebhook

class RegistryWebhook : KotlinCustomResource

Manages an Azure Container Registry Webhook.

Example Usage

import * as pulumi from "@pulumi/pulumi";
import * as azure from "@pulumi/azure";
const example = new azure.core.ResourceGroup("example", {
name: "example-resources",
location: "West Europe",
});
const acr = new azure.containerservice.Registry("acr", {
name: "containerRegistry1",
resourceGroupName: example.name,
location: example.location,
sku: "Standard",
adminEnabled: false,
});
const webhook = new azure.containerservice.RegistryWebhook("webhook", {
name: "mywebhook",
resourceGroupName: example.name,
registryName: acr.name,
location: example.location,
serviceUri: "https://mywebhookreceiver.example/mytag",
status: "enabled",
scope: "mytag:*",
actions: ["push"],
customHeaders: {
"Content-Type": "application/json",
},
});
import pulumi
import pulumi_azure as azure
example = azure.core.ResourceGroup("example",
name="example-resources",
location="West Europe")
acr = azure.containerservice.Registry("acr",
name="containerRegistry1",
resource_group_name=example.name,
location=example.location,
sku="Standard",
admin_enabled=False)
webhook = azure.containerservice.RegistryWebhook("webhook",
name="mywebhook",
resource_group_name=example.name,
registry_name=acr.name,
location=example.location,
service_uri="https://mywebhookreceiver.example/mytag",
status="enabled",
scope="mytag:*",
actions=["push"],
custom_headers={
"Content-Type": "application/json",
})
using System.Collections.Generic;
using System.Linq;
using Pulumi;
using Azure = Pulumi.Azure;
return await Deployment.RunAsync(() =>
{
var example = new Azure.Core.ResourceGroup("example", new()
{
Name = "example-resources",
Location = "West Europe",
});
var acr = new Azure.ContainerService.Registry("acr", new()
{
Name = "containerRegistry1",
ResourceGroupName = example.Name,
Location = example.Location,
Sku = "Standard",
AdminEnabled = false,
});
var webhook = new Azure.ContainerService.RegistryWebhook("webhook", new()
{
Name = "mywebhook",
ResourceGroupName = example.Name,
RegistryName = acr.Name,
Location = example.Location,
ServiceUri = "https://mywebhookreceiver.example/mytag",
Status = "enabled",
Scope = "mytag:*",
Actions = new[]
{
"push",
},
CustomHeaders =
{
{ "Content-Type", "application/json" },
},
});
});
package main
import (
"github.com/pulumi/pulumi-azure/sdk/v6/go/azure/containerservice"
"github.com/pulumi/pulumi-azure/sdk/v6/go/azure/core"
"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
)
func main() {
pulumi.Run(func(ctx *pulumi.Context) error {
example, err := core.NewResourceGroup(ctx, "example", &core.ResourceGroupArgs{
Name: pulumi.String("example-resources"),
Location: pulumi.String("West Europe"),
})
if err != nil {
return err
}
acr, err := containerservice.NewRegistry(ctx, "acr", &containerservice.RegistryArgs{
Name: pulumi.String("containerRegistry1"),
ResourceGroupName: example.Name,
Location: example.Location,
Sku: pulumi.String("Standard"),
AdminEnabled: pulumi.Bool(false),
})
if err != nil {
return err
}
_, err = containerservice.NewRegistryWebhook(ctx, "webhook", &containerservice.RegistryWebhookArgs{
Name: pulumi.String("mywebhook"),
ResourceGroupName: example.Name,
RegistryName: acr.Name,
Location: example.Location,
ServiceUri: pulumi.String("https://mywebhookreceiver.example/mytag"),
Status: pulumi.String("enabled"),
Scope: pulumi.String("mytag:*"),
Actions: pulumi.StringArray{
pulumi.String("push"),
},
CustomHeaders: pulumi.StringMap{
"Content-Type": pulumi.String("application/json"),
},
})
if err != nil {
return err
}
return nil
})
}
package generated_program;
import com.pulumi.Context;
import com.pulumi.Pulumi;
import com.pulumi.core.Output;
import com.pulumi.azure.core.ResourceGroup;
import com.pulumi.azure.core.ResourceGroupArgs;
import com.pulumi.azure.containerservice.Registry;
import com.pulumi.azure.containerservice.RegistryArgs;
import com.pulumi.azure.containerservice.RegistryWebhook;
import com.pulumi.azure.containerservice.RegistryWebhookArgs;
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 ResourceGroup("example", ResourceGroupArgs.builder()
.name("example-resources")
.location("West Europe")
.build());
var acr = new Registry("acr", RegistryArgs.builder()
.name("containerRegistry1")
.resourceGroupName(example.name())
.location(example.location())
.sku("Standard")
.adminEnabled(false)
.build());
var webhook = new RegistryWebhook("webhook", RegistryWebhookArgs.builder()
.name("mywebhook")
.resourceGroupName(example.name())
.registryName(acr.name())
.location(example.location())
.serviceUri("https://mywebhookreceiver.example/mytag")
.status("enabled")
.scope("mytag:*")
.actions("push")
.customHeaders(Map.of("Content-Type", "application/json"))
.build());
}
}
resources:
example:
type: azure:core:ResourceGroup
properties:
name: example-resources
location: West Europe
acr:
type: azure:containerservice:Registry
properties:
name: containerRegistry1
resourceGroupName: ${example.name}
location: ${example.location}
sku: Standard
adminEnabled: false
webhook:
type: azure:containerservice:RegistryWebhook
properties:
name: mywebhook
resourceGroupName: ${example.name}
registryName: ${acr.name}
location: ${example.location}
serviceUri: https://mywebhookreceiver.example/mytag
status: enabled
scope: mytag:*
actions:
- push
customHeaders:
Content-Type: application/json

Import

Container Registry Webhooks can be imported using the resource id, e.g.

$ pulumi import azure:containerservice/registryWebhook:RegistryWebhook example /subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/mygroup1/providers/Microsoft.ContainerRegistry/registries/myregistry1/webHooks/mywebhook1

Properties

Link copied to clipboard
val actions: Output<List<String>>

A list of actions that trigger the Webhook to post notifications. At least one action needs to be specified. Valid values are: push, delete, quarantine, chart_push, chart_delete

Link copied to clipboard
val customHeaders: Output<Map<String, String>>?

Custom headers that will be added to the webhook notifications request.

Link copied to clipboard
val id: Output<String>
Link copied to clipboard
val location: Output<String>

Specifies the supported Azure location where the resource exists. Changing this forces a new resource to be created.

Link copied to clipboard
val name: Output<String>

Specifies the name of the Container Registry Webhook. Only Alphanumeric characters allowed. Changing this forces a new resource to be created.

Link copied to clipboard
val pulumiChildResources: Set<KotlinResource>
Link copied to clipboard
Link copied to clipboard
Link copied to clipboard
val registryName: Output<String>

The Name of Container registry this Webhook belongs to. Changing this forces a new resource to be created.

Link copied to clipboard

The name of the resource group in which to create the Container Registry Webhook. Changing this forces a new resource to be created.

Link copied to clipboard
val scope: Output<String>?

Specifies the scope of repositories that can trigger an event. For example, foo:* means events for all tags under repository foo. foo:bar means events for 'foo:bar' only. foo is equivalent to foo:latest. Empty means all events. Defaults to "".

Link copied to clipboard
val serviceUri: Output<String>

Specifies the service URI for the Webhook to post notifications.

Link copied to clipboard
val status: Output<String>?

Specifies if this Webhook triggers notifications or not. Valid values: enabled and disabled. Default is enabled.

Link copied to clipboard
val tags: Output<Map<String, String>>?

A mapping of tags to assign to the resource.

Link copied to clipboard
val urn: Output<String>