How settings are handled in Django addons¶
In Django projects, settings are handled via the settings module (usually, the
In Aldryn addons - those that include an
aldryn_config.py file - many of these settings will be automatically
managed by the addon itself. This takes place in
All key settings (i.e. settings required for the package to function correctly) as well as many optional settings will be configured. They are then applied to the settings module via the lines:
import aldryn_addons.settings aldryn_addons.settings.load(locals())
From this point in the settings module, those settings that were automatically configured by the addon will be available
For example, in a Django project, you will find a file:
This files adds items to the
MIDDLEWARE, and applies other settings.
These settings can be controlled and determined in a number of different ways.
Via addon settings in the Control Panel¶
An addon can expose options for configuration in the Control Panel interface. For example, Aldryn Django has a Remove URL language prefix for default language option. This will apply to all environments of the project.
The value is stored in JSON. You can find the JSON file in the project locally, for example
Via environment variables¶
Environment variables are suitable for:
environment-specific settings (e.g. database settings, since each environment should have its own)
secret settings (e.g. keys for services and APIs)
Environment variables are better than the codebase for such settings. If committed as part of the codebase, they provide the same value in all environments, and they are vulnerable to being accidentally shared.
Via automatically applied environment variables¶
Some environment variables are provided automatically, and you don’t need to do anything about them at all.
Each project environment has its own variables provided for services such as the database (DEFAULT_DATABASE_DSN), media storage (DEFAULT_STORAGE_DSN) and so on. Locally, the
variables are saved in the
.env-local file and loaded into the environment via docker compose.
Via user-configured environment variables¶
Other environment variables can be provided by the user, via the Control Panel’s Env Variables view:
If you need the variable in the local development environment as well, add (for example):
SECRET_API_KEY = "aaPfaH1oJ5pdqYBc"
As mentioned above, all these settings will be applied to the settings file by the
aldryn_addons.settings.load(locals()) function. If any of them were written into the file manually before this
point, it will overwrite them. Any settings you wish to provide manually should be added after the function to avoid
Overwriting automatically-configured settings¶
Overwriting automatically-configured settings is almost always a bad idea. For example, multiple addons may have
added their own requirements to the
MIDDLEWARE setting. If you simply do:
MIDDLEWARE = [ ... ]
you will obliterate the automatic configuration (or if you place your setting before
aldryn_addons.settings.load(locals()), your own setting will be overwritten).
If for example you need to specify additional middleware, the safer and more sophisticated way to do it is by manipulating the list (see How to configure Django settings in Aldryn projects).
To understand which settings are provided automatically, you can:
examine the addon’s
You can list changed settings to see those that have been altered from Django’s own defaults.