forked from fivexl/terraform-aws-ecs-events-to-slack
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathvariables.tf
118 lines (100 loc) · 4.83 KB
/
variables.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
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
# ---------------------------------------------------------------------------------------------------------------------
# REQUIRED PARAMETERS
# You must provide a value for each of these parameters.
# ---------------------------------------------------------------------------------------------------------------------
variable "name" {
description = "The string which will be used for the name of AWS Lambda function and other created resources"
type = string
}
variable "slack_webhook_url" {
description = <<EOT
(default) A Slack incoming webhook URL.
(if slack_webhook_url_source_type is 'secret') A secretsmanager secret name
(if slack_webhook_url_source_type is 'ssm') The full path to the SSM parameter including the initial slash.
EOT
type = string
}
# ---------------------------------------------------------------------------------------------------------------------
# OPTIONAL PARAMETERS
# These parameters have reasonable defaults.
# ---------------------------------------------------------------------------------------------------------------------
variable "role_name" {
description = "The string which will be used for the name of Lambda IAM role"
type = string
default = null
}
variable "slack_webhook_url_source_type" {
description = "Define where to get the slack webhook URL for variable slack_webhook_url. Either as text input or from an AWS secretsmanager lookup"
validation {
condition = contains(["text", "secretsmanager", "ssm"], var.slack_webhook_url_source_type)
error_message = "Invalid source type. Must be one of 'text', 'secretsmanager', 'ssm'."
}
type = string
default = "text"
}
variable "enable_ecs_task_state_event_rule" {
description = "The boolean flag enabling the EvenBridge Rule for `ECS Task State Change` events. The `detail` section of this rule is configured with `ecs_task_state_event_rule_detail` variable."
type = bool
default = true
}
variable "enable_ecs_deployment_state_event_rule" {
description = "The boolean flag enabling the EvenBridge Rule for `ECS Deployment State Change` events. The `detail` section of this rule is configured with `ecs_deployment_state_event_rule_detail` variable."
type = bool
default = true
}
variable "enable_ecs_service_action_event_rule" {
description = "The boolean flag enabling the EvenBridge Rule for `ECS Service Action` events. The `detail` section of this rule is configured with `ecs_service_action_event_rule_detail` variable."
type = bool
default = true
}
variable "ecs_task_state_event_rule_detail" {
description = "The content of the `detail` section in the EvenBridge Rule for `ECS Task State Change` events. Use it to filter the events which will be processed and sent to Slack."
type = any
default = {
lastStatus = ["STOPPED"]
stoppedReason = [{ "anything-but" : { "prefix" : "Scaling activity initiated by (deployment ecs-svc/" } }] # skip task stopped events triggerd by deployments
}
}
variable "ecs_deployment_state_event_rule_detail" {
description = "The content of the `detail` section in the EvenBridge Rule for `ECS Deployment State Change` events. Use it to filter the events which will be processed and sent to Slack."
type = any
default = {
eventType = ["ERROR"]
}
}
variable "ecs_service_action_event_rule_detail" {
description = "The content of the `detail` section in the EvenBridge Rule for `ECS Service Action` events. Use it to filter the events which will be processed and sent to Slack."
type = any
default = {
eventType = ["WARN", "ERROR"]
}
}
variable "custom_event_rules" {
description = "A map of objects representing the custom EventBridge rule which will be created in addition to the default rules."
type = any
default = {}
validation {
error_message = "Each rule object should have both 'detail' and 'detail-type' keys."
condition = alltrue([for name, rule in var.custom_event_rules : length(setintersection(keys(rule), ["detail", "detail-type"])) == 2])
}
}
variable "tags" {
description = "A map of tags to add to all resources"
type = map(string)
default = {}
}
variable "recreate_missing_package" {
description = "Whether to recreate missing Lambda package if it is missing locally or not."
type = bool
default = true
}
variable "cloudwatch_logs_retention_in_days" {
description = "Specifies the number of days you want to retain log events in the specified log group. Possible values are: 1, 3, 5, 7, 14, 30, 60, 90, 120, 150, 180, 365, 400, 545, 731, 1827, and 3653."
type = number
default = 14
}
variable "lambda_memory_size" {
description = "Amount of memory in MB your Lambda Function can use at runtime. Valid value between 128 MB to 10,240 MB (10 GB), in 64 MB increments."
type = number
default = 256
}