Skip to main content

Django app allowing users to configure settings dynamically in the Admin screen

Project description

django-setty

Django-Setty allows you to dynamically change settings inside the Django Admin Console. The app provides both a database and a cache backend for storing and retrieving your settings.

Coverage Status

Requirements

  • Python 3.6+
  • Django 2.0+

Continuous integration currently tests Django >= v2.

Installation

pip install django-setty

Django Configuration

Add setty to the list of INSTALLED_APPS in your Django settings:

INSTALLED_APPS = [
    ...
    'setty'
]

Create the Setty database table by running

python manage.py migrate

Specify the backend to use using the SETTY_BACKEND setting. The valid backend values are 'DatabaseBackend' and 'CacheBackend'.

'DatabaseBackend' always accesses the database when retrieving settings.

'CacheBackend' only accesses the database if the item is not in the cache, and caches the value once retrieved.

Define the length of time settings should be cached for using the SETTY_CACHE_TTL setting. The default cache TTL is one hour.

SETTY_BACKEND = 'CacheBackend'
SETTY_CACHE_TTL = 60  # 60 seconds

Usage Examples

Open the Django admin console at /admin and open Setty Settings. Here, you will see the list of all settings defined in Setty.

To add a new setting, click the add button.

Enter the setting name, type (String, Integer, Float, Boolean, List, Dictionary) and the value. Note, the List and Dict data type expect the data to be in the JSON format e.g. {"a": 1, "b": 2} and [1, 2, 3].

Once settings have been created, you will be able to access these in your code.

from setty import config

assert config.my_integer == 10

If the setting does not exist in the database, the value defined in the setting SETTY_NOT_FOUND_VALUE will be used. If this is not set, None will be returned.

Setty can be used inside Django templates by adding 'setty.context_processors.setty_settings' to the TEMPLATE_CONTEXT_PROCESSORS setting and accessing it via the setty key.

The value of a setting can also be updated by using the syntax:

from setty import config

config.my_integer = 100

Note: Only settings that already exist in the database can be updated. New settings cannot be added this way.

Loading all settings into the Cache

If you use the CacheBackend backend, you can easily load all settings into the Cache. This is useful if you want to cache all settings when you start up your app.

from setty.backend import CacheBackend
CacheBackend().load_all_settings_into_cache()

Similar Projects

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-setty-3.2.2.tar.gz (15.0 kB view details)

Uploaded Source

Built Distribution

django_setty-3.2.2-py3-none-any.whl (14.4 kB view details)

Uploaded Python 3

File details

Details for the file django-setty-3.2.2.tar.gz.

File metadata

  • Download URL: django-setty-3.2.2.tar.gz
  • Upload date:
  • Size: 15.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/4.5.0 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.61.1 CPython/3.9.5

File hashes

Hashes for django-setty-3.2.2.tar.gz
Algorithm Hash digest
SHA256 88575980430909ca789b883d5b474b4ad87217c7493506743edf756502d58c74
MD5 e71f79840ff7ef4dead4d21300798c76
BLAKE2b-256 43a6cf7945a62833875275fe0f1ebdb7b29208b7b620f4298f14b5e80ef3360c

See more details on using hashes here.

File details

Details for the file django_setty-3.2.2-py3-none-any.whl.

File metadata

  • Download URL: django_setty-3.2.2-py3-none-any.whl
  • Upload date:
  • Size: 14.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/4.5.0 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.61.1 CPython/3.9.5

File hashes

Hashes for django_setty-3.2.2-py3-none-any.whl
Algorithm Hash digest
SHA256 87bbaeeefe0e682171ff5eddf61278566af731755a9a3c777d1cf1589626df47
MD5 17498dd1acdf80bdf5a6ae04f7cdebdd
BLAKE2b-256 e01f90938102e2da8c4addcc92b271a1e18eae622a7a727163327dc7aedc4f5c

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