Skip to main content

z4j Django framework adapter (Apache 2.0)

Project description

z4j-django

PyPI version Python License

License: Apache 2.0

Django framework adapter for z4j. Drops into any Django project via INSTALLED_APPS and bootstraps a z4j agent on Django startup - no boilerplate, no signal wiring, no custom management commands.

Install

Pick your task engine and install with the matching extra. Each extra pulls the engine adapter AND its companion scheduler in one shot, so a fresh install never needs a second command.

pip install z4j-django[celery]      # Celery + celery-beat
pip install z4j-django[rq]          # RQ + rq-scheduler
pip install z4j-django[dramatiq]    # Dramatiq + APScheduler
pip install z4j-django[huey]        # Huey + huey-periodic
pip install z4j-django[arq]         # arq + arq-cron
pip install z4j-django[taskiq]      # TaskIQ + taskiq-scheduler
pip install z4j-django[all]         # every engine (CI / kitchen sink)

pip install z4j-django (no extra) installs only the framework adapter. That's useful if you already manage engine packages elsewhere; otherwise always pick an engine extra.

Configure

Add z4j_django to your installed apps and set the Z4J dict in Django settings:

# settings.py
INSTALLED_APPS = [
    # ... your apps ...
    "z4j_django",
]

Z4J = {
    "brain_url": env("Z4J_BRAIN_URL"),   # e.g. "https://z4j.internal"
    "token":     env("Z4J_TOKEN"),       # minted in the brain dashboard
    "project_id": env("Z4J_PROJECT_ID", default="default"),
}

On python manage.py runserver (or gunicorn, daphne, uvicorn, ...) the agent starts, connects to the brain, and z4j's dashboard populates with every @shared_task and @task it discovers in your INSTALLED_APPS.

What it does

Piece Purpose
Z4JDjangoConfig.ready() Boots the agent once Django is fully loaded (after INSTALLED_APPS is populated)
Five-layer task discovery Walks INSTALLED_APPS to find @shared_task / @app.task declarations
Django auth bridge Maps the signed-in Django user to z4j_core.User for audit-log stamping
django.core.checks Surfaces misconfiguration at manage.py check time
Optional admin embed Renders a read-only "z4j agent status" panel in the Django admin

Reliability

z4j-django follows the project-wide safety rule: z4j never breaks your Django process. Agent failures are caught at the boundary, logged, and swallowed. Your runserver, gunicorn, and ASGI workers are never affected by a z4j issue.

Documentation

License

Apache 2.0 - see LICENSE. Your Django application is never AGPL-tainted by importing z4j_django.

Links

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

z4j_django-1.2.0.tar.gz (41.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

z4j_django-1.2.0-py3-none-any.whl (38.6 kB view details)

Uploaded Python 3

File details

Details for the file z4j_django-1.2.0.tar.gz.

File metadata

  • Download URL: z4j_django-1.2.0.tar.gz
  • Upload date:
  • Size: 41.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.4

File hashes

Hashes for z4j_django-1.2.0.tar.gz
Algorithm Hash digest
SHA256 d4ff24a0f959b0aab5d7369caf6aa4819f4c0eb3388928fdb3b677268502b4ae
MD5 84c7726c3abb8c10f6f97872771709bf
BLAKE2b-256 42e902f6ec1f5d92a8b15d6603f8e6865469b62f6b1eb05448f212828a6b77a7

See more details on using hashes here.

File details

Details for the file z4j_django-1.2.0-py3-none-any.whl.

File metadata

  • Download URL: z4j_django-1.2.0-py3-none-any.whl
  • Upload date:
  • Size: 38.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.4

File hashes

Hashes for z4j_django-1.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 72c0201a9d8523052a02270a03c514fade5a88197d7b8278fb2c2b451c9055fa
MD5 e779f5420614753ccfbf765be05b6064
BLAKE2b-256 c9c1cd97282f5d935ed07ff962dd6a072db7971476e61ece0cf945d755a59ec5

See more details on using hashes here.

Supported by

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