Skip to content

djaodjin/djaodjin-multitier

Repository files navigation

djaodjin-multitier is a Django application that implements shared tenancy.

Major Features:

  • Dynamically select the following based on subdomain or path prefix:
    • Database connection
    • SMTP connection
    • Templates
  • URL resolvers: Dynamic path prefix (as a hack in i18n module)

The notes of the presentation at a SF Django Meetup are useful to understand how middlewares, thread locals and template loaders were used to implement multi-tier applications here.

Development

After cloning the repository, create a virtualenv environment, install the prerequisites, create and load initial data into the database, then run the testsite webapp.

$ python -m venv .venv
$ source .venv/bin/activate
$ pip install -r testsite/requirements.txt

# Create the fixtures databases and run the server
$ make initdb
$ python manage.py runserver

Release Notes

Tested with

  • Python: 3.7, Django: 3.2 (LTS)
  • Python: 3.10, Django: 4.2 (latest)
  • Python: 2.7, Django: 1.11 (legacy) - use testsite/requirements-legacy.txt

0.2.1

  • hotfix extra field can be None
  • replaces field tag by extra to match coding conventions
  • returns multitier.Site when settings.MULTITIER_SITE_MODEL is None.

-- Sebastien Mirolo smirolo@djaodjin.com Tue, 10 Oct 2023 14:00:00 -0700

previous release notes