arboris-cli 1.0.0 → 1.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 (451) hide show
  1. package/dist/cli.mjs +382 -0
  2. package/manifest.json +323 -0
  3. package/package.json +22 -10
  4. package/prisma/skills/accessibility/SKILL.md +147 -0
  5. package/prisma/skills/agent-architecture-audit/SKILL.md +257 -0
  6. package/prisma/skills/agent-eval/SKILL.md +146 -0
  7. package/prisma/skills/agent-harness-construction/SKILL.md +74 -0
  8. package/prisma/skills/agent-introspection-debugging/SKILL.md +154 -0
  9. package/prisma/skills/agent-payment-x402/SKILL.md +225 -0
  10. package/prisma/skills/agent-self-evaluation/SKILL.md +182 -0
  11. package/prisma/skills/agent-self-evaluation/examples/high-score-example.md +87 -0
  12. package/prisma/skills/agent-self-evaluation/examples/low-score-example.md +86 -0
  13. package/prisma/skills/agent-self-evaluation/references/evaluation-criteria.md +71 -0
  14. package/prisma/skills/agent-self-evaluation/references/hook-integration.md +64 -0
  15. package/prisma/skills/agent-self-evaluation/scripts/evaluate.py +408 -0
  16. package/prisma/skills/agent-self-evaluation/templates/evaluation-report.md +86 -0
  17. package/prisma/skills/agent-sort/SKILL.md +216 -0
  18. package/prisma/skills/agentic-engineering/SKILL.md +64 -0
  19. package/prisma/skills/agentic-os/SKILL.md +388 -0
  20. package/prisma/skills/ai-first-engineering/SKILL.md +52 -0
  21. package/prisma/skills/ai-regression-testing/SKILL.md +386 -0
  22. package/prisma/skills/android-clean-architecture/SKILL.md +340 -0
  23. package/prisma/skills/angular-developer/SKILL.md +155 -0
  24. package/prisma/skills/angular-developer/references/angular-animations.md +160 -0
  25. package/prisma/skills/angular-developer/references/angular-aria.md +410 -0
  26. package/prisma/skills/angular-developer/references/cli.md +86 -0
  27. package/prisma/skills/angular-developer/references/component-harnesses.md +59 -0
  28. package/prisma/skills/angular-developer/references/component-styling.md +91 -0
  29. package/prisma/skills/angular-developer/references/components.md +117 -0
  30. package/prisma/skills/angular-developer/references/creating-services.md +97 -0
  31. package/prisma/skills/angular-developer/references/data-resolvers.md +69 -0
  32. package/prisma/skills/angular-developer/references/define-routes.md +67 -0
  33. package/prisma/skills/angular-developer/references/defining-providers.md +72 -0
  34. package/prisma/skills/angular-developer/references/di-fundamentals.md +120 -0
  35. package/prisma/skills/angular-developer/references/e2e-testing.md +56 -0
  36. package/prisma/skills/angular-developer/references/effects.md +83 -0
  37. package/prisma/skills/angular-developer/references/hierarchical-injectors.md +43 -0
  38. package/prisma/skills/angular-developer/references/host-elements.md +80 -0
  39. package/prisma/skills/angular-developer/references/injection-context.md +63 -0
  40. package/prisma/skills/angular-developer/references/inputs.md +101 -0
  41. package/prisma/skills/angular-developer/references/linked-signal.md +59 -0
  42. package/prisma/skills/angular-developer/references/loading-strategies.md +61 -0
  43. package/prisma/skills/angular-developer/references/mcp.md +108 -0
  44. package/prisma/skills/angular-developer/references/navigate-to-routes.md +69 -0
  45. package/prisma/skills/angular-developer/references/outputs.md +86 -0
  46. package/prisma/skills/angular-developer/references/reactive-forms.md +122 -0
  47. package/prisma/skills/angular-developer/references/rendering-strategies.md +44 -0
  48. package/prisma/skills/angular-developer/references/resource.md +77 -0
  49. package/prisma/skills/angular-developer/references/route-animations.md +56 -0
  50. package/prisma/skills/angular-developer/references/route-guards.md +52 -0
  51. package/prisma/skills/angular-developer/references/router-lifecycle.md +45 -0
  52. package/prisma/skills/angular-developer/references/router-testing.md +87 -0
  53. package/prisma/skills/angular-developer/references/show-routes-with-outlets.md +68 -0
  54. package/prisma/skills/angular-developer/references/signal-forms.md +795 -0
  55. package/prisma/skills/angular-developer/references/signals-overview.md +94 -0
  56. package/prisma/skills/angular-developer/references/tailwind-css.md +69 -0
  57. package/prisma/skills/angular-developer/references/template-driven-forms.md +114 -0
  58. package/prisma/skills/angular-developer/references/testing-fundamentals.md +65 -0
  59. package/prisma/skills/api-connector-builder/SKILL.md +121 -0
  60. package/prisma/skills/api-design/SKILL.md +524 -0
  61. package/prisma/skills/architecture-decision-records/SKILL.md +180 -0
  62. package/prisma/skills/article-writing/SKILL.md +80 -0
  63. package/prisma/skills/automation-audit-ops/SKILL.md +143 -0
  64. package/prisma/skills/autonomous-agent-harness/SKILL.md +274 -0
  65. package/prisma/skills/autonomous-loops/SKILL.md +611 -0
  66. package/prisma/skills/backend-patterns/SKILL.md +562 -0
  67. package/prisma/skills/benchmark/SKILL.md +94 -0
  68. package/prisma/skills/benchmark-methodology/SKILL.md +190 -0
  69. package/prisma/skills/benchmark-optimization-loop/SKILL.md +70 -0
  70. package/prisma/skills/blender-motion-state-inspection/SKILL.md +165 -0
  71. package/prisma/skills/blueprint/SKILL.md +106 -0
  72. package/prisma/skills/brand-discovery/SKILL.md +145 -0
  73. package/prisma/skills/brand-discovery/references/10_purpose-why.md +40 -0
  74. package/prisma/skills/brand-discovery/references/20_positioning.md +44 -0
  75. package/prisma/skills/brand-discovery/references/30_audience-niche.md +52 -0
  76. package/prisma/skills/brand-discovery/references/40_personality-archetype.md +57 -0
  77. package/prisma/skills/brand-discovery/references/50_voice-tone.md +59 -0
  78. package/prisma/skills/brand-discovery/references/60_narrative-story.md +50 -0
  79. package/prisma/skills/brand-discovery/references/70_founder-tension.md +49 -0
  80. package/prisma/skills/brand-discovery/references/90_SYNTHESIS.md +133 -0
  81. package/prisma/skills/brand-voice/SKILL.md +98 -0
  82. package/prisma/skills/brand-voice/references/voice-profile-schema.md +55 -0
  83. package/prisma/skills/browser-qa/SKILL.md +105 -0
  84. package/prisma/skills/bun-runtime/SKILL.md +85 -0
  85. package/prisma/skills/canary-watch/SKILL.md +108 -0
  86. package/prisma/skills/carrier-relationship-management/SKILL.md +212 -0
  87. package/prisma/skills/cisco-ios-patterns/SKILL.md +164 -0
  88. package/prisma/skills/ck/SKILL.md +148 -0
  89. package/prisma/skills/ck/commands/forget.mjs +44 -0
  90. package/prisma/skills/ck/commands/info.mjs +24 -0
  91. package/prisma/skills/ck/commands/init.mjs +143 -0
  92. package/prisma/skills/ck/commands/list.mjs +40 -0
  93. package/prisma/skills/ck/commands/migrate.mjs +202 -0
  94. package/prisma/skills/ck/commands/resume.mjs +36 -0
  95. package/prisma/skills/ck/commands/save.mjs +210 -0
  96. package/prisma/skills/ck/commands/shared.mjs +387 -0
  97. package/prisma/skills/ck/hooks/session-start.mjs +224 -0
  98. package/prisma/skills/claude-devfleet/SKILL.md +112 -0
  99. package/prisma/skills/click-path-audit/SKILL.md +245 -0
  100. package/prisma/skills/clickhouse-io/SKILL.md +440 -0
  101. package/prisma/skills/code-tour/SKILL.md +254 -0
  102. package/prisma/skills/codebase-onboarding/SKILL.md +234 -0
  103. package/prisma/skills/codehealth-mcp/SKILL.md +167 -0
  104. package/prisma/skills/coding-standards/SKILL.md +551 -0
  105. package/prisma/skills/competitive-platform-analysis/SKILL.md +214 -0
  106. package/prisma/skills/competitive-report-structure/SKILL.md +162 -0
  107. package/prisma/skills/compose-multiplatform-patterns/SKILL.md +300 -0
  108. package/prisma/skills/config-gc/SKILL.md +120 -0
  109. package/prisma/skills/configure-ecc/SKILL.md +385 -0
  110. package/prisma/skills/connections-optimizer/SKILL.md +190 -0
  111. package/prisma/skills/content-engine/SKILL.md +132 -0
  112. package/prisma/skills/content-hash-cache-pattern/SKILL.md +162 -0
  113. package/prisma/skills/context-budget/SKILL.md +136 -0
  114. package/prisma/skills/continuous-agent-loop/SKILL.md +46 -0
  115. package/prisma/skills/continuous-learning/SKILL.md +132 -0
  116. package/prisma/skills/continuous-learning/config.json +18 -0
  117. package/prisma/skills/continuous-learning/evaluate-session.sh +69 -0
  118. package/prisma/skills/continuous-learning-v2/SKILL.md +361 -0
  119. package/prisma/skills/continuous-learning-v2/agents/observer-loop.sh +359 -0
  120. package/prisma/skills/continuous-learning-v2/agents/observer.md +189 -0
  121. package/prisma/skills/continuous-learning-v2/agents/session-guardian.sh +150 -0
  122. package/prisma/skills/continuous-learning-v2/agents/start-observer.sh +248 -0
  123. package/prisma/skills/continuous-learning-v2/config.json +8 -0
  124. package/prisma/skills/continuous-learning-v2/hooks/observe.sh +585 -0
  125. package/prisma/skills/continuous-learning-v2/scripts/detect-project.sh +322 -0
  126. package/prisma/skills/continuous-learning-v2/scripts/instinct-cli.py +1956 -0
  127. package/prisma/skills/continuous-learning-v2/scripts/lib/homunculus-dir.sh +31 -0
  128. package/prisma/skills/continuous-learning-v2/scripts/migrate-homunculus.sh +68 -0
  129. package/prisma/skills/continuous-learning-v2/scripts/test_parse_instinct.py +1421 -0
  130. package/prisma/skills/cost-aware-llm-pipeline/SKILL.md +184 -0
  131. package/prisma/skills/cost-tracking/SKILL.md +97 -0
  132. package/prisma/skills/council/SKILL.md +204 -0
  133. package/prisma/skills/cpp-coding-standards/SKILL.md +724 -0
  134. package/prisma/skills/cpp-testing/SKILL.md +325 -0
  135. package/prisma/skills/crosspost/SKILL.md +112 -0
  136. package/prisma/skills/csharp-testing/SKILL.md +322 -0
  137. package/prisma/skills/customer-billing-ops/SKILL.md +141 -0
  138. package/prisma/skills/customs-trade-compliance/SKILL.md +263 -0
  139. package/prisma/skills/dart-flutter-patterns/SKILL.md +564 -0
  140. package/prisma/skills/dashboard-builder/SKILL.md +109 -0
  141. package/prisma/skills/data-scraper-agent/SKILL.md +765 -0
  142. package/prisma/skills/data-throughput-accelerator/SKILL.md +73 -0
  143. package/prisma/skills/database-migrations/SKILL.md +430 -0
  144. package/prisma/skills/deep-research/SKILL.md +160 -0
  145. package/prisma/skills/defi-amm-security/SKILL.md +167 -0
  146. package/prisma/skills/delivery-gate/SKILL.md +126 -0
  147. package/prisma/skills/delivery-gate/hooks/quality-gate.py +220 -0
  148. package/prisma/skills/deployment-patterns/SKILL.md +428 -0
  149. package/prisma/skills/design-system/SKILL.md +83 -0
  150. package/prisma/skills/django-celery/SKILL.md +458 -0
  151. package/prisma/skills/django-patterns/SKILL.md +735 -0
  152. package/prisma/skills/django-security/SKILL.md +644 -0
  153. package/prisma/skills/django-tdd/SKILL.md +730 -0
  154. package/prisma/skills/django-verification/SKILL.md +470 -0
  155. package/prisma/skills/dmux-workflows/SKILL.md +192 -0
  156. package/prisma/skills/docker-patterns/SKILL.md +365 -0
  157. package/prisma/skills/documentation-lookup/SKILL.md +91 -0
  158. package/prisma/skills/dotnet-patterns/SKILL.md +322 -0
  159. package/prisma/skills/dynamic-workflow-mode/SKILL.md +124 -0
  160. package/prisma/skills/e2e-testing/SKILL.md +327 -0
  161. package/prisma/skills/ecc-guide/SKILL.md +190 -0
  162. package/prisma/skills/ecc-recipes/SKILL.md +149 -0
  163. package/prisma/skills/ecc-tools-cost-audit/SKILL.md +161 -0
  164. package/prisma/skills/email-ops/SKILL.md +122 -0
  165. package/prisma/skills/energy-procurement/SKILL.md +228 -0
  166. package/prisma/skills/enterprise-agent-ops/SKILL.md +51 -0
  167. package/prisma/skills/error-handling/SKILL.md +377 -0
  168. package/prisma/skills/eval-harness/SKILL.md +271 -0
  169. package/prisma/skills/evm-token-decimals/SKILL.md +131 -0
  170. package/prisma/skills/exa-search/SKILL.md +108 -0
  171. package/prisma/skills/fal-ai-media/SKILL.md +289 -0
  172. package/prisma/skills/fastapi-patterns/SKILL.md +514 -0
  173. package/prisma/skills/finance-billing-ops/SKILL.md +128 -0
  174. package/prisma/skills/flox-environments/SKILL.md +497 -0
  175. package/prisma/skills/flutter-dart-code-review/SKILL.md +436 -0
  176. package/prisma/skills/foundation-models-on-device/SKILL.md +243 -0
  177. package/prisma/skills/frontend-a11y/SKILL.md +446 -0
  178. package/prisma/skills/frontend-design-direction/SKILL.md +93 -0
  179. package/prisma/skills/frontend-patterns/SKILL.md +657 -0
  180. package/prisma/skills/frontend-slides/SKILL.md +185 -0
  181. package/prisma/skills/frontend-slides/STYLE_PRESETS.md +330 -0
  182. package/prisma/skills/frontend-slides/animation-patterns.md +122 -0
  183. package/prisma/skills/frontend-slides/html-template.md +419 -0
  184. package/prisma/skills/frontend-slides/scripts/export-pdf.sh +418 -0
  185. package/prisma/skills/frontend-slides/scripts/extract-pptx.py +96 -0
  186. package/prisma/skills/frontend-slides/viewport-base.css +153 -0
  187. package/prisma/skills/fsharp-testing/SKILL.md +281 -0
  188. package/prisma/skills/gan-style-harness/SKILL.md +279 -0
  189. package/prisma/skills/gateguard/SKILL.md +133 -0
  190. package/prisma/skills/generating-python-installer/SKILL.md +820 -0
  191. package/prisma/skills/git-workflow/SKILL.md +716 -0
  192. package/prisma/skills/github-ops/SKILL.md +145 -0
  193. package/prisma/skills/golang-patterns/SKILL.md +675 -0
  194. package/prisma/skills/golang-testing/SKILL.md +721 -0
  195. package/prisma/skills/google-workspace-ops/SKILL.md +96 -0
  196. package/prisma/skills/growth-log/SKILL.md +128 -0
  197. package/prisma/skills/healthcare-cdss-patterns/SKILL.md +246 -0
  198. package/prisma/skills/healthcare-emr-patterns/SKILL.md +160 -0
  199. package/prisma/skills/healthcare-eval-harness/SKILL.md +208 -0
  200. package/prisma/skills/healthcare-phi-compliance/SKILL.md +146 -0
  201. package/prisma/skills/hermes-imports/SKILL.md +89 -0
  202. package/prisma/skills/hexagonal-architecture/SKILL.md +277 -0
  203. package/prisma/skills/hipaa-compliance/SKILL.md +79 -0
  204. package/prisma/skills/homelab-network-readiness/SKILL.md +170 -0
  205. package/prisma/skills/homelab-network-setup/SKILL.md +130 -0
  206. package/prisma/skills/homelab-pihole-dns/SKILL.md +275 -0
  207. package/prisma/skills/homelab-vlan-segmentation/SKILL.md +312 -0
  208. package/prisma/skills/homelab-wireguard-vpn/SKILL.md +306 -0
  209. package/prisma/skills/hookify-rules/SKILL.md +128 -0
  210. package/prisma/skills/inherit-legacy-style/SKILL.md +157 -0
  211. package/prisma/skills/intent-driven-development/SKILL.md +360 -0
  212. package/prisma/skills/inventory-demand-planning/SKILL.md +247 -0
  213. package/prisma/skills/investor-materials/SKILL.md +97 -0
  214. package/prisma/skills/investor-outreach/SKILL.md +92 -0
  215. package/prisma/skills/ios-icon-gen/SKILL.md +158 -0
  216. package/prisma/skills/ios-icon-gen/scripts/generate_icons.swift +258 -0
  217. package/prisma/skills/ios-icon-gen/scripts/iconify_gen.sh +235 -0
  218. package/prisma/skills/iterative-retrieval/SKILL.md +212 -0
  219. package/prisma/skills/ito-basket-compare/SKILL.md +64 -0
  220. package/prisma/skills/ito-data-atlas-agent/SKILL.md +64 -0
  221. package/prisma/skills/ito-market-intelligence/SKILL.md +61 -0
  222. package/prisma/skills/ito-trade-planner/SKILL.md +68 -0
  223. package/prisma/skills/java-coding-standards/SKILL.md +384 -0
  224. package/prisma/skills/jira-integration/SKILL.md +303 -0
  225. package/prisma/skills/jpa-patterns/SKILL.md +152 -0
  226. package/prisma/skills/knowledge-ops/SKILL.md +155 -0
  227. package/prisma/skills/kotlin-coroutines-flows/SKILL.md +285 -0
  228. package/prisma/skills/kotlin-exposed-patterns/SKILL.md +720 -0
  229. package/prisma/skills/kotlin-ktor-patterns/SKILL.md +690 -0
  230. package/prisma/skills/kotlin-patterns/SKILL.md +712 -0
  231. package/prisma/skills/kotlin-testing/SKILL.md +825 -0
  232. package/prisma/skills/kubernetes-patterns/SKILL.md +756 -0
  233. package/prisma/skills/laravel-patterns/SKILL.md +416 -0
  234. package/prisma/skills/laravel-plugin-discovery/SKILL.md +230 -0
  235. package/prisma/skills/laravel-security/SKILL.md +948 -0
  236. package/prisma/skills/laravel-tdd/SKILL.md +675 -0
  237. package/prisma/skills/laravel-verification/SKILL.md +180 -0
  238. package/prisma/skills/latency-critical-systems/SKILL.md +74 -0
  239. package/prisma/skills/lead-intelligence/SKILL.md +322 -0
  240. package/prisma/skills/lead-intelligence/agents/enrichment-agent.md +85 -0
  241. package/prisma/skills/lead-intelligence/agents/mutual-mapper.md +75 -0
  242. package/prisma/skills/lead-intelligence/agents/outreach-drafter.md +98 -0
  243. package/prisma/skills/lead-intelligence/agents/signal-scorer.md +60 -0
  244. package/prisma/skills/liquid-glass-design/SKILL.md +279 -0
  245. package/prisma/skills/llm-trading-agent-security/SKILL.md +147 -0
  246. package/prisma/skills/logistics-exception-management/SKILL.md +222 -0
  247. package/prisma/skills/loop-design-check/SKILL.md +143 -0
  248. package/prisma/skills/mailtrap-email-integration/SKILL.md +77 -0
  249. package/prisma/skills/make-interfaces-feel-better/SKILL.md +152 -0
  250. package/prisma/skills/manim-video/SKILL.md +90 -0
  251. package/prisma/skills/manim-video/assets/network_graph_scene.py +52 -0
  252. package/prisma/skills/market-research/SKILL.md +76 -0
  253. package/prisma/skills/marketing-campaign/SKILL.md +114 -0
  254. package/prisma/skills/mcp-server-patterns/SKILL.md +70 -0
  255. package/prisma/skills/messages-ops/SKILL.md +105 -0
  256. package/prisma/skills/ml-adoption-playbook/SKILL.md +57 -0
  257. package/prisma/skills/mle-workflow/SKILL.md +347 -0
  258. package/prisma/skills/motion-advanced/SKILL.md +596 -0
  259. package/prisma/skills/motion-foundations/SKILL.md +299 -0
  260. package/prisma/skills/motion-patterns/SKILL.md +434 -0
  261. package/prisma/skills/motion-ui/SKILL.md +576 -0
  262. package/prisma/skills/mysql-patterns/SKILL.md +413 -0
  263. package/prisma/skills/nanoclaw-repl/SKILL.md +34 -0
  264. package/prisma/skills/nestjs-patterns/SKILL.md +231 -0
  265. package/prisma/skills/netmiko-ssh-automation/SKILL.md +174 -0
  266. package/prisma/skills/network-bgp-diagnostics/SKILL.md +168 -0
  267. package/prisma/skills/network-config-validation/SKILL.md +211 -0
  268. package/prisma/skills/network-interface-health/SKILL.md +153 -0
  269. package/prisma/skills/nextjs-turbopack/SKILL.md +58 -0
  270. package/prisma/skills/nodejs-keccak256/SKILL.md +103 -0
  271. package/prisma/skills/nutrient-document-processing/SKILL.md +168 -0
  272. package/prisma/skills/nuxt4-patterns/SKILL.md +101 -0
  273. package/prisma/skills/openclaw-persona-forge/SKILL.md +289 -0
  274. package/prisma/skills/openclaw-persona-forge/gacha.py +224 -0
  275. package/prisma/skills/openclaw-persona-forge/gacha.sh +5 -0
  276. package/prisma/skills/openclaw-persona-forge/references/avatar-style.md +124 -0
  277. package/prisma/skills/openclaw-persona-forge/references/boundary-rules.md +53 -0
  278. package/prisma/skills/openclaw-persona-forge/references/error-handling.md +53 -0
  279. package/prisma/skills/openclaw-persona-forge/references/identity-tension.md +48 -0
  280. package/prisma/skills/openclaw-persona-forge/references/naming-system.md +39 -0
  281. package/prisma/skills/openclaw-persona-forge/references/output-template.md +166 -0
  282. package/prisma/skills/opensource-pipeline/SKILL.md +256 -0
  283. package/prisma/skills/orch-add-feature/SKILL.md +45 -0
  284. package/prisma/skills/orch-build-mvp/SKILL.md +49 -0
  285. package/prisma/skills/orch-change-feature/SKILL.md +43 -0
  286. package/prisma/skills/orch-fix-defect/SKILL.md +43 -0
  287. package/prisma/skills/orch-pipeline/SKILL.md +121 -0
  288. package/prisma/skills/orch-refine-code/SKILL.md +44 -0
  289. package/prisma/skills/parallel-execution-optimizer/SKILL.md +73 -0
  290. package/prisma/skills/perl-patterns/SKILL.md +505 -0
  291. package/prisma/skills/perl-security/SKILL.md +504 -0
  292. package/prisma/skills/perl-testing/SKILL.md +476 -0
  293. package/prisma/skills/plan-orchestrate/SKILL.md +263 -0
  294. package/prisma/skills/plankton-code-quality/SKILL.md +237 -0
  295. package/prisma/skills/postgres-patterns/SKILL.md +148 -0
  296. package/prisma/skills/prediction-market-oracle-research/SKILL.md +64 -0
  297. package/prisma/skills/prediction-market-risk-review/SKILL.md +61 -0
  298. package/prisma/skills/prisma-patterns/SKILL.md +401 -0
  299. package/prisma/skills/product-capability/SKILL.md +142 -0
  300. package/prisma/skills/product-lens/SKILL.md +93 -0
  301. package/prisma/skills/production-audit/SKILL.md +207 -0
  302. package/prisma/skills/production-scheduling/SKILL.md +238 -0
  303. package/prisma/skills/project-flow-ops/SKILL.md +112 -0
  304. package/prisma/skills/prompt-optimizer/SKILL.md +398 -0
  305. package/prisma/skills/python-patterns/SKILL.md +751 -0
  306. package/prisma/skills/python-testing/SKILL.md +817 -0
  307. package/prisma/skills/pytorch-patterns/SKILL.md +397 -0
  308. package/prisma/skills/quality-nonconformance/SKILL.md +260 -0
  309. package/prisma/skills/quarkus-patterns/SKILL.md +723 -0
  310. package/prisma/skills/quarkus-security/SKILL.md +468 -0
  311. package/prisma/skills/quarkus-tdd/SKILL.md +812 -0
  312. package/prisma/skills/quarkus-verification/SKILL.md +480 -0
  313. package/prisma/skills/ralphinho-rfc-pipeline/SKILL.md +68 -0
  314. package/prisma/skills/react-native-patterns/SKILL.md +326 -0
  315. package/prisma/skills/react-patterns/SKILL.md +342 -0
  316. package/prisma/skills/react-performance/SKILL.md +575 -0
  317. package/prisma/skills/react-testing/SKILL.md +424 -0
  318. package/prisma/skills/recsys-pipeline-architect/SKILL.md +115 -0
  319. package/prisma/skills/recursive-decision-ledger/SKILL.md +80 -0
  320. package/prisma/skills/redis-patterns/SKILL.md +404 -0
  321. package/prisma/skills/regex-vs-llm-structured-text/SKILL.md +221 -0
  322. package/prisma/skills/remotion-video-creation/SKILL.md +43 -0
  323. package/prisma/skills/remotion-video-creation/rules/3d.md +86 -0
  324. package/prisma/skills/remotion-video-creation/rules/animations.md +29 -0
  325. package/prisma/skills/remotion-video-creation/rules/assets/charts-bar-chart.tsx +173 -0
  326. package/prisma/skills/remotion-video-creation/rules/assets/text-animations-typewriter.tsx +100 -0
  327. package/prisma/skills/remotion-video-creation/rules/assets/text-animations-word-highlight.tsx +108 -0
  328. package/prisma/skills/remotion-video-creation/rules/assets.md +78 -0
  329. package/prisma/skills/remotion-video-creation/rules/audio.md +172 -0
  330. package/prisma/skills/remotion-video-creation/rules/calculate-metadata.md +104 -0
  331. package/prisma/skills/remotion-video-creation/rules/can-decode.md +75 -0
  332. package/prisma/skills/remotion-video-creation/rules/charts.md +58 -0
  333. package/prisma/skills/remotion-video-creation/rules/compositions.md +146 -0
  334. package/prisma/skills/remotion-video-creation/rules/display-captions.md +126 -0
  335. package/prisma/skills/remotion-video-creation/rules/extract-frames.md +229 -0
  336. package/prisma/skills/remotion-video-creation/rules/fonts.md +152 -0
  337. package/prisma/skills/remotion-video-creation/rules/get-audio-duration.md +58 -0
  338. package/prisma/skills/remotion-video-creation/rules/get-video-dimensions.md +68 -0
  339. package/prisma/skills/remotion-video-creation/rules/get-video-duration.md +58 -0
  340. package/prisma/skills/remotion-video-creation/rules/gifs.md +138 -0
  341. package/prisma/skills/remotion-video-creation/rules/images.md +130 -0
  342. package/prisma/skills/remotion-video-creation/rules/import-srt-captions.md +67 -0
  343. package/prisma/skills/remotion-video-creation/rules/lottie.md +67 -0
  344. package/prisma/skills/remotion-video-creation/rules/measuring-dom-nodes.md +34 -0
  345. package/prisma/skills/remotion-video-creation/rules/measuring-text.md +143 -0
  346. package/prisma/skills/remotion-video-creation/rules/sequencing.md +106 -0
  347. package/prisma/skills/remotion-video-creation/rules/tailwind.md +11 -0
  348. package/prisma/skills/remotion-video-creation/rules/text-animations.md +20 -0
  349. package/prisma/skills/remotion-video-creation/rules/timing.md +179 -0
  350. package/prisma/skills/remotion-video-creation/rules/transcribe-captions.md +19 -0
  351. package/prisma/skills/remotion-video-creation/rules/transitions.md +122 -0
  352. package/prisma/skills/remotion-video-creation/rules/trimming.md +52 -0
  353. package/prisma/skills/remotion-video-creation/rules/videos.md +171 -0
  354. package/prisma/skills/repo-scan/SKILL.md +79 -0
  355. package/prisma/skills/research-ops/SKILL.md +113 -0
  356. package/prisma/skills/returns-reverse-logistics/SKILL.md +240 -0
  357. package/prisma/skills/rules-distill/SKILL.md +265 -0
  358. package/prisma/skills/rules-distill/scripts/scan-rules.sh +58 -0
  359. package/prisma/skills/rules-distill/scripts/scan-skills.sh +129 -0
  360. package/prisma/skills/rust-patterns/SKILL.md +500 -0
  361. package/prisma/skills/rust-testing/SKILL.md +501 -0
  362. package/prisma/skills/safety-guard/SKILL.md +76 -0
  363. package/prisma/skills/santa-method/SKILL.md +307 -0
  364. package/prisma/skills/scientific-db-pubmed-database/SKILL.md +176 -0
  365. package/prisma/skills/scientific-db-uspto-database/SKILL.md +178 -0
  366. package/prisma/skills/scientific-pkg-gget/SKILL.md +167 -0
  367. package/prisma/skills/scientific-thinking-literature-review/SKILL.md +193 -0
  368. package/prisma/skills/scientific-thinking-scholar-evaluation/SKILL.md +161 -0
  369. package/prisma/skills/search-first/SKILL.md +183 -0
  370. package/prisma/skills/security-bounty-hunter/SKILL.md +100 -0
  371. package/prisma/skills/security-review/SKILL.md +504 -0
  372. package/prisma/skills/security-review/cloud-infrastructure-security.md +361 -0
  373. package/prisma/skills/security-scan/SKILL.md +166 -0
  374. package/prisma/skills/seo/SKILL.md +155 -0
  375. package/prisma/skills/skill-comply/SKILL.md +59 -0
  376. package/prisma/skills/skill-comply/fixtures/compliant_trace.jsonl +5 -0
  377. package/prisma/skills/skill-comply/fixtures/noncompliant_trace.jsonl +3 -0
  378. package/prisma/skills/skill-comply/fixtures/tdd_spec.yaml +44 -0
  379. package/prisma/skills/skill-comply/prompts/classifier.md +24 -0
  380. package/prisma/skills/skill-comply/prompts/scenario_generator.md +62 -0
  381. package/prisma/skills/skill-comply/prompts/spec_generator.md +42 -0
  382. package/prisma/skills/skill-comply/pyproject.toml +15 -0
  383. package/prisma/skills/skill-comply/scripts/__init__.py +0 -0
  384. package/prisma/skills/skill-comply/scripts/classifier.py +85 -0
  385. package/prisma/skills/skill-comply/scripts/grader.py +124 -0
  386. package/prisma/skills/skill-comply/scripts/parser.py +107 -0
  387. package/prisma/skills/skill-comply/scripts/report.py +170 -0
  388. package/prisma/skills/skill-comply/scripts/run.py +127 -0
  389. package/prisma/skills/skill-comply/scripts/runner.py +194 -0
  390. package/prisma/skills/skill-comply/scripts/scenario_generator.py +70 -0
  391. package/prisma/skills/skill-comply/scripts/spec_generator.py +72 -0
  392. package/prisma/skills/skill-comply/scripts/utils.py +13 -0
  393. package/prisma/skills/skill-comply/tests/test_grader.py +197 -0
  394. package/prisma/skills/skill-comply/tests/test_parser.py +90 -0
  395. package/prisma/skills/skill-comply/tests/test_runner.py +172 -0
  396. package/prisma/skills/skill-scout/SKILL.md +141 -0
  397. package/prisma/skills/skill-stocktake/SKILL.md +195 -0
  398. package/prisma/skills/skill-stocktake/scripts/quick-diff.sh +87 -0
  399. package/prisma/skills/skill-stocktake/scripts/save-results.sh +56 -0
  400. package/prisma/skills/skill-stocktake/scripts/scan.sh +170 -0
  401. package/prisma/skills/social-graph-ranker/SKILL.md +155 -0
  402. package/prisma/skills/social-publisher/SKILL.md +130 -0
  403. package/prisma/skills/springboot-patterns/SKILL.md +315 -0
  404. package/prisma/skills/springboot-security/SKILL.md +273 -0
  405. package/prisma/skills/springboot-tdd/SKILL.md +159 -0
  406. package/prisma/skills/springboot-verification/SKILL.md +232 -0
  407. package/prisma/skills/strategic-compact/SKILL.md +136 -0
  408. package/prisma/skills/swift-actor-persistence/SKILL.md +144 -0
  409. package/prisma/skills/swift-concurrency-6-2/SKILL.md +216 -0
  410. package/prisma/skills/swift-protocol-di-testing/SKILL.md +191 -0
  411. package/prisma/skills/swiftui-patterns/SKILL.md +259 -0
  412. package/prisma/skills/taste/SKILL.md +264 -0
  413. package/prisma/skills/taste/references/genre-taxonomy.md +87 -0
  414. package/prisma/skills/tdd-workflow/SKILL.md +583 -0
  415. package/prisma/skills/team-agent-orchestration/SKILL.md +111 -0
  416. package/prisma/skills/team-builder/SKILL.md +169 -0
  417. package/prisma/skills/terminal-ops/SKILL.md +110 -0
  418. package/prisma/skills/tinystruct-patterns/SKILL.md +279 -0
  419. package/prisma/skills/tinystruct-patterns/references/architecture.md +90 -0
  420. package/prisma/skills/tinystruct-patterns/references/data-handling.md +60 -0
  421. package/prisma/skills/tinystruct-patterns/references/database.md +99 -0
  422. package/prisma/skills/tinystruct-patterns/references/routing.md +64 -0
  423. package/prisma/skills/tinystruct-patterns/references/system-usage.md +97 -0
  424. package/prisma/skills/tinystruct-patterns/references/testing.md +72 -0
  425. package/prisma/skills/token-budget-advisor/SKILL.md +134 -0
  426. package/prisma/skills/ui-demo/SKILL.md +466 -0
  427. package/prisma/skills/ui-to-vue/SKILL.md +135 -0
  428. package/prisma/skills/uncloud/SKILL.md +344 -0
  429. package/prisma/skills/unified-notifications-ops/SKILL.md +188 -0
  430. package/prisma/skills/verification-loop/SKILL.md +127 -0
  431. package/prisma/skills/video-editing/SKILL.md +311 -0
  432. package/prisma/skills/videodb/SKILL.md +375 -0
  433. package/prisma/skills/videodb/reference/api-reference.md +550 -0
  434. package/prisma/skills/videodb/reference/capture-reference.md +407 -0
  435. package/prisma/skills/videodb/reference/capture.md +101 -0
  436. package/prisma/skills/videodb/reference/editor.md +443 -0
  437. package/prisma/skills/videodb/reference/generative.md +331 -0
  438. package/prisma/skills/videodb/reference/rtstream-reference.md +564 -0
  439. package/prisma/skills/videodb/reference/rtstream.md +65 -0
  440. package/prisma/skills/videodb/reference/search.md +230 -0
  441. package/prisma/skills/videodb/reference/streaming.md +406 -0
  442. package/prisma/skills/videodb/reference/use-cases.md +118 -0
  443. package/prisma/skills/videodb/scripts/ws_listener.py +282 -0
  444. package/prisma/skills/visa-doc-translate/README.md +86 -0
  445. package/prisma/skills/visa-doc-translate/SKILL.md +117 -0
  446. package/prisma/skills/vite-patterns/SKILL.md +450 -0
  447. package/prisma/skills/vue-patterns/SKILL.md +471 -0
  448. package/prisma/skills/windows-desktop-e2e/SKILL.md +888 -0
  449. package/prisma/skills/workspace-surface-audit/SKILL.md +126 -0
  450. package/prisma/skills/x-api/SKILL.md +235 -0
  451. package/run.mjs +0 -10
