-
Notifications
You must be signed in to change notification settings - Fork 39
/
Copy pathpagerduty_integration_us.tf
93 lines (80 loc) · 4.93 KB
/
pagerduty_integration_us.tf
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
terraform {
# Require Terraform version 0.15.x (recommended)
required_version = "~> 0.15.0"
required_providers {
site24x7 = {
source = "site24x7/site24x7"
# Update the latest version from https://registry.terraform.io/providers/site24x7/site24x7/latest
}
}
}
// Authentication API doc - https://www.site24x7.com/help/api/#authentication
provider "site24x7" {
// (Security recommendation - It is always best practice to store your credentials in a Vault of your choice.)
// (Required) The client ID will be looked up in the SITE24X7_OAUTH2_CLIENT_ID
// environment variable if the attribute is empty or omitted.
oauth2_client_id = "<SITE24X7_OAUTH2_CLIENT_ID>"
// (Security recommendation - It is always best practice to store your credentials in a Vault of your choice.)
// (Required) The client secret will be looked up in the SITE24X7_OAUTH2_CLIENT_SECRET
// environment variable if the attribute is empty or omitted.
oauth2_client_secret = "<SITE24X7_OAUTH2_CLIENT_SECRET>"
// (Security recommendation - It is always best practice to store your credentials in a Vault of your choice.)
// (Required) The refresh token will be looked up in the SITE24X7_OAUTH2_REFRESH_TOKEN
// environment variable if the attribute is empty or omitted.
oauth2_refresh_token = "<SITE24X7_OAUTH2_REFRESH_TOKEN>"
// (Required) Specify the data center from which you have obtained your
// OAuth client credentials and refresh token. It can be (US/EU/IN/AU/CN/JP/CA).
data_center = "US"
// (Optional) ZAAID of the customer under a MSP or BU
zaaid = "1234"
// (Optional) The minimum time to wait in seconds before retrying failed Site24x7 API requests.
retry_min_wait = 1
// (Optional) The maximum time to wait in seconds before retrying failed Site24x7 API
// requests. This is the upper limit for the wait duration with exponential
// backoff.
retry_max_wait = 30
// (Optional) Maximum number of Site24x7 API request retries to perform until giving up.
max_retries = 4
}
// PagerDuty API doc: https://www.site24x7.com/help/api/#create-pagerduty
resource "site24x7_pagerduty_integration" "pagerduty_integration_basic" {
// (Required) Display name for the PagerDuty Integration.
name = "PageDuty Integration - Terraform"
// (Required) Unique integration key provided by PagerDuty to facilitate incident creation in PagerDuty.
service_key = "service_key"
// (Required) Name of the service who posted the incident.
sender_name = "Site24x7 - Terraform"
// (Required) Title of the incident.
title = "$MONITORNAME is $STATUS"
}
// PagerDuty API doc: https://www.site24x7.com/help/api/#create-pagerduty
resource "site24x7_pagerduty_integration" "pagerduty_integration" {
// (Required) Display name for the PagerDuty Integration.
name = "PageDuty Integration - Terraform"
// (Required) Unique integration key provided by PagerDuty to facilitate incident creation in PagerDuty.
service_key = "service_key"
// (Required) Name of the service who posted the incident.
sender_name = "Site24x7 - Terraform"
// (Required) Title of the incident.
title = "$MONITORNAME is $STATUS"
// (Optional) Resource Type associated with this integration. Default value is '0'. Can take values 0|1|2|3. '0' denotes 'All Monitors', '1' denotes 'Monitor Group', '2' denotes 'Monitors', '3' denotes 'Tags'
selection_type = 0
// (Optional) Setting this to 'true' will send alert notifications to this third-party integration when the monitor status changes to 'Trouble'. One among trouble_alert|critical_alert|down_alert should be set to true for receiving notifications. Default value is 'true'.
trouble_alert = true
// (Optional) Setting this to 'true' will send alert notifications to this third-party integration when the monitor status changes to 'Critical'. One among trouble_alert|critical_alert|down_alert should be set to true for receiving notifications.
critical_alert = false
// (Optional) Setting this to 'true' will send alert notifications to this third-party integration when the monitor status changes to 'Down'. One among trouble_alert|critical_alert|down_alert should be set to true for receiving notifications.
down_alert = false
// (Optional) Configuration to resolve the incidents manually when the monitor changes to UP status.
manual_resolve = false
// (Optional) Configuration to send custom parameters while executing the action.
send_custom_parameters = true
// (Optional) Mandatory, if send_custom_parameters is set as true. Custom parameters to be passed while accessing the URL.
custom_parameters = "{\"test\":\"abcd\"}"
// (Optional) Monitors to be associated with the integration when the selection_type = 2.
monitors = ["756"]
// (Optional) Tags to be associated with the integration when the selection_type = 3.
tags = ["345"]
// (Optional) List of tag IDs to be associated with the integration.
alert_tags_id = ["123"]
}