@heyai-rules/pilo-masterkit 1.2.2 → 3.1.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 (594) hide show
  1. package/.agent/agents/architect.md +211 -211
  2. package/.agent/agents/build-error-resolver.md +114 -114
  3. package/.agent/agents/chief-of-staff.md +151 -151
  4. package/.agent/agents/code-reviewer.md +237 -237
  5. package/.agent/agents/cpp-build-resolver.md +90 -90
  6. package/.agent/agents/cpp-reviewer.md +72 -72
  7. package/.agent/agents/csharp-reviewer.md +101 -0
  8. package/.agent/agents/dart-build-resolver.md +201 -0
  9. package/.agent/agents/database-reviewer.md +91 -91
  10. package/.agent/agents/doc-updater.md +107 -107
  11. package/.agent/agents/docs-lookup.md +68 -68
  12. package/.agent/agents/e2e-runner.md +107 -107
  13. package/.agent/agents/flutter-reviewer.md +243 -243
  14. package/.agent/agents/gan-evaluator.md +209 -0
  15. package/.agent/agents/gan-generator.md +131 -0
  16. package/.agent/agents/gan-planner.md +99 -0
  17. package/.agent/agents/go-build-resolver.md +94 -94
  18. package/.agent/agents/go-reviewer.md +76 -76
  19. package/.agent/agents/harness-optimizer.md +35 -35
  20. package/.agent/agents/healthcare-reviewer.md +83 -0
  21. package/.agent/agents/java-build-resolver.md +153 -153
  22. package/.agent/agents/java-reviewer.md +92 -92
  23. package/.agent/agents/kotlin-build-resolver.md +118 -118
  24. package/.agent/agents/kotlin-reviewer.md +159 -159
  25. package/.agent/agents/loop-operator.md +36 -36
  26. package/.agent/agents/opensource-forker.md +198 -0
  27. package/.agent/agents/opensource-packager.md +249 -0
  28. package/.agent/agents/opensource-sanitizer.md +188 -0
  29. package/.agent/agents/performance-optimizer.md +392 -133
  30. package/.agent/agents/personas/athena-agent/agent.json +10 -0
  31. package/.agent/agents/personas/athena-agent/athena-backend-logic-architecture-profile.md +189 -0
  32. package/.agent/agents/personas/athena-agent/context-files/agents.md +55 -0
  33. package/.agent/agents/personas/athena-agent/context-files/identity.md +23 -0
  34. package/.agent/agents/personas/athena-agent/context-files/soul.md +51 -0
  35. package/.agent/agents/personas/athena-agent/context-files/user-predefined.md +15 -0
  36. package/.agent/agents/personas/athena-agent/user-context-files/system/bootstrap.md +37 -0
  37. package/.agent/agents/personas/athena-agent/user-context-files/system/user.md +45 -0
  38. package/.agent/agents/personas/da-vinci-agent/agent.json +10 -0
  39. package/.agent/agents/personas/da-vinci-agent/context-files/agents.md +55 -0
  40. package/.agent/agents/personas/da-vinci-agent/context-files/identity.md +23 -0
  41. package/.agent/agents/personas/da-vinci-agent/context-files/soul.md +51 -0
  42. package/.agent/agents/personas/da-vinci-agent/context-files/user-predefined.md +15 -0
  43. package/.agent/agents/personas/da-vinci-agent/da-vinci-frontend-ui-ux-design-profile.md +189 -0
  44. package/.agent/agents/personas/da-vinci-agent/user-context-files/system/bootstrap.md +37 -0
  45. package/.agent/agents/personas/da-vinci-agent/user-context-files/system/user.md +45 -0
  46. package/.agent/agents/personas/duong-tang-agent/agent.json +10 -0
  47. package/.agent/agents/personas/duong-tang-agent/context-files/agents.md +55 -0
  48. package/.agent/agents/personas/duong-tang-agent/context-files/identity.md +23 -0
  49. package/.agent/agents/personas/duong-tang-agent/context-files/soul.md +51 -0
  50. package/.agent/agents/personas/duong-tang-agent/context-files/user-predefined.md +15 -0
  51. package/.agent/agents/personas/duong-tang-agent/tang-monk-quality-testing-documentation-profile.md +189 -0
  52. package/.agent/agents/personas/duong-tang-agent/user-context-files/system/bootstrap.md +37 -0
  53. package/.agent/agents/personas/duong-tang-agent/user-context-files/system/user.md +45 -0
  54. package/.agent/agents/personas/gia-cat-luong-agent/agent.json +10 -0
  55. package/.agent/agents/personas/gia-cat-luong-agent/context-files/agents.md +55 -0
  56. package/.agent/agents/personas/gia-cat-luong-agent/context-files/identity.md +23 -0
  57. package/.agent/agents/personas/gia-cat-luong-agent/context-files/soul.md +51 -0
  58. package/.agent/agents/personas/gia-cat-luong-agent/context-files/user-predefined.md +15 -0
  59. package/.agent/agents/personas/gia-cat-luong-agent/kongming-research-strategy-analysis-profile.md +189 -0
  60. package/.agent/agents/personas/gia-cat-luong-agent/user-context-files/system/bootstrap.md +37 -0
  61. package/.agent/agents/personas/gia-cat-luong-agent/user-context-files/system/user.md +45 -0
  62. package/.agent/agents/personas/mihata-agent/agent.json +10 -0
  63. package/.agent/agents/personas/mihata-agent/context-files/agents.md +55 -0
  64. package/.agent/agents/personas/mihata-agent/context-files/identity.md +23 -0
  65. package/.agent/agents/personas/mihata-agent/context-files/soul.md +51 -0
  66. package/.agent/agents/personas/mihata-agent/context-files/user-predefined.md +15 -0
  67. package/.agent/agents/personas/mihata-agent/mihata-multi-agent-orchestration-profile.md +189 -0
  68. package/.agent/agents/personas/mihata-agent/user-context-files/system/bootstrap.md +37 -0
  69. package/.agent/agents/personas/mihata-agent/user-context-files/system/user.md +45 -0
  70. package/.agent/agents/personas/tesla-agent/agent.json +10 -0
  71. package/.agent/agents/personas/tesla-agent/context-files/agents.md +55 -0
  72. package/.agent/agents/personas/tesla-agent/context-files/identity.md +23 -0
  73. package/.agent/agents/personas/tesla-agent/context-files/soul.md +51 -0
  74. package/.agent/agents/personas/tesla-agent/context-files/user-predefined.md +15 -0
  75. package/.agent/agents/personas/tesla-agent/tesla-fullstack-system-optimization-profile.md +189 -0
  76. package/.agent/agents/personas/tesla-agent/user-context-files/system/bootstrap.md +37 -0
  77. package/.agent/agents/personas/tesla-agent/user-context-files/system/user.md +45 -0
  78. package/.agent/agents/personas/tu-ma-y-agent/agent.json +10 -0
  79. package/.agent/agents/personas/tu-ma-y-agent/context-files/agents.md +55 -0
  80. package/.agent/agents/personas/tu-ma-y-agent/context-files/identity.md +23 -0
  81. package/.agent/agents/personas/tu-ma-y-agent/context-files/soul.md +51 -0
  82. package/.agent/agents/personas/tu-ma-y-agent/context-files/user-predefined.md +15 -0
  83. package/.agent/agents/personas/tu-ma-y-agent/simayi-feasibility-risk-control-profile.md +189 -0
  84. package/.agent/agents/personas/tu-ma-y-agent/user-context-files/system/bootstrap.md +37 -0
  85. package/.agent/agents/personas/tu-ma-y-agent/user-context-files/system/user.md +45 -0
  86. package/.agent/agents/personas/venti-agent/agent.json +10 -0
  87. package/.agent/agents/personas/venti-agent/context-files/agents.md +55 -0
  88. package/.agent/agents/personas/venti-agent/context-files/identity.md +23 -0
  89. package/.agent/agents/personas/venti-agent/context-files/soul.md +51 -0
  90. package/.agent/agents/personas/venti-agent/context-files/user-predefined.md +15 -0
  91. package/.agent/agents/personas/venti-agent/user-context-files/system/bootstrap.md +37 -0
  92. package/.agent/agents/personas/venti-agent/user-context-files/system/user.md +45 -0
  93. package/.agent/agents/personas/venti-agent/venti-learning-communication-mentoring-profile.md +189 -0
  94. package/.agent/agents/planner.md +212 -212
  95. package/.agent/agents/python-reviewer.md +98 -98
  96. package/.agent/agents/pytorch-build-resolver.md +120 -120
  97. package/.agent/agents/refactor-cleaner.md +85 -85
  98. package/.agent/agents/rust-build-resolver.md +148 -148
  99. package/.agent/agents/rust-reviewer.md +94 -94
  100. package/.agent/agents/security-reviewer.md +108 -108
  101. package/.agent/agents/tdd-guide.md +91 -91
  102. package/.agent/agents/typescript-reviewer.md +112 -112
  103. package/.agent/contexts/dev.md +20 -0
  104. package/.agent/contexts/research.md +26 -0
  105. package/.agent/contexts/review.md +22 -0
  106. package/.agent/hooks/hooks.json +395 -0
  107. package/.agent/hooks/readme.md +222 -0
  108. package/.agent/mcp-configs/mcp-servers.json +181 -0
  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/skills/agent-eval/SKILL.md +145 -0
  199. package/.agent/skills/agent-harness-construction/SKILL.md +73 -0
  200. package/.agent/skills/agent-payment-x402/SKILL.md +178 -0
  201. package/.agent/skills/agentic-engineering/SKILL.md +63 -0
  202. package/.agent/skills/ai-first-engineering/SKILL.md +51 -0
  203. package/.agent/skills/ai-regression-testing/SKILL.md +385 -0
  204. package/.agent/skills/android-clean-architecture/SKILL.md +339 -0
  205. package/.agent/skills/api-design/SKILL.md +523 -0
  206. package/.agent/skills/architecture-decision-records/SKILL.md +179 -0
  207. package/.agent/skills/article-writing/SKILL.md +79 -0
  208. package/.agent/skills/autonomous-agent-harness/SKILL.md +267 -0
  209. package/.agent/skills/autonomous-loops/SKILL.md +610 -0
  210. package/.agent/skills/backend-patterns/SKILL.md +598 -0
  211. package/.agent/skills/benchmark/SKILL.md +93 -0
  212. package/.agent/skills/blueprint/SKILL.md +105 -0
  213. package/.agent/skills/brand-voice/SKILL.md +97 -0
  214. package/.agent/skills/brand-voice/references/voice-profile-schema.md +55 -0
  215. package/.agent/skills/browser-qa/SKILL.md +87 -0
  216. package/.agent/skills/bun-runtime/SKILL.md +84 -0
  217. package/.agent/skills/canary-watch/SKILL.md +99 -0
  218. package/.agent/skills/carrier-relationship-management/SKILL.md +212 -0
  219. package/.agent/skills/ck/SKILL.md +147 -0
  220. package/.agent/skills/ck/commands/forget.mjs +44 -0
  221. package/.agent/skills/ck/commands/info.mjs +24 -0
  222. package/.agent/skills/ck/commands/init.mjs +143 -0
  223. package/.agent/skills/ck/commands/list.mjs +40 -0
  224. package/.agent/skills/ck/commands/migrate.mjs +202 -0
  225. package/.agent/skills/ck/commands/resume.mjs +36 -0
  226. package/.agent/skills/ck/commands/save.mjs +210 -0
  227. package/.agent/skills/ck/commands/shared.mjs +387 -0
  228. package/.agent/skills/ck/hooks/session-start.mjs +224 -0
  229. package/.agent/skills/claude-api/SKILL.md +337 -0
  230. package/.agent/skills/claude-devfleet/SKILL.md +103 -0
  231. package/.agent/skills/click-path-audit/SKILL.md +244 -0
  232. package/.agent/skills/clickhouse-io/SKILL.md +439 -0
  233. package/.agent/skills/codebase-onboarding/SKILL.md +233 -0
  234. package/.agent/skills/coding-standards/SKILL.md +530 -0
  235. package/.agent/skills/compose-multiplatform-patterns/SKILL.md +299 -0
  236. package/.agent/skills/configure-ecc/SKILL.md +367 -0
  237. package/.agent/skills/connections-optimizer/SKILL.md +189 -0
  238. package/.agent/skills/content-engine/SKILL.md +131 -0
  239. package/.agent/skills/content-hash-cache-pattern/SKILL.md +161 -0
  240. package/.agent/skills/context-budget/SKILL.md +135 -0
  241. package/.agent/skills/continuous-agent-loop/SKILL.md +45 -0
  242. package/.agent/skills/continuous-learning/SKILL.md +119 -0
  243. package/.agent/skills/continuous-learning/config.json +18 -0
  244. package/.agent/skills/continuous-learning/evaluate-session.sh +69 -0
  245. package/.agent/skills/continuous-learning-v2/SKILL.md +365 -0
  246. package/.agent/skills/continuous-learning-v2/agents/observer-loop.sh +271 -0
  247. package/.agent/skills/continuous-learning-v2/agents/observer.md +198 -0
  248. package/.agent/skills/continuous-learning-v2/agents/session-guardian.sh +150 -0
  249. package/.agent/skills/continuous-learning-v2/agents/start-observer.sh +244 -0
  250. package/.agent/skills/continuous-learning-v2/config.json +8 -0
  251. package/.agent/skills/continuous-learning-v2/hooks/observe.sh +428 -0
  252. package/.agent/skills/continuous-learning-v2/scripts/detect-project.sh +228 -0
  253. package/.agent/skills/continuous-learning-v2/scripts/instinct-cli.py +1426 -0
  254. package/.agent/skills/continuous-learning-v2/scripts/test-parse-instinct.py +984 -0
  255. package/.agent/skills/cost-aware-llm-pipeline/SKILL.md +183 -0
  256. package/.agent/skills/cpp-coding-standards/SKILL.md +723 -0
  257. package/.agent/skills/cpp-testing/SKILL.md +324 -0
  258. package/.agent/skills/crosspost/SKILL.md +111 -0
  259. package/.agent/skills/csharp-testing/SKILL.md +321 -0
  260. package/.agent/skills/customer-billing-ops/SKILL.md +140 -0
  261. package/.agent/skills/customs-trade-compliance/SKILL.md +263 -0
  262. package/.agent/skills/dart-flutter-patterns/SKILL.md +563 -0
  263. package/.agent/skills/data-scraper-agent/SKILL.md +764 -0
  264. package/.agent/skills/database-migrations/SKILL.md +429 -0
  265. package/.agent/skills/deep-research/SKILL.md +155 -0
  266. package/.agent/skills/deployment-patterns/SKILL.md +427 -0
  267. package/.agent/skills/design-system/SKILL.md +82 -0
  268. package/.agent/skills/django-patterns/SKILL.md +734 -0
  269. package/.agent/skills/django-security/SKILL.md +593 -0
  270. package/.agent/skills/django-tdd/SKILL.md +729 -0
  271. package/.agent/skills/django-verification/SKILL.md +469 -0
  272. package/.agent/skills/dmux-workflows/SKILL.md +191 -0
  273. package/.agent/skills/docker-patterns/SKILL.md +364 -0
  274. package/.agent/skills/documentation-lookup/SKILL.md +90 -0
  275. package/.agent/skills/dotnet-patterns/SKILL.md +321 -0
  276. package/.agent/skills/e2e-testing/SKILL.md +326 -0
  277. package/.agent/skills/energy-procurement/SKILL.md +228 -0
  278. package/.agent/skills/enterprise-agent-ops/SKILL.md +50 -0
  279. package/.agent/skills/eval-harness/SKILL.md +270 -0
  280. package/.agent/skills/exa-search/SKILL.md +103 -0
  281. package/.agent/skills/fal-ai-media/SKILL.md +284 -0
  282. package/.agent/skills/flutter-dart-code-review/SKILL.md +435 -0
  283. package/.agent/skills/foundation-models-on-device/SKILL.md +243 -0
  284. package/.agent/skills/frontend-patterns/SKILL.md +642 -0
  285. package/.agent/skills/frontend-slides/SKILL.md +184 -0
  286. package/.agent/skills/frontend-slides/style-presets.md +330 -0
  287. package/.agent/skills/gan-style-harness/SKILL.md +278 -0
  288. package/.agent/skills/git-workflow/SKILL.md +715 -0
  289. package/.agent/skills/golang-patterns/SKILL.md +674 -0
  290. package/.agent/skills/golang-testing/SKILL.md +720 -0
  291. package/.agent/skills/google-workspace-ops/SKILL.md +95 -0
  292. package/.agent/skills/healthcare-cdss-patterns/SKILL.md +245 -0
  293. package/.agent/skills/healthcare-emr-patterns/SKILL.md +159 -0
  294. package/.agent/skills/healthcare-eval-harness/SKILL.md +207 -0
  295. package/.agent/skills/healthcare-phi-compliance/SKILL.md +145 -0
  296. package/.agent/skills/hexagonal-architecture/SKILL.md +276 -0
  297. package/.agent/skills/inventory-demand-planning/SKILL.md +247 -0
  298. package/.agent/skills/investor-materials/SKILL.md +96 -0
  299. package/.agent/skills/investor-outreach/SKILL.md +91 -0
  300. package/.agent/skills/iterative-retrieval/SKILL.md +211 -0
  301. package/.agent/skills/java-coding-standards/SKILL.md +147 -0
  302. package/.agent/skills/jira-integration/SKILL.md +293 -0
  303. package/.agent/skills/jpa-patterns/SKILL.md +151 -0
  304. package/.agent/skills/kotlin-coroutines-flows/SKILL.md +284 -0
  305. package/.agent/skills/kotlin-exposed-patterns/SKILL.md +719 -0
  306. package/.agent/skills/kotlin-ktor-patterns/SKILL.md +689 -0
  307. package/.agent/skills/kotlin-patterns/SKILL.md +711 -0
  308. package/.agent/skills/kotlin-testing/SKILL.md +824 -0
  309. package/.agent/skills/laravel-patterns/SKILL.md +415 -0
  310. package/.agent/skills/laravel-plugin-discovery/SKILL.md +229 -0
  311. package/.agent/skills/laravel-security/SKILL.md +285 -0
  312. package/.agent/skills/laravel-tdd/SKILL.md +283 -0
  313. package/.agent/skills/laravel-verification/SKILL.md +179 -0
  314. package/.agent/skills/lead-intelligence/SKILL.md +321 -0
  315. package/.agent/skills/lead-intelligence/agents/enrichment-agent.md +85 -0
  316. package/.agent/skills/lead-intelligence/agents/mutual-mapper.md +75 -0
  317. package/.agent/skills/lead-intelligence/agents/outreach-drafter.md +98 -0
  318. package/.agent/skills/lead-intelligence/agents/signal-scorer.md +60 -0
  319. package/.agent/skills/liquid-glass-design/SKILL.md +279 -0
  320. package/.agent/skills/logistics-exception-management/SKILL.md +222 -0
  321. package/.agent/skills/manim-video/SKILL.md +89 -0
  322. package/.agent/skills/manim-video/assets/network-graph-scene.py +52 -0
  323. package/.agent/skills/market-research/SKILL.md +75 -0
  324. package/.agent/skills/mcp-builder/SKILL.md +173 -113
  325. package/.agent/skills/mcp-builder/license.txt +202 -0
  326. package/.agent/skills/mcp-builder/reference/evaluation.md +602 -0
  327. package/.agent/skills/mcp-builder/reference/mcp-best-practices.md +249 -0
  328. package/.agent/skills/mcp-builder/reference/node-mcp-server.md +970 -0
  329. package/.agent/skills/mcp-builder/reference/python-mcp-server.md +719 -0
  330. package/.agent/skills/mcp-builder/scripts/connections.py +151 -0
  331. package/.agent/skills/mcp-builder/scripts/evaluation.py +373 -0
  332. package/.agent/skills/mcp-builder/scripts/example-evaluation.xml +22 -0
  333. package/.agent/skills/mcp-builder/scripts/requirements.txt +2 -0
  334. package/.agent/skills/mcp-server-patterns/SKILL.md +67 -0
  335. package/.agent/skills/nanoclaw-repl/SKILL.md +33 -0
  336. package/.agent/skills/nestjs-patterns/SKILL.md +230 -0
  337. package/.agent/skills/nextjs-turbopack/SKILL.md +44 -0
  338. package/.agent/skills/nutrient-document-processing/SKILL.md +167 -0
  339. package/.agent/skills/nuxt4-patterns/SKILL.md +100 -0
  340. package/.agent/skills/openclaw-persona-forge/SKILL.md +296 -0
  341. package/.agent/skills/openclaw-persona-forge/gacha.py +224 -0
  342. package/.agent/skills/openclaw-persona-forge/gacha.sh +5 -0
  343. package/.agent/skills/openclaw-persona-forge/references/avatar-style.md +124 -0
  344. package/.agent/skills/openclaw-persona-forge/references/boundary-rules.md +53 -0
  345. package/.agent/skills/openclaw-persona-forge/references/error-handling.md +53 -0
  346. package/.agent/skills/openclaw-persona-forge/references/identity-tension.md +48 -0
  347. package/.agent/skills/openclaw-persona-forge/references/naming-system.md +39 -0
  348. package/.agent/skills/openclaw-persona-forge/references/output-template.md +166 -0
  349. package/.agent/skills/opensource-pipeline/SKILL.md +255 -0
  350. package/.agent/skills/perl-patterns/SKILL.md +504 -0
  351. package/.agent/skills/perl-security/SKILL.md +503 -0
  352. package/.agent/skills/perl-testing/SKILL.md +475 -0
  353. package/.agent/skills/plankton-code-quality/SKILL.md +236 -0
  354. package/.agent/skills/postgres-patterns/SKILL.md +147 -0
  355. package/.agent/skills/product-lens/SKILL.md +85 -0
  356. package/.agent/skills/production-scheduling/SKILL.md +238 -0
  357. package/.agent/skills/project-flow-ops/SKILL.md +111 -0
  358. package/.agent/skills/project-guidelines-example/SKILL.md +349 -0
  359. package/.agent/skills/prompt-optimizer/SKILL.md +397 -0
  360. package/.agent/skills/python-patterns/SKILL.md +622 -313
  361. package/.agent/skills/python-testing/SKILL.md +816 -0
  362. package/.agent/skills/pytorch-patterns/SKILL.md +396 -0
  363. package/.agent/skills/quality-nonconformance/SKILL.md +260 -0
  364. package/.agent/skills/ralphinho-rfc-pipeline/SKILL.md +67 -0
  365. package/.agent/skills/regex-vs-llm-structured-text/SKILL.md +220 -0
  366. package/.agent/skills/remotion-video-creation/SKILL.md +43 -0
  367. package/.agent/skills/remotion-video-creation/rules/3d.md +86 -0
  368. package/.agent/skills/remotion-video-creation/rules/animations.md +29 -0
  369. package/.agent/skills/remotion-video-creation/rules/assets/charts-bar-chart.tsx +173 -0
  370. package/.agent/skills/remotion-video-creation/rules/assets/text-animations-typewriter.tsx +100 -0
  371. package/.agent/skills/remotion-video-creation/rules/assets/text-animations-word-highlight.tsx +108 -0
  372. package/.agent/skills/remotion-video-creation/rules/assets.md +78 -0
  373. package/.agent/skills/remotion-video-creation/rules/audio.md +172 -0
  374. package/.agent/skills/remotion-video-creation/rules/calculate-metadata.md +104 -0
  375. package/.agent/skills/remotion-video-creation/rules/can-decode.md +75 -0
  376. package/.agent/skills/remotion-video-creation/rules/charts.md +58 -0
  377. package/.agent/skills/remotion-video-creation/rules/compositions.md +146 -0
  378. package/.agent/skills/remotion-video-creation/rules/display-captions.md +126 -0
  379. package/.agent/skills/remotion-video-creation/rules/extract-frames.md +229 -0
  380. package/.agent/skills/remotion-video-creation/rules/fonts.md +152 -0
  381. package/.agent/skills/remotion-video-creation/rules/get-audio-duration.md +58 -0
  382. package/.agent/skills/remotion-video-creation/rules/get-video-dimensions.md +68 -0
  383. package/.agent/skills/remotion-video-creation/rules/get-video-duration.md +58 -0
  384. package/.agent/skills/remotion-video-creation/rules/gifs.md +138 -0
  385. package/.agent/skills/remotion-video-creation/rules/images.md +130 -0
  386. package/.agent/skills/remotion-video-creation/rules/import-srt-captions.md +67 -0
  387. package/.agent/skills/remotion-video-creation/rules/lottie.md +67 -0
  388. package/.agent/skills/remotion-video-creation/rules/measuring-dom-nodes.md +34 -0
  389. package/.agent/skills/remotion-video-creation/rules/measuring-text.md +143 -0
  390. package/.agent/skills/remotion-video-creation/rules/sequencing.md +106 -0
  391. package/.agent/skills/remotion-video-creation/rules/tailwind.md +11 -0
  392. package/.agent/skills/remotion-video-creation/rules/text-animations.md +20 -0
  393. package/.agent/skills/remotion-video-creation/rules/timing.md +179 -0
  394. package/.agent/skills/remotion-video-creation/rules/transcribe-captions.md +19 -0
  395. package/.agent/skills/remotion-video-creation/rules/transitions.md +122 -0
  396. package/.agent/skills/remotion-video-creation/rules/trimming.md +52 -0
  397. package/.agent/skills/remotion-video-creation/rules/videos.md +171 -0
  398. package/.agent/skills/repo-scan/SKILL.md +78 -0
  399. package/.agent/skills/returns-reverse-logistics/SKILL.md +240 -0
  400. package/.agent/skills/rules-distill/SKILL.md +264 -0
  401. package/.agent/skills/rules-distill/scripts/scan-rules.sh +58 -0
  402. package/.agent/skills/rules-distill/scripts/scan-skills.sh +129 -0
  403. package/.agent/skills/rust-patterns/SKILL.md +499 -0
  404. package/.agent/skills/rust-testing/SKILL.md +500 -0
  405. package/.agent/skills/safety-guard/SKILL.md +75 -0
  406. package/.agent/skills/santa-method/SKILL.md +306 -0
  407. package/.agent/skills/search-first/SKILL.md +161 -0
  408. package/.agent/skills/security-review/SKILL.md +495 -0
  409. package/.agent/skills/security-review/cloud-infrastructure-security.md +361 -0
  410. package/.agent/skills/security-scan/SKILL.md +165 -0
  411. package/.agent/skills/skill-comply/SKILL.md +58 -0
  412. package/.agent/skills/skill-comply/fixtures/compliant-trace.jsonl +5 -0
  413. package/.agent/skills/skill-comply/fixtures/noncompliant-trace.jsonl +3 -0
  414. package/.agent/skills/skill-comply/fixtures/tdd-spec.yaml +44 -0
  415. package/.agent/skills/skill-comply/prompts/classifier.md +24 -0
  416. package/.agent/skills/skill-comply/prompts/scenario-generator.md +62 -0
  417. package/.agent/skills/skill-comply/prompts/spec-generator.md +42 -0
  418. package/.agent/skills/skill-comply/pyproject.toml +15 -0
  419. package/.agent/skills/skill-comply/scripts/classifier.py +85 -0
  420. package/.agent/skills/skill-comply/scripts/grader.py +122 -0
  421. package/.agent/skills/skill-comply/scripts/init.py +0 -0
  422. package/.agent/skills/skill-comply/scripts/parser.py +107 -0
  423. package/.agent/skills/skill-comply/scripts/report.py +170 -0
  424. package/.agent/skills/skill-comply/scripts/run.py +127 -0
  425. package/.agent/skills/skill-comply/scripts/runner.py +161 -0
  426. package/.agent/skills/skill-comply/scripts/scenario-generator.py +70 -0
  427. package/.agent/skills/skill-comply/scripts/spec-generator.py +72 -0
  428. package/.agent/skills/skill-comply/scripts/utils.py +13 -0
  429. package/.agent/skills/skill-comply/tests/test-grader.py +137 -0
  430. package/.agent/skills/skill-comply/tests/test-parser.py +90 -0
  431. package/.agent/skills/skill-creator/SKILL.md +485 -0
  432. package/.agent/skills/skill-creator/agents/analyzer.md +274 -0
  433. package/.agent/skills/skill-creator/agents/comparator.md +202 -0
  434. package/.agent/skills/skill-creator/agents/grader.md +223 -0
  435. package/.agent/skills/skill-creator/assets/eval-review.html +146 -0
  436. package/.agent/skills/skill-creator/eval-viewer/generate-review.py +471 -0
  437. package/.agent/skills/skill-creator/eval-viewer/viewer.html +1325 -0
  438. package/.agent/skills/skill-creator/license.txt +202 -0
  439. package/.agent/skills/skill-creator/references/schemas.md +430 -0
  440. package/.agent/skills/skill-creator/scripts/aggregate-benchmark.py +401 -0
  441. package/.agent/skills/skill-creator/scripts/generate-report.py +326 -0
  442. package/.agent/skills/skill-creator/scripts/improve-description.py +247 -0
  443. package/.agent/skills/skill-creator/scripts/init.py +0 -0
  444. package/.agent/skills/skill-creator/scripts/package-skill.py +136 -0
  445. package/.agent/skills/skill-creator/scripts/quick-validate.py +103 -0
  446. package/.agent/skills/skill-creator/scripts/run-eval.py +310 -0
  447. package/.agent/skills/skill-creator/scripts/run-loop.py +328 -0
  448. package/.agent/skills/skill-creator/scripts/utils.py +47 -0
  449. package/.agent/skills/skill-stocktake/SKILL.md +193 -0
  450. package/.agent/skills/skill-stocktake/scripts/quick-diff.sh +87 -0
  451. package/.agent/skills/skill-stocktake/scripts/save-results.sh +56 -0
  452. package/.agent/skills/skill-stocktake/scripts/scan.sh +170 -0
  453. package/.agent/skills/social-graph-ranker/SKILL.md +154 -0
  454. package/.agent/skills/springboot-patterns/SKILL.md +314 -0
  455. package/.agent/skills/springboot-security/SKILL.md +272 -0
  456. package/.agent/skills/springboot-tdd/SKILL.md +158 -0
  457. package/.agent/skills/springboot-verification/SKILL.md +231 -0
  458. package/.agent/skills/strategic-compact/SKILL.md +131 -0
  459. package/.agent/skills/strategic-compact/suggest-compact.sh +54 -0
  460. package/.agent/skills/swift-actor-persistence/SKILL.md +143 -0
  461. package/.agent/skills/swift-concurrency-6-2/SKILL.md +216 -0
  462. package/.agent/skills/swift-protocol-di-testing/SKILL.md +190 -0
  463. package/.agent/skills/swiftui-patterns/SKILL.md +259 -0
  464. package/.agent/skills/tdd-workflow/SKILL.md +412 -98
  465. package/.agent/skills/team-builder/SKILL.md +168 -0
  466. package/.agent/skills/token-budget-advisor/SKILL.md +133 -0
  467. package/.agent/skills/ui-demo/SKILL.md +465 -0
  468. package/.agent/skills/ui-ux-pro-max/data/charts.csv +26 -26
  469. package/.agent/skills/ui-ux-pro-max/data/colors.csv +97 -97
  470. package/.agent/skills/ui-ux-pro-max/data/landing.csv +28 -28
  471. package/.agent/skills/ui-ux-pro-max/data/products.csv +96 -96
  472. package/.agent/skills/ui-ux-pro-max/data/stacks/flutter.csv +53 -53
  473. package/.agent/skills/ui-ux-pro-max/data/stacks/html-tailwind.csv +56 -56
  474. package/.agent/skills/ui-ux-pro-max/data/stacks/nextjs.csv +53 -53
  475. package/.agent/skills/ui-ux-pro-max/data/stacks/react-native.csv +52 -52
  476. package/.agent/skills/ui-ux-pro-max/data/stacks/react.csv +54 -54
  477. package/.agent/skills/ui-ux-pro-max/data/stacks/svelte.csv +54 -54
  478. package/.agent/skills/ui-ux-pro-max/data/stacks/swiftui.csv +51 -51
  479. package/.agent/skills/ui-ux-pro-max/data/stacks/vue.csv +50 -50
  480. package/.agent/skills/ui-ux-pro-max/data/styles.csv +68 -68
  481. package/.agent/skills/ui-ux-pro-max/data/ux-guidelines.csv +99 -99
  482. package/.agent/skills/ui-ux-pro-max/scripts/search.py +114 -114
  483. package/.agent/skills/verification-loop/SKILL.md +126 -0
  484. package/.agent/skills/video-editing/SKILL.md +310 -0
  485. package/.agent/skills/videodb/SKILL.md +374 -0
  486. package/.agent/skills/videodb/reference/api-reference.md +550 -0
  487. package/.agent/skills/videodb/reference/capture-reference.md +407 -0
  488. package/.agent/skills/videodb/reference/capture.md +101 -0
  489. package/.agent/skills/videodb/reference/editor.md +443 -0
  490. package/.agent/skills/videodb/reference/generative.md +331 -0
  491. package/.agent/skills/videodb/reference/rtstream-reference.md +564 -0
  492. package/.agent/skills/videodb/reference/rtstream.md +65 -0
  493. package/.agent/skills/videodb/reference/search.md +230 -0
  494. package/.agent/skills/videodb/reference/streaming.md +406 -0
  495. package/.agent/skills/videodb/reference/use-cases.md +118 -0
  496. package/.agent/skills/videodb/scripts/ws-listener.py +282 -0
  497. package/.agent/skills/visa-doc-translate/SKILL.md +117 -0
  498. package/.agent/skills/visa-doc-translate/readme.md +86 -0
  499. package/.agent/skills/workspace-surface-audit/SKILL.md +125 -0
  500. package/.agent/skills/x-api/SKILL.md +230 -0
  501. package/.agent/tasks/two-track-merge-contract.md +29 -0
  502. package/.agent/workflows/aside.md +164 -164
  503. package/.agent/workflows/build-fix.md +62 -62
  504. package/.agent/workflows/checkpoint.md +74 -74
  505. package/.agent/workflows/claw.md +23 -51
  506. package/.agent/workflows/clean-memory.md +34 -0
  507. package/.agent/workflows/code-review.md +289 -40
  508. package/.agent/workflows/context-budget.md +23 -29
  509. package/.agent/workflows/cpp-build.md +173 -173
  510. package/.agent/workflows/cpp-review.md +132 -132
  511. package/.agent/workflows/cpp-test.md +251 -251
  512. package/.agent/workflows/devfleet.md +23 -92
  513. package/.agent/workflows/docs.md +23 -31
  514. package/.agent/workflows/e2e.md +268 -365
  515. package/.agent/workflows/eval.md +23 -120
  516. package/.agent/workflows/evolve.md +178 -178
  517. package/.agent/workflows/flutter-build.md +164 -0
  518. package/.agent/workflows/flutter-review.md +116 -0
  519. package/.agent/workflows/flutter-test.md +144 -0
  520. package/.agent/workflows/gan-build.md +99 -0
  521. package/.agent/workflows/gan-design.md +35 -0
  522. package/.agent/workflows/go-build.md +183 -183
  523. package/.agent/workflows/go-review.md +148 -148
  524. package/.agent/workflows/go-test.md +268 -268
  525. package/.agent/workflows/gradle-build.md +70 -70
  526. package/.agent/workflows/harness-audit.md +73 -71
  527. package/.agent/workflows/instinct-export.md +66 -66
  528. package/.agent/workflows/instinct-import.md +114 -114
  529. package/.agent/workflows/instinct-status.md +59 -59
  530. package/.agent/workflows/jira.md +106 -0
  531. package/.agent/workflows/kotlin-build.md +174 -174
  532. package/.agent/workflows/kotlin-review.md +140 -140
  533. package/.agent/workflows/kotlin-test.md +312 -312
  534. package/.agent/workflows/learn-eval.md +116 -116
  535. package/.agent/workflows/learn.md +70 -70
  536. package/.agent/workflows/loop-start.md +32 -32
  537. package/.agent/workflows/loop-status.md +24 -24
  538. package/.agent/workflows/model-route.md +26 -26
  539. package/.agent/workflows/multi-backend.md +158 -158
  540. package/.agent/workflows/multi-execute.md +315 -315
  541. package/.agent/workflows/multi-frontend.md +158 -158
  542. package/.agent/workflows/multi-plan.md +268 -268
  543. package/.agent/workflows/multi-workflow.md +191 -191
  544. package/.agent/workflows/orchestrate.md +135 -231
  545. package/.agent/workflows/plan.md +117 -115
  546. package/.agent/workflows/pm2.md +272 -272
  547. package/.agent/workflows/projects.md +39 -39
  548. package/.agent/workflows/promote.md +41 -41
  549. package/.agent/workflows/prompt-optimize.md +23 -38
  550. package/.agent/workflows/prp-commit.md +112 -0
  551. package/.agent/workflows/prp-implement.md +385 -0
  552. package/.agent/workflows/prp-plan.md +502 -0
  553. package/.agent/workflows/prp-pr.md +184 -0
  554. package/.agent/workflows/prp-prd.md +447 -0
  555. package/.agent/workflows/prune.md +31 -31
  556. package/.agent/workflows/python-review.md +297 -297
  557. package/.agent/workflows/quality-gate.md +29 -29
  558. package/.agent/workflows/refactor-clean.md +80 -80
  559. package/.agent/workflows/resume-session.md +156 -156
  560. package/.agent/workflows/rules-distill.md +20 -11
  561. package/.agent/workflows/rust-build.md +187 -187
  562. package/.agent/workflows/rust-review.md +142 -142
  563. package/.agent/workflows/rust-test.md +308 -308
  564. package/.agent/workflows/santa-loop.md +175 -0
  565. package/.agent/workflows/save-session.md +275 -275
  566. package/.agent/workflows/sessions.md +333 -333
  567. package/.agent/workflows/setup-pm.md +80 -80
  568. package/.agent/workflows/skill-create.md +174 -174
  569. package/.agent/workflows/skill-health.md +54 -54
  570. package/.agent/workflows/tdd.md +231 -328
  571. package/.agent/workflows/test-coverage.md +69 -69
  572. package/.agent/workflows/update-codemaps.md +72 -72
  573. package/.agent/workflows/update-docs.md +84 -84
  574. package/.agent/workflows/verify.md +23 -59
  575. package/LICENSE +176 -176
  576. package/README.md +28 -20
  577. package/RELEASE.md +32 -36
  578. package/package.json +87 -79
  579. package/scripts/release-check.js +55 -55
  580. package/src/bin/cli.js +399 -53
  581. package/src/lib/installer.js +360 -114
  582. package/src/lib/manifests/stacks.js +122 -0
  583. package/src/lib/slash-commands.js +28 -0
  584. package/src/templates/claude/CLAUDE.en.md +42 -0
  585. package/src/templates/claude/CLAUDE.md +42 -0
  586. package/src/templates/claude/CLAUDE.vi.md +42 -0
  587. package/src/templates/codex/AGENTS.en.md +40 -0
  588. package/src/templates/codex/AGENTS.md +40 -0
  589. package/src/templates/codex/AGENTS.vi.md +40 -0
  590. package/src/templates/cursor/pilo-masterkit.mdc +20 -0
  591. package/src/templates/gemini/GEMINI.en.md +56 -0
  592. package/src/templates/gemini/GEMINI.md +56 -0
  593. package/src/templates/gemini/GEMINI.vi.md +56 -0
  594. package/src/templates/github/copilot-instructions.md +16 -0
