@rubix0270/arboris 1.0.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 (451) hide show
  1. package/README.md +151 -0
  2. package/cli/manifest.json +323 -0
  3. package/dist/cli.mjs +376 -0
  4. package/package.json +81 -0
  5. package/prisma/skills/accessibility/SKILL.md +147 -0
  6. package/prisma/skills/agent-architecture-audit/SKILL.md +257 -0
  7. package/prisma/skills/agent-eval/SKILL.md +146 -0
  8. package/prisma/skills/agent-harness-construction/SKILL.md +74 -0
  9. package/prisma/skills/agent-introspection-debugging/SKILL.md +154 -0
  10. package/prisma/skills/agent-payment-x402/SKILL.md +225 -0
  11. package/prisma/skills/agent-self-evaluation/SKILL.md +182 -0
  12. package/prisma/skills/agent-self-evaluation/examples/high-score-example.md +87 -0
  13. package/prisma/skills/agent-self-evaluation/examples/low-score-example.md +86 -0
  14. package/prisma/skills/agent-self-evaluation/references/evaluation-criteria.md +71 -0
  15. package/prisma/skills/agent-self-evaluation/references/hook-integration.md +64 -0
  16. package/prisma/skills/agent-self-evaluation/scripts/evaluate.py +408 -0
  17. package/prisma/skills/agent-self-evaluation/templates/evaluation-report.md +86 -0
  18. package/prisma/skills/agent-sort/SKILL.md +216 -0
  19. package/prisma/skills/agentic-engineering/SKILL.md +64 -0
  20. package/prisma/skills/agentic-os/SKILL.md +388 -0
  21. package/prisma/skills/ai-first-engineering/SKILL.md +52 -0
  22. package/prisma/skills/ai-regression-testing/SKILL.md +386 -0
  23. package/prisma/skills/android-clean-architecture/SKILL.md +340 -0
  24. package/prisma/skills/angular-developer/SKILL.md +155 -0
  25. package/prisma/skills/angular-developer/references/angular-animations.md +160 -0
  26. package/prisma/skills/angular-developer/references/angular-aria.md +410 -0
  27. package/prisma/skills/angular-developer/references/cli.md +86 -0
  28. package/prisma/skills/angular-developer/references/component-harnesses.md +59 -0
  29. package/prisma/skills/angular-developer/references/component-styling.md +91 -0
  30. package/prisma/skills/angular-developer/references/components.md +117 -0
  31. package/prisma/skills/angular-developer/references/creating-services.md +97 -0
  32. package/prisma/skills/angular-developer/references/data-resolvers.md +69 -0
  33. package/prisma/skills/angular-developer/references/define-routes.md +67 -0
  34. package/prisma/skills/angular-developer/references/defining-providers.md +72 -0
  35. package/prisma/skills/angular-developer/references/di-fundamentals.md +120 -0
  36. package/prisma/skills/angular-developer/references/e2e-testing.md +56 -0
  37. package/prisma/skills/angular-developer/references/effects.md +83 -0
  38. package/prisma/skills/angular-developer/references/hierarchical-injectors.md +43 -0
  39. package/prisma/skills/angular-developer/references/host-elements.md +80 -0
  40. package/prisma/skills/angular-developer/references/injection-context.md +63 -0
  41. package/prisma/skills/angular-developer/references/inputs.md +101 -0
  42. package/prisma/skills/angular-developer/references/linked-signal.md +59 -0
  43. package/prisma/skills/angular-developer/references/loading-strategies.md +61 -0
  44. package/prisma/skills/angular-developer/references/mcp.md +108 -0
  45. package/prisma/skills/angular-developer/references/navigate-to-routes.md +69 -0
  46. package/prisma/skills/angular-developer/references/outputs.md +86 -0
  47. package/prisma/skills/angular-developer/references/reactive-forms.md +122 -0
  48. package/prisma/skills/angular-developer/references/rendering-strategies.md +44 -0
  49. package/prisma/skills/angular-developer/references/resource.md +77 -0
  50. package/prisma/skills/angular-developer/references/route-animations.md +56 -0
  51. package/prisma/skills/angular-developer/references/route-guards.md +52 -0
  52. package/prisma/skills/angular-developer/references/router-lifecycle.md +45 -0
  53. package/prisma/skills/angular-developer/references/router-testing.md +87 -0
  54. package/prisma/skills/angular-developer/references/show-routes-with-outlets.md +68 -0
  55. package/prisma/skills/angular-developer/references/signal-forms.md +795 -0
  56. package/prisma/skills/angular-developer/references/signals-overview.md +94 -0
  57. package/prisma/skills/angular-developer/references/tailwind-css.md +69 -0
  58. package/prisma/skills/angular-developer/references/template-driven-forms.md +114 -0
  59. package/prisma/skills/angular-developer/references/testing-fundamentals.md +65 -0
  60. package/prisma/skills/api-connector-builder/SKILL.md +121 -0
  61. package/prisma/skills/api-design/SKILL.md +524 -0
  62. package/prisma/skills/architecture-decision-records/SKILL.md +180 -0
  63. package/prisma/skills/article-writing/SKILL.md +80 -0
  64. package/prisma/skills/automation-audit-ops/SKILL.md +143 -0
  65. package/prisma/skills/autonomous-agent-harness/SKILL.md +274 -0
  66. package/prisma/skills/autonomous-loops/SKILL.md +611 -0
  67. package/prisma/skills/backend-patterns/SKILL.md +562 -0
  68. package/prisma/skills/benchmark/SKILL.md +94 -0
  69. package/prisma/skills/benchmark-methodology/SKILL.md +190 -0
  70. package/prisma/skills/benchmark-optimization-loop/SKILL.md +70 -0
  71. package/prisma/skills/blender-motion-state-inspection/SKILL.md +165 -0
  72. package/prisma/skills/blueprint/SKILL.md +106 -0
  73. package/prisma/skills/brand-discovery/SKILL.md +145 -0
  74. package/prisma/skills/brand-discovery/references/10_purpose-why.md +40 -0
  75. package/prisma/skills/brand-discovery/references/20_positioning.md +44 -0
  76. package/prisma/skills/brand-discovery/references/30_audience-niche.md +52 -0
  77. package/prisma/skills/brand-discovery/references/40_personality-archetype.md +57 -0
  78. package/prisma/skills/brand-discovery/references/50_voice-tone.md +59 -0
  79. package/prisma/skills/brand-discovery/references/60_narrative-story.md +50 -0
  80. package/prisma/skills/brand-discovery/references/70_founder-tension.md +49 -0
  81. package/prisma/skills/brand-discovery/references/90_SYNTHESIS.md +133 -0
  82. package/prisma/skills/brand-voice/SKILL.md +98 -0
  83. package/prisma/skills/brand-voice/references/voice-profile-schema.md +55 -0
  84. package/prisma/skills/browser-qa/SKILL.md +105 -0
  85. package/prisma/skills/bun-runtime/SKILL.md +85 -0
  86. package/prisma/skills/canary-watch/SKILL.md +108 -0
  87. package/prisma/skills/carrier-relationship-management/SKILL.md +212 -0
  88. package/prisma/skills/cisco-ios-patterns/SKILL.md +164 -0
  89. package/prisma/skills/ck/SKILL.md +148 -0
  90. package/prisma/skills/ck/commands/forget.mjs +44 -0
  91. package/prisma/skills/ck/commands/info.mjs +24 -0
  92. package/prisma/skills/ck/commands/init.mjs +143 -0
  93. package/prisma/skills/ck/commands/list.mjs +40 -0
  94. package/prisma/skills/ck/commands/migrate.mjs +202 -0
  95. package/prisma/skills/ck/commands/resume.mjs +36 -0
  96. package/prisma/skills/ck/commands/save.mjs +210 -0
  97. package/prisma/skills/ck/commands/shared.mjs +387 -0
  98. package/prisma/skills/ck/hooks/session-start.mjs +224 -0
  99. package/prisma/skills/claude-devfleet/SKILL.md +112 -0
  100. package/prisma/skills/click-path-audit/SKILL.md +245 -0
  101. package/prisma/skills/clickhouse-io/SKILL.md +440 -0
  102. package/prisma/skills/code-tour/SKILL.md +254 -0
  103. package/prisma/skills/codebase-onboarding/SKILL.md +234 -0
  104. package/prisma/skills/codehealth-mcp/SKILL.md +167 -0
  105. package/prisma/skills/coding-standards/SKILL.md +551 -0
  106. package/prisma/skills/competitive-platform-analysis/SKILL.md +214 -0
  107. package/prisma/skills/competitive-report-structure/SKILL.md +162 -0
  108. package/prisma/skills/compose-multiplatform-patterns/SKILL.md +300 -0
  109. package/prisma/skills/config-gc/SKILL.md +120 -0
  110. package/prisma/skills/configure-ecc/SKILL.md +385 -0
  111. package/prisma/skills/connections-optimizer/SKILL.md +190 -0
  112. package/prisma/skills/content-engine/SKILL.md +132 -0
  113. package/prisma/skills/content-hash-cache-pattern/SKILL.md +162 -0
  114. package/prisma/skills/context-budget/SKILL.md +136 -0
  115. package/prisma/skills/continuous-agent-loop/SKILL.md +46 -0
  116. package/prisma/skills/continuous-learning/SKILL.md +132 -0
  117. package/prisma/skills/continuous-learning/config.json +18 -0
  118. package/prisma/skills/continuous-learning/evaluate-session.sh +69 -0
  119. package/prisma/skills/continuous-learning-v2/SKILL.md +361 -0
  120. package/prisma/skills/continuous-learning-v2/agents/observer-loop.sh +359 -0
  121. package/prisma/skills/continuous-learning-v2/agents/observer.md +189 -0
  122. package/prisma/skills/continuous-learning-v2/agents/session-guardian.sh +150 -0
  123. package/prisma/skills/continuous-learning-v2/agents/start-observer.sh +248 -0
  124. package/prisma/skills/continuous-learning-v2/config.json +8 -0
  125. package/prisma/skills/continuous-learning-v2/hooks/observe.sh +585 -0
  126. package/prisma/skills/continuous-learning-v2/scripts/detect-project.sh +322 -0
  127. package/prisma/skills/continuous-learning-v2/scripts/instinct-cli.py +1956 -0
  128. package/prisma/skills/continuous-learning-v2/scripts/lib/homunculus-dir.sh +31 -0
  129. package/prisma/skills/continuous-learning-v2/scripts/migrate-homunculus.sh +68 -0
  130. package/prisma/skills/continuous-learning-v2/scripts/test_parse_instinct.py +1421 -0
  131. package/prisma/skills/cost-aware-llm-pipeline/SKILL.md +184 -0
  132. package/prisma/skills/cost-tracking/SKILL.md +97 -0
  133. package/prisma/skills/council/SKILL.md +204 -0
  134. package/prisma/skills/cpp-coding-standards/SKILL.md +724 -0
  135. package/prisma/skills/cpp-testing/SKILL.md +325 -0
  136. package/prisma/skills/crosspost/SKILL.md +112 -0
  137. package/prisma/skills/csharp-testing/SKILL.md +322 -0
  138. package/prisma/skills/customer-billing-ops/SKILL.md +141 -0
  139. package/prisma/skills/customs-trade-compliance/SKILL.md +263 -0
  140. package/prisma/skills/dart-flutter-patterns/SKILL.md +564 -0
  141. package/prisma/skills/dashboard-builder/SKILL.md +109 -0
  142. package/prisma/skills/data-scraper-agent/SKILL.md +765 -0
  143. package/prisma/skills/data-throughput-accelerator/SKILL.md +73 -0
  144. package/prisma/skills/database-migrations/SKILL.md +430 -0
  145. package/prisma/skills/deep-research/SKILL.md +160 -0
  146. package/prisma/skills/defi-amm-security/SKILL.md +167 -0
  147. package/prisma/skills/delivery-gate/SKILL.md +126 -0
  148. package/prisma/skills/delivery-gate/hooks/quality-gate.py +220 -0
  149. package/prisma/skills/deployment-patterns/SKILL.md +428 -0
  150. package/prisma/skills/design-system/SKILL.md +83 -0
  151. package/prisma/skills/django-celery/SKILL.md +458 -0
  152. package/prisma/skills/django-patterns/SKILL.md +735 -0
  153. package/prisma/skills/django-security/SKILL.md +644 -0
  154. package/prisma/skills/django-tdd/SKILL.md +730 -0
  155. package/prisma/skills/django-verification/SKILL.md +470 -0
  156. package/prisma/skills/dmux-workflows/SKILL.md +192 -0
  157. package/prisma/skills/docker-patterns/SKILL.md +365 -0
  158. package/prisma/skills/documentation-lookup/SKILL.md +91 -0
  159. package/prisma/skills/dotnet-patterns/SKILL.md +322 -0
  160. package/prisma/skills/dynamic-workflow-mode/SKILL.md +124 -0
  161. package/prisma/skills/e2e-testing/SKILL.md +327 -0
  162. package/prisma/skills/ecc-guide/SKILL.md +190 -0
  163. package/prisma/skills/ecc-recipes/SKILL.md +149 -0
  164. package/prisma/skills/ecc-tools-cost-audit/SKILL.md +161 -0
  165. package/prisma/skills/email-ops/SKILL.md +122 -0
  166. package/prisma/skills/energy-procurement/SKILL.md +228 -0
  167. package/prisma/skills/enterprise-agent-ops/SKILL.md +51 -0
  168. package/prisma/skills/error-handling/SKILL.md +377 -0
  169. package/prisma/skills/eval-harness/SKILL.md +271 -0
  170. package/prisma/skills/evm-token-decimals/SKILL.md +131 -0
  171. package/prisma/skills/exa-search/SKILL.md +108 -0
  172. package/prisma/skills/fal-ai-media/SKILL.md +289 -0
  173. package/prisma/skills/fastapi-patterns/SKILL.md +514 -0
  174. package/prisma/skills/finance-billing-ops/SKILL.md +128 -0
  175. package/prisma/skills/flox-environments/SKILL.md +497 -0
  176. package/prisma/skills/flutter-dart-code-review/SKILL.md +436 -0
  177. package/prisma/skills/foundation-models-on-device/SKILL.md +243 -0
  178. package/prisma/skills/frontend-a11y/SKILL.md +446 -0
  179. package/prisma/skills/frontend-design-direction/SKILL.md +93 -0
  180. package/prisma/skills/frontend-patterns/SKILL.md +657 -0
  181. package/prisma/skills/frontend-slides/SKILL.md +185 -0
  182. package/prisma/skills/frontend-slides/STYLE_PRESETS.md +330 -0
  183. package/prisma/skills/frontend-slides/animation-patterns.md +122 -0
  184. package/prisma/skills/frontend-slides/html-template.md +419 -0
  185. package/prisma/skills/frontend-slides/scripts/export-pdf.sh +418 -0
  186. package/prisma/skills/frontend-slides/scripts/extract-pptx.py +96 -0
  187. package/prisma/skills/frontend-slides/viewport-base.css +153 -0
  188. package/prisma/skills/fsharp-testing/SKILL.md +281 -0
  189. package/prisma/skills/gan-style-harness/SKILL.md +279 -0
  190. package/prisma/skills/gateguard/SKILL.md +133 -0
  191. package/prisma/skills/generating-python-installer/SKILL.md +820 -0
  192. package/prisma/skills/git-workflow/SKILL.md +716 -0
  193. package/prisma/skills/github-ops/SKILL.md +145 -0
  194. package/prisma/skills/golang-patterns/SKILL.md +675 -0
  195. package/prisma/skills/golang-testing/SKILL.md +721 -0
  196. package/prisma/skills/google-workspace-ops/SKILL.md +96 -0
  197. package/prisma/skills/growth-log/SKILL.md +128 -0
  198. package/prisma/skills/healthcare-cdss-patterns/SKILL.md +246 -0
  199. package/prisma/skills/healthcare-emr-patterns/SKILL.md +160 -0
  200. package/prisma/skills/healthcare-eval-harness/SKILL.md +208 -0
  201. package/prisma/skills/healthcare-phi-compliance/SKILL.md +146 -0
  202. package/prisma/skills/hermes-imports/SKILL.md +89 -0
  203. package/prisma/skills/hexagonal-architecture/SKILL.md +277 -0
  204. package/prisma/skills/hipaa-compliance/SKILL.md +79 -0
  205. package/prisma/skills/homelab-network-readiness/SKILL.md +170 -0
  206. package/prisma/skills/homelab-network-setup/SKILL.md +130 -0
  207. package/prisma/skills/homelab-pihole-dns/SKILL.md +275 -0
  208. package/prisma/skills/homelab-vlan-segmentation/SKILL.md +312 -0
  209. package/prisma/skills/homelab-wireguard-vpn/SKILL.md +306 -0
  210. package/prisma/skills/hookify-rules/SKILL.md +128 -0
  211. package/prisma/skills/inherit-legacy-style/SKILL.md +157 -0
  212. package/prisma/skills/intent-driven-development/SKILL.md +360 -0
  213. package/prisma/skills/inventory-demand-planning/SKILL.md +247 -0
  214. package/prisma/skills/investor-materials/SKILL.md +97 -0
  215. package/prisma/skills/investor-outreach/SKILL.md +92 -0
  216. package/prisma/skills/ios-icon-gen/SKILL.md +158 -0
  217. package/prisma/skills/ios-icon-gen/scripts/generate_icons.swift +258 -0
  218. package/prisma/skills/ios-icon-gen/scripts/iconify_gen.sh +235 -0
  219. package/prisma/skills/iterative-retrieval/SKILL.md +212 -0
  220. package/prisma/skills/ito-basket-compare/SKILL.md +64 -0
  221. package/prisma/skills/ito-data-atlas-agent/SKILL.md +64 -0
  222. package/prisma/skills/ito-market-intelligence/SKILL.md +61 -0
  223. package/prisma/skills/ito-trade-planner/SKILL.md +68 -0
  224. package/prisma/skills/java-coding-standards/SKILL.md +384 -0
  225. package/prisma/skills/jira-integration/SKILL.md +303 -0
  226. package/prisma/skills/jpa-patterns/SKILL.md +152 -0
  227. package/prisma/skills/knowledge-ops/SKILL.md +155 -0
  228. package/prisma/skills/kotlin-coroutines-flows/SKILL.md +285 -0
  229. package/prisma/skills/kotlin-exposed-patterns/SKILL.md +720 -0
  230. package/prisma/skills/kotlin-ktor-patterns/SKILL.md +690 -0
  231. package/prisma/skills/kotlin-patterns/SKILL.md +712 -0
  232. package/prisma/skills/kotlin-testing/SKILL.md +825 -0
  233. package/prisma/skills/kubernetes-patterns/SKILL.md +756 -0
  234. package/prisma/skills/laravel-patterns/SKILL.md +416 -0
  235. package/prisma/skills/laravel-plugin-discovery/SKILL.md +230 -0
  236. package/prisma/skills/laravel-security/SKILL.md +948 -0
  237. package/prisma/skills/laravel-tdd/SKILL.md +675 -0
  238. package/prisma/skills/laravel-verification/SKILL.md +180 -0
  239. package/prisma/skills/latency-critical-systems/SKILL.md +74 -0
  240. package/prisma/skills/lead-intelligence/SKILL.md +322 -0
  241. package/prisma/skills/lead-intelligence/agents/enrichment-agent.md +85 -0
  242. package/prisma/skills/lead-intelligence/agents/mutual-mapper.md +75 -0
  243. package/prisma/skills/lead-intelligence/agents/outreach-drafter.md +98 -0
  244. package/prisma/skills/lead-intelligence/agents/signal-scorer.md +60 -0
  245. package/prisma/skills/liquid-glass-design/SKILL.md +279 -0
  246. package/prisma/skills/llm-trading-agent-security/SKILL.md +147 -0
  247. package/prisma/skills/logistics-exception-management/SKILL.md +222 -0
  248. package/prisma/skills/loop-design-check/SKILL.md +143 -0
  249. package/prisma/skills/mailtrap-email-integration/SKILL.md +77 -0
  250. package/prisma/skills/make-interfaces-feel-better/SKILL.md +152 -0
  251. package/prisma/skills/manim-video/SKILL.md +90 -0
  252. package/prisma/skills/manim-video/assets/network_graph_scene.py +52 -0
  253. package/prisma/skills/market-research/SKILL.md +76 -0
  254. package/prisma/skills/marketing-campaign/SKILL.md +114 -0
  255. package/prisma/skills/mcp-server-patterns/SKILL.md +70 -0
  256. package/prisma/skills/messages-ops/SKILL.md +105 -0
  257. package/prisma/skills/ml-adoption-playbook/SKILL.md +57 -0
  258. package/prisma/skills/mle-workflow/SKILL.md +347 -0
  259. package/prisma/skills/motion-advanced/SKILL.md +596 -0
  260. package/prisma/skills/motion-foundations/SKILL.md +299 -0
  261. package/prisma/skills/motion-patterns/SKILL.md +434 -0
  262. package/prisma/skills/motion-ui/SKILL.md +576 -0
  263. package/prisma/skills/mysql-patterns/SKILL.md +413 -0
  264. package/prisma/skills/nanoclaw-repl/SKILL.md +34 -0
  265. package/prisma/skills/nestjs-patterns/SKILL.md +231 -0
  266. package/prisma/skills/netmiko-ssh-automation/SKILL.md +174 -0
  267. package/prisma/skills/network-bgp-diagnostics/SKILL.md +168 -0
  268. package/prisma/skills/network-config-validation/SKILL.md +211 -0
  269. package/prisma/skills/network-interface-health/SKILL.md +153 -0
  270. package/prisma/skills/nextjs-turbopack/SKILL.md +58 -0
  271. package/prisma/skills/nodejs-keccak256/SKILL.md +103 -0
  272. package/prisma/skills/nutrient-document-processing/SKILL.md +168 -0
  273. package/prisma/skills/nuxt4-patterns/SKILL.md +101 -0
  274. package/prisma/skills/openclaw-persona-forge/SKILL.md +289 -0
  275. package/prisma/skills/openclaw-persona-forge/gacha.py +224 -0
  276. package/prisma/skills/openclaw-persona-forge/gacha.sh +5 -0
  277. package/prisma/skills/openclaw-persona-forge/references/avatar-style.md +124 -0
  278. package/prisma/skills/openclaw-persona-forge/references/boundary-rules.md +53 -0
  279. package/prisma/skills/openclaw-persona-forge/references/error-handling.md +53 -0
  280. package/prisma/skills/openclaw-persona-forge/references/identity-tension.md +48 -0
  281. package/prisma/skills/openclaw-persona-forge/references/naming-system.md +39 -0
  282. package/prisma/skills/openclaw-persona-forge/references/output-template.md +166 -0
  283. package/prisma/skills/opensource-pipeline/SKILL.md +256 -0
  284. package/prisma/skills/orch-add-feature/SKILL.md +45 -0
  285. package/prisma/skills/orch-build-mvp/SKILL.md +49 -0
  286. package/prisma/skills/orch-change-feature/SKILL.md +43 -0
  287. package/prisma/skills/orch-fix-defect/SKILL.md +43 -0
  288. package/prisma/skills/orch-pipeline/SKILL.md +121 -0
  289. package/prisma/skills/orch-refine-code/SKILL.md +44 -0
  290. package/prisma/skills/parallel-execution-optimizer/SKILL.md +73 -0
  291. package/prisma/skills/perl-patterns/SKILL.md +505 -0
  292. package/prisma/skills/perl-security/SKILL.md +504 -0
  293. package/prisma/skills/perl-testing/SKILL.md +476 -0
  294. package/prisma/skills/plan-orchestrate/SKILL.md +263 -0
  295. package/prisma/skills/plankton-code-quality/SKILL.md +237 -0
  296. package/prisma/skills/postgres-patterns/SKILL.md +148 -0
  297. package/prisma/skills/prediction-market-oracle-research/SKILL.md +64 -0
  298. package/prisma/skills/prediction-market-risk-review/SKILL.md +61 -0
  299. package/prisma/skills/prisma-patterns/SKILL.md +401 -0
  300. package/prisma/skills/product-capability/SKILL.md +142 -0
  301. package/prisma/skills/product-lens/SKILL.md +93 -0
  302. package/prisma/skills/production-audit/SKILL.md +207 -0
  303. package/prisma/skills/production-scheduling/SKILL.md +238 -0
  304. package/prisma/skills/project-flow-ops/SKILL.md +112 -0
  305. package/prisma/skills/prompt-optimizer/SKILL.md +398 -0
  306. package/prisma/skills/python-patterns/SKILL.md +751 -0
  307. package/prisma/skills/python-testing/SKILL.md +817 -0
  308. package/prisma/skills/pytorch-patterns/SKILL.md +397 -0
  309. package/prisma/skills/quality-nonconformance/SKILL.md +260 -0
  310. package/prisma/skills/quarkus-patterns/SKILL.md +723 -0
  311. package/prisma/skills/quarkus-security/SKILL.md +468 -0
  312. package/prisma/skills/quarkus-tdd/SKILL.md +812 -0
  313. package/prisma/skills/quarkus-verification/SKILL.md +480 -0
  314. package/prisma/skills/ralphinho-rfc-pipeline/SKILL.md +68 -0
  315. package/prisma/skills/react-native-patterns/SKILL.md +326 -0
  316. package/prisma/skills/react-patterns/SKILL.md +342 -0
  317. package/prisma/skills/react-performance/SKILL.md +575 -0
  318. package/prisma/skills/react-testing/SKILL.md +424 -0
  319. package/prisma/skills/recsys-pipeline-architect/SKILL.md +115 -0
  320. package/prisma/skills/recursive-decision-ledger/SKILL.md +80 -0
  321. package/prisma/skills/redis-patterns/SKILL.md +404 -0
  322. package/prisma/skills/regex-vs-llm-structured-text/SKILL.md +221 -0
  323. package/prisma/skills/remotion-video-creation/SKILL.md +43 -0
  324. package/prisma/skills/remotion-video-creation/rules/3d.md +86 -0
  325. package/prisma/skills/remotion-video-creation/rules/animations.md +29 -0
  326. package/prisma/skills/remotion-video-creation/rules/assets/charts-bar-chart.tsx +173 -0
  327. package/prisma/skills/remotion-video-creation/rules/assets/text-animations-typewriter.tsx +100 -0
  328. package/prisma/skills/remotion-video-creation/rules/assets/text-animations-word-highlight.tsx +108 -0
  329. package/prisma/skills/remotion-video-creation/rules/assets.md +78 -0
  330. package/prisma/skills/remotion-video-creation/rules/audio.md +172 -0
  331. package/prisma/skills/remotion-video-creation/rules/calculate-metadata.md +104 -0
  332. package/prisma/skills/remotion-video-creation/rules/can-decode.md +75 -0
  333. package/prisma/skills/remotion-video-creation/rules/charts.md +58 -0
  334. package/prisma/skills/remotion-video-creation/rules/compositions.md +146 -0
  335. package/prisma/skills/remotion-video-creation/rules/display-captions.md +126 -0
  336. package/prisma/skills/remotion-video-creation/rules/extract-frames.md +229 -0
  337. package/prisma/skills/remotion-video-creation/rules/fonts.md +152 -0
  338. package/prisma/skills/remotion-video-creation/rules/get-audio-duration.md +58 -0
  339. package/prisma/skills/remotion-video-creation/rules/get-video-dimensions.md +68 -0
  340. package/prisma/skills/remotion-video-creation/rules/get-video-duration.md +58 -0
  341. package/prisma/skills/remotion-video-creation/rules/gifs.md +138 -0
  342. package/prisma/skills/remotion-video-creation/rules/images.md +130 -0
  343. package/prisma/skills/remotion-video-creation/rules/import-srt-captions.md +67 -0
  344. package/prisma/skills/remotion-video-creation/rules/lottie.md +67 -0
  345. package/prisma/skills/remotion-video-creation/rules/measuring-dom-nodes.md +34 -0
  346. package/prisma/skills/remotion-video-creation/rules/measuring-text.md +143 -0
  347. package/prisma/skills/remotion-video-creation/rules/sequencing.md +106 -0
  348. package/prisma/skills/remotion-video-creation/rules/tailwind.md +11 -0
  349. package/prisma/skills/remotion-video-creation/rules/text-animations.md +20 -0
  350. package/prisma/skills/remotion-video-creation/rules/timing.md +179 -0
  351. package/prisma/skills/remotion-video-creation/rules/transcribe-captions.md +19 -0
  352. package/prisma/skills/remotion-video-creation/rules/transitions.md +122 -0
  353. package/prisma/skills/remotion-video-creation/rules/trimming.md +52 -0
  354. package/prisma/skills/remotion-video-creation/rules/videos.md +171 -0
  355. package/prisma/skills/repo-scan/SKILL.md +79 -0
  356. package/prisma/skills/research-ops/SKILL.md +113 -0
  357. package/prisma/skills/returns-reverse-logistics/SKILL.md +240 -0
  358. package/prisma/skills/rules-distill/SKILL.md +265 -0
  359. package/prisma/skills/rules-distill/scripts/scan-rules.sh +58 -0
  360. package/prisma/skills/rules-distill/scripts/scan-skills.sh +129 -0
  361. package/prisma/skills/rust-patterns/SKILL.md +500 -0
  362. package/prisma/skills/rust-testing/SKILL.md +501 -0
  363. package/prisma/skills/safety-guard/SKILL.md +76 -0
  364. package/prisma/skills/santa-method/SKILL.md +307 -0
  365. package/prisma/skills/scientific-db-pubmed-database/SKILL.md +176 -0
  366. package/prisma/skills/scientific-db-uspto-database/SKILL.md +178 -0
  367. package/prisma/skills/scientific-pkg-gget/SKILL.md +167 -0
  368. package/prisma/skills/scientific-thinking-literature-review/SKILL.md +193 -0
  369. package/prisma/skills/scientific-thinking-scholar-evaluation/SKILL.md +161 -0
  370. package/prisma/skills/search-first/SKILL.md +183 -0
  371. package/prisma/skills/security-bounty-hunter/SKILL.md +100 -0
  372. package/prisma/skills/security-review/SKILL.md +504 -0
  373. package/prisma/skills/security-review/cloud-infrastructure-security.md +361 -0
  374. package/prisma/skills/security-scan/SKILL.md +166 -0
  375. package/prisma/skills/seo/SKILL.md +155 -0
  376. package/prisma/skills/skill-comply/SKILL.md +59 -0
  377. package/prisma/skills/skill-comply/fixtures/compliant_trace.jsonl +5 -0
  378. package/prisma/skills/skill-comply/fixtures/noncompliant_trace.jsonl +3 -0
  379. package/prisma/skills/skill-comply/fixtures/tdd_spec.yaml +44 -0
  380. package/prisma/skills/skill-comply/prompts/classifier.md +24 -0
  381. package/prisma/skills/skill-comply/prompts/scenario_generator.md +62 -0
  382. package/prisma/skills/skill-comply/prompts/spec_generator.md +42 -0
  383. package/prisma/skills/skill-comply/pyproject.toml +15 -0
  384. package/prisma/skills/skill-comply/scripts/__init__.py +0 -0
  385. package/prisma/skills/skill-comply/scripts/classifier.py +85 -0
  386. package/prisma/skills/skill-comply/scripts/grader.py +124 -0
  387. package/prisma/skills/skill-comply/scripts/parser.py +107 -0
  388. package/prisma/skills/skill-comply/scripts/report.py +170 -0
  389. package/prisma/skills/skill-comply/scripts/run.py +127 -0
  390. package/prisma/skills/skill-comply/scripts/runner.py +194 -0
  391. package/prisma/skills/skill-comply/scripts/scenario_generator.py +70 -0
  392. package/prisma/skills/skill-comply/scripts/spec_generator.py +72 -0
  393. package/prisma/skills/skill-comply/scripts/utils.py +13 -0
  394. package/prisma/skills/skill-comply/tests/test_grader.py +197 -0
  395. package/prisma/skills/skill-comply/tests/test_parser.py +90 -0
  396. package/prisma/skills/skill-comply/tests/test_runner.py +172 -0
  397. package/prisma/skills/skill-scout/SKILL.md +141 -0
  398. package/prisma/skills/skill-stocktake/SKILL.md +195 -0
  399. package/prisma/skills/skill-stocktake/scripts/quick-diff.sh +87 -0
  400. package/prisma/skills/skill-stocktake/scripts/save-results.sh +56 -0
  401. package/prisma/skills/skill-stocktake/scripts/scan.sh +170 -0
  402. package/prisma/skills/social-graph-ranker/SKILL.md +155 -0
  403. package/prisma/skills/social-publisher/SKILL.md +130 -0
  404. package/prisma/skills/springboot-patterns/SKILL.md +315 -0
  405. package/prisma/skills/springboot-security/SKILL.md +273 -0
  406. package/prisma/skills/springboot-tdd/SKILL.md +159 -0
  407. package/prisma/skills/springboot-verification/SKILL.md +232 -0
  408. package/prisma/skills/strategic-compact/SKILL.md +136 -0
  409. package/prisma/skills/swift-actor-persistence/SKILL.md +144 -0
  410. package/prisma/skills/swift-concurrency-6-2/SKILL.md +216 -0
  411. package/prisma/skills/swift-protocol-di-testing/SKILL.md +191 -0
  412. package/prisma/skills/swiftui-patterns/SKILL.md +259 -0
  413. package/prisma/skills/taste/SKILL.md +264 -0
  414. package/prisma/skills/taste/references/genre-taxonomy.md +87 -0
  415. package/prisma/skills/tdd-workflow/SKILL.md +583 -0
  416. package/prisma/skills/team-agent-orchestration/SKILL.md +111 -0
  417. package/prisma/skills/team-builder/SKILL.md +169 -0
  418. package/prisma/skills/terminal-ops/SKILL.md +110 -0
  419. package/prisma/skills/tinystruct-patterns/SKILL.md +279 -0
  420. package/prisma/skills/tinystruct-patterns/references/architecture.md +90 -0
  421. package/prisma/skills/tinystruct-patterns/references/data-handling.md +60 -0
  422. package/prisma/skills/tinystruct-patterns/references/database.md +99 -0
  423. package/prisma/skills/tinystruct-patterns/references/routing.md +64 -0
  424. package/prisma/skills/tinystruct-patterns/references/system-usage.md +97 -0
  425. package/prisma/skills/tinystruct-patterns/references/testing.md +72 -0
  426. package/prisma/skills/token-budget-advisor/SKILL.md +134 -0
  427. package/prisma/skills/ui-demo/SKILL.md +466 -0
  428. package/prisma/skills/ui-to-vue/SKILL.md +135 -0
  429. package/prisma/skills/uncloud/SKILL.md +344 -0
  430. package/prisma/skills/unified-notifications-ops/SKILL.md +188 -0
  431. package/prisma/skills/verification-loop/SKILL.md +127 -0
  432. package/prisma/skills/video-editing/SKILL.md +311 -0
  433. package/prisma/skills/videodb/SKILL.md +375 -0
  434. package/prisma/skills/videodb/reference/api-reference.md +550 -0
  435. package/prisma/skills/videodb/reference/capture-reference.md +407 -0
  436. package/prisma/skills/videodb/reference/capture.md +101 -0
  437. package/prisma/skills/videodb/reference/editor.md +443 -0
  438. package/prisma/skills/videodb/reference/generative.md +331 -0
  439. package/prisma/skills/videodb/reference/rtstream-reference.md +564 -0
  440. package/prisma/skills/videodb/reference/rtstream.md +65 -0
  441. package/prisma/skills/videodb/reference/search.md +230 -0
  442. package/prisma/skills/videodb/reference/streaming.md +406 -0
  443. package/prisma/skills/videodb/reference/use-cases.md +118 -0
  444. package/prisma/skills/videodb/scripts/ws_listener.py +282 -0
  445. package/prisma/skills/visa-doc-translate/README.md +86 -0
  446. package/prisma/skills/visa-doc-translate/SKILL.md +117 -0
  447. package/prisma/skills/vite-patterns/SKILL.md +450 -0
  448. package/prisma/skills/vue-patterns/SKILL.md +471 -0
  449. package/prisma/skills/windows-desktop-e2e/SKILL.md +888 -0
  450. package/prisma/skills/workspace-surface-audit/SKILL.md +126 -0
  451. package/prisma/skills/x-api/SKILL.md +235 -0
