Skip to main content

Reusable app for Django introducing site preferences system

Project description

http://github.com/idlesign/django-siteprefs

https://img.shields.io/pypi/v/django-siteprefs.svg https://img.shields.io/pypi/dm/django-siteprefs.svg https://img.shields.io/pypi/l/django-siteprefs.svg https://img.shields.io/coveralls/idlesign/django-siteprefs/master.svg https://img.shields.io/travis/idlesign/django-siteprefs/master.svg https://landscape.io/github/idlesign/django-siteprefs/master/landscape.svg?style=flat

What’s that

django-siteprefs allows Django applications settings to come alive

Let’s suppose you have your pretty settings.py file with you application:

from django.conf import settings

MY_OPTION_1 = getattr(settings, 'MY_APP_MY_OPTION_1', True)
MY_OPTION_2 = getattr(settings, 'MY_APP_MY_OPTION_2', 'No alien utopia // Will long survive our bravery')
MY_OPTION_42 = getattr(settings, 'MY_APP_MY_OPTION_42', 42)

Now you want these options to be exposed to Django Admin interface:

from django.conf import settings

MY_OPTION_1 = getattr(settings, 'MY_APP_MY_OPTION_1', True)
MY_OPTION_2 = getattr(settings, 'MY_APP_MY_OPTION_2', 'No alien utopia // Will long survive our bravery')
MY_OPTION_42 = getattr(settings, 'MY_APP_MY_OPTION_42', 42)


# To be sure our app is still functional without django-siteprefs
# we use this try-except block.
try:
    from siteprefs.toolbox import patch_locals, register_prefs

    patch_locals()  # This bootstrap is required before `register_prefs` step.

    # And that's how we expose our options to Admin.
    register_prefs(MY_OPTION_1, MY_OPTION_2, MY_OPTION_42)

except ImportError:
    pass

We’re done with the app. Now to your settings.py of your project.

  • Add siteprefs into INSTALLED_APPS;

  • Use siteprefs autodiscover_siteprefs function to locate all the options exposed by apps in your project:

    from siteprefs.toolbox import autodiscover_siteprefs
    
    autodiscover_siteprefs()

Now you can view your settings in Django Admin.

If you want those settings to be editable through the Admin - siteprefs allows that too, and even more.

Read the docs ;)

Documentation

http://django-siteprefs.readthedocs.org/

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-siteprefs-0.6.0.tar.gz (19.4 kB view details)

Uploaded Source

Built Distribution

django_siteprefs-0.6.0-py2.py3-none-any.whl (18.9 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file django-siteprefs-0.6.0.tar.gz.

File metadata

File hashes

Hashes for django-siteprefs-0.6.0.tar.gz
Algorithm Hash digest
SHA256 4dac58d135398ff76dd2e6561dea55b65130522a1b4167fa6b57db01014df1c2
MD5 5814f0b47d86eb25c2d061819fc54099
BLAKE2b-256 91a0aca2b2a5249bf35237ddf24c4d79eb469afcc38fa544f5ae3a133d7caf8c

See more details on using hashes here.

Provenance

File details

Details for the file django_siteprefs-0.6.0-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for django_siteprefs-0.6.0-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 841122bca8e204d014e55f97942e91e7af3cdb611e62b01a85ddc348ca8741a8
MD5 3480b979efbb44e1376d97bd11a3c914
BLAKE2b-256 922abd27bb5f3cd83aec493b558f3230a16e841fa04433f7b6f4fbea23765486

See more details on using hashes here.

Provenance

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