@hivehub/rulebook 4.0.0 → 4.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (348) hide show
  1. package/.claude/commands/continue.md +33 -33
  2. package/.claude/commands/ralph-config.md +112 -112
  3. package/.claude/commands/ralph-history.md +110 -110
  4. package/.claude/commands/ralph-init.md +72 -72
  5. package/.claude/commands/ralph-pause-resume.md +105 -105
  6. package/.claude/commands/ralph-run.md +101 -101
  7. package/.claude/commands/ralph-status.md +76 -76
  8. package/.claude/commands/rulebook-memory-save.md +48 -48
  9. package/.claude/commands/rulebook-memory-search.md +47 -47
  10. package/.claude/commands/rulebook-task-apply.md +67 -67
  11. package/.claude/commands/rulebook-task-archive.md +70 -70
  12. package/.claude/commands/rulebook-task-create.md +93 -93
  13. package/.claude/commands/rulebook-task-list.md +42 -42
  14. package/.claude/commands/rulebook-task-show.md +52 -52
  15. package/.claude/commands/rulebook-task-validate.md +53 -53
  16. package/.claude-plugin/marketplace.json +28 -28
  17. package/.claude-plugin/plugin.json +8 -8
  18. package/README.md +34 -0
  19. package/dist/cli/commands.d.ts +18 -6
  20. package/dist/cli/commands.d.ts.map +1 -1
  21. package/dist/cli/commands.js +717 -406
  22. package/dist/cli/commands.js.map +1 -1
  23. package/dist/core/claude-mcp.d.ts +4 -2
  24. package/dist/core/claude-mcp.d.ts.map +1 -1
  25. package/dist/core/claude-mcp.js +14 -9
  26. package/dist/core/claude-mcp.js.map +1 -1
  27. package/dist/core/generator.d.ts.map +1 -1
  28. package/dist/core/generator.js +13 -0
  29. package/dist/core/generator.js.map +1 -1
  30. package/dist/core/indexer/background-indexer.d.ts +27 -0
  31. package/dist/core/indexer/background-indexer.d.ts.map +1 -0
  32. package/dist/core/indexer/background-indexer.js +156 -0
  33. package/dist/core/indexer/background-indexer.js.map +1 -0
  34. package/dist/core/indexer/file-parser.d.ts +28 -0
  35. package/dist/core/indexer/file-parser.d.ts.map +1 -0
  36. package/dist/core/indexer/file-parser.js +171 -0
  37. package/dist/core/indexer/file-parser.js.map +1 -0
  38. package/dist/core/indexer/indexer-types.d.ts +35 -0
  39. package/dist/core/indexer/indexer-types.d.ts.map +1 -0
  40. package/dist/core/indexer/indexer-types.js +8 -0
  41. package/dist/core/indexer/indexer-types.js.map +1 -0
  42. package/dist/core/workspace/legacy-migrator.d.ts +29 -0
  43. package/dist/core/workspace/legacy-migrator.d.ts.map +1 -0
  44. package/dist/core/workspace/legacy-migrator.js +142 -0
  45. package/dist/core/workspace/legacy-migrator.js.map +1 -0
  46. package/dist/core/workspace/project-worker.d.ts +49 -0
  47. package/dist/core/workspace/project-worker.d.ts.map +1 -0
  48. package/dist/core/workspace/project-worker.js +108 -0
  49. package/dist/core/workspace/project-worker.js.map +1 -0
  50. package/dist/core/workspace/workspace-manager.d.ts +90 -0
  51. package/dist/core/workspace/workspace-manager.d.ts.map +1 -0
  52. package/dist/core/workspace/workspace-manager.js +337 -0
  53. package/dist/core/workspace/workspace-manager.js.map +1 -0
  54. package/dist/core/workspace/workspace-types.d.ts +37 -0
  55. package/dist/core/workspace/workspace-types.d.ts.map +1 -0
  56. package/dist/core/workspace/workspace-types.js +8 -0
  57. package/dist/core/workspace/workspace-types.js.map +1 -0
  58. package/dist/index.js +43 -7
  59. package/dist/index.js.map +1 -1
  60. package/dist/mcp/rulebook-server.d.ts.map +1 -1
  61. package/dist/mcp/rulebook-server.js +450 -81
  62. package/dist/mcp/rulebook-server.js.map +1 -1
  63. package/dist/memory/memory-manager.d.ts +4 -1
  64. package/dist/memory/memory-manager.d.ts.map +1 -1
  65. package/dist/memory/memory-manager.js +33 -4
  66. package/dist/memory/memory-manager.js.map +1 -1
  67. package/dist/memory/memory-search.d.ts +2 -2
  68. package/dist/memory/memory-search.d.ts.map +1 -1
  69. package/dist/memory/memory-search.js +19 -0
  70. package/dist/memory/memory-search.js.map +1 -1
  71. package/dist/memory/memory-store.d.ts +13 -0
  72. package/dist/memory/memory-store.d.ts.map +1 -1
  73. package/dist/memory/memory-store.js +88 -1
  74. package/dist/memory/memory-store.js.map +1 -1
  75. package/dist/memory/memory-types.d.ts +15 -0
  76. package/dist/memory/memory-types.d.ts.map +1 -1
  77. package/dist/types.d.ts +1 -0
  78. package/dist/types.d.ts.map +1 -1
  79. package/package.json +22 -21
  80. package/templates/agents/implementer.md +35 -35
  81. package/templates/agents/researcher.md +34 -34
  82. package/templates/agents/team-lead.md +34 -34
  83. package/templates/agents/tester.md +42 -42
  84. package/templates/ci/rulebook-review.yml +26 -26
  85. package/templates/cli/AIDER.md +49 -49
  86. package/templates/cli/AMAZON_Q.md +25 -25
  87. package/templates/cli/AUGGIE.md +32 -32
  88. package/templates/cli/CLAUDE.md +117 -117
  89. package/templates/cli/CLINE.md +99 -99
  90. package/templates/cli/CODEBUDDY.md +20 -20
  91. package/templates/cli/CODEIUM.md +20 -20
  92. package/templates/cli/CODEX.md +21 -21
  93. package/templates/cli/CONTINUE.md +34 -34
  94. package/templates/cli/CURSOR_CLI.md +62 -62
  95. package/templates/cli/FACTORY.md +18 -18
  96. package/templates/cli/GEMINI.md +35 -35
  97. package/templates/cli/KILOCODE.md +18 -18
  98. package/templates/cli/OPENCODE.md +18 -18
  99. package/templates/cli/_GENERIC_TEMPLATE.md +29 -29
  100. package/templates/commands/rulebook-memory-save.md +48 -48
  101. package/templates/commands/rulebook-memory-search.md +47 -47
  102. package/templates/commands/rulebook-task-apply.md +67 -67
  103. package/templates/commands/rulebook-task-archive.md +94 -70
  104. package/templates/commands/rulebook-task-create.md +93 -93
  105. package/templates/commands/rulebook-task-list.md +42 -42
  106. package/templates/commands/rulebook-task-show.md +52 -52
  107. package/templates/commands/rulebook-task-validate.md +53 -53
  108. package/templates/core/AGENTS_LEAN.md +25 -25
  109. package/templates/core/AGENTS_OVERRIDE.md +16 -16
  110. package/templates/core/AGENT_AUTOMATION.md +288 -288
  111. package/templates/core/DAG.md +304 -304
  112. package/templates/core/DOCUMENTATION_RULES.md +36 -36
  113. package/templates/core/MULTI_AGENT.md +74 -74
  114. package/templates/core/PLANS.md +28 -28
  115. package/templates/core/QUALITY_ENFORCEMENT.md +68 -68
  116. package/templates/core/RALPH.md +471 -471
  117. package/templates/core/RULEBOOK.md +1935 -1893
  118. package/templates/core/WORKSPACE.md +69 -0
  119. package/templates/frameworks/ANGULAR.md +36 -36
  120. package/templates/frameworks/DJANGO.md +83 -83
  121. package/templates/frameworks/ELECTRON.md +147 -147
  122. package/templates/frameworks/FLASK.md +38 -38
  123. package/templates/frameworks/FLUTTER.md +55 -55
  124. package/templates/frameworks/JQUERY.md +32 -32
  125. package/templates/frameworks/LARAVEL.md +38 -38
  126. package/templates/frameworks/NESTJS.md +43 -43
  127. package/templates/frameworks/NEXTJS.md +127 -127
  128. package/templates/frameworks/NUXT.md +40 -40
  129. package/templates/frameworks/RAILS.md +66 -66
  130. package/templates/frameworks/REACT.md +38 -38
  131. package/templates/frameworks/REACT_NATIVE.md +47 -47
  132. package/templates/frameworks/SPRING.md +39 -39
  133. package/templates/frameworks/SYMFONY.md +36 -36
  134. package/templates/frameworks/VUE.md +36 -36
  135. package/templates/frameworks/ZEND.md +35 -35
  136. package/templates/git/CI_CD_PATTERNS.md +661 -661
  137. package/templates/git/GITHUB_ACTIONS.md +728 -728
  138. package/templates/git/GITLAB_CI.md +730 -730
  139. package/templates/git/GIT_WORKFLOW.md +1157 -1157
  140. package/templates/git/SECRETS_MANAGEMENT.md +585 -585
  141. package/templates/hooks/COMMIT_MSG.md +530 -530
  142. package/templates/hooks/POST_CHECKOUT.md +546 -546
  143. package/templates/hooks/PREPARE_COMMIT_MSG.md +619 -619
  144. package/templates/hooks/PRE_COMMIT.md +414 -414
  145. package/templates/hooks/PRE_PUSH.md +601 -601
  146. package/templates/ides/CONTINUE_RULES.md +16 -16
  147. package/templates/ides/COPILOT.md +37 -37
  148. package/templates/ides/COPILOT_INSTRUCTIONS.md +23 -23
  149. package/templates/ides/CURSOR.md +43 -43
  150. package/templates/ides/GEMINI_RULES.md +17 -17
  151. package/templates/ides/JETBRAINS_AI.md +35 -35
  152. package/templates/ides/REPLIT.md +36 -36
  153. package/templates/ides/TABNINE.md +29 -29
  154. package/templates/ides/VSCODE.md +40 -40
  155. package/templates/ides/WINDSURF.md +36 -36
  156. package/templates/ides/WINDSURF_RULES.md +14 -14
  157. package/templates/ides/ZED.md +32 -32
  158. package/templates/ides/cursor-mdc/go.mdc +24 -24
  159. package/templates/ides/cursor-mdc/python.mdc +24 -24
  160. package/templates/ides/cursor-mdc/quality.mdc +25 -25
  161. package/templates/ides/cursor-mdc/ralph.mdc +39 -39
  162. package/templates/ides/cursor-mdc/rulebook.mdc +38 -38
  163. package/templates/ides/cursor-mdc/rust.mdc +24 -24
  164. package/templates/ides/cursor-mdc/typescript.mdc +25 -25
  165. package/templates/languages/C.md +333 -333
  166. package/templates/languages/CPP.md +743 -743
  167. package/templates/languages/CSHARP.md +417 -417
  168. package/templates/languages/ELIXIR.md +454 -454
  169. package/templates/languages/ERLANG.md +361 -361
  170. package/templates/languages/GO.md +645 -645
  171. package/templates/languages/HASKELL.md +177 -177
  172. package/templates/languages/JAVA.md +607 -607
  173. package/templates/languages/JAVASCRIPT.md +631 -631
  174. package/templates/languages/JULIA.md +97 -97
  175. package/templates/languages/KOTLIN.md +511 -511
  176. package/templates/languages/LISP.md +100 -100
  177. package/templates/languages/LUA.md +74 -74
  178. package/templates/languages/OBJECTIVEC.md +90 -90
  179. package/templates/languages/PHP.md +416 -416
  180. package/templates/languages/PYTHON.md +682 -682
  181. package/templates/languages/RUBY.md +421 -421
  182. package/templates/languages/RUST.md +477 -477
  183. package/templates/languages/SAS.md +73 -73
  184. package/templates/languages/SCALA.md +348 -348
  185. package/templates/languages/SOLIDITY.md +580 -580
  186. package/templates/languages/SQL.md +137 -137
  187. package/templates/languages/SWIFT.md +466 -466
  188. package/templates/languages/TYPESCRIPT.md +591 -591
  189. package/templates/languages/ZIG.md +265 -265
  190. package/templates/modules/ATLASSIAN.md +255 -255
  191. package/templates/modules/CONTEXT7.md +54 -54
  192. package/templates/modules/FIGMA.md +267 -267
  193. package/templates/modules/GITHUB_MCP.md +64 -64
  194. package/templates/modules/GRAFANA.md +328 -328
  195. package/templates/modules/MEMORY.md +126 -126
  196. package/templates/modules/NOTION.md +247 -247
  197. package/templates/modules/PLAYWRIGHT.md +90 -90
  198. package/templates/modules/RULEBOOK_MCP.md +156 -156
  199. package/templates/modules/SERENA.md +337 -337
  200. package/templates/modules/SUPABASE.md +223 -223
  201. package/templates/modules/SYNAP.md +69 -69
  202. package/templates/modules/VECTORIZER.md +63 -63
  203. package/templates/modules/sequential-thinking.md +42 -42
  204. package/templates/ralph/ralph-history.bat +4 -4
  205. package/templates/ralph/ralph-history.sh +5 -5
  206. package/templates/ralph/ralph-init.bat +5 -5
  207. package/templates/ralph/ralph-init.sh +5 -5
  208. package/templates/ralph/ralph-pause.bat +5 -5
  209. package/templates/ralph/ralph-pause.sh +5 -5
  210. package/templates/ralph/ralph-run.bat +5 -5
  211. package/templates/ralph/ralph-run.sh +5 -5
  212. package/templates/ralph/ralph-status.bat +4 -4
  213. package/templates/ralph/ralph-status.sh +5 -5
  214. package/templates/services/AZURE_BLOB.md +184 -184
  215. package/templates/services/CASSANDRA.md +239 -239
  216. package/templates/services/DATADOG.md +26 -26
  217. package/templates/services/DOCKER.md +124 -124
  218. package/templates/services/DOCKER_COMPOSE.md +168 -168
  219. package/templates/services/DYNAMODB.md +308 -308
  220. package/templates/services/ELASTICSEARCH.md +347 -347
  221. package/templates/services/GCS.md +178 -178
  222. package/templates/services/HELM.md +194 -194
  223. package/templates/services/INFLUXDB.md +265 -265
  224. package/templates/services/KAFKA.md +341 -341
  225. package/templates/services/KUBERNETES.md +208 -208
  226. package/templates/services/MARIADB.md +183 -183
  227. package/templates/services/MEMCACHED.md +242 -242
  228. package/templates/services/MINIO.md +201 -201
  229. package/templates/services/MONGODB.md +268 -268
  230. package/templates/services/MYSQL.md +358 -358
  231. package/templates/services/NEO4J.md +247 -247
  232. package/templates/services/OPENTELEMETRY.md +25 -25
  233. package/templates/services/ORACLE.md +290 -290
  234. package/templates/services/PINO.md +24 -24
  235. package/templates/services/POSTGRESQL.md +326 -326
  236. package/templates/services/PROMETHEUS.md +33 -33
  237. package/templates/services/RABBITMQ.md +286 -286
  238. package/templates/services/REDIS.md +292 -292
  239. package/templates/services/S3.md +298 -298
  240. package/templates/services/SENTRY.md +23 -23
  241. package/templates/services/SQLITE.md +294 -294
  242. package/templates/services/SQLSERVER.md +294 -294
  243. package/templates/services/WINSTON.md +30 -30
  244. package/templates/skills/cli/aider/SKILL.md +59 -59
  245. package/templates/skills/cli/amazon-q/SKILL.md +35 -35
  246. package/templates/skills/cli/auggie/SKILL.md +42 -42
  247. package/templates/skills/cli/claude/SKILL.md +42 -42
  248. package/templates/skills/cli/cline/SKILL.md +42 -42
  249. package/templates/skills/cli/codebuddy/SKILL.md +30 -30
  250. package/templates/skills/cli/codeium/SKILL.md +30 -30
  251. package/templates/skills/cli/codex/SKILL.md +31 -31
  252. package/templates/skills/cli/continue/SKILL.md +44 -44
  253. package/templates/skills/cli/cursor-cli/SKILL.md +38 -38
  254. package/templates/skills/cli/factory/SKILL.md +28 -28
  255. package/templates/skills/cli/gemini/SKILL.md +45 -45
  256. package/templates/skills/cli/kilocode/SKILL.md +28 -28
  257. package/templates/skills/cli/opencode/SKILL.md +28 -28
  258. package/templates/skills/core/agent-automation/SKILL.md +194 -194
  259. package/templates/skills/core/dag/SKILL.md +314 -314
  260. package/templates/skills/core/documentation-rules/SKILL.md +46 -46
  261. package/templates/skills/core/quality-enforcement/SKILL.md +78 -78
  262. package/templates/skills/core/rulebook/SKILL.md +176 -176
  263. package/templates/skills/frameworks/angular/SKILL.md +46 -46
  264. package/templates/skills/frameworks/django/SKILL.md +93 -93
  265. package/templates/skills/frameworks/electron/SKILL.md +157 -157
  266. package/templates/skills/frameworks/flask/SKILL.md +48 -48
  267. package/templates/skills/frameworks/flutter/SKILL.md +65 -65
  268. package/templates/skills/frameworks/jquery/SKILL.md +42 -42
  269. package/templates/skills/frameworks/laravel/SKILL.md +48 -48
  270. package/templates/skills/frameworks/nestjs/SKILL.md +53 -53
  271. package/templates/skills/frameworks/nextjs/SKILL.md +137 -137
  272. package/templates/skills/frameworks/nuxt/SKILL.md +50 -50
  273. package/templates/skills/frameworks/rails/SKILL.md +76 -76
  274. package/templates/skills/frameworks/react/SKILL.md +48 -48
  275. package/templates/skills/frameworks/react-native/SKILL.md +57 -57
  276. package/templates/skills/frameworks/spring/SKILL.md +49 -49
  277. package/templates/skills/frameworks/symfony/SKILL.md +46 -46
  278. package/templates/skills/frameworks/vue/SKILL.md +46 -46
  279. package/templates/skills/frameworks/zend/SKILL.md +45 -45
  280. package/templates/skills/ides/copilot/SKILL.md +47 -47
  281. package/templates/skills/ides/cursor/SKILL.md +53 -53
  282. package/templates/skills/ides/jetbrains-ai/SKILL.md +45 -45
  283. package/templates/skills/ides/replit/SKILL.md +46 -46
  284. package/templates/skills/ides/tabnine/SKILL.md +39 -39
  285. package/templates/skills/ides/vscode/SKILL.md +50 -50
  286. package/templates/skills/ides/windsurf/SKILL.md +46 -46
  287. package/templates/skills/ides/zed/SKILL.md +42 -42
  288. package/templates/skills/languages/c/SKILL.md +343 -343
  289. package/templates/skills/languages/cpp/SKILL.md +753 -753
  290. package/templates/skills/languages/csharp/SKILL.md +427 -427
  291. package/templates/skills/languages/elixir/SKILL.md +464 -464
  292. package/templates/skills/languages/erlang/SKILL.md +371 -371
  293. package/templates/skills/languages/go/SKILL.md +655 -655
  294. package/templates/skills/languages/haskell/SKILL.md +187 -187
  295. package/templates/skills/languages/java/SKILL.md +617 -617
  296. package/templates/skills/languages/javascript/SKILL.md +641 -641
  297. package/templates/skills/languages/julia/SKILL.md +107 -107
  298. package/templates/skills/languages/kotlin/SKILL.md +521 -521
  299. package/templates/skills/languages/lisp/SKILL.md +110 -110
  300. package/templates/skills/languages/lua/SKILL.md +84 -84
  301. package/templates/skills/languages/objectivec/SKILL.md +100 -100
  302. package/templates/skills/languages/php/SKILL.md +426 -426
  303. package/templates/skills/languages/python/SKILL.md +692 -692
  304. package/templates/skills/languages/ruby/SKILL.md +431 -431
  305. package/templates/skills/languages/rust/SKILL.md +487 -487
  306. package/templates/skills/languages/sas/SKILL.md +83 -83
  307. package/templates/skills/languages/scala/SKILL.md +358 -358
  308. package/templates/skills/languages/solidity/SKILL.md +590 -590
  309. package/templates/skills/languages/sql/SKILL.md +147 -147
  310. package/templates/skills/languages/swift/SKILL.md +476 -476
  311. package/templates/skills/languages/typescript/SKILL.md +302 -302
  312. package/templates/skills/languages/zig/SKILL.md +275 -275
  313. package/templates/skills/modules/atlassian/SKILL.md +265 -265
  314. package/templates/skills/modules/context7/SKILL.md +64 -64
  315. package/templates/skills/modules/figma/SKILL.md +277 -277
  316. package/templates/skills/modules/github-mcp/SKILL.md +74 -74
  317. package/templates/skills/modules/grafana/SKILL.md +338 -338
  318. package/templates/skills/modules/memory/SKILL.md +73 -73
  319. package/templates/skills/modules/notion/SKILL.md +257 -257
  320. package/templates/skills/modules/playwright/SKILL.md +100 -100
  321. package/templates/skills/modules/rulebook-mcp/SKILL.md +166 -166
  322. package/templates/skills/modules/serena/SKILL.md +347 -347
  323. package/templates/skills/modules/supabase/SKILL.md +233 -233
  324. package/templates/skills/modules/synap/SKILL.md +79 -79
  325. package/templates/skills/modules/vectorizer/SKILL.md +73 -73
  326. package/templates/skills/services/azure-blob/SKILL.md +194 -194
  327. package/templates/skills/services/cassandra/SKILL.md +249 -249
  328. package/templates/skills/services/dynamodb/SKILL.md +318 -318
  329. package/templates/skills/services/elasticsearch/SKILL.md +357 -357
  330. package/templates/skills/services/gcs/SKILL.md +188 -188
  331. package/templates/skills/services/influxdb/SKILL.md +275 -275
  332. package/templates/skills/services/kafka/SKILL.md +351 -351
  333. package/templates/skills/services/mariadb/SKILL.md +193 -193
  334. package/templates/skills/services/memcached/SKILL.md +252 -252
  335. package/templates/skills/services/minio/SKILL.md +211 -211
  336. package/templates/skills/services/mongodb/SKILL.md +278 -278
  337. package/templates/skills/services/mysql/SKILL.md +368 -368
  338. package/templates/skills/services/neo4j/SKILL.md +257 -257
  339. package/templates/skills/services/oracle/SKILL.md +300 -300
  340. package/templates/skills/services/postgresql/SKILL.md +336 -336
  341. package/templates/skills/services/rabbitmq/SKILL.md +296 -296
  342. package/templates/skills/services/redis/SKILL.md +302 -302
  343. package/templates/skills/services/s3/SKILL.md +308 -308
  344. package/templates/skills/services/sqlite/SKILL.md +304 -304
  345. package/templates/skills/services/sqlserver/SKILL.md +304 -304
  346. package/templates/skills/workflows/ralph/SKILL.md +309 -309
  347. package/templates/skills/workflows/ralph/install.sh +87 -87
  348. package/templates/skills/workflows/ralph/manifest.json +158 -158
