@heytherevibin/skillforge 0.2.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (402) hide show
  1. package/CHANGELOG.md +16 -0
  2. package/CODE_OF_CONDUCT.md +34 -0
  3. package/CONTRIBUTING.md +38 -0
  4. package/LICENSE +21 -0
  5. package/README.md +337 -0
  6. package/RELEASING.md +93 -0
  7. package/SECURITY.md +31 -0
  8. package/STRATEGY.md +26 -0
  9. package/bin/cli.js +547 -0
  10. package/lib/packs.js +184 -0
  11. package/package.json +38 -0
  12. package/python/app/__init__.py +0 -0
  13. package/python/app/__pycache__/__init__.cpython-312.pyc +0 -0
  14. package/python/app/__pycache__/auth.cpython-312.pyc +0 -0
  15. package/python/app/__pycache__/main.cpython-312.pyc +0 -0
  16. package/python/app/auth.py +63 -0
  17. package/python/app/cli.py +78 -0
  18. package/python/app/db_paths.py +26 -0
  19. package/python/app/events_cli.py +175 -0
  20. package/python/app/main.py +647 -0
  21. package/python/app/materialize.py +138 -0
  22. package/python/app/mcp_server.py +610 -0
  23. package/python/app/route_cli.py +117 -0
  24. package/python/requirements-dev.txt +1 -0
  25. package/python/requirements.txt +7 -0
  26. package/python/tests/test_db_paths.py +41 -0
  27. package/skills/accessibility/SKILL.md +145 -0
  28. package/skills/agent-architecture-audit/SKILL.md +256 -0
  29. package/skills/agent-eval/SKILL.md +144 -0
  30. package/skills/agent-harness-construction/SKILL.md +72 -0
  31. package/skills/agent-introspection-debugging/SKILL.md +152 -0
  32. package/skills/agent-payment-x402/SKILL.md +224 -0
  33. package/skills/agent-sort/SKILL.md +214 -0
  34. package/skills/agentic-engineering/SKILL.md +62 -0
  35. package/skills/agentic-os/SKILL.md +386 -0
  36. package/skills/ai-first-engineering/SKILL.md +50 -0
  37. package/skills/ai-regression-testing/SKILL.md +384 -0
  38. package/skills/android-clean-architecture/SKILL.md +338 -0
  39. package/skills/angular-developer/SKILL.md +153 -0
  40. package/skills/angular-developer/references/angular-animations.md +160 -0
  41. package/skills/angular-developer/references/angular-aria.md +410 -0
  42. package/skills/angular-developer/references/cli.md +86 -0
  43. package/skills/angular-developer/references/component-harnesses.md +59 -0
  44. package/skills/angular-developer/references/component-styling.md +91 -0
  45. package/skills/angular-developer/references/components.md +117 -0
  46. package/skills/angular-developer/references/creating-services.md +97 -0
  47. package/skills/angular-developer/references/data-resolvers.md +69 -0
  48. package/skills/angular-developer/references/define-routes.md +67 -0
  49. package/skills/angular-developer/references/defining-providers.md +72 -0
  50. package/skills/angular-developer/references/di-fundamentals.md +120 -0
  51. package/skills/angular-developer/references/e2e-testing.md +56 -0
  52. package/skills/angular-developer/references/effects.md +83 -0
  53. package/skills/angular-developer/references/hierarchical-injectors.md +43 -0
  54. package/skills/angular-developer/references/host-elements.md +80 -0
  55. package/skills/angular-developer/references/injection-context.md +63 -0
  56. package/skills/angular-developer/references/inputs.md +101 -0
  57. package/skills/angular-developer/references/linked-signal.md +59 -0
  58. package/skills/angular-developer/references/loading-strategies.md +61 -0
  59. package/skills/angular-developer/references/mcp.md +108 -0
  60. package/skills/angular-developer/references/navigate-to-routes.md +69 -0
  61. package/skills/angular-developer/references/outputs.md +86 -0
  62. package/skills/angular-developer/references/reactive-forms.md +122 -0
  63. package/skills/angular-developer/references/rendering-strategies.md +44 -0
  64. package/skills/angular-developer/references/resource.md +77 -0
  65. package/skills/angular-developer/references/route-animations.md +56 -0
  66. package/skills/angular-developer/references/route-guards.md +52 -0
  67. package/skills/angular-developer/references/router-lifecycle.md +45 -0
  68. package/skills/angular-developer/references/router-testing.md +87 -0
  69. package/skills/angular-developer/references/show-routes-with-outlets.md +68 -0
  70. package/skills/angular-developer/references/signal-forms.md +795 -0
  71. package/skills/angular-developer/references/signals-overview.md +94 -0
  72. package/skills/angular-developer/references/tailwind-css.md +69 -0
  73. package/skills/angular-developer/references/template-driven-forms.md +114 -0
  74. package/skills/angular-developer/references/testing-fundamentals.md +65 -0
  75. package/skills/api-connector-builder/SKILL.md +120 -0
  76. package/skills/api-design/SKILL.md +522 -0
  77. package/skills/architecture-decision-records/SKILL.md +178 -0
  78. package/skills/article-writing/SKILL.md +78 -0
  79. package/skills/automation-audit-ops/SKILL.md +141 -0
  80. package/skills/autonomous-agent-harness/SKILL.md +272 -0
  81. package/skills/autonomous-loops/SKILL.md +609 -0
  82. package/skills/backend-patterns/SKILL.md +560 -0
  83. package/skills/benchmark/SKILL.md +92 -0
  84. package/skills/blueprint/SKILL.md +104 -0
  85. package/skills/browser-qa/SKILL.md +86 -0
  86. package/skills/bun-runtime/SKILL.md +83 -0
  87. package/skills/canary-watch/SKILL.md +98 -0
  88. package/skills/carrier-relationship-management/SKILL.md +211 -0
  89. package/skills/cisco-ios-patterns/SKILL.md +163 -0
  90. package/skills/ck/SKILL.md +147 -0
  91. package/skills/ck/commands/forget.mjs +44 -0
  92. package/skills/ck/commands/info.mjs +24 -0
  93. package/skills/ck/commands/init.mjs +143 -0
  94. package/skills/ck/commands/list.mjs +40 -0
  95. package/skills/ck/commands/migrate.mjs +202 -0
  96. package/skills/ck/commands/resume.mjs +36 -0
  97. package/skills/ck/commands/save.mjs +210 -0
  98. package/skills/ck/commands/shared.mjs +387 -0
  99. package/skills/ck/hooks/session-start.mjs +224 -0
  100. package/skills/claude-devfleet/SKILL.md +103 -0
  101. package/skills/click-path-audit/SKILL.md +244 -0
  102. package/skills/clickhouse-io/SKILL.md +438 -0
  103. package/skills/code-tour/SKILL.md +235 -0
  104. package/skills/codebase-onboarding/SKILL.md +232 -0
  105. package/skills/coding-standards/SKILL.md +548 -0
  106. package/skills/compose-multiplatform-patterns/SKILL.md +298 -0
  107. package/skills/connections-optimizer/SKILL.md +188 -0
  108. package/skills/content-engine/SKILL.md +126 -0
  109. package/skills/content-hash-cache-pattern/SKILL.md +160 -0
  110. package/skills/context-budget/SKILL.md +134 -0
  111. package/skills/continuous-agent-loop/SKILL.md +44 -0
  112. package/skills/continuous-learning/SKILL.md +129 -0
  113. package/skills/continuous-learning/config.json +18 -0
  114. package/skills/continuous-learning/evaluate-session.sh +69 -0
  115. package/skills/continuous-learning-v2/SKILL.md +358 -0
  116. package/skills/continuous-learning-v2/agents/observer-loop.sh +322 -0
  117. package/skills/continuous-learning-v2/agents/observer.md +198 -0
  118. package/skills/continuous-learning-v2/agents/session-guardian.sh +150 -0
  119. package/skills/continuous-learning-v2/agents/start-observer.sh +248 -0
  120. package/skills/continuous-learning-v2/config.json +8 -0
  121. package/skills/continuous-learning-v2/hooks/observe.sh +476 -0
  122. package/skills/continuous-learning-v2/scripts/detect-project.sh +288 -0
  123. package/skills/continuous-learning-v2/scripts/instinct-cli.py +1519 -0
  124. package/skills/continuous-learning-v2/scripts/lib/homunculus-dir.sh +31 -0
  125. package/skills/continuous-learning-v2/scripts/migrate-homunculus.sh +62 -0
  126. package/skills/continuous-learning-v2/scripts/test_parse_instinct.py +1018 -0
  127. package/skills/cost-aware-llm-pipeline/SKILL.md +182 -0
  128. package/skills/cost-tracking/SKILL.md +147 -0
  129. package/skills/council/SKILL.md +202 -0
  130. package/skills/cpp-coding-standards/SKILL.md +722 -0
  131. package/skills/cpp-testing/SKILL.md +323 -0
  132. package/skills/crosspost/SKILL.md +110 -0
  133. package/skills/csharp-testing/SKILL.md +320 -0
  134. package/skills/customer-billing-ops/SKILL.md +139 -0
  135. package/skills/customs-trade-compliance/SKILL.md +262 -0
  136. package/skills/dart-flutter-patterns/SKILL.md +562 -0
  137. package/skills/dashboard-builder/SKILL.md +108 -0
  138. package/skills/data-scraper-agent/SKILL.md +764 -0
  139. package/skills/database-migrations/SKILL.md +428 -0
  140. package/skills/deep-research/SKILL.md +158 -0
  141. package/skills/defi-amm-security/SKILL.md +166 -0
  142. package/skills/deployment-patterns/SKILL.md +426 -0
  143. package/skills/design-system/SKILL.md +81 -0
  144. package/skills/django-celery/SKILL.md +456 -0
  145. package/skills/django-patterns/SKILL.md +733 -0
  146. package/skills/django-security/SKILL.md +592 -0
  147. package/skills/django-tdd/SKILL.md +728 -0
  148. package/skills/django-verification/SKILL.md +468 -0
  149. package/skills/dmux-workflows/SKILL.md +190 -0
  150. package/skills/docker-patterns/SKILL.md +363 -0
  151. package/skills/documentation-lookup/SKILL.md +89 -0
  152. package/skills/dotnet-patterns/SKILL.md +320 -0
  153. package/skills/e2e-testing/SKILL.md +325 -0
  154. package/skills/email-ops/SKILL.md +120 -0
  155. package/skills/energy-procurement/SKILL.md +227 -0
  156. package/skills/enterprise-agent-ops/SKILL.md +49 -0
  157. package/skills/error-handling/SKILL.md +375 -0
  158. package/skills/eval-harness/SKILL.md +269 -0
  159. package/skills/evm-token-decimals/SKILL.md +130 -0
  160. package/skills/exa-search/SKILL.md +106 -0
  161. package/skills/fal-ai-media/SKILL.md +287 -0
  162. package/skills/fastapi-patterns/SKILL.md +327 -0
  163. package/skills/finance-billing-ops/SKILL.md +126 -0
  164. package/skills/flox-environments/SKILL.md +496 -0
  165. package/skills/flutter-dart-code-review/SKILL.md +434 -0
  166. package/skills/foundation-models-on-device/SKILL.md +243 -0
  167. package/skills/frontend-design-direction/SKILL.md +92 -0
  168. package/skills/frontend-patterns/SKILL.md +641 -0
  169. package/skills/frontend-slides/SKILL.md +183 -0
  170. package/skills/frontend-slides/STYLE_PRESETS.md +330 -0
  171. package/skills/frontend-slides/animation-patterns.md +122 -0
  172. package/skills/frontend-slides/html-template.md +419 -0
  173. package/skills/frontend-slides/scripts/export-pdf.sh +418 -0
  174. package/skills/frontend-slides/scripts/extract-pptx.py +96 -0
  175. package/skills/frontend-slides/viewport-base.css +153 -0
  176. package/skills/fsharp-testing/SKILL.md +279 -0
  177. package/skills/gan-style-harness/SKILL.md +278 -0
  178. package/skills/gateguard/SKILL.md +125 -0
  179. package/skills/git-workflow/SKILL.md +714 -0
  180. package/skills/github-ops/SKILL.md +143 -0
  181. package/skills/golang-patterns/SKILL.md +673 -0
  182. package/skills/golang-testing/SKILL.md +719 -0
  183. package/skills/google-workspace-ops/SKILL.md +94 -0
  184. package/skills/healthcare-cdss-patterns/SKILL.md +245 -0
  185. package/skills/healthcare-emr-patterns/SKILL.md +159 -0
  186. package/skills/healthcare-eval-harness/SKILL.md +207 -0
  187. package/skills/healthcare-phi-compliance/SKILL.md +145 -0
  188. package/skills/hermes-imports/SKILL.md +87 -0
  189. package/skills/hexagonal-architecture/SKILL.md +275 -0
  190. package/skills/hipaa-compliance/SKILL.md +78 -0
  191. package/skills/homelab-network-readiness/SKILL.md +169 -0
  192. package/skills/homelab-network-setup/SKILL.md +129 -0
  193. package/skills/homelab-pihole-dns/SKILL.md +274 -0
  194. package/skills/homelab-vlan-segmentation/SKILL.md +311 -0
  195. package/skills/homelab-wireguard-vpn/SKILL.md +305 -0
  196. package/skills/hookify-rules/SKILL.md +128 -0
  197. package/skills/inventory-demand-planning/SKILL.md +246 -0
  198. package/skills/investor-materials/SKILL.md +95 -0
  199. package/skills/investor-outreach/SKILL.md +90 -0
  200. package/skills/ios-icon-gen/SKILL.md +157 -0
  201. package/skills/ios-icon-gen/scripts/generate_icons.swift +258 -0
  202. package/skills/ios-icon-gen/scripts/iconify_gen.sh +235 -0
  203. package/skills/iterative-retrieval/SKILL.md +209 -0
  204. package/skills/java-coding-standards/SKILL.md +382 -0
  205. package/skills/jira-integration/SKILL.md +292 -0
  206. package/skills/jpa-patterns/SKILL.md +150 -0
  207. package/skills/knowledge-ops/SKILL.md +153 -0
  208. package/skills/kotlin-coroutines-flows/SKILL.md +283 -0
  209. package/skills/kotlin-exposed-patterns/SKILL.md +718 -0
  210. package/skills/kotlin-ktor-patterns/SKILL.md +688 -0
  211. package/skills/kotlin-patterns/SKILL.md +710 -0
  212. package/skills/kotlin-testing/SKILL.md +823 -0
  213. package/skills/laravel-patterns/SKILL.md +414 -0
  214. package/skills/laravel-plugin-discovery/SKILL.md +228 -0
  215. package/skills/laravel-security/SKILL.md +284 -0
  216. package/skills/laravel-tdd/SKILL.md +282 -0
  217. package/skills/laravel-verification/SKILL.md +178 -0
  218. package/skills/lead-intelligence/SKILL.md +320 -0
  219. package/skills/lead-intelligence/agents/enrichment-agent.md +85 -0
  220. package/skills/lead-intelligence/agents/mutual-mapper.md +75 -0
  221. package/skills/lead-intelligence/agents/outreach-drafter.md +98 -0
  222. package/skills/lead-intelligence/agents/signal-scorer.md +60 -0
  223. package/skills/liquid-glass-design/SKILL.md +279 -0
  224. package/skills/llm-trading-agent-security/SKILL.md +146 -0
  225. package/skills/logistics-exception-management/SKILL.md +221 -0
  226. package/skills/make-interfaces-feel-better/SKILL.md +151 -0
  227. package/skills/manim-video/SKILL.md +88 -0
  228. package/skills/manim-video/assets/network_graph_scene.py +52 -0
  229. package/skills/market-research/SKILL.md +74 -0
  230. package/skills/mcp-server-patterns/SKILL.md +68 -0
  231. package/skills/messages-ops/SKILL.md +103 -0
  232. package/skills/mle-workflow/SKILL.md +345 -0
  233. package/skills/motion-advanced/SKILL.md +596 -0
  234. package/skills/motion-foundations/SKILL.md +299 -0
  235. package/skills/motion-patterns/SKILL.md +435 -0
  236. package/skills/motion-ui/SKILL.md +574 -0
  237. package/skills/mysql-patterns/SKILL.md +411 -0
  238. package/skills/nanoclaw-repl/SKILL.md +32 -0
  239. package/skills/nestjs-patterns/SKILL.md +229 -0
  240. package/skills/netmiko-ssh-automation/SKILL.md +173 -0
  241. package/skills/network-bgp-diagnostics/SKILL.md +167 -0
  242. package/skills/network-config-validation/SKILL.md +210 -0
  243. package/skills/network-interface-health/SKILL.md +152 -0
  244. package/skills/nextjs-turbopack/SKILL.md +43 -0
  245. package/skills/nodejs-keccak256/SKILL.md +102 -0
  246. package/skills/nutrient-document-processing/SKILL.md +166 -0
  247. package/skills/nuxt4-patterns/SKILL.md +99 -0
  248. package/skills/openclaw-persona-forge/SKILL.md +288 -0
  249. package/skills/openclaw-persona-forge/gacha.py +224 -0
  250. package/skills/openclaw-persona-forge/gacha.sh +5 -0
  251. package/skills/openclaw-persona-forge/references/avatar-style.md +124 -0
  252. package/skills/openclaw-persona-forge/references/boundary-rules.md +53 -0
  253. package/skills/openclaw-persona-forge/references/error-handling.md +53 -0
  254. package/skills/openclaw-persona-forge/references/identity-tension.md +48 -0
  255. package/skills/openclaw-persona-forge/references/naming-system.md +39 -0
  256. package/skills/openclaw-persona-forge/references/output-template.md +166 -0
  257. package/skills/opensource-pipeline/SKILL.md +254 -0
  258. package/skills/perl-patterns/SKILL.md +503 -0
  259. package/skills/perl-security/SKILL.md +502 -0
  260. package/skills/perl-testing/SKILL.md +474 -0
  261. package/skills/plan-orchestrate/SKILL.md +253 -0
  262. package/skills/plankton-code-quality/SKILL.md +236 -0
  263. package/skills/postgres-patterns/SKILL.md +146 -0
  264. package/skills/product-capability/SKILL.md +140 -0
  265. package/skills/product-lens/SKILL.md +91 -0
  266. package/skills/production-audit/SKILL.md +206 -0
  267. package/skills/production-scheduling/SKILL.md +237 -0
  268. package/skills/project-flow-ops/SKILL.md +110 -0
  269. package/skills/prompt-optimizer/SKILL.md +398 -0
  270. package/skills/python-patterns/SKILL.md +749 -0
  271. package/skills/python-testing/SKILL.md +815 -0
  272. package/skills/pytorch-patterns/SKILL.md +395 -0
  273. package/skills/quality-nonconformance/SKILL.md +259 -0
  274. package/skills/quarkus-patterns/SKILL.md +721 -0
  275. package/skills/quarkus-security/SKILL.md +466 -0
  276. package/skills/quarkus-tdd/SKILL.md +810 -0
  277. package/skills/quarkus-verification/SKILL.md +478 -0
  278. package/skills/ralphinho-rfc-pipeline/SKILL.md +66 -0
  279. package/skills/redis-patterns/SKILL.md +402 -0
  280. package/skills/regex-vs-llm-structured-text/SKILL.md +219 -0
  281. package/skills/remotion-video-creation/SKILL.md +43 -0
  282. package/skills/remotion-video-creation/rules/3d.md +86 -0
  283. package/skills/remotion-video-creation/rules/animations.md +29 -0
  284. package/skills/remotion-video-creation/rules/assets/charts-bar-chart.tsx +173 -0
  285. package/skills/remotion-video-creation/rules/assets/text-animations-typewriter.tsx +100 -0
  286. package/skills/remotion-video-creation/rules/assets/text-animations-word-highlight.tsx +108 -0
  287. package/skills/remotion-video-creation/rules/assets.md +78 -0
  288. package/skills/remotion-video-creation/rules/audio.md +172 -0
  289. package/skills/remotion-video-creation/rules/calculate-metadata.md +104 -0
  290. package/skills/remotion-video-creation/rules/can-decode.md +75 -0
  291. package/skills/remotion-video-creation/rules/charts.md +58 -0
  292. package/skills/remotion-video-creation/rules/compositions.md +146 -0
  293. package/skills/remotion-video-creation/rules/display-captions.md +126 -0
  294. package/skills/remotion-video-creation/rules/extract-frames.md +229 -0
  295. package/skills/remotion-video-creation/rules/fonts.md +152 -0
  296. package/skills/remotion-video-creation/rules/get-audio-duration.md +58 -0
  297. package/skills/remotion-video-creation/rules/get-video-dimensions.md +68 -0
  298. package/skills/remotion-video-creation/rules/get-video-duration.md +58 -0
  299. package/skills/remotion-video-creation/rules/gifs.md +138 -0
  300. package/skills/remotion-video-creation/rules/images.md +130 -0
  301. package/skills/remotion-video-creation/rules/import-srt-captions.md +67 -0
  302. package/skills/remotion-video-creation/rules/lottie.md +67 -0
  303. package/skills/remotion-video-creation/rules/measuring-dom-nodes.md +34 -0
  304. package/skills/remotion-video-creation/rules/measuring-text.md +143 -0
  305. package/skills/remotion-video-creation/rules/sequencing.md +106 -0
  306. package/skills/remotion-video-creation/rules/tailwind.md +11 -0
  307. package/skills/remotion-video-creation/rules/text-animations.md +20 -0
  308. package/skills/remotion-video-creation/rules/timing.md +179 -0
  309. package/skills/remotion-video-creation/rules/transcribe-captions.md +19 -0
  310. package/skills/remotion-video-creation/rules/transitions.md +122 -0
  311. package/skills/remotion-video-creation/rules/trimming.md +52 -0
  312. package/skills/remotion-video-creation/rules/videos.md +171 -0
  313. package/skills/repo-scan/SKILL.md +78 -0
  314. package/skills/research-ops/SKILL.md +111 -0
  315. package/skills/returns-reverse-logistics/SKILL.md +239 -0
  316. package/skills/rules-distill/SKILL.md +263 -0
  317. package/skills/rules-distill/scripts/scan-rules.sh +58 -0
  318. package/skills/rules-distill/scripts/scan-skills.sh +129 -0
  319. package/skills/rust-patterns/SKILL.md +498 -0
  320. package/skills/rust-testing/SKILL.md +499 -0
  321. package/skills/safety-guard/SKILL.md +74 -0
  322. package/skills/santa-method/SKILL.md +306 -0
  323. package/skills/scientific-db-pubmed-database/SKILL.md +175 -0
  324. package/skills/scientific-db-uspto-database/SKILL.md +177 -0
  325. package/skills/scientific-pkg-gget/SKILL.md +166 -0
  326. package/skills/scientific-thinking-literature-review/SKILL.md +192 -0
  327. package/skills/scientific-thinking-scholar-evaluation/SKILL.md +160 -0
  328. package/skills/search-first/SKILL.md +181 -0
  329. package/skills/security-bounty-hunter/SKILL.md +99 -0
  330. package/skills/security-review/SKILL.md +502 -0
  331. package/skills/security-review/cloud-infrastructure-security.md +361 -0
  332. package/skills/seo/SKILL.md +153 -0
  333. package/skills/skill-comply/SKILL.md +57 -0
  334. package/skills/skill-comply/fixtures/compliant_trace.jsonl +5 -0
  335. package/skills/skill-comply/fixtures/noncompliant_trace.jsonl +3 -0
  336. package/skills/skill-comply/fixtures/tdd_spec.yaml +44 -0
  337. package/skills/skill-comply/prompts/classifier.md +24 -0
  338. package/skills/skill-comply/prompts/scenario_generator.md +62 -0
  339. package/skills/skill-comply/prompts/spec_generator.md +42 -0
  340. package/skills/skill-comply/pyproject.toml +15 -0
  341. package/skills/skill-comply/scripts/__init__.py +0 -0
  342. package/skills/skill-comply/scripts/classifier.py +85 -0
  343. package/skills/skill-comply/scripts/grader.py +124 -0
  344. package/skills/skill-comply/scripts/parser.py +107 -0
  345. package/skills/skill-comply/scripts/report.py +170 -0
  346. package/skills/skill-comply/scripts/run.py +127 -0
  347. package/skills/skill-comply/scripts/runner.py +186 -0
  348. package/skills/skill-comply/scripts/scenario_generator.py +70 -0
  349. package/skills/skill-comply/scripts/spec_generator.py +72 -0
  350. package/skills/skill-comply/scripts/utils.py +13 -0
  351. package/skills/skill-comply/tests/test_grader.py +197 -0
  352. package/skills/skill-comply/tests/test_parser.py +90 -0
  353. package/skills/skill-comply/tests/test_runner.py +172 -0
  354. package/skills/skill-scout/SKILL.md +139 -0
  355. package/skills/skill-stocktake/SKILL.md +193 -0
  356. package/skills/skill-stocktake/scripts/quick-diff.sh +87 -0
  357. package/skills/skill-stocktake/scripts/save-results.sh +56 -0
  358. package/skills/skill-stocktake/scripts/scan.sh +170 -0
  359. package/skills/social-graph-ranker/SKILL.md +153 -0
  360. package/skills/springboot-patterns/SKILL.md +313 -0
  361. package/skills/springboot-security/SKILL.md +271 -0
  362. package/skills/springboot-tdd/SKILL.md +157 -0
  363. package/skills/springboot-verification/SKILL.md +230 -0
  364. package/skills/strategic-compact/SKILL.md +129 -0
  365. package/skills/strategic-compact/suggest-compact.sh +54 -0
  366. package/skills/swift-actor-persistence/SKILL.md +142 -0
  367. package/skills/swift-concurrency-6-2/SKILL.md +216 -0
  368. package/skills/swift-protocol-di-testing/SKILL.md +189 -0
  369. package/skills/swiftui-patterns/SKILL.md +259 -0
  370. package/skills/tdd-workflow/SKILL.md +462 -0
  371. package/skills/team-builder/SKILL.md +166 -0
  372. package/skills/terminal-ops/SKILL.md +108 -0
  373. package/skills/tinystruct-patterns/SKILL.md +130 -0
  374. package/skills/tinystruct-patterns/references/architecture.md +77 -0
  375. package/skills/tinystruct-patterns/references/data-handling.md +35 -0
  376. package/skills/tinystruct-patterns/references/routing.md +57 -0
  377. package/skills/tinystruct-patterns/references/system-usage.md +74 -0
  378. package/skills/tinystruct-patterns/references/testing.md +59 -0
  379. package/skills/token-budget-advisor/SKILL.md +133 -0
  380. package/skills/ui-demo/SKILL.md +464 -0
  381. package/skills/ui-to-vue/SKILL.md +134 -0
  382. package/skills/unified-notifications-ops/SKILL.md +186 -0
  383. package/skills/verification-loop/SKILL.md +125 -0
  384. package/skills/video-editing/SKILL.md +309 -0
  385. package/skills/videodb/SKILL.md +373 -0
  386. package/skills/videodb/reference/api-reference.md +550 -0
  387. package/skills/videodb/reference/capture-reference.md +407 -0
  388. package/skills/videodb/reference/capture.md +101 -0
  389. package/skills/videodb/reference/editor.md +443 -0
  390. package/skills/videodb/reference/generative.md +331 -0
  391. package/skills/videodb/reference/rtstream-reference.md +564 -0
  392. package/skills/videodb/reference/rtstream.md +65 -0
  393. package/skills/videodb/reference/search.md +230 -0
  394. package/skills/videodb/reference/streaming.md +406 -0
  395. package/skills/videodb/reference/use-cases.md +118 -0
  396. package/skills/videodb/scripts/ws_listener.py +282 -0
  397. package/skills/visa-doc-translate/README.md +86 -0
  398. package/skills/visa-doc-translate/SKILL.md +117 -0
  399. package/skills/vite-patterns/SKILL.md +448 -0
  400. package/skills/windows-desktop-e2e/SKILL.md +787 -0
  401. package/skills/workspace-surface-audit/SKILL.md +124 -0
  402. package/skills/x-api/SKILL.md +233 -0
