aboutsummaryrefslogtreecommitdiffstats
path: root/terraform/lambda.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/lambda.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/lambda.tf')
-rw-r--r--terraform/lambda.tf83
1 files changed, 83 insertions, 0 deletions
diff --git a/terraform/lambda.tf b/terraform/lambda.tf
new file mode 100644
index 0000000..72d1306
--- /dev/null
+++ b/terraform/lambda.tf
@@ -0,0 +1,83 @@
+# Extract Lambda Function
+data "archive_file" "extract_lambda_zip" {
+ type = "zip"
+ source_file = "${path.module}/../src/extract_lambda.py"
+ output_path = "${path.module}/../extract_function.zip"
+}
+resource "aws_s3_object" "extract_lambda_code" {
+ bucket = aws_s3_bucket.lambda_code_bucket.bucket
+ key = "${var.extract_lambda_name}/extract_function.zip"
+ source = data.archive_file.extract_lambda_zip.output_path
+ etag = filemd5(data.archive_file.extract_lambda_zip.output_path)
+}
+
+resource "aws_lambda_function" "extract_lambda" {
+ 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"
+
+ lifecycle {
+ create_before_destroy = true
+ }
+
+ depends_on = [aws_s3_object.extract_lambda_code]
+}
+
+# Transform Lambda Function
+data "archive_file" "transform_lambda_zip" {
+ type = "zip"
+ source_file = "${path.module}/../src/transform_lambda.py"
+ output_path = "${path.module}/../transform_function.zip"
+}
+resource "aws_s3_object" "transform_lambda_code" {
+ bucket = aws_s3_bucket.lambda_code_bucket.bucket
+ key = "${var.transform_lambda_name}/transform_function.zip"
+ source = data.archive_file.transform_lambda_zip.output_path
+ etag = filemd5(data.archive_file.transform_lambda_zip.output_path)
+}
+
+resource "aws_lambda_function" "transform_lambda" {
+ 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"
+
+ lifecycle {
+ create_before_destroy = true
+ }
+
+ depends_on = [aws_s3_object.transform_lambda_code]
+}
+
+# Load Lambda Function
+data "archive_file" "load_lambda_zip" {
+ type = "zip"
+ source_file = "${path.module}/../src/load_lambda.py"
+ output_path = "${path.module}/../load_function.zip"
+}
+resource "aws_s3_object" "load_lambda_code" {
+ bucket = aws_s3_bucket.lambda_code_bucket.bucket
+ key = "${var.load_lambda_name}/load_function.zip"
+ source = data.archive_file.load_lambda_zip.output_path
+ etag = filemd5(data.archive_file.load_lambda_zip.output_path)
+}
+
+resource "aws_lambda_function" "load_lambda" {
+ 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