33<img src="https://img.shields.io/badge/LocalStack-deploys-4D29B4.svg?logo="> <img src="https://img.shields.io/badge/AWS-deploys-F29100.svg?logo=amazon">
44
55### Prerequisites
6- ** This demo was conceived and ran on macOS Catalina version 10.15.7. Other operating systems might
7- need slight variations in using command line tools.
6+ ** This demo was conceived and ran on macOS Catalina version 10.15.7. Other operating systems might
7+ need slight variations in using command line tools.
88
99- Maven 3.8.5 & Java 17
1010- AWS free tier account
@@ -66,38 +66,38 @@ needs to be created with the following policies:
6666We will be using the user's credentials and export them as temporary environment variable with the
6767` export ` (` set ` on Windows) command:
6868```
69- export AWS_ACCESS_KEY_ID=[your_aws_access_key_id]
70- export AWS_SECRET_ACCESS_KEY=[your_aws_secret_access_key_id]
69+ $ export AWS_ACCESS_KEY_ID=[your_aws_access_key_id]
70+ $ export AWS_SECRET_ACCESS_KEY=[your_aws_secret_access_key_id]
7171```
7272Make sure you have Terraform [ installed] ( https://developer.hashicorp.com/terraform/downloads ) .
7373Under setup/terraform run:
7474```
75- terraform init
76- terraform plan
75+ $ terraform init
76+ $ terraform plan
7777```
7878once these 2 commands run successfully and no errors occur, it's time to run:
7979```
80- terraform apply --auto-approve
80+ $ terraform apply --auto-approve
8181```
8282
8383This should create the needed S3 bucket, the DynamoDB ` shipment ` table and populate it with some sample data.
8484
8585Now ` cd ` into ` src/main/shipment-list-frontend ` and run ` npm install ` and ` npm start ` .
8686This will spin up the React app that can be accessed on ` localhost:3000 ` .
8787
88- For running it on Windows, there are some
88+ For running it on Windows, there are some
8989[ extra requirements] ( https://learn.microsoft.com/en-us/windows/dev-environment/javascript/react-on-windows ) ,
9090but no worries, it should be straightforward.
9191
9292Go back to the root folder and run the backend simply by using
9393
9494```
95- mvn spring-boot:run -Dspring-boot.run.profiles=prod
95+ $ mvn spring-boot:run -Dspring-boot.run.profiles=prod
9696```
9797Notice the ` prod ` profile is being set via command line arguments.
9898
99- At ` localhost:3000 ` you should now be able to see a list of shipments with standard icons,
100- that means that only the database is populated, the pictures still need to be added from the
99+ At ` localhost:3000 ` you should now be able to see a list of shipments with standard icons,
100+ that means that only the database is populated, the pictures still need to be added from the
101101` sample-pictures ` folder.
102102The weight of a shipment we can perceive, but not the size, that's why we need pictures to understand,
103103using the "banana for scale" measuring unit. How else would we know??
@@ -106,7 +106,7 @@ using the "banana for scale" measuring unit. How else would we know??
106106The Lambda function is still not up. This falls under the ` shipment-list-lambda-validator ` project.
107107
108108```
109- git clone https://github.com/tinyg210/shipment-list-lambda-validator.git
109+ $ git clone https://github.com/tinyg210/shipment-list-lambda-validator.git
110110```
111111
112112The ` create-lambda.sh ` script will do everything that needs for the creation and configuration of
@@ -124,19 +124,38 @@ and the shipment picture will be replaced with a generic icon.
124124
125125### Developer environment
126126
127- To switch to using LocalStack instead of AWS services just run ` docker compose up ` to spin up a
128- Localstack
129- container.
130- After that, the Spring Boot application needs to start using the dev profile:
131127
128+ To switch to using LocalStack instead of AWS services just run ` docker compose up ` in the root folder
129+ to spin up a Localstack container.
130+
131+ To generate the exact same resources on LocalStack, we need ` tflocal ` , a thin wrapper script around
132+ the terraform command line client. ` tflocal ` takes care of automatically configuring the local service
133+ endpoints, which allows you to easily deploy your unmodified Terraform scripts against LocalStack.
134+
135+ You can [ install] ( https://docs.localstack.cloud/user-guide/integrations/terraform/ ) the ` tflocal `
136+ command via pip (requires a local Python installation):
137+ ```
138+ $ pip install terraform-local
139+ ```
140+ Once installed, the ` tflocal ` command should be available, with the same interface as the terraform
141+ command line. Try it out:
142+ ```
143+ $ tflocal --help
144+ Usage: terraform [global options] <subcommand> [args]
145+ ...
132146```
133- mvn spring-boot:run -Dspring-boot.run.profiles=dev
147+ From here on, it's the same as before:
134148```
149+ $ terraform plan
150+ $ terraform apply --auto-approve
151+ ```
152+
153+
154+ After that, the Spring Boot application needs to start using the dev profile:
135155
136- This should again populate the DynamoDB, this time on LocalStack.
137- From here on, the rest of the steps are the same, but all the scripts that need to run end
138- in ` -local ` ,
139- as they use the ` awslocal ` CLI.
156+ ```
157+ $ mvn spring-boot:run -Dspring-boot.run.profiles=dev
158+ ```
140159
141160The same actions should be easily achieved again, but locally.
142161
0 commit comments