Skip to content

Latest commit

Β 

History

History
736 lines (695 loc) Β· 73.9 KB

File metadata and controls

736 lines (695 loc) Β· 73.9 KB

Event Storming Artifacts

Library Domain Model

This document contains the Event Storming artifacts and domain model diagrams for the Library system.


Table of Contents

  1. Event Storming Legend
  2. Big Picture Event Storming
  3. Process Level: Borrowing Flow
  4. Process Level: Return Flow
  5. Process Level: Hold Flow
  6. Aggregate Diagrams
  7. Domain Model Diagram
  8. Context Map Diagram

Event Storming Legend

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚                    EVENT STORMING COLORS                         β”‚
β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€
β”‚                                                                  β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”                                               β”‚
β”‚  β”‚   ORANGE     β”‚  DOMAIN EVENT                                 β”‚
β”‚  β”‚              β”‚  Something that happened (past tense)         β”‚
β”‚  β”‚ BookBorrowed β”‚  "BookBorrowed", "FineIssued"                β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜                                               β”‚
β”‚                                                                  β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”                                               β”‚
β”‚  β”‚    BLUE      β”‚  COMMAND                                      β”‚
β”‚  β”‚              β”‚  Action that triggers event (imperative)      β”‚
β”‚  β”‚ Borrow Book  β”‚  "Borrow Book", "Return Book"                β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜                                               β”‚
β”‚                                                                  β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”                                               β”‚
β”‚  β”‚   YELLOW     β”‚  AGGREGATE                                    β”‚
β”‚  β”‚              β”‚  Entity cluster that processes command        β”‚
β”‚  β”‚    Loan      β”‚  "Book", "Loan", "Patron"                    β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜                                               β”‚
β”‚                                                                  β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”                                               β”‚
β”‚  β”‚   PURPLE     β”‚  POLICY / PROCESS MANAGER                     β”‚
β”‚  β”‚              β”‚  "When X happens, do Y"                       β”‚
β”‚  β”‚  When overdueβ”‚  Reactive business logic                      β”‚
β”‚  β”‚  issue fine  β”‚                                               β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜                                               β”‚
β”‚                                                                  β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”                                               β”‚
β”‚  β”‚    PINK      β”‚  EXTERNAL SYSTEM                              β”‚
β”‚  β”‚              β”‚  Outside the domain boundary                  β”‚
β”‚  β”‚   Stripe     β”‚  "Payment Gateway", "Email Service"          β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜                                               β”‚
β”‚                                                                  β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”                                               β”‚
β”‚  β”‚   GREEN      β”‚  READ MODEL / QUERY                           β”‚
β”‚  β”‚              β”‚  Data needed to make decisions                β”‚
β”‚  β”‚ Patron       β”‚  "Available Books", "Patron Status"          β”‚
β”‚  β”‚ Profile      β”‚                                               β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜                                               β”‚
β”‚                                                                  β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”                                               β”‚
β”‚  β”‚    RED       β”‚  HOT SPOT / PROBLEM                           β”‚
β”‚  β”‚              β”‚  Needs clarification or has conflict          β”‚
β”‚  β”‚      ?       β”‚  Questions, disagreements                     β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜                                               β”‚
β”‚                                                                  β”‚
β”‚       β—‹          ACTOR                                          β”‚
β”‚      /|\         Person or system initiating action             β”‚
β”‚      / \         "Patron", "Librarian", "System"               β”‚
β”‚                                                                  β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

Big Picture Event Storming

