Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/debasishg/frdomain
Code repo for Functional and Reactive Domain Modeling
https://github.com/debasishg/frdomain
Last synced: 3 months ago
JSON representation
Code repo for Functional and Reactive Domain Modeling
- Host: GitHub
- URL: https://github.com/debasishg/frdomain
- Owner: debasishg
- License: apache-2.0
- Created: 2014-10-26T10:26:37.000Z (about 10 years ago)
- Default Branch: master
- Last Pushed: 2019-12-08T07:15:03.000Z (about 5 years ago)
- Last Synced: 2024-08-02T17:39:59.177Z (6 months ago)
- Language: Scala
- Size: 204 KB
- Stars: 465
- Watchers: 48
- Forks: 136
- Open Issues: 13
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
frdomain
========Code repo for [Functional and Reactive Domain Modeling](https://www.manning.com/books/functional-and-reactive-domain-modeling).
From the book page:
> Functional and Reactive Domain Modeling teaches you how to think of the domain model in terms of pure functions and how to compose them to build larger abstractions. You will start with the basics of functional programming and gradually progress to the advanced concepts and patterns that you need to know to implement complex domain models. The book demonstrates how advanced FP patterns like algebraic data types, typeclass based design, and isolation of side-effects can make your model compose for readability and verifiability. On the subject of reactive modeling, the book focuses on higher order concurrency patterns like actors and futures. It uses the Akka framework as the reference implementation and demonstrates how advanced architectural patterns like event sourcing and CQRS can be put to great use in implementing scalable models. You will learn techniques that are radically different from the standard RDBMS based applications that are based on mutation of records. You'll also pick up important patterns like using asynchronous messaging for interaction based on non blocking concurrency and model persistence, which delivers the speed of in-memory processing along with suitable guarantees of reliability.