arboris-cli 1.0.0 → 1.1.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (451) hide show
  1. package/dist/cli.mjs +420 -0
  2. package/manifest.json +602 -0
  3. package/package.json +22 -10
  4. package/prisma/skills/accessibility/SKILL.md +147 -0
  5. package/prisma/skills/agent-architecture-audit/SKILL.md +257 -0
  6. package/prisma/skills/agent-eval/SKILL.md +146 -0
  7. package/prisma/skills/agent-harness-construction/SKILL.md +74 -0
  8. package/prisma/skills/agent-introspection-debugging/SKILL.md +154 -0
  9. package/prisma/skills/agent-payment-x402/SKILL.md +225 -0
  10. package/prisma/skills/agent-self-evaluation/SKILL.md +182 -0
  11. package/prisma/skills/agent-self-evaluation/examples/high-score-example.md +87 -0
  12. package/prisma/skills/agent-self-evaluation/examples/low-score-example.md +86 -0
  13. package/prisma/skills/agent-self-evaluation/references/evaluation-criteria.md +71 -0
  14. package/prisma/skills/agent-self-evaluation/references/hook-integration.md +64 -0
  15. package/prisma/skills/agent-self-evaluation/scripts/evaluate.py +408 -0
  16. package/prisma/skills/agent-self-evaluation/templates/evaluation-report.md +86 -0
  17. package/prisma/skills/agent-sort/SKILL.md +216 -0
  18. package/prisma/skills/agentic-engineering/SKILL.md +64 -0
  19. package/prisma/skills/agentic-os/SKILL.md +388 -0
  20. package/prisma/skills/ai-first-engineering/SKILL.md +52 -0
  21. package/prisma/skills/ai-regression-testing/SKILL.md +386 -0
  22. package/prisma/skills/android-clean-architecture/SKILL.md +340 -0
  23. package/prisma/skills/angular-developer/SKILL.md +155 -0
  24. package/prisma/skills/angular-developer/references/angular-animations.md +160 -0
  25. package/prisma/skills/angular-developer/references/angular-aria.md +410 -0
  26. package/prisma/skills/angular-developer/references/cli.md +86 -0
  27. package/prisma/skills/angular-developer/references/component-harnesses.md +59 -0
  28. package/prisma/skills/angular-developer/references/component-styling.md +91 -0
  29. package/prisma/skills/angular-developer/references/components.md +117 -0
  30. package/prisma/skills/angular-developer/references/creating-services.md +97 -0
  31. package/prisma/skills/angular-developer/references/data-resolvers.md +69 -0
  32. package/prisma/skills/angular-developer/references/define-routes.md +67 -0
  33. package/prisma/skills/angular-developer/references/defining-providers.md +72 -0
  34. package/prisma/skills/angular-developer/references/di-fundamentals.md +120 -0
  35. package/prisma/skills/angular-developer/references/e2e-testing.md +56 -0
  36. package/prisma/skills/angular-developer/references/effects.md +83 -0
  37. package/prisma/skills/angular-developer/references/hierarchical-injectors.md +43 -0
  38. package/prisma/skills/angular-developer/references/host-elements.md +80 -0
  39. package/prisma/skills/angular-developer/references/injection-context.md +63 -0
  40. package/prisma/skills/angular-developer/references/inputs.md +101 -0
  41. package/prisma/skills/angular-developer/references/linked-signal.md +59 -0
  42. package/prisma/skills/angular-developer/references/loading-strategies.md +61 -0
  43. package/prisma/skills/angular-developer/references/mcp.md +108 -0
  44. package/prisma/skills/angular-developer/references/navigate-to-routes.md +69 -0
  45. package/prisma/skills/angular-developer/references/outputs.md +86 -0
  46. package/prisma/skills/angular-developer/references/reactive-forms.md +122 -0
  47. package/prisma/skills/angular-developer/references/rendering-strategies.md +44 -0
  48. package/prisma/skills/angular-developer/references/resource.md +77 -0
  49. package/prisma/skills/angular-developer/references/route-animations.md +56 -0
  50. package/prisma/skills/angular-developer/references/route-guards.md +52 -0
  51. package/prisma/skills/angular-developer/references/router-lifecycle.md +45 -0
  52. package/prisma/skills/angular-developer/references/router-testing.md +87 -0
  53. package/prisma/skills/angular-developer/references/show-routes-with-outlets.md +68 -0
  54. package/prisma/skills/angular-developer/references/signal-forms.md +795 -0
  55. package/prisma/skills/angular-developer/references/signals-overview.md +94 -0
  56. package/prisma/skills/angular-developer/references/tailwind-css.md +69 -0
  57. package/prisma/skills/angular-developer/references/template-driven-forms.md +114 -0
  58. package/prisma/skills/angular-developer/references/testing-fundamentals.md +65 -0
  59. package/prisma/skills/api-connector-builder/SKILL.md +121 -0
  60. package/prisma/skills/api-design/SKILL.md +524 -0
  61. package/prisma/skills/architecture-decision-records/SKILL.md +180 -0
  62. package/prisma/skills/article-writing/SKILL.md +80 -0
  63. package/prisma/skills/automation-audit-ops/SKILL.md +143 -0
  64. package/prisma/skills/autonomous-agent-harness/SKILL.md +274 -0
  65. package/prisma/skills/autonomous-loops/SKILL.md +611 -0
  66. package/prisma/skills/backend-patterns/SKILL.md +562 -0
  67. package/prisma/skills/benchmark/SKILL.md +94 -0
  68. package/prisma/skills/benchmark-methodology/SKILL.md +190 -0
  69. package/prisma/skills/benchmark-optimization-loop/SKILL.md +70 -0
  70. package/prisma/skills/blender-motion-state-inspection/SKILL.md +165 -0
  71. package/prisma/skills/blueprint/SKILL.md +106 -0
  72. package/prisma/skills/brand-discovery/SKILL.md +145 -0
  73. package/prisma/skills/brand-discovery/references/10_purpose-why.md +40 -0
  74. package/prisma/skills/brand-discovery/references/20_positioning.md +44 -0
  75. package/prisma/skills/brand-discovery/references/30_audience-niche.md +52 -0
  76. package/prisma/skills/brand-discovery/references/40_personality-archetype.md +57 -0
  77. package/prisma/skills/brand-discovery/references/50_voice-tone.md +59 -0
  78. package/prisma/skills/brand-discovery/references/60_narrative-story.md +50 -0
  79. package/prisma/skills/brand-discovery/references/70_founder-tension.md +49 -0
  80. package/prisma/skills/brand-discovery/references/90_SYNTHESIS.md +133 -0
  81. package/prisma/skills/brand-voice/SKILL.md +98 -0
  82. package/prisma/skills/brand-voice/references/voice-profile-schema.md +55 -0
  83. package/prisma/skills/browser-qa/SKILL.md +105 -0
  84. package/prisma/skills/bun-runtime/SKILL.md +85 -0
  85. package/prisma/skills/canary-watch/SKILL.md +108 -0
  86. package/prisma/skills/carrier-relationship-management/SKILL.md +212 -0
  87. package/prisma/skills/cisco-ios-patterns/SKILL.md +164 -0
  88. package/prisma/skills/ck/SKILL.md +148 -0
  89. package/prisma/skills/ck/commands/forget.mjs +44 -0
  90. package/prisma/skills/ck/commands/info.mjs +24 -0
  91. package/prisma/skills/ck/commands/init.mjs +143 -0
  92. package/prisma/skills/ck/commands/list.mjs +40 -0
  93. package/prisma/skills/ck/commands/migrate.mjs +202 -0
  94. package/prisma/skills/ck/commands/resume.mjs +36 -0
  95. package/prisma/skills/ck/commands/save.mjs +210 -0
  96. package/prisma/skills/ck/commands/shared.mjs +387 -0
  97. package/prisma/skills/ck/hooks/session-start.mjs +224 -0
  98. package/prisma/skills/claude-devfleet/SKILL.md +112 -0
  99. package/prisma/skills/click-path-audit/SKILL.md +245 -0
  100. package/prisma/skills/clickhouse-io/SKILL.md +440 -0
  101. package/prisma/skills/code-tour/SKILL.md +254 -0
  102. package/prisma/skills/codebase-onboarding/SKILL.md +234 -0
  103. package/prisma/skills/codehealth-mcp/SKILL.md +167 -0
  104. package/prisma/skills/coding-standards/SKILL.md +551 -0
  105. package/prisma/skills/competitive-platform-analysis/SKILL.md +214 -0
  106. package/prisma/skills/competitive-report-structure/SKILL.md +162 -0
  107. package/prisma/skills/compose-multiplatform-patterns/SKILL.md +300 -0
  108. package/prisma/skills/config-gc/SKILL.md +120 -0
  109. package/prisma/skills/configure-ecc/SKILL.md +385 -0
  110. package/prisma/skills/connections-optimizer/SKILL.md +190 -0
  111. package/prisma/skills/content-engine/SKILL.md +132 -0
  112. package/prisma/skills/content-hash-cache-pattern/SKILL.md +162 -0
  113. package/prisma/skills/context-budget/SKILL.md +136 -0
  114. package/prisma/skills/continuous-agent-loop/SKILL.md +46 -0
  115. package/prisma/skills/continuous-learning/SKILL.md +132 -0
  116. package/prisma/skills/continuous-learning/config.json +18 -0
  117. package/prisma/skills/continuous-learning/evaluate-session.sh +69 -0
  118. package/prisma/skills/continuous-learning-v2/SKILL.md +361 -0
  119. package/prisma/skills/continuous-learning-v2/agents/observer-loop.sh +359 -0
  120. package/prisma/skills/continuous-learning-v2/agents/observer.md +189 -0
  121. package/prisma/skills/continuous-learning-v2/agents/session-guardian.sh +150 -0
  122. package/prisma/skills/continuous-learning-v2/agents/start-observer.sh +248 -0
  123. package/prisma/skills/continuous-learning-v2/config.json +8 -0
  124. package/prisma/skills/continuous-learning-v2/hooks/observe.sh +585 -0
  125. package/prisma/skills/continuous-learning-v2/scripts/detect-project.sh +322 -0
  126. package/prisma/skills/continuous-learning-v2/scripts/instinct-cli.py +1956 -0
  127. package/prisma/skills/continuous-learning-v2/scripts/lib/homunculus-dir.sh +31 -0
  128. package/prisma/skills/continuous-learning-v2/scripts/migrate-homunculus.sh +68 -0
  129. package/prisma/skills/continuous-learning-v2/scripts/test_parse_instinct.py +1421 -0
  130. package/prisma/skills/cost-aware-llm-pipeline/SKILL.md +184 -0
  131. package/prisma/skills/cost-tracking/SKILL.md +97 -0
  132. package/prisma/skills/council/SKILL.md +204 -0
  133. package/prisma/skills/cpp-coding-standards/SKILL.md +724 -0
  134. package/prisma/skills/cpp-testing/SKILL.md +325 -0
  135. package/prisma/skills/crosspost/SKILL.md +112 -0
  136. package/prisma/skills/csharp-testing/SKILL.md +322 -0
  137. package/prisma/skills/customer-billing-ops/SKILL.md +141 -0
  138. package/prisma/skills/customs-trade-compliance/SKILL.md +263 -0
  139. package/prisma/skills/dart-flutter-patterns/SKILL.md +564 -0
  140. package/prisma/skills/dashboard-builder/SKILL.md +109 -0
  141. package/prisma/skills/data-scraper-agent/SKILL.md +765 -0
  142. package/prisma/skills/data-throughput-accelerator/SKILL.md +73 -0
  143. package/prisma/skills/database-migrations/SKILL.md +430 -0
  144. package/prisma/skills/deep-research/SKILL.md +160 -0
  145. package/prisma/skills/defi-amm-security/SKILL.md +167 -0
  146. package/prisma/skills/delivery-gate/SKILL.md +126 -0
  147. package/prisma/skills/delivery-gate/hooks/quality-gate.py +220 -0
  148. package/prisma/skills/deployment-patterns/SKILL.md +428 -0
  149. package/prisma/skills/design-system/SKILL.md +83 -0
  150. package/prisma/skills/django-celery/SKILL.md +458 -0
  151. package/prisma/skills/django-patterns/SKILL.md +735 -0
  152. package/prisma/skills/django-security/SKILL.md +644 -0
  153. package/prisma/skills/django-tdd/SKILL.md +730 -0
  154. package/prisma/skills/django-verification/SKILL.md +470 -0
  155. package/prisma/skills/dmux-workflows/SKILL.md +192 -0
  156. package/prisma/skills/docker-patterns/SKILL.md +365 -0
  157. package/prisma/skills/documentation-lookup/SKILL.md +91 -0
  158. package/prisma/skills/dotnet-patterns/SKILL.md +322 -0
  159. package/prisma/skills/dynamic-workflow-mode/SKILL.md +124 -0
  160. package/prisma/skills/e2e-testing/SKILL.md +327 -0
  161. package/prisma/skills/ecc-guide/SKILL.md +190 -0
  162. package/prisma/skills/ecc-recipes/SKILL.md +149 -0
  163. package/prisma/skills/ecc-tools-cost-audit/SKILL.md +161 -0
  164. package/prisma/skills/email-ops/SKILL.md +122 -0
  165. package/prisma/skills/energy-procurement/SKILL.md +228 -0
  166. package/prisma/skills/enterprise-agent-ops/SKILL.md +51 -0
  167. package/prisma/skills/error-handling/SKILL.md +377 -0
  168. package/prisma/skills/eval-harness/SKILL.md +271 -0
  169. package/prisma/skills/evm-token-decimals/SKILL.md +131 -0
  170. package/prisma/skills/exa-search/SKILL.md +108 -0
  171. package/prisma/skills/fal-ai-media/SKILL.md +289 -0
  172. package/prisma/skills/fastapi-patterns/SKILL.md +514 -0
  173. package/prisma/skills/finance-billing-ops/SKILL.md +128 -0
  174. package/prisma/skills/flox-environments/SKILL.md +497 -0
  175. package/prisma/skills/flutter-dart-code-review/SKILL.md +436 -0
  176. package/prisma/skills/foundation-models-on-device/SKILL.md +243 -0
  177. package/prisma/skills/frontend-a11y/SKILL.md +446 -0
  178. package/prisma/skills/frontend-design-direction/SKILL.md +93 -0
  179. package/prisma/skills/frontend-patterns/SKILL.md +657 -0
  180. package/prisma/skills/frontend-slides/SKILL.md +185 -0
  181. package/prisma/skills/frontend-slides/STYLE_PRESETS.md +330 -0
  182. package/prisma/skills/frontend-slides/animation-patterns.md +122 -0
  183. package/prisma/skills/frontend-slides/html-template.md +419 -0
  184. package/prisma/skills/frontend-slides/scripts/export-pdf.sh +418 -0
  185. package/prisma/skills/frontend-slides/scripts/extract-pptx.py +96 -0
  186. package/prisma/skills/frontend-slides/viewport-base.css +153 -0
  187. package/prisma/skills/fsharp-testing/SKILL.md +281 -0
  188. package/prisma/skills/gan-style-harness/SKILL.md +279 -0
  189. package/prisma/skills/gateguard/SKILL.md +133 -0
  190. package/prisma/skills/generating-python-installer/SKILL.md +820 -0
  191. package/prisma/skills/git-workflow/SKILL.md +716 -0
  192. package/prisma/skills/github-ops/SKILL.md +145 -0
  193. package/prisma/skills/golang-patterns/SKILL.md +675 -0
  194. package/prisma/skills/golang-testing/SKILL.md +721 -0
  195. package/prisma/skills/google-workspace-ops/SKILL.md +96 -0
  196. package/prisma/skills/growth-log/SKILL.md +128 -0
  197. package/prisma/skills/healthcare-cdss-patterns/SKILL.md +246 -0
  198. package/prisma/skills/healthcare-emr-patterns/SKILL.md +160 -0
  199. package/prisma/skills/healthcare-eval-harness/SKILL.md +208 -0
  200. package/prisma/skills/healthcare-phi-compliance/SKILL.md +146 -0
  201. package/prisma/skills/hermes-imports/SKILL.md +89 -0
  202. package/prisma/skills/hexagonal-architecture/SKILL.md +277 -0
  203. package/prisma/skills/hipaa-compliance/SKILL.md +79 -0
  204. package/prisma/skills/homelab-network-readiness/SKILL.md +170 -0
  205. package/prisma/skills/homelab-network-setup/SKILL.md +130 -0
  206. package/prisma/skills/homelab-pihole-dns/SKILL.md +275 -0
  207. package/prisma/skills/homelab-vlan-segmentation/SKILL.md +312 -0
  208. package/prisma/skills/homelab-wireguard-vpn/SKILL.md +306 -0
  209. package/prisma/skills/hookify-rules/SKILL.md +128 -0
  210. package/prisma/skills/inherit-legacy-style/SKILL.md +157 -0
  211. package/prisma/skills/intent-driven-development/SKILL.md +360 -0
  212. package/prisma/skills/inventory-demand-planning/SKILL.md +247 -0
  213. package/prisma/skills/investor-materials/SKILL.md +97 -0
  214. package/prisma/skills/investor-outreach/SKILL.md +92 -0
  215. package/prisma/skills/ios-icon-gen/SKILL.md +158 -0
  216. package/prisma/skills/ios-icon-gen/scripts/generate_icons.swift +258 -0
  217. package/prisma/skills/ios-icon-gen/scripts/iconify_gen.sh +235 -0
  218. package/prisma/skills/iterative-retrieval/SKILL.md +212 -0
  219. package/prisma/skills/ito-basket-compare/SKILL.md +64 -0
  220. package/prisma/skills/ito-data-atlas-agent/SKILL.md +64 -0
  221. package/prisma/skills/ito-market-intelligence/SKILL.md +61 -0
  222. package/prisma/skills/ito-trade-planner/SKILL.md +68 -0
  223. package/prisma/skills/java-coding-standards/SKILL.md +384 -0
  224. package/prisma/skills/jira-integration/SKILL.md +303 -0
  225. package/prisma/skills/jpa-patterns/SKILL.md +152 -0
  226. package/prisma/skills/knowledge-ops/SKILL.md +155 -0
  227. package/prisma/skills/kotlin-coroutines-flows/SKILL.md +285 -0
  228. package/prisma/skills/kotlin-exposed-patterns/SKILL.md +720 -0
  229. package/prisma/skills/kotlin-ktor-patterns/SKILL.md +690 -0
  230. package/prisma/skills/kotlin-patterns/SKILL.md +712 -0
  231. package/prisma/skills/kotlin-testing/SKILL.md +825 -0
  232. package/prisma/skills/kubernetes-patterns/SKILL.md +756 -0
  233. package/prisma/skills/laravel-patterns/SKILL.md +416 -0
  234. package/prisma/skills/laravel-plugin-discovery/SKILL.md +230 -0
  235. package/prisma/skills/laravel-security/SKILL.md +948 -0
  236. package/prisma/skills/laravel-tdd/SKILL.md +675 -0
  237. package/prisma/skills/laravel-verification/SKILL.md +180 -0
  238. package/prisma/skills/latency-critical-systems/SKILL.md +74 -0
  239. package/prisma/skills/lead-intelligence/SKILL.md +322 -0
  240. package/prisma/skills/lead-intelligence/agents/enrichment-agent.md +85 -0
  241. package/prisma/skills/lead-intelligence/agents/mutual-mapper.md +75 -0
  242. package/prisma/skills/lead-intelligence/agents/outreach-drafter.md +98 -0
  243. package/prisma/skills/lead-intelligence/agents/signal-scorer.md +60 -0
  244. package/prisma/skills/liquid-glass-design/SKILL.md +279 -0
  245. package/prisma/skills/llm-trading-agent-security/SKILL.md +147 -0
  246. package/prisma/skills/logistics-exception-management/SKILL.md +222 -0
  247. package/prisma/skills/loop-design-check/SKILL.md +143 -0
  248. package/prisma/skills/mailtrap-email-integration/SKILL.md +77 -0
  249. package/prisma/skills/make-interfaces-feel-better/SKILL.md +152 -0
  250. package/prisma/skills/manim-video/SKILL.md +90 -0
  251. package/prisma/skills/manim-video/assets/network_graph_scene.py +52 -0
  252. package/prisma/skills/market-research/SKILL.md +76 -0
  253. package/prisma/skills/marketing-campaign/SKILL.md +114 -0
  254. package/prisma/skills/mcp-server-patterns/SKILL.md +70 -0
  255. package/prisma/skills/messages-ops/SKILL.md +105 -0
  256. package/prisma/skills/ml-adoption-playbook/SKILL.md +57 -0
  257. package/prisma/skills/mle-workflow/SKILL.md +347 -0
  258. package/prisma/skills/motion-advanced/SKILL.md +596 -0
  259. package/prisma/skills/motion-foundations/SKILL.md +299 -0
  260. package/prisma/skills/motion-patterns/SKILL.md +434 -0
  261. package/prisma/skills/motion-ui/SKILL.md +576 -0
  262. package/prisma/skills/mysql-patterns/SKILL.md +413 -0
  263. package/prisma/skills/nanoclaw-repl/SKILL.md +34 -0
  264. package/prisma/skills/nestjs-patterns/SKILL.md +231 -0
  265. package/prisma/skills/netmiko-ssh-automation/SKILL.md +174 -0
  266. package/prisma/skills/network-bgp-diagnostics/SKILL.md +168 -0
  267. package/prisma/skills/network-config-validation/SKILL.md +211 -0
  268. package/prisma/skills/network-interface-health/SKILL.md +153 -0
  269. package/prisma/skills/nextjs-turbopack/SKILL.md +58 -0
  270. package/prisma/skills/nodejs-keccak256/SKILL.md +103 -0
  271. package/prisma/skills/nutrient-document-processing/SKILL.md +168 -0
  272. package/prisma/skills/nuxt4-patterns/SKILL.md +101 -0
  273. package/prisma/skills/openclaw-persona-forge/SKILL.md +289 -0
  274. package/prisma/skills/openclaw-persona-forge/gacha.py +224 -0
  275. package/prisma/skills/openclaw-persona-forge/gacha.sh +5 -0
  276. package/prisma/skills/openclaw-persona-forge/references/avatar-style.md +124 -0
  277. package/prisma/skills/openclaw-persona-forge/references/boundary-rules.md +53 -0
  278. package/prisma/skills/openclaw-persona-forge/references/error-handling.md +53 -0
  279. package/prisma/skills/openclaw-persona-forge/references/identity-tension.md +48 -0
  280. package/prisma/skills/openclaw-persona-forge/references/naming-system.md +39 -0
  281. package/prisma/skills/openclaw-persona-forge/references/output-template.md +166 -0
  282. package/prisma/skills/opensource-pipeline/SKILL.md +256 -0
  283. package/prisma/skills/orch-add-feature/SKILL.md +45 -0
  284. package/prisma/skills/orch-build-mvp/SKILL.md +49 -0
  285. package/prisma/skills/orch-change-feature/SKILL.md +43 -0
  286. package/prisma/skills/orch-fix-defect/SKILL.md +43 -0
  287. package/prisma/skills/orch-pipeline/SKILL.md +121 -0
  288. package/prisma/skills/orch-refine-code/SKILL.md +44 -0
  289. package/prisma/skills/parallel-execution-optimizer/SKILL.md +73 -0
  290. package/prisma/skills/perl-patterns/SKILL.md +505 -0
  291. package/prisma/skills/perl-security/SKILL.md +504 -0
  292. package/prisma/skills/perl-testing/SKILL.md +476 -0
  293. package/prisma/skills/plan-orchestrate/SKILL.md +263 -0
  294. package/prisma/skills/plankton-code-quality/SKILL.md +237 -0
  295. package/prisma/skills/postgres-patterns/SKILL.md +148 -0
  296. package/prisma/skills/prediction-market-oracle-research/SKILL.md +64 -0
  297. package/prisma/skills/prediction-market-risk-review/SKILL.md +61 -0
  298. package/prisma/skills/prisma-patterns/SKILL.md +401 -0
  299. package/prisma/skills/product-capability/SKILL.md +142 -0
  300. package/prisma/skills/product-lens/SKILL.md +93 -0
  301. package/prisma/skills/production-audit/SKILL.md +207 -0
  302. package/prisma/skills/production-scheduling/SKILL.md +238 -0
  303. package/prisma/skills/project-flow-ops/SKILL.md +112 -0
  304. package/prisma/skills/prompt-optimizer/SKILL.md +398 -0
  305. package/prisma/skills/python-patterns/SKILL.md +751 -0
  306. package/prisma/skills/python-testing/SKILL.md +817 -0
  307. package/prisma/skills/pytorch-patterns/SKILL.md +397 -0
  308. package/prisma/skills/quality-nonconformance/SKILL.md +260 -0
  309. package/prisma/skills/quarkus-patterns/SKILL.md +723 -0
  310. package/prisma/skills/quarkus-security/SKILL.md +468 -0
  311. package/prisma/skills/quarkus-tdd/SKILL.md +812 -0
  312. package/prisma/skills/quarkus-verification/SKILL.md +480 -0
  313. package/prisma/skills/ralphinho-rfc-pipeline/SKILL.md +68 -0
  314. package/prisma/skills/react-native-patterns/SKILL.md +326 -0
  315. package/prisma/skills/react-patterns/SKILL.md +342 -0
  316. package/prisma/skills/react-performance/SKILL.md +575 -0
  317. package/prisma/skills/react-testing/SKILL.md +424 -0
  318. package/prisma/skills/recsys-pipeline-architect/SKILL.md +115 -0
  319. package/prisma/skills/recursive-decision-ledger/SKILL.md +80 -0
  320. package/prisma/skills/redis-patterns/SKILL.md +404 -0
  321. package/prisma/skills/regex-vs-llm-structured-text/SKILL.md +221 -0
  322. package/prisma/skills/remotion-video-creation/SKILL.md +43 -0
  323. package/prisma/skills/remotion-video-creation/rules/3d.md +86 -0
  324. package/prisma/skills/remotion-video-creation/rules/animations.md +29 -0
  325. package/prisma/skills/remotion-video-creation/rules/assets/charts-bar-chart.tsx +173 -0
  326. package/prisma/skills/remotion-video-creation/rules/assets/text-animations-typewriter.tsx +100 -0
  327. package/prisma/skills/remotion-video-creation/rules/assets/text-animations-word-highlight.tsx +108 -0
  328. package/prisma/skills/remotion-video-creation/rules/assets.md +78 -0
  329. package/prisma/skills/remotion-video-creation/rules/audio.md +172 -0
  330. package/prisma/skills/remotion-video-creation/rules/calculate-metadata.md +104 -0
  331. package/prisma/skills/remotion-video-creation/rules/can-decode.md +75 -0
  332. package/prisma/skills/remotion-video-creation/rules/charts.md +58 -0
  333. package/prisma/skills/remotion-video-creation/rules/compositions.md +146 -0
  334. package/prisma/skills/remotion-video-creation/rules/display-captions.md +126 -0
  335. package/prisma/skills/remotion-video-creation/rules/extract-frames.md +229 -0
  336. package/prisma/skills/remotion-video-creation/rules/fonts.md +152 -0
  337. package/prisma/skills/remotion-video-creation/rules/get-audio-duration.md +58 -0
  338. package/prisma/skills/remotion-video-creation/rules/get-video-dimensions.md +68 -0
  339. package/prisma/skills/remotion-video-creation/rules/get-video-duration.md +58 -0
  340. package/prisma/skills/remotion-video-creation/rules/gifs.md +138 -0
  341. package/prisma/skills/remotion-video-creation/rules/images.md +130 -0
  342. package/prisma/skills/remotion-video-creation/rules/import-srt-captions.md +67 -0
  343. package/prisma/skills/remotion-video-creation/rules/lottie.md +67 -0
  344. package/prisma/skills/remotion-video-creation/rules/measuring-dom-nodes.md +34 -0
  345. package/prisma/skills/remotion-video-creation/rules/measuring-text.md +143 -0
  346. package/prisma/skills/remotion-video-creation/rules/sequencing.md +106 -0
  347. package/prisma/skills/remotion-video-creation/rules/tailwind.md +11 -0
  348. package/prisma/skills/remotion-video-creation/rules/text-animations.md +20 -0
  349. package/prisma/skills/remotion-video-creation/rules/timing.md +179 -0
  350. package/prisma/skills/remotion-video-creation/rules/transcribe-captions.md +19 -0
  351. package/prisma/skills/remotion-video-creation/rules/transitions.md +122 -0
  352. package/prisma/skills/remotion-video-creation/rules/trimming.md +52 -0
  353. package/prisma/skills/remotion-video-creation/rules/videos.md +171 -0
  354. package/prisma/skills/repo-scan/SKILL.md +79 -0
  355. package/prisma/skills/research-ops/SKILL.md +113 -0
  356. package/prisma/skills/returns-reverse-logistics/SKILL.md +240 -0
  357. package/prisma/skills/rules-distill/SKILL.md +265 -0
  358. package/prisma/skills/rules-distill/scripts/scan-rules.sh +58 -0
  359. package/prisma/skills/rules-distill/scripts/scan-skills.sh +129 -0
  360. package/prisma/skills/rust-patterns/SKILL.md +500 -0
  361. package/prisma/skills/rust-testing/SKILL.md +501 -0
  362. package/prisma/skills/safety-guard/SKILL.md +76 -0
  363. package/prisma/skills/santa-method/SKILL.md +307 -0
  364. package/prisma/skills/scientific-db-pubmed-database/SKILL.md +176 -0
  365. package/prisma/skills/scientific-db-uspto-database/SKILL.md +178 -0
  366. package/prisma/skills/scientific-pkg-gget/SKILL.md +167 -0
  367. package/prisma/skills/scientific-thinking-literature-review/SKILL.md +193 -0
  368. package/prisma/skills/scientific-thinking-scholar-evaluation/SKILL.md +161 -0
  369. package/prisma/skills/search-first/SKILL.md +183 -0
  370. package/prisma/skills/security-bounty-hunter/SKILL.md +100 -0
  371. package/prisma/skills/security-review/SKILL.md +504 -0
  372. package/prisma/skills/security-review/cloud-infrastructure-security.md +361 -0
  373. package/prisma/skills/security-scan/SKILL.md +166 -0
  374. package/prisma/skills/seo/SKILL.md +155 -0
  375. package/prisma/skills/skill-comply/SKILL.md +59 -0
  376. package/prisma/skills/skill-comply/fixtures/compliant_trace.jsonl +5 -0
  377. package/prisma/skills/skill-comply/fixtures/noncompliant_trace.jsonl +3 -0
  378. package/prisma/skills/skill-comply/fixtures/tdd_spec.yaml +44 -0
  379. package/prisma/skills/skill-comply/prompts/classifier.md +24 -0
  380. package/prisma/skills/skill-comply/prompts/scenario_generator.md +62 -0
  381. package/prisma/skills/skill-comply/prompts/spec_generator.md +42 -0
  382. package/prisma/skills/skill-comply/pyproject.toml +15 -0
  383. package/prisma/skills/skill-comply/scripts/__init__.py +0 -0
  384. package/prisma/skills/skill-comply/scripts/classifier.py +85 -0
  385. package/prisma/skills/skill-comply/scripts/grader.py +124 -0
  386. package/prisma/skills/skill-comply/scripts/parser.py +107 -0
  387. package/prisma/skills/skill-comply/scripts/report.py +170 -0
  388. package/prisma/skills/skill-comply/scripts/run.py +127 -0
  389. package/prisma/skills/skill-comply/scripts/runner.py +194 -0
  390. package/prisma/skills/skill-comply/scripts/scenario_generator.py +70 -0
  391. package/prisma/skills/skill-comply/scripts/spec_generator.py +72 -0
  392. package/prisma/skills/skill-comply/scripts/utils.py +13 -0
  393. package/prisma/skills/skill-comply/tests/test_grader.py +197 -0
  394. package/prisma/skills/skill-comply/tests/test_parser.py +90 -0
  395. package/prisma/skills/skill-comply/tests/test_runner.py +172 -0
  396. package/prisma/skills/skill-scout/SKILL.md +141 -0
  397. package/prisma/skills/skill-stocktake/SKILL.md +195 -0
  398. package/prisma/skills/skill-stocktake/scripts/quick-diff.sh +87 -0
  399. package/prisma/skills/skill-stocktake/scripts/save-results.sh +56 -0
  400. package/prisma/skills/skill-stocktake/scripts/scan.sh +170 -0
  401. package/prisma/skills/social-graph-ranker/SKILL.md +155 -0
  402. package/prisma/skills/social-publisher/SKILL.md +130 -0
  403. package/prisma/skills/springboot-patterns/SKILL.md +315 -0
  404. package/prisma/skills/springboot-security/SKILL.md +273 -0
  405. package/prisma/skills/springboot-tdd/SKILL.md +159 -0
  406. package/prisma/skills/springboot-verification/SKILL.md +232 -0
  407. package/prisma/skills/strategic-compact/SKILL.md +136 -0
  408. package/prisma/skills/swift-actor-persistence/SKILL.md +144 -0
  409. package/prisma/skills/swift-concurrency-6-2/SKILL.md +216 -0
  410. package/prisma/skills/swift-protocol-di-testing/SKILL.md +191 -0
  411. package/prisma/skills/swiftui-patterns/SKILL.md +259 -0
  412. package/prisma/skills/taste/SKILL.md +264 -0
  413. package/prisma/skills/taste/references/genre-taxonomy.md +87 -0
  414. package/prisma/skills/tdd-workflow/SKILL.md +583 -0
  415. package/prisma/skills/team-agent-orchestration/SKILL.md +111 -0
  416. package/prisma/skills/team-builder/SKILL.md +169 -0
  417. package/prisma/skills/terminal-ops/SKILL.md +110 -0
  418. package/prisma/skills/tinystruct-patterns/SKILL.md +279 -0
  419. package/prisma/skills/tinystruct-patterns/references/architecture.md +90 -0
  420. package/prisma/skills/tinystruct-patterns/references/data-handling.md +60 -0
  421. package/prisma/skills/tinystruct-patterns/references/database.md +99 -0
  422. package/prisma/skills/tinystruct-patterns/references/routing.md +64 -0
  423. package/prisma/skills/tinystruct-patterns/references/system-usage.md +97 -0
  424. package/prisma/skills/tinystruct-patterns/references/testing.md +72 -0
  425. package/prisma/skills/token-budget-advisor/SKILL.md +134 -0
  426. package/prisma/skills/ui-demo/SKILL.md +466 -0
  427. package/prisma/skills/ui-to-vue/SKILL.md +135 -0
  428. package/prisma/skills/uncloud/SKILL.md +344 -0
  429. package/prisma/skills/unified-notifications-ops/SKILL.md +188 -0
  430. package/prisma/skills/verification-loop/SKILL.md +127 -0
  431. package/prisma/skills/video-editing/SKILL.md +311 -0
  432. package/prisma/skills/videodb/SKILL.md +375 -0
  433. package/prisma/skills/videodb/reference/api-reference.md +550 -0
  434. package/prisma/skills/videodb/reference/capture-reference.md +407 -0
  435. package/prisma/skills/videodb/reference/capture.md +101 -0
  436. package/prisma/skills/videodb/reference/editor.md +443 -0
  437. package/prisma/skills/videodb/reference/generative.md +331 -0
  438. package/prisma/skills/videodb/reference/rtstream-reference.md +564 -0
  439. package/prisma/skills/videodb/reference/rtstream.md +65 -0
  440. package/prisma/skills/videodb/reference/search.md +230 -0
  441. package/prisma/skills/videodb/reference/streaming.md +406 -0
  442. package/prisma/skills/videodb/reference/use-cases.md +118 -0
  443. package/prisma/skills/videodb/scripts/ws_listener.py +282 -0
  444. package/prisma/skills/visa-doc-translate/README.md +86 -0
  445. package/prisma/skills/visa-doc-translate/SKILL.md +117 -0
  446. package/prisma/skills/vite-patterns/SKILL.md +450 -0
  447. package/prisma/skills/vue-patterns/SKILL.md +471 -0
  448. package/prisma/skills/windows-desktop-e2e/SKILL.md +888 -0
  449. package/prisma/skills/workspace-surface-audit/SKILL.md +126 -0
  450. package/prisma/skills/x-api/SKILL.md +235 -0
  451. package/run.mjs +0 -10