Timeline of Domain Events

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚                              LIBRARY DOMAIN - BIG PICTURE                                β”‚
β”‚                                                                                          β”‚
β”‚  TIME ──────────────────────────────────────────────────────────────────────────────▢   β”‚
β”‚                                                                                          β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”                                                                        β”‚
β”‚  β”‚ ACQUISITION β”‚                                                                        β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜                                                                        β”‚
β”‚        β”‚                                                                                β”‚
β”‚        β–Ό                                                                                β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”   β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”   β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”                                         β”‚
β”‚  β”‚   Book    β”‚   β”‚   Book    β”‚   β”‚   Book    β”‚                                         β”‚
β”‚  β”‚ Ordered   │──▢│ Received  │──▢│  Added    β”‚                                         β”‚
β”‚  β”‚           β”‚   β”‚           β”‚   β”‚to Catalog β”‚                                         β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜   β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜   β””β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”˜                                         β”‚
β”‚                                        β”‚                                                β”‚
β”‚  ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─│─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─  β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”                       β”‚                                                β”‚
β”‚  β”‚   PATRON    β”‚                       β”‚                                                β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜                       β”‚                                                β”‚
β”‚        β”‚                               β”‚                                                β”‚
β”‚        β–Ό                               β”‚                                                β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”   β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”        β”‚                                                β”‚
β”‚  β”‚  Patron   β”‚   β”‚  Patron   β”‚        β”‚                                                β”‚
β”‚  β”‚Registered │──▢│ Verified  β”‚        β”‚                                                β”‚
β”‚  β”‚           β”‚   β”‚           β”‚        β”‚                                                β”‚
β”‚  β””β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”˜   β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜        β”‚                                                β”‚
β”‚        β”‚                               β”‚                                                β”‚
β”‚  ─ ─ ─ β”Ό ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─│─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─  β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”΄β”€β”€β”€β”€β”€β”€β”€β”                       β”‚                                                β”‚
β”‚  β”‚   LENDING   β”‚β—€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜                                                β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜                                                                        β”‚
β”‚        β”‚                                                                                β”‚
β”‚        β–Ό                                                                                β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”   β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”   β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”   β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”   β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”        β”‚
β”‚  β”‚   Book    β”‚   β”‚   Loan    β”‚   β”‚   Loan    β”‚   β”‚   Loan    β”‚   β”‚   Book    β”‚        β”‚
β”‚  β”‚ Borrowed  │──▢│  Active   │──▢│  Became   │──▢│  Renewed  │──▢│ Returned  β”‚        β”‚
β”‚  β”‚           β”‚   β”‚           β”‚   β”‚  Overdue  β”‚   β”‚    OR     β”‚   β”‚           β”‚        β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜   β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜   β””β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”˜   β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜   β””β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”˜        β”‚
β”‚                                        β”‚                               β”‚                β”‚
β”‚  ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─│─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─│─ ─ ─ ─ ─ ─ ─  β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”                       β”‚                               β”‚                β”‚
β”‚  β”‚    FINES    β”‚β—€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”΄β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜                β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜                                                                        β”‚
β”‚        β”‚                                                                                β”‚
β”‚        β–Ό                                                                                β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”   β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”   β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”   β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”                         β”‚
β”‚  β”‚   Fine    β”‚   β”‚  Patron   β”‚   β”‚   Fine    β”‚   β”‚  Patron   β”‚                         β”‚
β”‚  β”‚  Issued   │──▢│ Suspended │──▢│   Paid    │──▢│Reinstated β”‚                         β”‚
β”‚  β”‚           β”‚   β”‚           β”‚   β”‚           β”‚   β”‚           β”‚                         β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜   β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜   β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜   β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜                         β”‚
β”‚                                                                                          β”‚
β”‚  ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─ ─  β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”                                                                        β”‚
β”‚  β”‚    HOLDS    β”‚                                                                        β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜                                                                        β”‚
β”‚        β”‚                                                                                β”‚
β”‚        β–Ό                                                                                β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”   β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”   β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”   β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”                         β”‚
β”‚  β”‚   Hold    β”‚   β”‚   Hold    β”‚   β”‚   Hold    β”‚   β”‚   Hold    β”‚                         β”‚
β”‚  β”‚  Placed   │──▢│Ready for  │──▢│ Fulfilled β”‚   β”‚  Expired  β”‚                         β”‚
β”‚  β”‚           β”‚   β”‚  Pickup   β”‚   β”‚    OR     β”‚   β”‚    OR     β”‚                         β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜   β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜   β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜   β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜                         β”‚
β”‚                                                                                          β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

Process Level: Borrowing Flow

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚                              BORROW BOOK PROCESS                                         β”‚
β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€
β”‚                                                                                          β”‚
β”‚     β—‹                                                                                    β”‚
β”‚    /|\   Patron                                                                         β”‚
β”‚    / \                                                                                   β”‚
β”‚     β”‚                                                                                    β”‚
β”‚     β”‚ wants to borrow                                                                   β”‚
β”‚     β–Ό                                                                                    β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”                                                                       β”‚
β”‚  β”‚              β”‚                                                                       β”‚
β”‚  β”‚ Borrow Book  β”‚ ◀─────── COMMAND                                                     β”‚
β”‚  β”‚              β”‚                                                                       β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”€β”€β”˜                                                                       β”‚
β”‚         β”‚                                                                               β”‚
β”‚         β”‚ needs                                                                         β”‚
β”‚         β–Ό                                                                               β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”    β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”    β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”                              β”‚
β”‚  β”‚   Patron     β”‚    β”‚    Book      β”‚    β”‚   Patron     β”‚                              β”‚
β”‚  β”‚   Status     β”‚    β”‚ Availability β”‚    β”‚   Loans      β”‚ ◀─── READ MODELS            β”‚
β”‚  β”‚  (active?)   β”‚    β”‚ (in stock?)  β”‚    β”‚   (< max?)   β”‚                              β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜    β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜    β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜                              β”‚
β”‚         β”‚                   β”‚                   β”‚                                       β”‚
β”‚         β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”΄β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜                                       β”‚
β”‚                             β”‚                                                           β”‚
β”‚                             β–Ό                                                           β”‚
β”‚                    β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”                                                     β”‚
β”‚                    β”‚              β”‚                                                     β”‚
β”‚                    β”‚     Loan     β”‚ ◀─────── AGGREGATE                                 β”‚
β”‚                    β”‚              β”‚                                                     β”‚
β”‚                    β””β”€β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”€β”€β”˜                                                     β”‚
β”‚                           β”‚                                                             β”‚
β”‚                           β”‚ produces                                                    β”‚
β”‚                           β–Ό                                                             β”‚
β”‚                    β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”                                                     β”‚
β”‚                    β”‚              β”‚                                                     β”‚
β”‚                    β”‚BookBorrowed  β”‚ ◀─────── DOMAIN EVENT                              β”‚
β”‚                    β”‚              β”‚                                                     β”‚
β”‚                    β””β”€β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”€β”€β”˜                                                     β”‚
β”‚                           β”‚                                                             β”‚
β”‚              β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”Όβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”                                               β”‚
β”‚              β”‚            β”‚            β”‚                                               β”‚
β”‚              β–Ό            β–Ό            β–Ό                                               β”‚
β”‚       β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β” β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β” β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”                                     β”‚
β”‚       β”‚  Update    β”‚ β”‚   Send     β”‚ β”‚  Fulfill   β”‚                                     β”‚
β”‚       β”‚   Book     β”‚ β”‚   Email    β”‚ β”‚   Hold     β”‚ ◀─── POLICIES                       β”‚
β”‚       β”‚Availabilityβ”‚ β”‚Notificationβ”‚ β”‚ (if any)   β”‚                                     β”‚
β”‚       β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜ β””β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”€β”˜ β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜                                     β”‚
β”‚                            β”‚                                                            β”‚
β”‚                            β–Ό                                                            β”‚
β”‚                     β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”                                                      β”‚
β”‚                     β”‚  SendGrid  β”‚ ◀─────── EXTERNAL SYSTEM                            β”‚
β”‚                     β”‚            β”‚                                                      β”‚
β”‚                     β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜                                                      β”‚
β”‚                                                                                          β”‚
β”‚  BUSINESS RULES:                                                                        β”‚
β”‚  ─────────────────────────────────────────────────────────────────────────────────     β”‚
β”‚  β€’ Patron must be ACTIVE (not suspended)                                                β”‚
β”‚  β€’ Book must be AVAILABLE                                                               β”‚
β”‚  β€’ Patron current loans < borrowing limit                                               β”‚
β”‚  β€’ Loan period: 14 days (standard), 30 days (researcher)                               β”‚
β”‚                                                                                          β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

