Working slowly on adding state machine to perform reservations

This commit is contained in:
Collin Duncan 2021-11-28 22:34:51 +01:00
parent 6b204a30f2
commit 0329b60a5d
No known key found for this signature in database
3 changed files with 59 additions and 18 deletions

33
terraform/iam.tf Normal file
View file

@ -0,0 +1,33 @@
resource "aws_iam_role" "reservation_scheduler_lambda_iam_role" {
name = "reservation_scheduler_lambda_iam_role"
assume_role_policy = jsonencode({
"Version" = "2012-10-17",
"Statement" = [
{
"Sid" = "reservation_scheduler_lambda-assume_role"
"Action" = "sts:AssumeRole",
"Principal" = {
"Service" = "lambda.amazonaws.com"
},
"Effect" = "Allow",
}
]
})
}
resource "aws_iam_role" "reservation_state_machine_iam_role" {
name = "reservation_state_machine_iam_role"
assume_role_policy = jsonencode({
"Version" = "2012-10-17",
"Statement" = [
{
"Sid" = "reservation_state_machine-invoke_lambda"
"Action" = "lambda:InvokeAsync"
"Effect" = "Allow"
"Resource" = aws_lambda_function.reservation_scheduler_lambda.arn
}
]
})
}

View file

@ -7,27 +7,11 @@ resource "aws_lambda_function" "reservation_scheduler_lambda" {
source_code_hash = filebase64sha256("../deploy/reservationScheduler.zip")
role = aws_iam_role.reservation_scheduler_lambda_iam_role.arn
}
resource "aws_iam_role" "reservation_scheduler_lambda_iam_role" {
name = "reservation_scheduler_lambda_iam_role"
assume_role_policy = <<EOF
{
"Version": "2012-10-17",
"Statement": [
{
"Action": "sts:AssumeRole",
"Principal": {
"Service": "lambda.amazonaws.com"
},
"Effect": "Allow",
"Sid": ""
}
depends_on = [
aws_iam_role.reservation_scheduler_lambda_iam_role
]
}
EOF
}
resource "aws_lambda_function_event_invoke_config" "reservation_scheduler_lambda_config" {
function_name = aws_lambda_function.reservation_scheduler_lambda.function_name

View file

@ -0,0 +1,24 @@
resource "aws_sfn_state_machine" "reservation_state_machine" {
name = "reservation-state-machine"
role_arn = aws_iam_role.reservation_scheduler_lambda_iam_role.arn
definition = jsonencode({
Comment = "Schedules and attempts to create a reservation based on incoming request to API",
StartAt = "schedule-reservation",
States = {
schedule-reservation = {
Type = "Task"
Resource = "arn:aws:states:::lambda:invoke"
Parameters = {
FunctionName = format("%s:$LATEST", aws_lambda_function.reservation_scheduler_lambda.arn)
Payload = {}
}
End = true
}
}
})
depends_on = [
aws_iam_role.reservation_scheduler_lambda_iam_role
]
}