Skip to content
This repository has been archived by the owner on Oct 22, 2023. It is now read-only.

Latest commit

 

History

History
162 lines (96 loc) · 4.73 KB

README.md

File metadata and controls

162 lines (96 loc) · 4.73 KB

vaidyuti-dex-22

Quickstart

  1. Set up a Python virtual environment and install the required Python dependencies:

     pipenv install
    
  2. Create .env configuration file based on env.sample:

     cp env.sample .env
     vim .env
    
  3. Set up the database

    You'll need to create the database and set DATABASE_URL in the configuration file before you can run migrations and use the code.

    To use SQLite (supported out of the box), set the DATABASE_URL to the location of database file (it will be created on the first run), either relative to the project directory:

     DATABASE_URL=sqlite:///sqlite.db
    

    Or absolutely positioned in the file system:

     DATABASE_URL=sqlite:////full/path/to/sqlite.db
    

    (Note the three or four dashes in the URL, respectively).

    To use PostgreSQL or MariaDB databases, install the appropriate driver and create database and user as needed. Example for PostgreSQL (this assumes you already have PostgreSQL installed on your system via package manager such as apt, rpm, or brew):

    1. Connect to the database as admin and create a new user and database

      CREATE USER 'appuser' WITH PASSWORD 'secretpassword'; CREATE DATABASE 'dbname' WITH OWNER 'appuser';

    2. Install Python database driver for PostgreSQL

      pipenv install psycopg2

    3. Set up DATABASE_URL in your .env:

      DATABASE_URL=postgres://appuser:secretpassword@localhost/dbname

  4. Run migrations:

     pipenv run python manage.py migrate
    
  5. Run the server:

     pipenv run python manage.py runserver
    
  6. Visit the browsable API at http://localhost:8000/api/v1/

  7. Access the Django admin at http://localhost:8000/admin/

Creating superuser

A superuser account can be created using the Django management command:

pipenv run python manage.py createsuperuser

Running tests

pipenv run python manage.py test

Code formatting using black

To format the code automatically using black, just run it in the project directory:

black .

Background tasks using Celery

Use CELERY_BROKER_URL and CELERY_BACKEND environment variables to configure broker and optional results backend to use for the background jobs, see env.sample for details.

Tasks are defined in tasks.py in the appropriate app module.

To run the worker, in the project root, run:

    celery -A dex worker

Logging from the tasks will be shown/hidden based on the celery worker log level (default is WARNING, can be changed with -l LEVEL worker option), not based on Django logging configuration.

To show INFO or higher-priority messages, use:

    celery -A dex worker -l INFO

To run periodic tasks using Celery Beat, specify beat entries in settings/base.py and run celery beat:

    celery -A dex beat -l INFO

Docker support

Build the docker image with:

    docker build -t vaidyuti-dex-22 .

The default command is to start the web server (gunicorn). Run the image with -P docker option to expose the internal port and check the exposed port with docker ps:

    docker run --env-file .env --P vaidyuti-dex-22
    docker ps

Make sure you provide the correct path to the env file (this example assumes it's located in the local directory).

To run a custom command using the image (for example, db migrations):

    docker run --env-file .env vaidyuti-dex-22 python manage.py migrate

To run a Django shell inside the container:

    docker run --env-file .env -t vaidyuti-dex-22

Note that any changes inside the container will be lost. For that reason, running collectstatic or using a SQLite database within a container will have no effect. If you want to use SQLite with docker, mount a docker volume and place the SQLite database inside it.

For more information on the docker build process, see the included Dockerfile.

Heroku support

Heroku automatically provides PostgreSQL database for Python projects and will set DATABASE_URL environment variable automatically to point to the provisioned database. To use this database, add psycopg2 to the list of requirements in requirements.txt before pushing to Heroku.

Initialize Git repository for the project, if you haven't already done so:

    git init
    git add .
    git commit -m 'initial commit'

In Heroku dashboard, create a new app named vaidyuti-dex-22. Initialize Heroku remote in the repository:

    heroku git:remote -a vaidyuti-dex-22

Set up environment variables in Heroku dashboard. At least SECRET_KEY must be specified. Heroku will provide DATABASE_URL automatically. See env.sample for more information.

Deploy the project:

    git push heroku master

After first deploy, make sure you enable the web dyno in Heroku dashboard if it is not already enabled.