@@ -0,0 +1,720 @@
1
+ ---
2
+ name: kotlin-exposed-patterns
3
+ description: JetBrains Exposed ORM patterns including DSL queries, DAO pattern, transactions, HikariCP connection pooling, Flyway migrations, and repository pattern.
4
+ metadata:
5
+ origin: ECC
6
+ ---
7
+
8
+ # Kotlin Exposed Patterns
9
+
10
+ Comprehensive patterns for database access with JetBrains Exposed ORM, including DSL queries, DAO, transactions, and production-ready configuration.
11
+
12
+ ## When to Use
13
+
14
+ - Setting up database access with Exposed
15
+ - Writing SQL queries using Exposed DSL or DAO
16
+ - Configuring connection pooling with HikariCP
17
+ - Creating database migrations with Flyway
18
+ - Implementing the repository pattern with Exposed
19
+ - Handling JSON columns and complex queries
20
+
21
+ ## How It Works
22
+
23
+ Exposed provides two query styles: DSL for direct SQL-like expressions and DAO for entity lifecycle management. HikariCP manages a pool of reusable database connections configured via `HikariConfig`. Flyway runs versioned SQL migration scripts at startup to keep the schema in sync. All database operations run inside `newSuspendedTransaction` blocks for coroutine safety and atomicity. The repository pattern wraps Exposed queries behind an interface so business logic stays decoupled from the data layer and tests can use an in-memory H2 database.
24
+
25
+ ## Examples
26
+
27
+ ### DSL Query
28
+
29
+ ```kotlin
30
+ suspend fun findUserById(id: UUID): UserRow? =
31
+ newSuspendedTransaction {
32
+ UsersTable.selectAll()
33
+ .where { UsersTable.id eq id }
34
+ .map { it.toUser() }
35
+ .singleOrNull()
36
+ }
37
+ ```
38
+
39
+ ### DAO Entity Usage
40
+
41
+ ```kotlin
42
+ suspend fun createUser(request: CreateUserRequest): User =
43
+ newSuspendedTransaction {
44
+ UserEntity.new {
45
+ name = request.name
46
+ email = request.email
47
+ role = request.role
48
+ }.toModel()
49
+ }
50
+ ```
51
+
52
+ ### HikariCP Configuration
53
+
54
+ ```kotlin
55
+ val hikariConfig = HikariConfig().apply {
56
+ driverClassName = config.driver
57
+ jdbcUrl = config.url
58
+ username = config.username
59
+ password = config.password
60
+ maximumPoolSize = config.maxPoolSize
61
+ isAutoCommit = false
62
+ transactionIsolation = "TRANSACTION_READ_COMMITTED"
63
+ validate()
64
+ }
65
+ ```
66
+
67
+ ## Database Setup
68
+
69
+ ### HikariCP Connection Pooling
70
+
71
+ ```kotlin
72
+ // DatabaseFactory.kt
73
+ object DatabaseFactory {
74
+ fun create(config: DatabaseConfig): Database {
75
+ val hikariConfig = HikariConfig().apply {
76
+ driverClassName = config.driver
77
+ jdbcUrl = config.url
78
+ username = config.username
79
+ password = config.password
80
+ maximumPoolSize = config.maxPoolSize
81
+ isAutoCommit = false
82
+ transactionIsolation = "TRANSACTION_READ_COMMITTED"
83
+ validate()
84
+ }
85
+
86
+ return Database.connect(HikariDataSource(hikariConfig))
87
+ }
88
+ }
89
+
90
+ data class DatabaseConfig(
91
+ val url: String,
92
+ val driver: String = "org.postgresql.Driver",
93
+ val username: String = "",
94
+ val password: String = "",
95
+ val maxPoolSize: Int = 10,
96
+ )
97
+ ```
98
+
99
+ ### Flyway Migrations
100
+
101
+ ```kotlin
102
+ // FlywayMigration.kt
103
+ fun runMigrations(config: DatabaseConfig) {
104
+ Flyway.configure()
105
+ .dataSource(config.url, config.username, config.password)
106
+ .locations("classpath:db/migration")
107
+ .baselineOnMigrate(true)
108
+ .load()
109
+ .migrate()
110
+ }
111
+
112
+ // Application startup
113
+ fun Application.module() {
114
+ val config = DatabaseConfig(
115
+ url = environment.config.property("database.url").getString(),
116
+ username = environment.config.property("database.username").getString(),
117
+ password = environment.config.property("database.password").getString(),
118
+ )
119
+ runMigrations(config)
120
+ val database = DatabaseFactory.create(config)
121
+ // ...
122
+ }
123
+ ```
124
+
125
+ ### Migration Files
126
+
127
+ ```sql
128
+ -- src/main/resources/db/migration/V1__create_users.sql
129
+ CREATE TABLE users (
130
+ id UUID PRIMARY KEY DEFAULT gen_random_uuid(),
131
+ name VARCHAR(100) NOT NULL,
132
+ email VARCHAR(255) NOT NULL UNIQUE,
133
+ role VARCHAR(20) NOT NULL DEFAULT 'USER',
134
+ metadata JSONB,
135
+ created_at TIMESTAMPTZ NOT NULL DEFAULT NOW(),
136
+ updated_at TIMESTAMPTZ NOT NULL DEFAULT NOW()
137
+ );
138
+
139
+ CREATE INDEX idx_users_email ON users(email);
140
+ CREATE INDEX idx_users_role ON users(role);
141
+ ```
142
+
143
+ ## Table Definitions
144
+
145
+ ### DSL Style Tables
146
+
147
+ ```kotlin
148
+ // tables/UsersTable.kt
149
+ object UsersTable : UUIDTable("users") {
150
+ val name = varchar("name", 100)
151
+ val email = varchar("email", 255).uniqueIndex()
152
+ val role = enumerationByName<Role>("role", 20)
153
+ val metadata = jsonb<UserMetadata>("metadata", Json.Default).nullable()
154
+ val createdAt = timestampWithTimeZone("created_at").defaultExpression(CurrentTimestampWithTimeZone)
155
+ val updatedAt = timestampWithTimeZone("updated_at").defaultExpression(CurrentTimestampWithTimeZone)
156
+ }
157
+
158
+ object OrdersTable : UUIDTable("orders") {
159
+ val userId = uuid("user_id").references(UsersTable.id)
160
+ val status = enumerationByName<OrderStatus>("status", 20)
161
+ val totalAmount = long("total_amount")
162
+ val currency = varchar("currency", 3)
163
+ val createdAt = timestampWithTimeZone("created_at").defaultExpression(CurrentTimestampWithTimeZone)
164
+ }
165
+
166
+ object OrderItemsTable : UUIDTable("order_items") {
167
+ val orderId = uuid("order_id").references(OrdersTable.id, onDelete = ReferenceOption.CASCADE)
168
+ val productId = uuid("product_id")
169
+ val quantity = integer("quantity")
170
+ val unitPrice = long("unit_price")
171
+ }
172
+ ```
173
+
174
+ ### Composite Tables
175
+
176
+ ```kotlin
177
+ object UserRolesTable : Table("user_roles") {
178
+ val userId = uuid("user_id").references(UsersTable.id, onDelete = ReferenceOption.CASCADE)
179
+ val roleId = uuid("role_id").references(RolesTable.id, onDelete = ReferenceOption.CASCADE)
180
+ override val primaryKey = PrimaryKey(userId, roleId)
181
+ }
182
+ ```
183
+
184
+ ## DSL Queries
185
+
186
+ ### Basic CRUD
187
+
188
+ ```kotlin
189
+ // Insert
190
+ suspend fun insertUser(name: String, email: String, role: Role): UUID =
191
+ newSuspendedTransaction {
192
+ UsersTable.insertAndGetId {
193
+ it[UsersTable.name] = name
194
+ it[UsersTable.email] = email
195
+ it[UsersTable.role] = role
196
+ }.value
197
+ }
198
+
199
+ // Select by ID
200
+ suspend fun findUserById(id: UUID): UserRow? =
201
+ newSuspendedTransaction {
202
+ UsersTable.selectAll()
203
+ .where { UsersTable.id eq id }
204
+ .map { it.toUser() }
205
+ .singleOrNull()
206
+ }
207
+
208
+ // Select with conditions
209
+ suspend fun findActiveAdmins(): List<UserRow> =
210
+ newSuspendedTransaction {
211
+ UsersTable.selectAll()
212
+ .where { (UsersTable.role eq Role.ADMIN) }
213
+ .orderBy(UsersTable.name)
214
+ .map { it.toUser() }
215
+ }
216
+
217
+ // Update
218
+ suspend fun updateUserEmail(id: UUID, newEmail: String): Boolean =
219
+ newSuspendedTransaction {
220
+ UsersTable.update({ UsersTable.id eq id }) {
221
+ it[email] = newEmail
222
+ it[updatedAt] = CurrentTimestampWithTimeZone
223
+ } > 0
224
+ }
225
+
226
+ // Delete
227
+ suspend fun deleteUser(id: UUID): Boolean =
228
+ newSuspendedTransaction {
229
+ UsersTable.deleteWhere { UsersTable.id eq id } > 0
230
+ }
231
+
232
+ // Row mapping
233
+ private fun ResultRow.toUser() = UserRow(
234
+ id = this[UsersTable.id].value,
235
+ name = this[UsersTable.name],
236
+ email = this[UsersTable.email],
237
+ role = this[UsersTable.role],
238
+ metadata = this[UsersTable.metadata],
239
+ createdAt = this[UsersTable.createdAt],
240
+ updatedAt = this[UsersTable.updatedAt],
241
+ )
242
+ ```
243
+
244
+ ### Advanced Queries
245
+
246
+ ```kotlin
247
+ // Join queries
248
+ suspend fun findOrdersWithUser(userId: UUID): List<OrderWithUser> =
249
+ newSuspendedTransaction {
250
+ (OrdersTable innerJoin UsersTable)
251
+ .selectAll()
252
+ .where { OrdersTable.userId eq userId }
253
+ .orderBy(OrdersTable.createdAt, SortOrder.DESC)
254
+ .map { row ->
255
+ OrderWithUser(
256
+ orderId = row[OrdersTable.id].value,
257
+ status = row[OrdersTable.status],
258
+ totalAmount = row[OrdersTable.totalAmount],
259
+ userName = row[UsersTable.name],
260
+ )
261
+ }
262
+ }
263
+
264
+ // Aggregation
265
+ suspend fun countUsersByRole(): Map<Role, Long> =
266
+ newSuspendedTransaction {
267
+ UsersTable
268
+ .select(UsersTable.role, UsersTable.id.count())
269
+ .groupBy(UsersTable.role)
270
+ .associate { row ->
271
+ row[UsersTable.role] to row[UsersTable.id.count()]
272
+ }
273
+ }
274
+
275
+ // Subqueries
276
+ suspend fun findUsersWithOrders(): List<UserRow> =
277
+ newSuspendedTransaction {
278
+ UsersTable.selectAll()
279
+ .where {
280
+ UsersTable.id inSubQuery
281
+ OrdersTable.select(OrdersTable.userId).withDistinct()
282
+ }
283
+ .map { it.toUser() }
284
+ }
285
+
286
+ // LIKE and pattern matching — always escape user input to prevent wildcard injection
287
+ private fun escapeLikePattern(input: String): String =
288
+ input.replace("\\", "\\\\").replace("%", "\\%").replace("_", "\\_")
289
+
290
+ suspend fun searchUsers(query: String): List<UserRow> =
291
+ newSuspendedTransaction {
292
+ val sanitized = escapeLikePattern(query.lowercase())
293
+ UsersTable.selectAll()
294
+ .where {
295
+ (UsersTable.name.lowerCase() like "%${sanitized}%") or
296
+ (UsersTable.email.lowerCase() like "%${sanitized}%")
297
+ }
298
+ .map { it.toUser() }
299
+ }
300
+ ```
301
+
302
+ ### Pagination
303
+
304
+ ```kotlin
305
+ data class Page<T>(
306
+ val data: List<T>,
307
+ val total: Long,
308
+ val page: Int,
309
+ val limit: Int,
310
+ ) {
311
+ val totalPages: Int get() = ((total + limit - 1) / limit).toInt()
312
+ val hasNext: Boolean get() = page < totalPages
313
+ val hasPrevious: Boolean get() = page > 1
314
+ }
315
+
316
+ suspend fun findUsersPaginated(page: Int, limit: Int): Page<UserRow> =
317
+ newSuspendedTransaction {
318
+ val total = UsersTable.selectAll().count()
319
+ val data = UsersTable.selectAll()
320
+ .orderBy(UsersTable.createdAt, SortOrder.DESC)
321
+ .limit(limit)
322
+ .offset(((page - 1) * limit).toLong())
323
+ .map { it.toUser() }
324
+
325
+ Page(data = data, total = total, page = page, limit = limit)
326
+ }
327
+ ```
328
+
329
+ ### Batch Operations
330
+
331
+ ```kotlin
332
+ // Batch insert
333
+ suspend fun insertUsers(users: List<CreateUserRequest>): List<UUID> =
334
+ newSuspendedTransaction {
335
+ UsersTable.batchInsert(users) { user ->
336
+ this[UsersTable.name] = user.name
337
+ this[UsersTable.email] = user.email
338
+ this[UsersTable.role] = user.role
339
+ }.map { it[UsersTable.id].value }
340
+ }
341
+
342
+ // Upsert (insert or update on conflict)
343
+ suspend fun upsertUser(id: UUID, name: String, email: String) {
344
+ newSuspendedTransaction {
345
+ UsersTable.upsert(UsersTable.email) {
346
+ it[UsersTable.id] = EntityID(id, UsersTable)
347
+ it[UsersTable.name] = name
348
+ it[UsersTable.email] = email
349
+ it[updatedAt] = CurrentTimestampWithTimeZone
350
+ }
351
+ }
352
+ }
353
+ ```
354
+
355
+ ## DAO Pattern
356
+
357
+ ### Entity Definitions
358
+
359
+ ```kotlin
360
+ // entities/UserEntity.kt
361
+ class UserEntity(id: EntityID<UUID>) : UUIDEntity(id) {
362
+ companion object : UUIDEntityClass<UserEntity>(UsersTable)
363
+
364
+ var name by UsersTable.name
365
+ var email by UsersTable.email
366
+ var role by UsersTable.role
367
+ var metadata by UsersTable.metadata
368
+ var createdAt by UsersTable.createdAt
369
+ var updatedAt by UsersTable.updatedAt
370
+
371
+ val orders by OrderEntity referrersOn OrdersTable.userId
372
+
373
+ fun toModel(): User = User(
374
+ id = id.value,
375
+ name = name,
376
+ email = email,
377
+ role = role,
378
+ metadata = metadata,
379
+ createdAt = createdAt,
380
+ updatedAt = updatedAt,
381
+ )
382
+ }
383
+
384
+ class OrderEntity(id: EntityID<UUID>) : UUIDEntity(id) {
385
+ companion object : UUIDEntityClass<OrderEntity>(OrdersTable)
386
+
387
+ var user by UserEntity referencedOn OrdersTable.userId
388
+ var status by OrdersTable.status
389
+ var totalAmount by OrdersTable.totalAmount
390
+ var currency by OrdersTable.currency
391
+ var createdAt by OrdersTable.createdAt
392
+
393
+ val items by OrderItemEntity referrersOn OrderItemsTable.orderId
394
+ }
395
+ ```
396
+
397
+ ### DAO Operations
398
+
399
+ ```kotlin
400
+ suspend fun findUserByEmail(email: String): User? =
401
+ newSuspendedTransaction {
402
+ UserEntity.find { UsersTable.email eq email }
403
+ .firstOrNull()
404
+ ?.toModel()
405
+ }
406
+
407
+ suspend fun createUser(request: CreateUserRequest): User =
408
+ newSuspendedTransaction {
409
+ UserEntity.new {
410
+ name = request.name
411
+ email = request.email
412
+ role = request.role
413
+ }.toModel()
414
+ }
415
+
416
+ suspend fun updateUser(id: UUID, request: UpdateUserRequest): User? =
417
+ newSuspendedTransaction {
418
+ UserEntity.findById(id)?.apply {
419
+ request.name?.let { name = it }
420
+ request.email?.let { email = it }
421
+ updatedAt = OffsetDateTime.now(ZoneOffset.UTC)
422
+ }?.toModel()
423
+ }
424
+ ```
425
+
426
+ ## Transactions
427
+
428
+ ### Suspend Transaction Support
429
+
430
+ ```kotlin
431
+ // Good: Use newSuspendedTransaction for coroutine support
432
+ suspend fun performDatabaseOperation(): Result<User> =
433
+ runCatching {
434
+ newSuspendedTransaction {
435
+ val user = UserEntity.new {
436
+ name = "Alice"
437
+ email = "alice@example.com"
438
+ }
439
+ // All operations in this block are atomic
440
+ user.toModel()
441
+ }
442
+ }
443
+
444
+ // Good: Nested transactions with savepoints
445
+ suspend fun transferFunds(fromId: UUID, toId: UUID, amount: Long) {
446
+ newSuspendedTransaction {
447
+ val from = UserEntity.findById(fromId) ?: throw NotFoundException("User $fromId not found")
448
+ val to = UserEntity.findById(toId) ?: throw NotFoundException("User $toId not found")
449
+
450
+ // Debit
451
+ from.balance -= amount
452
+ // Credit
453
+ to.balance += amount
454
+
455
+ // Both succeed or both fail
456
+ }
457
+ }
458
+ ```
459
+
460
+ ### Transaction Isolation
461
+
462
+ ```kotlin
463
+ suspend fun readCommittedQuery(): List<User> =
464
+ newSuspendedTransaction(transactionIsolation = Connection.TRANSACTION_READ_COMMITTED) {
465
+ UserEntity.all().map { it.toModel() }
466
+ }
467
+
468
+ suspend fun serializableOperation() {
469
+ newSuspendedTransaction(transactionIsolation = Connection.TRANSACTION_SERIALIZABLE) {
470
+ // Strictest isolation level for critical operations
471
+ }
472
+ }
473
+ ```
474
+
475
+ ## Repository Pattern
476
+
477
+ ### Interface Definition
478
+
479
+ ```kotlin
480
+ interface UserRepository {
481
+ suspend fun findById(id: UUID): User?
482
+ suspend fun findByEmail(email: String): User?
483
+ suspend fun findAll(page: Int, limit: Int): Page<User>
484
+ suspend fun search(query: String): List<User>
485
+ suspend fun create(request: CreateUserRequest): User
486
+ suspend fun update(id: UUID, request: UpdateUserRequest): User?
487
+ suspend fun delete(id: UUID): Boolean
488
+ suspend fun count(): Long
489
+ }
490
+ ```
491
+
492
+ ### Exposed Implementation
493
+
494
+ ```kotlin
495
+ class ExposedUserRepository(
496
+ private val database: Database,
497
+ ) : UserRepository {
498
+
499
+ override suspend fun findById(id: UUID): User? =
500
+ newSuspendedTransaction(db = database) {
501
+ UsersTable.selectAll()
502
+ .where { UsersTable.id eq id }
503
+ .map { it.toUser() }
504
+ .singleOrNull()
505
+ }
506
+
507
+ override suspend fun findByEmail(email: String): User? =
508
+ newSuspendedTransaction(db = database) {
509
+ UsersTable.selectAll()
510
+ .where { UsersTable.email eq email }
511
+ .map { it.toUser() }
512
+ .singleOrNull()
513
+ }
514
+
515
+ override suspend fun findAll(page: Int, limit: Int): Page<User> =
516
+ newSuspendedTransaction(db = database) {
517
+ val total = UsersTable.selectAll().count()
518
+ val data = UsersTable.selectAll()
519
+ .orderBy(UsersTable.createdAt, SortOrder.DESC)
520
+ .limit(limit)
521
+ .offset(((page - 1) * limit).toLong())
522
+ .map { it.toUser() }
523
+ Page(data = data, total = total, page = page, limit = limit)
524
+ }
525
+
526
+ override suspend fun search(query: String): List<User> =
527
+ newSuspendedTransaction(db = database) {
528
+ val sanitized = escapeLikePattern(query.lowercase())
529
+ UsersTable.selectAll()
530
+ .where {
531
+ (UsersTable.name.lowerCase() like "%${sanitized}%") or
532
+ (UsersTable.email.lowerCase() like "%${sanitized}%")
533
+ }
534
+ .orderBy(UsersTable.name)
535
+ .map { it.toUser() }
536
+ }
537
+
538
+ override suspend fun create(request: CreateUserRequest): User =
539
+ newSuspendedTransaction(db = database) {
540
+ UsersTable.insert {
541
+ it[name] = request.name
542
+ it[email] = request.email
543
+ it[role] = request.role
544
+ }.resultedValues!!.first().toUser()
545
+ }
546
+
547
+ override suspend fun update(id: UUID, request: UpdateUserRequest): User? =
548
+ newSuspendedTransaction(db = database) {
549
+ val updated = UsersTable.update({ UsersTable.id eq id }) {
550
+ request.name?.let { name -> it[UsersTable.name] = name }
551
+ request.email?.let { email -> it[UsersTable.email] = email }
552
+ it[updatedAt] = CurrentTimestampWithTimeZone
553
+ }
554
+ if (updated > 0) findById(id) else null
555
+ }
556
+
557
+ override suspend fun delete(id: UUID): Boolean =
558
+ newSuspendedTransaction(db = database) {
559
+ UsersTable.deleteWhere { UsersTable.id eq id } > 0
560
+ }
561
+
562
+ override suspend fun count(): Long =
563
+ newSuspendedTransaction(db = database) {
564
+ UsersTable.selectAll().count()
565
+ }
566
+
567
+ private fun ResultRow.toUser() = User(
568
+ id = this[UsersTable.id].value,
569
+ name = this[UsersTable.name],
570
+ email = this[UsersTable.email],
571
+ role = this[UsersTable.role],
572
+ metadata = this[UsersTable.metadata],
573
+ createdAt = this[UsersTable.createdAt],
574
+ updatedAt = this[UsersTable.updatedAt],
575
+ )
576
+ }
577
+ ```
578
+
579
+ ## JSON Columns
580
+
581
+ ### JSONB with kotlinx.serialization
582
+
583
+ ```kotlin
584
+ // Custom column type for JSONB
585
+ inline fun <reified T : Any> Table.jsonb(
586
+ name: String,
587
+ json: Json,
588
+ ): Column<T> = registerColumn(name, object : ColumnType<T>() {
589
+ override fun sqlType() = "JSONB"
590
+
591
+ override fun valueFromDB(value: Any): T = when (value) {
592
+ is String -> json.decodeFromString(value)
593
+ is PGobject -> {
594
+ val jsonString = value.value
595
+ ?: throw IllegalArgumentException("PGobject value is null for column '$name'")
596
+ json.decodeFromString(jsonString)
597
+ }
598
+ else -> throw IllegalArgumentException("Unexpected value: $value")
599
+ }
600
+
601
+ override fun notNullValueToDB(value: T): Any =
602
+ PGobject().apply {
603
+ type = "jsonb"
604
+ this.value = json.encodeToString(value)
605
+ }
606
+ })
607
+
608
+ // Usage in table
609
+ @Serializable
610
+ data class UserMetadata(
611
+ val preferences: Map<String, String> = emptyMap(),
612
+ val tags: List<String> = emptyList(),
613
+ )
614
+
615
+ object UsersTable : UUIDTable("users") {
616
+ val metadata = jsonb<UserMetadata>("metadata", Json.Default).nullable()
617
+ }
618
+ ```
619
+
620
+ ## Testing with Exposed
621
+
622
+ ### In-Memory Database for Tests
623
+
624
+ ```kotlin
625
+ class UserRepositoryTest : FunSpec({
626
+ lateinit var database: Database
627
+ lateinit var repository: UserRepository
628
+
629
+ beforeSpec {
630
+ database = Database.connect(
631
+ url = "jdbc:h2:mem:test;DB_CLOSE_DELAY=-1;MODE=PostgreSQL",
632
+ driver = "org.h2.Driver",
633
+ )
634
+ transaction(database) {
635
+ SchemaUtils.create(UsersTable)
636
+ }
637
+ repository = ExposedUserRepository(database)
638
+ }
639
+
640
+ beforeTest {
641
+ transaction(database) {
642
+ UsersTable.deleteAll()
643
+ }
644
+ }
645
+
646
+ test("create and find user") {
647
+ val user = repository.create(CreateUserRequest("Alice", "alice@example.com"))
648
+
649
+ user.name shouldBe "Alice"
650
+ user.email shouldBe "alice@example.com"
651
+
652
+ val found = repository.findById(user.id)
653
+ found shouldBe user
654
+ }
655
+
656
+ test("findByEmail returns null for unknown email") {
657
+ val result = repository.findByEmail("unknown@example.com")
658
+ result.shouldBeNull()
659
+ }
660
+
661
+ test("pagination works correctly") {
662
+ repeat(25) { i ->
663
+ repository.create(CreateUserRequest("User $i", "user$i@example.com"))
664
+ }
665
+
666
+ val page1 = repository.findAll(page = 1, limit = 10)
667
+ page1.data shouldHaveSize 10
668
+ page1.total shouldBe 25
669
+ page1.hasNext shouldBe true
670
+
671
+ val page3 = repository.findAll(page = 3, limit = 10)
672
+ page3.data shouldHaveSize 5
673
+ page3.hasNext shouldBe false
674
+ }
675
+ })
676
+ ```
677
+
678
+ ## Gradle Dependencies
679
+
680
+ ```kotlin
681
+ // build.gradle.kts
682
+ dependencies {
683
+ // Exposed
684
+ implementation("org.jetbrains.exposed:exposed-core:1.0.0")
685
+ implementation("org.jetbrains.exposed:exposed-dao:1.0.0")
686
+ implementation("org.jetbrains.exposed:exposed-jdbc:1.0.0")
687
+ implementation("org.jetbrains.exposed:exposed-kotlin-datetime:1.0.0")
688
+ implementation("org.jetbrains.exposed:exposed-json:1.0.0")
689
+
690
+ // Database driver
691
+ implementation("org.postgresql:postgresql:42.7.5")
692
+
693
+ // Connection pooling
694
+ implementation("com.zaxxer:HikariCP:6.2.1")
695
+
696
+ // Migrations
697
+ implementation("org.flywaydb:flyway-core:10.22.0")
698
+ implementation("org.flywaydb:flyway-database-postgresql:10.22.0")
699
+
700
+ // Testing
701
+ testImplementation("com.h2database:h2:2.3.232")
702
+ }
703
+ ```
704
+
705
+ ## Quick Reference: Exposed Patterns
706
+
707
+ | Pattern | Description |
708
+ |---------|-------------|
709
+ | `object Table : UUIDTable("name")` | Define table with UUID primary key |
710
+ | `newSuspendedTransaction { }` | Coroutine-safe transaction block |
711
+ | `Table.selectAll().where { }` | Query with conditions |
712
+ | `Table.insertAndGetId { }` | Insert and return generated ID |
713
+ | `Table.update({ condition }) { }` | Update matching rows |
714
+ | `Table.deleteWhere { }` | Delete matching rows |
715
+ | `Table.batchInsert(items) { }` | Efficient bulk insert |
716
+ | `innerJoin` / `leftJoin` | Join tables |
717
+ | `orderBy` / `limit` / `offset` | Sort and paginate |
718
+ | `count()` / `sum()` / `avg()` | Aggregation functions |
719
+
720
+ **Remember**: Use the DSL style for simple queries and the DAO style when you need entity lifecycle management. Always use `newSuspendedTransaction` for coroutine support, and wrap database operations behind a repository interface for testability.