Skip to main content

No project description provided

Project description

Koherent

codecov PyPI version Maintenance Maintainer PyPI pyversions PyPI status PyPI download month Code style: black Checked with mypy Ruff

What is Koherent?

Koherent is a python library that allows you to integrated based audit logging into your application. It thinly wraps the django-simple-history library, and provides a simple interface for logging and reverting changes to your models.

Note: This library is still heavily tied to the Arkitekt Framework. We are working on making it more generic.

What do we track?

By default (soon to be configurable), we track the following parameters:

  • user - The user who made the change
  • app - The application that made the change (if present)
  • assignation_id - In which context the change was made (if present)
  • action - The action that was performed (create, update, delete)
  • model - The model that was changed

What is an assignation?

An assignation ID (or more commonly known as a context_id or correlation_id) is a unique identifier that is used to group changes together. FOr example, if you have a Task model, and you want to track all changes to a specific task, you would use the Task's ID as the assignation ID. This allows you to easily track all changes to a specific task, and revert them if necessary.

How do I use it?

Koherent is a Django Libary, so you will have to add it to your INSTALLED_APPS in your settings.py file.

INSTALLED_APPS = [
    ...
    'koherent',
    ...
]

Model Setup

Then in your models, you will need to add the KoherentHistoryModel mixin to your model.

from koherent.fields import HistoryField, HistoricForeignKey
import koherent.signal # This is required to register the signal handlers

class MyModel(KoherentHistoryModel):
    your_field = models.CharField(max_length=255)
    history = HistoryField()
    ...

Strawberry Setup

Koherent is designed to work with Strawberry, so you will need to add its extension to your schema.

import strawberry_django
from koherent.strawberry.extension import KoherentExtension
from app import models

@strawberry_django.type(models.MyModel)
class MyModel:
    id: strawberry.ID
    name: str

@strawberry.type
class Query:

    @strawberry_django.field
    def create_model(self, info, your_field: str) -> MyModel:
        model = models.MyModel.objects.create(your_field=your_field)
        # This will create a new history entry (by sending a signal)
        # bound to the current user and the assignation id

        return model

    @strawberry_django.field
    def update_model(self, info, id: strawberry.ID, your_field: str) -> MyModel:
        model = models.MyModel.objects.get(id=id)
        model.your_field = your_field
        model.save()
        # This will create a new history entry (by sending a signal)
        # bound to the current user and the assignation id

        return model



schema = strawberry.Schema(query=Query, extensions=[KoherentExtension])

GraphQL Setup

Currently we require that you use the Kante GraphQL library, as it provides the assignation_id and user context required for the audit logging. We are soon going to make this more generic.

ASSIGNATION_ID in the Arkitekt Framework

In the Arkitekt Framework, we use the assignation_id to track changes that are done by an app when a user is calling that app through an Arkitekt Rekuest. This allows us to track all changes that are done by a specific Rekuest, and revert them if necessary.

from arkitekt import register
from service.generated_api import create_model, update_model, delete_model, MyModel


@register
def do_some_transactions(name: str) -> MyModel:
    """ Do some transactions """
    # Within this function, all api requests will have the assignatio-id header
    # set to the same value. This allows us to track all changes that are done

    z = create_model(name=name)

    f = update_model(id=z.id, name="New Name") # tracked with the same assignation_id
    
    return f

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

koherent-0.2.0.tar.gz (6.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

koherent-0.2.0-py3-none-any.whl (8.1 kB view details)

Uploaded Python 3

File details

Details for the file koherent-0.2.0.tar.gz.

File metadata

  • Download URL: koherent-0.2.0.tar.gz
  • Upload date:
  • Size: 6.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.7.2

File hashes

Hashes for koherent-0.2.0.tar.gz
Algorithm Hash digest
SHA256 2904c88fef5a545515da01279bddbd90230bb42292a0cef52d8afe7f400102b8
MD5 6887043df9e60ff2d516b77ca64d2e57
BLAKE2b-256 a9a5a6bf33905ce4389c582da86fd5724ab4556508800308c85018faca35b43a

See more details on using hashes here.

File details

Details for the file koherent-0.2.0-py3-none-any.whl.

File metadata

  • Download URL: koherent-0.2.0-py3-none-any.whl
  • Upload date:
  • Size: 8.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.7.2

File hashes

Hashes for koherent-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 8bf97932074d782843cea67b84075838604ca29679e46a6564dae6edabd148de
MD5 c5332bd23639c13bca0acd6d02839b6a
BLAKE2b-256 3fed1e2cb054985a869f29575d6e9eccae7999168af8b2c7cd50c6ada8ec5a76

See more details on using hashes here.

Supported by

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