pagerduty.ServiceIntegration
Explore with Pulumi AI
A service integration is an integration that belongs to a service.
Example Usage
import * as pulumi from "@pulumi/pulumi";
import * as pagerduty from "@pulumi/pagerduty";
const example = new pagerduty.User("example", {
    name: "Earline Greenholt",
    email: "125.greenholt.earline@graham.name",
    teams: [examplePagerdutyTeam.id],
});
const foo = new pagerduty.EscalationPolicy("foo", {
    name: "Engineering Escalation Policy",
    numLoops: 2,
    rules: [{
        escalationDelayInMinutes: 10,
        targets: [{
            type: "user",
            id: example.id,
        }],
    }],
});
const exampleService = new pagerduty.Service("example", {
    name: "My Web App",
    autoResolveTimeout: "14400",
    acknowledgementTimeout: "600",
    escalationPolicy: examplePagerdutyEscalationPolicy.id,
});
const exampleServiceIntegration = new pagerduty.ServiceIntegration("example", {
    name: "Generic API Service Integration",
    type: "generic_events_api_inbound_integration",
    service: exampleService.id,
});
const apiv2 = new pagerduty.ServiceIntegration("apiv2", {
    name: "API V2",
    type: "events_api_v2_inbound_integration",
    service: exampleService.id,
});
const emailX = new pagerduty.ServiceIntegration("email_x", {
    name: "Email X",
    type: "generic_email_inbound_integration",
    integrationEmail: "ecommerce@subdomain.pagerduty.com",
    service: exampleService.id,
});
const datadog = pagerduty.getVendor({
    name: "Datadog",
});
const datadogServiceIntegration = new pagerduty.ServiceIntegration("datadog", {
    name: datadog.then(datadog => datadog.name),
    service: exampleService.id,
    vendor: datadog.then(datadog => datadog.id),
});
const cloudwatch = pagerduty.getVendor({
    name: "Cloudwatch",
});
const cloudwatchServiceIntegration = new pagerduty.ServiceIntegration("cloudwatch", {
    name: cloudwatch.then(cloudwatch => cloudwatch.name),
    service: exampleService.id,
    vendor: cloudwatch.then(cloudwatch => cloudwatch.id),
});
const email = pagerduty.getVendor({
    name: "Email",
});
const emailServiceIntegration = new pagerduty.ServiceIntegration("email", {
    name: email.then(email => email.name),
    service: exampleService.id,
    vendor: email.then(email => email.id),
    integrationEmail: "s1@your_account.pagerduty.com",
    emailIncidentCreation: "use_rules",
    emailFilterMode: "and-rules-email",
    emailFilters: [
        {
            bodyMode: "always",
            bodyRegex: undefined,
            fromEmailMode: "match",
            fromEmailRegex: "(@foo.test*)",
            subjectMode: "match",
            subjectRegex: "(CRITICAL*)",
        },
        {
            bodyMode: "always",
            bodyRegex: undefined,
            fromEmailMode: "match",
            fromEmailRegex: "(@bar.com*)",
            subjectMode: "match",
            subjectRegex: "(CRITICAL*)",
        },
    ],
    emailParsers: [{
        action: "resolve",
        matchPredicate: {
            type: "any",
            predicates: [
                {
                    matcher: "foo",
                    part: "subject",
                    type: "contains",
                },
                {
                    type: "not",
                    predicates: [{
                        matcher: "(bar*)",
                        part: "body",
                        type: "regex",
                    }],
                },
            ],
        },
        valueExtractors: [
            {
                endsBefore: "end",
                part: "subject",
                startsAfter: "start",
                type: "between",
                valueName: "incident_key",
            },
            {
                endsBefore: "end",
                part: "subject",
                startsAfter: "start",
                type: "between",
                valueName: "FieldName1",
            },
        ],
    }],
});
import pulumi
import pulumi_pagerduty as pagerduty
example = pagerduty.User("example",
    name="Earline Greenholt",
    email="125.greenholt.earline@graham.name",
    teams=[example_pagerduty_team["id"]])
foo = pagerduty.EscalationPolicy("foo",
    name="Engineering Escalation Policy",
    num_loops=2,
    rules=[{
        "escalation_delay_in_minutes": 10,
        "targets": [{
            "type": "user",
            "id": example.id,
        }],
    }])
example_service = pagerduty.Service("example",
    name="My Web App",
    auto_resolve_timeout="14400",
    acknowledgement_timeout="600",
    escalation_policy=example_pagerduty_escalation_policy["id"])
example_service_integration = pagerduty.ServiceIntegration("example",
    name="Generic API Service Integration",
    type="generic_events_api_inbound_integration",
    service=example_service.id)
apiv2 = pagerduty.ServiceIntegration("apiv2",
    name="API V2",
    type="events_api_v2_inbound_integration",
    service=example_service.id)
email_x = pagerduty.ServiceIntegration("email_x",
    name="Email X",
    type="generic_email_inbound_integration",
    integration_email="ecommerce@subdomain.pagerduty.com",
    service=example_service.id)
datadog = pagerduty.get_vendor(name="Datadog")
datadog_service_integration = pagerduty.ServiceIntegration("datadog",
    name=datadog.name,
    service=example_service.id,
    vendor=datadog.id)
cloudwatch = pagerduty.get_vendor(name="Cloudwatch")
cloudwatch_service_integration = pagerduty.ServiceIntegration("cloudwatch",
    name=cloudwatch.name,
    service=example_service.id,
    vendor=cloudwatch.id)
email = pagerduty.get_vendor(name="Email")
email_service_integration = pagerduty.ServiceIntegration("email",
    name=email.name,
    service=example_service.id,
    vendor=email.id,
    integration_email="s1@your_account.pagerduty.com",
    email_incident_creation="use_rules",
    email_filter_mode="and-rules-email",
    email_filters=[
        {
            "body_mode": "always",
            "body_regex": None,
            "from_email_mode": "match",
            "from_email_regex": "(@foo.test*)",
            "subject_mode": "match",
            "subject_regex": "(CRITICAL*)",
        },
        {
            "body_mode": "always",
            "body_regex": None,
            "from_email_mode": "match",
            "from_email_regex": "(@bar.com*)",
            "subject_mode": "match",
            "subject_regex": "(CRITICAL*)",
        },
    ],
    email_parsers=[{
        "action": "resolve",
        "match_predicate": {
            "type": "any",
            "predicates": [
                {
                    "matcher": "foo",
                    "part": "subject",
                    "type": "contains",
                },
                {
                    "type": "not",
                    "predicates": [{
                        "matcher": "(bar*)",
                        "part": "body",
                        "type": "regex",
                    }],
                },
            ],
        },
        "value_extractors": [
            {
                "ends_before": "end",
                "part": "subject",
                "starts_after": "start",
                "type": "between",
                "value_name": "incident_key",
            },
            {
                "ends_before": "end",
                "part": "subject",
                "starts_after": "start",
                "type": "between",
                "value_name": "FieldName1",
            },
        ],
    }])
