@rubix0270/arboris 1.0.1 → 1.0.3

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/package.json +8 -19
  2. package/run.mjs +10 -0
  3. package/dist/cli.mjs +0 -382
  4. package/manifest.json +0 -323
  5. package/prisma/skills/accessibility/SKILL.md +0 -147
  6. package/prisma/skills/agent-architecture-audit/SKILL.md +0 -257
  7. package/prisma/skills/agent-eval/SKILL.md +0 -146
  8. package/prisma/skills/agent-harness-construction/SKILL.md +0 -74
  9. package/prisma/skills/agent-introspection-debugging/SKILL.md +0 -154
  10. package/prisma/skills/agent-payment-x402/SKILL.md +0 -225
  11. package/prisma/skills/agent-self-evaluation/SKILL.md +0 -182
  12. package/prisma/skills/agent-self-evaluation/examples/high-score-example.md +0 -87
  13. package/prisma/skills/agent-self-evaluation/examples/low-score-example.md +0 -86
  14. package/prisma/skills/agent-self-evaluation/references/evaluation-criteria.md +0 -71
  15. package/prisma/skills/agent-self-evaluation/references/hook-integration.md +0 -64
  16. package/prisma/skills/agent-self-evaluation/scripts/evaluate.py +0 -408
  17. package/prisma/skills/agent-self-evaluation/templates/evaluation-report.md +0 -86
  18. package/prisma/skills/agent-sort/SKILL.md +0 -216
  19. package/prisma/skills/agentic-engineering/SKILL.md +0 -64
  20. package/prisma/skills/agentic-os/SKILL.md +0 -388
  21. package/prisma/skills/ai-first-engineering/SKILL.md +0 -52
  22. package/prisma/skills/ai-regression-testing/SKILL.md +0 -386
  23. package/prisma/skills/android-clean-architecture/SKILL.md +0 -340
  24. package/prisma/skills/angular-developer/SKILL.md +0 -155
  25. package/prisma/skills/angular-developer/references/angular-animations.md +0 -160
  26. package/prisma/skills/angular-developer/references/angular-aria.md +0 -410
  27. package/prisma/skills/angular-developer/references/cli.md +0 -86
  28. package/prisma/skills/angular-developer/references/component-harnesses.md +0 -59
  29. package/prisma/skills/angular-developer/references/component-styling.md +0 -91
  30. package/prisma/skills/angular-developer/references/components.md +0 -117
  31. package/prisma/skills/angular-developer/references/creating-services.md +0 -97
  32. package/prisma/skills/angular-developer/references/data-resolvers.md +0 -69
  33. package/prisma/skills/angular-developer/references/define-routes.md +0 -67
  34. package/prisma/skills/angular-developer/references/defining-providers.md +0 -72
  35. package/prisma/skills/angular-developer/references/di-fundamentals.md +0 -120
  36. package/prisma/skills/angular-developer/references/e2e-testing.md +0 -56
  37. package/prisma/skills/angular-developer/references/effects.md +0 -83
  38. package/prisma/skills/angular-developer/references/hierarchical-injectors.md +0 -43
  39. package/prisma/skills/angular-developer/references/host-elements.md +0 -80
  40. package/prisma/skills/angular-developer/references/injection-context.md +0 -63
  41. package/prisma/skills/angular-developer/references/inputs.md +0 -101
  42. package/prisma/skills/angular-developer/references/linked-signal.md +0 -59
  43. package/prisma/skills/angular-developer/references/loading-strategies.md +0 -61
  44. package/prisma/skills/angular-developer/references/mcp.md +0 -108
  45. package/prisma/skills/angular-developer/references/navigate-to-routes.md +0 -69
  46. package/prisma/skills/angular-developer/references/outputs.md +0 -86
  47. package/prisma/skills/angular-developer/references/reactive-forms.md +0 -122
  48. package/prisma/skills/angular-developer/references/rendering-strategies.md +0 -44
  49. package/prisma/skills/angular-developer/references/resource.md +0 -77
  50. package/prisma/skills/angular-developer/references/route-animations.md +0 -56
  51. package/prisma/skills/angular-developer/references/route-guards.md +0 -52
  52. package/prisma/skills/angular-developer/references/router-lifecycle.md +0 -45
  53. package/prisma/skills/angular-developer/references/router-testing.md +0 -87
  54. package/prisma/skills/angular-developer/references/show-routes-with-outlets.md +0 -68
  55. package/prisma/skills/angular-developer/references/signal-forms.md +0 -795
  56. package/prisma/skills/angular-developer/references/signals-overview.md +0 -94
  57. package/prisma/skills/angular-developer/references/tailwind-css.md +0 -69
  58. package/prisma/skills/angular-developer/references/template-driven-forms.md +0 -114
  59. package/prisma/skills/angular-developer/references/testing-fundamentals.md +0 -65
  60. package/prisma/skills/api-connector-builder/SKILL.md +0 -121
  61. package/prisma/skills/api-design/SKILL.md +0 -524
  62. package/prisma/skills/architecture-decision-records/SKILL.md +0 -180
  63. package/prisma/skills/article-writing/SKILL.md +0 -80
  64. package/prisma/skills/automation-audit-ops/SKILL.md +0 -143
  65. package/prisma/skills/autonomous-agent-harness/SKILL.md +0 -274
  66. package/prisma/skills/autonomous-loops/SKILL.md +0 -611
  67. package/prisma/skills/backend-patterns/SKILL.md +0 -562
  68. package/prisma/skills/benchmark/SKILL.md +0 -94
  69. package/prisma/skills/benchmark-methodology/SKILL.md +0 -190
  70. package/prisma/skills/benchmark-optimization-loop/SKILL.md +0 -70
  71. package/prisma/skills/blender-motion-state-inspection/SKILL.md +0 -165
  72. package/prisma/skills/blueprint/SKILL.md +0 -106
  73. package/prisma/skills/brand-discovery/SKILL.md +0 -145
  74. package/prisma/skills/brand-discovery/references/10_purpose-why.md +0 -40
  75. package/prisma/skills/brand-discovery/references/20_positioning.md +0 -44
  76. package/prisma/skills/brand-discovery/references/30_audience-niche.md +0 -52
  77. package/prisma/skills/brand-discovery/references/40_personality-archetype.md +0 -57
  78. package/prisma/skills/brand-discovery/references/50_voice-tone.md +0 -59
  79. package/prisma/skills/brand-discovery/references/60_narrative-story.md +0 -50
  80. package/prisma/skills/brand-discovery/references/70_founder-tension.md +0 -49
  81. package/prisma/skills/brand-discovery/references/90_SYNTHESIS.md +0 -133
  82. package/prisma/skills/brand-voice/SKILL.md +0 -98
  83. package/prisma/skills/brand-voice/references/voice-profile-schema.md +0 -55
  84. package/prisma/skills/browser-qa/SKILL.md +0 -105
  85. package/prisma/skills/bun-runtime/SKILL.md +0 -85
  86. package/prisma/skills/canary-watch/SKILL.md +0 -108
  87. package/prisma/skills/carrier-relationship-management/SKILL.md +0 -212
  88. package/prisma/skills/cisco-ios-patterns/SKILL.md +0 -164
  89. package/prisma/skills/ck/SKILL.md +0 -148
  90. package/prisma/skills/ck/commands/forget.mjs +0 -44
  91. package/prisma/skills/ck/commands/info.mjs +0 -24
  92. package/prisma/skills/ck/commands/init.mjs +0 -143
  93. package/prisma/skills/ck/commands/list.mjs +0 -40
  94. package/prisma/skills/ck/commands/migrate.mjs +0 -202
  95. package/prisma/skills/ck/commands/resume.mjs +0 -36
  96. package/prisma/skills/ck/commands/save.mjs +0 -210
  97. package/prisma/skills/ck/commands/shared.mjs +0 -387
  98. package/prisma/skills/ck/hooks/session-start.mjs +0 -224
  99. package/prisma/skills/claude-devfleet/SKILL.md +0 -112
  100. package/prisma/skills/click-path-audit/SKILL.md +0 -245
  101. package/prisma/skills/clickhouse-io/SKILL.md +0 -440
  102. package/prisma/skills/code-tour/SKILL.md +0 -254
  103. package/prisma/skills/codebase-onboarding/SKILL.md +0 -234
  104. package/prisma/skills/codehealth-mcp/SKILL.md +0 -167
  105. package/prisma/skills/coding-standards/SKILL.md +0 -551
  106. package/prisma/skills/competitive-platform-analysis/SKILL.md +0 -214
  107. package/prisma/skills/competitive-report-structure/SKILL.md +0 -162
  108. package/prisma/skills/compose-multiplatform-patterns/SKILL.md +0 -300
  109. package/prisma/skills/config-gc/SKILL.md +0 -120
  110. package/prisma/skills/configure-ecc/SKILL.md +0 -385
  111. package/prisma/skills/connections-optimizer/SKILL.md +0 -190
  112. package/prisma/skills/content-engine/SKILL.md +0 -132
  113. package/prisma/skills/content-hash-cache-pattern/SKILL.md +0 -162
  114. package/prisma/skills/context-budget/SKILL.md +0 -136
  115. package/prisma/skills/continuous-agent-loop/SKILL.md +0 -46
  116. package/prisma/skills/continuous-learning/SKILL.md +0 -132
  117. package/prisma/skills/continuous-learning/config.json +0 -18
  118. package/prisma/skills/continuous-learning/evaluate-session.sh +0 -69
  119. package/prisma/skills/continuous-learning-v2/SKILL.md +0 -361
  120. package/prisma/skills/continuous-learning-v2/agents/observer-loop.sh +0 -359
  121. package/prisma/skills/continuous-learning-v2/agents/observer.md +0 -189
  122. package/prisma/skills/continuous-learning-v2/agents/session-guardian.sh +0 -150
  123. package/prisma/skills/continuous-learning-v2/agents/start-observer.sh +0 -248
  124. package/prisma/skills/continuous-learning-v2/config.json +0 -8
  125. package/prisma/skills/continuous-learning-v2/hooks/observe.sh +0 -585
  126. package/prisma/skills/continuous-learning-v2/scripts/detect-project.sh +0 -322
  127. package/prisma/skills/continuous-learning-v2/scripts/instinct-cli.py +0 -1956
  128. package/prisma/skills/continuous-learning-v2/scripts/lib/homunculus-dir.sh +0 -31
  129. package/prisma/skills/continuous-learning-v2/scripts/migrate-homunculus.sh +0 -68
  130. package/prisma/skills/continuous-learning-v2/scripts/test_parse_instinct.py +0 -1421
  131. package/prisma/skills/cost-aware-llm-pipeline/SKILL.md +0 -184
  132. package/prisma/skills/cost-tracking/SKILL.md +0 -97
  133. package/prisma/skills/council/SKILL.md +0 -204
  134. package/prisma/skills/cpp-coding-standards/SKILL.md +0 -724
  135. package/prisma/skills/cpp-testing/SKILL.md +0 -325
  136. package/prisma/skills/crosspost/SKILL.md +0 -112
  137. package/prisma/skills/csharp-testing/SKILL.md +0 -322
  138. package/prisma/skills/customer-billing-ops/SKILL.md +0 -141
  139. package/prisma/skills/customs-trade-compliance/SKILL.md +0 -263
  140. package/prisma/skills/dart-flutter-patterns/SKILL.md +0 -564
  141. package/prisma/skills/dashboard-builder/SKILL.md +0 -109
  142. package/prisma/skills/data-scraper-agent/SKILL.md +0 -765
  143. package/prisma/skills/data-throughput-accelerator/SKILL.md +0 -73
  144. package/prisma/skills/database-migrations/SKILL.md +0 -430
  145. package/prisma/skills/deep-research/SKILL.md +0 -160
  146. package/prisma/skills/defi-amm-security/SKILL.md +0 -167
  147. package/prisma/skills/delivery-gate/SKILL.md +0 -126
  148. package/prisma/skills/delivery-gate/hooks/quality-gate.py +0 -220
  149. package/prisma/skills/deployment-patterns/SKILL.md +0 -428
  150. package/prisma/skills/design-system/SKILL.md +0 -83
  151. package/prisma/skills/django-celery/SKILL.md +0 -458
  152. package/prisma/skills/django-patterns/SKILL.md +0 -735
  153. package/prisma/skills/django-security/SKILL.md +0 -644
  154. package/prisma/skills/django-tdd/SKILL.md +0 -730
  155. package/prisma/skills/django-verification/SKILL.md +0 -470
  156. package/prisma/skills/dmux-workflows/SKILL.md +0 -192
  157. package/prisma/skills/docker-patterns/SKILL.md +0 -365
  158. package/prisma/skills/documentation-lookup/SKILL.md +0 -91
  159. package/prisma/skills/dotnet-patterns/SKILL.md +0 -322
  160. package/prisma/skills/dynamic-workflow-mode/SKILL.md +0 -124
  161. package/prisma/skills/e2e-testing/SKILL.md +0 -327
  162. package/prisma/skills/ecc-guide/SKILL.md +0 -190
  163. package/prisma/skills/ecc-recipes/SKILL.md +0 -149
  164. package/prisma/skills/ecc-tools-cost-audit/SKILL.md +0 -161
  165. package/prisma/skills/email-ops/SKILL.md +0 -122
  166. package/prisma/skills/energy-procurement/SKILL.md +0 -228
  167. package/prisma/skills/enterprise-agent-ops/SKILL.md +0 -51
  168. package/prisma/skills/error-handling/SKILL.md +0 -377
  169. package/prisma/skills/eval-harness/SKILL.md +0 -271
  170. package/prisma/skills/evm-token-decimals/SKILL.md +0 -131
  171. package/prisma/skills/exa-search/SKILL.md +0 -108
  172. package/prisma/skills/fal-ai-media/SKILL.md +0 -289
  173. package/prisma/skills/fastapi-patterns/SKILL.md +0 -514
  174. package/prisma/skills/finance-billing-ops/SKILL.md +0 -128
  175. package/prisma/skills/flox-environments/SKILL.md +0 -497
  176. package/prisma/skills/flutter-dart-code-review/SKILL.md +0 -436
  177. package/prisma/skills/foundation-models-on-device/SKILL.md +0 -243
  178. package/prisma/skills/frontend-a11y/SKILL.md +0 -446
  179. package/prisma/skills/frontend-design-direction/SKILL.md +0 -93
  180. package/prisma/skills/frontend-patterns/SKILL.md +0 -657
  181. package/prisma/skills/frontend-slides/SKILL.md +0 -185
  182. package/prisma/skills/frontend-slides/STYLE_PRESETS.md +0 -330
  183. package/prisma/skills/frontend-slides/animation-patterns.md +0 -122
  184. package/prisma/skills/frontend-slides/html-template.md +0 -419
  185. package/prisma/skills/frontend-slides/scripts/export-pdf.sh +0 -418
  186. package/prisma/skills/frontend-slides/scripts/extract-pptx.py +0 -96
  187. package/prisma/skills/frontend-slides/viewport-base.css +0 -153
  188. package/prisma/skills/fsharp-testing/SKILL.md +0 -281
  189. package/prisma/skills/gan-style-harness/SKILL.md +0 -279
  190. package/prisma/skills/gateguard/SKILL.md +0 -133
  191. package/prisma/skills/generating-python-installer/SKILL.md +0 -820
  192. package/prisma/skills/git-workflow/SKILL.md +0 -716
  193. package/prisma/skills/github-ops/SKILL.md +0 -145
  194. package/prisma/skills/golang-patterns/SKILL.md +0 -675
  195. package/prisma/skills/golang-testing/SKILL.md +0 -721
  196. package/prisma/skills/google-workspace-ops/SKILL.md +0 -96
  197. package/prisma/skills/growth-log/SKILL.md +0 -128
  198. package/prisma/skills/healthcare-cdss-patterns/SKILL.md +0 -246
  199. package/prisma/skills/healthcare-emr-patterns/SKILL.md +0 -160
  200. package/prisma/skills/healthcare-eval-harness/SKILL.md +0 -208
  201. package/prisma/skills/healthcare-phi-compliance/SKILL.md +0 -146
  202. package/prisma/skills/hermes-imports/SKILL.md +0 -89
  203. package/prisma/skills/hexagonal-architecture/SKILL.md +0 -277
  204. package/prisma/skills/hipaa-compliance/SKILL.md +0 -79
  205. package/prisma/skills/homelab-network-readiness/SKILL.md +0 -170
  206. package/prisma/skills/homelab-network-setup/SKILL.md +0 -130
  207. package/prisma/skills/homelab-pihole-dns/SKILL.md +0 -275
  208. package/prisma/skills/homelab-vlan-segmentation/SKILL.md +0 -312
  209. package/prisma/skills/homelab-wireguard-vpn/SKILL.md +0 -306
  210. package/prisma/skills/hookify-rules/SKILL.md +0 -128
  211. package/prisma/skills/inherit-legacy-style/SKILL.md +0 -157
  212. package/prisma/skills/intent-driven-development/SKILL.md +0 -360
  213. package/prisma/skills/inventory-demand-planning/SKILL.md +0 -247
  214. package/prisma/skills/investor-materials/SKILL.md +0 -97
  215. package/prisma/skills/investor-outreach/SKILL.md +0 -92
  216. package/prisma/skills/ios-icon-gen/SKILL.md +0 -158
  217. package/prisma/skills/ios-icon-gen/scripts/generate_icons.swift +0 -258
  218. package/prisma/skills/ios-icon-gen/scripts/iconify_gen.sh +0 -235
  219. package/prisma/skills/iterative-retrieval/SKILL.md +0 -212
  220. package/prisma/skills/ito-basket-compare/SKILL.md +0 -64
  221. package/prisma/skills/ito-data-atlas-agent/SKILL.md +0 -64
  222. package/prisma/skills/ito-market-intelligence/SKILL.md +0 -61
  223. package/prisma/skills/ito-trade-planner/SKILL.md +0 -68
  224. package/prisma/skills/java-coding-standards/SKILL.md +0 -384
  225. package/prisma/skills/jira-integration/SKILL.md +0 -303
  226. package/prisma/skills/jpa-patterns/SKILL.md +0 -152
  227. package/prisma/skills/knowledge-ops/SKILL.md +0 -155
  228. package/prisma/skills/kotlin-coroutines-flows/SKILL.md +0 -285
  229. package/prisma/skills/kotlin-exposed-patterns/SKILL.md +0 -720
  230. package/prisma/skills/kotlin-ktor-patterns/SKILL.md +0 -690
  231. package/prisma/skills/kotlin-patterns/SKILL.md +0 -712
  232. package/prisma/skills/kotlin-testing/SKILL.md +0 -825
  233. package/prisma/skills/kubernetes-patterns/SKILL.md +0 -756
  234. package/prisma/skills/laravel-patterns/SKILL.md +0 -416
  235. package/prisma/skills/laravel-plugin-discovery/SKILL.md +0 -230
  236. package/prisma/skills/laravel-security/SKILL.md +0 -948
  237. package/prisma/skills/laravel-tdd/SKILL.md +0 -675
  238. package/prisma/skills/laravel-verification/SKILL.md +0 -180
  239. package/prisma/skills/latency-critical-systems/SKILL.md +0 -74
  240. package/prisma/skills/lead-intelligence/SKILL.md +0 -322
  241. package/prisma/skills/lead-intelligence/agents/enrichment-agent.md +0 -85
  242. package/prisma/skills/lead-intelligence/agents/mutual-mapper.md +0 -75
  243. package/prisma/skills/lead-intelligence/agents/outreach-drafter.md +0 -98
  244. package/prisma/skills/lead-intelligence/agents/signal-scorer.md +0 -60
  245. package/prisma/skills/liquid-glass-design/SKILL.md +0 -279
  246. package/prisma/skills/llm-trading-agent-security/SKILL.md +0 -147
  247. package/prisma/skills/logistics-exception-management/SKILL.md +0 -222
  248. package/prisma/skills/loop-design-check/SKILL.md +0 -143
  249. package/prisma/skills/mailtrap-email-integration/SKILL.md +0 -77
  250. package/prisma/skills/make-interfaces-feel-better/SKILL.md +0 -152
  251. package/prisma/skills/manim-video/SKILL.md +0 -90
  252. package/prisma/skills/manim-video/assets/network_graph_scene.py +0 -52
  253. package/prisma/skills/market-research/SKILL.md +0 -76
  254. package/prisma/skills/marketing-campaign/SKILL.md +0 -114
  255. package/prisma/skills/mcp-server-patterns/SKILL.md +0 -70
  256. package/prisma/skills/messages-ops/SKILL.md +0 -105
  257. package/prisma/skills/ml-adoption-playbook/SKILL.md +0 -57
  258. package/prisma/skills/mle-workflow/SKILL.md +0 -347
  259. package/prisma/skills/motion-advanced/SKILL.md +0 -596
  260. package/prisma/skills/motion-foundations/SKILL.md +0 -299
  261. package/prisma/skills/motion-patterns/SKILL.md +0 -434
  262. package/prisma/skills/motion-ui/SKILL.md +0 -576
  263. package/prisma/skills/mysql-patterns/SKILL.md +0 -413
  264. package/prisma/skills/nanoclaw-repl/SKILL.md +0 -34
  265. package/prisma/skills/nestjs-patterns/SKILL.md +0 -231
  266. package/prisma/skills/netmiko-ssh-automation/SKILL.md +0 -174
  267. package/prisma/skills/network-bgp-diagnostics/SKILL.md +0 -168
  268. package/prisma/skills/network-config-validation/SKILL.md +0 -211
  269. package/prisma/skills/network-interface-health/SKILL.md +0 -153
  270. package/prisma/skills/nextjs-turbopack/SKILL.md +0 -58
  271. package/prisma/skills/nodejs-keccak256/SKILL.md +0 -103
  272. package/prisma/skills/nutrient-document-processing/SKILL.md +0 -168
  273. package/prisma/skills/nuxt4-patterns/SKILL.md +0 -101
  274. package/prisma/skills/openclaw-persona-forge/SKILL.md +0 -289
  275. package/prisma/skills/openclaw-persona-forge/gacha.py +0 -224
  276. package/prisma/skills/openclaw-persona-forge/gacha.sh +0 -5
  277. package/prisma/skills/openclaw-persona-forge/references/avatar-style.md +0 -124
  278. package/prisma/skills/openclaw-persona-forge/references/boundary-rules.md +0 -53
  279. package/prisma/skills/openclaw-persona-forge/references/error-handling.md +0 -53
  280. package/prisma/skills/openclaw-persona-forge/references/identity-tension.md +0 -48
  281. package/prisma/skills/openclaw-persona-forge/references/naming-system.md +0 -39
  282. package/prisma/skills/openclaw-persona-forge/references/output-template.md +0 -166
  283. package/prisma/skills/opensource-pipeline/SKILL.md +0 -256
  284. package/prisma/skills/orch-add-feature/SKILL.md +0 -45
  285. package/prisma/skills/orch-build-mvp/SKILL.md +0 -49
  286. package/prisma/skills/orch-change-feature/SKILL.md +0 -43
  287. package/prisma/skills/orch-fix-defect/SKILL.md +0 -43
  288. package/prisma/skills/orch-pipeline/SKILL.md +0 -121
  289. package/prisma/skills/orch-refine-code/SKILL.md +0 -44
  290. package/prisma/skills/parallel-execution-optimizer/SKILL.md +0 -73
  291. package/prisma/skills/perl-patterns/SKILL.md +0 -505
  292. package/prisma/skills/perl-security/SKILL.md +0 -504
  293. package/prisma/skills/perl-testing/SKILL.md +0 -476
  294. package/prisma/skills/plan-orchestrate/SKILL.md +0 -263
  295. package/prisma/skills/plankton-code-quality/SKILL.md +0 -237
  296. package/prisma/skills/postgres-patterns/SKILL.md +0 -148
  297. package/prisma/skills/prediction-market-oracle-research/SKILL.md +0 -64
  298. package/prisma/skills/prediction-market-risk-review/SKILL.md +0 -61
  299. package/prisma/skills/prisma-patterns/SKILL.md +0 -401
  300. package/prisma/skills/product-capability/SKILL.md +0 -142
  301. package/prisma/skills/product-lens/SKILL.md +0 -93
  302. package/prisma/skills/production-audit/SKILL.md +0 -207
  303. package/prisma/skills/production-scheduling/SKILL.md +0 -238
  304. package/prisma/skills/project-flow-ops/SKILL.md +0 -112
  305. package/prisma/skills/prompt-optimizer/SKILL.md +0 -398
  306. package/prisma/skills/python-patterns/SKILL.md +0 -751
  307. package/prisma/skills/python-testing/SKILL.md +0 -817
  308. package/prisma/skills/pytorch-patterns/SKILL.md +0 -397
  309. package/prisma/skills/quality-nonconformance/SKILL.md +0 -260
  310. package/prisma/skills/quarkus-patterns/SKILL.md +0 -723
  311. package/prisma/skills/quarkus-security/SKILL.md +0 -468
  312. package/prisma/skills/quarkus-tdd/SKILL.md +0 -812
  313. package/prisma/skills/quarkus-verification/SKILL.md +0 -480
  314. package/prisma/skills/ralphinho-rfc-pipeline/SKILL.md +0 -68
  315. package/prisma/skills/react-native-patterns/SKILL.md +0 -326
  316. package/prisma/skills/react-patterns/SKILL.md +0 -342
  317. package/prisma/skills/react-performance/SKILL.md +0 -575
  318. package/prisma/skills/react-testing/SKILL.md +0 -424
  319. package/prisma/skills/recsys-pipeline-architect/SKILL.md +0 -115
  320. package/prisma/skills/recursive-decision-ledger/SKILL.md +0 -80
  321. package/prisma/skills/redis-patterns/SKILL.md +0 -404
  322. package/prisma/skills/regex-vs-llm-structured-text/SKILL.md +0 -221
  323. package/prisma/skills/remotion-video-creation/SKILL.md +0 -43
  324. package/prisma/skills/remotion-video-creation/rules/3d.md +0 -86
  325. package/prisma/skills/remotion-video-creation/rules/animations.md +0 -29
  326. package/prisma/skills/remotion-video-creation/rules/assets/charts-bar-chart.tsx +0 -173
  327. package/prisma/skills/remotion-video-creation/rules/assets/text-animations-typewriter.tsx +0 -100
  328. package/prisma/skills/remotion-video-creation/rules/assets/text-animations-word-highlight.tsx +0 -108
  329. package/prisma/skills/remotion-video-creation/rules/assets.md +0 -78
  330. package/prisma/skills/remotion-video-creation/rules/audio.md +0 -172
  331. package/prisma/skills/remotion-video-creation/rules/calculate-metadata.md +0 -104
  332. package/prisma/skills/remotion-video-creation/rules/can-decode.md +0 -75
  333. package/prisma/skills/remotion-video-creation/rules/charts.md +0 -58
  334. package/prisma/skills/remotion-video-creation/rules/compositions.md +0 -146
  335. package/prisma/skills/remotion-video-creation/rules/display-captions.md +0 -126
  336. package/prisma/skills/remotion-video-creation/rules/extract-frames.md +0 -229
  337. package/prisma/skills/remotion-video-creation/rules/fonts.md +0 -152
  338. package/prisma/skills/remotion-video-creation/rules/get-audio-duration.md +0 -58
  339. package/prisma/skills/remotion-video-creation/rules/get-video-dimensions.md +0 -68
  340. package/prisma/skills/remotion-video-creation/rules/get-video-duration.md +0 -58
  341. package/prisma/skills/remotion-video-creation/rules/gifs.md +0 -138
  342. package/prisma/skills/remotion-video-creation/rules/images.md +0 -130
  343. package/prisma/skills/remotion-video-creation/rules/import-srt-captions.md +0 -67
  344. package/prisma/skills/remotion-video-creation/rules/lottie.md +0 -67
  345. package/prisma/skills/remotion-video-creation/rules/measuring-dom-nodes.md +0 -34
  346. package/prisma/skills/remotion-video-creation/rules/measuring-text.md +0 -143
  347. package/prisma/skills/remotion-video-creation/rules/sequencing.md +0 -106
  348. package/prisma/skills/remotion-video-creation/rules/tailwind.md +0 -11
  349. package/prisma/skills/remotion-video-creation/rules/text-animations.md +0 -20
  350. package/prisma/skills/remotion-video-creation/rules/timing.md +0 -179
  351. package/prisma/skills/remotion-video-creation/rules/transcribe-captions.md +0 -19
  352. package/prisma/skills/remotion-video-creation/rules/transitions.md +0 -122
  353. package/prisma/skills/remotion-video-creation/rules/trimming.md +0 -52
  354. package/prisma/skills/remotion-video-creation/rules/videos.md +0 -171
  355. package/prisma/skills/repo-scan/SKILL.md +0 -79
  356. package/prisma/skills/research-ops/SKILL.md +0 -113
  357. package/prisma/skills/returns-reverse-logistics/SKILL.md +0 -240
  358. package/prisma/skills/rules-distill/SKILL.md +0 -265
  359. package/prisma/skills/rules-distill/scripts/scan-rules.sh +0 -58
  360. package/prisma/skills/rules-distill/scripts/scan-skills.sh +0 -129
  361. package/prisma/skills/rust-patterns/SKILL.md +0 -500
  362. package/prisma/skills/rust-testing/SKILL.md +0 -501
  363. package/prisma/skills/safety-guard/SKILL.md +0 -76
  364. package/prisma/skills/santa-method/SKILL.md +0 -307
  365. package/prisma/skills/scientific-db-pubmed-database/SKILL.md +0 -176
  366. package/prisma/skills/scientific-db-uspto-database/SKILL.md +0 -178
  367. package/prisma/skills/scientific-pkg-gget/SKILL.md +0 -167
  368. package/prisma/skills/scientific-thinking-literature-review/SKILL.md +0 -193
  369. package/prisma/skills/scientific-thinking-scholar-evaluation/SKILL.md +0 -161
  370. package/prisma/skills/search-first/SKILL.md +0 -183
  371. package/prisma/skills/security-bounty-hunter/SKILL.md +0 -100
  372. package/prisma/skills/security-review/SKILL.md +0 -504
  373. package/prisma/skills/security-review/cloud-infrastructure-security.md +0 -361
  374. package/prisma/skills/security-scan/SKILL.md +0 -166
  375. package/prisma/skills/seo/SKILL.md +0 -155
  376. package/prisma/skills/skill-comply/SKILL.md +0 -59
  377. package/prisma/skills/skill-comply/fixtures/compliant_trace.jsonl +0 -5
  378. package/prisma/skills/skill-comply/fixtures/noncompliant_trace.jsonl +0 -3
  379. package/prisma/skills/skill-comply/fixtures/tdd_spec.yaml +0 -44
  380. package/prisma/skills/skill-comply/prompts/classifier.md +0 -24
  381. package/prisma/skills/skill-comply/prompts/scenario_generator.md +0 -62
  382. package/prisma/skills/skill-comply/prompts/spec_generator.md +0 -42
  383. package/prisma/skills/skill-comply/pyproject.toml +0 -15
  384. package/prisma/skills/skill-comply/scripts/__init__.py +0 -0
  385. package/prisma/skills/skill-comply/scripts/classifier.py +0 -85
  386. package/prisma/skills/skill-comply/scripts/grader.py +0 -124
  387. package/prisma/skills/skill-comply/scripts/parser.py +0 -107
  388. package/prisma/skills/skill-comply/scripts/report.py +0 -170
  389. package/prisma/skills/skill-comply/scripts/run.py +0 -127
  390. package/prisma/skills/skill-comply/scripts/runner.py +0 -194
  391. package/prisma/skills/skill-comply/scripts/scenario_generator.py +0 -70
  392. package/prisma/skills/skill-comply/scripts/spec_generator.py +0 -72
  393. package/prisma/skills/skill-comply/scripts/utils.py +0 -13
  394. package/prisma/skills/skill-comply/tests/test_grader.py +0 -197
  395. package/prisma/skills/skill-comply/tests/test_parser.py +0 -90
  396. package/prisma/skills/skill-comply/tests/test_runner.py +0 -172
  397. package/prisma/skills/skill-scout/SKILL.md +0 -141
  398. package/prisma/skills/skill-stocktake/SKILL.md +0 -195
  399. package/prisma/skills/skill-stocktake/scripts/quick-diff.sh +0 -87
  400. package/prisma/skills/skill-stocktake/scripts/save-results.sh +0 -56
  401. package/prisma/skills/skill-stocktake/scripts/scan.sh +0 -170
  402. package/prisma/skills/social-graph-ranker/SKILL.md +0 -155
  403. package/prisma/skills/social-publisher/SKILL.md +0 -130
  404. package/prisma/skills/springboot-patterns/SKILL.md +0 -315
  405. package/prisma/skills/springboot-security/SKILL.md +0 -273
  406. package/prisma/skills/springboot-tdd/SKILL.md +0 -159
  407. package/prisma/skills/springboot-verification/SKILL.md +0 -232
  408. package/prisma/skills/strategic-compact/SKILL.md +0 -136
  409. package/prisma/skills/swift-actor-persistence/SKILL.md +0 -144
  410. package/prisma/skills/swift-concurrency-6-2/SKILL.md +0 -216
  411. package/prisma/skills/swift-protocol-di-testing/SKILL.md +0 -191
  412. package/prisma/skills/swiftui-patterns/SKILL.md +0 -259
  413. package/prisma/skills/taste/SKILL.md +0 -264
  414. package/prisma/skills/taste/references/genre-taxonomy.md +0 -87
  415. package/prisma/skills/tdd-workflow/SKILL.md +0 -583
  416. package/prisma/skills/team-agent-orchestration/SKILL.md +0 -111
  417. package/prisma/skills/team-builder/SKILL.md +0 -169
  418. package/prisma/skills/terminal-ops/SKILL.md +0 -110
  419. package/prisma/skills/tinystruct-patterns/SKILL.md +0 -279
  420. package/prisma/skills/tinystruct-patterns/references/architecture.md +0 -90
  421. package/prisma/skills/tinystruct-patterns/references/data-handling.md +0 -60
  422. package/prisma/skills/tinystruct-patterns/references/database.md +0 -99
  423. package/prisma/skills/tinystruct-patterns/references/routing.md +0 -64
  424. package/prisma/skills/tinystruct-patterns/references/system-usage.md +0 -97
  425. package/prisma/skills/tinystruct-patterns/references/testing.md +0 -72
  426. package/prisma/skills/token-budget-advisor/SKILL.md +0 -134
  427. package/prisma/skills/ui-demo/SKILL.md +0 -466
  428. package/prisma/skills/ui-to-vue/SKILL.md +0 -135
  429. package/prisma/skills/uncloud/SKILL.md +0 -344
  430. package/prisma/skills/unified-notifications-ops/SKILL.md +0 -188
  431. package/prisma/skills/verification-loop/SKILL.md +0 -127
  432. package/prisma/skills/video-editing/SKILL.md +0 -311
  433. package/prisma/skills/videodb/SKILL.md +0 -375
  434. package/prisma/skills/videodb/reference/api-reference.md +0 -550
  435. package/prisma/skills/videodb/reference/capture-reference.md +0 -407
  436. package/prisma/skills/videodb/reference/capture.md +0 -101
  437. package/prisma/skills/videodb/reference/editor.md +0 -443
  438. package/prisma/skills/videodb/reference/generative.md +0 -331
  439. package/prisma/skills/videodb/reference/rtstream-reference.md +0 -564
  440. package/prisma/skills/videodb/reference/rtstream.md +0 -65
  441. package/prisma/skills/videodb/reference/search.md +0 -230
  442. package/prisma/skills/videodb/reference/streaming.md +0 -406
  443. package/prisma/skills/videodb/reference/use-cases.md +0 -118
  444. package/prisma/skills/videodb/scripts/ws_listener.py +0 -282
  445. package/prisma/skills/visa-doc-translate/README.md +0 -86
  446. package/prisma/skills/visa-doc-translate/SKILL.md +0 -117
  447. package/prisma/skills/vite-patterns/SKILL.md +0 -450
  448. package/prisma/skills/vue-patterns/SKILL.md +0 -471
  449. package/prisma/skills/windows-desktop-e2e/SKILL.md +0 -888
  450. package/prisma/skills/workspace-surface-audit/SKILL.md +0 -126
  451. package/prisma/skills/x-api/SKILL.md +0 -235
@@ -1,720 +0,0 @@
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.