aboutsummaryrefslogtreecommitdiffstats
path: root/terraform/lambda.tf
diff options
context:
space:
mode:
authorAlex Schofield <git@ajschof.me>2024-08-15 09:58:42 +0100
committerAlex Schofield <git@ajschof.me>2024-08-15 09:58:42 +0100
commitf04841ac661a5ab44422a0f58be50330ef2de4c8 (patch)
tree2f790f7d3d76fb29ea0dadab1b022cbfda0157f5 /terraform/lambda.tf
parent51eb46bbeb8fe5cb7b8750c37c776e8c9b4ae7f6 (diff)
parentd78db8a0f99c778b1e4b401c7cb4a094a5f2b103 (diff)
downloadde-project-bentley-f04841ac661a5ab44422a0f58be50330ef2de4c8.tar.gz
de-project-bentley-f04841ac661a5ab44422a0f58be50330ef2de4c8.zip
Merge branch 'feature/iam/alex-changes' into feature/iam.tf
Diffstat (limited to 'terraform/lambda.tf')
-rw-r--r--terraform/lambda.tf109
1 files changed, 52 insertions, 57 deletions
diff --git a/terraform/lambda.tf b/terraform/lambda.tf
index c190ea8..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.extract" # << 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]
+}
git.ajschof.me — hosted by ajschofield — powered by cgit