Execute management commands from the Django admin
Project description
# Django-AdminCommand
[](https://github.com/ambv/black)
Django-AdminCommand is a Django application that makes it possible
to run Django management commands from the admin.
## Contributions
This is an enhanced fork, see the original repo: https://github.com/liberation/django-admincommand
First author: `Djaz Team`, with commits from @amirouche, @diox, @lauxley
Django 1.11 compatibility pull request taken from @mgaitan : https://github.com/liberation/django-admincommand/pull/10
## Dependencies
- django-async (not mandatory)
- django-sneak
## Installation
For now you can only clone this repo and run `python setup.py develop` (sudo if needed) to setup Django AdminCommand.
(Soon on PyPi)
## Settings
You need to activate the Django admin in the settings and ``urls.py``
depending on your needs the configuration may vary, refer
to the Django documentation related to the
[`admin application`](https://docs.djangoproject.com/en/dev/ref/contrib/admin/).
Don't forget to add the application where you defined management
commands in the list of installed applications. This might be already
done but it might not be the case if you use an application to gather
all the management commands that must be admin commands.
## Make magic happens
Create a Django Management Command::
```py
# ./music/management/commands/lyrics.py
class Command(BaseCommand):
help = "Compute lyrics based an bitorological fluctuations"
def handle(self, *args, **options):
# algorithm that generated lyrics based on a title and a dictionary
```
Then you will have to create a configuration class for the command::
```py
# ./music/admincommands.py
from admincommand.models import AdminCommand
class Lyrics(AdminCommand):
pass
```
*NOTE*: This all works based on naming conventions. The file with the form must be called `admincommands` and the form class name must be the same as the management command file name (with camel case converted to underscore notation).
(This will probably change to settings based property in upcoming days)
And all is well, the new admin command will be available under the
«Admin Command» area of the administration of the default admin site.
If you use custom admin site, don't forget to register
``admincommand.models.AdminCommand`` to the admin site object.
## Forms
Forms for the options are build by running an inspection of the command argument (default to bool / checkbox).
If the form does not seems correct for your management command, please check the `type` option in your management command.
## Logs
Logs emitted using the Django (and Python) logging module will be printed on the result page of the admin. They will still go into the normal logging process.
## Compatibility
This module was tested and is designed for Django 1.11, may work with other versions
## Permissions
You MUST add to every user or groups that should have access to the list of commands
«Can change admincommand» permission. Every admin command gets it's own permission
«Can Run AnAdminCommand», so you can add it to proper users or group. Users will
only see and be able to execute admin commands for which they have the permission.
## Asynchronous tasks
**This is not actively supported for now, use at your own risk**
If you want to execute commands asynchronously you have to
specify it in the AdminCommand configuration class with the
``asynchronous`` property set to ``True``::
```py
# ./music/admincommands.py
from admincommands.models import AdminCommand
class Fugue(AdminCommand):
asynchronous = True
class form(forms.Form):
title = forms.CharField()
def get_command_arguments(self, forms_data):
return [forms_data['title']], {}
```
You also need to run periodically ``flush_queue`` from ``django-async`` application for that matter don't forget to install the application.
[](https://github.com/ambv/black)
Django-AdminCommand is a Django application that makes it possible
to run Django management commands from the admin.
## Contributions
This is an enhanced fork, see the original repo: https://github.com/liberation/django-admincommand
First author: `Djaz Team`, with commits from @amirouche, @diox, @lauxley
Django 1.11 compatibility pull request taken from @mgaitan : https://github.com/liberation/django-admincommand/pull/10
## Dependencies
- django-async (not mandatory)
- django-sneak
## Installation
For now you can only clone this repo and run `python setup.py develop` (sudo if needed) to setup Django AdminCommand.
(Soon on PyPi)
## Settings
You need to activate the Django admin in the settings and ``urls.py``
depending on your needs the configuration may vary, refer
to the Django documentation related to the
[`admin application`](https://docs.djangoproject.com/en/dev/ref/contrib/admin/).
Don't forget to add the application where you defined management
commands in the list of installed applications. This might be already
done but it might not be the case if you use an application to gather
all the management commands that must be admin commands.
## Make magic happens
Create a Django Management Command::
```py
# ./music/management/commands/lyrics.py
class Command(BaseCommand):
help = "Compute lyrics based an bitorological fluctuations"
def handle(self, *args, **options):
# algorithm that generated lyrics based on a title and a dictionary
```
Then you will have to create a configuration class for the command::
```py
# ./music/admincommands.py
from admincommand.models import AdminCommand
class Lyrics(AdminCommand):
pass
```
*NOTE*: This all works based on naming conventions. The file with the form must be called `admincommands` and the form class name must be the same as the management command file name (with camel case converted to underscore notation).
(This will probably change to settings based property in upcoming days)
And all is well, the new admin command will be available under the
«Admin Command» area of the administration of the default admin site.
If you use custom admin site, don't forget to register
``admincommand.models.AdminCommand`` to the admin site object.
## Forms
Forms for the options are build by running an inspection of the command argument (default to bool / checkbox).
If the form does not seems correct for your management command, please check the `type` option in your management command.
## Logs
Logs emitted using the Django (and Python) logging module will be printed on the result page of the admin. They will still go into the normal logging process.
## Compatibility
This module was tested and is designed for Django 1.11, may work with other versions
## Permissions
You MUST add to every user or groups that should have access to the list of commands
«Can change admincommand» permission. Every admin command gets it's own permission
«Can Run AnAdminCommand», so you can add it to proper users or group. Users will
only see and be able to execute admin commands for which they have the permission.
## Asynchronous tasks
**This is not actively supported for now, use at your own risk**
If you want to execute commands asynchronously you have to
specify it in the AdminCommand configuration class with the
``asynchronous`` property set to ``True``::
```py
# ./music/admincommands.py
from admincommands.models import AdminCommand
class Fugue(AdminCommand):
asynchronous = True
class form(forms.Form):
title = forms.CharField()
def get_command_arguments(self, forms_data):
return [forms_data['title']], {}
```
You also need to run periodically ``flush_queue`` from ``django-async`` application for that matter don't forget to install the application.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distributions
No source distribution files available for this release.
See tutorial on generating distribution archives.
Built Distribution
Close
Hashes for django_admincommand-0.1.6-py2-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 2dc2cf0058dc1f49af6622fdcd53ddc0bf5b4c4ba2af1d42ab57f74404d4d518 |
|
MD5 | 5689057af2cfc053d2b7358466d9ef82 |
|
BLAKE2b-256 | cbb4b32609351f06f5b3ddafd536c9df677a2210f090e6204ed0a79edbddc768 |