Deployment tooling built on top of Kubernetes, Hashicorp Consul, Hashicorp Vault, Docker, and Python to power automated rollout and management of software and configuration changes, including
- end-to-end verified TLS
- secure management of secrets
- continuous delivery of changes
See a two-minute video demo from late February 2018.
Originally developed for use within Python Software Foundation infrastructure. See the PyPI infrastructure pull request for more on design goals.
The development environment is managed using Docker and Compose, and you will need these tools installed before doing anything else. They create containers for all the services the app needs, including any dependencies.
To get started, you will normally want to start the application containers, run the database migrations, and create an "admin" user, which you can do with the following shell commands:
$ make start
$ make migrate
$ make create-admin
After running these you should be able to visit http://localhost:8000/
and use
the email address ad@min.com
and password admin
to log in.
The following commands are available for working with the application stack during development:
Starts all the containers needed to run the application. This is normally the first command you'll run, and will download and build any images you don't already have locally. It may take a few minutes the first time it's run, but later invocations are much faster.
Most changes to application code will show up immediately without having to
explicitly restart anything. However, some changes may require rebuilding the
base application image. For example, changing the dependencies in the
requirements.*
files, or changing the Docker config itself. Use this command
after making such changes to rebuild images and restart containers.
Recompiles dependency files.
Additional arguments can be passed to pip-compile with F=
:
make requirements/base.txt F='--upgrade-package flask'
Stops all running containers, but keeps any volumes containing database files, caches, and other persistent state.
Stops all running containers and removes any volumes containing databases and other persistent state. This essentially returns the environment to a blank state as though you had just cloned the repository.
Runs any pending database migrations. This command requires the application containers to already be running.
Creates an admin user, organisation and project. The admin user's ID is
ad@min.com
and its password is admin
. This command requires the application
containers to already be running.
Displays all the application’s HTTP routes.
We currently have a shortage of test coverage. However, we are working on addressing this. We welcome and appreciate any contributions you can make to assist with this task.
Thank you very much for your interest! We have a guide designed for you, please take a moment to read it at CONTRIBUTING.md.
All participants in the Cabotage project are expected to adhere to the PSF Code of Conduct.