Skip to content

Latest commit

 

History

History
77 lines (54 loc) · 1.85 KB

README.md

File metadata and controls

77 lines (54 loc) · 1.85 KB

Django Finite State Machine Log

Build Status

Automatic logging for the excellent Django FSM package.

Installation

First, install the package with pip. This will automatically install any dependencies you may be missing

pip install git+https://github.com/gizmag/django-fsm-log.git#egg=django-fsm-log

Then migrate the app to create the database table

python manage.py migrate django_fsm_log

Usage

This app will listen for the django_fsm.signals.post_transition to be fired and create a new record for each transition. To query logs simply

from django_fsm_log.models import StateLog
StateLog.objects.all()
# ...all recorded logs...

for_ Manager Method

For convenience there is a custom for_ manager method to easily filter on the generic foreign key

from my_app.models import Article
from django_fsm_log.models import StateLog

article = Article.objects.all()[0]

StateLog.objects.for_(article)
# ...logs for article...

by Decorator

We found that our transitions are commonly called by a user, so we've added a decorator to make logging that painless

from django.db import models
from django_fsm.db.fields import FSMField, transition
from django_fsm_log.decorators import fsm_log_by

class Article(models.Model):

    state = FSMField(default='draft', protected=True)

    @fsm_log_by
    @transition(field=state, source='draft', target='submitted')
    def submit(self, by=None):
        pass

Then every time the transition is called with the by kwarg set, it will be logged

article = Article.objects.create()
article.submit(by=some_user) # StateLog.by will be some_user

Running Tests

./runtests.py