@@ -0,0 +1,144 @@
1
+ ---
2
+ name: agent-eval
3
+ description: Head-to-head comparison of coding agents (Claude Code, Aider, Codex, etc.) on custom tasks with pass rate, cost, time, and consistency metrics
4
+ tools: Read, Write, Edit, Bash, Grep, Glob
5
+ ---
6
+
7
+ # Agent Eval Skill
8
+
9
+ A lightweight CLI tool for comparing coding agents head-to-head on reproducible tasks. Every "which coding agent is best?" comparison runs on vibes — this tool systematizes it.
10
+
11
+ ## When to Activate
12
+
13
+ - Comparing coding agents (Claude Code, Aider, Codex, etc.) on your own codebase
14
+ - Measuring agent performance before adopting a new tool or model
15
+ - Running regression checks when an agent updates its model or tooling
16
+ - Producing data-backed agent selection decisions for a team
17
+
18
+ ## Installation
19
+
20
+ > **Note:** Install agent-eval from its repository after reviewing the source.
21
+
22
+ ## Core Concepts
23
+
24
+ ### YAML Task Definitions
25
+
26
+ Define tasks declaratively. Each task specifies what to do, which files to touch, and how to judge success:
27
+
28
+ ```yaml
29
+ name: add-retry-logic
30
+ description: Add exponential backoff retry to the HTTP client
31
+ repo: ./my-project
32
+ files:
33
+ - src/http_client.py
34
+ prompt: |
35
+ Add retry logic with exponential backoff to all HTTP requests.
36
+ Max 3 retries. Initial delay 1s, max delay 30s.
37
+ judge:
38
+ - type: pytest
39
+ command: pytest tests/test_http_client.py -v
40
+ - type: grep
41
+ pattern: "exponential_backoff|retry"
42
+ files: src/http_client.py
43
+ commit: "abc1234" # pin to specific commit for reproducibility
44
+ ```
45
+
46
+ ### Git Worktree Isolation
47
+
48
+ Each agent run gets its own git worktree — no Docker required. This provides reproducibility isolation so agents cannot interfere with each other or corrupt the base repo.
49
+
50
+ ### Metrics Collected
51
+
52
+ | Metric | What It Measures |
53
+ |--------|-----------------|
54
+ | Pass rate | Did the agent produce code that passes the judge? |
55
+ | Cost | API spend per task (when available) |
56
+ | Time | Wall-clock seconds to completion |
57
+ | Consistency | Pass rate across repeated runs (e.g., 3/3 = 100%) |
58
+
59
+ ## Workflow
60
+
61
+ ### 1. Define Tasks
62
+
63
+ Create a `tasks/` directory with YAML files, one per task:
64
+
65
+ ```bash
66
+ mkdir tasks
67
+ # Write task definitions (see template above)
68
+ ```
69
+
70
+ ### 2. Run Agents
71
+
72
+ Execute agents against your tasks:
73
+
74
+ ```bash
75
+ agent-eval run --task tasks/add-retry-logic.yaml --agent claude-code --agent aider --runs 3
76
+ ```
77
+
78
+ Each run:
79
+ 1. Creates a fresh git worktree from the specified commit
80
+ 2. Hands the prompt to the agent
81
+ 3. Runs the judge criteria
82
+ 4. Records pass/fail, cost, and time
83
+
84
+ ### 3. Compare Results
85
+
86
+ Generate a comparison report:
87
+
88
+ ```bash
89
+ agent-eval report --format table
90
+ ```
91
+
92
+ ```
93
+ Task: add-retry-logic (3 runs each)
94
+ ┌──────────────┬───────────┬────────┬────────┬─────────────┐
95
+ │ Agent │ Pass Rate │ Cost │ Time │ Consistency │
96
+ ├──────────────┼───────────┼────────┼────────┼─────────────┤
97
+ │ claude-code │ 3/3 │ $0.12 │ 45s │ 100% │
98
+ │ aider │ 2/3 │ $0.08 │ 38s │ 67% │
99
+ └──────────────┴───────────┴────────┴────────┴─────────────┘
100
+ ```
101
+
102
+ ## Judge Types
103
+
104
+ ### Code-Based (deterministic)
105
+
106
+ ```yaml
107
+ judge:
108
+ - type: pytest
109
+ command: pytest tests/ -v
110
+ - type: command
111
+ command: npm run build
112
+ ```
113
+
114
+ ### Pattern-Based
115
+
116
+ ```yaml
117
+ judge:
118
+ - type: grep
119
+ pattern: "class.*Retry"
120
+ files: src/**/*.py
121
+ ```
122
+
123
+ ### Model-Based (LLM-as-judge)
124
+
125
+ ```yaml
126
+ judge:
127
+ - type: llm
128
+ prompt: |
129
+ Does this implementation correctly handle exponential backoff?
130
+ Check for: max retries, increasing delays, jitter.
131
+ ```
132
+
133
+ ## Best Practices
134
+
135
+ - **Start with 3-5 tasks** that represent your real workload, not toy examples
136
+ - **Run at least 3 trials** per agent to capture variance — agents are non-deterministic
137
+ - **Pin the commit** in your task YAML so results are reproducible across days/weeks
138
+ - **Include at least one deterministic judge** (tests, build) per task — LLM judges add noise
139
+ - **Track cost alongside pass rate** — a 95% agent at 10x the cost may not be the right choice
140
+ - **Version your task definitions** — they are test fixtures, treat them as code
141
+
142
+ ## Links
143
+
144
+ - Repository: [github.com/joaquinhuigomez/agent-eval](https://github.com/joaquinhuigomez/agent-eval)
@@ -0,0 +1,72 @@
1
+ ---
2
+ name: agent-harness-construction
3
+ description: Design and optimize AI agent action spaces, tool definitions, and observation formatting for higher completion rates.
4
+ ---
5
+
6
+ # Agent Harness Construction
7
+
8
+ Use this skill when you are improving how an agent plans, calls tools, recovers from errors, and converges on completion.
9
+
10
+ ## Core Model
11
+
12
+ Agent output quality is constrained by:
13
+ 1. Action space quality
14
+ 2. Observation quality
15
+ 3. Recovery quality
16
+ 4. Context budget quality
17
+
18
+ ## Action Space Design
19
+
20
+ 1. Use stable, explicit tool names.
21
+ 2. Keep inputs schema-first and narrow.
22
+ 3. Return deterministic output shapes.
23
+ 4. Avoid catch-all tools unless isolation is impossible.
24
+
25
+ ## Granularity Rules
26
+
27
+ - Use micro-tools for high-risk operations (deploy, migration, permissions).
28
+ - Use medium tools for common edit/read/search loops.
29
+ - Use macro-tools only when round-trip overhead is the dominant cost.
30
+
31
+ ## Observation Design
32
+
33
+ Every tool response should include:
34
+ - `status`: success|warning|error
35
+ - `summary`: one-line result
36
+ - `next_actions`: actionable follow-ups
37
+ - `artifacts`: file paths / IDs
38
+
39
+ ## Error Recovery Contract
40
+
41
+ For every error path, include:
42
+ - root cause hint
43
+ - safe retry instruction
44
+ - explicit stop condition
45
+
46
+ ## Context Budgeting
47
+
48
+ 1. Keep system prompt minimal and invariant.
49
+ 2. Move large guidance into skills loaded on demand.
50
+ 3. Prefer references to files over inlining long documents.
51
+ 4. Compact at phase boundaries, not arbitrary token thresholds.
52
+
53
+ ## Architecture Pattern Guidance
54
+
55
+ - ReAct: best for exploratory tasks with uncertain path.
56
+ - Function-calling: best for structured deterministic flows.
57
+ - Hybrid (recommended): ReAct planning + typed tool execution.
58
+
59
+ ## Benchmarking
60
+
61
+ Track:
62
+ - completion rate
63
+ - retries per task
64
+ - pass@1 and pass@3
65
+ - cost per successful task
66
+
67
+ ## Anti-Patterns
68
+
69
+ - Too many tools with overlapping semantics.
70
+ - Opaque tool output with no recovery hints.
71
+ - Error-only output without next steps.
72
+ - Context overloading with irrelevant references.
@@ -0,0 +1,152 @@
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
+ ---
5
+
6
+ # Agent Introspection Debugging
7
+
8
+ 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.
9
+
10
+ This is a workflow skill, not a hidden runtime. It teaches the agent to debug itself systematically before escalating to a human.
11
+
12
+ ## When to Activate
13
+
14
+ - Maximum tool call / loop-limit failures
15
+ - Repeated retries with no forward progress
16
+ - Context growth or prompt drift that starts degrading output quality
17
+ - File-system or environment state mismatch between expectation and reality
18
+ - Tool failures that are likely recoverable with diagnosis and a smaller corrective action
19
+
20
+ ## Scope Boundaries
21
+
22
+ Activate this skill for:
23
+ - capturing failure state before retrying blindly
24
+ - diagnosing common agent-specific failure patterns
25
+ - applying contained recovery actions
26
+ - producing a structured human-readable debug report
27
+
28
+ Do not use this skill as the primary source for:
29
+ - feature verification after code changes; use `verification-loop`
30
+ - framework-specific debugging when a narrower the toolset skill already exists
31
+ - runtime promises the current harness cannot enforce automatically
32
+
33
+ ## Four-Phase Loop
34
+
35
+ ### Phase 1: Failure Capture
36
+
37
+ Before trying to recover, record the failure precisely.
38
+
39
+ Capture:
40
+ - error type, message, and stack trace when available
41
+ - last meaningful tool call sequence
42
+ - what the agent was trying to do
43
+ - current context pressure: repeated prompts, oversized pasted logs, duplicated plans, or runaway notes
44
+ - current environment assumptions: cwd, branch, relevant service state, expected files
45
+
46
+ Minimum capture template:
47
+
48
+ ```markdown
49
+ ## Failure Capture
50
+ - Session / task:
51
+ - Goal in progress:
52
+ - Error:
53
+ - Last successful step:
54
+ - Last failed tool / command:
55
+ - Repeated pattern seen:
56
+ - Environment assumptions to verify:
57
+ ```
58
+
59
+ ### Phase 2: Root-Cause Diagnosis
60
+
61
+ Match the failure to a known pattern before changing anything.
62
+
63
+ | Pattern | Likely Cause | Check |
64
+ | --- | --- | --- |
65
+ | Maximum tool calls / repeated same command | loop or no-exit observer path | inspect the last N tool calls for repetition |
66
+ | Context overflow / degraded reasoning | unbounded notes, repeated plans, oversized logs | inspect recent context for duplication and low-signal bulk |
67
+ | `ECONNREFUSED` / timeout | service unavailable or wrong port | verify service health, URL, and port assumptions |
68
+ | `429` / quota exhaustion | retry storm or missing backoff | count repeated calls and inspect retry spacing |
69
+ | file missing after write / stale diff | race, wrong cwd, or branch drift | re-check path, cwd, git status, and actual file existence |
70
+ | tests still failing after “fix” | wrong hypothesis | isolate the exact failing test and re-derive the bug |
71
+
72
+ Diagnosis questions:
73
+ - is this a logic failure, state failure, environment failure, or policy failure?
74
+ - did the agent lose the real objective and start optimizing the wrong subtask?
75
+ - is the failure deterministic or transient?
76
+ - what is the smallest reversible action that would validate the diagnosis?
77
+
78
+ ### Phase 3: Contained Recovery
79
+
80
+ Recover with the smallest action that changes the diagnosis surface.
81
+
82
+ Safe recovery actions:
83
+ - stop repeated retries and restate the hypothesis
84
+ - trim low-signal context and keep only the active goal, blockers, and evidence
85
+ - re-check the actual filesystem / branch / process state
86
+ - narrow the task to one failing command, one file, or one test
87
+ - switch from speculative reasoning to direct observation
88
+ - escalate to a human when the failure is high-risk or externally blocked
89
+
90
+ 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.
91
+
92
+ Contained recovery checklist:
93
+
94
+ ```markdown
95
+ ## Recovery Action
96
+ - Diagnosis chosen:
97
+ - Smallest action taken:
98
+ - Why this is safe:
99
+ - What evidence would prove the fix worked:
100
+ ```
101
+
102
+ ### Phase 4: Introspection Report
103
+
104
+ End with a report that makes the recovery legible to the next agent or human.
105
+
106
+ ```markdown
107
+ ## Agent Self-Debug Report
108
+ - Session / task:
109
+ - Failure:
110
+ - Root cause:
111
+ - Recovery action:
112
+ - Result: success | partial | blocked
113
+ - Token / time burn risk:
114
+ - Follow-up needed:
115
+ - Preventive change to encode later:
116
+ ```
117
+
118
+ ## Recovery Heuristics
119
+
120
+ Prefer these interventions in order:
121
+
122
+ 1. Restate the real objective in one sentence.
123
+ 2. Verify the world state instead of trusting memory.
124
+ 3. Shrink the failing scope.
125
+ 4. Run one discriminating check.
126
+ 5. Only then retry.
127
+
128
+ Bad pattern:
129
+ - retrying the same action three times with slightly different wording
130
+
131
+ Good pattern:
132
+ - capture failure
133
+ - classify the pattern
134
+ - run one direct check
135
+ - change the plan only if the check supports it
136
+
137
+ ## Integration with the toolset
138
+
139
+ - Use `verification-loop` after recovery if code was changed.
140
+ - Use `continuous-learning-v2` when the failure pattern is worth turning into an instinct or later skill.
141
+ - Use `council` when the issue is not technical failure but decision ambiguity.
142
+ - Use `workspace-surface-audit` if the failure came from conflicting local state or repo drift.
143
+
144
+ ## Output Standard
145
+
146
+ When this skill is active, do not end with “I fixed it” alone.
147
+
148
+ Always provide:
149
+ - the failure pattern
150
+ - the root-cause hypothesis
151
+ - the recovery action
152
+ - the evidence that the situation is now better or still blocked
@@ -0,0 +1,224 @@
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
+ origin: community
5
+ ---
6
+
7
+ # Agent Payment Execution (x402)
8
+
9
+ 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.
10
+
11
+ ## When to Use
12
+
13
+ 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.
14
+
15
+ ## Decision Tree
16
+
17
+ Choose the integration path based on whether your agent is buying access to a paid API or charging others for one:
18
+
19
+ | Need | Recommended path |
20
+ |------|------------------|
21
+ | 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 |
22
+ | 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 |
23
+ | TypeScript API charges agents | Use OKX Payments TypeScript seller SDK docs for Express, Hono, Fastify, or Next.js |
24
+ | Go API charges agents | Use OKX Payments Go seller SDK docs for Gin, Echo, or `net/http` |
25
+ | Rust API charges agents | Use OKX Payments Rust seller SDK docs for Axum |
26
+ | Java API charges agents | Use OKX Payments Java seller SDK docs for Spring Boot 2/3, Java EE, or Jakarta |
27
+ | Python API charges agents | Check the current OKX Payments repository before implementation; a Python seller guide may not be available |
28
+
29
+ ## Supported Networks
30
+
31
+ - `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.
32
+ - 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.
33
+
34
+ ## How It Works
35
+
36
+ ### x402 Protocol
37
+ 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.
38
+
39
+ ### Spending Controls
40
+ Every payment tool call enforces a `SpendingPolicy`:
41
+ - **Per-task budget** — max spend for a single agent action
42
+ - **Per-session budget** — cumulative limit across an entire session
43
+ - **Allowlisted recipients** — restrict which addresses/services the agent can pay
44
+ - **Rate limits** — max transactions per minute/hour
45
+
46
+ ### Non-Custodial Wallets
47
+ 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.
48
+
49
+ ## MCP Integration
50
+
51
+ The payment layer exposes standard MCP tools that slot into any Claude Code or agent harness setup.
52
+
53
+ > **Security note**: Always pin the package version. This tool manages private keys — unpinned `npx` installs introduce supply-chain risk.
54
+
55
+ ### Option A: agentwallet-sdk (Base / multi-chain)
56
+
57
+ ```json
58
+ {
59
+ "mcpServers": {
60
+ "agentpay": {
61
+ "command": "npx",
62
+ "args": ["agentwallet-sdk@6.0.0"]
63
+ }
64
+ }
65
+ }
66
+ ```
67
+
68
+ ### Available Tools (agent-callable)
69
+
70
+ | Tool | Purpose |
71
+ |------|---------|
72
+ | `get_balance` | Check agent wallet balance |
73
+ | `send_payment` | Send payment to address or ENS |
74
+ | `check_spending` | Query remaining budget |
75
+ | `list_transactions` | Audit trail of all payments |
76
+
77
+ > **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.
78
+
79
+ ### Option B: OKX Agent Payments Protocol (X Layer)
80
+
81
+ Use this path for X Layer x402, Multi-Party Payment (MPP), session payment, charge, and A2A charge flows.
82
+
83
+ For buyer-side agent flows:
84
+
85
+ 1. Install or reference the current `okx/onchainos-skills` repository.
86
+ 2. Use `skills/okx-agent-payments-protocol/SKILL.md` as the dispatcher.
87
+ 3. Treat `skills/okx-x402-payment/SKILL.md` as a deprecated compatibility alias, not as the canonical skill.
88
+ 4. Require explicit user confirmation before wallet status checks or payment actions. Do not hide payment execution behind a generic tool call.
89
+
90
+ For seller-side API flows, fetch the latest language-specific guide before generating code:
91
+
92
+ | Runtime | Current guide |
93
+ |---------|---------------|
94
+ | TypeScript | `https://raw.githubusercontent.com/okx/payments/main/typescript/SELLER.md` |
95
+ | Go | `https://raw.githubusercontent.com/okx/payments/main/go/x402/SELLER.md` |
96
+ | Rust | `https://raw.githubusercontent.com/okx/payments/main/rust/x402/SELLER.md` |
97
+ | Java | `https://raw.githubusercontent.com/okx/payments/main/java/SELLER.md` |
98
+
99
+ 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.
100
+
101
+ ## Examples
102
+
103
+ ### Budget enforcement in an MCP client
104
+
105
+ When building an orchestrator that calls the agentpay MCP server, enforce budgets before dispatching paid tool calls.
106
+
107
+ > **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`
108
+
109
+ ```typescript
110
+ import { Client } from "@modelcontextprotocol/sdk/client/index.js";
111
+ import { StdioClientTransport } from "@modelcontextprotocol/sdk/client/stdio.js";
112
+
113
+ async function main() {
114
+ // 1. Validate credentials before constructing the transport.
115
+ // A missing key must fail immediately — never let the subprocess start without auth.
116
+ const walletKey = process.env.WALLET_PRIVATE_KEY;
117
+ if (!walletKey) {
118
+ throw new Error("WALLET_PRIVATE_KEY is not set — refusing to start payment server");
119
+ }
120
+
121
+ // Connect to the agentpay MCP server via stdio transport.
122
+ // Whitelist only the env vars the server needs — never forward all of process.env
123
+ // to a third-party subprocess that manages private keys.
124
+ const transport = new StdioClientTransport({
125
+ command: "npx",
126
+ args: ["agentwallet-sdk@6.0.0"],
127
+ env: {
128
+ PATH: process.env.PATH ?? "",
129
+ NODE_ENV: process.env.NODE_ENV ?? "production",
130
+ WALLET_PRIVATE_KEY: walletKey,
131
+ },
132
+ });
133
+ const agentpay = new Client({ name: "orchestrator", version: "1.0.0" });
134
+ await agentpay.connect(transport);
135
+
136
+ // 2. Set spending policy before delegating to the agent.
137
+ // Always verify success — a silent failure means no controls are active.
138
+ const policyResult = await agentpay.callTool({
139
+ name: "set_policy",
140
+ arguments: {
141
+ per_task_budget: 0.50,
142
+ per_session_budget: 5.00,
143
+ allowlisted_recipients: ["api.example.com"],
144
+ },
145
+ });
146
+ if (policyResult.isError) {
147
+ throw new Error(
148
+ `Failed to set spending policy — do not delegate: ${JSON.stringify(policyResult.content)}`
149
+ );
150
+ }
151
+
152
+ // 3. Use preToolCheck before any paid action
153
+ await preToolCheck(agentpay, 0.01);
154
+ }
155
+
156
+ // Pre-tool hook: fail-closed budget enforcement with four distinct error paths.
157
+ async function preToolCheck(agentpay: Client, apiCost: number): Promise<void> {
158
+ // Path 1: Reject invalid input (NaN/Infinity bypass the < comparison)
159
+ if (!Number.isFinite(apiCost) || apiCost < 0) {
160
+ throw new Error(`Invalid apiCost: ${apiCost} — action blocked`);
161
+ }
162
+
163
+ // Path 2: Transport/connectivity failure
164
+ let result;
165
+ try {
166
+ result = await agentpay.callTool({ name: "check_spending" });
167
+ } catch (err) {
168
+ throw new Error(`Payment service unreachable — action blocked: ${err}`);
169
+ }
170
+
171
+ // Path 3: Tool returned an error (e.g., auth failure, wallet not initialised)
172
+ if (result.isError) {
173
+ throw new Error(
174
+ `check_spending failed — action blocked: ${JSON.stringify(result.content)}`
175
+ );
176
+ }
177
+
178
+ // Path 4: Parse and validate the response shape
179
+ let remaining: number;
180
+ try {
181
+ const parsed = JSON.parse(
182
+ (result.content as Array<{ text: string }>)[0].text
183
+ );
184
+ if (!Number.isFinite(parsed?.remaining)) {
185
+ throw new TypeError("missing or non-finite 'remaining' field");
186
+ }
187
+ remaining = parsed.remaining;
188
+ } catch (err) {
189
+ throw new Error(
190
+ `check_spending returned unexpected format — action blocked: ${err}`
191
+ );
192
+ }
193
+
194
+ // Path 5: Budget exceeded
195
+ if (remaining < apiCost) {
196
+ throw new Error(
197
+ `Budget exceeded: need $${apiCost} but only $${remaining} remaining`
198
+ );
199
+ }
200
+ }
201
+
202
+ main().catch((err) => {
203
+ console.error(err);
204
+ process.exitCode = 1;
205
+ });
206
+ ```
207
+
208
+ ## Best Practices
209
+
210
+ - **Set budgets before delegation**: When spawning sub-agents, attach a SpendingPolicy via your orchestration layer. Never give an agent unlimited spend.
211
+ - **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.
212
+ - **Audit trails**: Use `list_transactions` in post-task hooks to log what was spent and why.
213
+ - **Fail closed**: If the payment tool is unreachable, block the paid action — don't fall back to unmetered access.
214
+ - **Pair with security-review**: Payment tools are high-privilege. Apply the same scrutiny as shell access.
215
+ - **Test with testnets first**: Use Base Sepolia for development; switch to Base mainnet for production.
216
+
217
+ ## Production Reference
218
+
219
+ - **npm**: [`agentwallet-sdk`](https://www.npmjs.com/package/agentwallet-sdk)
220
+ - **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
221
+ - **Protocol spec**: [x402.org](https://x402.org)
222
+ - **OKX Payments SDKs**: [`okx/payments`](https://github.com/okx/payments) — TypeScript, Go, Rust, and Java seller integrations for X Layer x402
223
+ - **OKX Agent Payments Protocol skill**: [`okx/onchainos-skills`](https://github.com/okx/onchainos-skills/tree/main/skills/okx-agent-payments-protocol)
224
+ - **OKX Payments overview**: [web3.okx.com/onchainos/dev-docs/payments/overview](https://web3.okx.com/onchainos/dev-docs/payments/overview)