Skip to main content

Define Django application settings with Django ORM models and edit them in the admin area.

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

  1. 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.

  2. 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.

  3. 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.

  4. 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.

  5. 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).

  6. Programmatically, all settings from all application are accessible via a single object.

  7. There is a page for Django Admin.

Requirements

The latest version supports Django 1.7-1.9.

Installation

pip install django-modelsettings

Migration from 0.1.x

django-modelsettings 0.1.x had a different API and supported Django 1.4-1.8. To migrate from 0.1.x, run manage.py migrate dbsettings --fake.

Usage

Add dbsettings to INSTALLED_APPS:

# settings.py

INSTALLED_APPS = [
        ...
        'dbsettings',
]

Add Settings class in your application:

# blog/models.py

from dbsettings.models import AppSettings

class Settings(AppSettings):
        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 via django.conf.settings.db:

from django.conf import settings

print(settings.db.blog.contact_email)

settings.db.blog.update_interval = 60
settings.db.blog.save()

or directly:

from dbsettings import settings

print(settings.blog.contact_email)

settings.blog.update_interval = 60
settings.blog.save()

print(settings.django.SECRET_KEY)  # shortcut to django.conf.settings

Admin area

The settings editor will be automatically added at Django Admin > Settings.

You can also add a direct link (e.g. in your admin/base_site.html overrides):

<a href="{% url 'admin:dbsettings_root_changelist' %}">{% trans "Settings" %}</a>

Customizing admin area form

To provide a custom admin form for your settings model, create a ModelAdmin class and register it:

# blog/admin.py

from blog.models import Settings
from dbsettings.admin import RootSettingsAdmin

@RootSettingsAdmin.register(Settings)
class SettingsAdmin(admin.ModelAdmin):
        def formfield_for_dbfield(self, db_field, **kwargs):
                if db_field.name == 'welcome_text':
                        kwargs['widget'] = SummernoteWidget()
                return super().formfield_for_dbfield(db_field, **kwargs)

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 AppSettings

class Settings(AppSettings):
        option1 = models.IntegerField()

class Foo(AppSettings):
        option2 = models.IntegerField()

class Bar(AppSettings):
        option3 = models.IntegerField()
from dbsettings import settings

print(settings.blog.option1)
print(settings.blog_foo.option2)
print(settings.blog_bar.option3)

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

django-modelsettings-0.5.1.tar.gz (6.0 kB view details)

Uploaded Source

File details

Details for the file django-modelsettings-0.5.1.tar.gz.

File metadata

  • Download URL: django-modelsettings-0.5.1.tar.gz
  • Upload date:
  • Size: 6.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/20.10.1 requests-toolbelt/0.9.1 tqdm/4.32.1 CPython/3.5.2

File hashes

Hashes for django-modelsettings-0.5.1.tar.gz
Algorithm Hash digest
SHA256 a536897a27c45f47742aadc2253e6937daede22441d2d4eb7aa2380b9665e6ad
MD5 c898ed0d7a3ae599b729ddb9d38a952a
BLAKE2b-256 829ec23c5a2fcb4c7e5b017f9e42b03645d8b3486567e3c88ba6dc4373c320dc

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page