package main
import (
	"github.com/pulumi/pulumi-pagerduty/sdk/v4/go/pagerduty"
	"github.com/pulumi/pulumi/sdk/v3/go/pulumi"
)
func main() {
	pulumi.Run(func(ctx *pulumi.Context) error {
		example, err := pagerduty.NewUser(ctx, "example", &pagerduty.UserArgs{
			Name:  pulumi.String("Earline Greenholt"),
			Email: pulumi.String("125.greenholt.earline@graham.name"),
			Teams: pulumi.StringArray{
				examplePagerdutyTeam.Id,
			},
		})
		if err != nil {
			return err
		}
		_, err = pagerduty.NewEscalationPolicy(ctx, "foo", &pagerduty.EscalationPolicyArgs{
			Name:     pulumi.String("Engineering Escalation Policy"),
			NumLoops: pulumi.Int(2),
			Rules: pagerduty.EscalationPolicyRuleArray{
				&pagerduty.EscalationPolicyRuleArgs{
					EscalationDelayInMinutes: pulumi.Int(10),
					Targets: pagerduty.EscalationPolicyRuleTargetArray{
						&pagerduty.EscalationPolicyRuleTargetArgs{
							Type: pulumi.String("user"),
							Id:   example.ID(),
						},
					},
				},
			},
		})
		if err != nil {
			return err
		}
		exampleService, err := pagerduty.NewService(ctx, "example", &pagerduty.ServiceArgs{
			Name:                   pulumi.String("My Web App"),
			AutoResolveTimeout:     pulumi.String("14400"),
			AcknowledgementTimeout: pulumi.String("600"),
			EscalationPolicy:       pulumi.Any(examplePagerdutyEscalationPolicy.Id),
		})
		if err != nil {
			return err
		}
		_, err = pagerduty.NewServiceIntegration(ctx, "example", &pagerduty.ServiceIntegrationArgs{
			Name:    pulumi.String("Generic API Service Integration"),
			Type:    pulumi.String("generic_events_api_inbound_integration"),
			Service: exampleService.ID(),
		})
		if err != nil {
			return err
		}
		_, err = pagerduty.NewServiceIntegration(ctx, "apiv2", &pagerduty.ServiceIntegrationArgs{
			Name:    pulumi.String("API V2"),
			Type:    pulumi.String("events_api_v2_inbound_integration"),
			Service: exampleService.ID(),
		})
		if err != nil {
			return err
		}
		_, err = pagerduty.NewServiceIntegration(ctx, "email_x", &pagerduty.ServiceIntegrationArgs{
			Name:             pulumi.String("Email X"),
			Type:             pulumi.String("generic_email_inbound_integration"),
			IntegrationEmail: pulumi.String("ecommerce@subdomain.pagerduty.com"),
			Service:          exampleService.ID(),
		})
		if err != nil {
			return err
		}
		datadog, err := pagerduty.GetVendor(ctx, &pagerduty.GetVendorArgs{
			Name: "Datadog",
		}, nil)
		if err != nil {
			return err
		}
		_, err = pagerduty.NewServiceIntegration(ctx, "datadog", &pagerduty.ServiceIntegrationArgs{
			Name:    pulumi.String(datadog.Name),
			Service: exampleService.ID(),
			Vendor:  pulumi.String(datadog.Id),
		})
		if err != nil {
			return err
		}
		cloudwatch, err := pagerduty.GetVendor(ctx, &pagerduty.GetVendorArgs{
			Name: "Cloudwatch",
		}, nil)
		if err != nil {
			return err
		}
		_, err = pagerduty.NewServiceIntegration(ctx, "cloudwatch", &pagerduty.ServiceIntegrationArgs{
			Name:    pulumi.String(cloudwatch.Name),
			Service: exampleService.ID(),
			Vendor:  pulumi.String(cloudwatch.Id),
		})
		if err != nil {
			return err
		}
		email, err := pagerduty.GetVendor(ctx, &pagerduty.GetVendorArgs{
			Name: "Email",
		}, nil)
		if err != nil {
			return err
		}
		_, err = pagerduty.NewServiceIntegration(ctx, "email", &pagerduty.ServiceIntegrationArgs{
			Name:                  pulumi.String(email.Name),
			Service:               exampleService.ID(),
			Vendor:                pulumi.String(email.Id),
			IntegrationEmail:      pulumi.String("s1@your_account.pagerduty.com"),
			EmailIncidentCreation: pulumi.String("use_rules"),
			EmailFilterMode:       pulumi.String("and-rules-email"),
			EmailFilters: pagerduty.ServiceIntegrationEmailFilterArray{
				&pagerduty.ServiceIntegrationEmailFilterArgs{
					BodyMode:       pulumi.String("always"),
					BodyRegex:      nil,
					FromEmailMode:  pulumi.String("match"),
					FromEmailRegex: pulumi.String("(@foo.test*)"),
					SubjectMode:    pulumi.String("match"),
					SubjectRegex:   pulumi.String("(CRITICAL*)"),
				},
				&pagerduty.ServiceIntegrationEmailFilterArgs{
					BodyMode:       pulumi.String("always"),
					BodyRegex:      nil,
					FromEmailMode:  pulumi.String("match"),
					FromEmailRegex: pulumi.String("(@bar.com*)"),
					SubjectMode:    pulumi.String("match"),
					SubjectRegex:   pulumi.String("(CRITICAL*)"),
				},
			},
			EmailParsers: pagerduty.ServiceIntegrationEmailParserArray{
				&pagerduty.ServiceIntegrationEmailParserArgs{
					Action: pulumi.String("resolve"),
					MatchPredicate: &pagerduty.ServiceIntegrationEmailParserMatchPredicateArgs{
						Type: pulumi.String("any"),
						Predicates: pagerduty.ServiceIntegrationEmailParserMatchPredicatePredicateArray{
							&pagerduty.ServiceIntegrationEmailParserMatchPredicatePredicateArgs{
								Matcher: pulumi.String("foo"),
								Part:    pulumi.String("subject"),
								Type:    pulumi.String("contains"),
							},
							&pagerduty.ServiceIntegrationEmailParserMatchPredicatePredicateArgs{
								Type: pulumi.String("not"),
								Predicates: pagerduty.ServiceIntegrationEmailParserMatchPredicatePredicatePredicateArray{
									&pagerduty.ServiceIntegrationEmailParserMatchPredicatePredicatePredicateArgs{
										Matcher: pulumi.String("(bar*)"),
										Part:    pulumi.String("body"),
										Type:    pulumi.String("regex"),
									},
								},
							},
						},
					},
					ValueExtractors: pagerduty.ServiceIntegrationEmailParserValueExtractorArray{
						&pagerduty.ServiceIntegrationEmailParserValueExtractorArgs{
							EndsBefore:  pulumi.String("end"),
							Part:        pulumi.String("subject"),
							StartsAfter: pulumi.String("start"),
							Type:        pulumi.String("between"),
							ValueName:   pulumi.String("incident_key"),
						},
						&pagerduty.ServiceIntegrationEmailParserValueExtractorArgs{
							EndsBefore:  pulumi.String("end"),
							Part:        pulumi.String("subject"),
							StartsAfter: pulumi.String("start"),
							Type:        pulumi.String("between"),
							ValueName:   pulumi.String("FieldName1"),
						},
					},
				},
			},
		})
		if err != nil {
			return err
		}
		return nil
	})
}
using System.Collections.Generic;
using System.Linq;
using Pulumi;
using Pagerduty = Pulumi.Pagerduty;
return await Deployment.RunAsync(() => 
{
    var example = new Pagerduty.User("example", new()
    {
        Name = "Earline Greenholt",
        Email = "125.greenholt.earline@graham.name",
        Teams = new[]
        {
            examplePagerdutyTeam.Id,
        },
    });
    var foo = new Pagerduty.EscalationPolicy("foo", new()
    {
        Name = "Engineering Escalation Policy",
        NumLoops = 2,
        Rules = new[]
        {
            new Pagerduty.Inputs.EscalationPolicyRuleArgs
            {
                EscalationDelayInMinutes = 10,
                Targets = new[]
                {
                    new Pagerduty.Inputs.EscalationPolicyRuleTargetArgs
                    {
                        Type = "user",
                        Id = example.Id,
                    },
                },
            },
        },
    });
    var exampleService = new Pagerduty.Service("example", new()
    {
        Name = "My Web App",
        AutoResolveTimeout = "14400",
        AcknowledgementTimeout = "600",
        EscalationPolicy = examplePagerdutyEscalationPolicy.Id,
    });
    var exampleServiceIntegration = new Pagerduty.ServiceIntegration("example", new()
    {
        Name = "Generic API Service Integration",
        Type = "generic_events_api_inbound_integration",
        Service = exampleService.Id,
    });
    var apiv2 = new Pagerduty.ServiceIntegration("apiv2", new()
    {
        Name = "API V2",
        Type = "events_api_v2_inbound_integration",
        Service = exampleService.Id,
    });
    var emailX = new Pagerduty.ServiceIntegration("email_x", new()
    {
        Name = "Email X",
        Type = "generic_email_inbound_integration",
        IntegrationEmail = "ecommerce@subdomain.pagerduty.com",
        Service = exampleService.Id,
    });
    var datadog = Pagerduty.GetVendor.Invoke(new()
    {
        Name = "Datadog",
    });
    var datadogServiceIntegration = new Pagerduty.ServiceIntegration("datadog", new()
    {
        Name = datadog.Apply(getVendorResult => getVendorResult.Name),
        Service = exampleService.Id,
        Vendor = datadog.Apply(getVendorResult => getVendorResult.Id),
    });
    var cloudwatch = Pagerduty.GetVendor.Invoke(new()
    {
        Name = "Cloudwatch",
    });
    var cloudwatchServiceIntegration = new Pagerduty.ServiceIntegration("cloudwatch", new()
    {
        Name = cloudwatch.Apply(getVendorResult => getVendorResult.Name),
        Service = exampleService.Id,
        Vendor = cloudwatch.Apply(getVendorResult => getVendorResult.Id),
    });
    var email = Pagerduty.GetVendor.Invoke(new()
    {
        Name = "Email",
    });
    var emailServiceIntegration = new Pagerduty.ServiceIntegration("email", new()
    {
        Name = email.Apply(getVendorResult => getVendorResult.Name),
        Service = exampleService.Id,
        Vendor = email.Apply(getVendorResult => getVendorResult.Id),
        IntegrationEmail = "s1@your_account.pagerduty.com",
        EmailIncidentCreation = "use_rules",
        EmailFilterMode = "and-rules-email",
        EmailFilters = new[]
        {
            new Pagerduty.Inputs.ServiceIntegrationEmailFilterArgs
            {
                BodyMode = "always",
                BodyRegex = null,
                FromEmailMode = "match",
                FromEmailRegex = "(@foo.test*)",
                SubjectMode = "match",
                SubjectRegex = "(CRITICAL*)",
            },
            new Pagerduty.Inputs.ServiceIntegrationEmailFilterArgs
            {
                BodyMode = "always",
                BodyRegex = null,
                FromEmailMode = "match",
                FromEmailRegex = "(@bar.com*)",
                SubjectMode = "match",
                SubjectRegex = "(CRITICAL*)",
            },
        },
        EmailParsers = new[]
        {
            new Pagerduty.Inputs.ServiceIntegrationEmailParserArgs
            {
                Action = "resolve",
                MatchPredicate = new Pagerduty.Inputs.ServiceIntegrationEmailParserMatchPredicateArgs
                {
                    Type = "any",
                    Predicates = new[]
                    {
                        new Pagerduty.Inputs.ServiceIntegrationEmailParserMatchPredicatePredicateArgs
                        {
                            Matcher = "foo",
                            Part = "subject",
                            Type = "contains",
                        },
                        new Pagerduty.Inputs.ServiceIntegrationEmailParserMatchPredicatePredicateArgs
                        {
                            Type = "not",
                            Predicates = new[]
                            {
                                new Pagerduty.Inputs.ServiceIntegrationEmailParserMatchPredicatePredicatePredicateArgs
                                {
                                    Matcher = "(bar*)",
                                    Part = "body",
                                    Type = "regex",
                                },
                            },
                        },
                    },
                },
                ValueExtractors = new[]
                {
                    new Pagerduty.Inputs.ServiceIntegrationEmailParserValueExtractorArgs
                    {
                        EndsBefore = "end",
                        Part = "subject",
                        StartsAfter = "start",
                        Type = "between",
                        ValueName = "incident_key",
                    },
                    new Pagerduty.Inputs.ServiceIntegrationEmailParserValueExtractorArgs
                    {
                        EndsBefore = "end",
                        Part = "subject",
                        StartsAfter = "start",
                        Type = "between",
                        ValueName = "FieldName1",
                    },
                },
            },
        },
    });
});
package generated_program;
import com.pulumi.Context;
import com.pulumi.Pulumi;
import com.pulumi.core.Output;
import com.pulumi.pagerduty.User;
import com.pulumi.pagerduty.UserArgs;
import com.pulumi.pagerduty.EscalationPolicy;
import com.pulumi.pagerduty.EscalationPolicyArgs;
import com.pulumi.pagerduty.inputs.EscalationPolicyRuleArgs;
import com.pulumi.pagerduty.Service;
import com.pulumi.pagerduty.ServiceArgs;
import com.pulumi.pagerduty.ServiceIntegration;
import com.pulumi.pagerduty.ServiceIntegrationArgs;
import com.pulumi.pagerduty.PagerdutyFunctions;
import com.pulumi.pagerduty.inputs.GetVendorArgs;
import com.pulumi.pagerduty.inputs.ServiceIntegrationEmailFilterArgs;
import com.pulumi.pagerduty.inputs.ServiceIntegrationEmailParserArgs;
import com.pulumi.pagerduty.inputs.ServiceIntegrationEmailParserMatchPredicateArgs;
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 User("example", UserArgs.builder()
            .name("Earline Greenholt")
            .email("125.greenholt.earline@graham.name")
            .teams(examplePagerdutyTeam.id())
            .build());
        var foo = new EscalationPolicy("foo", EscalationPolicyArgs.builder()
            .name("Engineering Escalation Policy")
            .numLoops(2)
            .rules(EscalationPolicyRuleArgs.builder()
                .escalationDelayInMinutes(10)
                .targets(EscalationPolicyRuleTargetArgs.builder()
                    .type("user")
                    .id(example.id())
                    .build())
                .build())
            .build());
        var exampleService = new Service("exampleService", ServiceArgs.builder()
            .name("My Web App")
            .autoResolveTimeout(14400)
            .acknowledgementTimeout(600)
            .escalationPolicy(examplePagerdutyEscalationPolicy.id())
            .build());
        var exampleServiceIntegration = new ServiceIntegration("exampleServiceIntegration", ServiceIntegrationArgs.builder()
            .name("Generic API Service Integration")
            .type("generic_events_api_inbound_integration")
            .service(exampleService.id())
            .build());
        var apiv2 = new ServiceIntegration("apiv2", ServiceIntegrationArgs.builder()
            .name("API V2")
            .type("events_api_v2_inbound_integration")
            .service(exampleService.id())
            .build());
        var emailX = new ServiceIntegration("emailX", ServiceIntegrationArgs.builder()
            .name("Email X")
            .type("generic_email_inbound_integration")
            .integrationEmail("ecommerce@subdomain.pagerduty.com")
            .service(exampleService.id())
            .build());
        final var datadog = PagerdutyFunctions.getVendor(GetVendorArgs.builder()
            .name("Datadog")
            .build());
        var datadogServiceIntegration = new ServiceIntegration("datadogServiceIntegration", ServiceIntegrationArgs.builder()
            .name(datadog.applyValue(getVendorResult -> getVendorResult.name()))
            .service(exampleService.id())
            .vendor(datadog.applyValue(getVendorResult -> getVendorResult.id()))
            .build());
        final var cloudwatch = PagerdutyFunctions.getVendor(GetVendorArgs.builder()
            .name("Cloudwatch")
            .build());
        var cloudwatchServiceIntegration = new ServiceIntegration("cloudwatchServiceIntegration", ServiceIntegrationArgs.builder()
            .name(cloudwatch.applyValue(getVendorResult -> getVendorResult.name()))
            .service(exampleService.id())
            .vendor(cloudwatch.applyValue(getVendorResult -> getVendorResult.id()))
            .build());
        final var email = PagerdutyFunctions.getVendor(GetVendorArgs.builder()
            .name("Email")
            .build());
        var emailServiceIntegration = new ServiceIntegration("emailServiceIntegration", ServiceIntegrationArgs.builder()
            .name(email.applyValue(getVendorResult -> getVendorResult.name()))
            .service(exampleService.id())
            .vendor(email.applyValue(getVendorResult -> getVendorResult.id()))
            .integrationEmail("s1@your_account.pagerduty.com")
            .emailIncidentCreation("use_rules")
            .emailFilterMode("and-rules-email")
            .emailFilters(            
                ServiceIntegrationEmailFilterArgs.builder()
                    .bodyMode("always")
                    .bodyRegex(null)
                    .fromEmailMode("match")
                    .fromEmailRegex("(@foo.test*)")
                    .subjectMode("match")
                    .subjectRegex("(CRITICAL*)")
                    .build(),
                ServiceIntegrationEmailFilterArgs.builder()
                    .bodyMode("always")
                    .bodyRegex(null)
                    .fromEmailMode("match")
                    .fromEmailRegex("(@bar.com*)")
                    .subjectMode("match")
                    .subjectRegex("(CRITICAL*)")
                    .build())
            .emailParsers(ServiceIntegrationEmailParserArgs.builder()
                .action("resolve")
                .matchPredicate(ServiceIntegrationEmailParserMatchPredicateArgs.builder()
                    .type("any")
                    .predicates(                    
                        ServiceIntegrationEmailParserMatchPredicatePredicateArgs.builder()
                            .matcher("foo")
                            .part("subject")
                            .type("contains")
                            .build(),
                        ServiceIntegrationEmailParserMatchPredicatePredicateArgs.builder()
                            .type("not")
                            .predicates(ServiceIntegrationEmailParserMatchPredicatePredicatePredicateArgs.builder()
                                .matcher("(bar*)")
                                .part("body")
                                .type("regex")
                                .build())
                            .build())
                    .build())
                .valueExtractors(                
                    ServiceIntegrationEmailParserValueExtractorArgs.builder()
                        .endsBefore("end")
                        .part("subject")
                        .startsAfter("start")
                        .type("between")
                        .valueName("incident_key")
                        .build(),
                    ServiceIntegrationEmailParserValueExtractorArgs.builder()
                        .endsBefore("end")
                        .part("subject")
                        .startsAfter("start")
                        .type("between")
                        .valueName("FieldName1")
                        .build())
                .build())
            .build());
    }
}
resources:
  example:
    type: pagerduty:User
    properties:
      name: Earline Greenholt
      email: 125.greenholt.earline@graham.name
      teams:
        - ${examplePagerdutyTeam.id}
  foo:
    type: pagerduty:EscalationPolicy
    properties:
      name: Engineering Escalation Policy
      numLoops: 2
      rules:
        - escalationDelayInMinutes: 10
          targets:
            - type: user
              id: ${example.id}
  exampleService:
    type: pagerduty:Service
    name: example
    properties:
      name: My Web App
      autoResolveTimeout: 14400
      acknowledgementTimeout: 600
      escalationPolicy: ${examplePagerdutyEscalationPolicy.id}
  exampleServiceIntegration:
    type: pagerduty:ServiceIntegration
    name: example
    properties:
      name: Generic API Service Integration
      type: generic_events_api_inbound_integration
      service: ${exampleService.id}
  apiv2:
    type: pagerduty:ServiceIntegration
    properties:
      name: API V2
      type: events_api_v2_inbound_integration
      service: ${exampleService.id}
  emailX:
    type: pagerduty:ServiceIntegration
    name: email_x
    properties:
      name: Email X
      type: generic_email_inbound_integration
      integrationEmail: ecommerce@subdomain.pagerduty.com
      service: ${exampleService.id}
  datadogServiceIntegration:
    type: pagerduty:ServiceIntegration
    name: datadog
    properties:
      name: ${datadog.name}
      service: ${exampleService.id}
      vendor: ${datadog.id}
  cloudwatchServiceIntegration:
    type: pagerduty:ServiceIntegration
    name: cloudwatch
    properties:
      name: ${cloudwatch.name}
      service: ${exampleService.id}
      vendor: ${cloudwatch.id}
  emailServiceIntegration:
    type: pagerduty:ServiceIntegration
    name: email
    properties:
      name: ${email.name}
      service: ${exampleService.id}
      vendor: ${email.id}
      integrationEmail: s1@your_account.pagerduty.com
      emailIncidentCreation: use_rules
      emailFilterMode: and-rules-email
      emailFilters:
        - bodyMode: always
          bodyRegex: null
          fromEmailMode: match
          fromEmailRegex: (@foo.test*)
          subjectMode: match
          subjectRegex: (CRITICAL*)
        - bodyMode: always
          bodyRegex: null
          fromEmailMode: match
          fromEmailRegex: (@bar.com*)
          subjectMode: match
          subjectRegex: (CRITICAL*)
      emailParsers:
        - action: resolve
          matchPredicate:
            type: any
            predicates:
              - matcher: foo
                part: subject
                type: contains
              - type: not
                predicates:
                  - matcher: (bar*)
                    part: body
                    type: regex
          valueExtractors:
            - endsBefore: end
              part: subject
              startsAfter: start
              type: between
              valueName: incident_key
            - endsBefore: end
              part: subject
              startsAfter: start
              type: between
              valueName: FieldName1