Process Level: Return Flow

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚                              RETURN BOOK PROCESS                                         β”‚
β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€
β”‚                                                                                          β”‚
β”‚     β—‹                                                                                    β”‚
β”‚    /|\   Patron                                                                         β”‚
β”‚    / \                                                                                   β”‚
β”‚     β”‚                                                                                    β”‚
β”‚     β”‚ returns book                                                                      β”‚
β”‚     β–Ό                                                                                    β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”                                                                       β”‚
β”‚  β”‚              β”‚                                                                       β”‚
β”‚  β”‚ Return Book  β”‚ ◀─────── COMMAND                                                     β”‚
β”‚  β”‚              β”‚                                                                       β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”€β”€β”˜                                                                       β”‚
β”‚         β”‚                                                                               β”‚
β”‚         β”‚ needs                                                                         β”‚
β”‚         β–Ό                                                                               β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”    β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”                                                  β”‚
β”‚  β”‚    Loan      β”‚    β”‚   Current    β”‚                                                  β”‚
β”‚  β”‚   Details    β”‚    β”‚    Date      β”‚ ◀─────── READ MODELS                             β”‚
β”‚  β”‚              β”‚    β”‚              β”‚                                                  β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜    β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜                                                  β”‚
β”‚         β”‚                   β”‚                                                           β”‚
β”‚         β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜                                                           β”‚
β”‚                   β”‚                                                                     β”‚
β”‚                   β–Ό                                                                     β”‚
β”‚          β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”                                                               β”‚
β”‚          β”‚              β”‚                                                               β”‚
β”‚          β”‚     Loan     β”‚ ◀─────── AGGREGATE                                           β”‚
β”‚          β”‚              β”‚                                                               β”‚
β”‚          β””β”€β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”€β”€β”˜                                                               β”‚
β”‚                 β”‚                                                                       β”‚
β”‚                 β”‚ produces                                                              β”‚
β”‚                 β–Ό                                                                       β”‚
β”‚          β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”                                                               β”‚
β”‚          β”‚              β”‚                                                               β”‚
β”‚          β”‚BookReturned  β”‚ ◀─────── DOMAIN EVENT                                        β”‚
β”‚          β”‚{wasOverdue}  β”‚                                                               β”‚
β”‚          β””β”€β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”€β”€β”˜                                                               β”‚
β”‚                 β”‚                                                                       β”‚
β”‚     β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”΄β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”                                                          β”‚
β”‚     β”‚                       β”‚                                                          β”‚
β”‚     β–Ό                       β–Ό                                                          β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”    β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”                                       β”‚
β”‚  β”‚   Update     β”‚    β”‚    When wasOverdue      β”‚                                       β”‚
β”‚  β”‚    Book      β”‚    β”‚    ─────────────────    β”‚                                       β”‚
β”‚  β”‚ Availability β”‚    β”‚                         β”‚ ◀─── POLICY                           β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜    β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”  β”‚                                       β”‚
β”‚         β”‚            β”‚  β”‚  Calculate Fine   β”‚  β”‚                                       β”‚
β”‚         β”‚            β”‚  β”‚                   β”‚  β”‚                                       β”‚
β”‚         β–Ό            β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜  β”‚                                       β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”    β”‚           β”‚             β”‚                                       β”‚
β”‚  β”‚   Notify     β”‚    β”‚           β–Ό             β”‚                                       β”‚
β”‚  β”‚ Next Patron  β”‚    β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”  β”‚                                       β”‚
β”‚  β”‚  in Hold Q   β”‚    β”‚  β”‚       Fine       β”‚  β”‚ ◀─── AGGREGATE                        β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜    β”‚  β”‚                   β”‚  β”‚                                       β”‚
β”‚                      β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜  β”‚                                       β”‚
β”‚                      β”‚           β”‚             β”‚                                       β”‚
β”‚                      β”‚           β–Ό             β”‚                                       β”‚
β”‚                      β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”  β”‚                                       β”‚
β”‚                      β”‚  β”‚   FineIssued     β”‚  β”‚ ◀─── EVENT                            β”‚
β”‚                      β”‚  β”‚                   β”‚  β”‚                                       β”‚
β”‚                      β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜  β”‚                                       β”‚
β”‚                      β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜                                       β”‚
β”‚                                                                                          β”‚
β”‚  BUSINESS RULES:                                                                        β”‚
β”‚  ─────────────────────────────────────────────────────────────────────────────────     β”‚
β”‚  β€’ Fine = $0.25/day overdue (books), $1.00/day (DVDs)                                  β”‚
β”‚  β€’ Maximum fine capped at item replacement cost                                         β”‚
β”‚  β€’ If total fines > $25, suspend patron                                                β”‚
β”‚                                                                                          β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