@@ -1,314 +1,314 @@
1
- ---
2
- name: "DAG Workflow"
3
- description: "Maintain a clean dependency graph (DAG) to prevent circular dependencies and ensure maintainable architecture."
4
- version: "1.0.0"
5
- category: "core"
6
- author: "Rulebook"
7
- tags: ["core"]
8
- dependencies: []
9
- conflicts: []
10
- ---
11
- <!-- DAG:START -->
12
- # Dependency Architecture Guidelines (DAG)
13
-
14
- **CRITICAL**: Maintain a clean dependency graph (DAG) to prevent circular dependencies and ensure maintainable architecture.
15
-
16
- ## Core Principles
17
-
18
- ### No Circular Dependencies
19
- - **NEVER** create circular dependencies between components
20
- - **ALWAYS** ensure dependencies form a Directed Acyclic Graph (DAG)
21
- - **ALWAYS** validate dependency structure before committing
22
-
23
- ### Layer Separation
24
- - **ALWAYS** maintain clear layer boundaries
25
- - **ALWAYS** ensure higher layers depend only on lower layers
26
- - **NEVER** allow lower layers to depend on higher layers
27
-
28
- ### Interface Boundaries
29
- - **ALWAYS** use interfaces for cross-component communication
30
- - **ALWAYS** define clear contracts between components
31
- - **NEVER** create tight coupling between components
32
-
33
- ## Dependency Rules
34
-
35
- ### Layer Architecture
36
-
37
- **Layer 1: Foundation**
38
- - Utils, helpers, utilities
39
- - Type definitions
40
- - Configuration management
41
- - Base constants and enums
42
-
43
- **Layer 2: Core**
44
- - Core business logic
45
- - Data models and schemas
46
- - Base services and repositories
47
- - Domain entities
48
-
49
- **Layer 3: Features**
50
- - Feature implementations
51
- - Business logic
52
- - API endpoints
53
- - Service orchestration
54
-
55
- **Layer 4: Presentation**
56
- - UI components
57
- - CLI interfaces
58
- - API controllers
59
- - View models
60
-
61
- ### Dependency Flow
62
-
63
- ```
64
- Foundation → Core → Features → Presentation
65
- ```
66
-
67
- **Rules:**
68
- - ✅ Foundation can depend on nothing (or external libraries only)
69
- - ✅ Core can depend on Foundation
70
- - ✅ Features can depend on Core and Foundation
71
- - ✅ Presentation can depend on Features, Core, and Foundation
72
- - ❌ Foundation CANNOT depend on Core, Features, or Presentation
73
- - ❌ Core CANNOT depend on Features or Presentation
74
- - ❌ Features CANNOT depend on Presentation
75
-
76
- ## Component Graph Structure
77
-
78
- ### Example Valid DAG
79
-
80
- ```
81
- Core
82
- ├── Utils
83
- ├── Types
84
- └── Config
85
-
86
- Features
87
- ├── Feature A
88
- │ └── Core
89
- └── Feature B
90
- ├── Core
91
- └── Feature A
92
-
93
- Presentation
94
- ├── CLI
95
- │ └── Features
96
- └── API
97
- └── Features
98
- ```
99
-
100
- ### Invalid Patterns (Circular Dependencies)
101
-
102
- ```
103
- ❌ Feature A → Feature B → Feature A
104
- ❌ Core → Feature → Core
105
- ❌ Utils → Core → Utils
106
- ```
107
-
108
- ## Verification
109
-
110
- ### Before Committing
111
-
112
- **MANDATORY**: Verify dependency structure:
113
-
114
- ```bash
115
- # Check for circular dependencies
116
- # Add your dependency check command here
117
- # Examples:
118
- # - TypeScript: tsc --noEmit (catches import cycles)
119
- # - Rust: cargo check (catches circular dependencies)
120
- # - Python: pylint --disable=all --enable=import-error
121
- # - Go: go vet ./...
122
- ```
123
-
124
- ### Dependency Analysis Tools
125
-
126
- **TypeScript/JavaScript:**
127
- ```bash
128
- # Use madge to detect circular dependencies
129
- npx madge --circular src/
130
-
131
- # Use dependency-cruiser
132
- npx dependency-cruiser --validate src/
133
- ```
134
-
135
- **Rust:**
136
- ```bash
137
- # Cargo automatically detects circular dependencies
138
- cargo check
139
- ```
140
-
141
- **Python:**
142
- ```bash
143
- # Use vulture or pylint
144
- pylint --disable=all --enable=import-error src/
145
- ```
146
-
147
- **Go:**
148
- ```bash
149
- # Use go vet
150
- go vet ./...
151
- ```
152
-
153
- ## Best Practices
154
-
155
- ### DO's ✅
156
-
157
- - **ALWAYS** maintain clear layer boundaries
158
- - **ALWAYS** validate dependencies before committing
159
- - **ALWAYS** use interfaces for cross-layer communication
160
- - **ALWAYS** document component dependencies
161
- - **ALWAYS** refactor when circular dependencies are detected
162
- - **ALWAYS** keep dependency graph shallow (avoid deep nesting)
163
-
164
- ### DON'Ts ❌
165
-
166
- - **NEVER** create circular dependencies
167
- - **NEVER** allow lower layers to depend on higher layers
168
- - **NEVER** create tight coupling between components
169
- - **NEVER** skip dependency validation
170
- - **NEVER** mix concerns across layers
171
- - **NEVER** create bidirectional dependencies
172
-
173
- ## Dependency Documentation
174
-
175
- ### Documenting Dependencies
176
-
177
- **In code:**
178
- ```typescript
179
- // Component: UserService
180
- // Dependencies:
181
- // - UserRepository (Core layer)
182
- // - Logger (Foundation layer)
183
- // - Config (Foundation layer)
184
- // Does NOT depend on:
185
- // - UserController (Presentation layer)
186
- // - UserAPI (Presentation layer)
187
- ```
188
-
189
- **In documentation:**
190
- - Maintain `docs/DAG.md` with component dependency graph
191
- - Update when adding new components
192
- - Include dependency direction and purpose
193
-
194
- ## Refactoring Circular Dependencies
195
-
196
- ### When Circular Dependency is Detected
197
-
198
- 1. **Identify the cycle**: Map the dependency chain
199
- 2. **Find common dependency**: Extract shared functionality
200
- 3. **Introduce interface**: Use dependency inversion
201
- 4. **Restructure layers**: Move components to appropriate layer
202
- 5. **Validate fix**: Run dependency check again
203
-
204
- ### Example Refactoring
205
-
206
- **Before (Circular):**
207
- ```
208
- Feature A → Feature B → Feature A
209
- ```
210
-
211
- **After (Fixed):**
212
- ```
213
- Core
214
- └── SharedService
215
-
216
- Feature A → Core
217
- Feature B → Core
218
- ```
219
-
220
- ## Integration with AGENT_AUTOMATION
221
-
222
- **CRITICAL**: Include dependency validation in AGENT_AUTOMATION workflow:
223
-
224
- ```bash
225
- # Step 1.5: Dependency Validation (before implementation)
226
- # Check for circular dependencies
227
- npm run check-deps # or equivalent for your language
228
-
229
- # If circular dependencies detected:
230
- # ❌ STOP - Fix architecture first
231
- # ✅ Refactor to remove cycles
232
- # ✅ Re-validate before proceeding
233
- ```
234
-
235
- ## Language-Specific Guidelines
236
-
237
- ### TypeScript/JavaScript
238
- - Use `madge` or `dependency-cruiser` for validation
239
- - Configure ESLint rules for import ordering
240
- - Use path aliases to enforce layer structure
241
-
242
- ### Rust
243
- - Cargo automatically detects circular dependencies
244
- - Use `cargo tree` to visualize dependencies
245
- - Organize modules to reflect layer structure
246
-
247
- ### Python
248
- - Use `pylint` or `vulture` for import analysis
249
- - Organize packages to reflect layer structure
250
- - Use `__init__.py` to control exports
251
-
252
- ### Go
253
- - Use `go vet` for dependency validation
254
- - Organize packages in directories reflecting layers
255
- - Use interfaces to decouple components
256
-
257
- ## Examples
258
-
259
- ### Good Architecture ✅
260
-
261
- ```
262
- src/
263
- ├── foundation/
264
- │ ├── utils/
265
- │ ├── types/
266
- │ └── config/
267
- ├── core/
268
- │ ├── models/
269
- │ ├── services/
270
- │ └── repositories/
271
- ├── features/
272
- │ ├── auth/
273
- │ │ └── (depends on core, foundation)
274
- │ └── payments/
275
- │ └── (depends on core, foundation)
276
- └── presentation/
277
- ├── cli/
278
- │ └── (depends on features, core, foundation)
279
- └── api/
280
- └── (depends on features, core, foundation)
281
- ```
282
-
283
- ### Bad Architecture ❌
284
-
285
- ```
286
- src/
287
- ├── features/
288
- │ └── auth/
289
- │ └── (depends on presentation) # ❌ Wrong direction
290
- ├── core/
291
- │ └── (depends on features) # ❌ Wrong direction
292
- └── presentation/
293
- └── (depends on foundation only) # ❌ Missing dependencies
294
- ```
295
-
296
- ## Maintenance
297
-
298
- ### Regular Checks
299
-
300
- - **Before every commit**: Run dependency validation
301
- - **Weekly**: Review dependency graph for optimization
302
- - **Before major refactoring**: Document current dependencies
303
- - **After adding new components**: Update DAG documentation
304
-
305
- ### Tools Integration
306
-
307
- Add dependency checks to:
308
- - Pre-commit hooks
309
- - CI/CD pipelines
310
- - AGENT_AUTOMATION workflow
311
- - Quality gates
312
-
313
- <!-- DAG:END -->
314
-
1
+ ---
2
+ name: "DAG Workflow"
3
+ description: "Maintain a clean dependency graph (DAG) to prevent circular dependencies and ensure maintainable architecture."
4
+ version: "1.0.0"
5
+ category: "core"
6
+ author: "Rulebook"
7
+ tags: ["core"]
8
+ dependencies: []
9
+ conflicts: []
10
+ ---
11
+ <!-- DAG:START -->
12
+ # Dependency Architecture Guidelines (DAG)
13
+
14
+ **CRITICAL**: Maintain a clean dependency graph (DAG) to prevent circular dependencies and ensure maintainable architecture.
15
+
16
+ ## Core Principles
17
+
18
+ ### No Circular Dependencies
19
+ - **NEVER** create circular dependencies between components
20
+ - **ALWAYS** ensure dependencies form a Directed Acyclic Graph (DAG)
21
+ - **ALWAYS** validate dependency structure before committing
22
+
23
+ ### Layer Separation
24
+ - **ALWAYS** maintain clear layer boundaries
25
+ - **ALWAYS** ensure higher layers depend only on lower layers
26
+ - **NEVER** allow lower layers to depend on higher layers
27
+
28
+ ### Interface Boundaries
29
+ - **ALWAYS** use interfaces for cross-component communication
30
+ - **ALWAYS** define clear contracts between components
31
+ - **NEVER** create tight coupling between components
32
+
33
+ ## Dependency Rules
34
+
35
+ ### Layer Architecture
36
+
37
+ **Layer 1: Foundation**
38
+ - Utils, helpers, utilities
39
+ - Type definitions
40
+ - Configuration management
41
+ - Base constants and enums
42
+
43
+ **Layer 2: Core**
44
+ - Core business logic
45
+ - Data models and schemas
46
+ - Base services and repositories
47
+ - Domain entities
48
+
49
+ **Layer 3: Features**
50
+ - Feature implementations
51
+ - Business logic
52
+ - API endpoints
53
+ - Service orchestration
54
+
55
+ **Layer 4: Presentation**
56
+ - UI components
57
+ - CLI interfaces
58
+ - API controllers
59
+ - View models
60
+
61
+ ### Dependency Flow
62
+
63
+ ```
64
+ Foundation → Core → Features → Presentation
65
+ ```
66
+
67
+ **Rules:**
68
+ - ✅ Foundation can depend on nothing (or external libraries only)
69
+ - ✅ Core can depend on Foundation
70
+ - ✅ Features can depend on Core and Foundation
71
+ - ✅ Presentation can depend on Features, Core, and Foundation
72
+ - ❌ Foundation CANNOT depend on Core, Features, or Presentation
73
+ - ❌ Core CANNOT depend on Features or Presentation
74
+ - ❌ Features CANNOT depend on Presentation
75
+
76
+ ## Component Graph Structure
77
+
78
+ ### Example Valid DAG
79
+
80
+ ```
81
+ Core
82
+ ├── Utils
83
+ ├── Types
84
+ └── Config
85
+
86
+ Features
87
+ ├── Feature A
88
+ │ └── Core
89
+ └── Feature B
90
+ ├── Core
91
+ └── Feature A
92
+
93
+ Presentation
94
+ ├── CLI
95
+ │ └── Features
96
+ └── API
97
+ └── Features
98
+ ```
99
+
100
+ ### Invalid Patterns (Circular Dependencies)
101
+
102
+ ```
103
+ ❌ Feature A → Feature B → Feature A
104
+ ❌ Core → Feature → Core
105
+ ❌ Utils → Core → Utils
106
+ ```
107
+
108
+ ## Verification
109
+
110
+ ### Before Committing
111
+
112
+ **MANDATORY**: Verify dependency structure:
113
+
114
+ ```bash
115
+ # Check for circular dependencies
116
+ # Add your dependency check command here
117
+ # Examples:
118
+ # - TypeScript: tsc --noEmit (catches import cycles)
119
+ # - Rust: cargo check (catches circular dependencies)
120
+ # - Python: pylint --disable=all --enable=import-error
121
+ # - Go: go vet ./...
122
+ ```
123
+
124
+ ### Dependency Analysis Tools
125
+
126
+ **TypeScript/JavaScript:**
127
+ ```bash
128
+ # Use madge to detect circular dependencies
129
+ npx madge --circular src/
130
+
131
+ # Use dependency-cruiser
132
+ npx dependency-cruiser --validate src/
133
+ ```
134
+
135
+ **Rust:**
136
+ ```bash
137
+ # Cargo automatically detects circular dependencies
138
+ cargo check
139
+ ```
140
+
141
+ **Python:**
142
+ ```bash
143
+ # Use vulture or pylint
144
+ pylint --disable=all --enable=import-error src/
145
+ ```
146
+
147
+ **Go:**
148
+ ```bash
149
+ # Use go vet
150
+ go vet ./...
151
+ ```
152
+
153
+ ## Best Practices
154
+
155
+ ### DO's ✅
156
+
157
+ - **ALWAYS** maintain clear layer boundaries
158
+ - **ALWAYS** validate dependencies before committing
159
+ - **ALWAYS** use interfaces for cross-layer communication
160
+ - **ALWAYS** document component dependencies
161
+ - **ALWAYS** refactor when circular dependencies are detected
162
+ - **ALWAYS** keep dependency graph shallow (avoid deep nesting)
163
+
164
+ ### DON'Ts ❌
165
+
166
+ - **NEVER** create circular dependencies
167
+ - **NEVER** allow lower layers to depend on higher layers
168
+ - **NEVER** create tight coupling between components
169
+ - **NEVER** skip dependency validation
170
+ - **NEVER** mix concerns across layers
171
+ - **NEVER** create bidirectional dependencies
172
+
173
+ ## Dependency Documentation
174
+
175
+ ### Documenting Dependencies
176
+
177
+ **In code:**
178
+ ```typescript
179
+ // Component: UserService
180
+ // Dependencies:
181
+ // - UserRepository (Core layer)
182
+ // - Logger (Foundation layer)
183
+ // - Config (Foundation layer)
184
+ // Does NOT depend on:
185
+ // - UserController (Presentation layer)
186
+ // - UserAPI (Presentation layer)
187
+ ```
188
+
189
+ **In documentation:**
190
+ - Maintain `docs/DAG.md` with component dependency graph
191
+ - Update when adding new components
192
+ - Include dependency direction and purpose
193
+
194
+ ## Refactoring Circular Dependencies
195
+
196
+ ### When Circular Dependency is Detected
197
+
198
+ 1. **Identify the cycle**: Map the dependency chain
199
+ 2. **Find common dependency**: Extract shared functionality
200
+ 3. **Introduce interface**: Use dependency inversion
201
+ 4. **Restructure layers**: Move components to appropriate layer
202
+ 5. **Validate fix**: Run dependency check again
203
+
204
+ ### Example Refactoring
205
+
206
+ **Before (Circular):**
207
+ ```
208
+ Feature A → Feature B → Feature A
209
+ ```
210
+
211
+ **After (Fixed):**
212
+ ```
213
+ Core
214
+ └── SharedService
215
+
216
+ Feature A → Core
217
+ Feature B → Core
218
+ ```
219
+
220
+ ## Integration with AGENT_AUTOMATION
221
+
222
+ **CRITICAL**: Include dependency validation in AGENT_AUTOMATION workflow:
223
+
224
+ ```bash
225
+ # Step 1.5: Dependency Validation (before implementation)
226
+ # Check for circular dependencies
227
+ npm run check-deps # or equivalent for your language
228
+
229
+ # If circular dependencies detected:
230
+ # ❌ STOP - Fix architecture first
231
+ # ✅ Refactor to remove cycles
232
+ # ✅ Re-validate before proceeding
233
+ ```
234
+
235
+ ## Language-Specific Guidelines
236
+
237
+ ### TypeScript/JavaScript
238
+ - Use `madge` or `dependency-cruiser` for validation
239
+ - Configure ESLint rules for import ordering
240
+ - Use path aliases to enforce layer structure
241
+
242
+ ### Rust
243
+ - Cargo automatically detects circular dependencies
244
+ - Use `cargo tree` to visualize dependencies
245
+ - Organize modules to reflect layer structure
246
+
247
+ ### Python
248
+ - Use `pylint` or `vulture` for import analysis
249
+ - Organize packages to reflect layer structure
250
+ - Use `__init__.py` to control exports
251
+
252
+ ### Go
253
+ - Use `go vet` for dependency validation
254
+ - Organize packages in directories reflecting layers
255
+ - Use interfaces to decouple components
256
+
257
+ ## Examples
258
+
259
+ ### Good Architecture ✅
260
+
261
+ ```
262
+ src/
263
+ ├── foundation/
264
+ │ ├── utils/
265
+ │ ├── types/
266
+ │ └── config/
267
+ ├── core/
268
+ │ ├── models/
269
+ │ ├── services/
270
+ │ └── repositories/
271
+ ├── features/
272
+ │ ├── auth/
273
+ │ │ └── (depends on core, foundation)
274
+ │ └── payments/
275
+ │ └── (depends on core, foundation)
276
+ └── presentation/
277
+ ├── cli/
278
+ │ └── (depends on features, core, foundation)
279
+ └── api/
280
+ └── (depends on features, core, foundation)
281
+ ```
282
+
283
+ ### Bad Architecture ❌
284
+
285
+ ```
286
+ src/
287
+ ├── features/
288
+ │ └── auth/
289
+ │ └── (depends on presentation) # ❌ Wrong direction
290
+ ├── core/
291
+ │ └── (depends on features) # ❌ Wrong direction
292
+ └── presentation/
293
+ └── (depends on foundation only) # ❌ Missing dependencies
294
+ ```
295
+
296
+ ## Maintenance
297
+
298
+ ### Regular Checks
299
+
300
+ - **Before every commit**: Run dependency validation
301
+ - **Weekly**: Review dependency graph for optimization
302
+ - **Before major refactoring**: Document current dependencies
303
+ - **After adding new components**: Update DAG documentation
304
+
305
+ ### Tools Integration
306
+
307
+ Add dependency checks to:
308
+ - Pre-commit hooks
309
+ - CI/CD pipelines
310
+ - AGENT_AUTOMATION workflow
311
+ - Quality gates
312
+
313
+ <!-- DAG:END -->
314
+