@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.
- package/CHANGELOG.md +16 -0
- package/CODE_OF_CONDUCT.md +34 -0
- package/CONTRIBUTING.md +38 -0
- package/LICENSE +21 -0
- package/README.md +337 -0
- package/RELEASING.md +93 -0
- package/SECURITY.md +31 -0
- package/STRATEGY.md +26 -0
- package/bin/cli.js +547 -0
- package/lib/packs.js +184 -0
- package/package.json +38 -0
- package/python/app/__init__.py +0 -0
- package/python/app/__pycache__/__init__.cpython-312.pyc +0 -0
- package/python/app/__pycache__/auth.cpython-312.pyc +0 -0
- package/python/app/__pycache__/main.cpython-312.pyc +0 -0
- package/python/app/auth.py +63 -0
- package/python/app/cli.py +78 -0
- package/python/app/db_paths.py +26 -0
- package/python/app/events_cli.py +175 -0
- package/python/app/main.py +647 -0
- package/python/app/materialize.py +138 -0
- package/python/app/mcp_server.py +610 -0
- package/python/app/route_cli.py +117 -0
- package/python/requirements-dev.txt +1 -0
- package/python/requirements.txt +7 -0
- package/python/tests/test_db_paths.py +41 -0
- package/skills/accessibility/SKILL.md +145 -0
- package/skills/agent-architecture-audit/SKILL.md +256 -0
- package/skills/agent-eval/SKILL.md +144 -0
- package/skills/agent-harness-construction/SKILL.md +72 -0
- package/skills/agent-introspection-debugging/SKILL.md +152 -0
- package/skills/agent-payment-x402/SKILL.md +224 -0
- package/skills/agent-sort/SKILL.md +214 -0
- package/skills/agentic-engineering/SKILL.md +62 -0
- package/skills/agentic-os/SKILL.md +386 -0
- package/skills/ai-first-engineering/SKILL.md +50 -0
- package/skills/ai-regression-testing/SKILL.md +384 -0
- package/skills/android-clean-architecture/SKILL.md +338 -0
- package/skills/angular-developer/SKILL.md +153 -0
- package/skills/angular-developer/references/angular-animations.md +160 -0
- package/skills/angular-developer/references/angular-aria.md +410 -0
- package/skills/angular-developer/references/cli.md +86 -0
- package/skills/angular-developer/references/component-harnesses.md +59 -0
- package/skills/angular-developer/references/component-styling.md +91 -0
- package/skills/angular-developer/references/components.md +117 -0
- package/skills/angular-developer/references/creating-services.md +97 -0
- package/skills/angular-developer/references/data-resolvers.md +69 -0
- package/skills/angular-developer/references/define-routes.md +67 -0
- package/skills/angular-developer/references/defining-providers.md +72 -0
- package/skills/angular-developer/references/di-fundamentals.md +120 -0
- package/skills/angular-developer/references/e2e-testing.md +56 -0
- package/skills/angular-developer/references/effects.md +83 -0
- package/skills/angular-developer/references/hierarchical-injectors.md +43 -0
- package/skills/angular-developer/references/host-elements.md +80 -0
- package/skills/angular-developer/references/injection-context.md +63 -0
- package/skills/angular-developer/references/inputs.md +101 -0
- package/skills/angular-developer/references/linked-signal.md +59 -0
- package/skills/angular-developer/references/loading-strategies.md +61 -0
- package/skills/angular-developer/references/mcp.md +108 -0
- package/skills/angular-developer/references/navigate-to-routes.md +69 -0
- package/skills/angular-developer/references/outputs.md +86 -0
- package/skills/angular-developer/references/reactive-forms.md +122 -0
- package/skills/angular-developer/references/rendering-strategies.md +44 -0
- package/skills/angular-developer/references/resource.md +77 -0
- package/skills/angular-developer/references/route-animations.md +56 -0
- package/skills/angular-developer/references/route-guards.md +52 -0
- package/skills/angular-developer/references/router-lifecycle.md +45 -0
- package/skills/angular-developer/references/router-testing.md +87 -0
- package/skills/angular-developer/references/show-routes-with-outlets.md +68 -0
- package/skills/angular-developer/references/signal-forms.md +795 -0
- package/skills/angular-developer/references/signals-overview.md +94 -0
- package/skills/angular-developer/references/tailwind-css.md +69 -0
- package/skills/angular-developer/references/template-driven-forms.md +114 -0
- package/skills/angular-developer/references/testing-fundamentals.md +65 -0
- package/skills/api-connector-builder/SKILL.md +120 -0
- package/skills/api-design/SKILL.md +522 -0
- package/skills/architecture-decision-records/SKILL.md +178 -0
- package/skills/article-writing/SKILL.md +78 -0
- package/skills/automation-audit-ops/SKILL.md +141 -0
- package/skills/autonomous-agent-harness/SKILL.md +272 -0
- package/skills/autonomous-loops/SKILL.md +609 -0
- package/skills/backend-patterns/SKILL.md +560 -0
- package/skills/benchmark/SKILL.md +92 -0
- package/skills/blueprint/SKILL.md +104 -0
- package/skills/browser-qa/SKILL.md +86 -0
- package/skills/bun-runtime/SKILL.md +83 -0
- package/skills/canary-watch/SKILL.md +98 -0
- package/skills/carrier-relationship-management/SKILL.md +211 -0
- package/skills/cisco-ios-patterns/SKILL.md +163 -0
- package/skills/ck/SKILL.md +147 -0
- package/skills/ck/commands/forget.mjs +44 -0
- package/skills/ck/commands/info.mjs +24 -0
- package/skills/ck/commands/init.mjs +143 -0
- package/skills/ck/commands/list.mjs +40 -0
- package/skills/ck/commands/migrate.mjs +202 -0
- package/skills/ck/commands/resume.mjs +36 -0
- package/skills/ck/commands/save.mjs +210 -0
- package/skills/ck/commands/shared.mjs +387 -0
- package/skills/ck/hooks/session-start.mjs +224 -0
- package/skills/claude-devfleet/SKILL.md +103 -0
- package/skills/click-path-audit/SKILL.md +244 -0
- package/skills/clickhouse-io/SKILL.md +438 -0
- package/skills/code-tour/SKILL.md +235 -0
- package/skills/codebase-onboarding/SKILL.md +232 -0
- package/skills/coding-standards/SKILL.md +548 -0
- package/skills/compose-multiplatform-patterns/SKILL.md +298 -0
- package/skills/connections-optimizer/SKILL.md +188 -0
- package/skills/content-engine/SKILL.md +126 -0
- package/skills/content-hash-cache-pattern/SKILL.md +160 -0
- package/skills/context-budget/SKILL.md +134 -0
- package/skills/continuous-agent-loop/SKILL.md +44 -0
- package/skills/continuous-learning/SKILL.md +129 -0
- package/skills/continuous-learning/config.json +18 -0
- package/skills/continuous-learning/evaluate-session.sh +69 -0
- package/skills/continuous-learning-v2/SKILL.md +358 -0
- package/skills/continuous-learning-v2/agents/observer-loop.sh +322 -0
- package/skills/continuous-learning-v2/agents/observer.md +198 -0
- package/skills/continuous-learning-v2/agents/session-guardian.sh +150 -0
- package/skills/continuous-learning-v2/agents/start-observer.sh +248 -0
- package/skills/continuous-learning-v2/config.json +8 -0
- package/skills/continuous-learning-v2/hooks/observe.sh +476 -0
- package/skills/continuous-learning-v2/scripts/detect-project.sh +288 -0
- package/skills/continuous-learning-v2/scripts/instinct-cli.py +1519 -0
- package/skills/continuous-learning-v2/scripts/lib/homunculus-dir.sh +31 -0
- package/skills/continuous-learning-v2/scripts/migrate-homunculus.sh +62 -0
- package/skills/continuous-learning-v2/scripts/test_parse_instinct.py +1018 -0
- package/skills/cost-aware-llm-pipeline/SKILL.md +182 -0
- package/skills/cost-tracking/SKILL.md +147 -0
- package/skills/council/SKILL.md +202 -0
- package/skills/cpp-coding-standards/SKILL.md +722 -0
- package/skills/cpp-testing/SKILL.md +323 -0
- package/skills/crosspost/SKILL.md +110 -0
- package/skills/csharp-testing/SKILL.md +320 -0
- package/skills/customer-billing-ops/SKILL.md +139 -0
- package/skills/customs-trade-compliance/SKILL.md +262 -0
- package/skills/dart-flutter-patterns/SKILL.md +562 -0
- package/skills/dashboard-builder/SKILL.md +108 -0
- package/skills/data-scraper-agent/SKILL.md +764 -0
- package/skills/database-migrations/SKILL.md +428 -0
- package/skills/deep-research/SKILL.md +158 -0
- package/skills/defi-amm-security/SKILL.md +166 -0
- package/skills/deployment-patterns/SKILL.md +426 -0
- package/skills/design-system/SKILL.md +81 -0
- package/skills/django-celery/SKILL.md +456 -0
- package/skills/django-patterns/SKILL.md +733 -0
- package/skills/django-security/SKILL.md +592 -0
- package/skills/django-tdd/SKILL.md +728 -0
- package/skills/django-verification/SKILL.md +468 -0
- package/skills/dmux-workflows/SKILL.md +190 -0
- package/skills/docker-patterns/SKILL.md +363 -0
- package/skills/documentation-lookup/SKILL.md +89 -0
- package/skills/dotnet-patterns/SKILL.md +320 -0
- package/skills/e2e-testing/SKILL.md +325 -0
- package/skills/email-ops/SKILL.md +120 -0
- package/skills/energy-procurement/SKILL.md +227 -0
- package/skills/enterprise-agent-ops/SKILL.md +49 -0
- package/skills/error-handling/SKILL.md +375 -0
- package/skills/eval-harness/SKILL.md +269 -0
- package/skills/evm-token-decimals/SKILL.md +130 -0
- package/skills/exa-search/SKILL.md +106 -0
- package/skills/fal-ai-media/SKILL.md +287 -0
- package/skills/fastapi-patterns/SKILL.md +327 -0
- package/skills/finance-billing-ops/SKILL.md +126 -0
- package/skills/flox-environments/SKILL.md +496 -0
- package/skills/flutter-dart-code-review/SKILL.md +434 -0
- package/skills/foundation-models-on-device/SKILL.md +243 -0
- package/skills/frontend-design-direction/SKILL.md +92 -0
- package/skills/frontend-patterns/SKILL.md +641 -0
- package/skills/frontend-slides/SKILL.md +183 -0
- package/skills/frontend-slides/STYLE_PRESETS.md +330 -0
- package/skills/frontend-slides/animation-patterns.md +122 -0
- package/skills/frontend-slides/html-template.md +419 -0
- package/skills/frontend-slides/scripts/export-pdf.sh +418 -0
- package/skills/frontend-slides/scripts/extract-pptx.py +96 -0
- package/skills/frontend-slides/viewport-base.css +153 -0
- package/skills/fsharp-testing/SKILL.md +279 -0
- package/skills/gan-style-harness/SKILL.md +278 -0
- package/skills/gateguard/SKILL.md +125 -0
- package/skills/git-workflow/SKILL.md +714 -0
- package/skills/github-ops/SKILL.md +143 -0
- package/skills/golang-patterns/SKILL.md +673 -0
- package/skills/golang-testing/SKILL.md +719 -0
- package/skills/google-workspace-ops/SKILL.md +94 -0
- package/skills/healthcare-cdss-patterns/SKILL.md +245 -0
- package/skills/healthcare-emr-patterns/SKILL.md +159 -0
- package/skills/healthcare-eval-harness/SKILL.md +207 -0
- package/skills/healthcare-phi-compliance/SKILL.md +145 -0
- package/skills/hermes-imports/SKILL.md +87 -0
- package/skills/hexagonal-architecture/SKILL.md +275 -0
- package/skills/hipaa-compliance/SKILL.md +78 -0
- package/skills/homelab-network-readiness/SKILL.md +169 -0
- package/skills/homelab-network-setup/SKILL.md +129 -0
- package/skills/homelab-pihole-dns/SKILL.md +274 -0
- package/skills/homelab-vlan-segmentation/SKILL.md +311 -0
- package/skills/homelab-wireguard-vpn/SKILL.md +305 -0
- package/skills/hookify-rules/SKILL.md +128 -0
- package/skills/inventory-demand-planning/SKILL.md +246 -0
- package/skills/investor-materials/SKILL.md +95 -0
- package/skills/investor-outreach/SKILL.md +90 -0
- package/skills/ios-icon-gen/SKILL.md +157 -0
- package/skills/ios-icon-gen/scripts/generate_icons.swift +258 -0
- package/skills/ios-icon-gen/scripts/iconify_gen.sh +235 -0
- package/skills/iterative-retrieval/SKILL.md +209 -0
- package/skills/java-coding-standards/SKILL.md +382 -0
- package/skills/jira-integration/SKILL.md +292 -0
- package/skills/jpa-patterns/SKILL.md +150 -0
- package/skills/knowledge-ops/SKILL.md +153 -0
- package/skills/kotlin-coroutines-flows/SKILL.md +283 -0
- package/skills/kotlin-exposed-patterns/SKILL.md +718 -0
- package/skills/kotlin-ktor-patterns/SKILL.md +688 -0
- package/skills/kotlin-patterns/SKILL.md +710 -0
- package/skills/kotlin-testing/SKILL.md +823 -0
- package/skills/laravel-patterns/SKILL.md +414 -0
- package/skills/laravel-plugin-discovery/SKILL.md +228 -0
- package/skills/laravel-security/SKILL.md +284 -0
- package/skills/laravel-tdd/SKILL.md +282 -0
- package/skills/laravel-verification/SKILL.md +178 -0
- package/skills/lead-intelligence/SKILL.md +320 -0
- package/skills/lead-intelligence/agents/enrichment-agent.md +85 -0
- package/skills/lead-intelligence/agents/mutual-mapper.md +75 -0
- package/skills/lead-intelligence/agents/outreach-drafter.md +98 -0
- package/skills/lead-intelligence/agents/signal-scorer.md +60 -0
- package/skills/liquid-glass-design/SKILL.md +279 -0
- package/skills/llm-trading-agent-security/SKILL.md +146 -0
- package/skills/logistics-exception-management/SKILL.md +221 -0
- package/skills/make-interfaces-feel-better/SKILL.md +151 -0
- package/skills/manim-video/SKILL.md +88 -0
- package/skills/manim-video/assets/network_graph_scene.py +52 -0
- package/skills/market-research/SKILL.md +74 -0
- package/skills/mcp-server-patterns/SKILL.md +68 -0
- package/skills/messages-ops/SKILL.md +103 -0
- package/skills/mle-workflow/SKILL.md +345 -0
- package/skills/motion-advanced/SKILL.md +596 -0
- package/skills/motion-foundations/SKILL.md +299 -0
- package/skills/motion-patterns/SKILL.md +435 -0
- package/skills/motion-ui/SKILL.md +574 -0
- package/skills/mysql-patterns/SKILL.md +411 -0
- package/skills/nanoclaw-repl/SKILL.md +32 -0
- package/skills/nestjs-patterns/SKILL.md +229 -0
- package/skills/netmiko-ssh-automation/SKILL.md +173 -0
- package/skills/network-bgp-diagnostics/SKILL.md +167 -0
- package/skills/network-config-validation/SKILL.md +210 -0
- package/skills/network-interface-health/SKILL.md +152 -0
- package/skills/nextjs-turbopack/SKILL.md +43 -0
- package/skills/nodejs-keccak256/SKILL.md +102 -0
- package/skills/nutrient-document-processing/SKILL.md +166 -0
- package/skills/nuxt4-patterns/SKILL.md +99 -0
- package/skills/openclaw-persona-forge/SKILL.md +288 -0
- package/skills/openclaw-persona-forge/gacha.py +224 -0
- package/skills/openclaw-persona-forge/gacha.sh +5 -0
- package/skills/openclaw-persona-forge/references/avatar-style.md +124 -0
- package/skills/openclaw-persona-forge/references/boundary-rules.md +53 -0
- package/skills/openclaw-persona-forge/references/error-handling.md +53 -0
- package/skills/openclaw-persona-forge/references/identity-tension.md +48 -0
- package/skills/openclaw-persona-forge/references/naming-system.md +39 -0
- package/skills/openclaw-persona-forge/references/output-template.md +166 -0
- package/skills/opensource-pipeline/SKILL.md +254 -0
- package/skills/perl-patterns/SKILL.md +503 -0
- package/skills/perl-security/SKILL.md +502 -0
- package/skills/perl-testing/SKILL.md +474 -0
- package/skills/plan-orchestrate/SKILL.md +253 -0
- package/skills/plankton-code-quality/SKILL.md +236 -0
- package/skills/postgres-patterns/SKILL.md +146 -0
- package/skills/product-capability/SKILL.md +140 -0
- package/skills/product-lens/SKILL.md +91 -0
- package/skills/production-audit/SKILL.md +206 -0
- package/skills/production-scheduling/SKILL.md +237 -0
- package/skills/project-flow-ops/SKILL.md +110 -0
- package/skills/prompt-optimizer/SKILL.md +398 -0
- package/skills/python-patterns/SKILL.md +749 -0
- package/skills/python-testing/SKILL.md +815 -0
- package/skills/pytorch-patterns/SKILL.md +395 -0
- package/skills/quality-nonconformance/SKILL.md +259 -0
- package/skills/quarkus-patterns/SKILL.md +721 -0
- package/skills/quarkus-security/SKILL.md +466 -0
- package/skills/quarkus-tdd/SKILL.md +810 -0
- package/skills/quarkus-verification/SKILL.md +478 -0
- package/skills/ralphinho-rfc-pipeline/SKILL.md +66 -0
- package/skills/redis-patterns/SKILL.md +402 -0
- package/skills/regex-vs-llm-structured-text/SKILL.md +219 -0
- package/skills/remotion-video-creation/SKILL.md +43 -0
- package/skills/remotion-video-creation/rules/3d.md +86 -0
- package/skills/remotion-video-creation/rules/animations.md +29 -0
- package/skills/remotion-video-creation/rules/assets/charts-bar-chart.tsx +173 -0
- package/skills/remotion-video-creation/rules/assets/text-animations-typewriter.tsx +100 -0
- package/skills/remotion-video-creation/rules/assets/text-animations-word-highlight.tsx +108 -0
- package/skills/remotion-video-creation/rules/assets.md +78 -0
- package/skills/remotion-video-creation/rules/audio.md +172 -0
- package/skills/remotion-video-creation/rules/calculate-metadata.md +104 -0
- package/skills/remotion-video-creation/rules/can-decode.md +75 -0
- package/skills/remotion-video-creation/rules/charts.md +58 -0
- package/skills/remotion-video-creation/rules/compositions.md +146 -0
- package/skills/remotion-video-creation/rules/display-captions.md +126 -0
- package/skills/remotion-video-creation/rules/extract-frames.md +229 -0
- package/skills/remotion-video-creation/rules/fonts.md +152 -0
- package/skills/remotion-video-creation/rules/get-audio-duration.md +58 -0
- package/skills/remotion-video-creation/rules/get-video-dimensions.md +68 -0
- package/skills/remotion-video-creation/rules/get-video-duration.md +58 -0
- package/skills/remotion-video-creation/rules/gifs.md +138 -0
- package/skills/remotion-video-creation/rules/images.md +130 -0
- package/skills/remotion-video-creation/rules/import-srt-captions.md +67 -0
- package/skills/remotion-video-creation/rules/lottie.md +67 -0
- package/skills/remotion-video-creation/rules/measuring-dom-nodes.md +34 -0
- package/skills/remotion-video-creation/rules/measuring-text.md +143 -0
- package/skills/remotion-video-creation/rules/sequencing.md +106 -0
- package/skills/remotion-video-creation/rules/tailwind.md +11 -0
- package/skills/remotion-video-creation/rules/text-animations.md +20 -0
- package/skills/remotion-video-creation/rules/timing.md +179 -0
- package/skills/remotion-video-creation/rules/transcribe-captions.md +19 -0
- package/skills/remotion-video-creation/rules/transitions.md +122 -0
- package/skills/remotion-video-creation/rules/trimming.md +52 -0
- package/skills/remotion-video-creation/rules/videos.md +171 -0
- package/skills/repo-scan/SKILL.md +78 -0
- package/skills/research-ops/SKILL.md +111 -0
- package/skills/returns-reverse-logistics/SKILL.md +239 -0
- package/skills/rules-distill/SKILL.md +263 -0
- package/skills/rules-distill/scripts/scan-rules.sh +58 -0
- package/skills/rules-distill/scripts/scan-skills.sh +129 -0
- package/skills/rust-patterns/SKILL.md +498 -0
- package/skills/rust-testing/SKILL.md +499 -0
- package/skills/safety-guard/SKILL.md +74 -0
- package/skills/santa-method/SKILL.md +306 -0
- package/skills/scientific-db-pubmed-database/SKILL.md +175 -0
- package/skills/scientific-db-uspto-database/SKILL.md +177 -0
- package/skills/scientific-pkg-gget/SKILL.md +166 -0
- package/skills/scientific-thinking-literature-review/SKILL.md +192 -0
- package/skills/scientific-thinking-scholar-evaluation/SKILL.md +160 -0
- package/skills/search-first/SKILL.md +181 -0
- package/skills/security-bounty-hunter/SKILL.md +99 -0
- package/skills/security-review/SKILL.md +502 -0
- package/skills/security-review/cloud-infrastructure-security.md +361 -0
- package/skills/seo/SKILL.md +153 -0
- package/skills/skill-comply/SKILL.md +57 -0
- package/skills/skill-comply/fixtures/compliant_trace.jsonl +5 -0
- package/skills/skill-comply/fixtures/noncompliant_trace.jsonl +3 -0
- package/skills/skill-comply/fixtures/tdd_spec.yaml +44 -0
- package/skills/skill-comply/prompts/classifier.md +24 -0
- package/skills/skill-comply/prompts/scenario_generator.md +62 -0
- package/skills/skill-comply/prompts/spec_generator.md +42 -0
- package/skills/skill-comply/pyproject.toml +15 -0
- package/skills/skill-comply/scripts/__init__.py +0 -0
- package/skills/skill-comply/scripts/classifier.py +85 -0
- package/skills/skill-comply/scripts/grader.py +124 -0
- package/skills/skill-comply/scripts/parser.py +107 -0
- package/skills/skill-comply/scripts/report.py +170 -0
- package/skills/skill-comply/scripts/run.py +127 -0
- package/skills/skill-comply/scripts/runner.py +186 -0
- package/skills/skill-comply/scripts/scenario_generator.py +70 -0
- package/skills/skill-comply/scripts/spec_generator.py +72 -0
- package/skills/skill-comply/scripts/utils.py +13 -0
- package/skills/skill-comply/tests/test_grader.py +197 -0
- package/skills/skill-comply/tests/test_parser.py +90 -0
- package/skills/skill-comply/tests/test_runner.py +172 -0
- package/skills/skill-scout/SKILL.md +139 -0
- package/skills/skill-stocktake/SKILL.md +193 -0
- package/skills/skill-stocktake/scripts/quick-diff.sh +87 -0
- package/skills/skill-stocktake/scripts/save-results.sh +56 -0
- package/skills/skill-stocktake/scripts/scan.sh +170 -0
- package/skills/social-graph-ranker/SKILL.md +153 -0
- package/skills/springboot-patterns/SKILL.md +313 -0
- package/skills/springboot-security/SKILL.md +271 -0
- package/skills/springboot-tdd/SKILL.md +157 -0
- package/skills/springboot-verification/SKILL.md +230 -0
- package/skills/strategic-compact/SKILL.md +129 -0
- package/skills/strategic-compact/suggest-compact.sh +54 -0
- package/skills/swift-actor-persistence/SKILL.md +142 -0
- package/skills/swift-concurrency-6-2/SKILL.md +216 -0
- package/skills/swift-protocol-di-testing/SKILL.md +189 -0
- package/skills/swiftui-patterns/SKILL.md +259 -0
- package/skills/tdd-workflow/SKILL.md +462 -0
- package/skills/team-builder/SKILL.md +166 -0
- package/skills/terminal-ops/SKILL.md +108 -0
- package/skills/tinystruct-patterns/SKILL.md +130 -0
- package/skills/tinystruct-patterns/references/architecture.md +77 -0
- package/skills/tinystruct-patterns/references/data-handling.md +35 -0
- package/skills/tinystruct-patterns/references/routing.md +57 -0
- package/skills/tinystruct-patterns/references/system-usage.md +74 -0
- package/skills/tinystruct-patterns/references/testing.md +59 -0
- package/skills/token-budget-advisor/SKILL.md +133 -0
- package/skills/ui-demo/SKILL.md +464 -0
- package/skills/ui-to-vue/SKILL.md +134 -0
- package/skills/unified-notifications-ops/SKILL.md +186 -0
- package/skills/verification-loop/SKILL.md +125 -0
- package/skills/video-editing/SKILL.md +309 -0
- package/skills/videodb/SKILL.md +373 -0
- package/skills/videodb/reference/api-reference.md +550 -0
- package/skills/videodb/reference/capture-reference.md +407 -0
- package/skills/videodb/reference/capture.md +101 -0
- package/skills/videodb/reference/editor.md +443 -0
- package/skills/videodb/reference/generative.md +331 -0
- package/skills/videodb/reference/rtstream-reference.md +564 -0
- package/skills/videodb/reference/rtstream.md +65 -0
- package/skills/videodb/reference/search.md +230 -0
- package/skills/videodb/reference/streaming.md +406 -0
- package/skills/videodb/reference/use-cases.md +118 -0
- package/skills/videodb/scripts/ws_listener.py +282 -0
- package/skills/visa-doc-translate/README.md +86 -0
- package/skills/visa-doc-translate/SKILL.md +117 -0
- package/skills/vite-patterns/SKILL.md +448 -0
- package/skills/windows-desktop-e2e/SKILL.md +787 -0
- package/skills/workspace-surface-audit/SKILL.md +124 -0
- 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
|