@heyai-rules/pilo-masterkit 1.2.2 → 2.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 (709) hide show
  1. package/.agent/agents/PILO_MASTER.md +77 -77
  2. package/.agent/agents/backend-specialist.md +263 -263
  3. package/.agent/agents/code-archaeologist.md +106 -106
  4. package/.agent/agents/csharp-reviewer.md +101 -0
  5. package/.agent/agents/dart-build-resolver.md +201 -0
  6. package/.agent/agents/database-architect.md +226 -226
  7. package/.agent/agents/debugger.md +225 -225
  8. package/.agent/agents/devops-engineer.md +242 -242
  9. package/.agent/agents/documentation-writer.md +104 -104
  10. package/.agent/agents/explorer-agent.md +73 -73
  11. package/.agent/agents/frontend-specialist.md +593 -593
  12. package/.agent/agents/game-developer.md +162 -162
  13. package/.agent/agents/gan-evaluator.md +209 -0
  14. package/.agent/agents/gan-generator.md +131 -0
  15. package/.agent/agents/gan-planner.md +99 -0
  16. package/.agent/agents/healthcare-reviewer.md +83 -0
  17. package/.agent/agents/mobile-developer.md +377 -377
  18. package/.agent/agents/opensource-forker.md +198 -0
  19. package/.agent/agents/opensource-packager.md +249 -0
  20. package/.agent/agents/opensource-sanitizer.md +188 -0
  21. package/.agent/agents/orchestrator.md +416 -416
  22. package/.agent/agents/penetration-tester.md +188 -188
  23. package/.agent/agents/performance-optimizer.md +446 -187
  24. package/.agent/agents/personas/athena-agent/agent.json +10 -0
  25. package/.agent/agents/personas/athena-agent/athena-backend-logic-architecture-profile.md +189 -0
  26. package/.agent/agents/personas/athena-agent/context-files/agents.md +55 -0
  27. package/.agent/agents/personas/athena-agent/context-files/identity.md +23 -0
  28. package/.agent/agents/personas/athena-agent/context-files/soul.md +51 -0
  29. package/.agent/agents/personas/athena-agent/context-files/user-predefined.md +15 -0
  30. package/.agent/agents/personas/athena-agent/user-context-files/system/bootstrap.md +37 -0
  31. package/.agent/agents/personas/athena-agent/user-context-files/system/user.md +45 -0
  32. package/.agent/agents/personas/da-vinci-agent/agent.json +10 -0
  33. package/.agent/agents/personas/da-vinci-agent/context-files/agents.md +55 -0
  34. package/.agent/agents/personas/da-vinci-agent/context-files/identity.md +23 -0
  35. package/.agent/agents/personas/da-vinci-agent/context-files/soul.md +51 -0
  36. package/.agent/agents/personas/da-vinci-agent/context-files/user-predefined.md +15 -0
  37. package/.agent/agents/personas/da-vinci-agent/da-vinci-frontend-ui-ux-design-profile.md +189 -0
  38. package/.agent/agents/personas/da-vinci-agent/user-context-files/system/bootstrap.md +37 -0
  39. package/.agent/agents/personas/da-vinci-agent/user-context-files/system/user.md +45 -0
  40. package/.agent/agents/personas/duong-tang-agent/agent.json +10 -0
  41. package/.agent/agents/personas/duong-tang-agent/context-files/agents.md +55 -0
  42. package/.agent/agents/personas/duong-tang-agent/context-files/identity.md +23 -0
  43. package/.agent/agents/personas/duong-tang-agent/context-files/soul.md +51 -0
  44. package/.agent/agents/personas/duong-tang-agent/context-files/user-predefined.md +15 -0
  45. package/.agent/agents/personas/duong-tang-agent/tang-monk-quality-testing-documentation-profile.md +189 -0
  46. package/.agent/agents/personas/duong-tang-agent/user-context-files/system/bootstrap.md +37 -0
  47. package/.agent/agents/personas/duong-tang-agent/user-context-files/system/user.md +45 -0
  48. package/.agent/agents/personas/gia-cat-luong-agent/agent.json +10 -0
  49. package/.agent/agents/personas/gia-cat-luong-agent/context-files/agents.md +55 -0
  50. package/.agent/agents/personas/gia-cat-luong-agent/context-files/identity.md +23 -0
  51. package/.agent/agents/personas/gia-cat-luong-agent/context-files/soul.md +51 -0
  52. package/.agent/agents/personas/gia-cat-luong-agent/context-files/user-predefined.md +15 -0
  53. package/.agent/agents/personas/gia-cat-luong-agent/kongming-research-strategy-analysis-profile.md +189 -0
  54. package/.agent/agents/personas/gia-cat-luong-agent/user-context-files/system/bootstrap.md +37 -0
  55. package/.agent/agents/personas/gia-cat-luong-agent/user-context-files/system/user.md +45 -0
  56. package/.agent/agents/personas/mihata-agent/agent.json +10 -0
  57. package/.agent/agents/personas/mihata-agent/context-files/agents.md +55 -0
  58. package/.agent/agents/personas/mihata-agent/context-files/identity.md +23 -0
  59. package/.agent/agents/personas/mihata-agent/context-files/soul.md +51 -0
  60. package/.agent/agents/personas/mihata-agent/context-files/user-predefined.md +15 -0
  61. package/.agent/agents/personas/mihata-agent/mihata-multi-agent-orchestration-profile.md +189 -0
  62. package/.agent/agents/personas/mihata-agent/user-context-files/system/bootstrap.md +37 -0
  63. package/.agent/agents/personas/mihata-agent/user-context-files/system/user.md +45 -0
  64. package/.agent/agents/personas/tesla-agent/agent.json +10 -0
  65. package/.agent/agents/personas/tesla-agent/context-files/agents.md +55 -0
  66. package/.agent/agents/personas/tesla-agent/context-files/identity.md +23 -0
  67. package/.agent/agents/personas/tesla-agent/context-files/soul.md +51 -0
  68. package/.agent/agents/personas/tesla-agent/context-files/user-predefined.md +15 -0
  69. package/.agent/agents/personas/tesla-agent/tesla-fullstack-system-optimization-profile.md +189 -0
  70. package/.agent/agents/personas/tesla-agent/user-context-files/system/bootstrap.md +37 -0
  71. package/.agent/agents/personas/tesla-agent/user-context-files/system/user.md +45 -0
  72. package/.agent/agents/personas/tu-ma-y-agent/agent.json +10 -0
  73. package/.agent/agents/personas/tu-ma-y-agent/context-files/agents.md +55 -0
  74. package/.agent/agents/personas/tu-ma-y-agent/context-files/identity.md +23 -0
  75. package/.agent/agents/personas/tu-ma-y-agent/context-files/soul.md +51 -0
  76. package/.agent/agents/personas/tu-ma-y-agent/context-files/user-predefined.md +15 -0
  77. package/.agent/agents/personas/tu-ma-y-agent/simayi-feasibility-risk-control-profile.md +189 -0
  78. package/.agent/agents/personas/tu-ma-y-agent/user-context-files/system/bootstrap.md +37 -0
  79. package/.agent/agents/personas/tu-ma-y-agent/user-context-files/system/user.md +45 -0
  80. package/.agent/agents/personas/venti-agent/agent.json +10 -0
  81. package/.agent/agents/personas/venti-agent/context-files/agents.md +55 -0
  82. package/.agent/agents/personas/venti-agent/context-files/identity.md +23 -0
  83. package/.agent/agents/personas/venti-agent/context-files/soul.md +51 -0
  84. package/.agent/agents/personas/venti-agent/context-files/user-predefined.md +15 -0
  85. package/.agent/agents/personas/venti-agent/user-context-files/system/bootstrap.md +37 -0
  86. package/.agent/agents/personas/venti-agent/user-context-files/system/user.md +45 -0
  87. package/.agent/agents/personas/venti-agent/venti-learning-communication-mentoring-profile.md +189 -0
  88. package/.agent/agents/product-manager.md +112 -112
  89. package/.agent/agents/product-owner.md +95 -95
  90. package/.agent/agents/project-planner.md +406 -406
  91. package/.agent/agents/qa-automation-engineer.md +103 -103
  92. package/.agent/agents/security-auditor.md +170 -170
  93. package/.agent/agents/seo-specialist.md +111 -111
  94. package/.agent/agents/test-engineer.md +158 -158
  95. package/.agent/contexts/dev.md +20 -0
  96. package/.agent/contexts/research.md +26 -0
  97. package/.agent/contexts/review.md +22 -0
  98. package/.agent/hooks/hooks.json +395 -0
  99. package/.agent/hooks/readme.md +222 -0
  100. package/.agent/mcp-configs/mcp-servers.json +181 -0
  101. package/.agent/rules/ARCHITECTURAL_BLUEPRINTS.md +62 -62
  102. package/.agent/rules/CODE_CRAFTSMANSHIP.md +69 -69
  103. package/.agent/rules/CORE_RULES.md +72 -72
  104. package/.agent/rules/PROJECT_MAP.md +58 -58
  105. package/.agent/rules/QUALITY_ASSURANCE.md +54 -54
  106. package/.agent/rules/SECURITY_ARMOR.md +44 -44
  107. package/.agent/rules/VERSION_ORCHESTRATION.md +64 -64
  108. package/.agent/rules/WORKFLOW_ORCHESTRATION.md +55 -55
  109. package/.agent/rules/common/agents.md +50 -0
  110. package/.agent/rules/common/code-review.md +124 -0
  111. package/.agent/rules/common/coding-style.md +48 -0
  112. package/.agent/rules/common/development-workflow.md +44 -0
  113. package/.agent/rules/common/git-workflow.md +24 -0
  114. package/.agent/rules/common/hooks.md +30 -0
  115. package/.agent/rules/common/patterns.md +31 -0
  116. package/.agent/rules/common/performance.md +55 -0
  117. package/.agent/rules/common/security.md +29 -0
  118. package/.agent/rules/common/testing.md +29 -0
  119. package/.agent/rules/cpp/coding-style.md +44 -0
  120. package/.agent/rules/cpp/hooks.md +39 -0
  121. package/.agent/rules/cpp/patterns.md +51 -0
  122. package/.agent/rules/cpp/security.md +51 -0
  123. package/.agent/rules/cpp/testing.md +44 -0
  124. package/.agent/rules/csharp/coding-style.md +72 -0
  125. package/.agent/rules/csharp/hooks.md +25 -0
  126. package/.agent/rules/csharp/patterns.md +50 -0
  127. package/.agent/rules/csharp/security.md +58 -0
  128. package/.agent/rules/csharp/testing.md +46 -0
  129. package/.agent/rules/dart/coding-style.md +159 -0
  130. package/.agent/rules/dart/hooks.md +66 -0
  131. package/.agent/rules/dart/patterns.md +261 -0
  132. package/.agent/rules/dart/security.md +135 -0
  133. package/.agent/rules/dart/testing.md +215 -0
  134. package/.agent/rules/golang/coding-style.md +32 -0
  135. package/.agent/rules/golang/hooks.md +17 -0
  136. package/.agent/rules/golang/patterns.md +45 -0
  137. package/.agent/rules/golang/security.md +34 -0
  138. package/.agent/rules/golang/testing.md +31 -0
  139. package/.agent/rules/java/coding-style.md +114 -0
  140. package/.agent/rules/java/hooks.md +18 -0
  141. package/.agent/rules/java/patterns.md +146 -0
  142. package/.agent/rules/java/security.md +100 -0
  143. package/.agent/rules/java/testing.md +131 -0
  144. package/.agent/rules/kotlin/coding-style.md +86 -0
  145. package/.agent/rules/kotlin/hooks.md +17 -0
  146. package/.agent/rules/kotlin/patterns.md +146 -0
  147. package/.agent/rules/kotlin/security.md +82 -0
  148. package/.agent/rules/kotlin/testing.md +128 -0
  149. package/.agent/rules/perl/coding-style.md +46 -0
  150. package/.agent/rules/perl/hooks.md +22 -0
  151. package/.agent/rules/perl/patterns.md +76 -0
  152. package/.agent/rules/perl/security.md +69 -0
  153. package/.agent/rules/perl/testing.md +54 -0
  154. package/.agent/rules/php/coding-style.md +40 -0
  155. package/.agent/rules/php/hooks.md +24 -0
  156. package/.agent/rules/php/patterns.md +33 -0
  157. package/.agent/rules/php/security.md +37 -0
  158. package/.agent/rules/php/testing.md +39 -0
  159. package/.agent/rules/python/coding-style.md +42 -0
  160. package/.agent/rules/python/hooks.md +19 -0
  161. package/.agent/rules/python/patterns.md +39 -0
  162. package/.agent/rules/python/security.md +30 -0
  163. package/.agent/rules/python/testing.md +38 -0
  164. package/.agent/rules/readme.md +111 -0
  165. package/.agent/rules/rust/coding-style.md +151 -0
  166. package/.agent/rules/rust/hooks.md +16 -0
  167. package/.agent/rules/rust/patterns.md +168 -0
  168. package/.agent/rules/rust/security.md +141 -0
  169. package/.agent/rules/rust/testing.md +154 -0
  170. package/.agent/rules/swift/coding-style.md +47 -0
  171. package/.agent/rules/swift/hooks.md +20 -0
  172. package/.agent/rules/swift/patterns.md +66 -0
  173. package/.agent/rules/swift/security.md +33 -0
  174. package/.agent/rules/swift/testing.md +45 -0
  175. package/.agent/rules/typescript/coding-style.md +199 -0
  176. package/.agent/rules/typescript/hooks.md +22 -0
  177. package/.agent/rules/typescript/patterns.md +52 -0
  178. package/.agent/rules/typescript/security.md +28 -0
  179. package/.agent/rules/typescript/testing.md +18 -0
  180. package/.agent/rules/web/coding-style.md +96 -0
  181. package/.agent/rules/web/design-quality.md +63 -0
  182. package/.agent/rules/web/hooks.md +120 -0
  183. package/.agent/rules/web/patterns.md +79 -0
  184. package/.agent/rules/web/performance.md +64 -0
  185. package/.agent/rules/web/security.md +57 -0
  186. package/.agent/rules/web/testing.md +55 -0
  187. package/.agent/rules/zh/agents.md +50 -0
  188. package/.agent/rules/zh/code-review.md +124 -0
  189. package/.agent/rules/zh/coding-style.md +48 -0
  190. package/.agent/rules/zh/development-workflow.md +44 -0
  191. package/.agent/rules/zh/git-workflow.md +24 -0
  192. package/.agent/rules/zh/hooks.md +30 -0
  193. package/.agent/rules/zh/patterns.md +31 -0
  194. package/.agent/rules/zh/performance.md +55 -0
  195. package/.agent/rules/zh/readme.md +108 -0
  196. package/.agent/rules/zh/security.md +29 -0
  197. package/.agent/rules/zh/testing.md +29 -0
  198. package/.agent/scripts/auto_preview.py +148 -148
  199. package/.agent/scripts/checklist.py +217 -217
  200. package/.agent/scripts/session_manager.py +120 -120
  201. package/.agent/scripts/verify_all.py +327 -327
  202. package/.agent/skills/agent-eval/SKILL.md +145 -0
  203. package/.agent/skills/agent-harness-construction/SKILL.md +73 -0
  204. package/.agent/skills/agent-payment-x402/SKILL.md +178 -0
  205. package/.agent/skills/agentic-engineering/SKILL.md +63 -0
  206. package/.agent/skills/ai-first-engineering/SKILL.md +51 -0
  207. package/.agent/skills/ai-regression-testing/SKILL.md +385 -0
  208. package/.agent/skills/android-clean-architecture/SKILL.md +339 -0
  209. package/.agent/skills/api-design/SKILL.md +523 -0
  210. package/.agent/skills/api-patterns/SKILL.md +81 -81
  211. package/.agent/skills/api-patterns/api-style.md +42 -42
  212. package/.agent/skills/api-patterns/auth.md +24 -24
  213. package/.agent/skills/api-patterns/documentation.md +26 -26
  214. package/.agent/skills/api-patterns/graphql.md +41 -41
  215. package/.agent/skills/api-patterns/rate-limiting.md +31 -31
  216. package/.agent/skills/api-patterns/response.md +37 -37
  217. package/.agent/skills/api-patterns/rest.md +40 -40
  218. package/.agent/skills/api-patterns/scripts/api_validator.py +211 -211
  219. package/.agent/skills/api-patterns/security-testing.md +122 -122
  220. package/.agent/skills/api-patterns/trpc.md +41 -41
  221. package/.agent/skills/api-patterns/versioning.md +22 -22
  222. package/.agent/skills/app-builder/SKILL.md +75 -75
  223. package/.agent/skills/app-builder/agent-coordination.md +71 -71
  224. package/.agent/skills/app-builder/feature-building.md +53 -53
  225. package/.agent/skills/app-builder/project-detection.md +34 -34
  226. package/.agent/skills/app-builder/scaffolding.md +118 -118
  227. package/.agent/skills/app-builder/tech-stack.md +41 -41
  228. package/.agent/skills/app-builder/templates/SKILL.md +39 -39
  229. package/.agent/skills/app-builder/templates/astro-static/TEMPLATE.md +76 -76
  230. package/.agent/skills/app-builder/templates/chrome-extension/TEMPLATE.md +92 -92
  231. package/.agent/skills/app-builder/templates/cli-tool/TEMPLATE.md +88 -88
  232. package/.agent/skills/app-builder/templates/electron-desktop/TEMPLATE.md +88 -88
  233. package/.agent/skills/app-builder/templates/express-api/TEMPLATE.md +83 -83
  234. package/.agent/skills/app-builder/templates/flutter-app/TEMPLATE.md +90 -90
  235. package/.agent/skills/app-builder/templates/monorepo-turborepo/TEMPLATE.md +90 -90
  236. package/.agent/skills/app-builder/templates/nextjs-fullstack/TEMPLATE.md +122 -122
  237. package/.agent/skills/app-builder/templates/nextjs-saas/TEMPLATE.md +122 -122
  238. package/.agent/skills/app-builder/templates/nextjs-static/TEMPLATE.md +169 -169
  239. package/.agent/skills/app-builder/templates/nuxt-app/TEMPLATE.md +134 -134
  240. package/.agent/skills/app-builder/templates/python-fastapi/TEMPLATE.md +83 -83
  241. package/.agent/skills/app-builder/templates/react-native-app/TEMPLATE.md +119 -119
  242. package/.agent/skills/architecture/SKILL.md +55 -55
  243. package/.agent/skills/architecture/context-discovery.md +43 -43
  244. package/.agent/skills/architecture/examples.md +94 -94
  245. package/.agent/skills/architecture/pattern-selection.md +68 -68
  246. package/.agent/skills/architecture/patterns-reference.md +50 -50
  247. package/.agent/skills/architecture/trade-off-analysis.md +77 -77
  248. package/.agent/skills/architecture-decision-records/SKILL.md +179 -0
  249. package/.agent/skills/article-writing/SKILL.md +79 -0
  250. package/.agent/skills/autonomous-agent-harness/SKILL.md +267 -0
  251. package/.agent/skills/autonomous-loops/SKILL.md +610 -0
  252. package/.agent/skills/backend-patterns/SKILL.md +598 -0
  253. package/.agent/skills/bash-linux/SKILL.md +199 -199
  254. package/.agent/skills/behavioral-modes/SKILL.md +242 -242
  255. package/.agent/skills/benchmark/SKILL.md +93 -0
  256. package/.agent/skills/blueprint/SKILL.md +105 -0
  257. package/.agent/skills/brainstorming/SKILL.md +163 -163
  258. package/.agent/skills/brainstorming/dynamic-questioning.md +350 -350
  259. package/.agent/skills/brand-voice/SKILL.md +97 -0
  260. package/.agent/skills/brand-voice/references/voice-profile-schema.md +55 -0
  261. package/.agent/skills/browser-qa/SKILL.md +87 -0
  262. package/.agent/skills/bun-runtime/SKILL.md +84 -0
  263. package/.agent/skills/canary-watch/SKILL.md +99 -0
  264. package/.agent/skills/carrier-relationship-management/SKILL.md +212 -0
  265. package/.agent/skills/ck/SKILL.md +147 -0
  266. package/.agent/skills/ck/commands/forget.mjs +44 -0
  267. package/.agent/skills/ck/commands/info.mjs +24 -0
  268. package/.agent/skills/ck/commands/init.mjs +143 -0
  269. package/.agent/skills/ck/commands/list.mjs +40 -0
  270. package/.agent/skills/ck/commands/migrate.mjs +202 -0
  271. package/.agent/skills/ck/commands/resume.mjs +36 -0
  272. package/.agent/skills/ck/commands/save.mjs +210 -0
  273. package/.agent/skills/ck/commands/shared.mjs +387 -0
  274. package/.agent/skills/ck/hooks/session-start.mjs +224 -0
  275. package/.agent/skills/claude-api/SKILL.md +337 -0
  276. package/.agent/skills/claude-devfleet/SKILL.md +103 -0
  277. package/.agent/skills/clean-code/SKILL.md +201 -201
  278. package/.agent/skills/click-path-audit/SKILL.md +244 -0
  279. package/.agent/skills/clickhouse-io/SKILL.md +439 -0
  280. package/.agent/skills/code-review-checklist/SKILL.md +109 -109
  281. package/.agent/skills/codebase-onboarding/SKILL.md +233 -0
  282. package/.agent/skills/coding-standards/SKILL.md +530 -0
  283. package/.agent/skills/compose-multiplatform-patterns/SKILL.md +299 -0
  284. package/.agent/skills/configure-ecc/SKILL.md +367 -0
  285. package/.agent/skills/connections-optimizer/SKILL.md +189 -0
  286. package/.agent/skills/content-engine/SKILL.md +131 -0
  287. package/.agent/skills/content-hash-cache-pattern/SKILL.md +161 -0
  288. package/.agent/skills/context-budget/SKILL.md +135 -0
  289. package/.agent/skills/continuous-agent-loop/SKILL.md +45 -0
  290. package/.agent/skills/continuous-learning/SKILL.md +119 -0
  291. package/.agent/skills/continuous-learning/config.json +18 -0
  292. package/.agent/skills/continuous-learning/evaluate-session.sh +69 -0
  293. package/.agent/skills/continuous-learning-v2/SKILL.md +365 -0
  294. package/.agent/skills/continuous-learning-v2/agents/observer-loop.sh +271 -0
  295. package/.agent/skills/continuous-learning-v2/agents/observer.md +198 -0
  296. package/.agent/skills/continuous-learning-v2/agents/session-guardian.sh +150 -0
  297. package/.agent/skills/continuous-learning-v2/agents/start-observer.sh +244 -0
  298. package/.agent/skills/continuous-learning-v2/config.json +8 -0
  299. package/.agent/skills/continuous-learning-v2/hooks/observe.sh +428 -0
  300. package/.agent/skills/continuous-learning-v2/scripts/detect-project.sh +228 -0
  301. package/.agent/skills/continuous-learning-v2/scripts/instinct-cli.py +1426 -0
  302. package/.agent/skills/continuous-learning-v2/scripts/test-parse-instinct.py +984 -0
  303. package/.agent/skills/cost-aware-llm-pipeline/SKILL.md +183 -0
  304. package/.agent/skills/cpp-coding-standards/SKILL.md +723 -0
  305. package/.agent/skills/cpp-testing/SKILL.md +324 -0
  306. package/.agent/skills/crosspost/SKILL.md +111 -0
  307. package/.agent/skills/csharp-testing/SKILL.md +321 -0
  308. package/.agent/skills/customer-billing-ops/SKILL.md +140 -0
  309. package/.agent/skills/customs-trade-compliance/SKILL.md +263 -0
  310. package/.agent/skills/dart-flutter-patterns/SKILL.md +563 -0
  311. package/.agent/skills/data-scraper-agent/SKILL.md +764 -0
  312. package/.agent/skills/database-design/SKILL.md +52 -52
  313. package/.agent/skills/database-design/database-selection.md +43 -43
  314. package/.agent/skills/database-design/indexing.md +39 -39
  315. package/.agent/skills/database-design/migrations.md +48 -48
  316. package/.agent/skills/database-design/optimization.md +36 -36
  317. package/.agent/skills/database-design/orm-selection.md +30 -30
  318. package/.agent/skills/database-design/schema-design.md +56 -56
  319. package/.agent/skills/database-design/scripts/schema_validator.py +172 -172
  320. package/.agent/skills/database-migrations/SKILL.md +429 -0
  321. package/.agent/skills/deep-research/SKILL.md +155 -0
  322. package/.agent/skills/deployment-patterns/SKILL.md +427 -0
  323. package/.agent/skills/deployment-procedures/SKILL.md +241 -241
  324. package/.agent/skills/design-system/SKILL.md +82 -0
  325. package/.agent/skills/django-patterns/SKILL.md +734 -0
  326. package/.agent/skills/django-security/SKILL.md +593 -0
  327. package/.agent/skills/django-tdd/SKILL.md +729 -0
  328. package/.agent/skills/django-verification/SKILL.md +469 -0
  329. package/.agent/skills/dmux-workflows/SKILL.md +191 -0
  330. package/.agent/skills/doc.md +177 -177
  331. package/.agent/skills/docker-patterns/SKILL.md +364 -0
  332. package/.agent/skills/documentation-lookup/SKILL.md +90 -0
  333. package/.agent/skills/documentation-templates/SKILL.md +194 -194
  334. package/.agent/skills/dotnet-patterns/SKILL.md +321 -0
  335. package/.agent/skills/e2e-testing/SKILL.md +326 -0
  336. package/.agent/skills/energy-procurement/SKILL.md +228 -0
  337. package/.agent/skills/enterprise-agent-ops/SKILL.md +50 -0
  338. package/.agent/skills/eval-harness/SKILL.md +270 -0
  339. package/.agent/skills/exa-search/SKILL.md +103 -0
  340. package/.agent/skills/fal-ai-media/SKILL.md +284 -0
  341. package/.agent/skills/flutter-dart-code-review/SKILL.md +435 -0
  342. package/.agent/skills/foundation-models-on-device/SKILL.md +243 -0
  343. package/.agent/skills/frontend-design/SKILL.md +452 -452
  344. package/.agent/skills/frontend-design/animation-guide.md +331 -331
  345. package/.agent/skills/frontend-design/color-system.md +311 -311
  346. package/.agent/skills/frontend-design/decision-trees.md +418 -418
  347. package/.agent/skills/frontend-design/motion-graphics.md +306 -306
  348. package/.agent/skills/frontend-design/scripts/accessibility_checker.py +183 -183
  349. package/.agent/skills/frontend-design/scripts/ux_audit.py +722 -722
  350. package/.agent/skills/frontend-design/typography-system.md +345 -345
  351. package/.agent/skills/frontend-design/ux-psychology.md +1116 -1116
  352. package/.agent/skills/frontend-design/visual-effects.md +383 -383
  353. package/.agent/skills/frontend-patterns/SKILL.md +642 -0
  354. package/.agent/skills/frontend-slides/SKILL.md +184 -0
  355. package/.agent/skills/frontend-slides/style-presets.md +330 -0
  356. package/.agent/skills/game-development/2d-games/SKILL.md +119 -119
  357. package/.agent/skills/game-development/3d-games/SKILL.md +135 -135
  358. package/.agent/skills/game-development/SKILL.md +167 -167
  359. package/.agent/skills/game-development/game-art/SKILL.md +185 -185
  360. package/.agent/skills/game-development/game-audio/SKILL.md +190 -190
  361. package/.agent/skills/game-development/game-design/SKILL.md +129 -129
  362. package/.agent/skills/game-development/mobile-games/SKILL.md +108 -108
  363. package/.agent/skills/game-development/multiplayer/SKILL.md +132 -132
  364. package/.agent/skills/game-development/pc-games/SKILL.md +144 -144
  365. package/.agent/skills/game-development/vr-ar/SKILL.md +123 -123
  366. package/.agent/skills/game-development/web-games/SKILL.md +150 -150
  367. package/.agent/skills/gan-style-harness/SKILL.md +278 -0
  368. package/.agent/skills/geo-fundamentals/SKILL.md +156 -156
  369. package/.agent/skills/geo-fundamentals/scripts/geo_checker.py +289 -289
  370. package/.agent/skills/git-workflow/SKILL.md +715 -0
  371. package/.agent/skills/golang-patterns/SKILL.md +674 -0
  372. package/.agent/skills/golang-testing/SKILL.md +720 -0
  373. package/.agent/skills/google-workspace-ops/SKILL.md +95 -0
  374. package/.agent/skills/healthcare-cdss-patterns/SKILL.md +245 -0
  375. package/.agent/skills/healthcare-emr-patterns/SKILL.md +159 -0
  376. package/.agent/skills/healthcare-eval-harness/SKILL.md +207 -0
  377. package/.agent/skills/healthcare-phi-compliance/SKILL.md +145 -0
  378. package/.agent/skills/hexagonal-architecture/SKILL.md +276 -0
  379. package/.agent/skills/i18n-localization/SKILL.md +154 -154
  380. package/.agent/skills/i18n-localization/scripts/i18n_checker.py +241 -241
  381. package/.agent/skills/intelligent-routing/SKILL.md +335 -335
  382. package/.agent/skills/inventory-demand-planning/SKILL.md +247 -0
  383. package/.agent/skills/investor-materials/SKILL.md +96 -0
  384. package/.agent/skills/investor-outreach/SKILL.md +91 -0
  385. package/.agent/skills/iterative-retrieval/SKILL.md +211 -0
  386. package/.agent/skills/java-coding-standards/SKILL.md +147 -0
  387. package/.agent/skills/jira-integration/SKILL.md +293 -0
  388. package/.agent/skills/jpa-patterns/SKILL.md +151 -0
  389. package/.agent/skills/kotlin-coroutines-flows/SKILL.md +284 -0
  390. package/.agent/skills/kotlin-exposed-patterns/SKILL.md +719 -0
  391. package/.agent/skills/kotlin-ktor-patterns/SKILL.md +689 -0
  392. package/.agent/skills/kotlin-patterns/SKILL.md +711 -0
  393. package/.agent/skills/kotlin-testing/SKILL.md +824 -0
  394. package/.agent/skills/laravel-patterns/SKILL.md +415 -0
  395. package/.agent/skills/laravel-plugin-discovery/SKILL.md +229 -0
  396. package/.agent/skills/laravel-security/SKILL.md +285 -0
  397. package/.agent/skills/laravel-tdd/SKILL.md +283 -0
  398. package/.agent/skills/laravel-verification/SKILL.md +179 -0
  399. package/.agent/skills/lead-intelligence/SKILL.md +321 -0
  400. package/.agent/skills/lead-intelligence/agents/enrichment-agent.md +85 -0
  401. package/.agent/skills/lead-intelligence/agents/mutual-mapper.md +75 -0
  402. package/.agent/skills/lead-intelligence/agents/outreach-drafter.md +98 -0
  403. package/.agent/skills/lead-intelligence/agents/signal-scorer.md +60 -0
  404. package/.agent/skills/lint-and-validate/SKILL.md +45 -45
  405. package/.agent/skills/lint-and-validate/scripts/lint_runner.py +184 -184
  406. package/.agent/skills/lint-and-validate/scripts/type_coverage.py +173 -173
  407. package/.agent/skills/liquid-glass-design/SKILL.md +279 -0
  408. package/.agent/skills/logistics-exception-management/SKILL.md +222 -0
  409. package/.agent/skills/manim-video/SKILL.md +89 -0
  410. package/.agent/skills/manim-video/assets/network-graph-scene.py +52 -0
  411. package/.agent/skills/market-research/SKILL.md +75 -0
  412. package/.agent/skills/mcp-builder/SKILL.md +173 -113
  413. package/.agent/skills/mcp-builder/license.txt +202 -0
  414. package/.agent/skills/mcp-builder/reference/evaluation.md +602 -0
  415. package/.agent/skills/mcp-builder/reference/mcp-best-practices.md +249 -0
  416. package/.agent/skills/mcp-builder/reference/node-mcp-server.md +970 -0
  417. package/.agent/skills/mcp-builder/reference/python-mcp-server.md +719 -0
  418. package/.agent/skills/mcp-builder/scripts/connections.py +151 -0
  419. package/.agent/skills/mcp-builder/scripts/evaluation.py +373 -0
  420. package/.agent/skills/mcp-builder/scripts/example-evaluation.xml +22 -0
  421. package/.agent/skills/mcp-builder/scripts/requirements.txt +2 -0
  422. package/.agent/skills/mcp-server-patterns/SKILL.md +67 -0
  423. package/.agent/skills/mobile-design/SKILL.md +394 -394
  424. package/.agent/skills/mobile-design/decision-trees.md +516 -516
  425. package/.agent/skills/mobile-design/mobile-backend.md +491 -491
  426. package/.agent/skills/mobile-design/mobile-color-system.md +420 -420
  427. package/.agent/skills/mobile-design/mobile-debugging.md +122 -122
  428. package/.agent/skills/mobile-design/mobile-design-thinking.md +357 -357
  429. package/.agent/skills/mobile-design/mobile-navigation.md +458 -458
  430. package/.agent/skills/mobile-design/mobile-performance.md +767 -767
  431. package/.agent/skills/mobile-design/mobile-testing.md +356 -356
  432. package/.agent/skills/mobile-design/mobile-typography.md +433 -433
  433. package/.agent/skills/mobile-design/platform-android.md +666 -666
  434. package/.agent/skills/mobile-design/platform-ios.md +561 -561
  435. package/.agent/skills/mobile-design/scripts/mobile_audit.py +670 -670
  436. package/.agent/skills/mobile-design/touch-psychology.md +537 -537
  437. package/.agent/skills/nanoclaw-repl/SKILL.md +33 -0
  438. package/.agent/skills/nestjs-patterns/SKILL.md +230 -0
  439. package/.agent/skills/nextjs-react-expert/1-async-eliminating-waterfalls.md +351 -351
  440. package/.agent/skills/nextjs-react-expert/2-bundle-bundle-size-optimization.md +240 -240
  441. package/.agent/skills/nextjs-react-expert/3-server-server-side-performance.md +490 -490
  442. package/.agent/skills/nextjs-react-expert/4-client-client-side-data-fetching.md +264 -264
  443. package/.agent/skills/nextjs-react-expert/5-rerender-re-render-optimization.md +581 -581
  444. package/.agent/skills/nextjs-react-expert/6-rendering-rendering-performance.md +432 -432
  445. package/.agent/skills/nextjs-react-expert/7-js-javascript-performance.md +684 -684
  446. package/.agent/skills/nextjs-react-expert/8-advanced-advanced-patterns.md +150 -150
  447. package/.agent/skills/nextjs-react-expert/9-cache-components.md +103 -103
  448. package/.agent/skills/nextjs-react-expert/SKILL.md +293 -293
  449. package/.agent/skills/nextjs-react-expert/scripts/convert_rules.py +222 -222
  450. package/.agent/skills/nextjs-react-expert/scripts/react_performance_checker.py +252 -252
  451. package/.agent/skills/nextjs-turbopack/SKILL.md +44 -0
  452. package/.agent/skills/nodejs-best-practices/SKILL.md +333 -333
  453. package/.agent/skills/nutrient-document-processing/SKILL.md +167 -0
  454. package/.agent/skills/nuxt4-patterns/SKILL.md +100 -0
  455. package/.agent/skills/openclaw-persona-forge/SKILL.md +296 -0
  456. package/.agent/skills/openclaw-persona-forge/gacha.py +224 -0
  457. package/.agent/skills/openclaw-persona-forge/gacha.sh +5 -0
  458. package/.agent/skills/openclaw-persona-forge/references/avatar-style.md +124 -0
  459. package/.agent/skills/openclaw-persona-forge/references/boundary-rules.md +53 -0
  460. package/.agent/skills/openclaw-persona-forge/references/error-handling.md +53 -0
  461. package/.agent/skills/openclaw-persona-forge/references/identity-tension.md +48 -0
  462. package/.agent/skills/openclaw-persona-forge/references/naming-system.md +39 -0
  463. package/.agent/skills/openclaw-persona-forge/references/output-template.md +166 -0
  464. package/.agent/skills/opensource-pipeline/SKILL.md +255 -0
  465. package/.agent/skills/parallel-agents/SKILL.md +175 -175
  466. package/.agent/skills/performance-profiling/SKILL.md +143 -143
  467. package/.agent/skills/performance-profiling/scripts/lighthouse_audit.py +76 -76
  468. package/.agent/skills/perl-patterns/SKILL.md +504 -0
  469. package/.agent/skills/perl-security/SKILL.md +503 -0
  470. package/.agent/skills/perl-testing/SKILL.md +475 -0
  471. package/.agent/skills/plan-writing/SKILL.md +152 -152
  472. package/.agent/skills/plankton-code-quality/SKILL.md +236 -0
  473. package/.agent/skills/postgres-patterns/SKILL.md +147 -0
  474. package/.agent/skills/powershell-windows/SKILL.md +167 -167
  475. package/.agent/skills/product-lens/SKILL.md +85 -0
  476. package/.agent/skills/production-scheduling/SKILL.md +238 -0
  477. package/.agent/skills/project-flow-ops/SKILL.md +111 -0
  478. package/.agent/skills/project-guidelines-example/SKILL.md +349 -0
  479. package/.agent/skills/prompt-optimizer/SKILL.md +397 -0
  480. package/.agent/skills/python-patterns/SKILL.md +750 -441
  481. package/.agent/skills/python-testing/SKILL.md +816 -0
  482. package/.agent/skills/pytorch-patterns/SKILL.md +396 -0
  483. package/.agent/skills/quality-nonconformance/SKILL.md +260 -0
  484. package/.agent/skills/ralphinho-rfc-pipeline/SKILL.md +67 -0
  485. package/.agent/skills/red-team-tactics/SKILL.md +199 -199
  486. package/.agent/skills/regex-vs-llm-structured-text/SKILL.md +220 -0
  487. package/.agent/skills/remotion-video-creation/SKILL.md +43 -0
  488. package/.agent/skills/remotion-video-creation/rules/3d.md +86 -0
  489. package/.agent/skills/remotion-video-creation/rules/animations.md +29 -0
  490. package/.agent/skills/remotion-video-creation/rules/assets/charts-bar-chart.tsx +173 -0
  491. package/.agent/skills/remotion-video-creation/rules/assets/text-animations-typewriter.tsx +100 -0
  492. package/.agent/skills/remotion-video-creation/rules/assets/text-animations-word-highlight.tsx +108 -0
  493. package/.agent/skills/remotion-video-creation/rules/assets.md +78 -0
  494. package/.agent/skills/remotion-video-creation/rules/audio.md +172 -0
  495. package/.agent/skills/remotion-video-creation/rules/calculate-metadata.md +104 -0
  496. package/.agent/skills/remotion-video-creation/rules/can-decode.md +75 -0
  497. package/.agent/skills/remotion-video-creation/rules/charts.md +58 -0
  498. package/.agent/skills/remotion-video-creation/rules/compositions.md +146 -0
  499. package/.agent/skills/remotion-video-creation/rules/display-captions.md +126 -0
  500. package/.agent/skills/remotion-video-creation/rules/extract-frames.md +229 -0
  501. package/.agent/skills/remotion-video-creation/rules/fonts.md +152 -0
  502. package/.agent/skills/remotion-video-creation/rules/get-audio-duration.md +58 -0
  503. package/.agent/skills/remotion-video-creation/rules/get-video-dimensions.md +68 -0
  504. package/.agent/skills/remotion-video-creation/rules/get-video-duration.md +58 -0
  505. package/.agent/skills/remotion-video-creation/rules/gifs.md +138 -0
  506. package/.agent/skills/remotion-video-creation/rules/images.md +130 -0
  507. package/.agent/skills/remotion-video-creation/rules/import-srt-captions.md +67 -0
  508. package/.agent/skills/remotion-video-creation/rules/lottie.md +67 -0
  509. package/.agent/skills/remotion-video-creation/rules/measuring-dom-nodes.md +34 -0
  510. package/.agent/skills/remotion-video-creation/rules/measuring-text.md +143 -0
  511. package/.agent/skills/remotion-video-creation/rules/sequencing.md +106 -0
  512. package/.agent/skills/remotion-video-creation/rules/tailwind.md +11 -0
  513. package/.agent/skills/remotion-video-creation/rules/text-animations.md +20 -0
  514. package/.agent/skills/remotion-video-creation/rules/timing.md +179 -0
  515. package/.agent/skills/remotion-video-creation/rules/transcribe-captions.md +19 -0
  516. package/.agent/skills/remotion-video-creation/rules/transitions.md +122 -0
  517. package/.agent/skills/remotion-video-creation/rules/trimming.md +52 -0
  518. package/.agent/skills/remotion-video-creation/rules/videos.md +171 -0
  519. package/.agent/skills/repo-scan/SKILL.md +78 -0
  520. package/.agent/skills/returns-reverse-logistics/SKILL.md +240 -0
  521. package/.agent/skills/rules-distill/SKILL.md +264 -0
  522. package/.agent/skills/rules-distill/scripts/scan-rules.sh +58 -0
  523. package/.agent/skills/rules-distill/scripts/scan-skills.sh +129 -0
  524. package/.agent/skills/rust-patterns/SKILL.md +499 -0
  525. package/.agent/skills/rust-pro/SKILL.md +175 -175
  526. package/.agent/skills/rust-testing/SKILL.md +500 -0
  527. package/.agent/skills/safety-guard/SKILL.md +75 -0
  528. package/.agent/skills/santa-method/SKILL.md +306 -0
  529. package/.agent/skills/search-first/SKILL.md +161 -0
  530. package/.agent/skills/security-review/SKILL.md +495 -0
  531. package/.agent/skills/security-review/cloud-infrastructure-security.md +361 -0
  532. package/.agent/skills/security-scan/SKILL.md +165 -0
  533. package/.agent/skills/seo-fundamentals/SKILL.md +129 -129
  534. package/.agent/skills/seo-fundamentals/scripts/seo_checker.py +219 -219
  535. package/.agent/skills/server-management/SKILL.md +161 -161
  536. package/.agent/skills/skill-comply/SKILL.md +58 -0
  537. package/.agent/skills/skill-comply/fixtures/compliant-trace.jsonl +5 -0
  538. package/.agent/skills/skill-comply/fixtures/noncompliant-trace.jsonl +3 -0
  539. package/.agent/skills/skill-comply/fixtures/tdd-spec.yaml +44 -0
  540. package/.agent/skills/skill-comply/prompts/classifier.md +24 -0
  541. package/.agent/skills/skill-comply/prompts/scenario-generator.md +62 -0
  542. package/.agent/skills/skill-comply/prompts/spec-generator.md +42 -0
  543. package/.agent/skills/skill-comply/pyproject.toml +15 -0
  544. package/.agent/skills/skill-comply/scripts/classifier.py +85 -0
  545. package/.agent/skills/skill-comply/scripts/grader.py +122 -0
  546. package/.agent/skills/skill-comply/scripts/init.py +0 -0
  547. package/.agent/skills/skill-comply/scripts/parser.py +107 -0
  548. package/.agent/skills/skill-comply/scripts/report.py +170 -0
  549. package/.agent/skills/skill-comply/scripts/run.py +127 -0
  550. package/.agent/skills/skill-comply/scripts/runner.py +161 -0
  551. package/.agent/skills/skill-comply/scripts/scenario-generator.py +70 -0
  552. package/.agent/skills/skill-comply/scripts/spec-generator.py +72 -0
  553. package/.agent/skills/skill-comply/scripts/utils.py +13 -0
  554. package/.agent/skills/skill-comply/tests/test-grader.py +137 -0
  555. package/.agent/skills/skill-comply/tests/test-parser.py +90 -0
  556. package/.agent/skills/skill-creator/SKILL.md +485 -0
  557. package/.agent/skills/skill-creator/agents/analyzer.md +274 -0
  558. package/.agent/skills/skill-creator/agents/comparator.md +202 -0
  559. package/.agent/skills/skill-creator/agents/grader.md +223 -0
  560. package/.agent/skills/skill-creator/assets/eval-review.html +146 -0
  561. package/.agent/skills/skill-creator/eval-viewer/generate-review.py +471 -0
  562. package/.agent/skills/skill-creator/eval-viewer/viewer.html +1325 -0
  563. package/.agent/skills/skill-creator/license.txt +202 -0
  564. package/.agent/skills/skill-creator/references/schemas.md +430 -0
  565. package/.agent/skills/skill-creator/scripts/aggregate-benchmark.py +401 -0
  566. package/.agent/skills/skill-creator/scripts/generate-report.py +326 -0
  567. package/.agent/skills/skill-creator/scripts/improve-description.py +247 -0
  568. package/.agent/skills/skill-creator/scripts/init.py +0 -0
  569. package/.agent/skills/skill-creator/scripts/package-skill.py +136 -0
  570. package/.agent/skills/skill-creator/scripts/quick-validate.py +103 -0
  571. package/.agent/skills/skill-creator/scripts/run-eval.py +310 -0
  572. package/.agent/skills/skill-creator/scripts/run-loop.py +328 -0
  573. package/.agent/skills/skill-creator/scripts/utils.py +47 -0
  574. package/.agent/skills/skill-stocktake/SKILL.md +193 -0
  575. package/.agent/skills/skill-stocktake/scripts/quick-diff.sh +87 -0
  576. package/.agent/skills/skill-stocktake/scripts/save-results.sh +56 -0
  577. package/.agent/skills/skill-stocktake/scripts/scan.sh +170 -0
  578. package/.agent/skills/social-graph-ranker/SKILL.md +154 -0
  579. package/.agent/skills/springboot-patterns/SKILL.md +314 -0
  580. package/.agent/skills/springboot-security/SKILL.md +272 -0
  581. package/.agent/skills/springboot-tdd/SKILL.md +158 -0
  582. package/.agent/skills/springboot-verification/SKILL.md +231 -0
  583. package/.agent/skills/strategic-compact/SKILL.md +131 -0
  584. package/.agent/skills/strategic-compact/suggest-compact.sh +54 -0
  585. package/.agent/skills/swift-actor-persistence/SKILL.md +143 -0
  586. package/.agent/skills/swift-concurrency-6-2/SKILL.md +216 -0
  587. package/.agent/skills/swift-protocol-di-testing/SKILL.md +190 -0
  588. package/.agent/skills/swiftui-patterns/SKILL.md +259 -0
  589. package/.agent/skills/systematic-debugging/SKILL.md +109 -109
  590. package/.agent/skills/tailwind-patterns/SKILL.md +269 -269
  591. package/.agent/skills/tdd-workflow/SKILL.md +463 -149
  592. package/.agent/skills/team-builder/SKILL.md +168 -0
  593. package/.agent/skills/testing-patterns/SKILL.md +178 -178
  594. package/.agent/skills/testing-patterns/scripts/test_runner.py +219 -219
  595. package/.agent/skills/token-budget-advisor/SKILL.md +133 -0
  596. package/.agent/skills/ui-demo/SKILL.md +465 -0
  597. package/.agent/skills/ui-ux-pro-max/SKILL.md +292 -292
  598. package/.agent/skills/ui-ux-pro-max/data/icons.csv +101 -101
  599. package/.agent/skills/ui-ux-pro-max/data/landing.csv +3 -3
  600. package/.agent/skills/ui-ux-pro-max/data/react-performance.csv +45 -45
  601. package/.agent/skills/ui-ux-pro-max/data/stacks/astro.csv +54 -54
  602. package/.agent/skills/ui-ux-pro-max/data/stacks/jetpack-compose.csv +53 -53
  603. package/.agent/skills/ui-ux-pro-max/data/stacks/nuxt-ui.csv +51 -51
  604. package/.agent/skills/ui-ux-pro-max/data/stacks/nuxtjs.csv +59 -59
  605. package/.agent/skills/ui-ux-pro-max/data/stacks/shadcn.csv +61 -61
  606. package/.agent/skills/ui-ux-pro-max/data/typography.csv +57 -57
  607. package/.agent/skills/ui-ux-pro-max/data/ui-reasoning.csv +101 -101
  608. package/.agent/skills/ui-ux-pro-max/data/web-interface.csv +31 -31
  609. package/.agent/skills/ui-ux-pro-max/scripts/core.py +253 -253
  610. package/.agent/skills/ui-ux-pro-max/scripts/design_system.py +1067 -1067
  611. package/.agent/skills/verification-loop/SKILL.md +126 -0
  612. package/.agent/skills/video-editing/SKILL.md +310 -0
  613. package/.agent/skills/videodb/SKILL.md +374 -0
  614. package/.agent/skills/videodb/reference/api-reference.md +550 -0
  615. package/.agent/skills/videodb/reference/capture-reference.md +407 -0
  616. package/.agent/skills/videodb/reference/capture.md +101 -0
  617. package/.agent/skills/videodb/reference/editor.md +443 -0
  618. package/.agent/skills/videodb/reference/generative.md +331 -0
  619. package/.agent/skills/videodb/reference/rtstream-reference.md +564 -0
  620. package/.agent/skills/videodb/reference/rtstream.md +65 -0
  621. package/.agent/skills/videodb/reference/search.md +230 -0
  622. package/.agent/skills/videodb/reference/streaming.md +406 -0
  623. package/.agent/skills/videodb/reference/use-cases.md +118 -0
  624. package/.agent/skills/videodb/scripts/ws-listener.py +282 -0
  625. package/.agent/skills/visa-doc-translate/SKILL.md +117 -0
  626. package/.agent/skills/visa-doc-translate/readme.md +86 -0
  627. package/.agent/skills/vulnerability-scanner/SKILL.md +276 -276
  628. package/.agent/skills/vulnerability-scanner/checklists.md +121 -121
  629. package/.agent/skills/vulnerability-scanner/scripts/security_scan.py +458 -458
  630. package/.agent/skills/web-design-guidelines/SKILL.md +57 -57
  631. package/.agent/skills/webapp-testing/SKILL.md +187 -187
  632. package/.agent/skills/webapp-testing/scripts/playwright_runner.py +173 -173
  633. package/.agent/skills/workspace-surface-audit/SKILL.md +125 -0
  634. package/.agent/skills/x-api/SKILL.md +230 -0
  635. package/.agent/tasks/lessons.md +40 -40
  636. package/.agent/tasks/todo.md +33 -33
  637. package/.agent/tasks/two-track-merge-contract.md +29 -0
  638. package/.agent/workflows/aside.md +3 -3
  639. package/.agent/workflows/brainstorm.md +113 -113
  640. package/.agent/workflows/claw.md +13 -41
  641. package/.agent/workflows/clean-memory.md +34 -0
  642. package/.agent/workflows/code-review.md +260 -11
  643. package/.agent/workflows/context-budget.md +12 -18
  644. package/.agent/workflows/cpp-build.md +1 -1
  645. package/.agent/workflows/cpp-review.md +4 -4
  646. package/.agent/workflows/create.md +59 -59
  647. package/.agent/workflows/debug.md +103 -103
  648. package/.agent/workflows/deploy.md +176 -176
  649. package/.agent/workflows/devfleet.md +13 -82
  650. package/.agent/workflows/docs.md +13 -21
  651. package/.agent/workflows/e2e.md +38 -135
  652. package/.agent/workflows/enhance.md +63 -63
  653. package/.agent/workflows/eval.md +15 -112
  654. package/.agent/workflows/flutter-build.md +164 -0
  655. package/.agent/workflows/flutter-review.md +116 -0
  656. package/.agent/workflows/flutter-test.md +144 -0
  657. package/.agent/workflows/gan-build.md +99 -0
  658. package/.agent/workflows/gan-design.md +35 -0
  659. package/.agent/workflows/go-build.md +1 -1
  660. package/.agent/workflows/go-review.md +4 -4
  661. package/.agent/workflows/harness-audit.md +5 -3
  662. package/.agent/workflows/init-docs.md +46 -46
  663. package/.agent/workflows/instinct-import.md +4 -4
  664. package/.agent/workflows/jira.md +106 -0
  665. package/.agent/workflows/kotlin-build.md +1 -1
  666. package/.agent/workflows/kotlin-review.md +5 -5
  667. package/.agent/workflows/learn-eval.md +9 -9
  668. package/.agent/workflows/multi-plan.md +10 -10
  669. package/.agent/workflows/orchestrate.md +23 -119
  670. package/.agent/workflows/plan.md +2 -0
  671. package/.agent/workflows/preview.md +81 -81
  672. package/.agent/workflows/prompt-optimize.md +13 -28
  673. package/.agent/workflows/prp-commit.md +112 -0
  674. package/.agent/workflows/prp-implement.md +385 -0
  675. package/.agent/workflows/prp-plan.md +502 -0
  676. package/.agent/workflows/prp-pr.md +184 -0
  677. package/.agent/workflows/prp-prd.md +447 -0
  678. package/.agent/workflows/python-review.md +5 -5
  679. package/.agent/workflows/refactor-clean.md +1 -1
  680. package/.agent/workflows/resume-session.md +10 -10
  681. package/.agent/workflows/rules-distill.md +14 -5
  682. package/.agent/workflows/santa-loop.md +175 -0
  683. package/.agent/workflows/save-session.md +9 -9
  684. package/.agent/workflows/status.md +86 -86
  685. package/.agent/workflows/tdd.md +30 -127
  686. package/.agent/workflows/test-coverage.md +1 -1
  687. package/.agent/workflows/test.md +144 -144
  688. package/.agent/workflows/ui-ux-pro-max.md +295 -295
  689. package/.agent/workflows/verify.md +15 -51
  690. package/README.md +163 -136
  691. package/RELEASE.md +32 -36
  692. package/SLASH_COMMANDS.md +121 -0
  693. package/package.json +12 -3
  694. package/scripts/release-check.js +1 -1
  695. package/src/bin/cli.js +399 -53
  696. package/src/lib/installer.js +360 -114
  697. package/src/lib/manifests/stacks.js +122 -0
  698. package/src/lib/slash-commands.js +28 -0
  699. package/src/templates/claude/CLAUDE.en.md +42 -0
  700. package/src/templates/claude/CLAUDE.md +42 -0
  701. package/src/templates/claude/CLAUDE.vi.md +42 -0
  702. package/src/templates/codex/AGENTS.en.md +40 -0
  703. package/src/templates/codex/AGENTS.md +40 -0
  704. package/src/templates/codex/AGENTS.vi.md +40 -0
  705. package/src/templates/cursor/pilo-masterkit.mdc +20 -0
  706. package/src/templates/gemini/GEMINI.en.md +56 -0
  707. package/src/templates/gemini/GEMINI.md +56 -0
  708. package/src/templates/gemini/GEMINI.vi.md +56 -0
  709. package/src/templates/github/copilot-instructions.md +16 -0
