The NetDash project's goal is to create an interface to allow delegation of specific IT infrastructure management tasks to IT teams outside of a central IT team.
This is implemented with a suite of extensible Django apps and core Django project that seamlessly integrate new modules and customizations without requiring code changes.
- Clone this repository:
git clone [email protected]:netdash/netdash.git
- Change to the new directory:
cd netdash
- Copy the example settings to use them:
cp netdash/netdash/settings_example.py netdash/netdash/settings.py
- Install dependencies:
pip install -r requirements.deploy.txt
- Run migrations:
python netdash/manage.py migrate
- Create a superuser:
python netdash/manage.py createsuperuser
- Run the development server:
python netdash/manage.py runserver
You can now visit the interface in your browser at http://localhost:8000. Click 'login' and use your superuser credentials.
A NetDash Module is a Django App that follows certain conventions and thereby integrates automatically with NetDash without any additional code changes. These integrations include UI link generation, Swagger API inclusion, routing and permissions.
- Change directory to NetDash apps:
cd netdash
- Create a new NetDash Module, substituting
my_custom_nd_module
for your module's name:python manage.py startapp --template ../netdash_module_template my_custom_nd_module
- To enable your new module, add your module's name to
NETDASH_MODULES
innetdash/settings.py
:NetDash Modules can be specified as Django app labels or as paths to an AppConfig the same way thatNETDASH_MODULES = [ 'my_custom_nd_module', ]
settings.INSTALLED_APPS
is configured. - Exclude your app from NetDash's source control, substituting
my_custom_nd_module
for your module's name:echo netdash/my_custom_nd_module >> ../.git/info/exclude
- Initialize a git repo in your new NetDash Module's directory:
git init my_custom_nd_module
- Run its initial migration:
python manage.py migrate
- Restart the development server:
python manage.py runserver
Congrats! You can now explore the interface and look at the NetDash Module you created. If you don't see the module in the interface, make sure you are logged in as your superuser.
If your NetDash Module requires additional packages, add them to requirements.user.txt
and install them with
pip install -r requirements.user.txt
- A module with
urls.py
should declare anapp_name
. - A module with
urls.py
will have its URLs placed under/<app_name>/*
. - A module with a url named
index
in itsurls.py
will have a link toindex
generated in the NetDash navbar. - A module that generates a permission named
can_view_module
will only generate anindex
link in the NetDash navbar for users who have that permission. - A module with
api/urls.py
should declare anapp_name
. If the module also has aurls.py
, it should reuse the previousapp_name
like so:<app_name>-api
- A module with
api/urls.py
will have its API URLs placed under/api/<app_name>/*
.
Check the example apps for examples of these conventions.
If a NetDash Module doesn't properly follow conventions, certain integrations might not work. NetDash includes a diagnose
command to output information about your NetDash Modules that may assist in refactoring them for inclusion in NetDash.
python netdash/manage.py diagnose -v2
Will output diagnostics for all NetDash Modules, including any exception traces (-v2
flag).
If an unrecoverable error is encountered while parsing NetDash Modules, all diagnostics up until the error will be displayed.