@rubix0270/arboris 1.0.0

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