aboutsummaryrefslogtreecommitdiffstats
path: root/terraform
diff options
context:
space:
mode:
Diffstat (limited to 'terraform')
-rw-r--r--terraform/lambda.tf74
-rw-r--r--terraform/rds.tf78
-rw-r--r--terraform/vars.tf10
3 files changed, 162 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"
+}
+
diff --git a/terraform/rds.tf b/terraform/rds.tf
new file mode 100644
index 0000000..4b25c5f
--- /dev/null
+++ b/terraform/rds.tf
@@ -0,0 +1,78 @@
+data "aws_availability_zones" "available" {}
+
+module "vpc" {
+ source = "terraform-aws-modules/vpc/aws"
+ version = "2.77.0"
+
+ name = "${var.project_name}"
+ cidr = "10.0.0.0/16"
+ azs = data.aws_availability_zones.available.names
+ public_subnets = ["10.0.4.0/24", "10.0.5.0/24", "10.0.6.0/24"]
+ enable_dns_hostnames = true
+ enable_dns_support = true
+}
+
+resource "aws_db_subnet_group" "Terrific-Totes-sub-gr" {
+ name = "TT-db-subnet"
+ subnet_ids = module.vpc.public_subnets
+
+ tags = {
+ Name = "${var.project_name}"
+ }
+}
+
+resource "aws_security_group" "rds" {
+ name = "${var.project_name}-rds"
+ vpc_id = module.vpc.vpc_id
+
+ ingress {
+ from_port = 5432
+ to_port = 5432
+ protocol = "tcp"
+ cidr_blocks = ["0.0.0.0/0"]
+ }
+
+ egress {
+ from_port = 5432
+ to_port = 5432
+ protocol = "tcp"
+ cidr_blocks = ["0.0.0.0/0"]
+ }
+
+ tags = {
+ Name = "${var.project_name}-rds"
+ }
+}
+
+resource "aws_db_parameter_group" "Terrific-Totes-param-gr" {
+ name = "TT-db-param"
+ family = "postgres14"
+
+ parameter {
+ name = "log_connections"
+ value = "1"
+ }
+}
+
+resource "aws_db_instance" "Terrific-Totes-rds" {
+ db_name = "${var.project_name}"
+ instance_class = "db.t3.micro"
+ allocated_storage = 5
+ engine = "postgres"
+ engine_version = "14.1"
+ username = "user credentials for the root user" # we could use .env here
+ password = "user password for the root user" # we could use .env here
+ ### alternatively to providing username nad password we can specify:
+# resource "aws_kms_key" "example_key" {
+# description = "Example KMS Key"
+# }
+# within the resource:
+# manage_master_user_password = true
+# master_user_secret_kms_key_id = aws_kms_key.example.key_id
+# }
+ db_subnet_group_name = aws_db_subnet_group.Terrific-Totes-sub-gr.name
+ vpc_security_group_ids = [aws_security_group.rds.id]
+ parameter_group_name = aws_db_parameter_group.Terrific-Totes-param-gr.name
+ publicly_accessible = false
+ skip_final_snapshot = true
+} \ No newline at end of file
diff --git a/terraform/vars.tf b/terraform/vars.tf
index fa84222..350c2c6 100644
--- a/terraform/vars.tf
+++ b/terraform/vars.tf
@@ -23,6 +23,16 @@ variable "transform_lambda_name" {
default = "transform-lambda"
}
+variable "load_lambda_name" {
+ type = string
+ default = "load-lambda"
+}
+
+variable "project_name" {
+ type = string
+ default = "Terrific-Totes"
+}
+
data "aws_caller_identity" "current" {}
data "aws_region" "current" {} \ No newline at end of file
git.ajschof.me — hosted by ajschofield — powered by cgit