variables:
  datadog:
    fn::invoke:
      Function: pagerduty:getVendor
      Arguments:
        name: Datadog
  cloudwatch:
    fn::invoke:
      Function: pagerduty:getVendor
      Arguments:
        name: Cloudwatch
  email:
    fn::invoke:
      Function: pagerduty:getVendor
      Arguments:
        name: Email
Create ServiceIntegration Resource
Resources are created with functions called constructors. To learn more about declaring and configuring resources, see Resources.
Constructor syntax
new ServiceIntegration(name: string, args: ServiceIntegrationArgs, opts?: CustomResourceOptions);@overload
def ServiceIntegration(resource_name: str,
                       args: ServiceIntegrationArgs,
                       opts: Optional[ResourceOptions] = None)
@overload
def ServiceIntegration(resource_name: str,
                       opts: Optional[ResourceOptions] = None,
                       service: Optional[str] = None,
                       email_filter_mode: Optional[str] = None,
                       email_filters: Optional[Sequence[ServiceIntegrationEmailFilterArgs]] = None,
                       email_incident_creation: Optional[str] = None,
                       email_parsers: Optional[Sequence[ServiceIntegrationEmailParserArgs]] = None,
                       email_parsing_fallback: Optional[str] = None,
                       integration_email: Optional[str] = None,
                       integration_key: Optional[str] = None,
                       name: Optional[str] = None,
                       type: Optional[str] = None,
                       vendor: Optional[str] = None)func NewServiceIntegration(ctx *Context, name string, args ServiceIntegrationArgs, opts ...ResourceOption) (*ServiceIntegration, error)public ServiceIntegration(string name, ServiceIntegrationArgs args, CustomResourceOptions? opts = null)