@@ -0,0 +1,690 @@
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
+ metadata:
5
+ origin: ECC
6
+ ---
7
+
8
+ # Ktor Server Patterns
9
+
10
+ Comprehensive Ktor patterns for building robust, maintainable HTTP servers with Kotlin coroutines.
11
+
12
+ ## When to Activate
13
+
14
+ - Building Ktor HTTP servers
15
+ - Configuring Ktor plugins (Auth, CORS, ContentNegotiation, StatusPages)
16
+ - Implementing REST APIs with Ktor
17
+ - Setting up dependency injection with Koin
18
+ - Writing Ktor integration tests with testApplication
19
+ - Working with WebSockets in Ktor
20
+
21
+ ## Application Structure
22
+
23
+ ### Standard Ktor Project Layout
24
+
25
+ ```text
26
+ src/main/kotlin/
27
+ ├── com/example/
28
+ │ ├── Application.kt # Entry point, module configuration
29
+ │ ├── plugins/
30
+ │ │ ├── Routing.kt # Route definitions
31
+ │ │ ├── Serialization.kt # Content negotiation setup
32
+ │ │ ├── Authentication.kt # Auth configuration
33
+ │ │ ├── StatusPages.kt # Error handling
34
+ │ │ └── CORS.kt # CORS configuration
35
+ │ ├── routes/
36
+ │ │ ├── UserRoutes.kt # /users endpoints
37
+ │ │ ├── AuthRoutes.kt # /auth endpoints
38
+ │ │ └── HealthRoutes.kt # /health endpoints
39
+ │ ├── models/
40
+ │ │ ├── User.kt # Domain models
41
+ │ │ └── ApiResponse.kt # Response envelopes
42
+ │ ├── services/
43
+ │ │ ├── UserService.kt # Business logic
44
+ │ │ └── AuthService.kt # Auth logic
45
+ │ ├── repositories/
46
+ │ │ ├── UserRepository.kt # Data access interface
47
+ │ │ └── ExposedUserRepository.kt
48
+ │ └── di/
49
+ │ └── AppModule.kt # Koin modules
50
+ src/test/kotlin/
51
+ ├── com/example/
52
+ │ ├── routes/
53
+ │ │ └── UserRoutesTest.kt
54
+ │ └── services/
55
+ │ └── UserServiceTest.kt
56
+ ```
57
+
58
+ ### Application Entry Point
59
+
60
+ ```kotlin
61
+ // Application.kt
62
+ fun main() {
63
+ embeddedServer(Netty, port = 8080, module = Application::module).start(wait = true)
64
+ }
65
+
66
+ fun Application.module() {
67
+ configureSerialization()
68
+ configureAuthentication()
69
+ configureStatusPages()
70
+ configureCORS()
71
+ configureDI()
72
+ configureRouting()
73
+ }
74
+ ```
75
+
76
+ ## Routing DSL
77
+
78
+ ### Basic Routes
79
+
80
+ ```kotlin
81
+ // plugins/Routing.kt
82
+ fun Application.configureRouting() {
83
+ routing {
84
+ userRoutes()
85
+ authRoutes()
86
+ healthRoutes()
87
+ }
88
+ }
89
+
90
+ // routes/UserRoutes.kt
91
+ fun Route.userRoutes() {
92
+ val userService by inject<UserService>()
93
+
94
+ route("/users") {
95
+ get {
96
+ val users = userService.getAll()
97
+ call.respond(users)
98
+ }
99
+
100
+ get("/{id}") {
101
+ val id = call.parameters["id"]
102
+ ?: return@get call.respond(HttpStatusCode.BadRequest, "Missing id")
103
+ val user = userService.getById(id)
104
+ ?: return@get call.respond(HttpStatusCode.NotFound)
105
+ call.respond(user)
106
+ }
107
+
108
+ post {
109
+ val request = call.receive<CreateUserRequest>()
110
+ val user = userService.create(request)
111
+ call.respond(HttpStatusCode.Created, user)
112
+ }
113
+
114
+ put("/{id}") {
115
+ val id = call.parameters["id"]
116
+ ?: return@put call.respond(HttpStatusCode.BadRequest, "Missing id")
117
+ val request = call.receive<UpdateUserRequest>()
118
+ val user = userService.update(id, request)
119
+ ?: return@put call.respond(HttpStatusCode.NotFound)
120
+ call.respond(user)
121
+ }
122
+
123
+ delete("/{id}") {
124
+ val id = call.parameters["id"]
125
+ ?: return@delete call.respond(HttpStatusCode.BadRequest, "Missing id")
126
+ val deleted = userService.delete(id)
127
+ if (deleted) call.respond(HttpStatusCode.NoContent)
128
+ else call.respond(HttpStatusCode.NotFound)
129
+ }
130
+ }
131
+ }
132
+ ```
133
+
134
+ ### Route Organization with Authenticated Routes
135
+
136
+ ```kotlin
137
+ fun Route.userRoutes() {
138
+ route("/users") {
139
+ // Public routes
140
+ get { /* list users */ }
141
+ get("/{id}") { /* get user */ }
142
+
143
+ // Protected routes
144
+ authenticate("jwt") {
145
+ post { /* create user - requires auth */ }
146
+ put("/{id}") { /* update user - requires auth */ }
147
+ delete("/{id}") { /* delete user - requires auth */ }
148
+ }
149
+ }
150
+ }
151
+ ```
152
+
153
+ ## Content Negotiation & Serialization
154
+
155
+ ### kotlinx.serialization Setup
156
+
157
+ ```kotlin
158
+ // plugins/Serialization.kt
159
+ fun Application.configureSerialization() {
160
+ install(ContentNegotiation) {
161
+ json(Json {
162
+ prettyPrint = true
163
+ isLenient = false
164
+ ignoreUnknownKeys = true
165
+ encodeDefaults = true
166
+ explicitNulls = false
167
+ })
168
+ }
169
+ }
170
+ ```
171
+
172
+ ### Serializable Models
173
+
174
+ ```kotlin
175
+ @Serializable
176
+ data class UserResponse(
177
+ val id: String,
178
+ val name: String,
179
+ val email: String,
180
+ val role: Role,
181
+ @Serializable(with = InstantSerializer::class)
182
+ val createdAt: Instant,
183
+ )
184
+
185
+ @Serializable
186
+ data class CreateUserRequest(
187
+ val name: String,
188
+ val email: String,
189
+ val role: Role = Role.USER,
190
+ )
191
+
192
+ @Serializable
193
+ data class ApiResponse<T>(
194
+ val success: Boolean,
195
+ val data: T? = null,
196
+ val error: String? = null,
197
+ ) {
198
+ companion object {
199
+ fun <T> ok(data: T): ApiResponse<T> = ApiResponse(success = true, data = data)
200
+ fun <T> error(message: String): ApiResponse<T> = ApiResponse(success = false, error = message)
201
+ }
202
+ }
203
+
204
+ @Serializable
205
+ data class PaginatedResponse<T>(
206
+ val data: List<T>,
207
+ val total: Long,
208
+ val page: Int,
209
+ val limit: Int,
210
+ )
211
+ ```
212
+
213
+ ### Custom Serializers
214
+
215
+ ```kotlin
216
+ object InstantSerializer : KSerializer<Instant> {
217
+ override val descriptor = PrimitiveSerialDescriptor("Instant", PrimitiveKind.STRING)
218
+ override fun serialize(encoder: Encoder, value: Instant) =
219
+ encoder.encodeString(value.toString())
220
+ override fun deserialize(decoder: Decoder): Instant =
221
+ Instant.parse(decoder.decodeString())
222
+ }
223
+ ```
224
+
225
+ ## Authentication
226
+
227
+ ### JWT Authentication
228
+
229
+ ```kotlin
230
+ // plugins/Authentication.kt
231
+ fun Application.configureAuthentication() {
232
+ val jwtSecret = environment.config.property("jwt.secret").getString()
233
+ val jwtIssuer = environment.config.property("jwt.issuer").getString()
234
+ val jwtAudience = environment.config.property("jwt.audience").getString()
235
+ val jwtRealm = environment.config.property("jwt.realm").getString()
236
+
237
+ install(Authentication) {
238
+ jwt("jwt") {
239
+ realm = jwtRealm
240
+ verifier(
241
+ JWT.require(Algorithm.HMAC256(jwtSecret))
242
+ .withAudience(jwtAudience)
243
+ .withIssuer(jwtIssuer)
244
+ .build()
245
+ )
246
+ validate { credential ->
247
+ if (credential.payload.audience.contains(jwtAudience)) {
248
+ JWTPrincipal(credential.payload)
249
+ } else {
250
+ null
251
+ }
252
+ }
253
+ challenge { _, _ ->
254
+ call.respond(HttpStatusCode.Unauthorized, ApiResponse.error<Unit>("Invalid or expired token"))
255
+ }
256
+ }
257
+ }
258
+ }
259
+
260
+ // Extracting user from JWT
261
+ fun ApplicationCall.userId(): String =
262
+ principal<JWTPrincipal>()
263
+ ?.payload
264
+ ?.getClaim("userId")
265
+ ?.asString()
266
+ ?: throw AuthenticationException("No userId in token")
267
+ ```
268
+
269
+ ### Auth Routes
270
+
271
+ ```kotlin
272
+ fun Route.authRoutes() {
273
+ val authService by inject<AuthService>()
274
+
275
+ route("/auth") {
276
+ post("/login") {
277
+ val request = call.receive<LoginRequest>()
278
+ val token = authService.login(request.email, request.password)
279
+ ?: return@post call.respond(
280
+ HttpStatusCode.Unauthorized,
281
+ ApiResponse.error<Unit>("Invalid credentials"),
282
+ )
283
+ call.respond(ApiResponse.ok(TokenResponse(token)))
284
+ }
285
+
286
+ post("/register") {
287
+ val request = call.receive<RegisterRequest>()
288
+ val user = authService.register(request)
289
+ call.respond(HttpStatusCode.Created, ApiResponse.ok(user))
290
+ }
291
+
292
+ authenticate("jwt") {
293
+ get("/me") {
294
+ val userId = call.userId()
295
+ val user = authService.getProfile(userId)
296
+ call.respond(ApiResponse.ok(user))
297
+ }
298
+ }
299
+ }
300
+ }
301
+ ```
302
+
303
+ ## Status Pages (Error Handling)
304
+
305
+ ```kotlin
306
+ // plugins/StatusPages.kt
307
+ fun Application.configureStatusPages() {
308
+ install(StatusPages) {
309
+ exception<ContentTransformationException> { call, cause ->
310
+ call.respond(
311
+ HttpStatusCode.BadRequest,
312
+ ApiResponse.error<Unit>("Invalid request body: ${cause.message}"),
313
+ )
314
+ }
315
+
316
+ exception<IllegalArgumentException> { call, cause ->
317
+ call.respond(
318
+ HttpStatusCode.BadRequest,
319
+ ApiResponse.error<Unit>(cause.message ?: "Bad request"),
320
+ )
321
+ }
322
+
323
+ exception<AuthenticationException> { call, _ ->
324
+ call.respond(
325
+ HttpStatusCode.Unauthorized,
326
+ ApiResponse.error<Unit>("Authentication required"),
327
+ )
328
+ }
329
+
330
+ exception<AuthorizationException> { call, _ ->
331
+ call.respond(
332
+ HttpStatusCode.Forbidden,
333
+ ApiResponse.error<Unit>("Access denied"),
334
+ )
335
+ }
336
+
337
+ exception<NotFoundException> { call, cause ->
338
+ call.respond(
339
+ HttpStatusCode.NotFound,
340
+ ApiResponse.error<Unit>(cause.message ?: "Resource not found"),
341
+ )
342
+ }
343
+
344
+ exception<Throwable> { call, cause ->
345
+ call.application.log.error("Unhandled exception", cause)
346
+ call.respond(
347
+ HttpStatusCode.InternalServerError,
348
+ ApiResponse.error<Unit>("Internal server error"),
349
+ )
350
+ }
351
+
352
+ status(HttpStatusCode.NotFound) { call, status ->
353
+ call.respond(status, ApiResponse.error<Unit>("Route not found"))
354
+ }
355
+ }
356
+ }
357
+ ```
358
+
359
+ ## CORS Configuration
360
+
361
+ ```kotlin
362
+ // plugins/CORS.kt
363
+ fun Application.configureCORS() {
364
+ install(CORS) {
365
+ allowHost("localhost:3000")
366
+ allowHost("example.com", schemes = listOf("https"))
367
+ allowHeader(HttpHeaders.ContentType)
368
+ allowHeader(HttpHeaders.Authorization)
369
+ allowMethod(HttpMethod.Put)
370
+ allowMethod(HttpMethod.Delete)
371
+ allowMethod(HttpMethod.Patch)
372
+ allowCredentials = true
373
+ maxAgeInSeconds = 3600
374
+ }
375
+ }
376
+ ```
377
+
378
+ ## Koin Dependency Injection
379
+
380
+ ### Module Definition
381
+
382
+ ```kotlin
383
+ // di/AppModule.kt
384
+ val appModule = module {
385
+ // Database
386
+ single<Database> { DatabaseFactory.create(get()) }
387
+
388
+ // Repositories
389
+ single<UserRepository> { ExposedUserRepository(get()) }
390
+ single<OrderRepository> { ExposedOrderRepository(get()) }
391
+
392
+ // Services
393
+ single { UserService(get()) }
394
+ single { OrderService(get(), get()) }
395
+ single { AuthService(get(), get()) }
396
+ }
397
+
398
+ // Application setup
399
+ fun Application.configureDI() {
400
+ install(Koin) {
401
+ modules(appModule)
402
+ }
403
+ }
404
+ ```
405
+
406
+ ### Using Koin in Routes
407
+
408
+ ```kotlin
409
+ fun Route.userRoutes() {
410
+ val userService by inject<UserService>()
411
+
412
+ route("/users") {
413
+ get {
414
+ val users = userService.getAll()
415
+ call.respond(ApiResponse.ok(users))
416
+ }
417
+ }
418
+ }
419
+ ```
420
+
421
+ ### Koin for Testing
422
+
423
+ ```kotlin
424
+ class UserServiceTest : FunSpec(), KoinTest {
425
+ override fun extensions() = listOf(KoinExtension(testModule))
426
+
427
+ private val testModule = module {
428
+ single<UserRepository> { mockk() }
429
+ single { UserService(get()) }
430
+ }
431
+
432
+ private val repository by inject<UserRepository>()
433
+ private val service by inject<UserService>()
434
+
435
+ init {
436
+ test("getUser returns user") {
437
+ coEvery { repository.findById("1") } returns testUser
438
+ service.getById("1") shouldBe testUser
439
+ }
440
+ }
441
+ }
442
+ ```
443
+
444
+ ## Request Validation
445
+
446
+ ```kotlin
447
+ // Validate request data in routes
448
+ fun Route.userRoutes() {
449
+ val userService by inject<UserService>()
450
+
451
+ post("/users") {
452
+ val request = call.receive<CreateUserRequest>()
453
+
454
+ // Validate
455
+ require(request.name.isNotBlank()) { "Name is required" }
456
+ require(request.name.length <= 100) { "Name must be 100 characters or less" }
457
+ require(request.email.matches(Regex(".+@.+\\..+"))) { "Invalid email format" }
458
+
459
+ val user = userService.create(request)
460
+ call.respond(HttpStatusCode.Created, ApiResponse.ok(user))
461
+ }
462
+ }
463
+
464
+ // Or use a validation extension
465
+ fun CreateUserRequest.validate() {
466
+ require(name.isNotBlank()) { "Name is required" }
467
+ require(name.length <= 100) { "Name must be 100 characters or less" }
468
+ require(email.matches(Regex(".+@.+\\..+"))) { "Invalid email format" }
469
+ }
470
+ ```
471
+
472
+ ## WebSockets
473
+
474
+ ```kotlin
475
+ fun Application.configureWebSockets() {
476
+ install(WebSockets) {
477
+ pingPeriod = 15.seconds
478
+ timeout = 15.seconds
479
+ maxFrameSize = 64 * 1024 // 64 KiB — increase only if your protocol requires larger frames
480
+ masking = false // Server-to-client frames are unmasked per RFC 6455; client-to-server are always masked by Ktor
481
+ }
482
+ }
483
+
484
+ fun Route.chatRoutes() {
485
+ val connections = Collections.synchronizedSet<Connection>(LinkedHashSet())
486
+
487
+ webSocket("/chat") {
488
+ val thisConnection = Connection(this)
489
+ connections += thisConnection
490
+
491
+ try {
492
+ send("Connected! Users online: ${connections.size}")
493
+
494
+ for (frame in incoming) {
495
+ frame as? Frame.Text ?: continue
496
+ val text = frame.readText()
497
+ val message = ChatMessage(thisConnection.name, text)
498
+
499
+ // Snapshot under lock to avoid ConcurrentModificationException
500
+ val snapshot = synchronized(connections) { connections.toList() }
501
+ snapshot.forEach { conn ->
502
+ conn.session.send(Json.encodeToString(message))
503
+ }
504
+ }
505
+ } catch (e: Exception) {
506
+ logger.error("WebSocket error", e)
507
+ } finally {
508
+ connections -= thisConnection
509
+ }
510
+ }
511
+ }
512
+
513
+ data class Connection(val session: DefaultWebSocketSession) {
514
+ val name: String = "User-${counter.getAndIncrement()}"
515
+
516
+ companion object {
517
+ private val counter = AtomicInteger(0)
518
+ }
519
+ }
520
+ ```
521
+
522
+ ## testApplication Testing
523
+
524
+ ### Basic Route Testing
525
+
526
+ ```kotlin
527
+ class UserRoutesTest : FunSpec({
528
+ test("GET /users returns list of users") {
529
+ testApplication {
530
+ application {
531
+ install(Koin) { modules(testModule) }
532
+ configureSerialization()
533
+ configureRouting()
534
+ }
535
+
536
+ val response = client.get("/users")
537
+
538
+ response.status shouldBe HttpStatusCode.OK
539
+ val body = response.body<ApiResponse<List<UserResponse>>>()
540
+ body.success shouldBe true
541
+ body.data.shouldNotBeNull().shouldNotBeEmpty()
542
+ }
543
+ }
544
+
545
+ test("POST /users creates a user") {
546
+ testApplication {
547
+ application {
548
+ install(Koin) { modules(testModule) }
549
+ configureSerialization()
550
+ configureStatusPages()
551
+ configureRouting()
552
+ }
553
+
554
+ val client = createClient {
555
+ install(io.ktor.client.plugins.contentnegotiation.ContentNegotiation) {
556
+ json()
557
+ }
558
+ }
559
+
560
+ val response = client.post("/users") {
561
+ contentType(ContentType.Application.Json)
562
+ setBody(CreateUserRequest("Alice", "alice@example.com"))
563
+ }
564
+
565
+ response.status shouldBe HttpStatusCode.Created
566
+ }
567
+ }
568
+
569
+ test("GET /users/{id} returns 404 for unknown id") {
570
+ testApplication {
571
+ application {
572
+ install(Koin) { modules(testModule) }
573
+ configureSerialization()
574
+ configureStatusPages()
575
+ configureRouting()
576
+ }
577
+
578
+ val response = client.get("/users/unknown-id")
579
+
580
+ response.status shouldBe HttpStatusCode.NotFound
581
+ }
582
+ }
583
+ })
584
+ ```
585
+
586
+ ### Testing Authenticated Routes
587
+
588
+ ```kotlin
589
+ class AuthenticatedRoutesTest : FunSpec({
590
+ test("protected route requires JWT") {
591
+ testApplication {
592
+ application {
593
+ install(Koin) { modules(testModule) }
594
+ configureSerialization()
595
+ configureAuthentication()
596
+ configureRouting()
597
+ }
598
+
599
+ val response = client.post("/users") {
600
+ contentType(ContentType.Application.Json)
601
+ setBody(CreateUserRequest("Alice", "alice@example.com"))
602
+ }
603
+
604
+ response.status shouldBe HttpStatusCode.Unauthorized
605
+ }
606
+ }
607
+
608
+ test("protected route succeeds with valid JWT") {
609
+ testApplication {
610
+ application {
611
+ install(Koin) { modules(testModule) }
612
+ configureSerialization()
613
+ configureAuthentication()
614
+ configureRouting()
615
+ }
616
+
617
+ val token = generateTestJWT(userId = "test-user")
618
+
619
+ val client = createClient {
620
+ install(io.ktor.client.plugins.contentnegotiation.ContentNegotiation) { json() }
621
+ }
622
+
623
+ val response = client.post("/users") {
624
+ contentType(ContentType.Application.Json)
625
+ bearerAuth(token)
626
+ setBody(CreateUserRequest("Alice", "alice@example.com"))
627
+ }
628
+
629
+ response.status shouldBe HttpStatusCode.Created
630
+ }
631
+ }
632
+ })
633
+ ```
634
+
635
+ ## Configuration
636
+
637
+ ### application.yaml
638
+
639
+ ```yaml
640
+ ktor:
641
+ application:
642
+ modules:
643
+ - com.example.ApplicationKt.module
644
+ deployment:
645
+ port: 8080
646
+
647
+ jwt:
648
+ secret: ${JWT_SECRET}
649
+ issuer: "https://example.com"
650
+ audience: "https://example.com/api"
651
+ realm: "example"
652
+
653
+ database:
654
+ url: ${DATABASE_URL}
655
+ driver: "org.postgresql.Driver"
656
+ maxPoolSize: 10
657
+ ```
658
+
659
+ ### Reading Config
660
+
661
+ ```kotlin
662
+ fun Application.configureDI() {
663
+ val dbUrl = environment.config.property("database.url").getString()
664
+ val dbDriver = environment.config.property("database.driver").getString()
665
+ val maxPoolSize = environment.config.property("database.maxPoolSize").getString().toInt()
666
+
667
+ install(Koin) {
668
+ modules(module {
669
+ single { DatabaseConfig(dbUrl, dbDriver, maxPoolSize) }
670
+ single { DatabaseFactory.create(get()) }
671
+ })
672
+ }
673
+ }
674
+ ```
675
+
676
+ ## Quick Reference: Ktor Patterns
677
+
678
+ | Pattern | Description |
679
+ |---------|-------------|
680
+ | `route("/path") { get { } }` | Route grouping with DSL |
681
+ | `call.receive<T>()` | Deserialize request body |
682
+ | `call.respond(status, body)` | Send response with status |
683
+ | `call.parameters["id"]` | Read path parameters |
684
+ | `call.request.queryParameters["q"]` | Read query parameters |
685
+ | `install(Plugin) { }` | Install and configure plugin |
686
+ | `authenticate("name") { }` | Protect routes with auth |
687
+ | `by inject<T>()` | Koin dependency injection |
688
+ | `testApplication { }` | Integration testing |
689
+
690
+ **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.