Process Level: Hold Flow

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚                               HOLD BOOK PROCESS                                          β”‚
β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€
β”‚                                                                                          β”‚
β”‚  PLACE HOLD                                                                              β”‚
β”‚  ──────────                                                                              β”‚
β”‚     β—‹                                                                                    β”‚
β”‚    /|\   Patron                                                                         β”‚
β”‚    / \                                                                                   β”‚
β”‚     β”‚                                                                                    β”‚
β”‚     β–Ό                                                                                    β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”     β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”     β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”                                   β”‚
β”‚  β”‚   Place    │────▢│    Hold    │────▢│   Hold     β”‚                                   β”‚
β”‚  β”‚   Hold     β”‚     β”‚            β”‚     β”‚  Placed    β”‚                                   β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜     β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜     β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜                                   β”‚
β”‚    COMMAND           AGGREGATE           EVENT                                          β”‚
β”‚                                                                                          β”‚
β”‚                                                                                          β”‚
β”‚  WHEN BOOK RETURNED (Policy)                                                            β”‚
β”‚  ────────────────────────────                                                           β”‚
β”‚                                                                                          β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”                                                                         β”‚
β”‚  β”‚   Book     β”‚                                                                         β”‚
β”‚  β”‚ Returned   β”‚                                                                         β”‚
β”‚  β””β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”€β”˜                                                                         β”‚
β”‚        β”‚                                                                                β”‚
β”‚        β–Ό                                                                                β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”                                                           β”‚
β”‚  β”‚   Check Hold Queue       β”‚                                                           β”‚
β”‚  β”‚   ──────────────────     β”‚                                                           β”‚
β”‚  β”‚   Is there a hold        β”‚                                                           β”‚
β”‚  β”‚   for this book?         β”‚                                                           β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜                                                           β”‚
β”‚               β”‚                                                                         β”‚
β”‚       β”Œβ”€β”€β”€β”€β”€β”€β”€β”΄β”€β”€β”€β”€β”€β”€β”€β”                                                                 β”‚
β”‚       β”‚               β”‚                                                                 β”‚
β”‚      YES              NO                                                                β”‚
β”‚       β”‚               β”‚                                                                 β”‚
β”‚       β–Ό               β–Ό                                                                 β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”   β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”                                                            β”‚
β”‚  β”‚  Notify  β”‚   β”‚  Mark    β”‚                                                            β”‚
β”‚  β”‚  Patron  β”‚   β”‚Available β”‚                                                            β”‚
β”‚  β””β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”˜   β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜                                                            β”‚
β”‚       β”‚                                                                                 β”‚
β”‚       β–Ό                                                                                 β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”                                                                       β”‚
β”‚  β”‚ HoldReady    β”‚                                                                       β”‚
β”‚  β”‚ ForPickup    β”‚                                                                       β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜                                                                       β”‚
β”‚       EVENT                                                                             β”‚
β”‚                                                                                          β”‚
β”‚                                                                                          β”‚
β”‚  HOLD EXPIRATION (Scheduled Policy)                                                     β”‚
β”‚  ──────────────────────────────────                                                     β”‚
β”‚                                                                                          β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”     β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”     β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”                                   β”‚
β”‚  β”‚  Daily     │────▢│   Check    │────▢│   Hold     β”‚                                   β”‚
β”‚  β”‚  Scheduler β”‚     β”‚   Expiry   β”‚     β”‚  Expired   β”‚                                   β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜     β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜     β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜                                   β”‚
β”‚                                              β”‚                                          β”‚
β”‚                                              β–Ό                                          β”‚
β”‚                                       β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”                                    β”‚
β”‚                                       β”‚   Notify   β”‚                                    β”‚
β”‚                                       β”‚   Next in  β”‚                                    β”‚
β”‚                                       β”‚   Queue    β”‚                                    β”‚
β”‚                                       β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜                                    β”‚
β”‚                                                                                          β”‚
β”‚  BUSINESS RULES:                                                                        β”‚
β”‚  ─────────────────────────────────────────────────────────────────────────────────     β”‚
β”‚  β€’ Hold pickup window: 7 days                                                           β”‚
β”‚  β€’ Maximum holds per patron: 10                                                         β”‚
β”‚  β€’ Hold queue: FIFO (first come, first served)                                         β”‚
β”‚  β€’ Patron notified via email when hold is ready                                        β”‚
β”‚                                                                                          β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

Aggregate Diagrams

