Skip to main content

Some Django Wizardry

Project description

NWON-Django-Toolbox

This package provides some Django additions that can be used across several projects.

Settings

The Django Toolbox can be configured using the Django settings. We expect the key NWON_DJANGO that holds a dictionary. The dictionary must be of type NWONDjangoSettings that comes with this package (nwon_django_toolbox.nwon_django_settings). The keys mus be snake case or camel case.

For example like this

NWON_DJANGO: NWONDjangoSettings = {
    "authorization_prefix": "Bearer",
    "logger_name": "your-log-name",
    "application_name": "application"
}

Dependencies

The project has a bunch of dependencies that we use in most of our projects. In the end we have quite a lot and need to slim this down in the future.

Django related libraries are:

  • Django (Obviously 🧠)
  • django-polymorphic
  • django-json-widget
  • django-rest-polymorphic

For API documentation our models and serializer support two library which come as a dependency as well:

  • drf-spectacular
  • drf-yasg

On top we use a bunch of helper libraries

  • Pydantic
  • Pillow
  • jsonref
  • jsonschema-to-openapi
  • pyhumps
  • nwon-baseline

Package is meant for internal use at NWON as breaking changes may occur on version changes. This may change at some point but not for now 😇.

Development Setup

We recommend developing using poetry.

This are the steps to setup the project with a local virtual environment:

  1. Tell poetry to create dependencies in a .venv folder withing the project: poetry config virtualenvs.in-project true
  2. Create a virtual environment using the local python version: poetry env use $(cat .python-version)
  3. Install dependencies: poetry install

Prepare Package

Before publishing the package we need to:

  1. Clean dist folder
  2. Bump up the version of the package
  3. Build the package

Luckily we provide a script for doing all of this python scripts/prepare.py patch. Alternatively you can run the script in a poetry context poetry run prepare patch. The argument at the end defines whether you want a patch, minor or major version bump.

The final zipped data ends up in the dist folder.

Publish Package

Test package publication

  1. Add test PyPi repository: poetry config repositories.testpypi https://test.pypi.org/legacy/
  2. Publish the package to the test repository: poetry publish -r testpypi
  3. Test package: pip install --index-url https://test.pypi.org/simple/ nwon_baseline

If everything works fine publish the package via poetry publish.

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

nwon_django_toolbox-0.5.20.tar.gz (1.1 MB view details)

Uploaded Source

Built Distribution

nwon_django_toolbox-0.5.20-py3-none-any.whl (2.0 MB view details)

Uploaded Python 3

File details

Details for the file nwon_django_toolbox-0.5.20.tar.gz.

File metadata

  • Download URL: nwon_django_toolbox-0.5.20.tar.gz
  • Upload date:
  • Size: 1.1 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.7.1 CPython/3.11.6 Linux/6.2.0-37-generic

File hashes

Hashes for nwon_django_toolbox-0.5.20.tar.gz
Algorithm Hash digest
SHA256 d9e576c8950d641cad3d376136faabfc2a7142529cd82972bbe98ea47b21fafa
MD5 c62a2a72200e9dce30973513f1a11d51
BLAKE2b-256 b4dfe79b90589c72c8253710e03d94d5e6c7cbfa7864f531b380582c226523df

See more details on using hashes here.

File details

Details for the file nwon_django_toolbox-0.5.20-py3-none-any.whl.

File metadata

File hashes

Hashes for nwon_django_toolbox-0.5.20-py3-none-any.whl
Algorithm Hash digest
SHA256 ce95885bc34281f7cfb2d08aa0cd4eb74e1b4e952d6c78825523285474dfb23b
MD5 be99910a1a3f9a0e3a2d1e4ca7c0aa70
BLAKE2b-256 48e8f7a38f6e02234d26be5fd907a0ebd19d29e6f4dc74919f2e231e9e77b2af

See more details on using hashes here.

Supported by

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