forked from moritzzimmer/terraform-aws-lambda
-
Notifications
You must be signed in to change notification settings - Fork 0
/
cloudwatch_event_rules.tf
36 lines (30 loc) · 1.68 KB
/
cloudwatch_event_rules.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
resource "aws_lambda_permission" "cloudwatch_events" {
for_each = var.cloudwatch_event_rules
action = "lambda:InvokeFunction"
function_name = var.ignore_external_function_updates ? aws_lambda_function.lambda_external_lifecycle[0].function_name : aws_lambda_function.lambda[0].function_name
principal = "events.amazonaws.com"
qualifier = contains(keys(each.value), "cloudwatch_event_target_arn") ? trimprefix(each.value["cloudwatch_event_target_arn"], "${local.function_arn}:") : null
source_arn = aws_cloudwatch_event_rule.lambda[each.key].arn
lifecycle {
replace_triggered_by = [aws_lambda_function.lambda, aws_cloudwatch_event_rule.lambda[each.key]]
}
}
resource "aws_cloudwatch_event_rule" "lambda" {
for_each = var.cloudwatch_event_rules
description = lookup(each.value, "description", null)
event_bus_name = lookup(each.value, "event_bus_name", null)
event_pattern = lookup(each.value, "event_pattern", null)
is_enabled = lookup(each.value, "is_enabled", null)
name = lookup(each.value, "name", null)
name_prefix = lookup(each.value, "name_prefix", null)
role_arn = lookup(each.value, "role_arn", null)
schedule_expression = lookup(each.value, "schedule_expression", null)
tags = var.tags
}
resource "aws_cloudwatch_event_target" "lambda" {
for_each = var.cloudwatch_event_rules
event_bus_name = lookup(each.value, "event_bus_name", null)
arn = lookup(each.value, "cloudwatch_event_target_arn", local.function_arn)
rule = aws_cloudwatch_event_rule.lambda[each.key].name
input = lookup(each.value, "cloudwatch_event_target_input", null)
}