public ServiceIntegration(String name, ServiceIntegrationArgs args)
public ServiceIntegration(String name, ServiceIntegrationArgs args, CustomResourceOptions options)
type: pagerduty:ServiceIntegration
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 ServiceIntegrationArgs
 - 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 ServiceIntegrationArgs
 - 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 ServiceIntegrationArgs
 - The arguments to resource properties.
 - opts ResourceOption
 - Bag of options to control resource's behavior.
 
- name string
 - The unique name of the resource.
 - args ServiceIntegrationArgs
 - The arguments to resource properties.
 - opts CustomResourceOptions
 - Bag of options to control resource's behavior.
 
- name String
 - The unique name of the resource.
 - args ServiceIntegrationArgs
 - 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 serviceIntegrationResource = new Pagerduty.ServiceIntegration("serviceIntegrationResource", new()
{
    Service = "string",
    EmailFilterMode = "string",
    EmailFilters = new[]
    {
        new Pagerduty.Inputs.ServiceIntegrationEmailFilterArgs
        {
            BodyMode = "string",
            BodyRegex = "string",
            FromEmailMode = "string",
            FromEmailRegex = "string",
            Id = "string",
            SubjectMode = "string",
            SubjectRegex = "string",
        },
    },
    EmailIncidentCreation = "string",
    EmailParsers = new[]
    {
        new Pagerduty.Inputs.ServiceIntegrationEmailParserArgs
        {
            Action = "string",
            MatchPredicate = new Pagerduty.Inputs.ServiceIntegrationEmailParserMatchPredicateArgs
            {
                Type = "string",
                Predicates = new[]
                {
                    new Pagerduty.Inputs.ServiceIntegrationEmailParserMatchPredicatePredicateArgs
                    {
                        Type = "string",
                        Matcher = "string",
                        Part = "string",
                        Predicates = new[]
                        {
                            new Pagerduty.Inputs.ServiceIntegrationEmailParserMatchPredicatePredicatePredicateArgs
                            {
                                Matcher = "string",
                                Part = "string",
                                Type = "string",
                            },
                        },
                    },
                },
            },
            Id = 0,
            ValueExtractors = new[]
            {
                new Pagerduty.Inputs.ServiceIntegrationEmailParserValueExtractorArgs
                {
                    Part = "string",
                    Type = "string",
                    ValueName = "string",
                    EndsBefore = "string",
                    Regex = "string",
                    StartsAfter = "string",
                },
            },
        },
    },
    EmailParsingFallback = "string",
    IntegrationEmail = "string",
    IntegrationKey = "string",
    Name = "string",
    Type = "string",
    Vendor = "string",
});
example, err := pagerduty.NewServiceIntegration(ctx, "serviceIntegrationResource", &pagerduty.ServiceIntegrationArgs{
	Service:         pulumi.String("string"),
	EmailFilterMode: pulumi.String("string"),
	EmailFilters: pagerduty.ServiceIntegrationEmailFilterArray{
		&pagerduty.ServiceIntegrationEmailFilterArgs{
			BodyMode:       pulumi.String("string"),
			BodyRegex:      pulumi.String("string"),
			FromEmailMode:  pulumi.String("string"),
			FromEmailRegex: pulumi.String("string"),
			Id:             pulumi.String("string"),
			SubjectMode:    pulumi.String("string"),
			SubjectRegex:   pulumi.String("string"),
		},
	},
	EmailIncidentCreation: pulumi.String("string"),
	EmailParsers: pagerduty.ServiceIntegrationEmailParserArray{
		&pagerduty.ServiceIntegrationEmailParserArgs{
			Action: pulumi.String("string"),
			MatchPredicate: &pagerduty.ServiceIntegrationEmailParserMatchPredicateArgs{
				Type: pulumi.String("string"),
				Predicates: pagerduty.ServiceIntegrationEmailParserMatchPredicatePredicateArray{
					&pagerduty.ServiceIntegrationEmailParserMatchPredicatePredicateArgs{
						Type:    pulumi.String("string"),
						Matcher: pulumi.String("string"),
						Part:    pulumi.String("string"),
						Predicates: pagerduty.ServiceIntegrationEmailParserMatchPredicatePredicatePredicateArray{
							&pagerduty.ServiceIntegrationEmailParserMatchPredicatePredicatePredicateArgs{
								Matcher: pulumi.String("string"),
								Part:    pulumi.String("string"),
								Type:    pulumi.String("string"),
							},
						},
					},
				},
			},
			Id: pulumi.Int(0),
			ValueExtractors: pagerduty.ServiceIntegrationEmailParserValueExtractorArray{
				&pagerduty.ServiceIntegrationEmailParserValueExtractorArgs{
					Part:        pulumi.String("string"),
					Type:        pulumi.String("string"),
					ValueName:   pulumi.String("string"),
					EndsBefore:  pulumi.String("string"),
					Regex:       pulumi.String("string"),
					StartsAfter: pulumi.String("string"),
				},
			},
		},
	},
	EmailParsingFallback: pulumi.String("string"),
	IntegrationEmail:     pulumi.String("string"),
	IntegrationKey:       pulumi.String("string"),
	Name:                 pulumi.String("string"),
	Type:                 pulumi.String("string"),
	Vendor:               pulumi.String("string"),
})
var serviceIntegrationResource = new ServiceIntegration("serviceIntegrationResource", ServiceIntegrationArgs.builder()
    .service("string")
    .emailFilterMode("string")
    .emailFilters(ServiceIntegrationEmailFilterArgs.builder()
        .bodyMode("string")
        .bodyRegex("string")
        .fromEmailMode("string")
        .fromEmailRegex("string")
        .id("string")
        .subjectMode("string")
        .subjectRegex("string")
        .build())
    .emailIncidentCreation("string")
    .emailParsers(ServiceIntegrationEmailParserArgs.builder()
        .action("string")
        .matchPredicate(ServiceIntegrationEmailParserMatchPredicateArgs.builder()
            .type("string")
            .predicates(ServiceIntegrationEmailParserMatchPredicatePredicateArgs.builder()
                .type("string")
                .matcher("string")
                .part("string")
                .predicates(ServiceIntegrationEmailParserMatchPredicatePredicatePredicateArgs.builder()
                    .matcher("string")
                    .part("string")
                    .type("string")
                    .build())
                .build())
            .build())
        .id(0)
        .valueExtractors(ServiceIntegrationEmailParserValueExtractorArgs.builder()
            .part("string")
            .type("string")
            .valueName("string")
            .endsBefore("string")
            .regex("string")
            .startsAfter("string")
            .build())
        .build())
    .emailParsingFallback("string")
    .integrationEmail("string")
    .integrationKey("string")
    .name("string")
    .type("string")
    .vendor("string")
    .build());
