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,154 @@
1
+ ---
2
+ name: agent-introspection-debugging
3
+ description: Structured self-debugging workflow for AI agent failures using capture, diagnosis, contained recovery, and introspection reports.
4
+ metadata:
5
+ origin: ECC
6
+ ---
7
+
8
+ # Agent Introspection Debugging
9
+
10
+ Use this skill when an agent run is failing repeatedly, consuming tokens without progress, looping on the same tools, or drifting away from the intended task.
11
+
12
+ This is a workflow skill, not a hidden runtime. It teaches the agent to debug itself systematically before escalating to a human.
13
+
14
+ ## When to Activate
15
+
16
+ - Maximum tool call / loop-limit failures
17
+ - Repeated retries with no forward progress
18
+ - Context growth or prompt drift that starts degrading output quality
19
+ - File-system or environment state mismatch between expectation and reality
20
+ - Tool failures that are likely recoverable with diagnosis and a smaller corrective action
21
+
22
+ ## Scope Boundaries
23
+
24
+ Activate this skill for:
25
+ - capturing failure state before retrying blindly
26
+ - diagnosing common agent-specific failure patterns
27
+ - applying contained recovery actions
28
+ - producing a structured human-readable debug report
29
+
30
+ Do not use this skill as the primary source for:
31
+ - feature verification after code changes; use `verification-loop`
32
+ - framework-specific debugging when a narrower ECC skill already exists
33
+ - runtime promises the current harness cannot enforce automatically
34
+
35
+ ## Four-Phase Loop
36
+
37
+ ### Phase 1: Failure Capture
38
+
39
+ Before trying to recover, record the failure precisely.
40
+
41
+ Capture:
42
+ - error type, message, and stack trace when available
43
+ - last meaningful tool call sequence
44
+ - what the agent was trying to do
45
+ - current context pressure: repeated prompts, oversized pasted logs, duplicated plans, or runaway notes
46
+ - current environment assumptions: cwd, branch, relevant service state, expected files
47
+
48
+ Minimum capture template:
49
+
50
+ ```markdown
51
+ ## Failure Capture
52
+ - Session / task:
53
+ - Goal in progress:
54
+ - Error:
55
+ - Last successful step:
56
+ - Last failed tool / command:
57
+ - Repeated pattern seen:
58
+ - Environment assumptions to verify:
59
+ ```
60
+
61
+ ### Phase 2: Root-Cause Diagnosis
62
+
63
+ Match the failure to a known pattern before changing anything.
64
+
65
+ | Pattern | Likely Cause | Check |
66
+ | --- | --- | --- |
67
+ | Maximum tool calls / repeated same command | loop or no-exit observer path | inspect the last N tool calls for repetition |
68
+ | Context overflow / degraded reasoning | unbounded notes, repeated plans, oversized logs | inspect recent context for duplication and low-signal bulk |
69
+ | `ECONNREFUSED` / timeout | service unavailable or wrong port | verify service health, URL, and port assumptions |
70
+ | `429` / quota exhaustion | retry storm or missing backoff | count repeated calls and inspect retry spacing |
71
+ | file missing after write / stale diff | race, wrong cwd, or branch drift | re-check path, cwd, git status, and actual file existence |
72
+ | tests still failing after “fix” | wrong hypothesis | isolate the exact failing test and re-derive the bug |
73
+
74
+ Diagnosis questions:
75
+ - is this a logic failure, state failure, environment failure, or policy failure?
76
+ - did the agent lose the real objective and start optimizing the wrong subtask?
77
+ - is the failure deterministic or transient?
78
+ - what is the smallest reversible action that would validate the diagnosis?
79
+
80
+ ### Phase 3: Contained Recovery
81
+
82
+ Recover with the smallest action that changes the diagnosis surface.
83
+
84
+ Safe recovery actions:
85
+ - stop repeated retries and restate the hypothesis
86
+ - trim low-signal context and keep only the active goal, blockers, and evidence
87
+ - re-check the actual filesystem / branch / process state
88
+ - narrow the task to one failing command, one file, or one test
89
+ - switch from speculative reasoning to direct observation
90
+ - escalate to a human when the failure is high-risk or externally blocked
91
+
92
+ Do not claim unsupported auto-healing actions like “reset agent state” or “update harness config” unless you are actually doing them through real tools in the current environment.
93
+
94
+ Contained recovery checklist:
95
+
96
+ ```markdown
97
+ ## Recovery Action
98
+ - Diagnosis chosen:
99
+ - Smallest action taken:
100
+ - Why this is safe:
101
+ - What evidence would prove the fix worked:
102
+ ```
103
+
104
+ ### Phase 4: Introspection Report
105
+
106
+ End with a report that makes the recovery legible to the next agent or human.
107
+
108
+ ```markdown
109
+ ## Agent Self-Debug Report
110
+ - Session / task:
111
+ - Failure:
112
+ - Root cause:
113
+ - Recovery action:
114
+ - Result: success | partial | blocked
115
+ - Token / time burn risk:
116
+ - Follow-up needed:
117
+ - Preventive change to encode later:
118
+ ```
119
+
120
+ ## Recovery Heuristics
121
+
122
+ Prefer these interventions in order:
123
+
124
+ 1. Restate the real objective in one sentence.
125
+ 2. Verify the world state instead of trusting memory.
126
+ 3. Shrink the failing scope.
127
+ 4. Run one discriminating check.
128
+ 5. Only then retry.
129
+
130
+ Bad pattern:
131
+ - retrying the same action three times with slightly different wording
132
+
133
+ Good pattern:
134
+ - capture failure
135
+ - classify the pattern
136
+ - run one direct check
137
+ - change the plan only if the check supports it
138
+
139
+ ## Integration with ECC
140
+
141
+ - Use `verification-loop` after recovery if code was changed.
142
+ - Use `continuous-learning-v2` when the failure pattern is worth turning into an instinct or later skill.
143
+ - Use `council` when the issue is not technical failure but decision ambiguity.
144
+ - Use `workspace-surface-audit` if the failure came from conflicting local state or repo drift.
145
+
146
+ ## Output Standard
147
+
148
+ When this skill is active, do not end with “I fixed it” alone.
149
+
150
+ Always provide:
151
+ - the failure pattern
152
+ - the root-cause hypothesis
153
+ - the recovery action
154
+ - the evidence that the situation is now better or still blocked
@@ -0,0 +1,225 @@
1
+ ---
2
+ name: agent-payment-x402
3
+ description: Add x402 payment execution to AI agents with per-task budgets, spending controls, and non-custodial wallets. Supports Base through agentwallet-sdk and X Layer through OKX Payments / OKX Agent Payments Protocol.
4
+ metadata:
5
+ origin: community
6
+ ---
7
+
8
+ # Agent Payment Execution (x402)
9
+
10
+ Enable AI agents to make policy-gated payments with built-in spending controls. Uses the x402 HTTP payment protocol and MCP tools so agents can pay for external services, APIs, or other agents without custodial risk.
11
+
12
+ ## When to Use
13
+
14
+ Use when: your agent needs to pay for an API call, purchase a service, settle with another agent, enforce per-task spending limits, or manage a non-custodial wallet. Pairs naturally with cost-aware-llm-pipeline and security-review skills.
15
+
16
+ ## Decision Tree
17
+
18
+ Choose the integration path based on whether your agent is buying access to a paid API or charging others for one:
19
+
20
+ | Need | Recommended path |
21
+ |------|------------------|
22
+ | Agent pays a 402-gated API on Base or another agentwallet-supported chain | Use `agentwallet-sdk` as an MCP payment server with strict spending policy |
23
+ | Agent pays a 402-gated API on X Layer | Use OKX Agent Payments Protocol from `okx/onchainos-skills`; `okx-x402-payment` is a deprecated legacy alias |
24
+ | TypeScript API charges agents | Use OKX Payments TypeScript seller SDK docs for Express, Hono, Fastify, or Next.js |
25
+ | Go API charges agents | Use OKX Payments Go seller SDK docs for Gin, Echo, or `net/http` |
26
+ | Rust API charges agents | Use OKX Payments Rust seller SDK docs for Axum |
27
+ | Java API charges agents | Use OKX Payments Java seller SDK docs for Spring Boot 2/3, Java EE, or Jakarta |
28
+ | Python API charges agents | Check the current OKX Payments repository before implementation; a Python seller guide may not be available |
29
+
30
+ ## Supported Networks
31
+
32
+ - `agentwallet-sdk`: use the package docs to confirm current network coverage before production. Base Sepolia is the safest development default; Base mainnet is the production path called out by the original skill.
33
+ - OKX Payments / X Layer: current seller docs target X Layer (`eip155:196`) and USDT0 settlement. Fetch current SDK docs before generating production code because payment packages and facilitator behavior can change quickly.
34
+
35
+ ## How It Works
36
+
37
+ ### x402 Protocol
38
+ x402 extends HTTP 402 (Payment Required) into a machine-negotiable flow. When a server returns `402`, the agent's payment tool negotiates price, checks budget, signs a transaction, and retries only inside the policy and confirmation boundary set by the orchestrator.
39
+
40
+ ### Spending Controls
41
+ Every payment tool call enforces a `SpendingPolicy`:
42
+ - **Per-task budget** — max spend for a single agent action
43
+ - **Per-session budget** — cumulative limit across an entire session
44
+ - **Allowlisted recipients** — restrict which addresses/services the agent can pay
45
+ - **Rate limits** — max transactions per minute/hour
46
+
47
+ ### Non-Custodial Wallets
48
+ Agents hold their own keys via ERC-4337 smart accounts. The orchestrator sets policy before delegation; the agent can only spend within bounds. No pooled funds, no custodial risk.
49
+
50
+ ## MCP Integration
51
+
52
+ The payment layer exposes standard MCP tools that slot into any Claude Code or agent harness setup.
53
+
54
+ > **Security note**: Always pin the package version. This tool manages private keys — unpinned `npx` installs introduce supply-chain risk.
55
+
56
+ ### Option A: agentwallet-sdk (Base / multi-chain)
57
+
58
+ ```json
59
+ {
60
+ "mcpServers": {
61
+ "agentpay": {
62
+ "command": "npx",
63
+ "args": ["agentwallet-sdk@6.0.0"]
64
+ }
65
+ }
66
+ }
67
+ ```
68
+
69
+ ### Available Tools (agent-callable)
70
+
71
+ | Tool | Purpose |
72
+ |------|---------|
73
+ | `get_balance` | Check agent wallet balance |
74
+ | `send_payment` | Send payment to address or ENS |
75
+ | `check_spending` | Query remaining budget |
76
+ | `list_transactions` | Audit trail of all payments |
77
+
78
+ > **Note**: Spending policy is set by the **orchestrator** before delegating to the agent — not by the agent itself. This prevents agents from escalating their own spending limits. Configure policy via `set_policy` in your orchestration layer or pre-task hook, never as an agent-callable tool.
79
+
80
+ ### Option B: OKX Agent Payments Protocol (X Layer)
81
+
82
+ Use this path for X Layer x402, Multi-Party Payment (MPP), session payment, charge, and A2A charge flows.
83
+
84
+ For buyer-side agent flows:
85
+
86
+ 1. Install or reference the current `okx/onchainos-skills` repository.
87
+ 2. Use `skills/okx-agent-payments-protocol/SKILL.md` as the dispatcher.
88
+ 3. Treat `skills/okx-x402-payment/SKILL.md` as a deprecated compatibility alias, not as the canonical skill.
89
+ 4. Require explicit user confirmation before wallet status checks or payment actions. Do not hide payment execution behind a generic tool call.
90
+
91
+ For seller-side API flows, fetch the latest language-specific guide before generating code:
92
+
93
+ | Runtime | Current guide |
94
+ |---------|---------------|
95
+ | TypeScript | `https://raw.githubusercontent.com/okx/payments/main/typescript/SELLER.md` |
96
+ | Go | `https://raw.githubusercontent.com/okx/payments/main/go/x402/SELLER.md` |
97
+ | Rust | `https://raw.githubusercontent.com/okx/payments/main/rust/x402/SELLER.md` |
98
+ | Java | `https://raw.githubusercontent.com/okx/payments/main/java/SELLER.md` |
99
+
100
+ Do not copy examples from older docs without checking the current OKX repository. Current OKX guidance uses `okx-agent-payments-protocol` as the dispatcher, and Java seller docs are now available.
101
+
102
+ ## Examples
103
+
104
+ ### Budget enforcement in an MCP client
105
+
106
+ When building an orchestrator that calls the agentpay MCP server, enforce budgets before dispatching paid tool calls.
107
+
108
+ > **Prerequisites**: Install the package before adding the MCP config — `npx` without `-y` will prompt for confirmation in non-interactive environments, causing the server to hang: `npm install -g agentwallet-sdk@6.0.0`
109
+
110
+ ```typescript
111
+ import { Client } from "@modelcontextprotocol/sdk/client/index.js";
112
+ import { StdioClientTransport } from "@modelcontextprotocol/sdk/client/stdio.js";
113
+
114
+ async function main() {
115
+ // 1. Validate credentials before constructing the transport.
116
+ // A missing key must fail immediately — never let the subprocess start without auth.
117
+ const walletKey = process.env.WALLET_PRIVATE_KEY;
118
+ if (!walletKey) {
119
+ throw new Error("WALLET_PRIVATE_KEY is not set — refusing to start payment server");
120
+ }
121
+
122
+ // Connect to the agentpay MCP server via stdio transport.
123
+ // Whitelist only the env vars the server needs — never forward all of process.env
124
+ // to a third-party subprocess that manages private keys.
125
+ const transport = new StdioClientTransport({
126
+ command: "npx",
127
+ args: ["agentwallet-sdk@6.0.0"],
128
+ env: {
129
+ PATH: process.env.PATH ?? "",
130
+ NODE_ENV: process.env.NODE_ENV ?? "production",
131
+ WALLET_PRIVATE_KEY: walletKey,
132
+ },
133
+ });
134
+ const agentpay = new Client({ name: "orchestrator", version: "1.0.0" });
135
+ await agentpay.connect(transport);
136
+
137
+ // 2. Set spending policy before delegating to the agent.
138
+ // Always verify success — a silent failure means no controls are active.
139
+ const policyResult = await agentpay.callTool({
140
+ name: "set_policy",
141
+ arguments: {
142
+ per_task_budget: 0.50,
143
+ per_session_budget: 5.00,
144
+ allowlisted_recipients: ["api.example.com"],
145
+ },
146
+ });
147
+ if (policyResult.isError) {
148
+ throw new Error(
149
+ `Failed to set spending policy — do not delegate: ${JSON.stringify(policyResult.content)}`
150
+ );
151
+ }
152
+
153
+ // 3. Use preToolCheck before any paid action
154
+ await preToolCheck(agentpay, 0.01);
155
+ }
156
+
157
+ // Pre-tool hook: fail-closed budget enforcement with four distinct error paths.
158
+ async function preToolCheck(agentpay: Client, apiCost: number): Promise<void> {
159
+ // Path 1: Reject invalid input (NaN/Infinity bypass the < comparison)
160
+ if (!Number.isFinite(apiCost) || apiCost < 0) {
161
+ throw new Error(`Invalid apiCost: ${apiCost} — action blocked`);
162
+ }
163
+
164
+ // Path 2: Transport/connectivity failure
165
+ let result;
166
+ try {
167
+ result = await agentpay.callTool({ name: "check_spending" });
168
+ } catch (err) {
169
+ throw new Error(`Payment service unreachable — action blocked: ${err}`);
170
+ }
171
+
172
+ // Path 3: Tool returned an error (e.g., auth failure, wallet not initialised)
173
+ if (result.isError) {
174
+ throw new Error(
175
+ `check_spending failed — action blocked: ${JSON.stringify(result.content)}`
176
+ );
177
+ }
178
+
179
+ // Path 4: Parse and validate the response shape
180
+ let remaining: number;
181
+ try {
182
+ const parsed = JSON.parse(
183
+ (result.content as Array<{ text: string }>)[0].text
184
+ );
185
+ if (!Number.isFinite(parsed?.remaining)) {
186
+ throw new TypeError("missing or non-finite 'remaining' field");
187
+ }
188
+ remaining = parsed.remaining;
189
+ } catch (err) {
190
+ throw new Error(
191
+ `check_spending returned unexpected format — action blocked: ${err}`
192
+ );
193
+ }
194
+
195
+ // Path 5: Budget exceeded
196
+ if (remaining < apiCost) {
197
+ throw new Error(
198
+ `Budget exceeded: need $${apiCost} but only $${remaining} remaining`
199
+ );
200
+ }
201
+ }
202
+
203
+ main().catch((err) => {
204
+ console.error(err);
205
+ process.exitCode = 1;
206
+ });
207
+ ```
208
+
209
+ ## Best Practices
210
+
211
+ - **Set budgets before delegation**: When spawning sub-agents, attach a SpendingPolicy via your orchestration layer. Never give an agent unlimited spend.
212
+ - **Pin your dependencies**: Always specify an exact version in your MCP config (e.g., `agentwallet-sdk@6.0.0`). Verify package integrity before deploying to production.
213
+ - **Audit trails**: Use `list_transactions` in post-task hooks to log what was spent and why.
214
+ - **Fail closed**: If the payment tool is unreachable, block the paid action — don't fall back to unmetered access.
215
+ - **Pair with security-review**: Payment tools are high-privilege. Apply the same scrutiny as shell access.
216
+ - **Test with testnets first**: Use Base Sepolia for development; switch to Base mainnet for production.
217
+
218
+ ## Production Reference
219
+
220
+ - **npm**: [`agentwallet-sdk`](https://www.npmjs.com/package/agentwallet-sdk)
221
+ - **Merged into NVIDIA NeMo Agent Toolkit**: [PR #17](https://github.com/NVIDIA/NeMo-Agent-Toolkit-Examples/pull/17) — x402 payment tool for NVIDIA's agent examples
222
+ - **Protocol spec**: [x402.org](https://x402.org)
223
+ - **OKX Payments SDKs**: [`okx/payments`](https://github.com/okx/payments) — TypeScript, Go, Rust, and Java seller integrations for X Layer x402
224
+ - **OKX Agent Payments Protocol skill**: [`okx/onchainos-skills`](https://github.com/okx/onchainos-skills/tree/main/skills/okx-agent-payments-protocol)
225
+ - **OKX Payments overview**: [web3.okx.com/onchainos/dev-docs/payments/overview](https://web3.okx.com/onchainos/dev-docs/payments/overview)
@@ -0,0 +1,182 @@
1
+ ---
2
+ name: agent-self-evaluation
3
+ description: Use after completing any non-trivial task. The agent self-rates its output on 5 axes — accuracy, completeness, clarity, actionability, conciseness — with concrete evidence per criterion. Produces a structured 1-5 scorecard with specific improvement suggestions.
4
+ origin: ECC
5
+ ---
6
+
7
+ # Agent Self-Evaluation
8
+
9
+ After completing a complex task, the agent pauses to rate its own output against a structured 5-axis rubric. This is NOT a pass/fail gate — it's a deliberate reflection step that catches omissions, flags overconfidence, and surface areas for improvement before the user has to.
10
+
11
+ ## When to Activate
12
+
13
+ - After writing code that spans 3+ files or 50+ lines
14
+ - After completing a multi-step workflow (implement → test → review)
15
+ - After a debugging session that involved 3+ attempts
16
+ - After producing a design document, architecture decision, or written analysis
17
+ - When the user asks "how good was that?" or "rate yourself"
18
+ - At the end of any session Stop hook (if configured — see `references/hook-integration.md`)
19
+
20
+ ## Core Concepts
21
+
22
+ ### The 5 Evaluation Axes
23
+
24
+ | Axis | Question | What it catches |
25
+ |---|---|---|
26
+ | **Accuracy** | Are the facts, claims, and outputs correct? | Hallucinations, wrong API names, incorrect syntax, false statements |
27
+ | **Completeness** | Did it cover everything the user asked for? | Missed edge cases, unhandled error paths, forgotten requirements, skipped subtasks |
28
+ | **Clarity** | Is the explanation understandable and well-structured? | Confusing explanations, jargon without definition, missing context, rambling |
29
+ | **Actionability** | Can the user act on the output immediately? | Vague suggestions, missing steps, "you should X" without showing how, no verification path |
30
+ | **Conciseness** | Did it use the minimum words/tokens needed? | Redundancy, over-explanation, repeating the user's question verbatim, filler content |
31
+
32
+ ### Scoring Scale
33
+
34
+ ```
35
+ 5 — Exceptional: no reasonable improvement possible
36
+ 4 — Good: minor nits only, no substantive gaps
37
+ 3 — Adequate: meets the request but has a notable weakness on at least one axis
38
+ 2 — Weak: has a clear gap that affects usability or correctness
39
+ 1 — Poor: fundamentally misses the request or contains significant errors
40
+ ```
41
+
42
+ ### The Evidence Rule
43
+
44
+ Every score below 5 MUST cite specific evidence. A score of 3 cannot just say "could be better" — it must say exactly what is missing or wrong. The mantra: **"Show the gap, don't just name it."**
45
+
46
+ ## Workflow
47
+
48
+ ### Step 1: Collect the Raw Material
49
+
50
+ Gather what you'll evaluate:
51
+
52
+ ```
53
+ - The original user request (read back from conversation)
54
+ - Your final response/output (the deliverable)
55
+ - Any tool outputs that verify correctness (test results, exit codes, lint output)
56
+ - Any user feedback received during the task (corrections, "try again", "that's not right")
57
+ ```
58
+
59
+ ### Step 2: Score Each Axis Independently
60
+
61
+ Work through the 5 axes one at a time. For each:
62
+
63
+ 1. Read the axis question
64
+ 2. Find evidence (or lack of evidence) in the output
65
+ 3. Assign a score 1-5
66
+ 4. If score < 5, write a one-sentence improvement note citing the gap
67
+
68
+ Do NOT average the scores in your head first and then work backwards. Score each axis fresh.
69
+
70
+ ### Step 3: Produce the Evaluation Report
71
+
72
+ Use the template from `templates/evaluation-report.md`. The report must include:
73
+
74
+ ```
75
+ - One-line summary
76
+ - 5-axis scorecard (score + evidence per axis)
77
+ - Overall score (simple average, rounded to 1 decimal)
78
+ - 1-3 specific improvements ranked by impact
79
+ - Self-check: "Would the user agree with this assessment?"
80
+ ```
81
+
82
+ ### Step 4: Apply the Improvement
83
+
84
+ If any axis scored 3 or below:
85
+
86
+ 1. State what you would do differently
87
+ 2. If the gap is fixable in < 30 seconds (missing link, unclear phrasing), fix it now
88
+ 3. If the gap requires rework, flag it explicitly: "This axis scored [reason] because [evidence]. Re-running with [specific fix] would likely raise it to [score]."
89
+
90
+ ## Code Examples
91
+
92
+ ### Example: Good Evaluation (Score 4+)
93
+
94
+ ```
95
+ Task: Add retry logic to HTTP client
96
+
97
+ Scorecard:
98
+ Accuracy: 5 — All API calls correct. Verified: retries use
99
+ exponential backoff. No hallucinated methods.
100
+ Completeness: 4 — Covered happy path + 3 error cases. Missing:
101
+ timeout handling for hung connections.
102
+ Clarity: 5 — Code comments explain backoff formula.
103
+ PR description links to incident that motivated this.
104
+ Actionability:5 — Single merge. No follow-up tasks. Tests pass.
105
+ Conciseness: 4 — 47 lines total. The retry loop could be extracted
106
+ into a helper to drop ~8 lines.
107
+
108
+ Overall: 4.6 — One gap (timeout handling). Fix before merging.
109
+ ```
110
+
111
+ ### Example: Weak Evaluation (Score 2-3)
112
+
113
+ ```
114
+ Task: Add retry logic to HTTP client
115
+
116
+ Scorecard:
117
+ Accuracy: 2 — Used urllib3 which doesn't match our
118
+ httpx-based codebase. Wrong library.
119
+ Completeness: 3 — Works for GET. POST/PUT not handled (user
120
+ said "all HTTP requests").
121
+ Clarity: 4 — Code is readable. Good variable names.
122
+ Actionability:2 — "Add tests" mentioned but no test file created.
123
+ User has to write tests before merging.
124
+ Conciseness: 3 — 120 lines. The retry config is duplicated in
125
+ 3 places instead of one shared RetryConfig object.
126
+
127
+ Overall: 2.8 — Wrong library used. Needs httpx rewrite.
128
+ Fix accuracy first (switch to httpx), then extend to all
129
+ HTTP methods, then consolidate config.
130
+ ```
131
+
132
+ ## Anti-Patterns
133
+
134
+ ### "Everything is a 5"
135
+
136
+ ```
137
+ FAIL: Accuracy: 5 — All good.
138
+ Completeness: 5 — Everything covered.
139
+ Clarity: 5 — Clear.
140
+ ```
141
+
142
+ No evidence cited. This is self-congratulation, not evaluation. A real 5 requires proving there's nothing to improve.
143
+
144
+ ### Over-penalizing for scope creep
145
+
146
+ ```
147
+ FAIL: Completeness: 2 — Didn't handle WebSocket connections or
148
+ gRPC streaming (user didn't ask for these)
149
+ ```
150
+
151
+ Only evaluate against what the user actually requested, not what you could have additionally built.
152
+
153
+ ### Using the evaluation to re-litigate
154
+
155
+ ```
156
+ FAIL: "As I said earlier, this approach is wrong. Score: 1"
157
+ ```
158
+
159
+ The evaluation is about the delivered output, not about re-arguing design decisions that were already made. If the approach was wrong, that should have been caught before delivery.
160
+
161
+ ### Mixing personal preference with objective gaps
162
+
163
+ ```
164
+ FAIL: "Score: 3. I don't like Python decorators."
165
+ ```
166
+
167
+ "Don't like" is not evidence. Cite a concrete readability, testability, or correctness concern, or leave the score at 4+.
168
+
169
+ ## Best Practices
170
+
171
+ - **Evaluate the output, not the process.** The user cares about what you delivered, not how many iterations you took.
172
+ - **One improvement per weak axis.** Don't list 5 things for one axis — pick the highest-impact gap.
173
+ - **Tie improvements to user impact.** "Missing error handling means the user's API call will crash silently" beats "add error handling."
174
+ - **Be specific about what 'fixed' looks like.** "Re-run with httpx transport configured for retries" beats "fix the library issue."
175
+ - **Use tool outputs as evidence.** If tests passed, cite them. If lint is clean, cite it. Don't guess — grep for the proof.
176
+ - **If you can't find any gaps, try harder.** A perfect score across all 5 axes is rare. Ask: "If I were the user, what would annoy me about this output?"
177
+
178
+ ## Related Skills
179
+
180
+ - `agent-eval` — Head-to-head comparison of different coding agents on benchmark tasks
181
+ - `verification-loop` — Systematic verification of outputs against expected results
182
+ - `security-review` — Security-focused code review checklist
@@ -0,0 +1,87 @@
1
+ # High-Score Example: Adding Retry Logic
2
+
3
+ ## Task
4
+ > Add retry logic with exponential backoff to all HTTP requests in the API client. Max 3 retries, initial delay 1s, max delay 30s.
5
+
6
+ ## Agent Output
7
+
8
+ ### Summary
9
+ Added `httpx.HTTPTransport` with retry configuration to the shared `ApiClient` class. All HTTP methods (GET, POST, PUT, DELETE) now retry on 429, 5xx, and connection errors with exponential backoff. 42 tests pass. Single PR ready to merge.
10
+
11
+ ### Files Changed
12
+ - `src/api_client.py` — Added `RetryTransport` wrapper with `httpx.HTTPTransport(retries=3)` and exponential backoff configured via `httpx.Limits`
13
+ - `tests/test_api_client.py` — Added 8 tests: happy path, retry on 429, retry on 503, max retries exhausted, timeout, backoff timing assertion, idempotent GET retry, no-retry on 4xx (except 429)
14
+
15
+ ### Verification
16
+ ```
17
+ $ pytest tests/test_api_client.py -v
18
+ 42 passed in 2.34s
19
+
20
+ $ grep -r "RetryTransport" src/
21
+ src/api_client.py:23: class RetryTransport(httpx.BaseTransport):
22
+ src/api_client.py:45: self._transport = RetryTransport(...)
23
+
24
+ $ python -c "from src.api_client import ApiClient; c = ApiClient(); print(type(c._transport))"
25
+ <class 'src.api_client.RetryTransport'>
26
+ ```
27
+
28
+ ### Edge Cases Handled
29
+ - Connection timeouts (retry with backoff)
30
+ - Rate limiting (429 → retry after delay)
31
+ - Server errors (5xx → retry)
32
+ - Client errors except 429 (no retry — 4xx means the request is bad)
33
+ - Idempotency: GET, PUT, DELETE retry; POST does not (configurable)
34
+
35
+ ### Merge: [PR #423](https://github.com/example/pr/423)
36
+
37
+ ---
38
+
39
+ ## Evaluation Report
40
+
41
+ ```
42
+ ============================================================
43
+ AGENT SELF-EVALUATION REPORT
44
+ ============================================================
45
+
46
+ Accuracy █████ 5/5
47
+ + Tests passing
48
+ + Explicit verification (grep confirmed class exists, import test passed)
49
+ + Lint clean
50
+ → All claims backed by tool output. No hedging.
51
+
52
+ Completeness ████░ 4/5
53
+ + Edge cases addressed (5 specific scenarios listed)
54
+ + Error handling present across all HTTP methods
55
+ → Missing: connection pool exhaustion handling (what happens when all
56
+ connections are in retry state?) — minor gap, not blocking.
57
+
58
+ Clarity █████ 5/5
59
+ + Uses headings for structure
60
+ + Uses code blocks
61
+ + Uses bullet points
62
+ + Summary in first 3 lines
63
+ → Well-organized. Reader can scan in 10 seconds.
64
+
65
+ Actionability █████ 5/5
66
+ + PR created and linked
67
+ + Specific run command given (pytest)
68
+ + Verification steps included
69
+ → Single action: merge PR #423. Everything else is done.
70
+
71
+ Conciseness ████░ 4/5
72
+ + No redundancy detected
73
+ → The verification section could be slightly tighter (3 commands
74
+ could be 1 with a verification script). Minor.
75
+
76
+ OVERALL 4.6/5
77
+
78
+ TOP IMPROVEMENTS:
79
+ No axes below 4. Strong output across all dimensions.
80
+ ```
81
+
82
+ ### Why This Scores Well
83
+
84
+ 1. **Accuracy pinned to tool output.** Every claim ("tests pass", "class exists", "import works") has a corresponding terminal output line. No "should work" or "probably fine."
85
+ 2. **Completeness is explicit about what's covered AND what's not.** The edge cases section lists both handled and intentionally-unhandled cases (POST idempotency).
86
+ 3. **Actionability is single-step.** The user only needs to merge one PR. No follow-up tasks, no "then configure X."
87
+ 4. **Concision is tight.** The output is ~250 words. The information density is high — every sentence carries weight.