- Pyramid web framework
- Cornice for REST endpoints
- Database migrations with alembic
- JWT authentication
- Login with Google and Microsoft accounts
- Task queues with Huey
- Pytest
- Webpack 4
- ES2017
- Karma, mocha and expect.js
- Preact
- ESLint
- Dokku deployments
Important: Install Python 3.7.x and npm 8.x before proceeding.
# Change directory into your newly created project.
cd canopus
# Install poetry
pip3 install poetry
# Install the project in editable mode with its testing requirements.
poetry install
npm install
# Run database migrations.
poetry run alembic upgrade head
# Run your project's tests.
poetry run pytest --cov=canopus
# Run your project.
npm start
poetry run pserve development.ini --reload
Given you added the remote repository you just need to do git push production master
to deploy to your production server.
git remote add production dokku@ip:canopus
Note: Assets are not compiled at deployment, therefore you need to compile them by yourself with npm run build
.
For new server instances secure the server (follow these two guides: https://www.ssdnodes.com/SSD_Nodes-The_6_Critical_Steps_to_Secure_Your_Servers.pdf and https://blog.ssdnodes.com/blog/connecting-vps-ssh-security), install dokku and configure the app:
# Install Dokku
wget https://raw.githubusercontent.com/dokku/dokku/v0.13.4/bootstrap.sh
sudo DOKKU_TAG=v0.13.4 bash bootstrap.sh
# Allow HTTP and HTTPS connections, if don't use iptables you should
sudo iptables -I INPUT -p tcp --dport 80 -j ACCEPT
sudo iptables -I INPUT -p tcp --dport 443 -j ACCEPT
# Create the Dokku app
dokku apps:create canopus
# Install PostgreSQL and PostGIS
sudo dokku plugin:install https://github.com/dokku/dokku-postgres.git postgres
sudo docker pull mdillon/postgis:latest
export POSTGRES_IMAGE="mdillon/postgis"
export POSTGRES_IMAGE_VERSION="latest"
dokku postgres:create canopus
dokku postgres:link canopus canopus
# Install Redis
sudo dokku plugin:install https://github.com/dokku/dokku-redis.git redis
dokku redis:create canopus
dokku redis:link canopus canopus
# Install and configure the rollbar notifier (optional)
sudo dokku plugin:install https://github.com/iloveitaly/dokku-rollbar.git
dokku config:set metropolitan ROLLBAR_TOKEN=
# Configure env variables
dokku config:set canopus JWT_SECRET=
dokku config:set canopus APP_CONFIG_FILE=production.ini
dokku config:set canopus PG_DATABASE_URL=postgres://postgres:@dokku-postgres-canopus:5432/canopus
dokku ps:scale canopus web=1 worker=1
# Setup DNS
dokku domains:add canopus example.com
# Generate an SSL certificate
sudo dokku plugin:install https://github.com/dokku/dokku-letsencrypt.git
dokku config:set --no-restart canopus DOKKU_LETSENCRYPT_EMAIL=
dokku letsencrypt canopus
dokku run canopus bash
poetry run pshell production.ini
- Setup better logging