service_integration_resource = pagerduty.ServiceIntegration("serviceIntegrationResource",
    service="string",
    email_filter_mode="string",
    email_filters=[{
        "body_mode": "string",
        "body_regex": "string",
        "from_email_mode": "string",
        "from_email_regex": "string",
        "id": "string",
        "subject_mode": "string",
        "subject_regex": "string",
    }],
    email_incident_creation="string",
    email_parsers=[{
        "action": "string",
        "match_predicate": {
            "type": "string",
            "predicates": [{
                "type": "string",
                "matcher": "string",
                "part": "string",
                "predicates": [{
                    "matcher": "string",
                    "part": "string",
                    "type": "string",
                }],
            }],
        },
        "id": 0,
        "value_extractors": [{
            "part": "string",
            "type": "string",
            "value_name": "string",
            "ends_before": "string",
            "regex": "string",
            "starts_after": "string",
        }],
    }],
    email_parsing_fallback="string",
    integration_email="string",
    integration_key="string",
    name="string",
    type="string",
    vendor="string")
const serviceIntegrationResource = new pagerduty.ServiceIntegration("serviceIntegrationResource", {
    service: "string",
    emailFilterMode: "string",
    emailFilters: [{
        bodyMode: "string",
        bodyRegex: "string",
        fromEmailMode: "string",
        fromEmailRegex: "string",
        id: "string",
        subjectMode: "string",
        subjectRegex: "string",
    }],
    emailIncidentCreation: "string",
    emailParsers: [{
        action: "string",
        matchPredicate: {
            type: "string",
            predicates: [{
                type: "string",
                matcher: "string",
                part: "string",
                predicates: [{
                    matcher: "string",
                    part: "string",
                    type: "string",
                }],
            }],
        },
        id: 0,
        valueExtractors: [{
            part: "string",
            type: "string",
            valueName: "string",
            endsBefore: "string",
            regex: "string",
            startsAfter: "string",
        }],
    }],
    emailParsingFallback: "string",
    integrationEmail: "string",
    integrationKey: "string",
    name: "string",
    type: "string",
    vendor: "string",
});
type: pagerduty:ServiceIntegration
properties:
    emailFilterMode: string
    emailFilters:
        - bodyMode: string
          bodyRegex: string
          fromEmailMode: string
          fromEmailRegex: string
          id: string
          subjectMode: string
          subjectRegex: string
    emailIncidentCreation: string
    emailParsers:
        - action: string
          id: 0
          matchPredicate:
            predicates:
                - matcher: string
                  part: string
                  predicates:
                    - matcher: string
                      part: string
                      type: string
                  type: string
            type: string
          valueExtractors:
            - endsBefore: string
              part: string
              regex: string
              startsAfter: string
              type: string
              valueName: string
    emailParsingFallback: string
    integrationEmail: string
    integrationKey: string
    name: string
    service: string
    type: string
    vendor: string
ServiceIntegration 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 ServiceIntegration resource accepts the following input properties:
- Service string
 - The ID of the service the integration should belong to.
 - Email
Filter stringMode  - Mode of Emails Filters feature (explained in PD docs). Can be 
all-email,or-rules-emailorand-rules-email. - Email
Filters List<ServiceIntegration Email Filter>  - Email
Incident stringCreation  - Behaviour of Email Management feature (explained in PD docs). Can be 
on_new_email,on_new_email_subject,only_if_no_open_incidentsoruse_rules. - Email
Parsers List<ServiceIntegration Email Parser>  - Email
Parsing stringFallback  - Can be 
open_new_incidentordiscard. - Integration
Email string - This is the unique fully-qualified email address used for routing emails to this integration for processing.
 - Integration
Key string - (Deprecated) This is the unique key used to route events to this integration when received via the PagerDuty Events API.
 - Name string
 - The name of the service integration.
 - Type string
 The service type. Can be:
aws_cloudwatch_inbound_integration,cloudkick_inbound_integration,event_transformer_api_inbound_integration,events_api_v2_inbound_integration(requires servicealert_creationto becreate_alerts_and_incidents),generic_email_inbound_integration,generic_events_api_inbound_integration,keynote_inbound_integration,nagios_inbound_integration,pingdom_inbound_integrationorsql_monitor_inbound_integration.Note: This is meant for generic service integrations. To integrate with a vendor (e.g. Datadog or Amazon Cloudwatch) use the
vendorfield instead.- Vendor string
 - The ID of the vendor the integration should integrate with (e.g. Datadog or Amazon Cloudwatch).
 
- Service string
 - The ID of the service the integration should belong to.
 - Email
Filter stringMode  - Mode of Emails Filters feature (explained in PD docs). Can be 
all-email,or-rules-emailorand-rules-email. - Email
Filters []ServiceIntegration Email Filter Args  - Email
Incident stringCreation  - Behaviour of Email Management feature (explained in PD docs). Can be 
on_new_email,on_new_email_subject,only_if_no_open_incidentsoruse_rules. - Email
Parsers []ServiceIntegration Email Parser Args  - Email
Parsing stringFallback  - Can be 
open_new_incidentordiscard. - Integration
Email string - This is the unique fully-qualified email address used for routing emails to this integration for processing.
 - Integration
Key string - (Deprecated) This is the unique key used to route events to this integration when received via the PagerDuty Events API.
 - Name string
 - The name of the service integration.
 - Type string
 The service type. Can be:
aws_cloudwatch_inbound_integration,cloudkick_inbound_integration,event_transformer_api_inbound_integration,events_api_v2_inbound_integration(requires servicealert_creationto becreate_alerts_and_incidents),generic_email_inbound_integration,generic_events_api_inbound_integration,keynote_inbound_integration,nagios_inbound_integration,pingdom_inbound_integrationorsql_monitor_inbound_integration.Note: This is meant for generic service integrations. To integrate with a vendor (e.g. Datadog or Amazon Cloudwatch) use the
vendorfield instead.- Vendor string
 - The ID of the vendor the integration should integrate with (e.g. Datadog or Amazon Cloudwatch).
 
- service String
 - The ID of the service the integration should belong to.
 - email
