@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,723 +0,0 @@
1
- ---
2
- name: quarkus-patterns
3
- description: Quarkus 3.x LTS architecture patterns with Camel for messaging, RESTful API design, CDI services, data access with Panache, and async processing. Use for Java Quarkus backend work with event-driven architectures.
4
- metadata:
5
- origin: ECC
6
- ---
7
-
8
- # Quarkus Development Patterns
9
-
10
- Quarkus 3.x architecture and API patterns for cloud-native, event-driven services with Apache Camel.
11
-
12
- ## When to Activate
13
-
14
- - Building REST APIs with JAX-RS or RESTEasy Reactive
15
- - Structuring resource → service → repository layers
16
- - Implementing event-driven patterns with Apache Camel and RabbitMQ
17
- - Configuring Hibernate Panache, caching, or reactive streams
18
- - Adding validation, exception mapping, or pagination
19
- - Setting up profiles for dev/staging/production environments (YAML config)
20
- - Custom logging with LogContext and Logback/Logstash encoder
21
- - Working with CompletableFuture for async operations
22
- - Implementing conditional flow processing
23
- - Working with GraalVM native compilation
24
-
25
- ## Service Layer with Multiple Dependencies
26
-
27
- ```java
28
- @Slf4j
29
- @ApplicationScoped
30
- @RequiredArgsConstructor
31
- public class OrderProcessingService {
32
-
33
- private final OrderValidator orderValidator;
34
- private final EventService eventService;
35
- private final OrderRepository orderRepository;
36
- private final FulfillmentPublisher fulfillmentPublisher;
37
- private final AuditPublisher auditPublisher;
38
-
39
- @Transactional
40
- public OrderReceipt process(CreateOrderCommand command) {
41
- ValidationResult validation = orderValidator.validate(command);
42
- if (!validation.valid()) {
43
- eventService.createErrorEvent(command, "ORDER_REJECTED", validation.message());
44
- throw new WebApplicationException(validation.message(), Response.Status.BAD_REQUEST);
45
- }
46
-
47
- Order order = Order.from(command);
48
- orderRepository.persist(order);
49
-
50
- OrderReceipt receipt = OrderReceipt.from(order);
51
- fulfillmentPublisher.publishAsync(receipt);
52
- auditPublisher.publish("ORDER_ACCEPTED", receipt);
53
- eventService.createSuccessEvent(receipt, "ORDER_ACCEPTED");
54
-
55
- log.info("Processed order {}", order.id);
56
- return receipt;
57
- }
58
- }
59
- ```
60
-
61
- **Key Patterns:**
62
- - `@RequiredArgsConstructor` for constructor injection via Lombok
63
- - `@Slf4j` for Logback logging
64
- - `@Transactional` on service methods that write through Panache or repositories
65
- - Validate input before persistence or message publication
66
- - Event tracking for success/error scenarios
67
- - Async Camel message publishing
68
-
69
- ## Custom Logging Context Pattern (Logback)
70
-
71
- ```java
72
- @ApplicationScoped
73
- public class ProcessingService {
74
-
75
- public void processDocument(Document doc) {
76
- LogContext logContext = CustomLog.getCurrentContext();
77
- try (SafeAutoCloseable ignored = CustomLog.startScope(logContext)) {
78
- // Add context to all log statements
79
- logContext.put("documentId", doc.getId().toString());
80
- logContext.put("documentType", doc.getType());
81
- logContext.put("userId", SecurityContext.getUserId());
82
-
83
- log.info("Starting document processing");
84
-
85
- // All logs within this scope inherit the context
86
- processInternal(doc);
87
-
88
- log.info("Document processing completed");
89
- } catch (Exception e) {
90
- log.error("Document processing failed", e);
91
- throw e;
92
- }
93
- }
94
- }
95
- ```
96
-
97
- **Logback Configuration (logback.xml):**
98
-
99
- ```xml
100
- <configuration>
101
- <appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
102
- <encoder class="net.logstash.logback.encoder.LogstashEncoder">
103
- <includeContext>true</includeContext>
104
- <includeMdc>true</includeMdc>
105
- </encoder>
106
- </appender>
107
-
108
- <logger name="com.example" level="INFO"/>
109
- <root level="WARN">
110
- <appender-ref ref="CONSOLE"/>
111
- </root>
112
- </configuration>
113
- ```
114
-
115
- ## Event Service Pattern
116
-
117
- ```java
118
- @Slf4j
119
- @ApplicationScoped
120
- @RequiredArgsConstructor
121
- public class EventService {
122
- private final EventRepository eventRepository;
123
- private final ObjectMapper objectMapper;
124
-
125
- public void createSuccessEvent(Object payload, String eventType) {
126
- Objects.requireNonNull(payload, "Payload cannot be null");
127
- Event event = new Event();
128
- event.setType(eventType);
129
- event.setStatus(EventStatus.SUCCESS);
130
- event.setPayload(serializePayload(payload));
131
- event.setTimestamp(Instant.now());
132
-
133
- eventRepository.persist(event);
134
- log.info("Success event created: {}", eventType);
135
- }
136
-
137
- public void createErrorEvent(Object payload, String eventType, String errorMessage) {
138
- Objects.requireNonNull(payload, "Payload cannot be null");
139
- if (errorMessage == null || errorMessage.isBlank()) {
140
- throw new IllegalArgumentException("Error message cannot be blank");
141
- }
142
- Event event = new Event();
143
- event.setType(eventType);
144
- event.setStatus(EventStatus.ERROR);
145
- event.setErrorMessage(errorMessage);
146
- event.setPayload(serializePayload(payload));
147
- event.setTimestamp(Instant.now());
148
-
149
- eventRepository.persist(event);
150
- log.error("Error event created: {} - {}", eventType, errorMessage);
151
- }
152
-
153
- private String serializePayload(Object payload) {
154
- try {
155
- return objectMapper.writeValueAsString(payload);
156
- } catch (JsonProcessingException e) {
157
- throw new IllegalStateException("Failed to serialize event payload", e);
158
- }
159
- }
160
- }
161
- ```
162
-
163
- ## Camel Message Publishing (RabbitMQ)
164
-
165
- ```java
166
- @Slf4j
167
- @ApplicationScoped
168
- @RequiredArgsConstructor
169
- public class BusinessRulesPublisher {
170
- private final ProducerTemplate producerTemplate;
171
-
172
- public void publishSync(BusinessRulesPayload payload) {
173
- producerTemplate.sendBody(
174
- "direct:business-rules-publisher",
175
- payload
176
- );
177
- }
178
- }
179
- ```
180
-
181
- **Camel Route Configuration:**
182
-
183
- ```java
184
- @ApplicationScoped
185
- public class BusinessRulesRoute extends RouteBuilder {
186
-
187
- @ConfigProperty(name = "camel.rabbitmq.queue.business-rules")
188
- String businessRulesQueue;
189
-
190
- @ConfigProperty(name = "rabbitmq.host")
191
- String rabbitHost;
192
-
193
- @ConfigProperty(name = "rabbitmq.port")
194
- Integer rabbitPort;
195
-
196
- @Override
197
- public void configure() {
198
- from("direct:business-rules-publisher")
199
- .routeId("business-rules-publisher")
200
- .log("Publishing message to RabbitMQ: ${body}")
201
- .marshal().json(JsonLibrary.Jackson)
202
- .toF("spring-rabbitmq:%s?hostname=%s&portNumber=%d",
203
- businessRulesQueue, rabbitHost, rabbitPort);
204
- }
205
- }
206
- ```
207
-
208
- ## Camel Direct Routes (In-Memory)
209
-
210
- ```java
211
- @ApplicationScoped
212
- public class DocumentProcessingRoute extends RouteBuilder {
213
-
214
- @Override
215
- public void configure() {
216
- // Error handling
217
- onException(ValidationException.class)
218
- .handled(true)
219
- .to("direct:validation-error-handler")
220
- .log("Validation error: ${exception.message}");
221
-
222
- // Main processing route
223
- from("direct:process-document")
224
- .routeId("document-processing")
225
- .log("Processing document: ${header.documentId}")
226
- .bean(DocumentValidator.class, "validate")
227
- .bean(DocumentTransformer.class, "transform")
228
- .choice()
229
- .when(header("documentType").isEqualTo("INVOICE"))
230
- .to("direct:process-invoice")
231
- .when(header("documentType").isEqualTo("CREDIT_NOTE"))
232
- .to("direct:process-credit-note")
233
- .otherwise()
234
- .to("direct:process-generic")
235
- .end();
236
-
237
- from("direct:validation-error-handler")
238
- .bean(EventService.class, "createErrorEvent")
239
- .log("Validation error handled");
240
- }
241
- }
242
- ```
243
-
244
- ## Camel File Processing
245
-
246
- ```java
247
- @ApplicationScoped
248
- public class FileMonitoringRoute extends RouteBuilder {
249
-
250
- @ConfigProperty(name = "file.input.directory")
251
- String inputDirectory;
252
-
253
- @ConfigProperty(name = "file.processed.directory")
254
- String processedDirectory;
255
-
256
- @ConfigProperty(name = "file.error.directory")
257
- String errorDirectory;
258
-
259
- @Override
260
- public void configure() {
261
- from("file:" + inputDirectory + "?move=" + processedDirectory +
262
- "&moveFailed=" + errorDirectory + "&delay=5000")
263
- .routeId("file-monitor")
264
- .log("Processing file: ${header.CamelFileName}")
265
- .to("direct:process-file");
266
-
267
- from("direct:process-file")
268
- .bean(OrderProcessingService.class, "processFile")
269
- .log("File processing completed");
270
- }
271
- }
272
- ```
273
-
274
- ## Camel Bean Invocation
275
-
276
- ```java
277
- @ApplicationScoped
278
- public class InvoiceRoute extends RouteBuilder {
279
-
280
- @Override
281
- public void configure() {
282
- from("direct:invoice-validation")
283
- .bean(InvoiceFlowValidator.class, "validateFlowWithConfig")
284
- .log("Validation result: ${body}");
285
-
286
- from("direct:persist-and-publish")
287
- .bean(DocumentJobService.class, "createDocumentAndJobEntities")
288
- .bean(BusinessRulesPublisher.class, "publishAsync")
289
- .bean(EventService.class, "createSuccessEvent(${body}, 'PUBLISHED')");
290
- }
291
- }
292
- ```
293
-
294
- ## REST API Structure
295
-
296
- ```java
297
- @Path("/api/documents")
298
- @Produces(MediaType.APPLICATION_JSON)
299
- @Consumes(MediaType.APPLICATION_JSON)
300
- @RequiredArgsConstructor
301
- public class DocumentResource {
302
- private final DocumentService documentService;
303
-
304
- @GET
305
- public Response list(
306
- @QueryParam("page") @DefaultValue("0") int page,
307
- @QueryParam("size") @DefaultValue("20") int size) {
308
- List<Document> documents = documentService.list(page, size);
309
- return Response.ok(documents).build();
310
- }
311
-
312
- @POST
313
- public Response create(@Valid CreateDocumentRequest request, @Context UriInfo uriInfo) {
314
- Document document = documentService.create(request);
315
- URI location = uriInfo.getAbsolutePathBuilder()
316
- .path(String.valueOf(document.id))
317
- .build();
318
- return Response.created(location).entity(DocumentResponse.from(document)).build();
319
- }
320
-
321
- @GET
322
- @Path("/{id}")
323
- public Response getById(@PathParam("id") Long id) {
324
- return documentService.findById(id)
325
- .map(DocumentResponse::from)
326
- .map(Response::ok)
327
- .orElse(Response.status(Response.Status.NOT_FOUND))
328
- .build();
329
- }
330
- }
331
- ```
332
-
333
- ## Repository Pattern (Panache Repository)
334
-
335
- ```java
336
- @ApplicationScoped
337
- public class DocumentRepository implements PanacheRepository<Document> {
338
-
339
- public List<Document> findByStatus(DocumentStatus status, int page, int size) {
340
- return find("status = ?1 order by createdAt desc", status)
341
- .page(page, size)
342
- .list();
343
- }
344
-
345
- public Optional<Document> findByReferenceNumber(String referenceNumber) {
346
- return find("referenceNumber", referenceNumber).firstResultOptional();
347
- }
348
-
349
- public long countByStatusAndDate(DocumentStatus status, LocalDate date) {
350
- return count("status = ?1 and createdAt >= ?2", status, date.atStartOfDay());
351
- }
352
- }
353
- ```
354
-
355
- ## Service Layer with Transactions
356
-
357
- ```java
358
- @ApplicationScoped
359
- @RequiredArgsConstructor
360
- public class DocumentService {
361
- private final DocumentRepository repo;
362
- private final EventService eventService;
363
-
364
- @Transactional
365
- public Document create(CreateDocumentRequest request) {
366
- Document document = new Document();
367
- document.setReferenceNumber(request.referenceNumber());
368
- document.setDescription(request.description());
369
- document.setStatus(DocumentStatus.PENDING);
370
- document.setCreatedAt(Instant.now());
371
-
372
- repo.persist(document);
373
-
374
- eventService.createSuccessEvent(document, "DOCUMENT_CREATED");
375
-
376
- return document;
377
- }
378
-
379
- public Optional<Document> findById(Long id) {
380
- return repo.findByIdOptional(id);
381
- }
382
-
383
- public List<Document> list(int page, int size) {
384
- return repo.findAll()
385
- .page(page, size)
386
- .list();
387
- }
388
- }
389
- ```
390
-
391
- ## DTOs and Validation
392
-
393
- ```java
394
- public record CreateDocumentRequest(
395
- @NotBlank @Size(max = 200) String referenceNumber,
396
- @NotBlank @Size(max = 2000) String description,
397
- @NotNull @FutureOrPresent Instant validUntil,
398
- @NotEmpty List<@NotBlank String> categories) {}
399
-
400
- public record DocumentResponse(Long id, String referenceNumber, DocumentStatus status) {
401
- public static DocumentResponse from(Document document) {
402
- return new DocumentResponse(document.getId(), document.getReferenceNumber(),
403
- document.getStatus());
404
- }
405
- }
406
- ```
407
-
408
- ## Exception Mapping
409
-
410
- ```java
411
- @Provider
412
- public class ValidationExceptionMapper implements ExceptionMapper<ConstraintViolationException> {
413
- @Override
414
- public Response toResponse(ConstraintViolationException exception) {
415
- String message = exception.getConstraintViolations().stream()
416
- .map(cv -> cv.getPropertyPath() + ": " + cv.getMessage())
417
- .collect(Collectors.joining(", "));
418
-
419
- return Response.status(Response.Status.BAD_REQUEST)
420
- .entity(Map.of("error", "validation_error", "message", message))
421
- .build();
422
- }
423
- }
424
-
425
- @Provider
426
- @Slf4j
427
- public class GenericExceptionMapper implements ExceptionMapper<Exception> {
428
-
429
- @Override
430
- public Response toResponse(Exception exception) {
431
- log.error("Unhandled exception", exception);
432
- return Response.status(Response.Status.INTERNAL_SERVER_ERROR)
433
- .entity(Map.of("error", "internal_error", "message", "An unexpected error occurred"))
434
- .build();
435
- }
436
- }
437
- ```
438
-
439
- ## CompletableFuture Async Operations
440
-
441
- ```java
442
- @Slf4j
443
- @ApplicationScoped
444
- @RequiredArgsConstructor
445
- public class FileStorageService {
446
- private final S3Client s3Client;
447
- private final ExecutorService executorService;
448
-
449
- @ConfigProperty(name = "storage.bucket-name")
450
- String bucketName;
451
-
452
- public CompletableFuture<StoredDocumentInfo> uploadOriginalFile(
453
- InputStream inputStream,
454
- long size,
455
- LogContext logContext,
456
- InvoiceFormat format) {
457
-
458
- return CompletableFuture.supplyAsync(() -> {
459
- try (SafeAutoCloseable ignored = CustomLog.startScope(logContext)) {
460
- String path = generateStoragePath(format);
461
-
462
- PutObjectRequest request = PutObjectRequest.builder()
463
- .bucket(bucketName)
464
- .key(path)
465
- .contentLength(size)
466
- .build();
467
-
468
- s3Client.putObject(request, RequestBody.fromInputStream(inputStream, size));
469
-
470
- log.info("File uploaded to S3: {}", path);
471
-
472
- return new StoredDocumentInfo(path, size, Instant.now());
473
- } catch (Exception e) {
474
- log.error("Failed to upload file to S3", e);
475
- throw new StorageException("Upload failed", e);
476
- }
477
- }, executorService);
478
- }
479
- }
480
- ```
481
-
482
- ## Caching
483
-
484
- ```java
485
- @ApplicationScoped
486
- @RequiredArgsConstructor
487
- public class DocumentCacheService {
488
- private final DocumentRepository repo;
489
-
490
- @CacheResult(cacheName = "document-cache")
491
- public Optional<Document> getById(@CacheKey Long id) {
492
- return repo.findByIdOptional(id);
493
- }
494
-
495
- @CacheInvalidate(cacheName = "document-cache")
496
- public void evict(@CacheKey Long id) {}
497
-
498
- @CacheInvalidateAll(cacheName = "document-cache")
499
- public void evictAll() {}
500
- }
501
- ```
502
-
503
- ## Configuration as YAML
504
-
505
- ```yaml
506
- # application.yml
507
- "%dev":
508
- quarkus:
509
- datasource:
510
- jdbc:
511
- url: jdbc:postgresql://localhost:5432/dev_db
512
- username: dev_user
513
- password: ${DB_PASSWORD}
514
- hibernate-orm:
515
- database:
516
- generation: drop-and-create
517
-
518
- rabbitmq:
519
- host: localhost
520
- port: 5672
521
- username: ${RABBITMQ_USER}
522
- password: ${RABBITMQ_PASSWORD}
523
-
524
- "%test":
525
- quarkus:
526
- datasource:
527
- jdbc:
528
- url: jdbc:h2:mem:test
529
- hibernate-orm:
530
- database:
531
- generation: drop-and-create
532
-
533
- "%prod":
534
- quarkus:
535
- datasource:
536
- jdbc:
537
- url: ${DATABASE_URL}
538
- username: ${DB_USER}
539
- password: ${DB_PASSWORD}
540
- hibernate-orm:
541
- database:
542
- generation: validate
543
-
544
- rabbitmq:
545
- host: ${RABBITMQ_HOST}
546
- port: ${RABBITMQ_PORT}
547
- username: ${RABBITMQ_USER}
548
- password: ${RABBITMQ_PASSWORD}
549
-
550
- # Camel configuration
551
- camel:
552
- rabbitmq:
553
- queue:
554
- business-rules: business-rules-queue
555
- invoice-processing: invoice-processing-queue
556
- ```
557
-
558
- ## Health Checks
559
-
560
- ```java
561
- @Readiness
562
- @ApplicationScoped
563
- @RequiredArgsConstructor
564
- public class DatabaseHealthCheck implements HealthCheck {
565
- private final AgroalDataSource dataSource;
566
-
567
- @Override
568
- public HealthCheckResponse call() {
569
- try (Connection conn = dataSource.getConnection()) {
570
- boolean valid = conn.isValid(2);
571
- return HealthCheckResponse.named("Database connection")
572
- .status(valid)
573
- .build();
574
- } catch (SQLException e) {
575
- return HealthCheckResponse.down("Database connection");
576
- }
577
- }
578
- }
579
-
580
- @Liveness
581
- @ApplicationScoped
582
- public class CamelHealthCheck implements HealthCheck {
583
- @Inject
584
- CamelContext camelContext;
585
-
586
- @Override
587
- public HealthCheckResponse call() {
588
- boolean isStarted = camelContext.getStatus().isStarted();
589
- return HealthCheckResponse.named("Camel Context")
590
- .status(isStarted)
591
- .build();
592
- }
593
- }
594
- ```
595
-
596
- ## Dependencies (Maven)
597
-
598
- ```xml
599
- <properties>
600
- <quarkus.platform.version>3.27.0</quarkus.platform.version>
601
- <lombok.version>1.18.42</lombok.version>
602
- <assertj-core.version>3.24.2</assertj-core.version>
603
- <jacoco-maven-plugin.version>0.8.13</jacoco-maven-plugin.version>
604
- <maven.compiler.release>17</maven.compiler.release>
605
- </properties>
606
-
607
- <dependencyManagement>
608
- <dependencies>
609
- <dependency>
610
- <groupId>io.quarkus.platform</groupId>
611
- <artifactId>quarkus-bom</artifactId>
612
- <version>${quarkus.platform.version}</version>
613
- <type>pom</type>
614
- <scope>import</scope>
615
- </dependency>
616
- <dependency>
617
- <groupId>io.quarkus.platform</groupId>
618
- <artifactId>quarkus-camel-bom</artifactId>
619
- <version>${quarkus.platform.version}</version>
620
- <type>pom</type>
621
- <scope>import</scope>
622
- </dependency>
623
- </dependencies>
624
- </dependencyManagement>
625
-
626
- <dependencies>
627
- <!-- Quarkus Core -->
628
- <dependency>
629
- <groupId>io.quarkus</groupId>
630
- <artifactId>quarkus-arc</artifactId>
631
- </dependency>
632
- <dependency>
633
- <groupId>io.quarkus</groupId>
634
- <artifactId>quarkus-config-yaml</artifactId>
635
- </dependency>
636
-
637
- <!-- Camel Extensions -->
638
- <dependency>
639
- <groupId>org.apache.camel.quarkus</groupId>
640
- <artifactId>camel-quarkus-spring-rabbitmq</artifactId>
641
- </dependency>
642
- <dependency>
643
- <groupId>org.apache.camel.quarkus</groupId>
644
- <artifactId>camel-quarkus-direct</artifactId>
645
- </dependency>
646
- <dependency>
647
- <groupId>org.apache.camel.quarkus</groupId>
648
- <artifactId>camel-quarkus-bean</artifactId>
649
- </dependency>
650
-
651
- <!-- Lombok -->
652
- <dependency>
653
- <groupId>org.projectlombok</groupId>
654
- <artifactId>lombok</artifactId>
655
- <version>${lombok.version}</version>
656
- <scope>provided</scope>
657
- </dependency>
658
-
659
- <!-- Logging -->
660
- <dependency>
661
- <groupId>io.quarkiverse.logging.logback</groupId>
662
- <artifactId>quarkus-logging-logback</artifactId>
663
- </dependency>
664
- <dependency>
665
- <groupId>net.logstash.logback</groupId>
666
- <artifactId>logstash-logback-encoder</artifactId>
667
- </dependency>
668
- </dependencies>
669
- ```
670
-
671
- ## Best Practices
672
-
673
- ### Architecture
674
- - Use `@RequiredArgsConstructor` with Lombok for constructor injection
675
- - Keep service layer thin; delegate complex logic to specialized classes
676
- - Use Camel routes for message routing and integration patterns
677
- - Prefer Panache Repository pattern for data access
678
-
679
- ### Event-Driven
680
- - Always track operations with EventService (success/error events)
681
- - Use Camel `direct:` endpoints for in-memory routing
682
- - Use `spring-rabbitmq` component for RabbitMQ integration
683
- - Implement async publishing with `ProducerTemplate.asyncSendBody()`
684
-
685
- ### Logging
686
- - Use Logback with Logstash encoder for structured logging
687
- - Propagate LogContext through service calls with `SafeAutoCloseable`
688
- - Add contextual information to LogContext for request tracing
689
- - Use `@Slf4j` instead of manual logger instantiation
690
-
691
- ### Async Operations
692
- - Use CompletableFuture for non-blocking I/O operations
693
- - Call `.join()` when you need to wait for completion
694
- - Handle exceptions from CompletableFuture properly
695
- - Pass LogContext to async operations for tracing
696
-
697
- ### Configuration
698
- - Use YAML configuration (`quarkus-config-yaml`)
699
- - Profile-aware configuration for dev/test/prod environments
700
- - Externalize sensitive configuration to environment variables
701
- - Use `@ConfigProperty` for type-safe config injection
702
-
703
- ### Validation
704
- - Validate at resource layer with `@Valid`
705
- - Use Bean Validation annotations on DTOs
706
- - Map exceptions to proper HTTP responses with `@Provider`
707
-
708
- ### Transactions
709
- - Use `@Transactional` on service methods that modify data
710
- - Keep transactions short and focused
711
- - Avoid calling async operations within transactions
712
-
713
- ### Testing
714
- - Use `camel-quarkus-junit5` for route testing
715
- - Use AssertJ for assertions
716
- - Mock all external dependencies
717
- - Test conditional flow logic thoroughly
718
-
719
- ### Quarkus-Specific
720
- - Stay on latest LTS version (3.x)
721
- - Use Quarkus dev mode for hot reload
722
- - Add health checks for production readiness
723
- - Test native compilation compatibility periodically