Skip to main content

Python toolbox of Ambient Digital containing an abundance of useful tools and gadgets.

Project description

PyPI release Downloads Coverage Linting Coding Style Documentation Status

Python toolbox of Ambient Digital containing an abundance of useful tools and gadgets.

PyPIGitHubFull documentation

Creator & Maintainer: Ambient Digital

Features

  • Useful classes and mixins for Django admin
  • Coverage script for GitLab
  • Extensions for DRF and GraphQL
  • Mailing backends for Django
  • Management commands for validating a projects test structure
  • Object ownership tracking with timestamping
  • Pattern for improved workflow with Django ORM
  • Helper and util functions for many different use-cases
  • Sentry plugins
  • django-scrubber wrapper class
  • Mixins and test classes for django (class-based) views

Migration from "ai_django_core"

This package was previously known as ai_django_core. Due to the misleading nature of the name, we chose to rename it with something more meaningful.

The migration is really simple, just:

  • Install ambient-toolbox and remove the dependency to ai-django-core
  • Search and replace all usages of from ai_django_core... to from ambient_toolbox...
  • The class-based mail functionality was moved to a separate package called django-pony-express.

Installation

  • Install the package via pip:

    pip install ambient-toolbox

    or via uv:

    uv add ambient-toolbox

  • Add module to INSTALLED_APPS within the main django settings.py:

INSTALLED_APPS = (
    # ...
    "ambient_toolbox",
)
  • Apply migrations by running:

    python ./manage.py migrate

Releasing a new version

Releases are fully automated. Push a version tag and the pipeline will build, sign with Sigstore, publish to PyPI via Trusted Publishing, and create a GitHub Release — no API tokens needed.

git tag v<version>          # e.g. git tag v1.2.3
git push origin v<version>

Tags must start with v. Tags without the prefix won't trigger the pipeline.

First-time setup

Before the pipeline can run for the first time, an admin must:

  1. Create GitHub Environment pypi

    • Go to Settings → Environments → New environment, name it exactly pypi
    • Under Deployment branches and tags, add a tag rule with pattern v*
    • Optionally add required reviewers for a manual approval gate
  2. Configure PyPI Trusted Publisher

    • Go to PyPI → Project settings → Publishing → Add a new publisher
    • Fill in: Owner ambient-innovation, Repository ambient-toolbox, Workflow release.yml, Environment pypi

Publish to ReadTheDocs.io

  • Fetch the latest changes in GitHub mirror and push them
  • Trigger new build at ReadTheDocs.io (follow instructions in admin panel at RTD) if the GitHub webhook is not yet set up.

Maintenance

Please note that this package supports the ambient-package-update. So you don't have to worry about the maintenance of this package. This updater is rendering all important configuration and setup files. It works similar to well-known updaters like pyupgrade or django-upgrade.

To run an update, refer to the documentation page of the "ambient-package-update".

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 Distribution

ambient_toolbox-12.9.4.tar.gz (277.5 kB view details)

Uploaded Source

Built Distribution

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

ambient_toolbox-12.9.4-py3-none-any.whl (89.2 kB view details)

Uploaded Python 3

File details

Details for the file ambient_toolbox-12.9.4.tar.gz.

File metadata

  • Download URL: ambient_toolbox-12.9.4.tar.gz
  • Upload date:
  • Size: 277.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for ambient_toolbox-12.9.4.tar.gz
Algorithm Hash digest
SHA256 28004886e1f9d8359e2d7a2909a803aaa2efacd1d5a948d2199e43a9e933505d
MD5 bb4a211497539d90bb873fb3ac21cda5
BLAKE2b-256 cc0b6961be1ca5d0662fc960950da6efeac673c75a774d1e55e136de1b3fc625

See more details on using hashes here.

Provenance

The following attestation bundles were made for ambient_toolbox-12.9.4.tar.gz:

Publisher: release.yml on ambient-innovation/ambient-toolbox

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file ambient_toolbox-12.9.4-py3-none-any.whl.

File metadata

File hashes

Hashes for ambient_toolbox-12.9.4-py3-none-any.whl
Algorithm Hash digest
SHA256 117e83219d61dc89e13b557817f38226d163e6e348e19309c93aaf4f470ccdc4
MD5 27531b34a1f89acc1739a96e9797073e
BLAKE2b-256 a31718c9a0c1ebfc3a3089c205d43f6d08847dbfcca865b5295eebdc63d0bd19

See more details on using hashes here.

Provenance

The following attestation bundles were made for ambient_toolbox-12.9.4-py3-none-any.whl:

Publisher: release.yml on ambient-innovation/ambient-toolbox

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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