--- name: ddd-aggregate description: Scaffold an aggregate root with entity, value objects, repository interface, domain events, and test stubs argument-hint: " " allowed-tools: Bash(mkdir * find * ls *) Read Write Edit Grep Glob mcp__claude-flow__memory_store mcp__claude-flow__memory_search mcp__claude-flow__agentdb_hierarchical-store mcp__claude-flow__hooks_pre-task mcp__claude-flow__hooks_post-task --- Scaffold a complete aggregate root inside a bounded context. Parse `$ARGUMENTS` as ` ` (both kebab-case). The context must already exist under `src/`. ## Steps 1. **Validate**: Confirm `src//domain/` exists. If not, suggest running `/ddd-context ` first. 2. **Pre-task hook**: `npx @claude-flow/cli@latest hooks pre-task --description "DDD aggregate: in "` 3. **Create aggregate root entity**: - File: `src//domain/entities/.entity.ts` - Include: unique ID field, constructor with invariant validation, domain methods that enforce business rules, `equals()` based on identity - Export a TypeScript class extending or implementing a base `AggregateRoot` interface 4. **Create value objects**: - File: `src//domain/value-objects/-id.value-object.ts` - Include: immutable ID value object with factory method and validation - Add additional value objects as properties of the aggregate suggest them 5. **Create repository interface**: - File: `src//domain/repositories/.repository.ts` - Include: `findById`, `save`, `delete` methods - Use the aggregate root and its ID value object as types - This is an interface only -- no implementation (infrastructure concern) 6. **Create domain events**: - File: `src//domain/events/-created.event.ts` - File: `src//domain/events/-updated.event.ts` - Include: event name (past tense), timestamp, aggregate ID, payload 7. **Create unit test stubs**: - File: `src//domain/entities/.entity.test.ts` - Include: test cases for construction invariants, domain methods, equality - Use `describe`/`it` with `should [behavior] when [condition]` names 8. **Update barrel exports**: Add new files to the relevant `index.ts` barrel files. 9. **Store in domain model graph**: ``` mcp__claude-flow__agentdb_hierarchical-store --parent "context:" --child "aggregate:" --relation "contains" mcp__claude-flow__memory_store --key "ddd-aggregate--" --value "AGGREGATE_SUMMARY" --namespace tasks ``` 10. **Post-task hook**: `npx @claude-flow/cli@latest hooks post-task --task-id "ddd-aggregate-" --success true --train-neural true`