Orkestra is a set of PHP components for building Systems and Applications using concepts from Domain Driven Design (DDD), Command Query Responsibility Segregation (CQRS) and Event Souring (ES).
These components can be used independently according to the needs of the systems.
The main goal behind this set of components is to simplify the plumbing required to support the principles of DDD/CQRS/ES and allow developers to build systems by simply focusing on the core domain and business logic.
These components are Infrastructure and Framework independent, allowing them to be used in any kind of setup. There is currently a component tailored for easy integration with the Symfony Framework to simplify the process even further.
Here's a list of the current core components of Orkestra:
- Messaging: Provides the building block to define messages and handlers such as Commands, Queries, Events, Time based messages called (Timers). It also includes the basic mechanisms to integrate intra-process message buses to an application to map messages to their message handlers while providing hooks to alter the behaviour of sending messages to their handlers. In short, it's the Mediator pattern with helpers for CQRS.
- Modeling: Provides the building blocks for Modeling Entities, Aggregates and Aggregate Roots.
- EventSourcing: This component contains the building block to add Event Sourcing capabilities to a system. It provides implementations for Event Sourced Aggregate Roots, interfaces for an Event Store as well as Event Processors which are services responsible for forwarding events saved in an event store to the various components of the system.
- Normalization: This component allows transforming complex object trees into simple PHP arrays of primitives for easy serialization in any format. As a side effect it greatly reduces the need for
ORMs while decoupling persistence mechanism from the domain model as it does not require annotations or inheriting interfaces. In short, it provides ways to do:
Entity -> array -> dump to database (MongoDb, PostgreSql, Redis etc.)
- Privacy: This component provides building blocks to make Personal Data and Privacy an explicit requirement of the system and to simplify the integration of regulations such as GDPR or CCPA.
- DateTime: Based on
cake-php/chronos
to improve the capabilities of DateTimes in an Immutable fashion as well as providing interfaces to access time throughClockInterface
some an application can provide different means to get the current time in different contexts, such as time travel. - Enum: Provides typed Enum to PHP.
- Collections: Provides typed Collections.
- Exceptions: Provides common exceptions.
- Retry: Provides utilities to improve the resiliency of some components in a system through the use of Retry Classes with support for delays and exponential backoff.
- Worker: Provides simple interfaces and base classes to define workers that should be used to run business logic in background processes.
There are also infrastructure specific implementations of some the Interfaces from the core Components:
- PostgreSQLDocumentStore: Allows treating PostgreSQL like a Document Store.
- PostgreSQLEventStore: Implementation of an Event Store in PostgreSQL.
- PostgreSQLPersonalInformationStore: To be used with the Privacy component, allows storing personal data of users in an encrypted form in a PostgreSQL Database.
- PostgreSQLTimerStorage: Allows storing timers of the Messaging component, making it easy to trigger tasks in the future in a much more complex way than Cron by using custom logic.
Here are additional components for easier integration with specific frameworks:
- SymfonyBundle: Integrates various Orkestra Components with Symfony, while also providing a Module system in order to structure projects in a Bounded Context oriented approach.
- Orkestra Framework: Corresponds to an opinionated integration of all the core components with Symfony. It has useful defaults as well as some technical decisions for quickly bootstrapping projects.
The current repository is maintained as a Monorepo, all issues and pull requests for any of the components should be done in this repository. Internally whenever a new release is made it is propagated to the standalone repositories of the different components. For more information please read the Contribution Guide.
To get started, please read the following page from the documentation.
If you are using Orkestra Components in your project and are stuck on something or want to deepen your understanding of the code base, do not hesitate to open an issue in this repository, we will try our best to help you.
Orkestra is open for contributions. If you want to contribute to one of the components or the documentation, please read the Contribution Guide.