Book Aggregate (Catalog Context)

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚                    BOOK AGGREGATE                                β”‚
β”‚                   (Catalog Context)                              β”‚
β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€
β”‚                                                                  β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”    β”‚
β”‚  β”‚                 Book (Aggregate Root)                    β”‚    β”‚
β”‚  β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€    β”‚
β”‚  β”‚  - id: BookId                                           β”‚    β”‚
β”‚  β”‚  - title: Title                                         β”‚    β”‚
β”‚  β”‚  - author: Author                                       β”‚    β”‚
β”‚  β”‚  - isbn: ISBN (optional)                                β”‚    β”‚
β”‚  β”‚  - publisher: String                                    β”‚    β”‚
β”‚  β”‚  - publicationYear: Int                                 β”‚    β”‚
β”‚  β”‚  - subjects: List<Subject>                              β”‚    β”‚
β”‚  β”‚  - description: String                                  β”‚    β”‚
β”‚  β”‚  - version: Int                                         β”‚    β”‚
β”‚  β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€    β”‚
β”‚  β”‚  + addToCatalog()                                       β”‚    β”‚
β”‚  β”‚  + updateDetails(...)                                   β”‚    β”‚
β”‚  β”‚  + removeFromCatalog(reason)                            β”‚    β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜    β”‚
β”‚                           β”‚                                      β”‚
β”‚           β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”Όβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”                     β”‚
β”‚           β”‚               β”‚               β”‚                     β”‚
β”‚           β–Ό               β–Ό               β–Ό                     β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”              β”‚
β”‚  β”‚   BookId    β”‚  β”‚    Title    β”‚  β”‚   Author    β”‚              β”‚
β”‚  β”‚   (Value)   β”‚  β”‚   (Value)   β”‚  β”‚   (Value)   β”‚              β”‚
β”‚  β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€  β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€  β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€              β”‚
β”‚  β”‚ value: UUID β”‚  β”‚ value: Str  β”‚  β”‚ value: Str  β”‚              β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜              β”‚
β”‚                                                                  β”‚
β”‚  INVARIANTS:                                                     β”‚
β”‚  β€’ Title cannot be empty                                         β”‚
β”‚  β€’ Author cannot be empty                                        β”‚
β”‚  β€’ ISBN must be valid format (10 or 13 digits) if provided      β”‚
β”‚                                                                  β”‚
β”‚  EVENTS PRODUCED:                                                β”‚
β”‚  β€’ BookAddedToCatalog                                            β”‚
β”‚  β€’ BookDetailsUpdated                                            β”‚
β”‚  β€’ BookRemovedFromCatalog                                        β”‚
β”‚                                                                  β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

Loan Aggregate (Lending Context)

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚                    LOAN AGGREGATE                                β”‚
β”‚                   (Lending Context)                              β”‚
β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€
β”‚                                                                  β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”    β”‚
β”‚  β”‚                 Loan (Aggregate Root)                    β”‚    β”‚
β”‚  β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€    β”‚
β”‚  β”‚  - id: LoanId                                           β”‚    β”‚
β”‚  β”‚  - bookId: BookId (reference)                           β”‚    β”‚
β”‚  β”‚  - patronId: PatronId (reference)                       β”‚    β”‚
β”‚  β”‚  - borrowedAt: DateTime                                 β”‚    β”‚
β”‚  β”‚  - dueDate: DateTime                                    β”‚    β”‚
β”‚  β”‚  - returnedAt: DateTime (optional)                      β”‚    β”‚
β”‚  β”‚  - renewalCount: Int                                    β”‚    β”‚
β”‚  β”‚  - status: LoanStatus                                   β”‚    β”‚
β”‚  β”‚  - version: Int                                         β”‚    β”‚
β”‚  β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€    β”‚
β”‚  β”‚  + create(bookId, patronId, loanPeriod)                 β”‚    β”‚
β”‚  β”‚  + renew(): Result                                      β”‚    β”‚
β”‚  β”‚  + markOverdue()                                        β”‚    β”‚
β”‚  β”‚  + return(): DaysOverdue                                β”‚    β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜    β”‚
β”‚                           β”‚                                      β”‚
β”‚           β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”Όβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”                     β”‚
β”‚           β”‚               β”‚               β”‚                     β”‚
β”‚           β–Ό               β–Ό               β–Ό                     β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”              β”‚
β”‚  β”‚   LoanId    β”‚  β”‚ LoanPeriod  β”‚  β”‚ LoanStatus  β”‚              β”‚
β”‚  β”‚   (Value)   β”‚  β”‚   (Value)   β”‚  β”‚   (Enum)    β”‚              β”‚
β”‚  β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€  β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€  β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€              β”‚
β”‚  β”‚ value: UUID β”‚  β”‚ days: Int   β”‚  β”‚ ACTIVE      β”‚              β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜  β”‚ OVERDUE     β”‚              β”‚
β”‚                                    β”‚ RETURNED    β”‚              β”‚
β”‚                                    β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜              β”‚
β”‚                                                                  β”‚
β”‚  INVARIANTS:                                                     β”‚
β”‚  β€’ Cannot renew if status is RETURNED                            β”‚
β”‚  β€’ Cannot renew more than 3 times                                β”‚
β”‚  β€’ Cannot renew if holds exist for this book                     β”‚
β”‚  β€’ DueDate must be after BorrowedAt                              β”‚
β”‚                                                                  β”‚
β”‚  EVENTS PRODUCED:                                                β”‚
β”‚  β€’ BookBorrowed                                                  β”‚
β”‚  β€’ LoanRenewed                                                   β”‚
β”‚  β€’ LoanBecameOverdue                                             β”‚
β”‚  β€’ BookReturned                                                  β”‚
β”‚                                                                  β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