Filter StringMode  - Mode of Emails Filters feature (explained in PD docs). Can be 
all-email,or-rules-emailorand-rules-email. - email
Filters List<ServiceIntegration Email Filter>  - email
Incident StringCreation  - Behaviour of Email Management feature (explained in PD docs). Can be 
on_new_email,on_new_email_subject,only_if_no_open_incidentsoruse_rules. - email
Parsers List<ServiceIntegration Email Parser>  - email
Parsing StringFallback  - Can be 
open_new_incidentordiscard. - integration
Email String - This is the unique fully-qualified email address used for routing emails to this integration for processing.
 - integration
Key String - (Deprecated) This is the unique key used to route events to this integration when received via the PagerDuty Events API.
 - name String
 - The name of the service integration.
 - type String
 The service type. Can be:
aws_cloudwatch_inbound_integration,cloudkick_inbound_integration,event_transformer_api_inbound_integration,events_api_v2_inbound_integration(requires servicealert_creationto becreate_alerts_and_incidents),generic_email_inbound_integration,generic_events_api_inbound_integration,keynote_inbound_integration,nagios_inbound_integration,pingdom_inbound_integrationorsql_monitor_inbound_integration.Note: This is meant for generic service integrations. To integrate with a vendor (e.g. Datadog or Amazon Cloudwatch) use the
vendorfield instead.- vendor String
 - The ID of the vendor the integration should integrate with (e.g. Datadog or Amazon Cloudwatch).
 
- service string
 - The ID of the service the integration should belong to.
 - email
Filter stringMode  - Mode of Emails Filters feature (explained in PD docs). Can be 
all-email,or-rules-emailorand-rules-email. - email
Filters ServiceIntegration Email Filter[]  - email
Incident stringCreation  - Behaviour of Email Management feature (explained in PD docs). Can be 
on_new_email,on_new_email_subject,only_if_no_open_incidentsoruse_rules. - email
Parsers ServiceIntegration Email Parser[]  - email
Parsing stringFallback  - Can be 
open_new_incidentordiscard. - integration
Email string - This is the unique fully-qualified email address used for routing emails to this integration for processing.
 - integration
Key string - (Deprecated) This is the unique key used to route events to this integration when received via the PagerDuty Events API.
 - name string
 - The name of the service integration.
 - type string
 The service type. Can be:
aws_cloudwatch_inbound_integration,cloudkick_inbound_integration,event_transformer_api_inbound_integration,events_api_v2_inbound_integration(requires servicealert_creationto becreate_alerts_and_incidents),generic_email_inbound_integration,generic_events_api_inbound_integration,keynote_inbound_integration,nagios_inbound_integration,pingdom_inbound_integrationorsql_monitor_inbound_integration.Note: This is meant for generic service integrations. To integrate with a vendor (e.g. Datadog or Amazon Cloudwatch) use the
vendorfield instead.- vendor string
 - The ID of the vendor the integration should integrate with (e.g. Datadog or Amazon Cloudwatch).
 
- service str
 - The ID of the service the integration should belong to.
 - email_
filter_ strmode  - Mode of Emails Filters feature (explained in PD docs). Can be 
all-email,or-rules-emailorand-rules-email. - email_
filters Sequence[ServiceIntegration Email Filter Args]  - email_
incident_ strcreation  - Behaviour of Email Management feature (explained in PD docs). Can be 
on_new_email,on_new_email_subject,only_if_no_open_incidentsoruse_rules. - email_
parsers Sequence[ServiceIntegration Email Parser Args]  - email_
parsing_ strfallback  - Can be 
open_new_incidentordiscard. - integration_
email str - This is the unique fully-qualified email address used for routing emails to this integration for processing.
 - integration_
key str - (Deprecated) This is the unique key used to route events to this integration when received via the PagerDuty Events API.
 - name str
 - The name of the service integration.
 - type str
 The service type. Can be:
aws_cloudwatch_inbound_integration,cloudkick_inbound_integration,event_transformer_api_inbound_integration,events_api_v2_inbound_integration(requires servicealert_creationto becreate_alerts_and_incidents),generic_email_inbound_integration,generic_events_api_inbound_integration,keynote_inbound_integration,nagios_inbound_integration,pingdom_inbound_integrationorsql_monitor_inbound_integration.Note: This is meant for generic service integrations. To integrate with a vendor (e.g. Datadog or Amazon Cloudwatch) use the
vendorfield instead.- vendor str
 - The ID of the vendor the integration should integrate with (e.g. Datadog or Amazon Cloudwatch).
 
- service String
 - The ID of the service the integration should belong to.
 - email
Filter StringMode  - Mode of Emails Filters feature (explained in PD docs). Can be 
all-email,or-rules-emailorand-rules-email. - email
Filters List<Property Map> - email
Incident StringCreation  - Behaviour of Email Management feature (explained in PD docs). Can be 
on_new_email,on_new_email_subject,only_if_no_open_incidentsoruse_rules. - email
Parsers List<Property Map> - email
Parsing StringFallback  - Can be 
open_new_incidentordiscard. - integration
Email String - This is the unique fully-qualified email address used for routing emails to this integration for processing.
 - integration
Key String - (Deprecated) This is the unique key used to route events to this integration when received via the PagerDuty Events API.
 - name String
 - The name of the service integration.
 - type String
 The service type. Can be:
aws_cloudwatch_inbound_integration,cloudkick_inbound_integration,event_transformer_api_inbound_integration,events_api_v2_inbound_integration(requires servicealert_creationto becreate_alerts_and_incidents),generic_email_inbound_integration,generic_events_api_inbound_integration,keynote_inbound_integration,nagios_inbound_integration,pingdom_inbound_integrationorsql_monitor_inbound_integration.Note: This is meant for generic service integrations. To integrate with a vendor (e.g. Datadog or Amazon Cloudwatch) use the
vendorfield instead.- vendor String
 - The ID of the vendor the integration should integrate with (e.g. Datadog or Amazon Cloudwatch).
 
Outputs
All input properties are implicitly available as output properties. Additionally, the ServiceIntegration resource produces the following output properties:
Look up Existing ServiceIntegration Resource
Get an existing ServiceIntegration 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?: ServiceIntegrationState, opts?: CustomResourceOptions): ServiceIntegration@staticmethod
def get(resource_name: str,
        id: str,
        opts: Optional[ResourceOptions] = None,
        email_filter_mode: Optional[str] = None,
        email_filters: Optional[Sequence[ServiceIntegrationEmailFilterArgs]] = None,
        email_incident_creation: Optional[str] = None,
        email_parsers: Optional[Sequence[ServiceIntegrationEmailParserArgs]] = None,
        email_parsing_fallback: Optional[str] = None,
        html_url: Optional[str] = None,
        integration_email: Optional[str] = None,
        integration_key: Optional[str] = None,
        name: Optional[str] = None,
        service: Optional[str] = None,
        type: Optional[str] = None,
        vendor: Optional[str] = None) -> ServiceIntegrationfunc GetServiceIntegration(ctx *Context, name string, id IDInput, state *ServiceIntegrationState, opts ...ResourceOption) (*ServiceIntegration, error)public static ServiceIntegration Get(string name, Input<string> id, ServiceIntegrationState? state, CustomResourceOptions? opts = null)public static ServiceIntegration get(String name, Output<String> id, ServiceIntegrationState state, CustomResourceOptions options)Resource lookup is not supported in YAML- 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.
 
- Email
Filter stringMode  - Mode of Emails Filters feature (explained in PD docs). Can be 
all-email,or-rules-emailorand-rules-email. - Email
Filters List<ServiceIntegration Email Filter>  - Email
Incident stringCreation  - Behaviour of Email Management feature (explained in PD docs). Can be 
on_new_email,on_new_email_subject,only_if_no_open_incidentsoruse_rules. - Email
Parsers List<ServiceIntegration Email Parser>  - Email
Parsing stringFallback  - Can be 
open_new_incidentordiscard. - Html
Url string - URL at which the entity is uniquely displayed in the Web app.
 - Integration
Email string - This is the unique fully-qualified email address used for routing emails to this integration for processing.
 - Integration
Key string - (Deprecated) This is the unique key used to route events to this integration when received via the PagerDuty Events API.
 - Name string
 - The name of the service integration.
 - Service string
 - The ID of the service the integration should belong to.
 - Type string
 The service type. Can be:
aws_cloudwatch_inbound_integration,cloudkick_inbound_integration,event_transformer_api_inbound_integration,events_api_v2_inbound_integration(requires servicealert_creationto becreate_alerts_and_incidents),generic_email_inbound_integration,generic_events_api_inbound_integration,keynote_inbound_integration,nagios_inbound_integration,pingdom_inbound_integrationorsql_monitor_inbound_integration.Note: This is meant for generic service integrations. To integrate with a vendor (e.g. Datadog or Amazon Cloudwatch) use the
vendorfield instead.- Vendor string
 - The ID of the vendor the integration should integrate with (e.g. Datadog or Amazon Cloudwatch).
 
