Databases
š Huge thanks to the sponsors who help me maintain this repo:
Event Sourcing is a data storage paradigm that saves changes in your application state rather than the state itself.
It is powerful as it enables rewinding to a previous state and exploring audit trails for debugging or business/legal purposes. It also integrates very well with event-driven architectures.
However, it is tricky to implement š
After years of using it at Theodo, we have grown to love it, but also experienced first-hand the lack of consensus and tooling around it. That's where Castore comes from!
Castore is a TypeScript library that makes Event Sourcing easy š
š Stack agnostic: Can be used in any JS context (web apps, containers, lambdas... you name it š)
šļø Light-weight: opt-in packages only
šļø Type-safety pushed to the limit
š Validation library agnostic (Zod, JSON schema...) with support for type inference
š On-the-shelf adapters for Redux, DynamoDB, SQS, EventBridge and more
šÆ Test tools included
š§ Migration & maintenance utils available
šØ React components to visualize and model your event stores
And much more to come š: Admin, snapshots, read models...