arboris-cli 1.0.0 → 1.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (451) hide show
  1. package/dist/cli.mjs +382 -0
  2. package/manifest.json +323 -0
  3. package/package.json +22 -10
  4. package/prisma/skills/accessibility/SKILL.md +147 -0
  5. package/prisma/skills/agent-architecture-audit/SKILL.md +257 -0
  6. package/prisma/skills/agent-eval/SKILL.md +146 -0
  7. package/prisma/skills/agent-harness-construction/SKILL.md +74 -0
  8. package/prisma/skills/agent-introspection-debugging/SKILL.md +154 -0
  9. package/prisma/skills/agent-payment-x402/SKILL.md +225 -0
  10. package/prisma/skills/agent-self-evaluation/SKILL.md +182 -0
  11. package/prisma/skills/agent-self-evaluation/examples/high-score-example.md +87 -0
  12. package/prisma/skills/agent-self-evaluation/examples/low-score-example.md +86 -0
  13. package/prisma/skills/agent-self-evaluation/references/evaluation-criteria.md +71 -0
  14. package/prisma/skills/agent-self-evaluation/references/hook-integration.md +64 -0
  15. package/prisma/skills/agent-self-evaluation/scripts/evaluate.py +408 -0
  16. package/prisma/skills/agent-self-evaluation/templates/evaluation-report.md +86 -0
  17. package/prisma/skills/agent-sort/SKILL.md +216 -0
  18. package/prisma/skills/agentic-engineering/SKILL.md +64 -0
  19. package/prisma/skills/agentic-os/SKILL.md +388 -0
  20. package/prisma/skills/ai-first-engineering/SKILL.md +52 -0
  21. package/prisma/skills/ai-regression-testing/SKILL.md +386 -0
  22. package/prisma/skills/android-clean-architecture/SKILL.md +340 -0
  23. package/prisma/skills/angular-developer/SKILL.md +155 -0
  24. package/prisma/skills/angular-developer/references/angular-animations.md +160 -0
  25. package/prisma/skills/angular-developer/references/angular-aria.md +410 -0
  26. package/prisma/skills/angular-developer/references/cli.md +86 -0
  27. package/prisma/skills/angular-developer/references/component-harnesses.md +59 -0
  28. package/prisma/skills/angular-developer/references/component-styling.md +91 -0
  29. package/prisma/skills/angular-developer/references/components.md +117 -0
  30. package/prisma/skills/angular-developer/references/creating-services.md +97 -0
  31. package/prisma/skills/angular-developer/references/data-resolvers.md +69 -0
  32. package/prisma/skills/angular-developer/references/define-routes.md +67 -0
  33. package/prisma/skills/angular-developer/references/defining-providers.md +72 -0
  34. package/prisma/skills/angular-developer/references/di-fundamentals.md +120 -0
  35. package/prisma/skills/angular-developer/references/e2e-testing.md +56 -0
  36. package/prisma/skills/angular-developer/references/effects.md +83 -0
  37. package/prisma/skills/angular-developer/references/hierarchical-injectors.md +43 -0
  38. package/prisma/skills/angular-developer/references/host-elements.md +80 -0
  39. package/prisma/skills/angular-developer/references/injection-context.md +63 -0
  40. package/prisma/skills/angular-developer/references/inputs.md +101 -0
  41. package/prisma/skills/angular-developer/references/linked-signal.md +59 -0
  42. package/prisma/skills/angular-developer/references/loading-strategies.md +61 -0
  43. package/prisma/skills/angular-developer/references/mcp.md +108 -0
  44. package/prisma/skills/angular-developer/references/navigate-to-routes.md +69 -0
  45. package/prisma/skills/angular-developer/references/outputs.md +86 -0
  46. package/prisma/skills/angular-developer/references/reactive-forms.md +122 -0
  47. package/prisma/skills/angular-developer/references/rendering-strategies.md +44 -0
  48. package/prisma/skills/angular-developer/references/resource.md +77 -0
  49. package/prisma/skills/angular-developer/references/route-animations.md +56 -0
  50. package/prisma/skills/angular-developer/references/route-guards.md +52 -0
  51. package/prisma/skills/angular-developer/references/router-lifecycle.md +45 -0
  52. package/prisma/skills/angular-developer/references/router-testing.md +87 -0
  53. package/prisma/skills/angular-developer/references/show-routes-with-outlets.md +68 -0
  54. package/prisma/skills/angular-developer/references/signal-forms.md +795 -0
  55. package/prisma/skills/angular-developer/references/signals-overview.md +94 -0
  56. package/prisma/skills/angular-developer/references/tailwind-css.md +69 -0
  57. package/prisma/skills/angular-developer/references/template-driven-forms.md +114 -0
  58. package/prisma/skills/angular-developer/references/testing-fundamentals.md +65 -0
  59. package/prisma/skills/api-connector-builder/SKILL.md +121 -0
  60. package/prisma/skills/api-design/SKILL.md +524 -0
  61. package/prisma/skills/architecture-decision-records/SKILL.md +180 -0
  62. package/prisma/skills/article-writing/SKILL.md +80 -0
  63. package/prisma/skills/automation-audit-ops/SKILL.md +143 -0
  64. package/prisma/skills/autonomous-agent-harness/SKILL.md +274 -0
  65. package/prisma/skills/autonomous-loops/SKILL.md +611 -0
  66. package/prisma/skills/backend-patterns/SKILL.md +562 -0
  67. package/prisma/skills/benchmark/SKILL.md +94 -0
  68. package/prisma/skills/benchmark-methodology/SKILL.md +190 -0
  69. package/prisma/skills/benchmark-optimization-loop/SKILL.md +70 -0
  70. package/prisma/skills/blender-motion-state-inspection/SKILL.md +165 -0
  71. package/prisma/skills/blueprint/SKILL.md +106 -0
  72. package/prisma/skills/brand-discovery/SKILL.md +145 -0
  73. package/prisma/skills/brand-discovery/references/10_purpose-why.md +40 -0
  74. package/prisma/skills/brand-discovery/references/20_positioning.md +44 -0
  75. package/prisma/skills/brand-discovery/references/30_audience-niche.md +52 -0
  76. package/prisma/skills/brand-discovery/references/40_personality-archetype.md +57 -0
  77. package/prisma/skills/brand-discovery/references/50_voice-tone.md +59 -0
  78. package/prisma/skills/brand-discovery/references/60_narrative-story.md +50 -0
  79. package/prisma/skills/brand-discovery/references/70_founder-tension.md +49 -0
  80. package/prisma/skills/brand-discovery/references/90_SYNTHESIS.md +133 -0
  81. package/prisma/skills/brand-voice/SKILL.md +98 -0
  82. package/prisma/skills/brand-voice/references/voice-profile-schema.md +55 -0
  83. package/prisma/skills/browser-qa/SKILL.md +105 -0
  84. package/prisma/skills/bun-runtime/SKILL.md +85 -0
  85. package/prisma/skills/canary-watch/SKILL.md +108 -0
  86. package/prisma/skills/carrier-relationship-management/SKILL.md +212 -0
  87. package/prisma/skills/cisco-ios-patterns/SKILL.md +164 -0
  88. package/prisma/skills/ck/SKILL.md +148 -0
  89. package/prisma/skills/ck/commands/forget.mjs +44 -0
  90. package/prisma/skills/ck/commands/info.mjs +24 -0
  91. package/prisma/skills/ck/commands/init.mjs +143 -0
  92. package/prisma/skills/ck/commands/list.mjs +40 -0
  93. package/prisma/skills/ck/commands/migrate.mjs +202 -0
  94. package/prisma/skills/ck/commands/resume.mjs +36 -0
  95. package/prisma/skills/ck/commands/save.mjs +210 -0
  96. package/prisma/skills/ck/commands/shared.mjs +387 -0
  97. package/prisma/skills/ck/hooks/session-start.mjs +224 -0
  98. package/prisma/skills/claude-devfleet/SKILL.md +112 -0
  99. package/prisma/skills/click-path-audit/SKILL.md +245 -0
  100. package/prisma/skills/clickhouse-io/SKILL.md +440 -0
  101. package/prisma/skills/code-tour/SKILL.md +254 -0
  102. package/prisma/skills/codebase-onboarding/SKILL.md +234 -0
  103. package/prisma/skills/codehealth-mcp/SKILL.md +167 -0
  104. package/prisma/skills/coding-standards/SKILL.md +551 -0
  105. package/prisma/skills/competitive-platform-analysis/SKILL.md +214 -0
  106. package/prisma/skills/competitive-report-structure/SKILL.md +162 -0
  107. package/prisma/skills/compose-multiplatform-patterns/SKILL.md +300 -0
  108. package/prisma/skills/config-gc/SKILL.md +120 -0
  109. package/prisma/skills/configure-ecc/SKILL.md +385 -0
  110. package/prisma/skills/connections-optimizer/SKILL.md +190 -0
  111. package/prisma/skills/content-engine/SKILL.md +132 -0
  112. package/prisma/skills/content-hash-cache-pattern/SKILL.md +162 -0
  113. package/prisma/skills/context-budget/SKILL.md +136 -0
  114. package/prisma/skills/continuous-agent-loop/SKILL.md +46 -0
  115. package/prisma/skills/continuous-learning/SKILL.md +132 -0
  116. package/prisma/skills/continuous-learning/config.json +18 -0
  117. package/prisma/skills/continuous-learning/evaluate-session.sh +69 -0
  118. package/prisma/skills/continuous-learning-v2/SKILL.md +361 -0
  119. package/prisma/skills/continuous-learning-v2/agents/observer-loop.sh +359 -0
  120. package/prisma/skills/continuous-learning-v2/agents/observer.md +189 -0
  121. package/prisma/skills/continuous-learning-v2/agents/session-guardian.sh +150 -0
  122. package/prisma/skills/continuous-learning-v2/agents/start-observer.sh +248 -0
  123. package/prisma/skills/continuous-learning-v2/config.json +8 -0
  124. package/prisma/skills/continuous-learning-v2/hooks/observe.sh +585 -0
  125. package/prisma/skills/continuous-learning-v2/scripts/detect-project.sh +322 -0
  126. package/prisma/skills/continuous-learning-v2/scripts/instinct-cli.py +1956 -0
  127. package/prisma/skills/continuous-learning-v2/scripts/lib/homunculus-dir.sh +31 -0
  128. package/prisma/skills/continuous-learning-v2/scripts/migrate-homunculus.sh +68 -0
  129. package/prisma/skills/continuous-learning-v2/scripts/test_parse_instinct.py +1421 -0
  130. package/prisma/skills/cost-aware-llm-pipeline/SKILL.md +184 -0
  131. package/prisma/skills/cost-tracking/SKILL.md +97 -0
  132. package/prisma/skills/council/SKILL.md +204 -0
  133. package/prisma/skills/cpp-coding-standards/SKILL.md +724 -0
  134. package/prisma/skills/cpp-testing/SKILL.md +325 -0
  135. package/prisma/skills/crosspost/SKILL.md +112 -0
  136. package/prisma/skills/csharp-testing/SKILL.md +322 -0
  137. package/prisma/skills/customer-billing-ops/SKILL.md +141 -0
  138. package/prisma/skills/customs-trade-compliance/SKILL.md +263 -0
  139. package/prisma/skills/dart-flutter-patterns/SKILL.md +564 -0
  140. package/prisma/skills/dashboard-builder/SKILL.md +109 -0
  141. package/prisma/skills/data-scraper-agent/SKILL.md +765 -0
  142. package/prisma/skills/data-throughput-accelerator/SKILL.md +73 -0
  143. package/prisma/skills/database-migrations/SKILL.md +430 -0
  144. package/prisma/skills/deep-research/SKILL.md +160 -0
  145. package/prisma/skills/defi-amm-security/SKILL.md +167 -0
  146. package/prisma/skills/delivery-gate/SKILL.md +126 -0
  147. package/prisma/skills/delivery-gate/hooks/quality-gate.py +220 -0
  148. package/prisma/skills/deployment-patterns/SKILL.md +428 -0
  149. package/prisma/skills/design-system/SKILL.md +83 -0
  150. package/prisma/skills/django-celery/SKILL.md +458 -0
  151. package/prisma/skills/django-patterns/SKILL.md +735 -0
  152. package/prisma/skills/django-security/SKILL.md +644 -0
  153. package/prisma/skills/django-tdd/SKILL.md +730 -0
  154. package/prisma/skills/django-verification/SKILL.md +470 -0
  155. package/prisma/skills/dmux-workflows/SKILL.md +192 -0
  156. package/prisma/skills/docker-patterns/SKILL.md +365 -0
  157. package/prisma/skills/documentation-lookup/SKILL.md +91 -0
  158. package/prisma/skills/dotnet-patterns/SKILL.md +322 -0
  159. package/prisma/skills/dynamic-workflow-mode/SKILL.md +124 -0
  160. package/prisma/skills/e2e-testing/SKILL.md +327 -0
  161. package/prisma/skills/ecc-guide/SKILL.md +190 -0
  162. package/prisma/skills/ecc-recipes/SKILL.md +149 -0
  163. package/prisma/skills/ecc-tools-cost-audit/SKILL.md +161 -0
  164. package/prisma/skills/email-ops/SKILL.md +122 -0
  165. package/prisma/skills/energy-procurement/SKILL.md +228 -0
  166. package/prisma/skills/enterprise-agent-ops/SKILL.md +51 -0
  167. package/prisma/skills/error-handling/SKILL.md +377 -0
  168. package/prisma/skills/eval-harness/SKILL.md +271 -0
  169. package/prisma/skills/evm-token-decimals/SKILL.md +131 -0
  170. package/prisma/skills/exa-search/SKILL.md +108 -0
  171. package/prisma/skills/fal-ai-media/SKILL.md +289 -0
  172. package/prisma/skills/fastapi-patterns/SKILL.md +514 -0
  173. package/prisma/skills/finance-billing-ops/SKILL.md +128 -0
  174. package/prisma/skills/flox-environments/SKILL.md +497 -0
  175. package/prisma/skills/flutter-dart-code-review/SKILL.md +436 -0
  176. package/prisma/skills/foundation-models-on-device/SKILL.md +243 -0
  177. package/prisma/skills/frontend-a11y/SKILL.md +446 -0
  178. package/prisma/skills/frontend-design-direction/SKILL.md +93 -0
  179. package/prisma/skills/frontend-patterns/SKILL.md +657 -0
  180. package/prisma/skills/frontend-slides/SKILL.md +185 -0
  181. package/prisma/skills/frontend-slides/STYLE_PRESETS.md +330 -0
  182. package/prisma/skills/frontend-slides/animation-patterns.md +122 -0
  183. package/prisma/skills/frontend-slides/html-template.md +419 -0
  184. package/prisma/skills/frontend-slides/scripts/export-pdf.sh +418 -0
  185. package/prisma/skills/frontend-slides/scripts/extract-pptx.py +96 -0
  186. package/prisma/skills/frontend-slides/viewport-base.css +153 -0
  187. package/prisma/skills/fsharp-testing/SKILL.md +281 -0
  188. package/prisma/skills/gan-style-harness/SKILL.md +279 -0
  189. package/prisma/skills/gateguard/SKILL.md +133 -0
  190. package/prisma/skills/generating-python-installer/SKILL.md +820 -0
  191. package/prisma/skills/git-workflow/SKILL.md +716 -0
  192. package/prisma/skills/github-ops/SKILL.md +145 -0
  193. package/prisma/skills/golang-patterns/SKILL.md +675 -0
  194. package/prisma/skills/golang-testing/SKILL.md +721 -0
  195. package/prisma/skills/google-workspace-ops/SKILL.md +96 -0
  196. package/prisma/skills/growth-log/SKILL.md +128 -0
  197. package/prisma/skills/healthcare-cdss-patterns/SKILL.md +246 -0
  198. package/prisma/skills/healthcare-emr-patterns/SKILL.md +160 -0
  199. package/prisma/skills/healthcare-eval-harness/SKILL.md +208 -0
  200. package/prisma/skills/healthcare-phi-compliance/SKILL.md +146 -0
  201. package/prisma/skills/hermes-imports/SKILL.md +89 -0
  202. package/prisma/skills/hexagonal-architecture/SKILL.md +277 -0
  203. package/prisma/skills/hipaa-compliance/SKILL.md +79 -0
  204. package/prisma/skills/homelab-network-readiness/SKILL.md +170 -0
  205. package/prisma/skills/homelab-network-setup/SKILL.md +130 -0
  206. package/prisma/skills/homelab-pihole-dns/SKILL.md +275 -0
  207. package/prisma/skills/homelab-vlan-segmentation/SKILL.md +312 -0
  208. package/prisma/skills/homelab-wireguard-vpn/SKILL.md +306 -0
  209. package/prisma/skills/hookify-rules/SKILL.md +128 -0
  210. package/prisma/skills/inherit-legacy-style/SKILL.md +157 -0
  211. package/prisma/skills/intent-driven-development/SKILL.md +360 -0
  212. package/prisma/skills/inventory-demand-planning/SKILL.md +247 -0
  213. package/prisma/skills/investor-materials/SKILL.md +97 -0
  214. package/prisma/skills/investor-outreach/SKILL.md +92 -0
  215. package/prisma/skills/ios-icon-gen/SKILL.md +158 -0
  216. package/prisma/skills/ios-icon-gen/scripts/generate_icons.swift +258 -0
  217. package/prisma/skills/ios-icon-gen/scripts/iconify_gen.sh +235 -0
  218. package/prisma/skills/iterative-retrieval/SKILL.md +212 -0
  219. package/prisma/skills/ito-basket-compare/SKILL.md +64 -0
  220. package/prisma/skills/ito-data-atlas-agent/SKILL.md +64 -0
  221. package/prisma/skills/ito-market-intelligence/SKILL.md +61 -0
  222. package/prisma/skills/ito-trade-planner/SKILL.md +68 -0
  223. package/prisma/skills/java-coding-standards/SKILL.md +384 -0
  224. package/prisma/skills/jira-integration/SKILL.md +303 -0
  225. package/prisma/skills/jpa-patterns/SKILL.md +152 -0
  226. package/prisma/skills/knowledge-ops/SKILL.md +155 -0
  227. package/prisma/skills/kotlin-coroutines-flows/SKILL.md +285 -0
  228. package/prisma/skills/kotlin-exposed-patterns/SKILL.md +720 -0
  229. package/prisma/skills/kotlin-ktor-patterns/SKILL.md +690 -0
  230. package/prisma/skills/kotlin-patterns/SKILL.md +712 -0
  231. package/prisma/skills/kotlin-testing/SKILL.md +825 -0
  232. package/prisma/skills/kubernetes-patterns/SKILL.md +756 -0
  233. package/prisma/skills/laravel-patterns/SKILL.md +416 -0
  234. package/prisma/skills/laravel-plugin-discovery/SKILL.md +230 -0
  235. package/prisma/skills/laravel-security/SKILL.md +948 -0
  236. package/prisma/skills/laravel-tdd/SKILL.md +675 -0
  237. package/prisma/skills/laravel-verification/SKILL.md +180 -0
  238. package/prisma/skills/latency-critical-systems/SKILL.md +74 -0
  239. package/prisma/skills/lead-intelligence/SKILL.md +322 -0
  240. package/prisma/skills/lead-intelligence/agents/enrichment-agent.md +85 -0
  241. package/prisma/skills/lead-intelligence/agents/mutual-mapper.md +75 -0
  242. package/prisma/skills/lead-intelligence/agents/outreach-drafter.md +98 -0
  243. package/prisma/skills/lead-intelligence/agents/signal-scorer.md +60 -0
  244. package/prisma/skills/liquid-glass-design/SKILL.md +279 -0
  245. package/prisma/skills/llm-trading-agent-security/SKILL.md +147 -0
  246. package/prisma/skills/logistics-exception-management/SKILL.md +222 -0
  247. package/prisma/skills/loop-design-check/SKILL.md +143 -0
  248. package/prisma/skills/mailtrap-email-integration/SKILL.md +77 -0
  249. package/prisma/skills/make-interfaces-feel-better/SKILL.md +152 -0
  250. package/prisma/skills/manim-video/SKILL.md +90 -0
  251. package/prisma/skills/manim-video/assets/network_graph_scene.py +52 -0
  252. package/prisma/skills/market-research/SKILL.md +76 -0
  253. package/prisma/skills/marketing-campaign/SKILL.md +114 -0
  254. package/prisma/skills/mcp-server-patterns/SKILL.md +70 -0
  255. package/prisma/skills/messages-ops/SKILL.md +105 -0
  256. package/prisma/skills/ml-adoption-playbook/SKILL.md +57 -0
  257. package/prisma/skills/mle-workflow/SKILL.md +347 -0
  258. package/prisma/skills/motion-advanced/SKILL.md +596 -0
  259. package/prisma/skills/motion-foundations/SKILL.md +299 -0
  260. package/prisma/skills/motion-patterns/SKILL.md +434 -0
  261. package/prisma/skills/motion-ui/SKILL.md +576 -0
  262. package/prisma/skills/mysql-patterns/SKILL.md +413 -0
  263. package/prisma/skills/nanoclaw-repl/SKILL.md +34 -0
  264. package/prisma/skills/nestjs-patterns/SKILL.md +231 -0
  265. package/prisma/skills/netmiko-ssh-automation/SKILL.md +174 -0
  266. package/prisma/skills/network-bgp-diagnostics/SKILL.md +168 -0
  267. package/prisma/skills/network-config-validation/SKILL.md +211 -0
  268. package/prisma/skills/network-interface-health/SKILL.md +153 -0
  269. package/prisma/skills/nextjs-turbopack/SKILL.md +58 -0
  270. package/prisma/skills/nodejs-keccak256/SKILL.md +103 -0
  271. package/prisma/skills/nutrient-document-processing/SKILL.md +168 -0
  272. package/prisma/skills/nuxt4-patterns/SKILL.md +101 -0
  273. package/prisma/skills/openclaw-persona-forge/SKILL.md +289 -0
  274. package/prisma/skills/openclaw-persona-forge/gacha.py +224 -0
  275. package/prisma/skills/openclaw-persona-forge/gacha.sh +5 -0
  276. package/prisma/skills/openclaw-persona-forge/references/avatar-style.md +124 -0
  277. package/prisma/skills/openclaw-persona-forge/references/boundary-rules.md +53 -0
  278. package/prisma/skills/openclaw-persona-forge/references/error-handling.md +53 -0
  279. package/prisma/skills/openclaw-persona-forge/references/identity-tension.md +48 -0
  280. package/prisma/skills/openclaw-persona-forge/references/naming-system.md +39 -0
  281. package/prisma/skills/openclaw-persona-forge/references/output-template.md +166 -0
  282. package/prisma/skills/opensource-pipeline/SKILL.md +256 -0
  283. package/prisma/skills/orch-add-feature/SKILL.md +45 -0
  284. package/prisma/skills/orch-build-mvp/SKILL.md +49 -0
  285. package/prisma/skills/orch-change-feature/SKILL.md +43 -0
  286. package/prisma/skills/orch-fix-defect/SKILL.md +43 -0
  287. package/prisma/skills/orch-pipeline/SKILL.md +121 -0
  288. package/prisma/skills/orch-refine-code/SKILL.md +44 -0
  289. package/prisma/skills/parallel-execution-optimizer/SKILL.md +73 -0
  290. package/prisma/skills/perl-patterns/SKILL.md +505 -0
  291. package/prisma/skills/perl-security/SKILL.md +504 -0
  292. package/prisma/skills/perl-testing/SKILL.md +476 -0
  293. package/prisma/skills/plan-orchestrate/SKILL.md +263 -0
  294. package/prisma/skills/plankton-code-quality/SKILL.md +237 -0
  295. package/prisma/skills/postgres-patterns/SKILL.md +148 -0
  296. package/prisma/skills/prediction-market-oracle-research/SKILL.md +64 -0
  297. package/prisma/skills/prediction-market-risk-review/SKILL.md +61 -0
  298. package/prisma/skills/prisma-patterns/SKILL.md +401 -0
  299. package/prisma/skills/product-capability/SKILL.md +142 -0
  300. package/prisma/skills/product-lens/SKILL.md +93 -0
  301. package/prisma/skills/production-audit/SKILL.md +207 -0
  302. package/prisma/skills/production-scheduling/SKILL.md +238 -0
  303. package/prisma/skills/project-flow-ops/SKILL.md +112 -0
  304. package/prisma/skills/prompt-optimizer/SKILL.md +398 -0
  305. package/prisma/skills/python-patterns/SKILL.md +751 -0
  306. package/prisma/skills/python-testing/SKILL.md +817 -0
  307. package/prisma/skills/pytorch-patterns/SKILL.md +397 -0
  308. package/prisma/skills/quality-nonconformance/SKILL.md +260 -0
  309. package/prisma/skills/quarkus-patterns/SKILL.md +723 -0
  310. package/prisma/skills/quarkus-security/SKILL.md +468 -0
  311. package/prisma/skills/quarkus-tdd/SKILL.md +812 -0
  312. package/prisma/skills/quarkus-verification/SKILL.md +480 -0
  313. package/prisma/skills/ralphinho-rfc-pipeline/SKILL.md +68 -0
  314. package/prisma/skills/react-native-patterns/SKILL.md +326 -0
  315. package/prisma/skills/react-patterns/SKILL.md +342 -0
  316. package/prisma/skills/react-performance/SKILL.md +575 -0
  317. package/prisma/skills/react-testing/SKILL.md +424 -0
  318. package/prisma/skills/recsys-pipeline-architect/SKILL.md +115 -0
  319. package/prisma/skills/recursive-decision-ledger/SKILL.md +80 -0
  320. package/prisma/skills/redis-patterns/SKILL.md +404 -0
  321. package/prisma/skills/regex-vs-llm-structured-text/SKILL.md +221 -0
  322. package/prisma/skills/remotion-video-creation/SKILL.md +43 -0
  323. package/prisma/skills/remotion-video-creation/rules/3d.md +86 -0
  324. package/prisma/skills/remotion-video-creation/rules/animations.md +29 -0
  325. package/prisma/skills/remotion-video-creation/rules/assets/charts-bar-chart.tsx +173 -0
  326. package/prisma/skills/remotion-video-creation/rules/assets/text-animations-typewriter.tsx +100 -0
  327. package/prisma/skills/remotion-video-creation/rules/assets/text-animations-word-highlight.tsx +108 -0
  328. package/prisma/skills/remotion-video-creation/rules/assets.md +78 -0
  329. package/prisma/skills/remotion-video-creation/rules/audio.md +172 -0
  330. package/prisma/skills/remotion-video-creation/rules/calculate-metadata.md +104 -0
  331. package/prisma/skills/remotion-video-creation/rules/can-decode.md +75 -0
  332. package/prisma/skills/remotion-video-creation/rules/charts.md +58 -0
  333. package/prisma/skills/remotion-video-creation/rules/compositions.md +146 -0
  334. package/prisma/skills/remotion-video-creation/rules/display-captions.md +126 -0
  335. package/prisma/skills/remotion-video-creation/rules/extract-frames.md +229 -0
  336. package/prisma/skills/remotion-video-creation/rules/fonts.md +152 -0
  337. package/prisma/skills/remotion-video-creation/rules/get-audio-duration.md +58 -0
  338. package/prisma/skills/remotion-video-creation/rules/get-video-dimensions.md +68 -0
  339. package/prisma/skills/remotion-video-creation/rules/get-video-duration.md +58 -0
  340. package/prisma/skills/remotion-video-creation/rules/gifs.md +138 -0
  341. package/prisma/skills/remotion-video-creation/rules/images.md +130 -0
  342. package/prisma/skills/remotion-video-creation/rules/import-srt-captions.md +67 -0
  343. package/prisma/skills/remotion-video-creation/rules/lottie.md +67 -0
  344. package/prisma/skills/remotion-video-creation/rules/measuring-dom-nodes.md +34 -0
  345. package/prisma/skills/remotion-video-creation/rules/measuring-text.md +143 -0
  346. package/prisma/skills/remotion-video-creation/rules/sequencing.md +106 -0
  347. package/prisma/skills/remotion-video-creation/rules/tailwind.md +11 -0
  348. package/prisma/skills/remotion-video-creation/rules/text-animations.md +20 -0
  349. package/prisma/skills/remotion-video-creation/rules/timing.md +179 -0
  350. package/prisma/skills/remotion-video-creation/rules/transcribe-captions.md +19 -0
  351. package/prisma/skills/remotion-video-creation/rules/transitions.md +122 -0
  352. package/prisma/skills/remotion-video-creation/rules/trimming.md +52 -0
  353. package/prisma/skills/remotion-video-creation/rules/videos.md +171 -0
  354. package/prisma/skills/repo-scan/SKILL.md +79 -0
  355. package/prisma/skills/research-ops/SKILL.md +113 -0
  356. package/prisma/skills/returns-reverse-logistics/SKILL.md +240 -0
  357. package/prisma/skills/rules-distill/SKILL.md +265 -0
  358. package/prisma/skills/rules-distill/scripts/scan-rules.sh +58 -0
  359. package/prisma/skills/rules-distill/scripts/scan-skills.sh +129 -0
  360. package/prisma/skills/rust-patterns/SKILL.md +500 -0
  361. package/prisma/skills/rust-testing/SKILL.md +501 -0
  362. package/prisma/skills/safety-guard/SKILL.md +76 -0
  363. package/prisma/skills/santa-method/SKILL.md +307 -0
  364. package/prisma/skills/scientific-db-pubmed-database/SKILL.md +176 -0
  365. package/prisma/skills/scientific-db-uspto-database/SKILL.md +178 -0
  366. package/prisma/skills/scientific-pkg-gget/SKILL.md +167 -0
  367. package/prisma/skills/scientific-thinking-literature-review/SKILL.md +193 -0
  368. package/prisma/skills/scientific-thinking-scholar-evaluation/SKILL.md +161 -0
  369. package/prisma/skills/search-first/SKILL.md +183 -0
  370. package/prisma/skills/security-bounty-hunter/SKILL.md +100 -0
  371. package/prisma/skills/security-review/SKILL.md +504 -0
  372. package/prisma/skills/security-review/cloud-infrastructure-security.md +361 -0
  373. package/prisma/skills/security-scan/SKILL.md +166 -0
  374. package/prisma/skills/seo/SKILL.md +155 -0
  375. package/prisma/skills/skill-comply/SKILL.md +59 -0
  376. package/prisma/skills/skill-comply/fixtures/compliant_trace.jsonl +5 -0
  377. package/prisma/skills/skill-comply/fixtures/noncompliant_trace.jsonl +3 -0
  378. package/prisma/skills/skill-comply/fixtures/tdd_spec.yaml +44 -0
  379. package/prisma/skills/skill-comply/prompts/classifier.md +24 -0
  380. package/prisma/skills/skill-comply/prompts/scenario_generator.md +62 -0
  381. package/prisma/skills/skill-comply/prompts/spec_generator.md +42 -0
  382. package/prisma/skills/skill-comply/pyproject.toml +15 -0
  383. package/prisma/skills/skill-comply/scripts/__init__.py +0 -0
  384. package/prisma/skills/skill-comply/scripts/classifier.py +85 -0
  385. package/prisma/skills/skill-comply/scripts/grader.py +124 -0
  386. package/prisma/skills/skill-comply/scripts/parser.py +107 -0
  387. package/prisma/skills/skill-comply/scripts/report.py +170 -0
  388. package/prisma/skills/skill-comply/scripts/run.py +127 -0
  389. package/prisma/skills/skill-comply/scripts/runner.py +194 -0
  390. package/prisma/skills/skill-comply/scripts/scenario_generator.py +70 -0
  391. package/prisma/skills/skill-comply/scripts/spec_generator.py +72 -0
  392. package/prisma/skills/skill-comply/scripts/utils.py +13 -0
  393. package/prisma/skills/skill-comply/tests/test_grader.py +197 -0
  394. package/prisma/skills/skill-comply/tests/test_parser.py +90 -0
  395. package/prisma/skills/skill-comply/tests/test_runner.py +172 -0
  396. package/prisma/skills/skill-scout/SKILL.md +141 -0
  397. package/prisma/skills/skill-stocktake/SKILL.md +195 -0
  398. package/prisma/skills/skill-stocktake/scripts/quick-diff.sh +87 -0
  399. package/prisma/skills/skill-stocktake/scripts/save-results.sh +56 -0
  400. package/prisma/skills/skill-stocktake/scripts/scan.sh +170 -0
  401. package/prisma/skills/social-graph-ranker/SKILL.md +155 -0
  402. package/prisma/skills/social-publisher/SKILL.md +130 -0
  403. package/prisma/skills/springboot-patterns/SKILL.md +315 -0
  404. package/prisma/skills/springboot-security/SKILL.md +273 -0
  405. package/prisma/skills/springboot-tdd/SKILL.md +159 -0
  406. package/prisma/skills/springboot-verification/SKILL.md +232 -0
  407. package/prisma/skills/strategic-compact/SKILL.md +136 -0
  408. package/prisma/skills/swift-actor-persistence/SKILL.md +144 -0
  409. package/prisma/skills/swift-concurrency-6-2/SKILL.md +216 -0
  410. package/prisma/skills/swift-protocol-di-testing/SKILL.md +191 -0
  411. package/prisma/skills/swiftui-patterns/SKILL.md +259 -0
  412. package/prisma/skills/taste/SKILL.md +264 -0
  413. package/prisma/skills/taste/references/genre-taxonomy.md +87 -0
  414. package/prisma/skills/tdd-workflow/SKILL.md +583 -0
  415. package/prisma/skills/team-agent-orchestration/SKILL.md +111 -0
  416. package/prisma/skills/team-builder/SKILL.md +169 -0
  417. package/prisma/skills/terminal-ops/SKILL.md +110 -0
  418. package/prisma/skills/tinystruct-patterns/SKILL.md +279 -0
  419. package/prisma/skills/tinystruct-patterns/references/architecture.md +90 -0
  420. package/prisma/skills/tinystruct-patterns/references/data-handling.md +60 -0
  421. package/prisma/skills/tinystruct-patterns/references/database.md +99 -0
  422. package/prisma/skills/tinystruct-patterns/references/routing.md +64 -0
  423. package/prisma/skills/tinystruct-patterns/references/system-usage.md +97 -0
  424. package/prisma/skills/tinystruct-patterns/references/testing.md +72 -0
  425. package/prisma/skills/token-budget-advisor/SKILL.md +134 -0
  426. package/prisma/skills/ui-demo/SKILL.md +466 -0
  427. package/prisma/skills/ui-to-vue/SKILL.md +135 -0
  428. package/prisma/skills/uncloud/SKILL.md +344 -0
  429. package/prisma/skills/unified-notifications-ops/SKILL.md +188 -0
  430. package/prisma/skills/verification-loop/SKILL.md +127 -0
  431. package/prisma/skills/video-editing/SKILL.md +311 -0
  432. package/prisma/skills/videodb/SKILL.md +375 -0
  433. package/prisma/skills/videodb/reference/api-reference.md +550 -0
  434. package/prisma/skills/videodb/reference/capture-reference.md +407 -0
  435. package/prisma/skills/videodb/reference/capture.md +101 -0
  436. package/prisma/skills/videodb/reference/editor.md +443 -0
  437. package/prisma/skills/videodb/reference/generative.md +331 -0
  438. package/prisma/skills/videodb/reference/rtstream-reference.md +564 -0
  439. package/prisma/skills/videodb/reference/rtstream.md +65 -0
  440. package/prisma/skills/videodb/reference/search.md +230 -0
  441. package/prisma/skills/videodb/reference/streaming.md +406 -0
  442. package/prisma/skills/videodb/reference/use-cases.md +118 -0
  443. package/prisma/skills/videodb/scripts/ws_listener.py +282 -0
  444. package/prisma/skills/visa-doc-translate/README.md +86 -0
  445. package/prisma/skills/visa-doc-translate/SKILL.md +117 -0
  446. package/prisma/skills/vite-patterns/SKILL.md +450 -0
  447. package/prisma/skills/vue-patterns/SKILL.md +471 -0
  448. package/prisma/skills/windows-desktop-e2e/SKILL.md +888 -0
  449. package/prisma/skills/workspace-surface-audit/SKILL.md +126 -0
  450. package/prisma/skills/x-api/SKILL.md +235 -0
  451. package/run.mjs +0 -10
