Skip to main content

Add special User ForeignKey fields which update automatically

Project description

https://github.com/lambdalisue/django-author/actions/workflows/main.yml/badge.svg https://coveralls.io/repos/github/lambdalisue/django-author/badge.svg?branch=master

Update author and updated_by fields of models automatically

This library is used for updating author and updated_by fields automatically with request.user when the model has created/changed.

Also if you are too lazy to write author = models.ForeignKey(User, _('author'), related_name ...) to every model, just add @with_author decorator to the top of class makes you happy.

Install

This library is on PyPI so you can install it with:

pip install django-author

or from github:

pip install git+https://github.com/lambdalisue/django-author.git

Usage

  1. Add 'author' to your INSTALLED_APPS on settings.py

  2. Add 'author.middlewares.AuthorDefaultBackendMiddleware' to your MIDDLEWARE_CLASSES if you use default author backend

  3. Add author and updated_by field to models which you want to have author and updated_by fields manually or use @with_author decorator like below:

    from django.db import models
    from author.decorators import with_author
    
    @with_author
    class Entry(models.Model):
        title = models.CharField('title', max_length=50)
        body = models.TextField('body')
  4. Done. Now you have automatically updated author and updated_by fields

    If you are in truble, see author_test directory for usage sample.

  5. If you want to forbid modification of the updated_by field for some actions, just set instance._change_updated_by = False before calling save().

Settings

AUTHOR_BACKEND

Class or string path of backend. the backend is used to determine user when object is created/updated.

AUTHOR_CREATED_BY_FIELD_NAME

A name of field. the setting also interfer the name of field created by @with_author decorator. default is ‘author’

AUTHOR_UPDATED_BY_FIELD_NAME

A name of field. the setting also interfer the name of field created by @with_author decorator. default is ‘updated_by’

AUTHOR_DO_NOT_UPDATE_WHILE_USER_IS_NONE

Do not update author or updated_by field when detected user is None. default is True

AUTHOR_MODELS

Check signals for only these models. default is None

AUTHOR_IGNORE_MODELS

Do not check signals for these models. default is [‘auth.user’, ‘auth.group’, ‘auth.permission’, ‘contenttype.contenttype’]

Backend

The default backend use thread_locals storategy to get current request in signal call.

If you want to change the strategy or whatever, create your own backend.

A backend is a class which have get_user method to determine current user.

AuthorDefaultBackend

Default backend. This backend return None when no request found or AnonymousUser create/update object.

AuthorSystemUserBackend

System user backend. This backend return system user when no request found or AnonymousUser create/update object.

system user is determined with get_system_user method and default is User.objects.get(pk=1)

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

django-author-1.2.0.tar.gz (10.7 kB view details)

Uploaded Source

File details

Details for the file django-author-1.2.0.tar.gz.

File metadata

  • Download URL: django-author-1.2.0.tar.gz
  • Upload date:
  • Size: 10.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.2 importlib_metadata/4.8.1 pkginfo/1.7.0 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.61.2 CPython/3.9.7

File hashes

Hashes for django-author-1.2.0.tar.gz
Algorithm Hash digest
SHA256 0c45d986cfe5eb856e968e2c88b552854d3d4e0b69bbca578c6bb5aae06cbd09
MD5 23cd3dac7b65adf3370eebb343489681
BLAKE2b-256 a3215f130f2be0de1f462bf58379d9f0c315e76c36c3d5c29fa5aed99fc0b7cd

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