@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,130 @@
1
+ ---
2
+ name: evm-token-decimals
3
+ description: Prevent silent decimal mismatch bugs across EVM chains. Covers runtime decimal lookup, chain-aware caching, bridged-token precision drift, and safe normalization for bots, dashboards, and DeFi tools.
4
+ origin: the toolset direct-port adaptation
5
+ version: "1.0.0"
6
+ ---
7
+
8
+ # EVM Token Decimals
9
+
10
+ Silent decimal mismatches are one of the easiest ways to ship balances or USD values that are off by orders of magnitude without throwing an error.
11
+
12
+ ## When to Use
13
+
14
+ - Reading ERC-20 balances in Python, TypeScript, or Solidity
15
+ - Calculating fiat values from on-chain balances
16
+ - Comparing token amounts across multiple EVM chains
17
+ - Handling bridged assets
18
+ - Building portfolio trackers, bots, or aggregators
19
+
20
+ ## How It Works
21
+
22
+ Never assume stablecoins use the same decimals everywhere. Query `decimals()` at runtime, cache by `(chain_id, token_address)`, and use decimal-safe math for value calculations.
23
+
24
+ ## Examples
25
+
26
+ ### Query decimals at runtime
27
+
28
+ ```python
29
+ from decimal import Decimal
30
+ from web3 import Web3
31
+
32
+ ERC20_ABI = [
33
+ {"name": "decimals", "type": "function", "inputs": [],
34
+ "outputs": [{"type": "uint8"}], "stateMutability": "view"},
35
+ {"name": "balanceOf", "type": "function",
36
+ "inputs": [{"name": "account", "type": "address"}],
37
+ "outputs": [{"type": "uint256"}], "stateMutability": "view"},
38
+ ]
39
+
40
+ def get_token_balance(w3: Web3, token_address: str, wallet: str) -> Decimal:
41
+ contract = w3.eth.contract(
42
+ address=Web3.to_checksum_address(token_address),
43
+ abi=ERC20_ABI,
44
+ )
45
+ decimals = contract.functions.decimals().call()
46
+ raw = contract.functions.balanceOf(Web3.to_checksum_address(wallet)).call()
47
+ return Decimal(raw) / Decimal(10 ** decimals)
48
+ ```
49
+
50
+ Do not hardcode `1_000_000` because a symbol usually has 6 decimals somewhere else.
51
+
52
+ ### Cache by chain and token
53
+
54
+ ```python
55
+ from functools import lru_cache
56
+
57
+ @lru_cache(maxsize=512)
58
+ def get_decimals(chain_id: int, token_address: str) -> int:
59
+ w3 = get_web3_for_chain(chain_id)
60
+ contract = w3.eth.contract(
61
+ address=Web3.to_checksum_address(token_address),
62
+ abi=ERC20_ABI,
63
+ )
64
+ return contract.functions.decimals().call()
65
+ ```
66
+
67
+ ### Handle odd tokens defensively
68
+
69
+ ```python
70
+ try:
71
+ decimals = contract.functions.decimals().call()
72
+ except Exception:
73
+ logging.warning(
74
+ "decimals() reverted on %s (chain %s), defaulting to 18",
75
+ token_address,
76
+ chain_id,
77
+ )
78
+ decimals = 18
79
+ ```
80
+
81
+ Log the fallback and keep it visible. Old or non-standard tokens still exist.
82
+
83
+ ### Normalize to 18-decimal WAD in Solidity
84
+
85
+ ```solidity
86
+ interface IERC20Metadata {
87
+ function decimals() external view returns (uint8);
88
+ }
89
+
90
+ function normalizeToWad(address token, uint256 amount) internal view returns (uint256) {
91
+ uint8 d = IERC20Metadata(token).decimals();
92
+ if (d == 18) return amount;
93
+ if (d < 18) return amount * 10 ** (18 - d);
94
+ return amount / 10 ** (d - 18);
95
+ }
96
+ ```
97
+
98
+ ### TypeScript with ethers
99
+
100
+ ```typescript
101
+ import { Contract, formatUnits } from 'ethers';
102
+
103
+ const ERC20_ABI = [
104
+ 'function decimals() view returns (uint8)',
105
+ 'function balanceOf(address) view returns (uint256)',
106
+ ];
107
+
108
+ async function getBalance(provider: any, tokenAddress: string, wallet: string): Promise<string> {
109
+ const token = new Contract(tokenAddress, ERC20_ABI, provider);
110
+ const [decimals, raw] = await Promise.all([
111
+ token.decimals(),
112
+ token.balanceOf(wallet),
113
+ ]);
114
+ return formatUnits(raw, decimals);
115
+ }
116
+ ```
117
+
118
+ ### Quick on-chain check
119
+
120
+ ```bash
121
+ cast call <token_address> "decimals()(uint8)" --rpc-url <rpc>
122
+ ```
123
+
124
+ ## Rules
125
+
126
+ - Always query `decimals()` at runtime
127
+ - Cache by chain plus token address, not symbol
128
+ - Use `Decimal`, `BigInt`, or equivalent exact math, not float
129
+ - Re-query decimals after bridging or wrapper changes
130
+ - Normalize internal accounting consistently before comparison or pricing
@@ -0,0 +1,106 @@
1
+ ---
2
+ name: exa-search
3
+ description: Neural search via Exa MCP for web, code, and company research. Use when the user needs web search, code examples, company intel, people lookup, or AI-powered deep research with Exa's neural search engine.
4
+ ---
5
+
6
+ # Exa Search
7
+
8
+ > **Drift-prone skill.** Exa MCP tool names, parameters, and account limits can
9
+ > change. Confirm the exposed tool surface and current Exa docs before relying
10
+ > on a specific search mode, category, or livecrawl behavior.
11
+
12
+ Neural search for web content, code, companies, and people via the Exa MCP server.
13
+
14
+ ## When to Activate
15
+
16
+ - User needs current web information or news
17
+ - Searching for code examples, API docs, or technical references
18
+ - Researching companies, competitors, or market players
19
+ - Finding professional profiles or people in a domain
20
+ - Running background research for any development task
21
+ - User says "search for", "look up", "find", or "what's the latest on"
22
+
23
+ ## MCP Requirement
24
+
25
+ Exa MCP server must be configured. Add to `~/.claude.json`:
26
+
27
+ ```json
28
+ "exa-web-search": {
29
+ "command": "npx",
30
+ "args": ["-y", "exa-mcp-server"],
31
+ "env": { "EXA_API_KEY": "YOUR_EXA_API_KEY_HERE" }
32
+ }
33
+ ```
34
+
35
+ Get an API key at [exa.ai](https://exa.ai).
36
+ This repo's current Exa setup documents the tool surface exposed here: `web_search_exa` and `get_code_context_exa`.
37
+ If your Exa server exposes additional tools, verify their exact names before depending on them in docs or prompts.
38
+
39
+ ## Core Tools
40
+
41
+ ### web_search_exa
42
+ General web search for current information, news, or facts.
43
+
44
+ ```
45
+ web_search_exa(query: "latest AI developments 2026", numResults: 5)
46
+ ```
47
+
48
+ **Parameters:**
49
+
50
+ | Param | Type | Default | Notes |
51
+ |-------|------|---------|-------|
52
+ | `query` | string | required | Search query |
53
+ | `numResults` | number | 8 | Number of results |
54
+ | `type` | string | `auto` | Search mode |
55
+ | `livecrawl` | string | `fallback` | Prefer live crawling when needed |
56
+ | `category` | string | none | Optional focus such as `company` or `research paper` |
57
+
58
+ ### get_code_context_exa
59
+ Find code examples and documentation from GitHub, Stack Overflow, and docs sites.
60
+
61
+ ```
62
+ get_code_context_exa(query: "Python asyncio patterns", tokensNum: 3000)
63
+ ```
64
+
65
+ **Parameters:**
66
+
67
+ | Param | Type | Default | Notes |
68
+ |-------|------|---------|-------|
69
+ | `query` | string | required | Code or API search query |
70
+ | `tokensNum` | number | 5000 | Content tokens (1000-50000) |
71
+
72
+ ## Usage Patterns
73
+
74
+ ### Quick Lookup
75
+ ```
76
+ web_search_exa(query: "Node.js 22 new features", numResults: 3)
77
+ ```
78
+
79
+ ### Code Research
80
+ ```
81
+ get_code_context_exa(query: "Rust error handling patterns Result type", tokensNum: 3000)
82
+ ```
83
+
84
+ ### Company or People Research
85
+ ```
86
+ web_search_exa(query: "Vercel funding valuation 2026", numResults: 3, category: "company")
87
+ web_search_exa(query: "site:linkedin.com/in AI safety researchers Anthropic", numResults: 5)
88
+ ```
89
+
90
+ ### Technical Deep Dive
91
+ ```
92
+ web_search_exa(query: "WebAssembly component model status and adoption", numResults: 5)
93
+ get_code_context_exa(query: "WebAssembly component model examples", tokensNum: 4000)
94
+ ```
95
+
96
+ ## Tips
97
+
98
+ - Use `web_search_exa` for current information, company lookups, and broad discovery
99
+ - Use search operators like `site:`, quoted phrases, and `intitle:` to narrow results
100
+ - Lower `tokensNum` (1000-2000) for focused code snippets, higher (5000+) for comprehensive context
101
+ - Use `get_code_context_exa` when you need API usage or code examples rather than general web pages
102
+
103
+ ## Related Skills
104
+
105
+ - `deep-research` — Full research workflow using firecrawl + exa together
106
+ - `market-research` — Business-oriented research with decision frameworks
@@ -0,0 +1,287 @@
1
+ ---
2
+ name: fal-ai-media
3
+ description: Unified media generation via fal.ai MCP — image, video, and audio. Covers text-to-image (Nano Banana), text/image-to-video (Seedance, Kling, Veo 3), text-to-speech (CSM-1B), and video-to-audio (ThinkSound). Use when the user wants to generate images, videos, or audio with AI.
4
+ ---
5
+
6
+ # fal.ai Media Generation
7
+
8
+ > **Drift-prone skill.** fal.ai model IDs, pricing, inputs, and MCP tool names
9
+ > change quickly. Search or fetch the current model metadata before promising a
10
+ > specific model, parameter, output format, or cost.
11
+
12
+ Generate images, videos, and audio using fal.ai models via MCP.
13
+
14
+ ## When to Activate
15
+
16
+ - User wants to generate images from text prompts
17
+ - Creating videos from text or images
18
+ - Generating speech, music, or sound effects
19
+ - Any media generation task
20
+ - User says "generate image", "create video", "text to speech", "make a thumbnail", or similar
21
+
22
+ ## MCP Requirement
23
+
24
+ fal.ai MCP server must be configured. Add to `~/.claude.json`:
25
+
26
+ ```json
27
+ "fal-ai": {
28
+ "command": "npx",
29
+ "args": ["-y", "fal-ai-mcp-server"],
30
+ "env": { "FAL_KEY": "YOUR_FAL_KEY_HERE" }
31
+ }
32
+ ```
33
+
34
+ Get an API key at [fal.ai](https://fal.ai).
35
+
36
+ ## MCP Tools
37
+
38
+ The fal.ai MCP provides these tools:
39
+ - `search` — Find available models by keyword
40
+ - `find` — Get model details and parameters
41
+ - `generate` — Run a model with parameters
42
+ - `result` — Check async generation status
43
+ - `status` — Check job status
44
+ - `cancel` — Cancel a running job
45
+ - `estimate_cost` — Estimate generation cost
46
+ - `models` — List popular models
47
+ - `upload` — Upload files for use as inputs
48
+
49
+ ---
50
+
51
+ ## Image Generation
52
+
53
+ ### Nano Banana 2 (Fast)
54
+ Best for: quick iterations, drafts, text-to-image, image editing.
55
+
56
+ ```
57
+ generate(
58
+ app_id: "fal-ai/nano-banana-2",
59
+ input_data: {
60
+ "prompt": "a futuristic cityscape at sunset, cyberpunk style",
61
+ "image_size": "landscape_16_9",
62
+ "num_images": 1,
63
+ "seed": 42
64
+ }
65
+ )
66
+ ```
67
+
68
+ ### Nano Banana Pro (High Fidelity)
69
+ Best for: production images, realism, typography, detailed prompts.
70
+
71
+ ```
72
+ generate(
73
+ app_id: "fal-ai/nano-banana-pro",
74
+ input_data: {
75
+ "prompt": "professional product photo of wireless headphones on marble surface, studio lighting",
76
+ "image_size": "square",
77
+ "num_images": 1,
78
+ "guidance_scale": 7.5
79
+ }
80
+ )
81
+ ```
82
+
83
+ ### Common Image Parameters
84
+
85
+ | Param | Type | Options | Notes |
86
+ |-------|------|---------|-------|
87
+ | `prompt` | string | required | Describe what you want |
88
+ | `image_size` | string | `square`, `portrait_4_3`, `landscape_16_9`, `portrait_16_9`, `landscape_4_3` | Aspect ratio |
89
+ | `num_images` | number | 1-4 | How many to generate |
90
+ | `seed` | number | any integer | Reproducibility |
91
+ | `guidance_scale` | number | 1-20 | How closely to follow the prompt (higher = more literal) |
92
+
93
+ ### Image Editing
94
+ Use Nano Banana 2 with an input image for inpainting, outpainting, or style transfer:
95
+
96
+ ```
97
+ # First upload the source image
98
+ upload(file_path: "/path/to/image.png")
99
+
100
+ # Then generate with image input
101
+ generate(
102
+ app_id: "fal-ai/nano-banana-2",
103
+ input_data: {
104
+ "prompt": "same scene but in watercolor style",
105
+ "image_url": "<uploaded_url>",
106
+ "image_size": "landscape_16_9"
107
+ }
108
+ )
109
+ ```
110
+
111
+ ---
112
+
113
+ ## Video Generation
114
+
115
+ ### Seedance 1.0 Pro (ByteDance)
116
+ Best for: text-to-video, image-to-video with high motion quality.
117
+
118
+ ```
119
+ generate(
120
+ app_id: "fal-ai/seedance-1-0-pro",
121
+ input_data: {
122
+ "prompt": "a drone flyover of a mountain lake at golden hour, cinematic",
123
+ "duration": "5s",
124
+ "aspect_ratio": "16:9",
125
+ "seed": 42
126
+ }
127
+ )
128
+ ```
129
+
130
+ ### Kling Video v3 Pro
131
+ Best for: text/image-to-video with native audio generation.
132
+
133
+ ```
134
+ generate(
135
+ app_id: "fal-ai/kling-video/v3/pro",
136
+ input_data: {
137
+ "prompt": "ocean waves crashing on a rocky coast, dramatic clouds",
138
+ "duration": "5s",
139
+ "aspect_ratio": "16:9"
140
+ }
141
+ )
142
+ ```
143
+
144
+ ### Veo 3 (Google DeepMind)
145
+ Best for: video with generated sound, high visual quality.
146
+
147
+ ```
148
+ generate(
149
+ app_id: "fal-ai/veo-3",
150
+ input_data: {
151
+ "prompt": "a bustling Tokyo street market at night, neon signs, crowd noise",
152
+ "aspect_ratio": "16:9"
153
+ }
154
+ )
155
+ ```
156
+
157
+ ### Image-to-Video
158
+ Start from an existing image:
159
+
160
+ ```
161
+ generate(
162
+ app_id: "fal-ai/seedance-1-0-pro",
163
+ input_data: {
164
+ "prompt": "camera slowly zooms out, gentle wind moves the trees",
165
+ "image_url": "<uploaded_image_url>",
166
+ "duration": "5s"
167
+ }
168
+ )
169
+ ```
170
+
171
+ ### Video Parameters
172
+
173
+ | Param | Type | Options | Notes |
174
+ |-------|------|---------|-------|
175
+ | `prompt` | string | required | Describe the video |
176
+ | `duration` | string | `"5s"`, `"10s"` | Video length |
177
+ | `aspect_ratio` | string | `"16:9"`, `"9:16"`, `"1:1"` | Frame ratio |
178
+ | `seed` | number | any integer | Reproducibility |
179
+ | `image_url` | string | URL | Source image for image-to-video |
180
+
181
+ ---
182
+
183
+ ## Audio Generation
184
+
185
+ ### CSM-1B (Conversational Speech)
186
+ Text-to-speech with natural, conversational quality.
187
+
188
+ ```
189
+ generate(
190
+ app_id: "fal-ai/csm-1b",
191
+ input_data: {
192
+ "text": "Hello, welcome to the demo. Let me show you how this works.",
193
+ "speaker_id": 0
194
+ }
195
+ )
196
+ ```
197
+
198
+ ### ThinkSound (Video-to-Audio)
199
+ Generate matching audio from video content.
200
+
201
+ ```
202
+ generate(
203
+ app_id: "fal-ai/thinksound",
204
+ input_data: {
205
+ "video_url": "<video_url>",
206
+ "prompt": "ambient forest sounds with birds chirping"
207
+ }
208
+ )
209
+ ```
210
+
211
+ ### ElevenLabs (via API, no MCP)
212
+ For professional voice synthesis, use ElevenLabs directly:
213
+
214
+ ```python
215
+ import os
216
+ import requests
217
+
218
+ resp = requests.post(
219
+ "https://api.elevenlabs.io/v1/text-to-speech/<voice_id>",
220
+ headers={
221
+ "xi-api-key": os.environ["ELEVENLABS_API_KEY"],
222
+ "Content-Type": "application/json"
223
+ },
224
+ json={
225
+ "text": "Your text here",
226
+ "model_id": "eleven_turbo_v2_5",
227
+ "voice_settings": {"stability": 0.5, "similarity_boost": 0.75}
228
+ }
229
+ )
230
+ with open("output.mp3", "wb") as f:
231
+ f.write(resp.content)
232
+ ```
233
+
234
+ ### VideoDB Generative Audio
235
+ If VideoDB is configured, use its generative audio:
236
+
237
+ ```python
238
+ # Voice generation
239
+ audio = coll.generate_voice(text="Your narration here", voice="alloy")
240
+
241
+ # Music generation
242
+ music = coll.generate_music(prompt="upbeat electronic background music", duration=30)
243
+
244
+ # Sound effects
245
+ sfx = coll.generate_sound_effect(prompt="thunder crack followed by rain")
246
+ ```
247
+
248
+ ---
249
+
250
+ ## Cost Estimation
251
+
252
+ Before generating, check estimated cost:
253
+
254
+ ```
255
+ estimate_cost(
256
+ estimate_type: "unit_price",
257
+ endpoints: {
258
+ "fal-ai/nano-banana-pro": {
259
+ "unit_quantity": 1
260
+ }
261
+ }
262
+ )
263
+ ```
264
+
265
+ ## Model Discovery
266
+
267
+ Find models for specific tasks:
268
+
269
+ ```
270
+ search(query: "text to video")
271
+ find(endpoint_ids: ["fal-ai/seedance-1-0-pro"])
272
+ models()
273
+ ```
274
+
275
+ ## Tips
276
+
277
+ - Use `seed` for reproducible results when iterating on prompts
278
+ - Start with lower-cost models (Nano Banana 2) for prompt iteration, then switch to Pro for finals
279
+ - For video, keep prompts descriptive but concise — focus on motion and scene
280
+ - Image-to-video produces more controlled results than pure text-to-video
281
+ - Check `estimate_cost` before running expensive video generations
282
+
283
+ ## Related Skills
284
+
285
+ - `videodb` — Video processing, editing, and streaming
286
+ - `video-editing` — AI-powered video editing workflows
287
+ - `content-engine` — Content creation for social platforms