Python toolbox of Ambient Digital containing an abundance of useful tools and gadgets.
PyPI | GitHub | Full documentation
Creator & Maintainer: Ambient Digital
- 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
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...
tofrom ambient_toolbox...
- The class-based mail functionality was moved to a separate package called django-pony-express.
-
Install the package via pip:
pip install ambient-toolbox
or via uv:
uv add ambient-toolbox
-
Add module to
INSTALLED_APPS
within the main djangosettings.py
:
INSTALLED_APPS = (
# ...
"ambient_toolbox",
)
-
Apply migrations by running:
python ./manage.py migrate
- 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.
This package uses uv for dependency management and building.
-
Update documentation about new/changed functionality
-
Update the
CHANGES.md
-
Increment version in main
__init__.py
-
Create pull request / merge to "master"
-
This project uses uv to publish to PyPI. This will create distribution files in the
dist/
directory.uv build
To publish to the production PyPI:
uv publish
To publish to TestPyPI first (recommended for testing):
uv publish --publish-url https://test.pypi.org/legacy/
You can then test the installation from TestPyPI:
uv pip install --index-url https://test.pypi.org/simple/ ambient-package-update
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".