Python framework for building robust, scalable applications with DDD, CQRS, and Event Sourcing.
Project description
Castlecraft Engineer
Castlecraft Engineer is a Python framework designed to help developers build robust, scalable, and maintainable applications by leveraging established software design patterns like Domain-Driven Design (DDD), Command Query Responsibility Segregation (CQRS), and Event Sourcing.
It provides a collection of abstractions, base classes, and utilities to streamline the development of complex business logic while promoting clean architecture principles.
Guiding Principles & Target Audience
Castlecraft Engineer is built upon established software design principles, primarily:
- Domain-Driven Design (DDD): Tools to model complex business domains effectively.
- Command Query Responsibility Segregation (CQRS): Encouraging separation of write and read operations.
- Event-Driven Architecture (EDA): Support for Domain Events for decoupled communication.
This library is ideal for Python developers building applications with these principles, aiming for highly testable, maintainable, and scalable systems. It may be less suitable for very simple CRUD applications or for teams seeking a fully opinionated, all-in-one web framework.
For a more detailed breakdown, see "Who Is This Library For?" in our main documentation.
Accelerate Development with Castlecraft Architect
While Castlecraft Engineer provides the foundational building blocks for DDD, we recognize that starting a new project can still involve significant boilerplate. To address this, we developed Castlecraft Architect—an intelligent scaffolding and development acceleration tool.
Architect leverages the principles of Engineer to:
- Generate DDD-aligned boilerplate: Quickly scaffold your application with a well-structured foundation.
- Facilitate Domain Exploration: Generate context for LLMs to assist in discussions with domain experts.
- Provide AI-Powered Guidance: Suggest contextually relevant code additions while respecting architectural integrity.
Engineer is the open-source framework that provides the building blocks, and Architect is our open-source tool to help you get started faster and streamline development on top of it.
Key Features
- Domain-Driven Design (DDD) Primitives: Base classes for
AggregateandAggregateRepositoryto model your domain and manage persistence with optimistic concurrency. - Command Query Responsibility Segregation (CQRS): Clear separation of write operations (Commands) and read operations (Queries) with dedicated buses (
CommandBus,QueryBus) and handlers. - Event System: Support for domain events (
Event), in-processEventBus, and abstractions forExternalEventPublisherandEventStreamConsumerfor integrating with message brokers. - Event Store: An
EventStoreabstraction for persisting event streams, crucial for implementing Event Sourcing. Includes anInMemoryEventStorefor testing. - Sagas: Support for managing distributed transactions and long-running processes through sagas (newly documented).
- Dependency Injection: Built-in DI container (
ContainerBuilderbased onpunq) for managing dependencies and promoting loosely coupled components. - SQLModel-based Persistence: Easy integration with SQL databases using
SQLModel, with generic repositories (ModelRepository,AsyncModelRepository) for data access. - Authorization Framework: A flexible authorization service (
AuthorizationService,Permissionobjects,@ctxdecorator) to secure your application's features. - Caching Utilities: Helpers for integrating with Redis (
RedisCacheClient,AsyncRedisCacheClient) for both synchronous and asynchronous caching needs. - OIDC Authentication: Utilities for OpenID Connect (OIDC) token verification and JWKS caching (
AuthenticationService). - Cryptography: Simple encryption/decryption utilities (
encrypt_data,decrypt_data) using AES-GCM (via thecryptographylibrary). - Testing Utilities: A suite of test helpers and base classes to facilitate unit and integration testing of components built with the framework.
- CLI Support: Basic CLI structure for bootstrapping tasks (e.g., database schema creation).
Installation
You can install castlecraft-engineer using uv (recommended) or pip:
uv pip install castlecraft-engineer
Or:
pip install castlecraft-engineer
Quickstart
To give you a taste of how Engineer structures operations, here's a brief example of defining a business command and its handler (a core concept in CQRS):
from dataclasses import dataclass
from castlecraft_engineer.abstractions.command import Command
from castlecraft_engineer.abstractions.command_handler import CommandHandler
from castlecraft_engineer.common.di import ContainerBuilder
from castlecraft_engineer.abstractions.command_bus import CommandBus
import asyncio
# 1. Define a Command
@dataclass(frozen=True)
class CreateItemCommand(Command[str]): # Returns a string (e.g., item ID)
name: str
# 2. Define a Command Handler
class CreateItemHandler(CommandHandler[CreateItemCommand, str]):
async def execute(self, command: CreateItemCommand) -> str:
print(f"Creating item: {command.name}")
# ... actual logic to create and persist item ...
item_id = f"item_{command.name.lower().replace(' ', '_')}"
print(f"Item created with ID: {item_id}")
return item_id
async def main():
# 3. Setup DI Container and Buses
builder = ContainerBuilder()
builder.with_command_bus()
# Register with DI
builder.register(CreateItemHandler)
# Register with Command Bus
builder.command_bus.register(CreateItemHandler)
container = builder.build()
# 4. Get the Command Bus and execute the command
command_bus = container.resolve(CommandBus)
item_id = await command_bus.execute(CreateItemCommand(name="My New Item"))
print(f"Command executed, returned ID: {item_id}")
if __name__ == "__main__":
asyncio.run(main())
For more detailed examples and usage, please refer to the Full Documentation.
Documentation
Comprehensive documentation, including conceptual guides, tutorials, and API references, is available at: https://engineer.castlecraft.in
The documentation is built using MkDocs with the Material theme and includes:
- Installation Guide
- Quickstart Guide
- In-depth Conceptual Explanations
- Step-by-step Tutorials
- API Reference
- Guides on Error Handling, Testing, and CLI usage.
To build the documentation locally:
uv pip install mkdocs mkdocs-material pymdown-extensions mike mkdocs-awesome-pages-plugin
mkdocs serve
Contributing
Contributions are welcome! If you'd like to contribute, please:
- Fork the repository on GitLab.
- Create a new branch for your feature or bug fix.
- Make your changes and ensure tests pass.
- Add or update documentation as necessary.
- Submit a Merge Request with a clear description of your changes.
Please refer to the CONTRIBUTING.md file for more detailed guidelines.
We use python-semantic-release for versioning and releases, and pre-commit for code quality checks.
Development Setup
To set up the project for development:
# 1. Clone the repository
git clone https://gitlab.com/castlecraft/framework/engineer.git
cd castlecraft-engineer
# 2. Create a virtual environment and install dependencies (using uv)
python -m venv .venv
source .venv/bin/activate
uv pip install -e ".[dev]"
# 3. Install pre-commit hooks
pre-commit install
Running Tests
To run the test suite:
pytest
License
This project is licensed under the MIT License - see the LICENSE file for details.
Built with passion by the Castlecraft Engineering team.
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file castlecraft_engineer-0.11.0.tar.gz.
File metadata
- Download URL: castlecraft_engineer-0.11.0.tar.gz
- Upload date:
- Size: 65.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.10.19
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
833111ee168747d62415363fb6013b8081b4295eb794ebf99825ba9fb3768032
|
|
| MD5 |
75a6a21f2ff15170778cdafe35783774
|
|
| BLAKE2b-256 |
db19adddb9c12c4fc7ff5709d40d64a9996e2589e396644b36bb899c27139a4e
|
File details
Details for the file castlecraft_engineer-0.11.0-py3-none-any.whl.
File metadata
- Download URL: castlecraft_engineer-0.11.0-py3-none-any.whl
- Upload date:
- Size: 96.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.10.19
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
2bf8369f7d315a66b3abcf284689e979df875f5d6c00da1119532ca571dbab4c
|
|
| MD5 |
7075f2316a8a1a0fc1e695e119e64240
|
|
| BLAKE2b-256 |
18827ea75751d2ce3d4099884dab92ddf3803f105dbe4f49972b33f033d85108
|