This is the backend component of Thunderbird Appointment written in Python using FastAPI, SQLAlchemy, and pytest.
More information will be provided in the future. There is currently a docker file provided which we use to deploy to AWS' ECS which should help you get started.
In order to create a user with password authentication mode, you will need to set APP_ALLOW_FIRST_TIME_REGISTER=True
in your .env
.
After the first login you'll want to fill the APP_ADMIN_ALLOW_LIST
env variable with your account's email to access the basic admin panel located at /admin/subscribers
.
The backend project uses dotenv files to inject environment variables into the application. A starting template can be found as .env.example. Copy that as your .env
to get started.
On first run (via dev-entry.sh) a setup command will run filling in some secret environment variables, and the database will initialize.
After that Appointment should be fully usable, however you may want to setup some third-party integrations like Google Calendar connections, or the creation of Zoom meetings. These are clearly labelled in the .env
file, simply setup accounts for them with the vendor, and enter your values in the .env
file.
Backend is formatted using Ruff.
pip install ruff
Commands
ruff check
This project is deployed with Mozilla Accounts (known as fxa in the code.) Since Mozilla Accounts is for internal use you will need to use password authentication. Note: password authentication does not currently have a registration flow.
To run tests in the backend, simply install the package in editing mode:
cd backend && pip install -e .
After this you can run tests with:
cd backend && python -m pytest
To generate a database migration, bash into a running backend container and run:
alembic revision -m "create ... table"
To roll back one migration, run:
alembic downgrade -1
Backend has a light selection of cli commands available to be run inside a container.
run-command main --help
Usage: run-command main [OPTIONS] COMMAND [ARGS]...
╭─ Options ──────────────────────────────────────────────────────╮
│ --help Show this message and exit. │
╰────────────────────────────────────────────────────────────────╯
╭─ Commands ─────────────────────────────────────────────────────╮
│ download-legal │
│ update-db │
│ create-invite-codes │
│ setup │
╰────────────────────────────────────────────────────────────────╯
download-legal
is an internal command to process privacy policy and terms of service files that will be served by the frontend.update-db
runs on docker container entry, and ensures the latest db migration has run, or if it's a new db then to kickstart that.create-invite-codes n
is an internal command to create invite codes which can be used for user registrations. Then
argument is an integer that specifies the amount of codes to be generated.setup
a first run setup that fills in some missing environment variables.