Patron Aggregate (Patron Context)

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚                   PATRON AGGREGATE                               β”‚
β”‚                   (Patron Context)                               β”‚
β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€
β”‚                                                                  β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”    β”‚
β”‚  β”‚                Patron (Aggregate Root)                   β”‚    β”‚
β”‚  β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€    β”‚
β”‚  β”‚  - id: PatronId                                         β”‚    β”‚
β”‚  β”‚  - name: Name                                           β”‚    β”‚
β”‚  β”‚  - email: EmailAddress                                  β”‚    β”‚
β”‚  β”‚  - membershipTier: MembershipTier                       β”‚    β”‚
β”‚  β”‚  - status: PatronStatus                                 β”‚    β”‚
β”‚  β”‚  - contactInfo: ContactInfo                             β”‚    β”‚
β”‚  β”‚  - registeredAt: DateTime                               β”‚    β”‚
β”‚  β”‚  - version: Int                                         β”‚    β”‚
β”‚  β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€    β”‚
β”‚  β”‚  + register(name, email, tier)                          β”‚    β”‚
β”‚  β”‚  + suspend(reason)                                      β”‚    β”‚
β”‚  β”‚  + reinstate()                                          β”‚    β”‚
β”‚  β”‚  + upgradeTier(newTier)                                 β”‚    β”‚
β”‚  β”‚  + getBorrowingLimit(): Int                             β”‚    β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜    β”‚
β”‚                           β”‚                                      β”‚
β”‚           β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”Όβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”                     β”‚
β”‚           β”‚               β”‚               β”‚                     β”‚
β”‚           β–Ό               β–Ό               β–Ό                     β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”              β”‚
β”‚  β”‚MembershipTier β”‚EmailAddress β”‚  β”‚PatronStatus β”‚              β”‚
β”‚  β”‚   (Enum)    β”‚  β”‚   (Value)   β”‚  β”‚   (Enum)    β”‚              β”‚
β”‚  β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€  β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€  β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€              β”‚
β”‚  β”‚ STANDARD    β”‚  β”‚ value: Str  β”‚  β”‚ ACTIVE      β”‚              β”‚
β”‚  β”‚ PREMIUM     β”‚  β”‚             β”‚  β”‚ SUSPENDED   β”‚              β”‚
β”‚  β”‚ RESEARCHER  β”‚  β”‚ validate()  β”‚  β”‚ EXPIRED     β”‚              β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜              β”‚
β”‚                                                                  β”‚
β”‚  BORROWING LIMITS BY TIER:                                       β”‚
β”‚  β€’ STANDARD: 5 books, 14-day loan                                β”‚
β”‚  β€’ PREMIUM: 10 books, 21-day loan                                β”‚
β”‚  β€’ RESEARCHER: 20 books, 30-day loan                             β”‚
β”‚                                                                  β”‚
β”‚  EVENTS PRODUCED:                                                β”‚
β”‚  β€’ PatronRegistered                                              β”‚
β”‚  β€’ PatronSuspended                                               β”‚
β”‚  β€’ PatronReinstated                                              β”‚
β”‚  β€’ MembershipTierChanged                                         β”‚
β”‚                                                                  β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

