Skip to main content

Declare multi-table rules for SQLAlchemy update logic -- 40X more concise, Python for extensibility.

Project description

This package enables you to declare rules that govern SQLAlchemy update transaction logic (multi-table derivations, constraints, and actions such as sending mail or messages).

Logic is stated in Python, and is over an 40X more concise than code.

Features

Logic is declared in Python (example below), and is:

  • Extensible: logic consists of rules (see below), plus standard Python code

  • Multi-table: rules like sum automate multi-table transactions

  • Scalable: rules are pruned and optimized; for example, sums are processed as 1 row adjustment updates, rather than expensive SQL aggregate queries

  • Manageable: develop and debug your rules in IDEs, manage it in SCS systems (such as git) using existing procedures

Example:

The following 5 rules represent the same logic as 200 lines of Python:

https://github.com/valhuber/LogicBank/raw/main/images/example.png

To activate the rules declared above:

LogicBank.activate(session=session, activator=declare_logic)

Depends on:

  • SQLAlchemy

  • Python 3.8

More information:

The github project includes documentation and examples.

Acknowledgements

Many thanks to

  • Tyler Band, for testing and the Banking sample

  • Max Tardiveau, for testing

  • Nishanth Shyamsundar, for testing

  • Achim Götz, for design collaboration

Change Log

0.0.6 - Initial Version

0.0.7 - Class Name can differ from Table Name

0.0.8 - Much-reduced pip-install dependencies

0.0.9 - Hybrid attribute support, old_row example

0.1.0 - Hybrid attribute support, bug fix

0.1.1 - Allocation example - allocate a payment to a set of outstanding orders

0.2.0 - Minor design refactoring of allocation

0.3.0 - Include logic_bank.extensions (allocation), constraint exceptions raised as ConstraintExceptions

0.4.0 - Eliminate “engine” from runtime, to facilitate use in servers. Rework nw tests to centralize open logic in setup().

0.5.0 - Support for Referential Integrity, with examples.

0.5.1 - Support domain object constructors with complex (side effects) __init__ behavior; use row_mapper.column_attrs (not all_orm_descriptors) to avoid ‘flush already in progress’ when using flask_sqlalchemy

0.6.0 - Support for

  • Rule Extensibility

    • e.g., for auditing

  • Generic early events: early_row_event_all_classes (see Rule Extensibility link above)

    • e.g., for time/date stamping

  • New LogicRow functions (see Rule Extensibility link above):

    • are_attributes_changed

    • set_same_named_attributes

  • Minor rename of logic class in nw. Some screen shots may still show the old name (rules_bank.py) instead of logic.py.

  • Bug Fix: (normal) row events weren’t firing (other events - early and commit events - were fine)

0.7.0 - Custom Exceptions, Improved docstrings, samples (and Tutorial) reorganized into examples folder

0.8.0 - Custom Exceptions, callback signature changed to include additional parameters

0.9.0 - Add logicRow.get_derived_attributes, which can be used to enforce behaviors such as Unalterable Derivations

0.9.2 - Add session to logic_row.__str__(), listeners

0.9.3 - Allow for nulls in summed/sum

0.9.4 - Fix bad Warning: Missing Parent:

0.9.5 - Reduce requirement to initialize summed field

0.9.6 - Show Constraint Failures in Console Log

1.0.2 - Replace print with logging for listing rules

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

logicbank-1.0.2.tar.gz (33.5 kB view details)

Uploaded Source

Built Distribution

logicbank-1.0.2-py3-none-any.whl (42.1 kB view details)

Uploaded Python 3

File details

Details for the file logicbank-1.0.2.tar.gz.

File metadata

  • Download URL: logicbank-1.0.2.tar.gz
  • Upload date:
  • Size: 33.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.6.1 requests/2.25.1 setuptools/50.3.2 requests-toolbelt/0.9.1 tqdm/4.51.0 CPython/3.8.6

File hashes

Hashes for logicbank-1.0.2.tar.gz
Algorithm Hash digest
SHA256 5a7c4bcf8a599177e1be835ff9c7423624e30bd4e14ec7e9bff09c3c67f25e46
MD5 01522a0c264766b61e7fd671b1af003b
BLAKE2b-256 02257f7e0245e7646caa7f01fc5c326386a1ba1ac0a7b352b745cb6bde997466

See more details on using hashes here.

File details

Details for the file logicbank-1.0.2-py3-none-any.whl.

File metadata

  • Download URL: logicbank-1.0.2-py3-none-any.whl
  • Upload date:
  • Size: 42.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.6.1 requests/2.25.1 setuptools/50.3.2 requests-toolbelt/0.9.1 tqdm/4.51.0 CPython/3.8.6

File hashes

Hashes for logicbank-1.0.2-py3-none-any.whl
Algorithm Hash digest
SHA256 451ab7384d2a8772e0a6065a195d72f5339af4be1aefd780183e7d08f64f1b9d
MD5 cdff0cc49fe4b00d42b831070c77c043
BLAKE2b-256 3a12fa7135675bee2a0c567c166c8e386e3de223fde56c60be5e42de0ff241bc

See more details on using hashes here.

Supported by

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