- Email
Filter stringMode  - Mode of Emails Filters feature (explained in PD docs). Can be 
all-email,or-rules-emailorand-rules-email. - Email
Filters []ServiceIntegration Email Filter Args  - Email
Incident stringCreation  - Behaviour of Email Management feature (explained in PD docs). Can be 
on_new_email,on_new_email_subject,only_if_no_open_incidentsoruse_rules. - Email
Parsers []ServiceIntegration Email Parser Args  - Email
Parsing stringFallback  - Can be 
open_new_incidentordiscard. - Html
Url string - URL at which the entity is uniquely displayed in the Web app.
 - Integration
Email string - This is the unique fully-qualified email address used for routing emails to this integration for processing.
 - Integration
Key string - (Deprecated) This is the unique key used to route events to this integration when received via the PagerDuty Events API.
 - Name string
 - The name of the service integration.
 - Service string
 - The ID of the service the integration should belong to.
 - Type string
 The service type. Can be:
aws_cloudwatch_inbound_integration,cloudkick_inbound_integration,event_transformer_api_inbound_integration,events_api_v2_inbound_integration(requires servicealert_creationto becreate_alerts_and_incidents),generic_email_inbound_integration,generic_events_api_inbound_integration,keynote_inbound_integration,nagios_inbound_integration,pingdom_inbound_integrationorsql_monitor_inbound_integration.Note: This is meant for generic service integrations. To integrate with a vendor (e.g. Datadog or Amazon Cloudwatch) use the
vendorfield instead.- Vendor string
 - The ID of the vendor the integration should integrate with (e.g. Datadog or Amazon Cloudwatch).
 
- email
Filter StringMode  - Mode of Emails Filters feature (explained in PD docs). Can be 
all-email,or-rules-emailorand-rules-email. - email
Filters List<ServiceIntegration Email Filter>  - email
Incident StringCreation  - Behaviour of Email Management feature (explained in PD docs). Can be 
on_new_email,on_new_email_subject,only_if_no_open_incidentsoruse_rules. - email
Parsers List<ServiceIntegration Email Parser>  - email
Parsing StringFallback  - Can be 
open_new_incidentordiscard. - html
Url String - URL at which the entity is uniquely displayed in the Web app.
 - integration
Email String - This is the unique fully-qualified email address used for routing emails to this integration for processing.
 - integration
Key String - (Deprecated) This is the unique key used to route events to this integration when received via the PagerDuty Events API.
 - name String
 - The name of the service integration.
 - service String
 - The ID of the service the integration should belong to.
 - type String
 The service type. Can be:
aws_cloudwatch_inbound_integration,cloudkick_inbound_integration,event_transformer_api_inbound_integration,events_api_v2_inbound_integration(requires servicealert_creationto becreate_alerts_and_incidents),generic_email_inbound_integration,generic_events_api_inbound_integration,keynote_inbound_integration,nagios_inbound_integration,pingdom_inbound_integrationorsql_monitor_inbound_integration.Note: This is meant for generic service integrations. To integrate with a vendor (e.g. Datadog or Amazon Cloudwatch) use the
vendorfield instead.- vendor String
 - The ID of the vendor the integration should integrate with (e.g. Datadog or Amazon Cloudwatch).
 
- email
Filter stringMode  - Mode of Emails Filters feature (explained in PD docs). Can be 
all-email,or-rules-emailorand-rules-email. - email
Filters ServiceIntegration Email Filter[]  - email
Incident stringCreation  - Behaviour of Email Management feature (explained in PD docs). Can be 
on_new_email,on_new_email_subject,only_if_no_open_incidentsoruse_rules. - email
Parsers ServiceIntegration Email Parser[]  - email
Parsing stringFallback  - Can be 
open_new_incidentordiscard. - html
Url string - URL at which the entity is uniquely displayed in the Web app.
 - integration
Email string - This is the unique fully-qualified email address used for routing emails to this integration for processing.
 - integration
Key string - (Deprecated) This is the unique key used to route events to this integration when received via the PagerDuty Events API.
 - name string
 - The name of the service integration.
 - service string
 - The ID of the service the integration should belong to.
 - type string
 The service type. Can be:
aws_cloudwatch_inbound_integration,cloudkick_inbound_integration,event_transformer_api_inbound_integration,events_api_v2_inbound_integration(requires servicealert_creationto becreate_alerts_and_incidents),generic_email_inbound_integration,generic_events_api_inbound_integration,keynote_inbound_integration,nagios_inbound_integration,pingdom_inbound_integrationorsql_monitor_inbound_integration.Note: This is meant for generic service integrations. To integrate with a vendor (e.g. Datadog or Amazon Cloudwatch) use the
vendorfield instead.- vendor string
 - The ID of the vendor the integration should integrate with (e.g. Datadog or Amazon Cloudwatch).
 
- email_
filter_ strmode  - Mode of Emails Filters feature (explained in PD docs). Can be 
all-email,or-rules-emailorand-rules-email. - email_
filters Sequence[ServiceIntegration Email Filter Args]  - email_
incident_ strcreation  - Behaviour of Email Management feature (explained in PD docs). Can be 
on_new_email,on_new_email_subject,only_if_no_open_incidentsoruse_rules. - email_
parsers Sequence[ServiceIntegration Email Parser Args]  - email_
parsing_ strfallback  - Can be 
open_new_incidentordiscard. - html_
url str - URL at which the entity is uniquely displayed in the Web app.
 - integration_
email str - This is the unique fully-qualified email address used for routing emails to this integration for processing.
 - integration_
key str - (Deprecated) This is the unique key used to route events to this integration when received via the PagerDuty Events API.
 - name str
 - The name of the service integration.
 - service str
 - The ID of the service the integration should belong to.
 - type str
 The service type. Can be:
aws_cloudwatch_inbound_integration,cloudkick_inbound_integration,event_transformer_api_inbound_integration,events_api_v2_inbound_integration(requires servicealert_creationto becreate_alerts_and_incidents),generic_email_inbound_integration,generic_events_api_inbound_integration,keynote_inbound_integration,nagios_inbound_integration,pingdom_inbound_integrationorsql_monitor_inbound_integration.Note: This is meant for generic service integrations. To integrate with a vendor (e.g. Datadog or Amazon Cloudwatch) use the
vendorfield instead.- vendor str
 - The ID of the vendor the integration should integrate with (e.g. Datadog or Amazon Cloudwatch).
 
- email
Filter StringMode  - Mode of Emails Filters feature (explained in PD docs). Can be 
all-email,or-rules-emailorand-rules-email. - email
Filters List<Property Map> - email
Incident StringCreation  - Behaviour of Email Management feature (explained in PD docs). Can be 
on_new_email,on_new_email_subject,only_if_no_open_incidentsoruse_rules. - email
Parsers List<Property Map> - email
Parsing StringFallback  - Can be 
open_new_incidentordiscard. - html
Url String - URL at which the entity is uniquely displayed in the Web app.
 - integration
Email String - This is the unique fully-qualified email address used for routing emails to this integration for processing.
 - integration
Key String - (Deprecated) This is the unique key used to route events to this integration when received via the PagerDuty Events API.
 - name String
 - The name of the service integration.
 - service String
 - The ID of the service the integration should belong to.
 - type String
 The service type. Can be:
aws_cloudwatch_inbound_integration,cloudkick_inbound_integration,event_transformer_api_inbound_integration,events_api_v2_inbound_integration(requires servicealert_creationto becreate_alerts_and_incidents),generic_email_inbound_integration,generic_events_api_inbound_integration,keynote_inbound_integration,nagios_inbound_integration,pingdom_inbound_integrationorsql_monitor_inbound_integration.Note: This is meant for generic service integrations. To integrate with a vendor (e.g. Datadog or Amazon Cloudwatch) use the
vendorfield instead.- vendor String
 - The ID of the vendor the integration should integrate with (e.g. Datadog or Amazon Cloudwatch).
 
Supporting Types
ServiceIntegrationEmailFilter, ServiceIntegrationEmailFilterArgs        
- Body
Mode string - Can be 
alwaysormatch. - Body
Regex string - Should be a valid regex or 
null - From
Email stringMode  - Can be 
alwaysormatch. - From
Email stringRegex  - Should be a valid regex or 
null - Id string
 - The ID of the service integration.
 - Subject
Mode string - Can be 
alwaysormatch. - Subject
Regex string - Should be a valid regex or 
null 
- Body
Mode string - Can be 
alwaysormatch. - Body
Regex string - Should be a valid regex or 
null - From
Email stringMode  - Can be 
alwaysormatch. - From
Email stringRegex  - Should be a valid regex or 
null - Id string
 - The ID of the service integration.
 - Subject
