aboutsummaryrefslogtreecommitdiffstats
path: root/terraform
diff options
context:
space:
mode:
Diffstat (limited to 'terraform')
-rw-r--r--terraform/events.tf35
-rw-r--r--terraform/iam.tf28
-rw-r--r--terraform/lambda.tf109
-rw-r--r--terraform/main.tf26
-rw-r--r--terraform/s3.tf43
-rw-r--r--terraform/vars.tf26
6 files changed, 124 insertions, 143 deletions
diff --git a/terraform/events.tf b/terraform/events.tf
index 9fd89e4..d2e2eb5 100644
--- a/terraform/events.tf
+++ b/terraform/events.tf
@@ -1,23 +1,18 @@
-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
- force_destroy = true
-}
-
resource "aws_cloudwatch_event_rule" "lambda_trigger" {
name = "lambda-scheduled-trigger"
description = "Schedule to trigger the Lambda function"
schedule_expression = "rate(30 minutes)"
- force_destroy = true
- # depends_on = [
- # aws_cloudwatch_event_target.extract_lambda_cw_event]
-
-# event_pattern = jsonencode({
-# detail-type =
-# "AWS Console Sign In via CloudTrail"
-# ]
-# })
+
+ lifecycle {
+ create_before_destroy = true
+ }
+}
+
+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" {
@@ -25,7 +20,7 @@ resource "aws_lambda_permission" "allow_eventbridge" {
action = "lambda:InvokeFunction"
function_name = aws_lambda_function.extract_lambda.function_name #replaced lambda name placeholder
principal = "events.amazonaws.com"
- source_arn = aws_cloudwatch_event_rule.lambda_trigger.arn
+ source_arn = aws_cloudwatch_event_rule.lambda_trigger.arn
}
@@ -43,7 +38,7 @@ resource "aws_s3_bucket_notification" "extract_bucket_notification" {
bucket = aws_s3_bucket.extract_bucket.id #replaced bucket name placeholder
lambda_function {
- events = ["s3:ObjectCreated:*"]
+ events = ["s3:ObjectCreated:*"]
lambda_function_arn = aws_lambda_function.transform_lambda.arn #replaced lambda name placeholder
}
@@ -65,9 +60,9 @@ resource "aws_s3_bucket_notification" "transform_bucket_notification" {
bucket = aws_s3_bucket.transform_bucket.id #replaced bucket name placeholder
lambda_function {
- events = ["s3:ObjectCreated:*"]
+ events = ["s3:ObjectCreated:*"]
lambda_function_arn = aws_lambda_function.transform_lambda.arn #replaced lambda name placeholder
}
depends_on = [aws_lambda_permission.allow_s3_transform_bucket]
-} \ No newline at end of file
+}
diff --git a/terraform/iam.tf b/terraform/iam.tf
index 20aeab3..6c6b4fc 100644
--- a/terraform/iam.tf
+++ b/terraform/iam.tf
@@ -143,3 +143,31 @@ resource "aws_iam_role_policy_attachment" "cw_attachment" {
################
# RDS POLICIES #
################
+
+###################
+# EVENTS POLICIES #
+###################
+
+data "aws_iam_policy_document" "cloudwatch_events_policy" {
+ statement {
+ actions = [
+ "events:PutRule",
+ "events:PutTargets",
+ "events:RemoveTargets",
+ "events:DeleteRule",
+ "events:PutEvents"
+ ]
+ resources = ["*"]
+ effect = "Allow"
+ }
+}
+
+resource "aws_iam_policy" "cloudwatch_events_policy" {
+ name = "cloudwatch_events_policy"
+ policy = data.aws_iam_policy_document.cloudwatch_events_policy.json
+}
+
+resource "aws_iam_role_policy_attachment" "cloudwatch_events_attachment" {
+ role = aws_iam_role.multi_service_role.name
+ policy_arn = aws_iam_policy.cloudwatch_events_policy.arn
+}
diff --git a/terraform/lambda.tf b/terraform/lambda.tf
index a5da972..fb0a666 100644
--- a/terraform/lambda.tf
+++ b/terraform/lambda.tf
@@ -1,73 +1,68 @@
-### EXTRACT LAMBDA SET UP
-data "archive_file" "extract_lambda_zip" {
- type = "zip"
- source_file = "${path.module}/../src/extract_lambda.py"
- output_path = "${path.module}/../extract_function.zip"
+# Extract Lambda Function
+resource "aws_s3_object" "extract_lambda_code" {
+ bucket = aws_s3_bucket.lambda_code_bucket.bucket
+ key = "${var.extract_lambda_name}/extract_function.zip"
+ source = "${path.module}/../extract_function.zip"
+ etag = filemd5("${path.module}/../extract_function.zip")
}
resource "aws_lambda_function" "extract_lambda" {
- function_name = "${var.extract_lambda_name}"
- s3_bucket = aws_s3_bucket.lambda_code_bucket.bucket
- s3_key = "extract-lambda/extract_function.zip"
- role = aws_iam_role.multi_service_role.arn #<< lambda role placehodler
- handler = "extract_lambda.lambda_handler" # << check that the function is called lambda handler
- runtime = "python3.11"
- environment {
- variables = {
- output = aws_s3_bucket.extract_bucket.bucket
- }
- }
-}
+ function_name = var.extract_lambda_name
+ s3_bucket = aws_s3_bucket.lambda_code_bucket.bucket
+ s3_key = aws_s3_object.extract_lambda_code.key
+ role = aws_iam_role.multi_service_role.arn
+ handler = "extract_lambda.extract"
+ runtime = "python3.11"
-resource "aws_lambda_permission" "allow_to_write_to_s3_extract_bucket" {
- action = "lambda:InvokeFunction"
- function_name = aws_lambda_function.extract_lambda.function_name
- principal = "s3.amazonaws.com"
- source_arn = aws_s3_bucket.extract_bucket.arn
-}
+ lifecycle {
+ create_before_destroy = true
+ }
+ depends_on = [aws_s3_object.extract_lambda_code]
+}
-### TRANSFORM LAMBDA SET UP
-data "archive_file" "transform_lambda_zip" {
- type = "zip"
- source_file = "${path.module}/../src/transform_lambda.py"
- output_path = "${path.module}/../transform_function.zip"
+# Transform Lambda Function
+resource "aws_s3_object" "transform_lambda_code" {
+ bucket = aws_s3_bucket.lambda_code_bucket.bucket
+ key = "${var.transform_lambda_name}/transform_function.zip"
+ source = "${path.module}/../transform_function.zip"
+ etag = filemd5("${path.module}/../transform_function.zip")
}
resource "aws_lambda_function" "transform_lambda" {
- function_name = "${var.transform_lambda_name}"
- s3_bucket = aws_s3_bucket.lambda_code_bucket.bucket
- s3_key = "transform-lambda/transform_function.zip"
- role = aws_iam_role.multi_service_role.arn # << lambda role placehodler
- handler = "transform_lambda.lambda_handler" # << check that the function is called lambda handler
- runtime = "python3.11"
- environment {
- variables = {
- output = aws_s3_bucket.transform_bucket.bucket
- }
- }
-}
+ function_name = var.transform_lambda_name
+ s3_bucket = aws_s3_bucket.lambda_code_bucket.bucket
+ s3_key = aws_s3_object.transform_lambda_code.key
+ role = aws_iam_role.multi_service_role.arn
+ handler = "transform_lambda.transform"
+ runtime = "python3.11"
-resource "aws_lambda_permission" "allow_to_write_to_s3_transform_bucket" {
- action = "lambda:InvokeFunction"
- function_name = aws_lambda_function.transform_lambda.function_name
- principal = "s3.amazonaws.com"
- source_arn = aws_s3_bucket.transform_bucket.arn
+ lifecycle {
+ create_before_destroy = true
+ }
+
+ depends_on = [aws_s3_object.transform_lambda_code]
}
-### LOAD LAMBDA SET UP
-data "archive_file" "load_lambda_zip" {
- type = "zip"
- source_file = "${path.module}/../src/load_lambda.py"
- output_path = "${path.module}/../load_function.zip"
+# Load Lambda Function
+resource "aws_s3_object" "load_lambda_code" {
+ bucket = aws_s3_bucket.lambda_code_bucket.bucket
+ key = "${var.load_lambda_name}/load_function.zip"
+ source = "${path.module}/../load_function.zip"
+ etag = filemd5("${path.module}/../load_function.zip")
}
resource "aws_lambda_function" "load_lambda" {
- function_name = "${var.load_lambda_name}"
- s3_bucket = aws_s3_bucket.lambda_code_bucket.bucket
- s3_key = "load-lambda/load_function.zip"
- role = aws_iam_role.multi_service_role.arn # << lambda role placehodler
- handler = "load_lambda.lambda_handler" # << check that the function is called lambda handler
- runtime = "python3.11"
-}
+ function_name = var.load_lambda_name
+ s3_bucket = aws_s3_bucket.lambda_code_bucket.bucket
+ s3_key = aws_s3_object.load_lambda_code.key
+ role = aws_iam_role.multi_service_role.arn
+ handler = "load_lambda.load"
+ runtime = "python3.11"
+ lifecycle {
+ create_before_destroy = true
+ }
+
+ depends_on = [aws_s3_object.load_lambda_code]
+}
diff --git a/terraform/main.tf b/terraform/main.tf
index 2a048b9..3b06701 100644
--- a/terraform/main.tf
+++ b/terraform/main.tf
@@ -1,26 +1,26 @@
terraform {
required_providers {
aws = {
- source = "hashicorp/aws"
- version = "~>5.0"
+ source = "hashicorp/aws"
+ version = "~>5.0"
}
}
backend "s3" {
bucket = "bentley-project-secrets"
- key = "bentley-project/terraform.tfstate"
+ key = "bentley-project/terraform.tfstate"
region = "eu-west-2"
}
}
provider "aws" {
- region = "eu-west-2"
- default_tags {
- tags = {
- ProjectName = "Terrific-Totes"
- Team = "Team-Bentley"
- Environment = "Dev"
- GitHubRepo = "de-project-bentley"
- ManagedBy = "Terraform"
- }
+ region = "eu-west-2"
+ default_tags {
+ tags = {
+ ProjectName = "Terrific-Totes"
+ Team = "Team-Bentley"
+ Environment = "Dev"
+ GitHubRepo = "de-project-bentley"
+ ManagedBy = "Terraform"
}
-} \ No newline at end of file
+ }
+}
diff --git a/terraform/s3.tf b/terraform/s3.tf
index 4c06b8e..d5cdee3 100644
--- a/terraform/s3.tf
+++ b/terraform/s3.tf
@@ -1,51 +1,14 @@
### EXTRACT BUCKET SET-UP
resource "aws_s3_bucket" "extract_bucket" {
- bucket_prefix = "${var.s3_extract_bucket_name}-"
+ bucket_prefix = "${var.s3_extract_bucket_name}-"
}
-# resource "aws_s3_bucket_notification" "extract_bucket_notification" {
-# bucket = aws_s3_bucket.extract_bucket.id
-# lambda_function {
-# lambda_function_arn = aws_lambda_function.extract_lambda.arn
-# events = ["s3:ObjectCreated:*"]
-# }
-# depends_on = [aws_lambda_permission.allow_to_write_to_s3_extract_bucket]
-# } # << is this the correct permission dependency?
-
### TRANSFORM BUCKET SET-UP
resource "aws_s3_bucket" "transform_bucket" {
- bucket_prefix = "${var.s3_transform_bucket_name}-"
+ bucket_prefix = "${var.s3_transform_bucket_name}-"
}
-# resource "aws_s3_bucket_notification" "transform_bucket_notification" {
-# bucket = aws_s3_bucket.transform_bucket.id
-# lambda_function {
-# lambda_function_arn = aws_lambda_function.transform_lambda.arn
-# events = ["s3:ObjectCreated:*"]
-# }
-# depends_on = [aws_lambda_permission.allow_to_write_to_s3_transform_bucket]
-# } # << is this the correct permission dependency?
-
-
### LAMBDA BUCKET
resource "aws_s3_bucket" "lambda_code_bucket" {
- bucket_prefix = "${var.s3_code_bucket_name}-"
+ bucket_prefix = "${var.s3_code_bucket_name}-"
}
-
-# resource "aws_s3_object" "extract_lambda_code" {
-# bucket = aws_s3_bucket.lambda_code_bucket.bucket
-# key = "${var.extract_lambda_name}/extract_function.zip"
-# source = "${path.module}/../extract_function.zip"
-# } # << can't figure out how this is being used but we seem to need it
-
-# resource "aws_s3_object" "transform_lambda_code" {
-# bucket = aws_s3_bucket.lambda_code_bucket.bucket
-# key = "${var.transform_lambda_name}/transform_function.zip"
-# source = "${path.module}/../transform_function.zip"
-# } # << can't figure out how this is being used but we seem to need it
-
-# resource "aws_s3_object" "load_lambda_code" {
-# bucket = aws_s3_bucket.lambda_code_bucket.bucket
-# key = "${var.load_lambda_name}/load_function.zip"
-# source = "${path.module}/../load_function.zip"
-# } \ No newline at end of file
diff --git a/terraform/vars.tf b/terraform/vars.tf
index cc9348a..84824ce 100644
--- a/terraform/vars.tf
+++ b/terraform/vars.tf
@@ -1,33 +1,33 @@
variable "s3_extract_bucket_name" {
- type = string
- default = "extract-bucket"
+ type = string
+ default = "extract-bucket"
}
variable "s3_transform_bucket_name" {
- type = string
- default = "transform-bucket"
+ type = string
+ default = "transform-bucket"
}
variable "s3_code_bucket_name" {
- type = string
- default = "lambda-bucket"
+ type = string
+ default = "lambda-bucket"
}
variable "extract_lambda_name" {
- type = string
- default = "extract-lambda"
+ type = string
+ default = "extract-lambda"
}
variable "transform_lambda_name" {
- type = string
- default = "transform-lambda"
+ type = string
+ default = "transform-lambda"
}
variable "load_lambda_name" {
- type = string
- default = "load-lambda"
+ type = string
+ default = "load-lambda"
}
data "aws_caller_identity" "current" {}
-data "aws_region" "current" {} \ No newline at end of file
+data "aws_region" "current" {}
git.ajschof.me — hosted by ajschofield — powered by cgit