Domain Model Diagram

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚                              LIBRARY DOMAIN MODEL                                        β”‚
β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€
β”‚                                                                                          β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”    β”‚
β”‚  β”‚                              CATALOG CONTEXT                                     β”‚    β”‚
β”‚  β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”                                                           β”‚    β”‚
β”‚  β”‚  β”‚      Book        β”‚                                                           β”‚    β”‚
β”‚  β”‚  β”‚  Β«aggregateΒ»     β”‚                                                           β”‚    β”‚
β”‚  β”‚  β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€                                                           β”‚    β”‚
β”‚  β”‚  β”‚ id: BookId       β”‚                                                           β”‚    β”‚
β”‚  β”‚  β”‚ title: Title     β”‚                                                           β”‚    β”‚
β”‚  β”‚  β”‚ author: Author   β”‚                                                           β”‚    β”‚
β”‚  β”‚  β”‚ isbn: ISBN       β”‚                                                           β”‚    β”‚
β”‚  β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜                                                           β”‚    β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜    β”‚
β”‚                    β”‚                                                                     β”‚
β”‚                    β”‚ BookAddedToCatalog                                                 β”‚
β”‚                    β–Ό                                                                     β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”    β”‚
β”‚  β”‚                              LENDING CONTEXT                                     β”‚    β”‚
β”‚  β”‚                                                                                  β”‚    β”‚
β”‚  β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”         β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”                              β”‚    β”‚
β”‚  β”‚  β”‚  LoanableBook    β”‚         β”‚      Loan        β”‚                              β”‚    β”‚
β”‚  β”‚  β”‚   Β«entityΒ»       │◀────────│  Β«aggregateΒ»     β”‚                              β”‚    β”‚
β”‚  β”‚  β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€ 0..*    β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€                              β”‚    β”‚
β”‚  β”‚  β”‚ catalogBookId    β”‚         β”‚ id: LoanId       β”‚                              β”‚    β”‚
β”‚  β”‚  β”‚ isAvailable      β”‚         β”‚ bookId           β”‚                              β”‚    β”‚
β”‚  β”‚  β”‚ holdQueue        β”‚         β”‚ patronId         β”‚                              β”‚    β”‚
β”‚  β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜         β”‚ borrowedAt       β”‚                              β”‚    β”‚
β”‚  β”‚           β”‚                   β”‚ dueDate          β”‚                              β”‚    β”‚
β”‚  β”‚           β”‚ 0..*              β”‚ status           β”‚                              β”‚    β”‚
β”‚  β”‚           β–Ό                   β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜                              β”‚    β”‚
β”‚  β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”                  β”‚                                        β”‚    β”‚
β”‚  β”‚  β”‚      Hold        β”‚                  β”‚                                        β”‚    β”‚
β”‚  β”‚  β”‚  Β«aggregateΒ»     β”‚                  β”‚ BookBorrowed                           β”‚    β”‚
β”‚  β”‚  β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€                  β”‚ BookReturned                           β”‚    β”‚
β”‚  β”‚  β”‚ id: HoldId       β”‚                  β”‚ LoanBecameOverdue                      β”‚    β”‚
β”‚  β”‚  β”‚ patronId         β”‚                  β–Ό                                        β”‚    β”‚
β”‚  β”‚  β”‚ bookId           β”‚                                                           β”‚    β”‚
β”‚  β”‚  β”‚ status           β”‚                                                           β”‚    β”‚
β”‚  β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜                                                           β”‚    β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜    β”‚
β”‚                    β”‚                                                                     β”‚
β”‚                    β”‚ LoanBecameOverdue                                                  β”‚
β”‚                    β–Ό                                                                     β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”    β”‚
β”‚  β”‚                               FINES CONTEXT                                      β”‚    β”‚
β”‚  β”‚                                                                                  β”‚    β”‚
β”‚  β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”         β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”                              β”‚    β”‚
β”‚  β”‚  β”‚      Fine        β”‚         β”‚    Payment       β”‚                              β”‚    β”‚
β”‚  β”‚  β”‚  Β«aggregateΒ»     │────────▢│    Β«entityΒ»      β”‚                              β”‚    β”‚
β”‚  β”‚  β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€  0..*   β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€                              β”‚    β”‚
β”‚  β”‚  β”‚ id: FineId       β”‚         β”‚ id: PaymentId    β”‚                              β”‚    β”‚
β”‚  β”‚  β”‚ loanId           β”‚         β”‚ amount: Money    β”‚                              β”‚    β”‚
β”‚  β”‚  β”‚ patronId         β”‚         β”‚ paidAt           β”‚                              β”‚    β”‚
β”‚  β”‚  β”‚ amount: Money    β”‚         β”‚ method           β”‚                              β”‚    β”‚
β”‚  β”‚  β”‚ status           β”‚         β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜                              β”‚    β”‚
β”‚  β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜                                                           β”‚    β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜    β”‚
β”‚                                                                                          β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”    β”‚
β”‚  β”‚                              PATRON CONTEXT                                      β”‚    β”‚
β”‚  β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”                                                           β”‚    β”‚
β”‚  β”‚  β”‚     Patron       β”‚                                                           β”‚    β”‚
β”‚  β”‚  β”‚  Β«aggregateΒ»     β”‚                                                           β”‚    β”‚
β”‚  β”‚  β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€                                                           β”‚    β”‚
β”‚  β”‚  β”‚ id: PatronId     β”‚                                                           β”‚    β”‚
β”‚  β”‚  β”‚ name             β”‚                                                           β”‚    β”‚
β”‚  β”‚  β”‚ email            β”‚                                                           β”‚    β”‚
β”‚  β”‚  β”‚ membershipTier   β”‚                                                           β”‚    β”‚
β”‚  β”‚  β”‚ status           β”‚                                                           β”‚    β”‚
β”‚  β”‚  β”‚ borrowingLimit   β”‚                                                           β”‚    β”‚
β”‚  β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜                                                           β”‚    β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜    β”‚
β”‚                                                                                          β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

