Skip to main content

Plugin interface to list and execute existing management commands.

Project description

Django Commands UI

This project offers a solution to list and execute all existing management commands in your Django project.

Requirements

This project requires Python 3.10 or greater.

Configuration

To install and configure it these steps should be followed:

  1. Install the dependency from PyPi.

    pip install django-commands-ui
    
  2. Add commands_ui as an installed app in your Django project.

  3. If you haven't already done so, you will need to add celery to your django project. You can follow the steps in the First steps with Django guide if you haven't used celery before.

  4. Add the root location of your management commands to your installed apps. For example, if your management commands are in the commands folder in your project root, you would add your-project-name.commands to your installed apps.

  5. Add these required settings:

     # Celery app name.
     COMMANDS_UI_CELERY_APP = ""
    
     # Working celery queue name for delayed jobs.
     COMMANDS_UI_DELAYED_JOBS_QUEUE = ""
    
     # Working celery queue name for standard jobs.
     COMMANDS_UI_JOBS_QUEUE = ""
    
     # Tuple of compiled regexes to extract the runnable commands from.
     # By default, all commands from all installed apps are extracted.
     COMMANDS_UI_JOB_APPS = (re.compile(r".*"),)
    
     # Primary database identifyer, not the replica one.
     DATABASE_PRIMARY = getattr(settings, "DATABASE_PRIMARY", "default")
    
     # Define if the current environment is a cron environment.
     CRON_ENVIRONMENT = getattr(settings, "CRON_ENVIRONMENT", False)
    
  6. Include package URLs to your base urls file like this:

    path("jobs/", include("commands_ui.urls")),
    
  7. Create tables:

    python manage.py migrate commands_ui
    

It is recommended to override base.html so the appearance is customizable, as all django-commands-ui templates extend from it.

Documentation

Implementing a management command job

The only needed thing for implementing a working management command job in django-commands-ui is extending the existing JobBasedCommand. This class adds some default arguments (such as --job-id).

Example on how to use this class:

from typing import Any
from commands_ui import management_commands
from django.core.management.base import CommandParser

# Extend the JobBasedCommand class
class Command(management_commands.JobBasedCommand):
   def handle(self, *args: Any, **options: Any) -> None:
      # Any time `self.print` is used, the message will be added to both standard output and
      # Job output.
      self.print("Starting")
      for i in range(0, 20):
         self.print(i)
      self.print("Finishing")

Command Grouping

You can group types of commands by adding a interface_name class attribute to your management command class. This will group all commands with the same interface_name together in the UI. For example you can group cronjobs together by adding interface_name = "cron" to all your cronjobs.

from typing import Any
from commands_ui import management_commands
from django.core.management.base import CommandParser

# Extend the JobBasedCommand class
class Command(management_commands.JobBasedCommand):
    interface_name = "cron"
   def handle(self, *args: Any, **options: Any) -> None:
      ...

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-commands-ui-0.0.2.tar.gz (22.9 kB view details)

Uploaded Source

Built Distribution

django_commands_ui-0.0.2-py3-none-any.whl (27.8 kB view details)

Uploaded Python 3

File details

Details for the file django-commands-ui-0.0.2.tar.gz.

File metadata

  • Download URL: django-commands-ui-0.0.2.tar.gz
  • Upload date:
  • Size: 22.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.11.3

File hashes

Hashes for django-commands-ui-0.0.2.tar.gz
Algorithm Hash digest
SHA256 82ce95605b4b6c18c555b9c3a2d6ba6d49781ae2f3b98d95b3941f60528c32f1
MD5 ad8b1ac09f73b08b0476f245b0b34710
BLAKE2b-256 c5d9f0fab02f4f66471d113ed81deb2049a2d0ce016ddeea94a216b19e40f02a

See more details on using hashes here.

File details

Details for the file django_commands_ui-0.0.2-py3-none-any.whl.

File metadata

File hashes

Hashes for django_commands_ui-0.0.2-py3-none-any.whl
Algorithm Hash digest
SHA256 21508fd73890a21f6a3f2a27241b343332b608d4eb07e72bdb986e58eede5763
MD5 8a09247849c0a539ef368a60da6edc2e
BLAKE2b-256 efc6a759839bf9141282db62bfd2907bb5df52a5ecca29d72f7fef2afbcf4c9e

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page