codecentric / serverless-astra-graalvm

Sample serverless order processing API using DataStax Astra Serverless and AWS Lambda.
1 stars 1 forks source link
aws-lambda datastax-astra graalvm graalvm-native-image serverless

Serverless Astra GraalVM

Build

Prerequisites

Package

./mvnw package

Note that for the Lambda deployment to work, you need to build a linux-amd64 native image. At this point in time, cross compilation doesn't seem to work so if you are on Mac or Windows, you might need a VM if you're planning to build this locally.

Deployment

Prerequisites

The Astra admin token should have permissions to create databases and keyspaces. Ideally you want a separate application token that can only access databases and keyspaces. At the point of writing this it was not possible to create the application token through Terraform.

The IAM user can use the following AWS managed policies:

Also add this inline policy to allow the management of Lambda roles and policies:

{
  "Version": "2012-10-17",
  "Statement": [
    {
      "Effect": "Allow",
      "Action": [
        "iam:AttachRolePolicy",
        "iam:CreatePolicy",
        "iam:CreateRole",
        "iam:DeletePolicy",
        "iam:DeleteRole",
        "iam:DetachRolePolicy",
        "iam:ListEntitiesForPolicy",
        "iam:ListInstanceProfilesForRole",
        "iam:ListPolicyVersions",
        "iam:TagRole"
      ],
      "Resource": "*"
    }
  ]
}

Initialization

gotf -m tf login
echo 'astra_client_token = "AstraCS:ZZZ' > tf/secrets.auto.tfvars
echo 'astra_db_client_id = "XXX"' >> tf/secrets.auto.tfvars
echo 'astra_db_client_secret = "YYY"' >> tf/secrets.auto.tfvars
echo 'astra_db_client_token = "AstraCS:ZZZ"' >> tf/secrets.auto.tfvars
gotf -m tf init

Apply

gotf -m tf apply

Destroy

gotf -m tf destroy

Usage

aws lambda invoke --function-name serverless-astra-graalvm --log-type Tail --payload "{}" response.json