@@ -0,0 +1,169 @@
1
+ ---
2
+ name: team-builder
3
+ description: Interactive agent picker for composing and dispatching parallel teams
4
+ metadata:
5
+ origin: community
6
+ ---
7
+
8
+ # Team Builder
9
+
10
+ Interactive menu for browsing and composing agent teams on demand. Works with flat or domain-subdirectory agent collections.
11
+
12
+ ## When to Use
13
+
14
+ - You have multiple agent personas (markdown files) and want to pick which ones to use for a task
15
+ - You want to compose an ad-hoc team from different domains (e.g., Security + SEO + Architecture)
16
+ - You want to browse what agents are available before deciding
17
+
18
+ ## Prerequisites
19
+
20
+ Agent files must be markdown files containing a persona prompt (identity, rules, workflow, deliverables). The first `# Heading` is used as the agent name and the first paragraph as the description.
21
+
22
+ Both flat and subdirectory layouts are supported:
23
+
24
+ **Subdirectory layout** — domain is inferred from the folder name:
25
+
26
+ ```
27
+ agents/
28
+ ├── engineering/
29
+ │ ├── security-engineer.md
30
+ │ └── software-architect.md
31
+ ├── marketing/
32
+ │ └── seo-specialist.md
33
+ └── sales/
34
+ └── discovery-coach.md
35
+ ```
36
+
37
+ **Flat layout** — domain inferred from shared filename prefixes. A prefix counts as a domain when 2+ files share it. Files with unique prefixes go to "General". Note: the algorithm splits at the first `-`, so multi-word domains (e.g., `product-management`) should use the subdirectory layout instead:
38
+
39
+ ```
40
+ agents/
41
+ ├── engineering-security-engineer.md
42
+ ├── engineering-software-architect.md
43
+ ├── marketing-seo-specialist.md
44
+ ├── marketing-content-strategist.md
45
+ ├── sales-discovery-coach.md
46
+ └── sales-outbound-strategist.md
47
+ ```
48
+
49
+ ## Configuration
50
+
51
+ Agents are discovered via two methods, merged and deduplicated by agent name:
52
+
53
+ 1. **`claude agents` command** (primary) — run `claude agents` to get all agents known to the CLI, including user agents, plugin agents (e.g. `everything-claude-code:architect`), and built-in agents. This automatically covers ECC marketplace installs without any path configuration.
54
+ 2. **File glob** (fallback, for reading agent content) — agent markdown files are read from:
55
+ - `./agents/**/*.md` + `./agents/*.md` — project-local agents
56
+ - `~/.claude/agents/**/*.md` + `~/.claude/agents/*.md` — global user agents
57
+
58
+ Earlier sources take precedence when names collide: user agents > plugin agents > built-in agents. A custom path can be used instead if the user specifies one.
59
+
60
+ ## How It Works
61
+
62
+ ### Step 1: Discover Available Agents
63
+
64
+ Run `claude agents` to get the full agent list. Parse each line:
65
+ - **Plugin agents** are prefixed with `plugin-name:` (e.g., `everything-claude-code:security-reviewer`). Use the part after `:` as the agent name and the plugin name as the domain.
66
+ - **User agents** have no prefix. Read the corresponding markdown file from `~/.claude/agents/` or `./agents/` to extract the name and description.
67
+ - **Built-in agents** (e.g., `Explore`, `Plan`) are skipped unless the user explicitly asks to include them.
68
+
69
+ For user agents loaded from markdown files:
70
+ - **Subdirectory layout:** extract the domain from the parent folder name
71
+ - **Flat layout:** collect all filename prefixes (text before the first `-`). A prefix qualifies as a domain only if it appears in 2 or more filenames (e.g., `engineering-security-engineer.md` and `engineering-software-architect.md` both start with `engineering` → Engineering domain). Files with unique prefixes (e.g., `code-reviewer.md`, `tdd-guide.md`) are grouped under "General"
72
+ - Extract the agent name from the first `# Heading`. If no heading is found, derive the name from the filename (strip `.md`, replace hyphens with spaces, title-case)
73
+ - Extract a one-line summary from the first paragraph after the heading
74
+
75
+ If no agents are found after running `claude agents` and probing file locations, inform the user: "No agents found. Run `claude agents` to verify your setup." Then stop.
76
+
77
+ ### Step 2: Present Domain Menu
78
+
79
+ ```
80
+ Available agent domains:
81
+ 1. Engineering — Software Architect, Security Engineer
82
+ 2. Marketing — SEO Specialist
83
+ 3. Sales — Discovery Coach, Outbound Strategist
84
+
85
+ Pick domains or name specific agents (e.g., "1,3" or "security + seo"):
86
+ ```
87
+
88
+ - Skip domains with zero agents (empty directories)
89
+ - Show agent count per domain
90
+
91
+ ### Step 3: Handle Selection
92
+
93
+ Accept flexible input:
94
+ - Numbers: "1,3" selects all agents from Engineering and Sales
95
+ - Names: "security + seo" fuzzy-matches against discovered agents
96
+ - "all from engineering" selects every agent in that domain
97
+
98
+ If more than 5 agents are selected, list them alphabetically and ask the user to narrow down: "You selected N agents (max 5). Pick which to keep, or say 'first 5' to use the first five alphabetically."
99
+
100
+ Confirm selection:
101
+ ```
102
+ Selected: Security Engineer + SEO Specialist
103
+ What should they work on? (describe the task):
104
+ ```
105
+
106
+ ### Step 4: Spawn Agents in Parallel
107
+
108
+ 1. Read each selected agent's markdown file
109
+ 2. Prompt for the task description if not already provided
110
+ 3. Spawn all agents in parallel using the Agent tool:
111
+ - `subagent_type: "general-purpose"`
112
+ - `prompt: "{agent file content}\n\nTask: {task description}"`
113
+ - Each agent runs independently — no inter-agent communication needed
114
+ 4. If an agent fails (error, timeout, or empty output), note the failure inline (e.g., "Security Engineer: failed — [reason]") and continue with results from agents that succeeded
115
+
116
+ ### Step 5: Synthesize Results
117
+
118
+ Collect all outputs and present a unified report:
119
+ - Results grouped by agent
120
+ - Synthesis section highlighting:
121
+ - Agreements across agents
122
+ - Conflicts or tensions between recommendations
123
+ - Recommended next steps
124
+
125
+ If only 1 agent was selected, skip synthesis and present the output directly.
126
+
127
+ ## Rules
128
+
129
+ - **Dynamic discovery only.** Never hardcode agent lists. New files in the directory auto-appear in the menu.
130
+ - **Max 5 agents per team.** More than 5 produces diminishing returns and excessive token usage. Enforce at selection time.
131
+ - **Parallel dispatch.** All agents run simultaneously — use the Agent tool's parallel invocation pattern.
132
+ - **Parallel Agent calls, not TeamCreate.** This skill uses parallel Agent tool calls for independent work. TeamCreate (a Claude Code tool for multi-agent dialogue) is only needed when agents must debate or respond to each other.
133
+
134
+ ## Examples
135
+
136
+ ```
137
+ User: team builder
138
+
139
+ Claude:
140
+ Available agent domains:
141
+ 1. Engineering (2) — Software Architect, Security Engineer
142
+ 2. Marketing (1) — SEO Specialist
143
+ 3. Sales (4) — Discovery Coach, Outbound Strategist, Proposal Strategist, Sales Engineer
144
+ 4. Support (1) — Executive Summary
145
+
146
+ Pick domains or name specific agents:
147
+
148
+ User: security + seo
149
+
150
+ Claude:
151
+ Selected: Security Engineer + SEO Specialist
152
+ What should they work on?
153
+
154
+ User: Review my Next.js e-commerce site before launch
155
+
156
+ [Both agents spawn in parallel, each applying their specialty to the codebase]
157
+
158
+ Claude:
159
+ ## Security Engineer Findings
160
+ - [findings...]
161
+
162
+ ## SEO Specialist Findings
163
+ - [findings...]
164
+
165
+ ## Synthesis
166
+ Both agents agree on: [...]
167
+ Tension: Security recommends CSP that blocks inline styles, SEO needs inline schema markup. Resolution: [...]
168
+ Next steps: [...]
169
+ ```
@@ -0,0 +1,110 @@
1
+ ---
2
+ name: terminal-ops
3
+ description: Evidence-first repo execution workflow for ECC. Use when the user wants a command run, a repo checked, a CI failure debugged, or a narrow fix pushed with exact proof of what was executed and verified.
4
+ metadata:
5
+ origin: ECC
6
+ ---
7
+
8
+ # Terminal Ops
9
+
10
+ Use this when the user wants real repo execution: run commands, inspect git state, debug CI or builds, make a narrow fix, and report exactly what changed and what was verified.
11
+
12
+ This skill is intentionally narrower than general coding guidance. It is an operator workflow for evidence-first terminal execution.
13
+
14
+ ## Skill Stack
15
+
16
+ Pull these ECC-native skills into the workflow when relevant:
17
+
18
+ - `verification-loop` for exact proving steps after changes
19
+ - `tdd-workflow` when the right fix needs regression coverage
20
+ - `security-review` when secrets, auth, or external inputs are involved
21
+ - `github-ops` when the task depends on CI runs, PR state, or release status
22
+ - `knowledge-ops` when the verified outcome needs to be captured into durable project context
23
+
24
+ ## When to Use
25
+
26
+ - user says "fix", "debug", "run this", "check the repo", or "push it"
27
+ - the task depends on command output, git state, test results, or a verified local fix
28
+ - the answer must distinguish changed locally, verified locally, committed, and pushed
29
+
30
+ ## Guardrails
31
+
32
+ - inspect before editing
33
+ - stay read-only if the user asked for audit/review only
34
+ - prefer repo-local scripts and helpers over improvised ad hoc wrappers
35
+ - do not claim fixed until the proving command was rerun
36
+ - do not claim pushed unless the branch actually moved upstream
37
+
38
+ ## Workflow
39
+
40
+ ### 1. Resolve the working surface
41
+
42
+ Settle:
43
+
44
+ - exact repo path
45
+ - branch
46
+ - local diff state
47
+ - requested mode:
48
+ - inspect
49
+ - fix
50
+ - verify
51
+ - push
52
+
53
+ ### 2. Read the failing surface first
54
+
55
+ Before changing anything:
56
+
57
+ - inspect the error
58
+ - inspect the file or test
59
+ - inspect git state
60
+ - use any already-supplied logs or context before re-reading blindly
61
+
62
+ ### 3. Keep the fix narrow
63
+
64
+ Solve one dominant failure at a time:
65
+
66
+ - use the smallest useful proving command first
67
+ - only escalate to a bigger build/test pass after the local failure is addressed
68
+ - if a command keeps failing with the same signature, stop broad retries and narrow scope
69
+
70
+ ### 4. Report exact execution state
71
+
72
+ Use exact status words:
73
+
74
+ - inspected
75
+ - changed locally
76
+ - verified locally
77
+ - committed
78
+ - pushed
79
+ - blocked
80
+
81
+ ## Output Format
82
+
83
+ ```text
84
+ SURFACE
85
+ - repo
86
+ - branch
87
+ - requested mode
88
+
89
+ EVIDENCE
90
+ - failing command / diff / test
91
+
92
+ ACTION
93
+ - what changed
94
+
95
+ STATUS
96
+ - inspected / changed locally / verified locally / committed / pushed / blocked
97
+ ```
98
+
99
+ ## Pitfalls
100
+
101
+ - do not work from stale memory when the live repo state can be read
102
+ - do not widen a narrow fix into repo-wide churn
103
+ - do not use destructive git commands
104
+ - do not ignore unrelated local work
105
+
106
+ ## Verification
107
+
108
+ - the response names the proving command or test
109
+ - git-related work names the repo path and branch
110
+ - any push claim includes the target branch and exact result
@@ -0,0 +1,279 @@
1
+ ---
2
+ name: tinystruct-patterns
3
+ description: Expert guidance for developing with the tinystruct Java framework. Use when working on the tinystruct codebase or any project built on tinystruct — including creating Application classes, @Action-mapped routes, unit tests, ActionRegistry, HTTP/CLI dual-mode handling, the built-in HTTP server, the event system, JSON with Builder/Builders, database persistence with AbstractData, POJO generation, Server-Sent Events (SSE), file uploads, and outbound HTTP networking.
4
+ metadata:
5
+ origin: ECC
6
+ ---
7
+
8
+ # tinystruct Development Patterns
9
+
10
+ Architecture and implementation patterns for building modules with the **tinystruct** Java framework – a lightweight, high-performance framework that treats CLI and HTTP as equal citizens, requiring no `main()` method and minimal configuration.
11
+
12
+ ## Core Principle
13
+
14
+ **CLI and HTTP are equal citizens.** Every method annotated with `@Action` should ideally be runnable from both a terminal and a web browser without modification. This "dual-mode" capability is the core design philosophy of tinystruct.
15
+
16
+ ## When to Activate
17
+
18
+ ### When to Use
19
+
20
+ - Creating new `Application` modules by extending `AbstractApplication`.
21
+ - Defining routes and command-line actions using `@Action`.
22
+ - Handling per-request state via `Context`.
23
+ - Performing JSON serialization using the native `Builder` and `Builders` components.
24
+ - Working with database persistence via `AbstractData` POJOs.
25
+ - Generating POJOs from database tables using the `generate` command.
26
+ - Implementing Server-Sent Events (SSE) for real-time push.
27
+ - Handling file uploads via multipart data.
28
+ - Making outbound HTTP requests with `URLRequest` and `HTTPHandler`.
29
+ - Configuring database connections or system settings in `application.properties`.
30
+ - Debugging routing conflicts (Actions) or CLI argument parsing.
31
+
32
+ ## How It Works
33
+
34
+ The tinystruct framework treats any method annotated with `@Action` as a routable endpoint for both terminal and web environments. Applications are created by extending `AbstractApplication`, which provides core lifecycle hooks like `init()` and access to the request `Context`.
35
+
36
+ Routing is handled by the `ActionRegistry`, which automatically maps path segments to method arguments and injects dependencies. For data-only services, the native `Builder` and `Builders` components should be used for JSON serialization to maintain a zero-dependency footprint. The database layer uses `AbstractData` POJOs paired with XML mapping files for CRUD operations without external ORM libraries.
37
+
38
+ ## Examples
39
+
40
+ ### Basic Application (MyService)
41
+ ```java
42
+ public class MyService extends AbstractApplication {
43
+ @Override
44
+ public void init() {
45
+ this.setTemplateRequired(false); // Disable .view lookup for data/API apps
46
+ }
47
+
48
+ @Override public String version() { return "1.0.0"; }
49
+
50
+ @Action("greet")
51
+ public String greet() {
52
+ return "Hello from tinystruct!";
53
+ }
54
+
55
+ // Path parameter: GET /?q=greet/James OR bin/dispatcher greet/James
56
+ @Action("greet")
57
+ public String greet(String name) {
58
+ return "Hello, " + name + "!";
59
+ }
60
+ }
61
+ ```
62
+
63
+ ### HTTP Mode Disambiguation (login)
64
+ ```java
65
+ @Action(value = "login", mode = Mode.HTTP_POST)
66
+ public String doLogin(Request<?, ?> request) throws ApplicationException {
67
+ request.getSession().setAttribute("userId", "42");
68
+ return "Logged in";
69
+ }
70
+ ```
71
+
72
+ ### Native JSON Data Handling (Builder + Builders)
73
+ ```java
74
+ import org.tinystruct.data.component.Builder;
75
+ import org.tinystruct.data.component.Builders;
76
+
77
+ @Action("api/data")
78
+ public String getData() throws ApplicationException {
79
+ Builders dataList = new Builders();
80
+ Builder item = new Builder();
81
+ item.put("id", 1);
82
+ item.put("name", "James");
83
+ dataList.add(item);
84
+
85
+ Builder response = new Builder();
86
+ response.put("status", "success");
87
+ response.put("data", dataList);
88
+ return response.toString(); // {"status":"success","data":[{"id":1,"name":"James"}]}
89
+ }
90
+ ```
91
+
92
+ ### SSE (Server-Sent Events)
93
+ ```java
94
+ import org.tinystruct.http.SSEPushManager;
95
+
96
+ @Action("sse/connect")
97
+ public String connect() {
98
+ return "{\"type\":\"connect\",\"message\":\"Connected to SSE\"}";
99
+ }
100
+
101
+ // Push to a specific client
102
+ String sessionId = getContext().getId();
103
+ Builder msg = new Builder();
104
+ msg.put("text", "Hello, user!");
105
+ SSEPushManager.getInstance().push(sessionId, msg);
106
+
107
+ // Broadcast to all
108
+ // Broadcast to all
109
+ SSEPushManager.getInstance().broadcast(msg);
110
+ ```
111
+
112
+ ### File Upload
113
+ ```java
114
+ import org.tinystruct.data.FileEntity;
115
+
116
+ @Action(value = "upload", mode = Mode.HTTP_POST)
117
+ public String upload(Request<?, ?> request) throws ApplicationException {
118
+ List<FileEntity> files = request.getAttachments();
119
+ if (files != null) {
120
+ for (FileEntity file : files) {
121
+ System.out.println("Uploaded: " + file.getFilename());
122
+ }
123
+ }
124
+ return "Upload OK";
125
+ }
126
+ ```
127
+
128
+ ## MCP Server and Tools Integration
129
+
130
+ tinystruct provides native support for the Model Context Protocol (MCP) starting with SDK version **`1.7.26`**.
131
+ The MCP APIs (e.g., `org.tinystruct.mcp.MCPTool`, `org.tinystruct.mcp.MCPServer`, `org.tinystruct.mcp.MCPException`) are included directly in the core dependency:
132
+ ```xml
133
+ <dependency>
134
+ <groupId>org.tinystruct</groupId>
135
+ <artifactId>tinystruct</artifactId>
136
+ <version>1.7.26</version>
137
+ </dependency>
138
+ ```
139
+
140
+ > **SECURITY WARNING (Prompt Injection):**
141
+ > Tool return values are fed directly back into the AI model's context window. You **MUST** validate and sanitize all caller-supplied arguments before including them in the tool's return string. Failure to sanitize inputs can allow an attacker to inject adversarial instructions (Prompt Injection) that override the model's behavior. Always validate length, character sets, and nullity.
142
+
143
+ **To create an MCP Tool:**
144
+ 1. Extend `org.tinystruct.mcp.MCPTool`.
145
+ 2. Annotate operations with `@Action` and declare parameters using `@Argument` within the `arguments` array.
146
+ 3. Accept parameters as explicit method arguments matching the keys in `@Argument`. (Do **not** use `getContext().getAttribute(...)` for tool arguments).
147
+
148
+ ```java
149
+ import org.tinystruct.mcp.MCPTool;
150
+ import org.tinystruct.mcp.MCPException;
151
+ import org.tinystruct.system.annotation.Action;
152
+ import org.tinystruct.system.annotation.Argument;
153
+
154
+ public class MyCustomTool extends MCPTool {
155
+ public MyCustomTool() {
156
+ super("custom", "A custom tool for demonstrating MCP");
157
+ }
158
+
159
+ @Action(
160
+ value = "custom/hello",
161
+ description = "Say hello to someone",
162
+ arguments = {
163
+ @Argument(key = "name", description = "The name to greet", type = "string", optional = false)
164
+ }
165
+ )
166
+ public String hello(String name) throws MCPException {
167
+ // SECURITY: Validate/sanitize tool inputs before returning to the model
168
+ // to prevent prompt injection vulnerabilities.
169
+ if (name == null || name.length() > 50 || !name.matches("^[a-zA-Z0-9 ]+$")) {
170
+ throw new MCPException("Invalid name provided");
171
+ }
172
+ return "Hello, " + name + "!";
173
+ }
174
+ }
175
+ ```
176
+
177
+ **To deploy an MCP Server:**
178
+ 1. Extend `org.tinystruct.mcp.MCPServer`.
179
+ 2. Override `init()` and register your tools using `this.registerTool()`. The framework automatically scans and maps the `@Action` methods.
180
+
181
+ ```java
182
+ import org.tinystruct.mcp.MCPServer;
183
+
184
+ public class MyMCPServer extends MCPServer {
185
+ @Override
186
+ public void init() {
187
+ super.init();
188
+ this.registerTool(new MyCustomTool());
189
+ }
190
+
191
+ @Override
192
+ public String version() {
193
+ return "1.0.0";
194
+ }
195
+ }
196
+ ```
197
+
198
+ Run the server via the dispatcher:
199
+ ```bash
200
+ bin/dispatcher start --import org.tinystruct.system.HttpServer --import com.example.MyMCPServer
201
+ ```
202
+
203
+ ## Configuration
204
+
205
+ Settings are managed in `src/main/resources/application.properties`.
206
+
207
+ ```properties
208
+ # Database
209
+ driver=org.h2.Driver
210
+ database.url=jdbc:h2:~/mydb
211
+ database.user=sa
212
+ database.password=
213
+
214
+ # Server
215
+ default.home.page=hello
216
+ server.port=8080
217
+
218
+ # Locale
219
+ default.language=en_US
220
+
221
+ # Session (Redis for clustered environments)
222
+ # default.session.repository=org.tinystruct.http.RedisSessionRepository
223
+ # redis.host=127.0.0.1
224
+ # redis.port=6379
225
+ ```
226
+
227
+ Access config values in your application:
228
+ ```java
229
+ String port = this.getConfiguration("server.port");
230
+ ```
231
+
232
+ ## Red Flags & Anti-patterns
233
+
234
+ | Symptom | Correct Pattern |
235
+ |---|---|
236
+ | Importing `com.google.gson` or `com.fasterxml.jackson` | Use `org.tinystruct.data.component.Builder` / `Builders`. |
237
+ | Using `List<Builder>` for JSON arrays | Use `Builders` to avoid generic type erasure issues. |
238
+ | `ApplicationRuntimeException: template not found` | Call `setTemplateRequired(false)` in `init()` for API-only apps. |
239
+ | Annotating `private` methods with `@Action` | Actions must be `public` to be registered by the framework. |
240
+ | Hardcoding `main(String[] args)` in apps | Use `bin/dispatcher` as the entry point for all modules. |
241
+ | Manual `ActionRegistry` registration | Prefer the `@Action` annotation for automatic discovery. |
242
+ | Action not found at runtime | Ensure class is imported via `--import` or listed in `application.properties`. |
243
+ | CLI arg not visible | Pass with `--key value`; access via `getContext().getAttribute("--key")`. |
244
+ | Two methods same path, wrong one fires | Set explicit `mode` (e.g., `HTTP_GET` vs `HTTP_POST`) to disambiguate. |
245
+
246
+ ## Best Practices
247
+
248
+ 1. **Granular Applications**: Break logic into smaller, focused applications rather than one monolithic class.
249
+ 2. **Setup in `init()`**: Leverage `init()` for setup (config, DB) rather than the constructor. Do NOT call `setAction()` — use `@Action` annotation.
250
+ 3. **Mode Awareness**: Use the `Mode` parameter in `@Action` to restrict sensitive operations to `CLI` only or specific HTTP methods.
251
+ 4. **Context over Params**: For optional CLI flags, use `getContext().getAttribute("--flag")` rather than adding parameters to the method signature.
252
+ 5. **Asynchronous Events**: For heavy tasks triggered by events, use `CompletableFuture.runAsync()` inside the event handler.
253
+
254
+ ## Technical Reference
255
+
256
+ Detailed guides are available in the `references/` directory:
257
+
258
+ - [Architecture & Config](references/architecture.md) — Abstractions, Package Map, Properties
259
+ - [Routing & @Action](references/routing.md) — Annotation details, Modes, Parameters
260
+ - [Data Handling](references/data-handling.md) — Builder, Builders, JSON serialization & parsing
261
+ - [Database Persistence](references/database.md) — AbstractData POJOs, CRUD, mapping XML, POJO generation
262
+ - [System & Usage](references/system-usage.md) — Context, Sessions, SSE, File Uploads, Events, Networking
263
+ - [Testing Patterns](references/testing.md) — JUnit 5 unit and HTTP integration testing
264
+
265
+ ## Reference Source Files (Internal)
266
+
267
+ - `src/main/java/org/tinystruct/AbstractApplication.java` — Core base class with lifecycle hooks
268
+ - `src/main/java/org/tinystruct/system/annotation/Action.java` — Annotation & Modes
269
+ - `src/main/java/org/tinystruct/application/ActionRegistry.java` — Routing Engine
270
+ - `src/main/java/org/tinystruct/data/component/Builder.java` — JSON object serializer
271
+ - `src/main/java/org/tinystruct/data/component/Builders.java` — JSON array serializer
272
+ - `src/main/java/org/tinystruct/data/component/AbstractData.java` — Base POJO class with CRUD
273
+ - `src/main/java/org/tinystruct/data/Mapping.java` — Mapping XML parser
274
+ - `src/main/java/org/tinystruct/data/tools/MySQLGenerator.java` — POJO generator reference
275
+ - `src/main/java/org/tinystruct/data/component/FieldType.java` — SQL-to-Java type mappings
276
+ - `src/main/java/org/tinystruct/data/component/Condition.java` — Fluent SQL query builder
277
+ - `src/main/java/org/tinystruct/http/SSEPushManager.java` — SSE connection management
278
+ - `src/test/java/org/tinystruct/application/ActionRegistryTest.java` — Registry test examples
279
+ - `src/test/java/org/tinystruct/system/HttpServerHttpModeTest.java` — HTTP integration test patterns
@@ -0,0 +1,90 @@
1
+ # tinystruct Architecture and Configuration
2
+
3
+ ## When to Use
4
+
5
+ Choose **tinystruct** when you need a lightweight, high-performance Java framework that treats CLI and HTTP as equal citizens. Ideal for microservices, CLI utilities, and data-driven applications with a small footprint and zero-dependency JSON handling.
6
+
7
+ ## How It Works
8
+
9
+ ### Core Architecture
10
+
11
+ The framework operates on a singleton `ActionRegistry` that maps URL patterns (or command strings) to `Action` objects. When a request arrives, the system resolves the path and invokes the corresponding method handle.
12
+
13
+ #### Key Abstractions
14
+
15
+ | Class/Interface | Role |
16
+ |---|---|
17
+ | `AbstractApplication` | Base class for all tinystruct applications. Extend this. |
18
+ | `@Action` annotation | Maps a method to a URI path (web) or command name (CLI). The single routing primitive. |
19
+ | `ActionRegistry` | Singleton that maps URL patterns to `Action` objects via regex. Never instantiate directly. |
20
+ | `Action` | Wraps a `MethodHandle` + regex pattern + priority + `Mode` for dispatch. |
21
+ | `Context` | Per-request state store. Access via `getContext()`. Holds CLI args and HTTP request/response. |
22
+ | `Dispatcher` | CLI entry point (`bin/dispatcher`). Reads `--import` to load applications. |
23
+ | `HttpServer` | Built-in HTTP server. Start with `bin/dispatcher start --import org.tinystruct.system.HttpServer`. |
24
+
25
+ ### Package Map
26
+
27
+ ```
28
+ org.tinystruct/
29
+ ├── AbstractApplication.java ← extend this
30
+ ├── Application.java ← interface
31
+ ├── ApplicationException.java ← checked exception
32
+ ├── ApplicationRuntimeException.java ← unchecked exception
33
+ ├── application/
34
+ │ ├── Action.java ← runtime action wrapper
35
+ │ ├── ActionRegistry.java ← singleton route registry
36
+ │ └── Context.java ← request context
37
+ ├── system/
38
+ │ ├── annotation/Action.java ← @Action annotation + Mode enum
39
+ │ ├── Dispatcher.java ← CLI dispatcher
40
+ │ ├── HttpServer.java ← built-in HTTP server
41
+ │ ├── EventDispatcher.java ← event bus
42
+ │ └── Settings.java ← reads application.properties
43
+ ├── data/
44
+ │ ├── component/Builder.java ← JSON object (use instead of Gson/Jackson)
45
+ │ ├── component/Builders.java ← JSON array
46
+ │ ├── component/AbstractData.java ← base POJO for DB persistence
47
+ │ ├── component/Condition.java ← fluent SQL query builder
48
+ │ ├── component/FieldType.java ← SQL-to-Java type mappings
49
+ │ ├── Mapping.java ← reads .map.xml metadata
50
+ │ ├── DatabaseOperator.java ← low-level JDBC wrapper
51
+ │ └── FileEntity.java ← file upload representation
52
+ ├── http/ ← Request, Response, Constants
53
+ │ └── SSEPushManager.java ← Server-Sent Events management
54
+ └── net/ ← URLRequest, HTTPHandler (outbound HTTP)
55
+ ```
56
+
57
+ ### Template Behavior and Dispatch Flow
58
+
59
+ By default, the framework assumes a view template is required. If `templateRequired` is `true`, `toString()` looks for a `.view` file in `src/main/resources/themes/<ClassName>.view`. Use `setVariable("name", value)` to pass data to templates, which use `{%name%}` for interpolation.
60
+
61
+ ## Examples
62
+
63
+ ### Minimal Application Initialization
64
+ ```java
65
+ @Override
66
+ public void init() {
67
+ this.setTemplateRequired(false); // Skip .view template lookup for data-only apps
68
+ // Do NOT call setAction() here — use @Action annotation instead
69
+ }
70
+ ```
71
+
72
+ ### Action Definition and CLI Invocation
73
+ ```java
74
+ @Action("hello")
75
+ public String hello() {
76
+ return "Hello, tinystruct!";
77
+ }
78
+ ```
79
+ **Execution via Dispatcher:**
80
+ ```bash
81
+ bin/dispatcher hello
82
+ bin/dispatcher greet/James
83
+ bin/dispatcher echo --words "Hello" --import com.example.HelloApp
84
+ ```
85
+
86
+ ### Configuration Access
87
+ Located at `src/main/resources/application.properties`:
88
+ ```java
89
+ String port = this.getConfiguration("server.port");
90
+ ```