Nexus is a pluggable admin application in Django. It's designed to give you a simple design and architecture for building admin applications.
Retired: this project is no longer maintained. I (Adam Johnson) no longer have time to continue maintaining this. I was doing so to support gargoyle-yplan, a fork for my ex-employer YPlan. If you’d like to sponsor ongoing maintenance or take it over yourself, please contact firstname.lastname@example.org.
Nexus is a pluggable admin application in Django. It’s designed to give you a simple design and architecture for building admin applications.
It was originally created by Disqus, but due to the inactivity we at YPlan have taken over maintenance on this fork.
Tested with all combinations of:
Django: 1.11, 2.0, 2.1, 2.2
Python 3.4+ supported.
Install it with pip:
pip install nexus-yplan
Make sure you pip uninstall nexus first if you’re upgrading from the original to this fork - the packages clash.
You’ll need to enable it much like you would django.contrib.admin.
First, add it to your INSTALLED_APPS setting:
INSTALLED_APPS = ( ... 'nexus', )
nexus has three dependencies from core Django - django.contrib.admin, django.contrib.auth, and django.contrib.sessions. If these applications are not in your INSTALLED_APPS, add them; or if you are using a custom auth system you can skip these requirements by adding the line NEXUS_SKIP_INSTALLED_APPS_REQUIREMENTS = True to your settings.
Second, include nexus at some url in your urls.py:
import nexus # urls.py urlpatterns = patterns('', ('^nexus/', include(nexus.site.urls)), )
Nexus has autodiscovery similar to Django Admin - it will look in each of your INSTALLED_APPS for a nexus_modules submodule, and import that. This is where the app should declare a NexusModule subclass and use nexus.site.register to add it to the main Nexus site. Thus to add functionality you should install some packages with modules, or write your own.
The following modules are tested against nexus-yplan:
There are also some older applications that provide Nexus modules, however these were only developed against Disqus’ Nexus and not this fork; your mileage may vary:
If you want to write a module, there are a couple of example modules in tests/testapp/nexus_modules.py, with templates in tests/testapp/templates/nexus/example. Also the source code shouldn’t be too hard to understand.
A Note on Login
Until Version 1.1, Nexus included a login/logout functionality. Unfortunately these were copied and adapted from an old version of the code in Django Admin, and were thus not up to date with security changes in newer Django versions. Since keeping them up to date would be a burden, and most sites use Django Admin for adminstrator login, the login/logout functions have been removed.
Nexus now relies on Django Admin login, or for users to visit it having logged in through another route.
Nexus’ behaviour can be customized by adding some values to your Django settings.
By default Nexus serves its media files itself through Python, avoiding any configuration to integrate with your project. This is convenient but can be slow. You can control where the media files are served from with the setting NEXUS_MEDIA_PREFIX, for example:
NEXUS_MEDIA_PREFIX = '/served/here/'
This will make Nexus write its media URLs using this prefix, where it assumes you have set up serving its files.
Tested on Django 2.2. No changes were needed for compatibility.
Drop Django 1.8, 1.9, and 1.10 support. Only Django 1.11+ is supported now.
Drop Python 2 support, only Python 3.4+ is supported now.
Fix Django deprecation warnings
Added Django 2.0b1 support
Tested on Django 1.11 (no changes were necessary)
Added CSRF token on the base template to make AJAX requests work when Django’s CSRF_COOKIE_HTTPONLY setting is set
Removed the now obsolete template tag nexus_csrf_cookie_name
Fixed footer appearance on long pages
Fixed the tab highlighting and removed NexusModule.get_request which existed only to support the old broken code.
‘jQuery Templates’ is no longer included in Nexus - this was done for Gargoyle, which now uses its own bundled templating code instead.
Theme updated a bit more to make buttons look nice
New Logo and theme, thanks @emache.
The login logic no longer sends users without permission to see Nexus through a redirect loop, thanks @ChunYin for the report.
Removed support for Django 1.7
Removed the need to add a call to nexus.autodiscover() in your URLConf by using the AppConfig, similar to Django Admin from Django 1.7+
Upgraded jQuery to 1.6.4
Upgraded Facebox to its master version
Removed support for old Django versions
Fixed all deprecation warnings on Django 1.7 and 1.8
Added Django 1.9 support
Added Python 3.4 and 3.5 support
Historically Nexus had a module that embedded Django Admin; this has not worked since Django 1.3 due to removal of the adminmedia template tag that the templates were still using. Because it seems that no one has been using it, it has been removed. Users are encourage to just use the normal Django Admin instead. Nexus thus ships with no modules included.
Removed the login/logout pages, which were copied and adapted from an old version of Django Admin, and likely no longer secure. If you are not logged in Nexus will now redirect you to Django Admin - thus Django Admin is now required by Nexus.
Fixed Nexus CSRF protection to work if you have changed the CSRF cookie name, thanks to a PR on the original Nexus from Github users @karech and @graingert.
First publication on PyPI as nexus-yplan
Django 1.8 compatibility
Better support for Django 1.7 and Python 3
Ensure on exempt views we still send .
Downgrade CSRF ajax to work with older versions of jQuery.
Update AJAX CSRF set to work against correct origins.
Added version to Nexus footer.
Release history Release notifications | RSS feed
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Hashes for nexus_yplan-2.1.2-py3-none-any.whl