Mode string - Can be 
alwaysormatch. - Subject
Regex string - Should be a valid regex or 
null 
- body
Mode String - Can be 
alwaysormatch. - body
Regex String - Should be a valid regex or 
null - from
Email StringMode  - Can be 
alwaysormatch. - from
Email StringRegex  - Should be a valid regex or 
null - id String
 - The ID of the service integration.
 - subject
Mode String - Can be 
alwaysormatch. - subject
Regex String - Should be a valid regex or 
null 
- body
Mode string - Can be 
alwaysormatch. - body
Regex string - Should be a valid regex or 
null - from
Email stringMode  - Can be 
alwaysormatch. - from
Email stringRegex  - Should be a valid regex or 
null - id string
 - The ID of the service integration.
 - subject
Mode string - Can be 
alwaysormatch. - subject
Regex string - Should be a valid regex or 
null 
- body_
mode str - Can be 
alwaysormatch. - body_
regex str - Should be a valid regex or 
null - from_
email_ strmode  - Can be 
alwaysormatch. - from_
email_ strregex  - Should be a valid regex or 
null - id str
 - The ID of the service integration.
 - subject_
mode str - Can be 
alwaysormatch. - subject_
regex str - Should be a valid regex or 
null 
- body
Mode String - Can be 
alwaysormatch. - body
Regex String - Should be a valid regex or 
null - from
Email StringMode  - Can be 
alwaysormatch. - from
Email StringRegex  - Should be a valid regex or 
null - id String
 - The ID of the service integration.
 - subject
Mode String - Can be 
alwaysormatch. - subject
Regex String - Should be a valid regex or 
null 
ServiceIntegrationEmailParser, ServiceIntegrationEmailParserArgs        
- Action string
 - Can be 
resolveortrigger. - Match
Predicate ServiceIntegration Email Parser Match Predicate  - Id int
 - The ID of the service integration.
 - Value
Extractors List<ServiceIntegration Email Parser Value Extractor>  
- Action string
 - Can be 
resolveortrigger. - Match
Predicate ServiceIntegration Email Parser Match Predicate  - Id int
 - The ID of the service integration.
 - Value
Extractors []ServiceIntegration Email Parser Value Extractor  
- action String
 - Can be 
resolveortrigger. - match
Predicate ServiceIntegration Email Parser Match Predicate  - id Integer
 - The ID of the service integration.
 - value
Extractors List<ServiceIntegration Email Parser Value Extractor>  
- action string
 - Can be 
resolveortrigger. - match
Predicate ServiceIntegration Email Parser Match Predicate  - id number
 - The ID of the service integration.
 - value
Extractors ServiceIntegration Email Parser Value Extractor[]  
- action str
 - Can be 
resolveortrigger. - match_
predicate ServiceIntegration Email Parser Match Predicate  - id int
 - The ID of the service integration.
 - value_
extractors Sequence[ServiceIntegration Email Parser Value Extractor]  
- action String
 - Can be 
resolveortrigger. - match
Predicate Property Map - id Number
 - The ID of the service integration.
 - value
Extractors List<Property Map> 
ServiceIntegrationEmailParserMatchPredicate, ServiceIntegrationEmailParserMatchPredicateArgs            
- Type string
 - Can be 
anyorall. - Predicates
List<Service
Integration Email Parser Match Predicate Predicate>  
- Type string
 - Can be 
anyorall. - Predicates
[]Service
Integration Email Parser Match Predicate Predicate  
- type String
 - Can be 
anyorall. - predicates
List<Service
Integration Email Parser Match Predicate Predicate>  
- type string
 - Can be 
anyorall. - predicates
Service
Integration Email Parser Match Predicate Predicate[]  
- type str
 - Can be 
anyorall. - predicates
Sequence[Service
Integration Email Parser Match Predicate Predicate]  
- type String
 - Can be 
anyorall. - predicates List<Property Map>
 
ServiceIntegrationEmailParserMatchPredicatePredicate, ServiceIntegrationEmailParserMatchPredicatePredicateArgs              
- Type string
 - Can be 
contains,exactly,regexornot. If type isnotpredicate should contain child predicate with all parameters. - Matcher string
 - Predicate value or valid regex.
 - Part string
 - Can be 
subject,bodyorfrom_addresses. - Predicates
List<Service
Integration Email Parser Match Predicate Predicate Predicate>  
- Type string
 - Can be 
contains,exactly,regexornot. If type isnotpredicate should contain child predicate with all parameters. - Matcher string
 - Predicate value or valid regex.
 - Part string
 - Can be 
subject,bodyorfrom_addresses. - Predicates
[]Service
Integration Email Parser Match Predicate Predicate Predicate  
- type String
 - Can be 
contains,exactly,regexornot. If type isnotpredicate should contain child predicate with all parameters. - matcher String
 - Predicate value or valid regex.
 - part String
 - Can be 
subject,bodyorfrom_addresses. - predicates
List<Service
Integration Email Parser Match Predicate Predicate Predicate>  
- type string
 - Can be 
contains,exactly,regexornot. If type isnotpredicate should contain child predicate with all parameters. - matcher string
 - Predicate value or valid regex.
 - part string
 - Can be 
subject,bodyorfrom_addresses. - predicates
Service
Integration Email Parser Match Predicate Predicate Predicate[]  
- type str
 - Can be 
contains,exactly,regexornot. If type isnotpredicate should contain child predicate with all parameters. - matcher str
 - Predicate value or valid regex.
 - part str
 - Can be 
subject,bodyorfrom_addresses. - predicates
Sequence[Service
Integration Email Parser Match Predicate Predicate Predicate]  
- type String
 - Can be 
contains,exactly,regexornot. If type isnotpredicate should contain child predicate with all parameters. - matcher String
 - Predicate value or valid regex.
 - part String
 - Can be 
subject,bodyorfrom_addresses. - predicates List<Property Map>
 
ServiceIntegrationEmailParserMatchPredicatePredicatePredicate, ServiceIntegrationEmailParserMatchPredicatePredicatePredicateArgs                
ServiceIntegrationEmailParserValueExtractor, ServiceIntegrationEmailParserValueExtractorArgs            
- Part string
 - Can be 
subjectorbody. - Type string
 - Can be 
between,entireorregex. - Value
Name string - First value extractor should have name 
incident_keyother value extractors should contain custom names. - Ends
Before string - Regex string
 If
typehas valueregexthis value should contain valid regex.Note: You can use the
pagerduty.getVendordata source to locate the appropriate vendor ID.- Starts
After string 
- Part string
 - Can be 
subjectorbody. - Type string
 - Can be 
between,entireorregex. - Value
Name string - First value extractor should have name 
incident_keyother value extractors should contain custom names. - Ends
Before string - Regex string
 If
typehas valueregexthis value should contain valid regex.Note: You can use the
pagerduty.getVendordata source to locate the appropriate vendor ID.- Starts
After string 
- part String
 - Can be 
subjectorbody. - type String
 - Can be 
between,entireorregex. - value
Name String - First value extractor should have name 
incident_keyother value extractors should contain custom names. - ends
Before String - regex String
 If
typehas valueregexthis value should contain valid regex.Note: You can use the
pagerduty.getVendordata source to locate the appropriate vendor ID.- starts
After String 
- part string
 - Can be 
subjectorbody. - type string
 - Can be 
between,entireorregex. - value
Name string - First value extractor should have name 
incident_keyother value extractors should contain custom names. - ends
Before string - regex string
 If
typehas valueregexthis value should contain valid regex.Note: You can use the
pagerduty.getVendordata source to locate the appropriate vendor ID.- starts
After string 
- part str
 - Can be 
subjectorbody. - type str
 - Can be 
between,entireorregex. - value_
name str - First value extractor should have name 
incident_keyother value extractors should contain custom names. - ends_
before str - regex str
 If
typehas valueregexthis value should contain valid regex.Note: You can use the
pagerduty.getVendordata source to locate the appropriate vendor ID.- starts_
after str 
- part String
 - Can be 
subjectorbody. - type String
 - Can be 
between,entireorregex. - value
Name String - First value extractor should have name 
incident_keyother value extractors should contain custom names. - ends
Before String - regex String
 If
typehas valueregexthis value should contain valid regex.Note: You can use the
pagerduty.getVendordata source to locate the appropriate vendor ID.- starts
After String 
Import
Services can be imported using their related service id and service integration id separated by a dot, e.g.
$ pulumi import pagerduty:index/serviceIntegration:ServiceIntegration main PLSSSSS.PLIIIII
To learn more about importing existing cloud resources, see Importing resources.
Package Details
- Repository
 - PagerDuty pulumi/pulumi-pagerduty
 - License
 - Apache-2.0
 - Notes
 - This Pulumi package is based on the 
pagerdutyTerraform Provider.