Distrubited calculations for Django models
Project description
Django Gem
Django-gem is a reusable Django package that allows user to offload on-the-fly calculations for Django models by putting them into database and providing and easy to use architecture to define, how and when those database fields need to be refreshed.
Installation
Using pip
pip install django-gem
Using poetry
poetry add django-gem
Then add 'django_gem' to your INSTALLED_APPS.
INSTALLED_APPS = [ ... 'django_gem', ]
Usage
First you will need to create a class that knows how to re-calculate your database fields. In this package those classes are called "Cutters".
Each of the methods on the cutter need to be defined as property
,
and the names of those methods should mirror re-calculated fields on the Gem model in the format of cut_<field_name>
.
Side effects on the properties define what related models should trigger recalculations on those fields.
from django_gems_example.gems.callbacks.author import AuthorCutterCallbacks
from django_gems_example.models import Author, Book
from django_gem.cutters.base import BaseCutter
from django_gem.decorators.cutters import side_effects
class AuthorCutter(BaseCutter):
instance: Author
@property
@side_effects(
(Author, [], AuthorCutterCallbacks.author),
(Book, ["author"], AuthorCutterCallbacks.book_author),
)
def cut_book_count(self):
return self.instance.books.count()
Django-gem allows you to create a "satellite" model for you main one,
and define the CutterEngineMeta
with the created cutter
.
from django.db import models
from django_gems_example.gems.cutters.author import AuthorCutter
from django_gems_example.models import Author
from django_gem.models.base import CutterEngineBaseModel, CutterEngineMetaBase
class AuthorGem(CutterEngineBaseModel):
book_count = models.IntegerField(default=0)
class CutterEngineMeta(CutterEngineMetaBase):
model = Author
cutter = AuthorCutter
To access these fields from the main model, you need to define a property on the model with the same name as
the Gem field name, and wrap it with a gem_property
decorator.
from django.db import models
from django_gem.decorators import gem_property
class Author(models.Model):
name = models.CharField(max_length=100)
@gem_property
def book_count(self):
return self.gem.book_count
All the calculations happen implicitly, as cutter_registry
that is populated on Django app startup
loads all the related models and attaches hooks for calculation. But, if needed, there are methods that you can
invoke directly from the Saw
class. It allows refreshing a model, a queryset or an entire content type.
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
Built Distribution
File details
Details for the file django_gem-1.0.1.tar.gz
.
File metadata
- Download URL: django_gem-1.0.1.tar.gz
- Upload date:
- Size: 16.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.5.0 CPython/3.11.0 Linux/5.15.0-1037-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 4346d533faae32bcd4d595dfea257b24bf54e5aa9c616e33ef162520a5a8c8b9 |
|
MD5 | 76d76aeca6a5ad96cec48199d382c814 |
|
BLAKE2b-256 | 4d0ab4c2fb86d281fbd1ece28ce135b43fa4077e2b50d5d4637dacc15a2a2f47 |
File details
Details for the file django_gem-1.0.1-py3-none-any.whl
.
File metadata
- Download URL: django_gem-1.0.1-py3-none-any.whl
- Upload date:
- Size: 28.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.5.0 CPython/3.11.0 Linux/5.15.0-1037-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 1cabc6476602171ea7460cb59c895975ffd8ed641cc7eaeb25c2ab6b74c2e069 |
|
MD5 | 6c604cefdb2ad48c90e7eba2160bc9d8 |
|
BLAKE2b-256 | dc8848653e167f7290c166d8c2d2b214f96e3f0c611d0d484f81b57fe6f11435 |