aboutsummaryrefslogtreecommitdiffstats
path: root/terraform/lambda.tf
diff options
context:
space:
mode:
authorEllie <167526066+ellsymonds@users.noreply.github.com>2024-08-13 14:21:47 +0100
committerGitHub <noreply@github.com>2024-08-13 14:21:47 +0100
commitb68b605a9ab64e40543dcf49f56133cab7bac8d1 (patch)
treea3777d7cfa6f1760cad3ebbc136905cfa809ee33 /terraform/lambda.tf
parent3bfa3d42f0f795c2625662e20191c5b3235608ac (diff)
parent8024c1a6c98a696f9664049c96d8fc58c9fd2435 (diff)
downloadde-project-bentley-b68b605a9ab64e40543dcf49f56133cab7bac8d1.tar.gz
de-project-bentley-b68b605a9ab64e40543dcf49f56133cab7bac8d1.zip
Merge pull request #18 from ajschofield/feature/lambdas-tf-setup
Merging lambda features branch to development
Diffstat (limited to 'terraform/lambda.tf')
-rw-r--r--terraform/lambda.tf74
1 files changed, 74 insertions, 0 deletions
diff --git a/terraform/lambda.tf b/terraform/lambda.tf
new file mode 100644
index 0000000..09d6697
--- /dev/null
+++ b/terraform/lambda.tf
@@ -0,0 +1,74 @@
+### 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"
+}
+
+resource "aws_lambda_function" "extract_lambda" {
+ function_name = "${var.extract_lambda_name}"
+ s3_bucket = aws_s3_bucket.lambda_bucket.bucket
+ s3_key = "extract_lambda/extract_function.zip"
+ role = aws_iam_role.PLACEHOLDER_extract_lambda_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
+ }
+ }
+}
+
+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
+}
+
+
+### 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"
+}
+
+resource "aws_lambda_function" "transform_lambda" {
+ function_name = "${var.transform_lambda_name}"
+ s3_bucket = aws_s3_bucket.lambda_bucket.bucket
+ s3_key = "transform_lambda/transform_function.zip"
+ role = aws_iam_role.PLACEHOLDER_transform_lambda_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
+ }
+ }
+}
+
+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
+}
+
+
+### 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"
+}
+
+resource "aws_lambda_function" "load_lambda" {
+ function_name = "${var.load_lambda_name}"
+ s3_bucket = aws_s3_bucket.lambda_bucket.bucket
+ s3_key = "load_lambda/load_function.zip"
+ role = aws_iam_role.PLACEHOLDER_load_lambda_role.arn # << lambda role placehodler
+ handler = "load_lambda.lambda_handler" # << check that the function is called lambda handler
+ runtime = "python3.11"
+}
+
git.ajschof.me — hosted by ajschofield — powered by cgit