@@ -0,0 +1,385 @@
1
+ ---
2
+ name: ai-regression-testing
3
+ description: Regression testing strategies for AI-assisted development. Sandbox-mode API testing without database dependencies, automated bug-check workflows, and patterns to catch AI blind spots where the same model writes and reviews code.
4
+ origin: ECC
5
+ ---
6
+
7
+ # AI Regression Testing
8
+
9
+ Testing patterns specifically designed for AI-assisted development, where the same model writes code and reviews it — creating systematic blind spots that only automated tests can catch.
10
+
11
+ ## When to Activate
12
+
13
+ - AI agent (Claude Code, Cursor, Codex) has modified API routes or backend logic
14
+ - A bug was found and fixed — need to prevent re-introduction
15
+ - Project has a sandbox/mock mode that can be leveraged for DB-free testing
16
+ - Running `/bug-check` or similar review commands after code changes
17
+ - Multiple code paths exist (sandbox vs production, feature flags, etc.)
18
+
19
+ ## The Core Problem
20
+
21
+ When an AI writes code and then reviews its own work, it carries the same assumptions into both steps. This creates a predictable failure pattern:
22
+
23
+ ```
24
+ AI writes fix → AI reviews fix → AI says "looks correct" → Bug still exists
25
+ ```
26
+
27
+ **Real-world example** (observed in production):
28
+
29
+ ```
30
+ Fix 1: Added notification_settings to API response
31
+ → Forgot to add it to the SELECT query
32
+ → AI reviewed and missed it (same blind spot)
33
+
34
+ Fix 2: Added it to SELECT query
35
+ → TypeScript build error (column not in generated types)
36
+ → AI reviewed Fix 1 but didn't catch the SELECT issue
37
+
38
+ Fix 3: Changed to SELECT *
39
+ → Fixed production path, forgot sandbox path
40
+ → AI reviewed and missed it AGAIN (4th occurrence)
41
+
42
+ Fix 4: Test caught it instantly on first run PASS:
43
+ ```
44
+
45
+ The pattern: **sandbox/production path inconsistency** is the #1 AI-introduced regression.
46
+
47
+ ## Sandbox-Mode API Testing
48
+
49
+ Most projects with AI-friendly architecture have a sandbox/mock mode. This is the key to fast, DB-free API testing.
50
+
51
+ ### Setup (Vitest + Next.js App Router)
52
+
53
+ ```typescript
54
+ // vitest.config.ts
55
+ import { defineConfig } from "vitest/config";
56
+ import path from "path";
57
+
58
+ export default defineConfig({
59
+ test: {
60
+ environment: "node",
61
+ globals: true,
62
+ include: ["__tests__/**/*.test.ts"],
63
+ setupFiles: ["__tests__/setup.ts"],
64
+ },
65
+ resolve: {
66
+ alias: {
67
+ "@": path.resolve(__dirname, "."),
68
+ },
69
+ },
70
+ });
71
+ ```
72
+
73
+ ```typescript
74
+ // __tests__/setup.ts
75
+ // Force sandbox mode — no database needed
76
+ process.env.SANDBOX_MODE = "true";
77
+ process.env.NEXT_PUBLIC_SUPABASE_URL = "";
78
+ process.env.NEXT_PUBLIC_SUPABASE_ANON_KEY = "";
79
+ ```
80
+
81
+ ### Test Helper for Next.js API Routes
82
+
83
+ ```typescript
84
+ // __tests__/helpers.ts
85
+ import { NextRequest } from "next/server";
86
+
87
+ export function createTestRequest(
88
+ url: string,
89
+ options?: {
90
+ method?: string;
91
+ body?: Record<string, unknown>;
92
+ headers?: Record<string, string>;
93
+ sandboxUserId?: string;
94
+ },
95
+ ): NextRequest {
96
+ const { method = "GET", body, headers = {}, sandboxUserId } = options || {};
97
+ const fullUrl = url.startsWith("http") ? url : `http://localhost:3000${url}`;
98
+ const reqHeaders: Record<string, string> = { ...headers };
99
+
100
+ if (sandboxUserId) {
101
+ reqHeaders["x-sandbox-user-id"] = sandboxUserId;
102
+ }
103
+
104
+ const init: { method: string; headers: Record<string, string>; body?: string } = {
105
+ method,
106
+ headers: reqHeaders,
107
+ };
108
+
109
+ if (body) {
110
+ init.body = JSON.stringify(body);
111
+ reqHeaders["content-type"] = "application/json";
112
+ }
113
+
114
+ return new NextRequest(fullUrl, init);
115
+ }
116
+
117
+ export async function parseResponse(response: Response) {
118
+ const json = await response.json();
119
+ return { status: response.status, json };
120
+ }
121
+ ```
122
+
123
+ ### Writing Regression Tests
124
+
125
+ The key principle: **write tests for bugs that were found, not for code that works**.
126
+
127
+ ```typescript
128
+ // __tests__/api/user/profile.test.ts
129
+ import { describe, it, expect } from "vitest";
130
+ import { createTestRequest, parseResponse } from "../../helpers";
131
+ import { GET, PATCH } from "@/app/api/user/profile/route";
132
+
133
+ // Define the contract — what fields MUST be in the response
134
+ const REQUIRED_FIELDS = [
135
+ "id",
136
+ "email",
137
+ "full_name",
138
+ "phone",
139
+ "role",
140
+ "created_at",
141
+ "avatar_url",
142
+ "notification_settings", // ← Added after bug found it missing
143
+ ];
144
+
145
+ describe("GET /api/user/profile", () => {
146
+ it("returns all required fields", async () => {
147
+ const req = createTestRequest("/api/user/profile");
148
+ const res = await GET(req);
149
+ const { status, json } = await parseResponse(res);
150
+
151
+ expect(status).toBe(200);
152
+ for (const field of REQUIRED_FIELDS) {
153
+ expect(json.data).toHaveProperty(field);
154
+ }
155
+ });
156
+
157
+ // Regression test — this exact bug was introduced by AI 4 times
158
+ it("notification_settings is not undefined (BUG-R1 regression)", async () => {
159
+ const req = createTestRequest("/api/user/profile");
160
+ const res = await GET(req);
161
+ const { json } = await parseResponse(res);
162
+
163
+ expect("notification_settings" in json.data).toBe(true);
164
+ const ns = json.data.notification_settings;
165
+ expect(ns === null || typeof ns === "object").toBe(true);
166
+ });
167
+ });
168
+ ```
169
+
170
+ ### Testing Sandbox/Production Parity
171
+
172
+ The most common AI regression: fixing production path but forgetting sandbox path (or vice versa).
173
+
174
+ ```typescript
175
+ // Test that sandbox responses match the expected contract
176
+ describe("GET /api/user/messages (conversation list)", () => {
177
+ it("includes partner_name in sandbox mode", async () => {
178
+ const req = createTestRequest("/api/user/messages", {
179
+ sandboxUserId: "user-001",
180
+ });
181
+ const res = await GET(req);
182
+ const { json } = await parseResponse(res);
183
+
184
+ // This caught a bug where partner_name was added
185
+ // to production path but not sandbox path
186
+ if (json.data.length > 0) {
187
+ for (const conv of json.data) {
188
+ expect("partner_name" in conv).toBe(true);
189
+ }
190
+ }
191
+ });
192
+ });
193
+ ```
194
+
195
+ ## Integrating Tests into Bug-Check Workflow
196
+
197
+ ### Custom Command Definition
198
+
199
+ ```markdown
200
+ <!-- .claude/commands/bug-check.md -->
201
+ # Bug Check
202
+
203
+ ## Step 1: Automated Tests (mandatory, cannot skip)
204
+
205
+ Run these commands FIRST before any code review:
206
+
207
+ npm run test # Vitest test suite
208
+ npm run build # TypeScript type check + build
209
+
210
+ - If tests fail → report as highest priority bug
211
+ - If build fails → report type errors as highest priority
212
+ - Only proceed to Step 2 if both pass
213
+
214
+ ## Step 2: Code Review (AI review)
215
+
216
+ 1. Sandbox / production path consistency
217
+ 2. API response shape matches frontend expectations
218
+ 3. SELECT clause completeness
219
+ 4. Error handling with rollback
220
+ 5. Optimistic update race conditions
221
+
222
+ ## Step 3: For each bug fixed, propose a regression test
223
+ ```
224
+
225
+ ### The Workflow
226
+
227
+ ```
228
+ User: "バグチェックして" (or "/bug-check")
229
+
230
+ ├─ Step 1: npm run test
231
+ │ ├─ FAIL → Bug found mechanically (no AI judgment needed)
232
+ │ └─ PASS → Continue
233
+
234
+ ├─ Step 2: npm run build
235
+ │ ├─ FAIL → Type error found mechanically
236
+ │ └─ PASS → Continue
237
+
238
+ ├─ Step 3: AI code review (with known blind spots in mind)
239
+ │ └─ Findings reported
240
+
241
+ └─ Step 4: For each fix, write a regression test
242
+ └─ Next bug-check catches if fix breaks
243
+ ```
244
+
245
+ ## Common AI Regression Patterns
246
+
247
+ ### Pattern 1: Sandbox/Production Path Mismatch
248
+
249
+ **Frequency**: Most common (observed in 3 out of 4 regressions)
250
+
251
+ ```typescript
252
+ // FAIL: AI adds field to production path only
253
+ if (isSandboxMode()) {
254
+ return { data: { id, email, name } }; // Missing new field
255
+ }
256
+ // Production path
257
+ return { data: { id, email, name, notification_settings } };
258
+
259
+ // PASS: Both paths must return the same shape
260
+ if (isSandboxMode()) {
261
+ return { data: { id, email, name, notification_settings: null } };
262
+ }
263
+ return { data: { id, email, name, notification_settings } };
264
+ ```
265
+
266
+ **Test to catch it**:
267
+
268
+ ```typescript
269
+ it("sandbox and production return same fields", async () => {
270
+ // In test env, sandbox mode is forced ON
271
+ const res = await GET(createTestRequest("/api/user/profile"));
272
+ const { json } = await parseResponse(res);
273
+
274
+ for (const field of REQUIRED_FIELDS) {
275
+ expect(json.data).toHaveProperty(field);
276
+ }
277
+ });
278
+ ```
279
+
280
+ ### Pattern 2: SELECT Clause Omission
281
+
282
+ **Frequency**: Common with Supabase/Prisma when adding new columns
283
+
284
+ ```typescript
285
+ // FAIL: New column added to response but not to SELECT
286
+ const { data } = await supabase
287
+ .from("users")
288
+ .select("id, email, name") // notification_settings not here
289
+ .single();
290
+
291
+ return { data: { ...data, notification_settings: data.notification_settings } };
292
+ // → notification_settings is always undefined
293
+
294
+ // PASS: Use SELECT * or explicitly include new columns
295
+ const { data } = await supabase
296
+ .from("users")
297
+ .select("*")
298
+ .single();
299
+ ```
300
+
301
+ ### Pattern 3: Error State Leakage
302
+
303
+ **Frequency**: Moderate — when adding error handling to existing components
304
+
305
+ ```typescript
306
+ // FAIL: Error state set but old data not cleared
307
+ catch (err) {
308
+ setError("Failed to load");
309
+ // reservations still shows data from previous tab!
310
+ }
311
+
312
+ // PASS: Clear related state on error
313
+ catch (err) {
314
+ setReservations([]); // Clear stale data
315
+ setError("Failed to load");
316
+ }
317
+ ```
318
+
319
+ ### Pattern 4: Optimistic Update Without Proper Rollback
320
+
321
+ ```typescript
322
+ // FAIL: No rollback on failure
323
+ const handleRemove = async (id: string) => {
324
+ setItems(prev => prev.filter(i => i.id !== id));
325
+ await fetch(`/api/items/${id}`, { method: "DELETE" });
326
+ // If API fails, item is gone from UI but still in DB
327
+ };
328
+
329
+ // PASS: Capture previous state and rollback on failure
330
+ const handleRemove = async (id: string) => {
331
+ const prevItems = [...items];
332
+ setItems(prev => prev.filter(i => i.id !== id));
333
+ try {
334
+ const res = await fetch(`/api/items/${id}`, { method: "DELETE" });
335
+ if (!res.ok) throw new Error("API error");
336
+ } catch {
337
+ setItems(prevItems); // Rollback
338
+ alert("削除に失敗しました");
339
+ }
340
+ };
341
+ ```
342
+
343
+ ## Strategy: Test Where Bugs Were Found
344
+
345
+ Don't aim for 100% coverage. Instead:
346
+
347
+ ```
348
+ Bug found in /api/user/profile → Write test for profile API
349
+ Bug found in /api/user/messages → Write test for messages API
350
+ Bug found in /api/user/favorites → Write test for favorites API
351
+ No bug in /api/user/notifications → Don't write test (yet)
352
+ ```
353
+
354
+ **Why this works with AI development:**
355
+
356
+ 1. AI tends to make the **same category of mistake** repeatedly
357
+ 2. Bugs cluster in complex areas (auth, multi-path logic, state management)
358
+ 3. Once tested, that exact regression **cannot happen again**
359
+ 4. Test count grows organically with bug fixes — no wasted effort
360
+
361
+ ## Quick Reference
362
+
363
+ | AI Regression Pattern | Test Strategy | Priority |
364
+ |---|---|---|
365
+ | Sandbox/production mismatch | Assert same response shape in sandbox mode | High |
366
+ | SELECT clause omission | Assert all required fields in response | High |
367
+ | Error state leakage | Assert state cleanup on error | Medium |
368
+ | Missing rollback | Assert state restored on API failure | Medium |
369
+ | Type cast masking null | Assert field is not undefined | Medium |
370
+
371
+ ## DO / DON'T
372
+
373
+ **DO:**
374
+ - Write tests immediately after finding a bug (before fixing it if possible)
375
+ - Test the API response shape, not the implementation
376
+ - Run tests as the first step of every bug-check
377
+ - Keep tests fast (< 1 second total with sandbox mode)
378
+ - Name tests after the bug they prevent (e.g., "BUG-R1 regression")
379
+
380
+ **DON'T:**
381
+ - Write tests for code that has never had a bug
382
+ - Trust AI self-review as a substitute for automated tests
383
+ - Skip sandbox path testing because "it's just mock data"
384
+ - Write integration tests when unit tests suffice
385
+ - Aim for coverage percentage — aim for regression prevention
@@ -0,0 +1,339 @@
1
+ ---
2
+ name: android-clean-architecture
3
+ description: Clean Architecture patterns for Android and Kotlin Multiplatform projects — module structure, dependency rules, UseCases, Repositories, and data layer patterns.
4
+ origin: ECC
5
+ ---
6
+
7
+ # Android Clean Architecture
8
+
9
+ Clean Architecture patterns for Android and KMP projects. Covers module boundaries, dependency inversion, UseCase/Repository patterns, and data layer design with Room, SQLDelight, and Ktor.
10
+
11
+ ## When to Activate
12
+
13
+ - Structuring Android or KMP project modules
14
+ - Implementing UseCases, Repositories, or DataSources
15
+ - Designing data flow between layers (domain, data, presentation)
16
+ - Setting up dependency injection with Koin or Hilt
17
+ - Working with Room, SQLDelight, or Ktor in a layered architecture
18
+
19
+ ## Module Structure
20
+
21
+ ### Recommended Layout
22
+
23
+ ```
24
+ project/
25
+ ├── app/ # Android entry point, DI wiring, Application class
26
+ ├── core/ # Shared utilities, base classes, error types
27
+ ├── domain/ # UseCases, domain models, repository interfaces (pure Kotlin)
28
+ ├── data/ # Repository implementations, DataSources, DB, network
29
+ ├── presentation/ # Screens, ViewModels, UI models, navigation
30
+ ├── design-system/ # Reusable Compose components, theme, typography
31
+ └── feature/ # Feature modules (optional, for larger projects)
32
+ ├── auth/
33
+ ├── settings/
34
+ └── profile/
35
+ ```
36
+
37
+ ### Dependency Rules
38
+
39
+ ```
40
+ app → presentation, domain, data, core
41
+ presentation → domain, design-system, core
42
+ data → domain, core
43
+ domain → core (or no dependencies)
44
+ core → (nothing)
45
+ ```
46
+
47
+ **Critical**: `domain` must NEVER depend on `data`, `presentation`, or any framework. It contains pure Kotlin only.
48
+
49
+ ## Domain Layer
50
+
51
+ ### UseCase Pattern
52
+
53
+ Each UseCase represents one business operation. Use `operator fun invoke` for clean call sites:
54
+
55
+ ```kotlin
56
+ class GetItemsByCategoryUseCase(
57
+ private val repository: ItemRepository
58
+ ) {
59
+ suspend operator fun invoke(category: String): Result<List<Item>> {
60
+ return repository.getItemsByCategory(category)
61
+ }
62
+ }
63
+
64
+ // Flow-based UseCase for reactive streams
65
+ class ObserveUserProgressUseCase(
66
+ private val repository: UserRepository
67
+ ) {
68
+ operator fun invoke(userId: String): Flow<UserProgress> {
69
+ return repository.observeProgress(userId)
70
+ }
71
+ }
72
+ ```
73
+
74
+ ### Domain Models
75
+
76
+ Domain models are plain Kotlin data classes — no framework annotations:
77
+
78
+ ```kotlin
79
+ data class Item(
80
+ val id: String,
81
+ val title: String,
82
+ val description: String,
83
+ val tags: List<String>,
84
+ val status: Status,
85
+ val category: String
86
+ )
87
+
88
+ enum class Status { DRAFT, ACTIVE, ARCHIVED }
89
+ ```
90
+
91
+ ### Repository Interfaces
92
+
93
+ Defined in domain, implemented in data:
94
+
95
+ ```kotlin
96
+ interface ItemRepository {
97
+ suspend fun getItemsByCategory(category: String): Result<List<Item>>
98
+ suspend fun saveItem(item: Item): Result<Unit>
99
+ fun observeItems(): Flow<List<Item>>
100
+ }
101
+ ```
102
+
103
+ ## Data Layer
104
+
105
+ ### Repository Implementation
106
+
107
+ Coordinates between local and remote data sources:
108
+
109
+ ```kotlin
110
+ class ItemRepositoryImpl(
111
+ private val localDataSource: ItemLocalDataSource,
112
+ private val remoteDataSource: ItemRemoteDataSource
113
+ ) : ItemRepository {
114
+
115
+ override suspend fun getItemsByCategory(category: String): Result<List<Item>> {
116
+ return runCatching {
117
+ val remote = remoteDataSource.fetchItems(category)
118
+ localDataSource.insertItems(remote.map { it.toEntity() })
119
+ localDataSource.getItemsByCategory(category).map { it.toDomain() }
120
+ }
121
+ }
122
+
123
+ override suspend fun saveItem(item: Item): Result<Unit> {
124
+ return runCatching {
125
+ localDataSource.insertItems(listOf(item.toEntity()))
126
+ }
127
+ }
128
+
129
+ override fun observeItems(): Flow<List<Item>> {
130
+ return localDataSource.observeAll().map { entities ->
131
+ entities.map { it.toDomain() }
132
+ }
133
+ }
134
+ }
135
+ ```
136
+
137
+ ### Mapper Pattern
138
+
139
+ Keep mappers as extension functions near the data models:
140
+
141
+ ```kotlin
142
+ // In data layer
143
+ fun ItemEntity.toDomain() = Item(
144
+ id = id,
145
+ title = title,
146
+ description = description,
147
+ tags = tags.split("|"),
148
+ status = Status.valueOf(status),
149
+ category = category
150
+ )
151
+
152
+ fun ItemDto.toEntity() = ItemEntity(
153
+ id = id,
154
+ title = title,
155
+ description = description,
156
+ tags = tags.joinToString("|"),
157
+ status = status,
158
+ category = category
159
+ )
160
+ ```
161
+
162
+ ### Room Database (Android)
163
+
164
+ ```kotlin
165
+ @Entity(tableName = "items")
166
+ data class ItemEntity(
167
+ @PrimaryKey val id: String,
168
+ val title: String,
169
+ val description: String,
170
+ val tags: String,
171
+ val status: String,
172
+ val category: String
173
+ )
174
+
175
+ @Dao
176
+ interface ItemDao {
177
+ @Query("SELECT * FROM items WHERE category = :category")
178
+ suspend fun getByCategory(category: String): List<ItemEntity>
179
+
180
+ @Upsert
181
+ suspend fun upsert(items: List<ItemEntity>)
182
+
183
+ @Query("SELECT * FROM items")
184
+ fun observeAll(): Flow<List<ItemEntity>>
185
+ }
186
+ ```
187
+
188
+ ### SQLDelight (KMP)
189
+
190
+ ```sql
191
+ -- Item.sq
192
+ CREATE TABLE ItemEntity (
193
+ id TEXT NOT NULL PRIMARY KEY,
194
+ title TEXT NOT NULL,
195
+ description TEXT NOT NULL,
196
+ tags TEXT NOT NULL,
197
+ status TEXT NOT NULL,
198
+ category TEXT NOT NULL
199
+ );
200
+
201
+ getByCategory:
202
+ SELECT * FROM ItemEntity WHERE category = ?;
203
+
204
+ upsert:
205
+ INSERT OR REPLACE INTO ItemEntity (id, title, description, tags, status, category)
206
+ VALUES (?, ?, ?, ?, ?, ?);
207
+
208
+ observeAll:
209
+ SELECT * FROM ItemEntity;
210
+ ```
211
+
212
+ ### Ktor Network Client (KMP)
213
+
214
+ ```kotlin
215
+ class ItemRemoteDataSource(private val client: HttpClient) {
216
+
217
+ suspend fun fetchItems(category: String): List<ItemDto> {
218
+ return client.get("api/items") {
219
+ parameter("category", category)
220
+ }.body()
221
+ }
222
+ }
223
+
224
+ // HttpClient setup with content negotiation
225
+ val httpClient = HttpClient {
226
+ install(ContentNegotiation) { json(Json { ignoreUnknownKeys = true }) }
227
+ install(Logging) { level = LogLevel.HEADERS }
228
+ defaultRequest { url("https://api.example.com/") }
229
+ }
230
+ ```
231
+
232
+ ## Dependency Injection
233
+
234
+ ### Koin (KMP-friendly)
235
+
236
+ ```kotlin
237
+ // Domain module
238
+ val domainModule = module {
239
+ factory { GetItemsByCategoryUseCase(get()) }
240
+ factory { ObserveUserProgressUseCase(get()) }
241
+ }
242
+
243
+ // Data module
244
+ val dataModule = module {
245
+ single<ItemRepository> { ItemRepositoryImpl(get(), get()) }
246
+ single { ItemLocalDataSource(get()) }
247
+ single { ItemRemoteDataSource(get()) }
248
+ }
249
+
250
+ // Presentation module
251
+ val presentationModule = module {
252
+ viewModelOf(::ItemListViewModel)
253
+ viewModelOf(::DashboardViewModel)
254
+ }
255
+ ```
256
+
257
+ ### Hilt (Android-only)
258
+
259
+ ```kotlin
260
+ @Module
261
+ @InstallIn(SingletonComponent::class)
262
+ abstract class RepositoryModule {
263
+ @Binds
264
+ abstract fun bindItemRepository(impl: ItemRepositoryImpl): ItemRepository
265
+ }
266
+
267
+ @HiltViewModel
268
+ class ItemListViewModel @Inject constructor(
269
+ private val getItems: GetItemsByCategoryUseCase
270
+ ) : ViewModel()
271
+ ```
272
+
273
+ ## Error Handling
274
+
275
+ ### Result/Try Pattern
276
+
277
+ Use `Result<T>` or a custom sealed type for error propagation:
278
+
279
+ ```kotlin
280
+ sealed interface Try<out T> {
281
+ data class Success<T>(val value: T) : Try<T>
282
+ data class Failure(val error: AppError) : Try<Nothing>
283
+ }
284
+
285
+ sealed interface AppError {
286
+ data class Network(val message: String) : AppError
287
+ data class Database(val message: String) : AppError
288
+ data object Unauthorized : AppError
289
+ }
290
+
291
+ // In ViewModel — map to UI state
292
+ viewModelScope.launch {
293
+ when (val result = getItems(category)) {
294
+ is Try.Success -> _state.update { it.copy(items = result.value, isLoading = false) }
295
+ is Try.Failure -> _state.update { it.copy(error = result.error.toMessage(), isLoading = false) }
296
+ }
297
+ }
298
+ ```
299
+
300
+ ## Convention Plugins (Gradle)
301
+
302
+ For KMP projects, use convention plugins to reduce build file duplication:
303
+
304
+ ```kotlin
305
+ // build-logic/src/main/kotlin/kmp-library.gradle.kts
306
+ plugins {
307
+ id("org.jetbrains.kotlin.multiplatform")
308
+ }
309
+
310
+ kotlin {
311
+ androidTarget()
312
+ iosX64(); iosArm64(); iosSimulatorArm64()
313
+ sourceSets {
314
+ commonMain.dependencies { /* shared deps */ }
315
+ commonTest.dependencies { implementation(kotlin("test")) }
316
+ }
317
+ }
318
+ ```
319
+
320
+ Apply in modules:
321
+
322
+ ```kotlin
323
+ // domain/build.gradle.kts
324
+ plugins { id("kmp-library") }
325
+ ```
326
+
327
+ ## Anti-Patterns to Avoid
328
+
329
+ - Importing Android framework classes in `domain` — keep it pure Kotlin
330
+ - Exposing database entities or DTOs to the UI layer — always map to domain models
331
+ - Putting business logic in ViewModels — extract to UseCases
332
+ - Using `GlobalScope` or unstructured coroutines — use `viewModelScope` or structured concurrency
333
+ - Fat repository implementations — split into focused DataSources
334
+ - Circular module dependencies — if A depends on B, B must not depend on A
335
+
336
+ ## References
337
+
338
+ See skill: `compose-multiplatform-patterns` for UI patterns.
339
+ See skill: `kotlin-coroutines-flows` for async patterns.