Context Map Diagram

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚                              CONTEXT MAP                                                 β”‚
β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€
β”‚                                                                                          β”‚
β”‚                         β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”                                         β”‚
β”‚                         β”‚    SHARED KERNEL    β”‚                                         β”‚
β”‚                         β”‚  ─────────────────  β”‚                                         β”‚
β”‚                         β”‚  β€’ AggregateRoot    β”‚                                         β”‚
β”‚                         β”‚  β€’ DomainEvent      β”‚                                         β”‚
β”‚                         β”‚  β€’ Money            β”‚                                         β”‚
β”‚                         β”‚  β€’ EmailAddress     β”‚                                         β”‚
β”‚                         β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜                                         β”‚
β”‚                                    β”‚                                                    β”‚
β”‚          β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”Όβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”                         β”‚
β”‚          β”‚                         β”‚                         β”‚                         β”‚
β”‚          β–Ό                         β–Ό                         β–Ό                         β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”        β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”        β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”                   β”‚
β”‚  β”‚   CATALOG     β”‚        β”‚    PATRON     β”‚        β”‚   LENDING     β”‚                   β”‚
β”‚  β”‚   CONTEXT     β”‚        β”‚   CONTEXT     β”‚        β”‚   CONTEXT     β”‚                   β”‚
β”‚  β”‚               β”‚        β”‚               β”‚        β”‚               β”‚                   β”‚
β”‚  β”‚ Team: 3 devs  β”‚        β”‚ Team: 2 devs  β”‚        β”‚ Team: 5 devs  β”‚                   β”‚
β”‚  β”‚               β”‚        β”‚               β”‚        β”‚  (CORE)       β”‚                   β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”€β”€β”˜        β””β”€β”€β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”€β”€β”˜        β””β”€β”€β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”€β”€β”˜                   β”‚
β”‚          β”‚                        β”‚                        β”‚                           β”‚
β”‚          β”‚                        β”‚                        β”‚                           β”‚
β”‚          β”‚    Published           β”‚   Customer             β”‚                           β”‚
β”‚          β”‚    Language            β”‚   Supplier             β”‚                           β”‚
β”‚          β”‚         β”‚              β”‚      β”‚                 β”‚                           β”‚
β”‚          β”‚         β–Ό              β–Ό      β”‚                 β”‚                           β”‚
β”‚          β”‚    β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”    β”‚                 β”‚                           β”‚
β”‚          └───▢│      LENDING        β”‚β—€β”€β”€β”€β”˜                 β”‚                           β”‚
β”‚               β”‚      CONTEXT        β”‚                      β”‚                           β”‚
β”‚               β”‚                     β”‚                      β”‚                           β”‚
β”‚               β”‚  Subscribes to:     β”‚                      β”‚                           β”‚
β”‚               β”‚  β€’ BookAddedToCatalog                      β”‚                           β”‚
β”‚               β”‚                     β”‚                      β”‚                           β”‚
β”‚               β”‚  Queries:           β”‚                      β”‚                           β”‚
β”‚               β”‚  β€’ PatronBorrowProfile                     β”‚                           β”‚
β”‚               β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜                      β”‚                           β”‚
β”‚                          β”‚                                 β”‚                           β”‚
β”‚                          β”‚ Customer-Supplier               β”‚                           β”‚
β”‚                          β”‚ (Events)                        β”‚                           β”‚
β”‚                          β”‚                                 β”‚                           β”‚
β”‚                          β–Ό                                 β”‚                           β”‚
β”‚               β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”                      β”‚                           β”‚
β”‚               β”‚      FINES          β”‚                      β”‚                           β”‚
β”‚               β”‚      CONTEXT        β”‚                      β”‚                           β”‚
β”‚               β”‚                     β”‚                      β”‚                           β”‚
β”‚               β”‚  Subscribes to:     β”‚                      β”‚                           β”‚
β”‚               β”‚  β€’ LoanBecameOverdueβ”‚                      β”‚                           β”‚
β”‚               β”‚  β€’ BookReturned     β”‚                      β”‚                           β”‚
β”‚               β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜                      β”‚                           β”‚
β”‚                          β”‚                                 β”‚                           β”‚
β”‚                          β”‚ ACL                             β”‚                           β”‚
β”‚                          β”‚                                 β”‚                           β”‚
β”‚                          β–Ό                                 β”‚                           β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”   β”‚
β”‚  β”‚                           EXTERNAL SYSTEMS                                       β”‚   β”‚
β”‚  β”‚                                                                                  β”‚   β”‚
β”‚  β”‚   β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”      β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”      β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”      β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”    β”‚   β”‚
β”‚  β”‚   β”‚  Payment   β”‚      β”‚   Email    β”‚      β”‚  Identity  β”‚      β”‚   Search   β”‚    β”‚   β”‚
β”‚  β”‚   β”‚  Gateway   β”‚      β”‚  Service   β”‚      β”‚  Provider  β”‚      β”‚   Engine   β”‚    β”‚   β”‚
β”‚  β”‚   β”‚  (Stripe)  β”‚      β”‚ (SendGrid) β”‚      β”‚  (Auth0)   β”‚      β”‚(Elasticsearch)  β”‚   β”‚
β”‚  β”‚   β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜      β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜      β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜      β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜    β”‚   β”‚
β”‚  β”‚                                                                                  β”‚   β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜   β”‚
β”‚                                                                                          β”‚
β”‚  LEGEND:                                                                                β”‚
β”‚  ────────────────────────────────────────────────────────────────────────────────────   β”‚
β”‚                                                                                          β”‚
β”‚  ─────▢  Published Language (documented events/API)                                     β”‚
β”‚  ─ ─ ─▢  Customer-Supplier (downstream depends on upstream)                             β”‚
β”‚  ══════▢  ACL (translation layer to external system)                                    β”‚
β”‚  [SK]    Shared Kernel (shared code ownership)                                          β”‚
β”‚                                                                                          β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

Summary: Key Artifacts Checklist

Artifact Purpose Created
Domain Events List All events in the system βœ…
Event Timeline Temporal flow of events βœ…
Process Flows Command β†’ Aggregate β†’ Event βœ…
Aggregate Diagrams Internal structure + invariants βœ…
Domain Model Relationships between aggregates βœ…
Context Map Bounded context relationships βœ…
Ubiquitous Language Glossary of terms βœ… (separate doc)

How to Use These Artifacts

  1. Onboarding: New team members read through to understand the domain
  2. Design Sessions: Reference during feature planning
  3. Code Reviews: Verify implementation matches model
  4. Refactoring: Identify where boundaries should change
  5. Communication: Share with stakeholders to validate understanding