Skip to content

Latest commit

 

History

History
96 lines (64 loc) · 3.6 KB

README.md

File metadata and controls

96 lines (64 loc) · 3.6 KB

DDP_backend

License: AGPL v3 Code coverage badge DeepSource

Django application for the DDP platform's management backend. Exposes API endpoints for the management frontend to communicate with, for the purposes of

  • Onboarding an NGO client
  • Adding users from the client-organization
  • Creating a client's workspace in our Airbyte installation
  • Configuring that workspace i.e. setting up sources, destinations and connections
  • Configuring data ingest jobs in our Prefect setup
  • Connecting to the client's dbt GitHub repository
  • Configuring dbt run jobs in our Prefect setup

Development conventions

Api end points naming

  • REST conventions are being followed.
  • CRUD end points for a User resource would look like:
    • GET /api/users/
    • GET /api/users/user_id
    • POST /api/users/
    • PUT /api/users/:user_id
    • DELETE /api/users/:user_id
  • Route parameteres should be named in snake_case as shown above.

Ninja api docs

Code style

  • Pep8 has been used to standardized variable names, classes, module names etc.
  • Pylint is the linting tool used to analyze the code as per Pep8 style.
  • Black is used as the code formatter.

Setting up your vscode env

  • Recommended IDE is VsCode.
  • Install the pylint extension in vscode and enable it.
  • Set the default format provider in vscode as black
  • Update the vscode settings.json as follows
    { "editor.defaultFormatter": null, "python.linting.enabled": true, "python.formatting.provider": "black", "editor.formatOnSave": true }

Running pylint

  • In your virtual environment run pylint ddpui/

Setup instructions

  • pyenv local 3.10

  • pyenv exec python -m venv venv

  • source venv/bin/activate

  • pip install --upgrade pip

  • pip install -r requirements.txt

  • create .env from .env.template

  • create a SQL database and populate its credentials into .env

  • Start Airbyte and populate connection info in .env

  • Start Prefect and populate connection info in .env

  • Make sure you run a Prefect Server (prefect server start) and a Prefect Agent (prefect agent start -q ddp --pool default-agent-pool)

  • Set DEV_SECRETS_DIR in .env unless you want to use Amazon's Secrets Manager

  • Run prefect-proxy and put its URL into PREFECT_PROXY_API_URL in .env

  • Create a local venv, install dbt and put its location into DBT_VENV in .env

  • Create empty directories for CLIENTDBT_ROOT

  • The SIGNUPCODE in .env is for signing up using the frontend. If you are running the frontend, set its URL in FRONTEND_URL

  • Run DB migrations python manage.py migrate

  • Start the server python manage.py runserver