aboutsummaryrefslogtreecommitdiffstats
path: root/terraform/events.tf
diff options
context:
space:
mode:
authorAlex Schofield <git@ajschof.me>2024-08-15 00:24:41 +0100
committerAlex Schofield <git@ajschof.me>2024-08-15 00:30:09 +0100
commitd78db8a0f99c778b1e4b401c7cb4a094a5f2b103 (patch)
tree2f790f7d3d76fb29ea0dadab1b022cbfda0157f5 /terraform/events.tf
parentc5f840e96b8c1696a6ed506e9260c4f1c26db10d (diff)
downloadde-project-bentley-d78db8a0f99c778b1e4b401c7cb4a094a5f2b103.tar.gz
de-project-bentley-d78db8a0f99c778b1e4b401c7cb4a094a5f2b103.zip
fix(infra/tf): add unique id to permissions
This was done to resolve issues with `ResourceConflictException` - add random_string resources for every lambda permission to add as suffixes - also add lifecycle options to force recreation whenever the random strings change
Diffstat (limited to 'terraform/events.tf')
-rw-r--r--terraform/events.tf45
1 files changed, 34 insertions, 11 deletions
diff --git a/terraform/events.tf b/terraform/events.tf
index d2e2eb5..263141f 100644
--- a/terraform/events.tf
+++ b/terraform/events.tf
@@ -1,11 +1,25 @@
+resource "random_string" "eventbridge_suffix" {
+ length = 8
+ special = false
+ upper = false
+}
+
+resource "random_string" "s3_ingestion_suffix" {
+ length = 8
+ special = false
+ upper = false
+}
+
+resource "random_string" "s3_transform_suffix" {
+ length = 8
+ special = false
+ upper = false
+}
+
resource "aws_cloudwatch_event_rule" "lambda_trigger" {
name = "lambda-scheduled-trigger"
description = "Schedule to trigger the Lambda function"
schedule_expression = "rate(30 minutes)"
-
- lifecycle {
- create_before_destroy = true
- }
}
resource "aws_cloudwatch_event_target" "extract_lambda_cw_event" {
@@ -16,21 +30,28 @@ resource "aws_cloudwatch_event_target" "extract_lambda_cw_event" {
}
resource "aws_lambda_permission" "allow_eventbridge" {
- statement_id = "AllowExecutionFromEventBridge"
+ statement_id = "AllowExecutionFromEventBridge${random_string.eventbridge_suffix.result}"
action = "lambda:InvokeFunction"
- function_name = aws_lambda_function.extract_lambda.function_name #replaced lambda name placeholder
+ function_name = aws_lambda_function.extract_lambda.function_name
principal = "events.amazonaws.com"
source_arn = aws_cloudwatch_event_rule.lambda_trigger.arn
-}
+ lifecycle {
+ replace_triggered_by = [random_string.eventbridge_suffix]
+ }
+}
# below is step function 1
resource "aws_lambda_permission" "allow_s3_ingestion" {
- statement_id = "AllowS3InvokeLambdaTransform"
+ statement_id = "AllowS3InvokeLambdaTransform${random_string.s3_ingestion_suffix.result}"
action = "lambda:InvokeFunction"
function_name = aws_lambda_function.transform_lambda.function_name #replaced lambda name placeholder
principal = "s3.amazonaws.com"
source_arn = aws_s3_bucket.extract_bucket.arn #replaced bucket name placeholder
+
+ lifecycle {
+ replace_triggered_by = [random_string.s3_ingestion_suffix]
+ }
}
@@ -45,14 +66,16 @@ resource "aws_s3_bucket_notification" "extract_bucket_notification" {
depends_on = [aws_lambda_permission.allow_s3_ingestion]
}
-######
-
resource "aws_lambda_permission" "allow_s3_transform_bucket" {
- statement_id = "AllowS3InvokeLambdaTransform"
+ statement_id = "AllowS3InvokeLambdaTransform${random_string.s3_transform_suffix.result}"
action = "lambda:InvokeFunction"
function_name = aws_lambda_function.transform_lambda.function_name #replaced lambda name placeholder
principal = "s3.amazonaws.com"
source_arn = aws_s3_bucket.transform_bucket.arn #replaced bucket name placeholder
+
+ lifecycle {
+ replace_triggered_by = [random_string.s3_transform_suffix]
+ }
}
git.ajschof.me — hosted by ajschofield — powered by cgit