Skip to content
This repository has been archived by the owner on Dec 16, 2024. It is now read-only.

TBD54566975/ftl-examples

Folders and files

NameName
Last commit message
Last commit date
Feb 13, 2024
Feb 13, 2024
Feb 29, 2024
Mar 7, 2024
Mar 15, 2024
Feb 13, 2024
Jan 19, 2024
Nov 5, 2023
Jan 19, 2024
Nov 5, 2023
Nov 5, 2023
Mar 15, 2024
Feb 13, 2024
Mar 7, 2024

Repository files navigation

FTL examples

This repository contains a few different example modules for FTL. The top-level go and kotlin directories contain language-specific examples, while the online-boutique directory contains a full micro-services demo based on GCP's demo of the same name.

Note

If using Hermit, be sure to open your editor from the activated environment in order to get the correct environment variables.

Running

In order to have all the tools you need to build and run the examples, follow one of these steps:

  • Install Hermit and related shell_hooks.
  • (or) Install and activate the Hermit environment manually: . ./bin/activate-hermit
  • (or) Manually install Just, FTL, Flutter, Go, Goreman, Watchexec, etc. (not recommended)

Online-boutique

The online-boutique directory is designed to show how to use FTL to build an online boutique backend with a mobile (Flutter) app and React frontend.

Preparation

After activating the Hermit environment (see above), change into the online-boutique directory:

cd online-boutique

To see a list of commands that can be run, run just --list in the root of the project.

Start FTL, code gen, and backend services with hot-reloading

just dev

Start the React web app

just web

Flutter app

Flutter is better run via an IDE like VSCode or Android Studio.

Interact with the boutique

Add a new item to your cart using the command-line:

curl -i --json '{"userId": "Larry", "item": {"productId": "OLJCESPC7Z", "quantity": 1}}' localhost:8892/ingress/cart/add
HTTP/1.1 200 OK
Content-Type: application/json; charset=utf-8
Vary: Origin
Date: Wed, 14 Feb 2024 03:00:03 GMT
Content-Length: 2

{}

Checkout the cart:

curl --json '{
  "userCurrency": "AUD",
  "address": {
    "streetAddress": "1600 Amphitheatre Parkway",
    "city": "Mountain View",
    "state": "CA",
    "country": "USA",
    "zipCode": 94043
  },
  "email": "alec@tbd.email",
  "creditCard": {
    "number": "423412341234",
    "cvv": 123,
    "expirationYear": 2024,
    "expirationMonth": 6
  }
}
' localhost:8892/ingress/checkout/Larry | jq .

Open up the FTL console. This will let you navigate the logs, traces and structure of the FTL modules running locally. In the timeline, if you click on one of the calls that we just issued you should see a call trace.

Open up your editor, alter the data structures, alter the logic, and see how it is all reflected in FTL automatically.