aboutsummaryrefslogtreecommitdiffstats
path: root/terraform/events.tf
diff options
context:
space:
mode:
authorlian-manonog <160282780+lian-manonog@users.noreply.github.com>2024-08-15 13:58:46 +0100
committerGitHub <noreply@github.com>2024-08-15 13:58:46 +0100
commit2309062a8099c04bedd7f88638abf03ebf5f5171 (patch)
tree1bdebb2046a9b1356faa2fe902d9187601ecb3f7 /terraform/events.tf
parent848a86b7f3b9c5ce16cd774d19e3fa62ca8ffc68 (diff)
parenta009ffe72a2005e72e67345f728539e500b899f5 (diff)
downloadde-project-bentley-2309062a8099c04bedd7f88638abf03ebf5f5171.tar.gz
de-project-bentley-2309062a8099c04bedd7f88638abf03ebf5f5171.zip
Merge pull request #33 from ajschofield/tf-secrets-manager
PR: merge secrets manager with extract_lambda
Diffstat (limited to 'terraform/events.tf')
-rw-r--r--terraform/events.tf87
1 files changed, 53 insertions, 34 deletions
diff --git a/terraform/events.tf b/terraform/events.tf
index 4d68a23..263141f 100644
--- a/terraform/events.tf
+++ b/terraform/events.tf
@@ -1,72 +1,91 @@
+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)"
-
-# event_pattern = jsonencode({
-# detail-type = [
-# "AWS Console Sign In via CloudTrail"
-# ]
-# })
}
-
-resource "aws_cloudwatch_event_target" "lambda" {
- rule = aws_cloudwatch_event_rule.lambda_trigger.name
- target_id = "TargetFunctionV1"
- arn = aws_lambda_function.my_lambda_function.arn
+resource "aws_cloudwatch_event_target" "extract_lambda_cw_event" {
+ rule = aws_cloudwatch_event_rule.lambda_trigger.name
+ target_id = "TargetFunctionV1"
+ arn = aws_lambda_function.extract_lambda.arn #replaced lambda name placeholder
+ depends_on = [aws_lambda_permission.allow_eventbridge]
}
-
-
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.my_lambda_function.function_name
+ function_name = aws_lambda_function.extract_lambda.function_name
principal = "events.amazonaws.com"
- source_arn = aws_cloudwatch_event_rule.lambda_trigger.arn
-}
+ 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.lambda_transform.function_name
+ function_name = aws_lambda_function.transform_lambda.function_name #replaced lambda name placeholder
principal = "s3.amazonaws.com"
- source_arn = aws_s3_bucket.extract.arn
+ source_arn = aws_s3_bucket.extract_bucket.arn #replaced bucket name placeholder
+
+ lifecycle {
+ replace_triggered_by = [random_string.s3_ingestion_suffix]
+ }
}
resource "aws_s3_bucket_notification" "extract_bucket_notification" {
- bucket = aws_s3_bucket.extract.id
+ bucket = aws_s3_bucket.extract_bucket.id #replaced bucket name placeholder
lambda_function {
- events = ["s3:ObjectCreated:*"]
- lambda_function_arn = aws_lambda_function.lambda_transform.arn
+ events = ["s3:ObjectCreated:*"]
+ lambda_function_arn = aws_lambda_function.transform_lambda.arn #replaced lambda name placeholder
}
depends_on = [aws_lambda_permission.allow_s3_ingestion]
}
-######
-
-resource "aws_lambda_permission" "allow_s3_transfrom_bucket" {
- statement_id = "AllowS3InvokeLambdaTransform"
+resource "aws_lambda_permission" "allow_s3_transform_bucket" {
+ statement_id = "AllowS3InvokeLambdaTransform${random_string.s3_transform_suffix.result}"
action = "lambda:InvokeFunction"
- function_name = aws_lambda_function.lambda_transform.function_name
+ function_name = aws_lambda_function.transform_lambda.function_name #replaced lambda name placeholder
principal = "s3.amazonaws.com"
- source_arn = aws_s3_bucket.transform.arn
+ source_arn = aws_s3_bucket.transform_bucket.arn #replaced bucket name placeholder
+
+ lifecycle {
+ replace_triggered_by = [random_string.s3_transform_suffix]
+ }
}
resource "aws_s3_bucket_notification" "transform_bucket_notification" {
- bucket = aws_s3_bucket.transform.id
+ bucket = aws_s3_bucket.transform_bucket.id #replaced bucket name placeholder
lambda_function {
- events = ["s3:ObjectCreated:*"]
- lambda_function_arn = aws_lambda_function.lambda_transform.arn
+ events = ["s3:ObjectCreated:*"]
+ lambda_function_arn = aws_lambda_function.transform_lambda.arn #replaced lambda name placeholder
}
- depends_on = [aws_lambda_permission.allow_s3_transform]
-} \ No newline at end of file
+ depends_on = [aws_lambda_permission.allow_s3_transform_bucket]
+}
git.ajschof.me — hosted by ajschofield — powered by cgit