@@ -0,0 +1,303 @@
1
+ ---
2
+ name: jira-integration
3
+ description: Use this skill when retrieving Jira tickets, analyzing requirements, updating ticket status, adding comments, or transitioning issues. Provides Jira API patterns via MCP or direct REST calls.
4
+ metadata:
5
+ origin: ECC
6
+ ---
7
+
8
+ # Jira Integration Skill
9
+
10
+ Retrieve, analyze, and update Jira tickets directly from your AI coding workflow. Supports both **MCP-based** (recommended) and **direct REST API** approaches.
11
+
12
+ ## When to Activate
13
+
14
+ - Fetching a Jira ticket to understand requirements
15
+ - Extracting testable acceptance criteria from a ticket
16
+ - Adding progress comments to a Jira issue
17
+ - Transitioning a ticket status (To Do → In Progress → Done)
18
+ - Linking merge requests or branches to a Jira issue
19
+ - Searching for issues by JQL query
20
+
21
+ ## Prerequisites
22
+
23
+ ### Option A: MCP Server (Recommended)
24
+
25
+ Install the `mcp-atlassian` MCP server. This exposes Jira tools directly to your AI agent.
26
+
27
+ **Requirements:**
28
+ - Python 3.10+
29
+ - `uvx` (from `uv`), installed via your package manager or the official `uv` installation documentation
30
+
31
+ **Add to your MCP config** (e.g., `~/.claude.json` → `mcpServers`):
32
+
33
+ ```json
34
+ {
35
+ "jira": {
36
+ "command": "uvx",
37
+ "args": ["mcp-atlassian==0.21.0"],
38
+ "env": {
39
+ "JIRA_URL": "https://YOUR_ORG.atlassian.net",
40
+ "JIRA_EMAIL": "your.email@example.com",
41
+ "JIRA_API_TOKEN": "your-api-token"
42
+ },
43
+ "description": "Jira issue tracking — search, create, update, comment, transition"
44
+ }
45
+ }
46
+ ```
47
+
48
+ > **Security:** Never hardcode secrets. Prefer setting `JIRA_URL`, `JIRA_EMAIL`, and `JIRA_API_TOKEN` in your system environment (or a secrets manager). Only use the MCP `env` block for local, uncommitted config files.
49
+
50
+ **To get a Jira API token:**
51
+ 1. Go to <https://id.atlassian.com/manage-profile/security/api-tokens>
52
+ 2. Click **Create API token**
53
+ 3. Copy the token — store it in your environment, never in source code
54
+
55
+ ### Option B: Direct REST API
56
+
57
+ If MCP is not available, use the Jira REST API v3 directly via `curl` or a helper script.
58
+
59
+ **Required environment variables:**
60
+
61
+ | Variable | Description |
62
+ |----------|-------------|
63
+ | `JIRA_URL` | Your Jira instance URL (e.g., `https://yourorg.atlassian.net`) |
64
+ | `JIRA_EMAIL` | Your Atlassian account email |
65
+ | `JIRA_API_TOKEN` | API token from id.atlassian.com |
66
+
67
+ Store these in your shell environment, secrets manager, or an untracked local env file. Do not commit them to the repo.
68
+
69
+ For direct `curl` examples, keep credentials out of command-line arguments by passing the Jira user config on stdin:
70
+
71
+ ```bash
72
+ jira_curl() {
73
+ printf 'user = "%s:%s"\n' "$JIRA_EMAIL" "$JIRA_API_TOKEN" |
74
+ curl -s -K - "$@"
75
+ }
76
+ ```
77
+
78
+ ## MCP Tools Reference
79
+
80
+ When the `mcp-atlassian` MCP server is configured, these tools are available:
81
+
82
+ | Tool | Purpose | Example |
83
+ |------|---------|---------|
84
+ | `jira_search` | JQL queries | `project = PROJ AND status = "In Progress"` |
85
+ | `jira_get_issue` | Fetch full issue details by key | `PROJ-1234` |
86
+ | `jira_create_issue` | Create issues (Task, Bug, Story, Epic) | New bug report |
87
+ | `jira_update_issue` | Update fields (summary, description, assignee) | Change assignee |
88
+ | `jira_transition_issue` | Change status | Move to "In Review" |
89
+ | `jira_add_comment` | Add comments | Progress update |
90
+ | `jira_get_sprint_issues` | List issues in a sprint | Active sprint review |
91
+ | `jira_create_issue_link` | Link issues (Blocks, Relates to) | Dependency tracking |
92
+ | `jira_get_issue_development_info` | See linked PRs, branches, commits | Dev context |
93
+
94
+ > **Tip:** Always call `jira_get_transitions` before transitioning — transition IDs vary per project workflow.
95
+
96
+ ## Direct REST API Reference
97
+
98
+ ### Fetch a Ticket
99
+
100
+ ```bash
101
+ jira_curl \
102
+ -H "Content-Type: application/json" \
103
+ "$JIRA_URL/rest/api/3/issue/PROJ-1234" | jq '{
104
+ key: .key,
105
+ summary: .fields.summary,
106
+ status: .fields.status.name,
107
+ priority: .fields.priority.name,
108
+ type: .fields.issuetype.name,
109
+ assignee: .fields.assignee.displayName,
110
+ labels: .fields.labels,
111
+ description: .fields.description
112
+ }'
113
+ ```
114
+
115
+ ### Fetch Comments
116
+
117
+ ```bash
118
+ jira_curl \
119
+ -H "Content-Type: application/json" \
120
+ "$JIRA_URL/rest/api/3/issue/PROJ-1234?fields=comment" | jq '.fields.comment.comments[] | {
121
+ author: .author.displayName,
122
+ created: .created[:10],
123
+ body: .body
124
+ }'
125
+ ```
126
+
127
+ ### Add a Comment
128
+
129
+ ```bash
130
+ jira_curl -X POST \
131
+ -H "Content-Type: application/json" \
132
+ -d '{
133
+ "body": {
134
+ "version": 1,
135
+ "type": "doc",
136
+ "content": [{
137
+ "type": "paragraph",
138
+ "content": [{"type": "text", "text": "Your comment here"}]
139
+ }]
140
+ }
141
+ }' \
142
+ "$JIRA_URL/rest/api/3/issue/PROJ-1234/comment"
143
+ ```
144
+
145
+ ### Transition a Ticket
146
+
147
+ ```bash
148
+ # 1. Get available transitions
149
+ jira_curl \
150
+ "$JIRA_URL/rest/api/3/issue/PROJ-1234/transitions" | jq '.transitions[] | {id, name: .name}'
151
+
152
+ # 2. Execute transition (replace TRANSITION_ID)
153
+ jira_curl -X POST \
154
+ -H "Content-Type: application/json" \
155
+ -d '{"transition": {"id": "TRANSITION_ID"}}' \
156
+ "$JIRA_URL/rest/api/3/issue/PROJ-1234/transitions"
157
+ ```
158
+
159
+ ### Search with JQL
160
+
161
+ ```bash
162
+ jira_curl -G \
163
+ --data-urlencode "jql=project = PROJ AND status = 'In Progress'" \
164
+ "$JIRA_URL/rest/api/3/search"
165
+ ```
166
+
167
+ ## Analyzing a Ticket
168
+
169
+ When retrieving a ticket for development or test automation, extract:
170
+
171
+ ### 1. Testable Requirements
172
+ - **Functional requirements** — What the feature does
173
+ - **Acceptance criteria** — Conditions that must be met
174
+ - **Testable behaviors** — Specific actions and expected outcomes
175
+ - **User roles** — Who uses this feature and their permissions
176
+ - **Data requirements** — What data is needed
177
+ - **Integration points** — APIs, services, or systems involved
178
+
179
+ ### 2. Test Types Needed
180
+ - **Unit tests** — Individual functions and utilities
181
+ - **Integration tests** — API endpoints and service interactions
182
+ - **E2E tests** — User-facing UI flows
183
+ - **API tests** — Endpoint contracts and error handling
184
+
185
+ ### 3. Edge Cases & Error Scenarios
186
+ - Invalid inputs (empty, too long, special characters)
187
+ - Unauthorized access
188
+ - Network failures or timeouts
189
+ - Concurrent users or race conditions
190
+ - Boundary conditions
191
+ - Missing or null data
192
+ - State transitions (back navigation, refresh, etc.)
193
+
194
+ ### 4. Structured Analysis Output
195
+
196
+ ```
197
+ Ticket: PROJ-1234
198
+ Summary: [ticket title]
199
+ Status: [current status]
200
+ Priority: [High/Medium/Low]
201
+ Test Types: Unit, Integration, E2E
202
+
203
+ Requirements:
204
+ 1. [requirement 1]
205
+ 2. [requirement 2]
206
+
207
+ Acceptance Criteria:
208
+ - [ ] [criterion 1]
209
+ - [ ] [criterion 2]
210
+
211
+ Test Scenarios:
212
+ - Happy Path: [description]
213
+ - Error Case: [description]
214
+ - Edge Case: [description]
215
+
216
+ Test Data Needed:
217
+ - [data item 1]
218
+ - [data item 2]
219
+
220
+ Dependencies:
221
+ - [dependency 1]
222
+ - [dependency 2]
223
+ ```
224
+
225
+ ## Updating Tickets
226
+
227
+ ### When to Update
228
+
229
+ | Workflow Step | Jira Update |
230
+ |---|---|
231
+ | Start work | Transition to "In Progress" |
232
+ | Tests written | Comment with test coverage summary |
233
+ | Branch created | Comment with branch name |
234
+ | PR/MR created | Comment with link, link issue |
235
+ | Tests passing | Comment with results summary |
236
+ | PR/MR merged | Transition to "Done" or "In Review" |
237
+
238
+ ### Comment Templates
239
+
240
+ **Starting Work:**
241
+ ```
242
+ Starting implementation for this ticket.
243
+ Branch: feat/PROJ-1234-feature-name
244
+ ```
245
+
246
+ **Tests Implemented:**
247
+ ```
248
+ Automated tests implemented:
249
+
250
+ Unit Tests:
251
+ - [test file 1] — [what it covers]
252
+ - [test file 2] — [what it covers]
253
+
254
+ Integration Tests:
255
+ - [test file] — [endpoints/flows covered]
256
+
257
+ All tests passing locally. Coverage: XX%
258
+ ```
259
+
260
+ **PR Created:**
261
+ ```
262
+ Pull request created:
263
+ [PR Title](https://github.com/org/repo/pull/XXX)
264
+
265
+ Ready for review.
266
+ ```
267
+
268
+ **Work Complete:**
269
+ ```
270
+ Implementation complete.
271
+
272
+ PR merged: [link]
273
+ Test results: All passing (X/Y)
274
+ Coverage: XX%
275
+ ```
276
+
277
+ ## Security Guidelines
278
+
279
+ - **Never hardcode** Jira API tokens in source code or skill files
280
+ - **Always use** environment variables or a secrets manager
281
+ - **Add `.env`** to `.gitignore` in every project
282
+ - **Rotate tokens** immediately if exposed in git history
283
+ - **Use least-privilege** API tokens scoped to required projects
284
+ - **Validate** that credentials are set before making API calls — fail fast with a clear message
285
+
286
+ ## Troubleshooting
287
+
288
+ | Error | Cause | Fix |
289
+ |---|---|---|
290
+ | `401 Unauthorized` | Invalid or expired API token | Regenerate at id.atlassian.com |
291
+ | `403 Forbidden` | Token lacks project permissions | Check token scopes and project access |
292
+ | `404 Not Found` | Wrong ticket key or base URL | Verify `JIRA_URL` and ticket key |
293
+ | `spawn uvx ENOENT` | IDE cannot find `uvx` on PATH | Use full path (e.g., `~/.local/bin/uvx`) or set PATH in `~/.zprofile` |
294
+ | Connection timeout | Network/VPN issue | Check VPN connection and firewall rules |
295
+
296
+ ## Best Practices
297
+
298
+ - Update Jira as you go, not all at once at the end
299
+ - Keep comments concise but informative
300
+ - Link rather than copy — point to PRs, test reports, and dashboards
301
+ - Use @mentions if you need input from others
302
+ - Check linked issues to understand full feature scope before starting
303
+ - If acceptance criteria are vague, ask for clarification before writing code
@@ -0,0 +1,152 @@
1
+ ---
2
+ name: jpa-patterns
3
+ description: JPA/Hibernate patterns for entity design, relationships, query optimization, transactions, auditing, indexing, pagination, and pooling in Spring Boot.
4
+ metadata:
5
+ origin: ECC
6
+ ---
7
+
8
+ # JPA/Hibernate Patterns
9
+
10
+ Use for data modeling, repositories, and performance tuning in Spring Boot.
11
+
12
+ ## When to Activate
13
+
14
+ - Designing JPA entities and table mappings
15
+ - Defining relationships (@OneToMany, @ManyToOne, @ManyToMany)
16
+ - Optimizing queries (N+1 prevention, fetch strategies, projections)
17
+ - Configuring transactions, auditing, or soft deletes
18
+ - Setting up pagination, sorting, or custom repository methods
19
+ - Tuning connection pooling (HikariCP) or second-level caching
20
+
21
+ ## Entity Design
22
+
23
+ ```java
24
+ @Entity
25
+ @Table(name = "markets", indexes = {
26
+ @Index(name = "idx_markets_slug", columnList = "slug", unique = true)
27
+ })
28
+ @EntityListeners(AuditingEntityListener.class)
29
+ public class MarketEntity {
30
+ @Id @GeneratedValue(strategy = GenerationType.IDENTITY)
31
+ private Long id;
32
+
33
+ @Column(nullable = false, length = 200)
34
+ private String name;
35
+
36
+ @Column(nullable = false, unique = true, length = 120)
37
+ private String slug;
38
+
39
+ @Enumerated(EnumType.STRING)
40
+ private MarketStatus status = MarketStatus.ACTIVE;
41
+
42
+ @CreatedDate private Instant createdAt;
43
+ @LastModifiedDate private Instant updatedAt;
44
+ }
45
+ ```
46
+
47
+ Enable auditing:
48
+ ```java
49
+ @Configuration
50
+ @EnableJpaAuditing
51
+ class JpaConfig {}
52
+ ```
53
+
54
+ ## Relationships and N+1 Prevention
55
+
56
+ ```java
57
+ @OneToMany(mappedBy = "market", cascade = CascadeType.ALL, orphanRemoval = true)
58
+ private List<PositionEntity> positions = new ArrayList<>();
59
+ ```
60
+
61
+ - Default to lazy loading; use `JOIN FETCH` in queries when needed
62
+ - Avoid `EAGER` on collections; use DTO projections for read paths
63
+
64
+ ```java
65
+ @Query("select m from MarketEntity m left join fetch m.positions where m.id = :id")
66
+ Optional<MarketEntity> findWithPositions(@Param("id") Long id);
67
+ ```
68
+
69
+ ## Repository Patterns
70
+
71
+ ```java
72
+ public interface MarketRepository extends JpaRepository<MarketEntity, Long> {
73
+ Optional<MarketEntity> findBySlug(String slug);
74
+
75
+ @Query("select m from MarketEntity m where m.status = :status")
76
+ Page<MarketEntity> findByStatus(@Param("status") MarketStatus status, Pageable pageable);
77
+ }
78
+ ```
79
+
80
+ - Use projections for lightweight queries:
81
+ ```java
82
+ public interface MarketSummary {
83
+ Long getId();
84
+ String getName();
85
+ MarketStatus getStatus();
86
+ }
87
+ Page<MarketSummary> findAllBy(Pageable pageable);
88
+ ```
89
+
90
+ ## Transactions
91
+
92
+ - Annotate service methods with `@Transactional`
93
+ - Use `@Transactional(readOnly = true)` for read paths to optimize
94
+ - Choose propagation carefully; avoid long-running transactions
95
+
96
+ ```java
97
+ @Transactional
98
+ public Market updateStatus(Long id, MarketStatus status) {
99
+ MarketEntity entity = repo.findById(id)
100
+ .orElseThrow(() -> new EntityNotFoundException("Market"));
101
+ entity.setStatus(status);
102
+ return Market.from(entity);
103
+ }
104
+ ```
105
+
106
+ ## Pagination
107
+
108
+ ```java
109
+ PageRequest page = PageRequest.of(pageNumber, pageSize, Sort.by("createdAt").descending());
110
+ Page<MarketEntity> markets = repo.findByStatus(MarketStatus.ACTIVE, page);
111
+ ```
112
+
113
+ For cursor-like pagination, include `id > :lastId` in JPQL with ordering.
114
+
115
+ ## Indexing and Performance
116
+
117
+ - Add indexes for common filters (`status`, `slug`, foreign keys)
118
+ - Use composite indexes matching query patterns (`status, created_at`)
119
+ - Avoid `select *`; project only needed columns
120
+ - Batch writes with `saveAll` and `hibernate.jdbc.batch_size`
121
+
122
+ ## Connection Pooling (HikariCP)
123
+
124
+ Recommended properties:
125
+ ```
126
+ spring.datasource.hikari.maximum-pool-size=20
127
+ spring.datasource.hikari.minimum-idle=5
128
+ spring.datasource.hikari.connection-timeout=30000
129
+ spring.datasource.hikari.validation-timeout=5000
130
+ ```
131
+
132
+ For PostgreSQL LOB handling, add:
133
+ ```
134
+ spring.jpa.properties.hibernate.jdbc.lob.non_contextual_creation=true
135
+ ```
136
+
137
+ ## Caching
138
+
139
+ - 1st-level cache is per EntityManager; avoid keeping entities across transactions
140
+ - For read-heavy entities, consider second-level cache cautiously; validate eviction strategy
141
+
142
+ ## Migrations
143
+
144
+ - Use Flyway or Liquibase; never rely on Hibernate auto DDL in production
145
+ - Keep migrations idempotent and additive; avoid dropping columns without plan
146
+
147
+ ## Testing Data Access
148
+
149
+ - Prefer `@DataJpaTest` with Testcontainers to mirror production
150
+ - Assert SQL efficiency using logs: set `logging.level.org.hibernate.SQL=DEBUG` and `logging.level.org.hibernate.orm.jdbc.bind=TRACE` for parameter values
151
+
152
+ **Remember**: Keep entities lean, queries intentional, and transactions short. Prevent N+1 with fetch strategies and projections, and index for your read/write paths.
@@ -0,0 +1,155 @@
1
+ ---
2
+ name: knowledge-ops
3
+ description: Knowledge base management, ingestion, sync, and retrieval across multiple storage layers (local files, MCP memory, vector stores, Git repos). Use when the user wants to save, organize, sync, deduplicate, or search across their knowledge systems.
4
+ metadata:
5
+ origin: ECC
6
+ ---
7
+
8
+ # Knowledge Operations
9
+
10
+ Manage a multi-layered knowledge system for ingesting, organizing, syncing, and retrieving knowledge across multiple stores.
11
+
12
+ Prefer the live workspace model:
13
+ - code work lives in the real cloned repos
14
+ - active execution context lives in GitHub, Linear, and repo-local working-context files
15
+ - broader human-facing notes can live in a non-repo context/archive folder
16
+ - durable cross-machine memory belongs in the knowledge base, not in a shadow repo workspace
17
+
18
+ ## When to Activate
19
+
20
+ - User wants to save information to their knowledge base
21
+ - Ingesting documents, conversations, or data into structured storage
22
+ - Syncing knowledge across systems (local files, MCP memory, Supabase, Git repos)
23
+ - Deduplicating or organizing existing knowledge
24
+ - User says "save this to KB", "sync knowledge", "what do I know about X", "ingest this", "update the knowledge base"
25
+ - Any knowledge management task beyond simple memory recall
26
+
27
+ ## Knowledge Architecture
28
+
29
+ ### Layer 1: Active execution truth
30
+ - **Sources:** GitHub issues, PRs, discussions, release notes, Linear issues/projects/docs
31
+ - **Use for:** the current operational state of the work
32
+ - **Rule:** if something affects an active engineering plan, roadmap, rollout, or release, prefer putting it here first
33
+
34
+ ### Layer 2: Claude Code Memory (Quick Access)
35
+ - **Path:** `~/.claude/projects/*/memory/`
36
+ - **Format:** Markdown files with frontmatter
37
+ - **Types:** user preferences, feedback, project context, reference
38
+ - **Use for:** quick-access context that persists across conversations
39
+ - **Automatically loaded at session start**
40
+
41
+ ### Layer 3: MCP Memory Server (Structured Knowledge Graph)
42
+ - **Access:** MCP memory tools (create_entities, create_relations, add_observations, search_nodes)
43
+ - **Use for:** Semantic search across all stored memories, relationship mapping
44
+ - **Cross-session persistence with queryable graph structure**
45
+
46
+ ### Layer 4: Knowledge base repo / durable document store
47
+ - **Use for:** curated durable notes, session exports, synthesized research, operator memory, long-form docs
48
+ - **Rule:** this is the preferred durable store for cross-machine context when the content is not repo-owned code
49
+
50
+ ### Layer 5: External Data Store (Supabase, PostgreSQL, etc.)
51
+ - **Use for:** Structured data, large document storage, full-text search
52
+ - **Good for:** Documents too large for memory files, data needing SQL queries
53
+
54
+ ### Layer 6: Local context/archive folder
55
+ - **Use for:** human-facing notes, archived gameplans, local media organization, temporary non-code docs
56
+ - **Rule:** writable for information storage, but not a shadow code workspace
57
+ - **Do not use for:** active code changes or repo truth that should live upstream
58
+
59
+ ## Ingestion Workflow
60
+
61
+ When new knowledge needs to be captured:
62
+
63
+ ### 1. Classify
64
+ What type of knowledge is it?
65
+ - Business decision -> memory file (project type) + MCP memory
66
+ - Active roadmap / release / implementation state -> GitHub + Linear first
67
+ - Personal preference -> memory file (user/feedback type)
68
+ - Reference info -> memory file (reference type) + MCP memory
69
+ - Large document -> external data store + summary in memory
70
+ - Conversation/session -> knowledge base repo + short summary in memory
71
+
72
+ ### 2. Deduplicate
73
+ Check if this knowledge already exists:
74
+ - Search memory files for existing entries
75
+ - Query MCP memory with relevant terms
76
+ - Check whether the information already exists in GitHub or Linear before creating another local note
77
+ - Do not create duplicates. Update existing entries instead.
78
+
79
+ ### 3. Store
80
+ Write to appropriate layer(s):
81
+ - Always update Claude Code memory for quick access
82
+ - Use MCP memory for semantic searchability and relationship mapping
83
+ - Update GitHub / Linear first when the information changes live project truth
84
+ - Commit to the knowledge base repo for durable long-form additions
85
+
86
+ ### 4. Index
87
+ Update any relevant indexes or summary files.
88
+
89
+ ## Sync Operations
90
+
91
+ ### Conversation Sync
92
+ Periodically sync conversation history into the knowledge base:
93
+ - Sources: Claude session files, Codex sessions, other agent sessions
94
+ - Destination: knowledge base repo
95
+ - Generate a session index for quick browsing
96
+ - Commit and push
97
+
98
+ ### Workspace State Sync
99
+ Mirror important workspace configuration and scripts to the knowledge base:
100
+ - Generate directory maps
101
+ - Redact sensitive config before committing
102
+ - Track changes over time
103
+ - Do not treat the knowledge base or archive folder as the live code workspace
104
+
105
+ ### GitHub / Linear Sync
106
+ When the information affects active execution:
107
+ - update the relevant GitHub issue, PR, discussion, release notes, or roadmap thread
108
+ - attach supporting docs to Linear when the work needs durable planning context
109
+ - only mirror a local note afterwards if it still adds value
110
+
111
+ ### Cross-Source Knowledge Sync
112
+ Pull knowledge from multiple sources into one place:
113
+ - Claude/ChatGPT/Grok conversation exports
114
+ - Browser bookmarks
115
+ - GitHub activity events
116
+ - Write status summary, commit and push
117
+
118
+ ## Memory Patterns
119
+
120
+ ```
121
+ # Short-term: current session context
122
+ Use TodoWrite for in-session task tracking
123
+
124
+ # Medium-term: project memory files
125
+ Write to ~/.claude/projects/*/memory/ for cross-session recall
126
+
127
+ # Long-term: GitHub / Linear / KB
128
+ Put active execution truth in GitHub + Linear
129
+ Put durable synthesized context in the knowledge base repo
130
+
131
+ # Semantic layer: MCP knowledge graph
132
+ Use mcp__memory__create_entities for permanent structured data
133
+ Use mcp__memory__create_relations for relationship mapping
134
+ Use mcp__memory__add_observations for new facts about known entities
135
+ Use mcp__memory__search_nodes to find existing knowledge
136
+ ```
137
+
138
+ ## Best Practices
139
+
140
+ - Keep memory files concise. Archive old data rather than letting files grow unbounded.
141
+ - Use frontmatter (YAML) for metadata on all knowledge files.
142
+ - Deduplicate before storing. Search first, then create or update.
143
+ - Prefer one canonical home per fact set. Avoid parallel copies of the same plan across local notes, repo files, and tracker docs.
144
+ - Redact sensitive information (API keys, passwords) before committing to Git.
145
+ - Use consistent naming conventions for knowledge files (lowercase-kebab-case).
146
+ - Tag entries with topics/categories for easier retrieval.
147
+
148
+ ## Quality Gate
149
+
150
+ Before completing any knowledge operation:
151
+ - no duplicate entries created
152
+ - sensitive data redacted from any Git-tracked files
153
+ - indexes and summaries updated
154
+ - appropriate storage layer chosen for the data type
155
+ - cross-references added where relevant