UNKNOWN
Project description
django-modelsettings
This Django application allows to define Django application settings with Django ORM models and edit them in the admin area.
Please check the other alternatives at https://www.djangopackages.com/grids/g/live-setting/. This project started because I tried them all and I was not really happy with any of them.
Key points
- The settings are stored in the database, in normalized tables with proper field types and constraints. In particular, it is possible to have a setting which is a ForeignKey to another model (e.g. “Default account”), and it will properly validate and/or update when the corresponding model is deleted.
- The settings are described using standard Django ORM classes (like EmailField or SmallPositiveIntegerField) with all the bells and whistles (e.g. validators). There is no parallel hierarchy of classes for different types of data.
- Each application may have any number of settings groups, however there is no fancy and complex syntax for that. The developer may simply add more Settings classes if he decides so.
- The settings are lazy and effective. The database is not hit until the settings are actually accessed, and then it takes exactly one SQL query to fetch all settings for all apps.
- The system behaves correctly when there is no corresponding data in the database (if the settings have never been saved yet, or have been saved partly).
- Programmatically, all settings from all application are accessible via a single object.
- There is a page for Django Admin.
Requirements
The latest version supports Django 1.7-1.9.
django-modelsettings 0.1.x had a different, more hackish API and supported Django 1.4-1.8.
Installation
pip install django-modelsettings
Usage
Add dbsettings to INSTALLED_APPS:
# settings.py INSTALLED_APPS = [ ... 'dbsettings', ]
Add Settings class in your application:
# blog/models.py from dbsettings.models import BaseSettings class Settings(BaseSettings): contact_email = models.EmailField(default="info@localhost") update_interval = models.PositiveIntegerField(null=True, default=10, help_text="Update interval in seconds") facebook_app_id = models.CharField("Facebook App ID", max_length=32, blank=True)
Create the corresponding database tables:
./manage.py makemigrations && ./manage.py migrate
In your business logic code, access settings directly:
from dbsettings import settings print(settings.blog.contact_email) settings.blog.update_interval = 60 settings.blog.save()
…or via django.conf.settings.db shortcut:
from django.conf import settings print(settings.db.blog.contact_email) settings.db.blog.update_interval = 60 settings.db.blog.save()
Admin area
Enable the admin area by adding a route:
# urls.py import dbsettings.urls urlpatterns = [ url(r'^admin/settings/', include(dbsettings.urls)), ... ]
The settings will be available under Admin > Settings > Settings.
You can also add a direct link with <a href="{% url 'dbsettings' %}">{% trans "Settings" %}</a> (e.g. in your admin/base_site.html overrides).
Several groups of settings per application
It is possible to split settings into several groups within one application.
# blog/models.py from dbsettings.models import BaseSettings class Settings(BaseSettings): option1 = models.IntegerField() class Foo(BaseSettings): option2 = models.IntegerField() class Bar(BaseSettings): option3 = models.IntegerField()
from dbsettings import settings print(settings.blog.option1) print(settings.blog_foo.option2) print(settings.blog_bar.option3)
Project details
Release history Release notifications
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Filename, size | File type | Python version | Upload date | Hashes |
---|---|---|---|---|
Filename, size django-modelsettings-0.2.2.tar.gz (5.2 kB) | File type Source | Python version None | Upload date | Hashes View hashes |
Hashes for django-modelsettings-0.2.2.tar.gz
Algorithm | Hash digest | |
---|---|---|
SHA256 | 5219af71dfbd666efd7a37da96ed9560321f5dd7be438f4b19367c23139f5ceb |
|
MD5 | be92f1aaa0de1126c627571a7ce1ef55 |
|
BLAKE2-256 | 9b643b014e214cadc8c70b67572fa3aa48d7bde424fff29b7edd4ea3e0d3774f |