@@ -0,0 +1,689 @@
1
+ ---
2
+ name: kotlin-ktor-patterns
3
+ description: Ktor server patterns including routing DSL, plugins, authentication, Koin DI, kotlinx.serialization, WebSockets, and testApplication testing.
4
+ origin: ECC
5
+ ---
6
+
7
+ # Ktor Server Patterns
8
+
9
+ Comprehensive Ktor patterns for building robust, maintainable HTTP servers with Kotlin coroutines.
10
+
11
+ ## When to Activate
12
+
13
+ - Building Ktor HTTP servers
14
+ - Configuring Ktor plugins (Auth, CORS, ContentNegotiation, StatusPages)
15
+ - Implementing REST APIs with Ktor
16
+ - Setting up dependency injection with Koin
17
+ - Writing Ktor integration tests with testApplication
18
+ - Working with WebSockets in Ktor
19
+
20
+ ## Application Structure
21
+
22
+ ### Standard Ktor Project Layout
23
+
24
+ ```text
25
+ src/main/kotlin/
26
+ ├── com/example/
27
+ │ ├── Application.kt # Entry point, module configuration
28
+ │ ├── plugins/
29
+ │ │ ├── Routing.kt # Route definitions
30
+ │ │ ├── Serialization.kt # Content negotiation setup
31
+ │ │ ├── Authentication.kt # Auth configuration
32
+ │ │ ├── StatusPages.kt # Error handling
33
+ │ │ └── CORS.kt # CORS configuration
34
+ │ ├── routes/
35
+ │ │ ├── UserRoutes.kt # /users endpoints
36
+ │ │ ├── AuthRoutes.kt # /auth endpoints
37
+ │ │ └── HealthRoutes.kt # /health endpoints
38
+ │ ├── models/
39
+ │ │ ├── User.kt # Domain models
40
+ │ │ └── ApiResponse.kt # Response envelopes
41
+ │ ├── services/
42
+ │ │ ├── UserService.kt # Business logic
43
+ │ │ └── AuthService.kt # Auth logic
44
+ │ ├── repositories/
45
+ │ │ ├── UserRepository.kt # Data access interface
46
+ │ │ └── ExposedUserRepository.kt
47
+ │ └── di/
48
+ │ └── AppModule.kt # Koin modules
49
+ src/test/kotlin/
50
+ ├── com/example/
51
+ │ ├── routes/
52
+ │ │ └── UserRoutesTest.kt
53
+ │ └── services/
54
+ │ └── UserServiceTest.kt
55
+ ```
56
+
57
+ ### Application Entry Point
58
+
59
+ ```kotlin
60
+ // Application.kt
61
+ fun main() {
62
+ embeddedServer(Netty, port = 8080, module = Application::module).start(wait = true)
63
+ }
64
+
65
+ fun Application.module() {
66
+ configureSerialization()
67
+ configureAuthentication()
68
+ configureStatusPages()
69
+ configureCORS()
70
+ configureDI()
71
+ configureRouting()
72
+ }
73
+ ```
74
+
75
+ ## Routing DSL
76
+
77
+ ### Basic Routes
78
+
79
+ ```kotlin
80
+ // plugins/Routing.kt
81
+ fun Application.configureRouting() {
82
+ routing {
83
+ userRoutes()
84
+ authRoutes()
85
+ healthRoutes()
86
+ }
87
+ }
88
+
89
+ // routes/UserRoutes.kt
90
+ fun Route.userRoutes() {
91
+ val userService by inject<UserService>()
92
+
93
+ route("/users") {
94
+ get {
95
+ val users = userService.getAll()
96
+ call.respond(users)
97
+ }
98
+
99
+ get("/{id}") {
100
+ val id = call.parameters["id"]
101
+ ?: return@get call.respond(HttpStatusCode.BadRequest, "Missing id")
102
+ val user = userService.getById(id)
103
+ ?: return@get call.respond(HttpStatusCode.NotFound)
104
+ call.respond(user)
105
+ }
106
+
107
+ post {
108
+ val request = call.receive<CreateUserRequest>()
109
+ val user = userService.create(request)
110
+ call.respond(HttpStatusCode.Created, user)
111
+ }
112
+
113
+ put("/{id}") {
114
+ val id = call.parameters["id"]
115
+ ?: return@put call.respond(HttpStatusCode.BadRequest, "Missing id")
116
+ val request = call.receive<UpdateUserRequest>()
117
+ val user = userService.update(id, request)
118
+ ?: return@put call.respond(HttpStatusCode.NotFound)
119
+ call.respond(user)
120
+ }
121
+
122
+ delete("/{id}") {
123
+ val id = call.parameters["id"]
124
+ ?: return@delete call.respond(HttpStatusCode.BadRequest, "Missing id")
125
+ val deleted = userService.delete(id)
126
+ if (deleted) call.respond(HttpStatusCode.NoContent)
127
+ else call.respond(HttpStatusCode.NotFound)
128
+ }
129
+ }
130
+ }
131
+ ```
132
+
133
+ ### Route Organization with Authenticated Routes
134
+
135
+ ```kotlin
136
+ fun Route.userRoutes() {
137
+ route("/users") {
138
+ // Public routes
139
+ get { /* list users */ }
140
+ get("/{id}") { /* get user */ }
141
+
142
+ // Protected routes
143
+ authenticate("jwt") {
144
+ post { /* create user - requires auth */ }
145
+ put("/{id}") { /* update user - requires auth */ }
146
+ delete("/{id}") { /* delete user - requires auth */ }
147
+ }
148
+ }
149
+ }
150
+ ```
151
+
152
+ ## Content Negotiation & Serialization
153
+
154
+ ### kotlinx.serialization Setup
155
+
156
+ ```kotlin
157
+ // plugins/Serialization.kt
158
+ fun Application.configureSerialization() {
159
+ install(ContentNegotiation) {
160
+ json(Json {
161
+ prettyPrint = true
162
+ isLenient = false
163
+ ignoreUnknownKeys = true
164
+ encodeDefaults = true
165
+ explicitNulls = false
166
+ })
167
+ }
168
+ }
169
+ ```
170
+
171
+ ### Serializable Models
172
+
173
+ ```kotlin
174
+ @Serializable
175
+ data class UserResponse(
176
+ val id: String,
177
+ val name: String,
178
+ val email: String,
179
+ val role: Role,
180
+ @Serializable(with = InstantSerializer::class)
181
+ val createdAt: Instant,
182
+ )
183
+
184
+ @Serializable
185
+ data class CreateUserRequest(
186
+ val name: String,
187
+ val email: String,
188
+ val role: Role = Role.USER,
189
+ )
190
+
191
+ @Serializable
192
+ data class ApiResponse<T>(
193
+ val success: Boolean,
194
+ val data: T? = null,
195
+ val error: String? = null,
196
+ ) {
197
+ companion object {
198
+ fun <T> ok(data: T): ApiResponse<T> = ApiResponse(success = true, data = data)
199
+ fun <T> error(message: String): ApiResponse<T> = ApiResponse(success = false, error = message)
200
+ }
201
+ }
202
+
203
+ @Serializable
204
+ data class PaginatedResponse<T>(
205
+ val data: List<T>,
206
+ val total: Long,
207
+ val page: Int,
208
+ val limit: Int,
209
+ )
210
+ ```
211
+
212
+ ### Custom Serializers
213
+
214
+ ```kotlin
215
+ object InstantSerializer : KSerializer<Instant> {
216
+ override val descriptor = PrimitiveSerialDescriptor("Instant", PrimitiveKind.STRING)
217
+ override fun serialize(encoder: Encoder, value: Instant) =
218
+ encoder.encodeString(value.toString())
219
+ override fun deserialize(decoder: Decoder): Instant =
220
+ Instant.parse(decoder.decodeString())
221
+ }
222
+ ```
223
+
224
+ ## Authentication
225
+
226
+ ### JWT Authentication
227
+
228
+ ```kotlin
229
+ // plugins/Authentication.kt
230
+ fun Application.configureAuthentication() {
231
+ val jwtSecret = environment.config.property("jwt.secret").getString()
232
+ val jwtIssuer = environment.config.property("jwt.issuer").getString()
233
+ val jwtAudience = environment.config.property("jwt.audience").getString()
234
+ val jwtRealm = environment.config.property("jwt.realm").getString()
235
+
236
+ install(Authentication) {
237
+ jwt("jwt") {
238
+ realm = jwtRealm
239
+ verifier(
240
+ JWT.require(Algorithm.HMAC256(jwtSecret))
241
+ .withAudience(jwtAudience)
242
+ .withIssuer(jwtIssuer)
243
+ .build()
244
+ )
245
+ validate { credential ->
246
+ if (credential.payload.audience.contains(jwtAudience)) {
247
+ JWTPrincipal(credential.payload)
248
+ } else {
249
+ null
250
+ }
251
+ }
252
+ challenge { _, _ ->
253
+ call.respond(HttpStatusCode.Unauthorized, ApiResponse.error<Unit>("Invalid or expired token"))
254
+ }
255
+ }
256
+ }
257
+ }
258
+
259
+ // Extracting user from JWT
260
+ fun ApplicationCall.userId(): String =
261
+ principal<JWTPrincipal>()
262
+ ?.payload
263
+ ?.getClaim("userId")
264
+ ?.asString()
265
+ ?: throw AuthenticationException("No userId in token")
266
+ ```
267
+
268
+ ### Auth Routes
269
+
270
+ ```kotlin
271
+ fun Route.authRoutes() {
272
+ val authService by inject<AuthService>()
273
+
274
+ route("/auth") {
275
+ post("/login") {
276
+ val request = call.receive<LoginRequest>()
277
+ val token = authService.login(request.email, request.password)
278
+ ?: return@post call.respond(
279
+ HttpStatusCode.Unauthorized,
280
+ ApiResponse.error<Unit>("Invalid credentials"),
281
+ )
282
+ call.respond(ApiResponse.ok(TokenResponse(token)))
283
+ }
284
+
285
+ post("/register") {
286
+ val request = call.receive<RegisterRequest>()
287
+ val user = authService.register(request)
288
+ call.respond(HttpStatusCode.Created, ApiResponse.ok(user))
289
+ }
290
+
291
+ authenticate("jwt") {
292
+ get("/me") {
293
+ val userId = call.userId()
294
+ val user = authService.getProfile(userId)
295
+ call.respond(ApiResponse.ok(user))
296
+ }
297
+ }
298
+ }
299
+ }
300
+ ```
301
+
302
+ ## Status Pages (Error Handling)
303
+
304
+ ```kotlin
305
+ // plugins/StatusPages.kt
306
+ fun Application.configureStatusPages() {
307
+ install(StatusPages) {
308
+ exception<ContentTransformationException> { call, cause ->
309
+ call.respond(
310
+ HttpStatusCode.BadRequest,
311
+ ApiResponse.error<Unit>("Invalid request body: ${cause.message}"),
312
+ )
313
+ }
314
+
315
+ exception<IllegalArgumentException> { call, cause ->
316
+ call.respond(
317
+ HttpStatusCode.BadRequest,
318
+ ApiResponse.error<Unit>(cause.message ?: "Bad request"),
319
+ )
320
+ }
321
+
322
+ exception<AuthenticationException> { call, _ ->
323
+ call.respond(
324
+ HttpStatusCode.Unauthorized,
325
+ ApiResponse.error<Unit>("Authentication required"),
326
+ )
327
+ }
328
+
329
+ exception<AuthorizationException> { call, _ ->
330
+ call.respond(
331
+ HttpStatusCode.Forbidden,
332
+ ApiResponse.error<Unit>("Access denied"),
333
+ )
334
+ }
335
+
336
+ exception<NotFoundException> { call, cause ->
337
+ call.respond(
338
+ HttpStatusCode.NotFound,
339
+ ApiResponse.error<Unit>(cause.message ?: "Resource not found"),
340
+ )
341
+ }
342
+
343
+ exception<Throwable> { call, cause ->
344
+ call.application.log.error("Unhandled exception", cause)
345
+ call.respond(
346
+ HttpStatusCode.InternalServerError,
347
+ ApiResponse.error<Unit>("Internal server error"),
348
+ )
349
+ }
350
+
351
+ status(HttpStatusCode.NotFound) { call, status ->
352
+ call.respond(status, ApiResponse.error<Unit>("Route not found"))
353
+ }
354
+ }
355
+ }
356
+ ```
357
+
358
+ ## CORS Configuration
359
+
360
+ ```kotlin
361
+ // plugins/CORS.kt
362
+ fun Application.configureCORS() {
363
+ install(CORS) {
364
+ allowHost("localhost:3000")
365
+ allowHost("example.com", schemes = listOf("https"))
366
+ allowHeader(HttpHeaders.ContentType)
367
+ allowHeader(HttpHeaders.Authorization)
368
+ allowMethod(HttpMethod.Put)
369
+ allowMethod(HttpMethod.Delete)
370
+ allowMethod(HttpMethod.Patch)
371
+ allowCredentials = true
372
+ maxAgeInSeconds = 3600
373
+ }
374
+ }
375
+ ```
376
+
377
+ ## Koin Dependency Injection
378
+
379
+ ### Module Definition
380
+
381
+ ```kotlin
382
+ // di/AppModule.kt
383
+ val appModule = module {
384
+ // Database
385
+ single<Database> { DatabaseFactory.create(get()) }
386
+
387
+ // Repositories
388
+ single<UserRepository> { ExposedUserRepository(get()) }
389
+ single<OrderRepository> { ExposedOrderRepository(get()) }
390
+
391
+ // Services
392
+ single { UserService(get()) }
393
+ single { OrderService(get(), get()) }
394
+ single { AuthService(get(), get()) }
395
+ }
396
+
397
+ // Application setup
398
+ fun Application.configureDI() {
399
+ install(Koin) {
400
+ modules(appModule)
401
+ }
402
+ }
403
+ ```
404
+
405
+ ### Using Koin in Routes
406
+
407
+ ```kotlin
408
+ fun Route.userRoutes() {
409
+ val userService by inject<UserService>()
410
+
411
+ route("/users") {
412
+ get {
413
+ val users = userService.getAll()
414
+ call.respond(ApiResponse.ok(users))
415
+ }
416
+ }
417
+ }
418
+ ```
419
+
420
+ ### Koin for Testing
421
+
422
+ ```kotlin
423
+ class UserServiceTest : FunSpec(), KoinTest {
424
+ override fun extensions() = listOf(KoinExtension(testModule))
425
+
426
+ private val testModule = module {
427
+ single<UserRepository> { mockk() }
428
+ single { UserService(get()) }
429
+ }
430
+
431
+ private val repository by inject<UserRepository>()
432
+ private val service by inject<UserService>()
433
+
434
+ init {
435
+ test("getUser returns user") {
436
+ coEvery { repository.findById("1") } returns testUser
437
+ service.getById("1") shouldBe testUser
438
+ }
439
+ }
440
+ }
441
+ ```
442
+
443
+ ## Request Validation
444
+
445
+ ```kotlin
446
+ // Validate request data in routes
447
+ fun Route.userRoutes() {
448
+ val userService by inject<UserService>()
449
+
450
+ post("/users") {
451
+ val request = call.receive<CreateUserRequest>()
452
+
453
+ // Validate
454
+ require(request.name.isNotBlank()) { "Name is required" }
455
+ require(request.name.length <= 100) { "Name must be 100 characters or less" }
456
+ require(request.email.matches(Regex(".+@.+\\..+"))) { "Invalid email format" }
457
+
458
+ val user = userService.create(request)
459
+ call.respond(HttpStatusCode.Created, ApiResponse.ok(user))
460
+ }
461
+ }
462
+
463
+ // Or use a validation extension
464
+ fun CreateUserRequest.validate() {
465
+ require(name.isNotBlank()) { "Name is required" }
466
+ require(name.length <= 100) { "Name must be 100 characters or less" }
467
+ require(email.matches(Regex(".+@.+\\..+"))) { "Invalid email format" }
468
+ }
469
+ ```
470
+
471
+ ## WebSockets
472
+
473
+ ```kotlin
474
+ fun Application.configureWebSockets() {
475
+ install(WebSockets) {
476
+ pingPeriod = 15.seconds
477
+ timeout = 15.seconds
478
+ maxFrameSize = 64 * 1024 // 64 KiB — increase only if your protocol requires larger frames
479
+ masking = false // Server-to-client frames are unmasked per RFC 6455; client-to-server are always masked by Ktor
480
+ }
481
+ }
482
+
483
+ fun Route.chatRoutes() {
484
+ val connections = Collections.synchronizedSet<Connection>(LinkedHashSet())
485
+
486
+ webSocket("/chat") {
487
+ val thisConnection = Connection(this)
488
+ connections += thisConnection
489
+
490
+ try {
491
+ send("Connected! Users online: ${connections.size}")
492
+
493
+ for (frame in incoming) {
494
+ frame as? Frame.Text ?: continue
495
+ val text = frame.readText()
496
+ val message = ChatMessage(thisConnection.name, text)
497
+
498
+ // Snapshot under lock to avoid ConcurrentModificationException
499
+ val snapshot = synchronized(connections) { connections.toList() }
500
+ snapshot.forEach { conn ->
501
+ conn.session.send(Json.encodeToString(message))
502
+ }
503
+ }
504
+ } catch (e: Exception) {
505
+ logger.error("WebSocket error", e)
506
+ } finally {
507
+ connections -= thisConnection
508
+ }
509
+ }
510
+ }
511
+
512
+ data class Connection(val session: DefaultWebSocketSession) {
513
+ val name: String = "User-${counter.getAndIncrement()}"
514
+
515
+ companion object {
516
+ private val counter = AtomicInteger(0)
517
+ }
518
+ }
519
+ ```
520
+
521
+ ## testApplication Testing
522
+
523
+ ### Basic Route Testing
524
+
525
+ ```kotlin
526
+ class UserRoutesTest : FunSpec({
527
+ test("GET /users returns list of users") {
528
+ testApplication {
529
+ application {
530
+ install(Koin) { modules(testModule) }
531
+ configureSerialization()
532
+ configureRouting()
533
+ }
534
+
535
+ val response = client.get("/users")
536
+
537
+ response.status shouldBe HttpStatusCode.OK
538
+ val body = response.body<ApiResponse<List<UserResponse>>>()
539
+ body.success shouldBe true
540
+ body.data.shouldNotBeNull().shouldNotBeEmpty()
541
+ }
542
+ }
543
+
544
+ test("POST /users creates a user") {
545
+ testApplication {
546
+ application {
547
+ install(Koin) { modules(testModule) }
548
+ configureSerialization()
549
+ configureStatusPages()
550
+ configureRouting()
551
+ }
552
+
553
+ val client = createClient {
554
+ install(io.ktor.client.plugins.contentnegotiation.ContentNegotiation) {
555
+ json()
556
+ }
557
+ }
558
+
559
+ val response = client.post("/users") {
560
+ contentType(ContentType.Application.Json)
561
+ setBody(CreateUserRequest("Alice", "alice@example.com"))
562
+ }
563
+
564
+ response.status shouldBe HttpStatusCode.Created
565
+ }
566
+ }
567
+
568
+ test("GET /users/{id} returns 404 for unknown id") {
569
+ testApplication {
570
+ application {
571
+ install(Koin) { modules(testModule) }
572
+ configureSerialization()
573
+ configureStatusPages()
574
+ configureRouting()
575
+ }
576
+
577
+ val response = client.get("/users/unknown-id")
578
+
579
+ response.status shouldBe HttpStatusCode.NotFound
580
+ }
581
+ }
582
+ })
583
+ ```
584
+
585
+ ### Testing Authenticated Routes
586
+
587
+ ```kotlin
588
+ class AuthenticatedRoutesTest : FunSpec({
589
+ test("protected route requires JWT") {
590
+ testApplication {
591
+ application {
592
+ install(Koin) { modules(testModule) }
593
+ configureSerialization()
594
+ configureAuthentication()
595
+ configureRouting()
596
+ }
597
+
598
+ val response = client.post("/users") {
599
+ contentType(ContentType.Application.Json)
600
+ setBody(CreateUserRequest("Alice", "alice@example.com"))
601
+ }
602
+
603
+ response.status shouldBe HttpStatusCode.Unauthorized
604
+ }
605
+ }
606
+
607
+ test("protected route succeeds with valid JWT") {
608
+ testApplication {
609
+ application {
610
+ install(Koin) { modules(testModule) }
611
+ configureSerialization()
612
+ configureAuthentication()
613
+ configureRouting()
614
+ }
615
+
616
+ val token = generateTestJWT(userId = "test-user")
617
+
618
+ val client = createClient {
619
+ install(io.ktor.client.plugins.contentnegotiation.ContentNegotiation) { json() }
620
+ }
621
+
622
+ val response = client.post("/users") {
623
+ contentType(ContentType.Application.Json)
624
+ bearerAuth(token)
625
+ setBody(CreateUserRequest("Alice", "alice@example.com"))
626
+ }
627
+
628
+ response.status shouldBe HttpStatusCode.Created
629
+ }
630
+ }
631
+ })
632
+ ```
633
+
634
+ ## Configuration
635
+
636
+ ### application.yaml
637
+
638
+ ```yaml
639
+ ktor:
640
+ application:
641
+ modules:
642
+ - com.example.ApplicationKt.module
643
+ deployment:
644
+ port: 8080
645
+
646
+ jwt:
647
+ secret: ${JWT_SECRET}
648
+ issuer: "https://example.com"
649
+ audience: "https://example.com/api"
650
+ realm: "example"
651
+
652
+ database:
653
+ url: ${DATABASE_URL}
654
+ driver: "org.postgresql.Driver"
655
+ maxPoolSize: 10
656
+ ```
657
+
658
+ ### Reading Config
659
+
660
+ ```kotlin
661
+ fun Application.configureDI() {
662
+ val dbUrl = environment.config.property("database.url").getString()
663
+ val dbDriver = environment.config.property("database.driver").getString()
664
+ val maxPoolSize = environment.config.property("database.maxPoolSize").getString().toInt()
665
+
666
+ install(Koin) {
667
+ modules(module {
668
+ single { DatabaseConfig(dbUrl, dbDriver, maxPoolSize) }
669
+ single { DatabaseFactory.create(get()) }
670
+ })
671
+ }
672
+ }
673
+ ```
674
+
675
+ ## Quick Reference: Ktor Patterns
676
+
677
+ | Pattern | Description |
678
+ |---------|-------------|
679
+ | `route("/path") { get { } }` | Route grouping with DSL |
680
+ | `call.receive<T>()` | Deserialize request body |
681
+ | `call.respond(status, body)` | Send response with status |
682
+ | `call.parameters["id"]` | Read path parameters |
683
+ | `call.request.queryParameters["q"]` | Read query parameters |
684
+ | `install(Plugin) { }` | Install and configure plugin |
685
+ | `authenticate("name") { }` | Protect routes with auth |
686
+ | `by inject<T>()` | Koin dependency injection |
687
+ | `testApplication { }` | Integration testing |
688
+
689
+ **Remember**: Ktor is designed around Kotlin coroutines and DSLs. Keep routes thin, push logic to services, and use Koin for dependency injection. Test with `testApplication` for full integration coverage.