UNPKG

@pulumi/pagerduty

Version:

A Pulumi package for creating and managing pagerduty cloud resources.

103 lines 4.4 kB
"use strict"; // *** WARNING: this file was generated by pulumi-language-nodejs. *** // *** Do not edit by hand unless you're certain you know what you are doing! *** Object.defineProperty(exports, "__esModule", { value: true }); exports.UserHandoffNotificationRule = void 0; const pulumi = require("@pulumi/pulumi"); const utilities = require("./utilities"); /** * An [user handoff notification rule](https://developer.pagerduty.com/api-reference/f2ab7a3c1418a-create-a-user-handoff-notification-rule) is a rule that specifies how a user should be notified when they are handed off an incident. * * ## Example Usage * * ```typescript * 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@foo.test", * }); * const phone = new pagerduty.UserContactMethod("phone", { * userId: example.id, * type: "phone_contact_method", * countryCode: 1, * address: "2025550199", * label: "Work", * }); * const example_oncall_offcall = new pagerduty.UserHandoffNotificationRule("example-oncall-offcall", { * userId: example.id, * handoffType: "both", * notifyAdvanceInMinutes: 180, * contactMethod: { * id: phone.id, * type: phone.type, * }, * }); * ``` * * ## Import * * User handoff notification rules can be imported using the `user_id` and `id` separated by a dot, e.g. * * ```sh * $ pulumi import pagerduty:index/userHandoffNotificationRule:UserHandoffNotificationRule main PX4IAP4.PULREBP * ``` */ class UserHandoffNotificationRule extends pulumi.CustomResource { /** * Get an existing UserHandoffNotificationRule resource's state with the given name, ID, and optional extra * properties used to qualify the lookup. * * @param name The _unique_ name of the resulting resource. * @param id The _unique_ provider ID of the resource to lookup. * @param state Any extra arguments used during the lookup. * @param opts Optional settings to control the behavior of the CustomResource. */ static get(name, id, state, opts) { return new UserHandoffNotificationRule(name, state, { ...opts, id: id }); } /** * Returns true if the given object is an instance of UserHandoffNotificationRule. This is designed to work even * when multiple copies of the Pulumi SDK have been loaded into the same process. */ static isInstance(obj) { if (obj === undefined || obj === null) { return false; } return obj['__pulumiType'] === UserHandoffNotificationRule.__pulumiType; } constructor(name, argsOrState, opts) { let resourceInputs = {}; opts = opts || {}; if (opts.id) { const state = argsOrState; resourceInputs["contactMethod"] = state?.contactMethod; resourceInputs["handoffType"] = state?.handoffType; resourceInputs["notifyAdvanceInMinutes"] = state?.notifyAdvanceInMinutes; resourceInputs["userId"] = state?.userId; } else { const args = argsOrState; if (args?.contactMethod === undefined && !opts.urn) { throw new Error("Missing required property 'contactMethod'"); } if (args?.notifyAdvanceInMinutes === undefined && !opts.urn) { throw new Error("Missing required property 'notifyAdvanceInMinutes'"); } if (args?.userId === undefined && !opts.urn) { throw new Error("Missing required property 'userId'"); } resourceInputs["contactMethod"] = args?.contactMethod; resourceInputs["handoffType"] = args?.handoffType; resourceInputs["notifyAdvanceInMinutes"] = args?.notifyAdvanceInMinutes; resourceInputs["userId"] = args?.userId; } opts = pulumi.mergeOptions(utilities.resourceOptsDefaults(), opts); super(UserHandoffNotificationRule.__pulumiType, name, resourceInputs, opts); } } exports.UserHandoffNotificationRule = UserHandoffNotificationRule; /** @internal */ UserHandoffNotificationRule.__pulumiType = 'pagerduty:index/userHandoffNotificationRule:UserHandoffNotificationRule'; //# sourceMappingURL=userHandoffNotificationRule.js.map