Skip to main content

Aggregates composition for domain driven design in Python

Project description

Pycider

Documentation StatusTest Status

Documentation is here. This code is a Python implementation of deciders based on the F# code from Jérémie Chassaing located here dddeu-2023-deciders. There was additionally a talk on this, to be found here.

Installation

You can use pip install pycider or poetry add pycider to install this project from PyPI.

Usage

You can create Process or a Decider. A simple example of this can be found under the test composition page.

Decider

Decider is a simple state machine that seperates state changes and actions. Commands are actions which when executed return Events representing the results from the actions. You can use Event's to deterministically update the State allowing replayability and easy serialization by only saving Event's.

  • Commands are turned into Event's through decide() calls.
  • Event's deterministically update the State through evolve() calls.

Process

Process is a simple state machine for managing a system. A system has several needs. The system given a State should be able to resume to the next Command, The system should be able to react to Event changes and return Command's for dealing with those changes. Finally the system should be able to update the State deterministically given a Event.

  • Event's are turned into Commands thrugh react() calls.
  • Given a State, the system should be able to resume() to the appropriate Command.
  • Event's deterministically update the State through evolve() calls.

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

pycider-1.0.0.tar.gz (7.4 kB view details)

Uploaded Source

Built Distribution

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

pycider-1.0.0-py3-none-any.whl (8.2 kB view details)

Uploaded Python 3

File details

Details for the file pycider-1.0.0.tar.gz.

File metadata

  • Download URL: pycider-1.0.0.tar.gz
  • Upload date:
  • Size: 7.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.2 CPython/3.12.3 Linux/6.8.0-48-generic

File hashes

Hashes for pycider-1.0.0.tar.gz
Algorithm Hash digest
SHA256 fda9b87c59f4ea7bb5276d0acb2c7f9ffe7d502d004957cac1eaa43c7d120935
MD5 be7fdbd80aa13aed61a368d18536fa75
BLAKE2b-256 5728e9fd052bd05c29bc1c8992e960f726b8261b66b1fbfd868d79cca25f7e00

See more details on using hashes here.

File details

Details for the file pycider-1.0.0-py3-none-any.whl.

File metadata

  • Download URL: pycider-1.0.0-py3-none-any.whl
  • Upload date:
  • Size: 8.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.2 CPython/3.12.3 Linux/6.8.0-48-generic

File hashes

Hashes for pycider-1.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 55f4160ba7be53e5da6d25d6e5ad68ab63c7f2df62b9cce5af7ab8108bb69bd8
MD5 044cadfa9810e21624f4da3c55c95a1e
BLAKE2b-256 1f4f7f8fa85ff6d8d053bbd1c72d1dc820874c2e5767ae3590348416ca71091f

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