@ngxtm/devkit 3.7.0 → 3.8.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/merged-commands/3d-web-experience.md +254 -0
- package/merged-commands/ab-test-setup.md +232 -0
- package/merged-commands/accessibility-compliance-accessibility-audit.md +42 -0
- package/merged-commands/active-directory-attacks.md +383 -0
- package/merged-commands/address-github-comments.md +55 -0
- package/merged-commands/aesthetic.md +134 -0
- package/merged-commands/agent-evaluation.md +64 -0
- package/merged-commands/agent-framework-azure-hosted-agents.md +332 -0
- package/merged-commands/agent-manager-skill.md +40 -0
- package/merged-commands/agent-memory-mcp.md +82 -0
- package/merged-commands/agent-memory-systems.md +67 -0
- package/merged-commands/agent-orchestration-improve-agent.md +349 -0
- package/merged-commands/agent-orchestration-multi-agent-optimize.md +239 -0
- package/merged-commands/agent-tool-builder.md +53 -0
- package/merged-commands/agile-product-owner.md +31 -0
- package/merged-commands/ai-agents-architect.md +90 -0
- package/merged-commands/ai-artist.md +75 -0
- package/merged-commands/ai-engineer.md +171 -0
- package/merged-commands/ai-multimodal.md +109 -0
- package/merged-commands/ai-product.md +54 -0
- package/merged-commands/ai-wrapper-product.md +273 -0
- package/merged-commands/airflow-dag-patterns.md +41 -0
- package/merged-commands/algolia-search.md +66 -0
- package/merged-commands/algorithmic-art.md +405 -0
- package/merged-commands/analytics-tracking.md +404 -0
- package/merged-commands/angular-architect.md +97 -0
- package/merged-commands/angular-migration.md +428 -0
- package/merged-commands/anti-reversing-techniques.md +42 -0
- package/merged-commands/api-design-principles.md +37 -0
- package/merged-commands/api-designer.md +101 -0
- package/merged-commands/api-documentation-generator.md +484 -0
- package/merged-commands/api-documenter.md +184 -0
- package/merged-commands/api-fuzzing-bug-bounty.md +433 -0
- package/merged-commands/api-patterns.md +81 -0
- package/merged-commands/api-security-best-practices.md +907 -0
- package/merged-commands/api-testing-observability-api-mock.md +46 -0
- package/merged-commands/app-builder.md +75 -0
- package/merged-commands/app-store-optimization.md +403 -0
- package/merged-commands/application-performance-performance-optimization.md +154 -0
- package/merged-commands/architect-review.md +174 -0
- package/merged-commands/architecture-decision-records.md +441 -0
- package/merged-commands/architecture-designer.md +89 -0
- package/merged-commands/architecture-patterns.md +37 -0
- package/merged-commands/architecture.md +55 -0
- package/merged-commands/arm-cortex-expert.md +306 -0
- package/merged-commands/artifacts-builder.md +74 -0
- package/merged-commands/ask-questions-if-underspecified.md +81 -0
- package/merged-commands/async-python-patterns.md +39 -0
- package/merged-commands/atlassian-mcp.md +100 -0
- package/merged-commands/attack-tree-construction.md +38 -0
- package/merged-commands/auth-implementation-patterns.md +39 -0
- package/merged-commands/automate-whatsapp.md +257 -0
- package/merged-commands/autonomous-agent-patterns.md +761 -0
- package/merged-commands/autonomous-agents.md +68 -0
- package/merged-commands/avalonia-layout-zafiro.md +59 -0
- package/merged-commands/avalonia-viewmodels-zafiro.md +29 -0
- package/merged-commands/avalonia-zafiro-development.md +29 -0
- package/merged-commands/aws-agentic-ai.md +117 -0
- package/merged-commands/aws-cdk-development.md +278 -0
- package/merged-commands/aws-cost-operations.md +317 -0
- package/merged-commands/aws-penetration-testing.md +405 -0
- package/merged-commands/aws-serverless-eda.md +757 -0
- package/merged-commands/aws-serverless.md +323 -0
- package/merged-commands/aws-skills.md +22 -0
- package/merged-commands/azd-deployment.md +296 -0
- package/merged-commands/azure-ai-agents-python.md +277 -0
- package/merged-commands/azure-ai-search-python.md +198 -0
- package/merged-commands/azure-ai-voicelive-skill.md +294 -0
- package/merged-commands/azure-functions.md +42 -0
- package/merged-commands/backend-architect.md +333 -0
- package/merged-commands/backend-dev-guidelines.md +342 -0
- package/merged-commands/backend-development-feature-development.md +180 -0
- package/merged-commands/backend-development.md +155 -0
- package/merged-commands/backend-security-coder.md +156 -0
- package/merged-commands/backtesting-frameworks.md +39 -0
- package/merged-commands/bash-defensive-patterns.md +43 -0
- package/merged-commands/bash-linux.md +199 -0
- package/merged-commands/bash-pro.md +310 -0
- package/merged-commands/bats-testing-patterns.md +34 -0
- package/merged-commands/bazel-build-optimization.md +397 -0
- package/merged-commands/beautiful-prose.md +22 -0
- package/merged-commands/behavioral-modes.md +242 -0
- package/merged-commands/best-practices.md +500 -0
- package/merged-commands/better-auth.md +204 -0
- package/merged-commands/billing-automation.md +42 -0
- package/merged-commands/binary-analysis-patterns.md +450 -0
- package/merged-commands/blockchain-developer.md +208 -0
- package/merged-commands/blockrun.md +292 -0
- package/merged-commands/brainstorming.md +230 -0
- package/merged-commands/brand-guidelines-anthropic.md +73 -0
- package/merged-commands/brand-guidelines-community.md +73 -0
- package/merged-commands/brand-guidelines.md +73 -0
- package/merged-commands/broken-authentication.md +476 -0
- package/merged-commands/browser-automation.md +70 -0
- package/merged-commands/browser-extension-builder.md +261 -0
- package/merged-commands/building-ai-agent-on-cloudflare.md +391 -0
- package/merged-commands/building-mcp-server-on-cloudflare.md +265 -0
- package/merged-commands/bullmq-specialist.md +57 -0
- package/merged-commands/bun-development.md +691 -0
- package/merged-commands/burp-suite-testing.md +380 -0
- package/merged-commands/business-analyst.md +182 -0
- package/merged-commands/busybox-on-windows.md +30 -0
- package/merged-commands/c-pro.md +56 -0
- package/merged-commands/c4-architecture-c4-architecture.md +389 -0
- package/merged-commands/c4-code.md +244 -0
- package/merged-commands/c4-component.md +153 -0
- package/merged-commands/c4-container.md +171 -0
- package/merged-commands/c4-context.md +150 -0
- package/merged-commands/canvas-design.md +130 -0
- package/merged-commands/cc-skill-backend-patterns.md +584 -0
- package/merged-commands/cc-skill-clickhouse-io.md +431 -0
- package/merged-commands/cc-skill-coding-standards.md +522 -0
- package/merged-commands/cc-skill-continuous-learning.md +10 -0
- package/merged-commands/cc-skill-frontend-patterns.md +633 -0
- package/merged-commands/cc-skill-project-guidelines-example.md +352 -0
- package/merged-commands/cc-skill-security-review.md +496 -0
- package/merged-commands/cc-skill-strategic-compact.md +10 -0
- package/merged-commands/changelog-automation.md +38 -0
- package/merged-commands/changelog-generator.md +104 -0
- package/merged-commands/chaos-engineer.md +98 -0
- package/merged-commands/chrome-devtools.md +407 -0
- package/merged-commands/cicd-automation-workflow-automate.md +51 -0
- package/merged-commands/clarity-gate.md +22 -0
- package/merged-commands/claude-ally-health.md +22 -0
- package/merged-commands/claude-code-guide.md +68 -0
- package/merged-commands/claude-d3js-skill.md +820 -0
- package/merged-commands/claude-scientific-skills.md +22 -0
- package/merged-commands/claude-speed-reader.md +22 -0
- package/merged-commands/claude-win11-speckit-update-skill.md +22 -0
- package/merged-commands/clean-code.md +201 -0
- package/merged-commands/clerk-auth.md +56 -0
- package/merged-commands/cli-developer.md +97 -0
- package/merged-commands/cloud-architect.md +135 -0
- package/merged-commands/cloud-penetration-testing.md +501 -0
- package/merged-commands/cloudflare-expert.md +227 -0
- package/merged-commands/code-documentation-code-explain.md +46 -0
- package/merged-commands/code-documentation-doc-generate.md +48 -0
- package/merged-commands/code-documentation.md +263 -0
- package/merged-commands/code-documenter.md +95 -0
- package/merged-commands/code-refactoring-context-restore.md +179 -0
- package/merged-commands/code-refactoring-refactor-clean.md +51 -0
- package/merged-commands/code-refactoring-tech-debt.md +386 -0
- package/merged-commands/code-refactoring.md +209 -0
- package/merged-commands/code-review-ai-ai-review.md +450 -0
- package/merged-commands/code-review-checklist.md +444 -0
- package/merged-commands/code-review-excellence.md +40 -0
- package/merged-commands/code-review.md +121 -0
- package/merged-commands/code-reviewer.md +178 -0
- package/merged-commands/codebase-cleanup-deps-audit.md +51 -0
- package/merged-commands/codebase-cleanup-refactor-clean.md +51 -0
- package/merged-commands/codebase-cleanup-tech-debt.md +386 -0
- package/merged-commands/codex-review.md +37 -0
- package/merged-commands/commit.md +171 -0
- package/merged-commands/competitive-ads-extractor.md +293 -0
- package/merged-commands/competitive-landscape.md +34 -0
- package/merged-commands/competitor-alternatives.md +750 -0
- package/merged-commands/comprehensive-review-full-review.md +146 -0
- package/merged-commands/comprehensive-review-pr-enhance.md +46 -0
- package/merged-commands/computer-use-agents.md +315 -0
- package/merged-commands/concise-planning.md +62 -0
- package/merged-commands/conductor-implement.md +388 -0
- package/merged-commands/conductor-manage.md +39 -0
- package/merged-commands/conductor-new-track.md +433 -0
- package/merged-commands/conductor-revert.md +372 -0
- package/merged-commands/conductor-setup.md +426 -0
- package/merged-commands/conductor-status.md +338 -0
- package/merged-commands/conductor-validator.md +62 -0
- package/merged-commands/content-creator.md +248 -0
- package/merged-commands/content-marketer.md +170 -0
- package/merged-commands/content-research-writer.md +538 -0
- package/merged-commands/context-compression.md +266 -0
- package/merged-commands/context-degradation.md +238 -0
- package/merged-commands/context-driven-development.md +400 -0
- package/merged-commands/context-engineering.md +107 -0
- package/merged-commands/context-fundamentals.md +192 -0
- package/merged-commands/context-management-context-restore.md +179 -0
- package/merged-commands/context-management-context-save.md +177 -0
- package/merged-commands/context-manager.md +185 -0
- package/merged-commands/context-optimization.md +186 -0
- package/merged-commands/context-window-management.md +53 -0
- package/merged-commands/context7-auto-research.md +36 -0
- package/merged-commands/conversation-memory.md +61 -0
- package/merged-commands/copy-editing.md +439 -0
- package/merged-commands/copywriting.md +225 -0
- package/merged-commands/core-components.md +264 -0
- package/merged-commands/cosmos-db-python-skill.md +198 -0
- package/merged-commands/cost-optimization.md +286 -0
- package/merged-commands/cpp-pro.md +59 -0
- package/merged-commands/cqrs-implementation.md +35 -0
- package/merged-commands/create-pr.md +192 -0
- package/merged-commands/crewai.md +243 -0
- package/merged-commands/csharp-developer.md +94 -0
- package/merged-commands/csharp-pro.md +59 -0
- package/merged-commands/culture-index.md +43 -0
- package/merged-commands/customer-support.md +170 -0
- package/merged-commands/daily-news-report.md +356 -0
- package/merged-commands/data-engineer.md +224 -0
- package/merged-commands/data-engineering-data-driven-feature.md +182 -0
- package/merged-commands/data-engineering-data-pipeline.md +201 -0
- package/merged-commands/data-quality-frameworks.md +40 -0
- package/merged-commands/data-scientist.md +199 -0
- package/merged-commands/data-storytelling.md +465 -0
- package/merged-commands/database-admin.md +165 -0
- package/merged-commands/database-architect.md +268 -0
- package/merged-commands/database-cloud-optimization-cost-optimize.md +44 -0
- package/merged-commands/database-design.md +52 -0
- package/merged-commands/database-migration.md +436 -0
- package/merged-commands/database-migrations-migration-observability.md +420 -0
- package/merged-commands/database-migrations-sql-migrations.md +53 -0
- package/merged-commands/database-optimizer.md +167 -0
- package/merged-commands/databases.md +232 -0
- package/merged-commands/dbt-transformation-patterns.md +34 -0
- package/merged-commands/debugger.md +49 -0
- package/merged-commands/debugging-strategies.md +34 -0
- package/merged-commands/debugging-toolkit-smart-debug.md +197 -0
- package/merged-commands/debugging-wizard.md +93 -0
- package/merged-commands/debugging.md +84 -0
- package/merged-commands/deep-research.md +114 -0
- package/merged-commands/defi-protocol-templates.md +466 -0
- package/merged-commands/dependency-management-deps-audit.md +44 -0
- package/merged-commands/dependency-upgrade.md +421 -0
- package/merged-commands/deployment-engineer.md +170 -0
- package/merged-commands/deployment-pipeline-design.md +371 -0
- package/merged-commands/deployment-procedures.md +241 -0
- package/merged-commands/deployment-validation-config-validate.md +496 -0
- package/merged-commands/design-md.md +178 -0
- package/merged-commands/design-orchestration.md +167 -0
- package/merged-commands/developer-growth-analysis.md +322 -0
- package/merged-commands/devops-engineer.md +92 -0
- package/merged-commands/devops-troubleshooter.md +161 -0
- package/merged-commands/devops.md +285 -0
- package/merged-commands/discord-bot-architect.md +277 -0
- package/merged-commands/dispatching-parallel-agents.md +180 -0
- package/merged-commands/distributed-debugging-debug-trace.md +44 -0
- package/merged-commands/distributed-tracing.md +450 -0
- package/merged-commands/django-expert.md +89 -0
- package/merged-commands/django-pro.md +180 -0
- package/merged-commands/doc-coauthoring.md +375 -0
- package/merged-commands/docker-expert.md +409 -0
- package/merged-commands/docs-architect.md +98 -0
- package/merged-commands/docs-seeker.md +102 -0
- package/merged-commands/documentation-generation-doc-generate.md +48 -0
- package/merged-commands/documentation-templates.md +194 -0
- package/merged-commands/docx-official.md +197 -0
- package/merged-commands/docx.md +197 -0
- package/merged-commands/domain-name-brainstormer.md +212 -0
- package/merged-commands/dotnet-architect.md +197 -0
- package/merged-commands/dotnet-backend-patterns.md +37 -0
- package/merged-commands/dotnet-core-expert.md +96 -0
- package/merged-commands/dx-optimizer.md +83 -0
- package/merged-commands/e2e-testing-patterns.md +41 -0
- package/merged-commands/elixir-pro.md +59 -0
- package/merged-commands/email-sequence.md +925 -0
- package/merged-commands/email-systems.md +54 -0
- package/merged-commands/embedded-systems.md +98 -0
- package/merged-commands/embedding-strategies.md +491 -0
- package/merged-commands/employment-contract-templates.md +39 -0
- package/merged-commands/environment-setup-guide.md +479 -0
- package/merged-commands/error-debugging-error-analysis.md +47 -0
- package/merged-commands/error-debugging-error-trace.md +43 -0
- package/merged-commands/error-debugging-multi-agent-review.md +216 -0
- package/merged-commands/error-detective.md +53 -0
- package/merged-commands/error-diagnostics-error-analysis.md +47 -0
- package/merged-commands/error-diagnostics-error-trace.md +48 -0
- package/merged-commands/error-diagnostics-smart-debug.md +197 -0
- package/merged-commands/error-handling-patterns.md +35 -0
- package/merged-commands/ethical-hacking-methodology.md +466 -0
- package/merged-commands/evaluation.md +238 -0
- package/merged-commands/event-sourcing-architect.md +58 -0
- package/merged-commands/event-store-design.md +449 -0
- package/merged-commands/exa-search.md +36 -0
- package/merged-commands/executing-plans.md +76 -0
- package/merged-commands/expo-app-design.md +22 -0
- package/merged-commands/expo-deployment.md +72 -0
- package/merged-commands/fal-audio.md +22 -0
- package/merged-commands/fal-generate.md +22 -0
- package/merged-commands/fal-image-edit.md +22 -0
- package/merged-commands/fal-platform.md +22 -0
- package/merged-commands/fal-upscale.md +22 -0
- package/merged-commands/fal-workflow.md +22 -0
- package/merged-commands/fastapi-expert.md +93 -0
- package/merged-commands/fastapi-pro.md +192 -0
- package/merged-commands/fastapi-router.md +52 -0
- package/merged-commands/fastapi-templates.md +32 -0
- package/merged-commands/feature-forge.md +90 -0
- package/merged-commands/ffuf-claude-skill.md +22 -0
- package/merged-commands/file-organizer.md +250 -0
- package/merged-commands/file-path-traversal.md +486 -0
- package/merged-commands/file-uploads.md +22 -0
- package/merged-commands/find-bugs.md +86 -0
- package/merged-commands/fine-tuning-expert.md +98 -0
- package/merged-commands/finishing-a-development-branch.md +200 -0
- package/merged-commands/firebase.md +56 -0
- package/merged-commands/firecrawl-scraper.md +37 -0
- package/merged-commands/firmware-analyst.md +320 -0
- package/merged-commands/fix-review.md +53 -0
- package/merged-commands/fixing.md +72 -0
- package/merged-commands/flutter-expert.md +200 -0
- package/merged-commands/form-cro.md +441 -0
- package/merged-commands/foundry-iq-agent.md +15 -0
- package/merged-commands/foundry-iq-python.md +275 -0
- package/merged-commands/foundry-nextgen-frontend.md +555 -0
- package/merged-commands/foundry-sdk-python.md +290 -0
- package/merged-commands/fp-ts-errors.md +856 -0
- package/merged-commands/fp-ts-pragmatic.md +598 -0
- package/merged-commands/fp-ts-react.md +796 -0
- package/merged-commands/framework-migration-code-migrate.md +48 -0
- package/merged-commands/framework-migration-deps-upgrade.md +48 -0
- package/merged-commands/framework-migration-legacy-modernize.md +132 -0
- package/merged-commands/free-tool-strategy.md +576 -0
- package/merged-commands/frontend-design.md +272 -0
- package/merged-commands/frontend-dev-guidelines.md +359 -0
- package/merged-commands/frontend-developer.md +171 -0
- package/merged-commands/frontend-development.md +399 -0
- package/merged-commands/frontend-mobile-development-component-scaffold.md +403 -0
- package/merged-commands/frontend-mobile-security-xss-scan.md +322 -0
- package/merged-commands/frontend-security-coder.md +170 -0
- package/merged-commands/frontend-slides.md +770 -0
- package/merged-commands/full-stack-orchestration-full-stack-feature.md +135 -0
- package/merged-commands/fullstack-guardian.md +99 -0
- package/merged-commands/game-developer.md +94 -0
- package/merged-commands/game-development.md +167 -0
- package/merged-commands/gcp-cloud-run.md +288 -0
- package/merged-commands/gdpr-data-handling.md +33 -0
- package/merged-commands/geo-fundamentals.md +156 -0
- package/merged-commands/git-advanced-workflows.md +412 -0
- package/merged-commands/git-pr-workflows-git-workflow.md +140 -0
- package/merged-commands/git-pr-workflows-onboard.md +416 -0
- package/merged-commands/git-pr-workflows-pr-enhance.md +48 -0
- package/merged-commands/git-pushing.md +33 -0
- package/merged-commands/github-actions-templates.md +345 -0
- package/merged-commands/github-workflow-automation.md +846 -0
- package/merged-commands/gitlab-ci-patterns.md +283 -0
- package/merged-commands/gitops-workflow.md +303 -0
- package/merged-commands/go-concurrency-patterns.md +33 -0
- package/merged-commands/godot-gdscript-patterns.md +33 -0
- package/merged-commands/golang-pro.md +179 -0
- package/merged-commands/google-adk-python.md +243 -0
- package/merged-commands/grafana-dashboards.md +381 -0
- package/merged-commands/graphql-architect.md +182 -0
- package/merged-commands/graphql.md +68 -0
- package/merged-commands/haskell-pro.md +56 -0
- package/merged-commands/helm-chart-scaffolding.md +34 -0
- package/merged-commands/hr-pro.md +126 -0
- package/merged-commands/html-injection-testing.md +498 -0
- package/merged-commands/hubspot-integration.md +42 -0
- package/merged-commands/hugging-face-cli.md +198 -0
- package/merged-commands/hugging-face-jobs.md +1038 -0
- package/merged-commands/hybrid-cloud-architect.md +168 -0
- package/merged-commands/hybrid-cloud-networking.md +238 -0
- package/merged-commands/hybrid-search-implementation.md +32 -0
- package/merged-commands/i18n-localization.md +154 -0
- package/merged-commands/idor-testing.md +442 -0
- package/merged-commands/image-enhancer.md +99 -0
- package/merged-commands/imagen.md +77 -0
- package/merged-commands/incident-responder.md +213 -0
- package/merged-commands/incident-response-incident-response.md +168 -0
- package/merged-commands/incident-response-smart-fix.md +29 -0
- package/merged-commands/incident-runbook-templates.md +395 -0
- package/merged-commands/infinite-gratitude.md +26 -0
- package/merged-commands/inngest.md +55 -0
- package/merged-commands/interactive-portfolio.md +223 -0
- package/merged-commands/internal-comms-anthropic.md +32 -0
- package/merged-commands/internal-comms-community.md +32 -0
- package/merged-commands/internal-comms.md +32 -0
- package/merged-commands/invoice-organizer.md +446 -0
- package/merged-commands/ios-developer.md +219 -0
- package/merged-commands/issue-creator.md +137 -0
- package/merged-commands/istio-traffic-management.md +337 -0
- package/merged-commands/iterate-pr.md +150 -0
- package/merged-commands/java-architect.md +95 -0
- package/merged-commands/java-pro.md +177 -0
- package/merged-commands/javascript-mastery.md +645 -0
- package/merged-commands/javascript-pro.md +57 -0
- package/merged-commands/javascript-testing-patterns.md +35 -0
- package/merged-commands/javascript-typescript-typescript-scaffold.md +361 -0
- package/merged-commands/javascript-typescript.md +142 -0
- package/merged-commands/jira-issues.md +181 -0
- package/merged-commands/job-application.md +90 -0
- package/merged-commands/julia-pro.md +209 -0
- package/merged-commands/k8s-manifest-generator.md +35 -0
- package/merged-commands/k8s-security-policies.md +346 -0
- package/merged-commands/kaizen.md +730 -0
- package/merged-commands/kotlin-specialist.md +94 -0
- package/merged-commands/kpi-dashboard-design.md +440 -0
- package/merged-commands/kubernetes-architect.md +170 -0
- package/merged-commands/kubernetes-specialist.md +117 -0
- package/merged-commands/langchain-architecture.md +350 -0
- package/merged-commands/langfuse.md +238 -0
- package/merged-commands/langgraph.md +287 -0
- package/merged-commands/laravel-specialist.md +101 -0
- package/merged-commands/last30days.md +421 -0
- package/merged-commands/launch-strategy.md +344 -0
- package/merged-commands/lead-research-assistant.md +199 -0
- package/merged-commands/learn.md +476 -0
- package/merged-commands/legacy-modernizer.md +53 -0
- package/merged-commands/legal-advisor.md +70 -0
- package/merged-commands/linear-claude-skill.md +543 -0
- package/merged-commands/linkerd-patterns.md +321 -0
- package/merged-commands/lint-and-validate.md +45 -0
- package/merged-commands/linux-privilege-escalation.md +504 -0
- package/merged-commands/linux-shell-scripting.md +504 -0
- package/merged-commands/llm-app-patterns.md +760 -0
- package/merged-commands/llm-application-dev-ai-assistant.md +35 -0
- package/merged-commands/llm-application-dev-langchain-agent.md +246 -0
- package/merged-commands/llm-application-dev-prompt-optimize.md +37 -0
- package/merged-commands/llm-application-dev.md +216 -0
- package/merged-commands/llm-evaluation.md +483 -0
- package/merged-commands/loki-mode.md +721 -0
- package/merged-commands/machine-learning-ops-ml-pipeline.md +314 -0
- package/merged-commands/makepad-skills.md +22 -0
- package/merged-commands/malware-analyst.md +247 -0
- package/merged-commands/markdown-novel-viewer.md +281 -0
- package/merged-commands/market-sizing-analysis.md +425 -0
- package/merged-commands/marketing-ideas.md +221 -0
- package/merged-commands/marketing-psychology.md +255 -0
- package/merged-commands/mcp-builder.md +236 -0
- package/merged-commands/mcp-developer.md +94 -0
- package/merged-commands/mcp-management.md +209 -0
- package/merged-commands/media-processing.md +358 -0
- package/merged-commands/meeting-insights-analyzer.md +327 -0
- package/merged-commands/memory-forensics.md +491 -0
- package/merged-commands/memory-safety-patterns.md +33 -0
- package/merged-commands/memory-systems.md +228 -0
- package/merged-commands/mermaid-expert.md +59 -0
- package/merged-commands/mermaidjs-v11.md +115 -0
- package/merged-commands/metasploit-framework.md +478 -0
- package/merged-commands/micro-saas-launcher.md +212 -0
- package/merged-commands/microservices-architect.md +102 -0
- package/merged-commands/microservices-patterns.md +35 -0
- package/merged-commands/minecraft-bukkit-pro.md +126 -0
- package/merged-commands/ml-engineer.md +168 -0
- package/merged-commands/ml-pipeline-workflow.md +257 -0
- package/merged-commands/ml-pipeline.md +111 -0
- package/merged-commands/mlops-engineer.md +219 -0
- package/merged-commands/mobile-design.md +284 -0
- package/merged-commands/mobile-developer.md +205 -0
- package/merged-commands/mobile-development.md +212 -0
- package/merged-commands/mobile-security-coder.md +184 -0
- package/merged-commands/modern-javascript-patterns.md +35 -0
- package/merged-commands/monitoring-expert.md +92 -0
- package/merged-commands/monorepo-architect.md +61 -0
- package/merged-commands/monorepo-management.md +35 -0
- package/merged-commands/moodle-external-api-development.md +597 -0
- package/merged-commands/mtls-configuration.md +359 -0
- package/merged-commands/multi-agent-brainstorming.md +256 -0
- package/merged-commands/multi-agent-patterns.md +262 -0
- package/merged-commands/multi-cloud-architecture.md +189 -0
- package/merged-commands/multi-platform-apps-multi-platform.md +203 -0
- package/merged-commands/n8n-code-python.md +750 -0
- package/merged-commands/n8n-mcp-tools-expert.md +654 -0
- package/merged-commands/n8n-node-configuration.md +796 -0
- package/merged-commands/nanobanana-ppt-skills.md +22 -0
- package/merged-commands/neon-postgres.md +56 -0
- package/merged-commands/nestjs-expert.md +552 -0
- package/merged-commands/network-101.md +342 -0
- package/merged-commands/network-engineer.md +169 -0
- package/merged-commands/nextjs-app-router-patterns.md +33 -0
- package/merged-commands/nextjs-best-practices.md +203 -0
- package/merged-commands/nextjs-developer.md +97 -0
- package/merged-commands/nextjs-supabase-auth.md +56 -0
- package/merged-commands/nft-standards.md +395 -0
- package/merged-commands/nodejs-backend-patterns.md +35 -0
- package/merged-commands/nodejs-best-practices.md +333 -0
- package/merged-commands/nosql-expert.md +111 -0
- package/merged-commands/notebooklm-skill.md +269 -0
- package/merged-commands/notebooklm.md +269 -0
- package/merged-commands/notion-template-business.md +216 -0
- package/merged-commands/nx-workspace-patterns.md +464 -0
- package/merged-commands/observability-engineer.md +237 -0
- package/merged-commands/observability-monitoring-monitor-setup.md +48 -0
- package/merged-commands/observability-monitoring-slo-implement.md +43 -0
- package/merged-commands/observe-whatsapp.md +109 -0
- package/merged-commands/obsidian-clipper-template-creator.md +64 -0
- package/merged-commands/on-call-handoff-patterns.md +453 -0
- package/merged-commands/onboarding-cro.md +433 -0
- package/merged-commands/openapi-spec-generation.md +33 -0
- package/merged-commands/page-cro.md +343 -0
- package/merged-commands/paid-ads.md +551 -0
- package/merged-commands/pandas-pro.md +96 -0
- package/merged-commands/parallel-agents.md +175 -0
- package/merged-commands/payment-integration.md +77 -0
- package/merged-commands/paypal-integration.md +479 -0
- package/merged-commands/paywall-upgrade-cro.md +570 -0
- package/merged-commands/pci-compliance.md +478 -0
- package/merged-commands/pdf-official.md +294 -0
- package/merged-commands/pdf.md +294 -0
- package/merged-commands/pentest-checklist.md +334 -0
- package/merged-commands/pentest-commands.md +438 -0
- package/merged-commands/performance-engineer.md +180 -0
- package/merged-commands/performance-profiling.md +143 -0
- package/merged-commands/performance-testing-review-ai-review.md +450 -0
- package/merged-commands/performance-testing-review-multi-agent-review.md +216 -0
- package/merged-commands/personal-tool-builder.md +289 -0
- package/merged-commands/php-pro.md +63 -0
- package/merged-commands/plaid-fintech.md +50 -0
- package/merged-commands/plan-writing.md +152 -0
- package/merged-commands/planning-with-files.md +211 -0
- package/merged-commands/planning.md +95 -0
- package/merged-commands/plans-kanban.md +166 -0
- package/merged-commands/playwright-expert.md +87 -0
- package/merged-commands/playwright-skill.md +453 -0
- package/merged-commands/podcast-generation.md +121 -0
- package/merged-commands/popup-cro.md +346 -0
- package/merged-commands/posix-shell-pro.md +304 -0
- package/merged-commands/postgres-best-practices.md +57 -0
- package/merged-commands/postgres-pro.md +98 -0
- package/merged-commands/postgresql.md +230 -0
- package/merged-commands/postmortem-writing.md +386 -0
- package/merged-commands/powershell-windows.md +167 -0
- package/merged-commands/pptx-official.md +484 -0
- package/merged-commands/pptx.md +484 -0
- package/merged-commands/pricing-strategy.md +356 -0
- package/merged-commands/prisma-expert.md +355 -0
- package/merged-commands/privilege-escalation-methods.md +333 -0
- package/merged-commands/problem-solving.md +96 -0
- package/merged-commands/product-manager-toolkit.md +351 -0
- package/merged-commands/product-strategist.md +26 -0
- package/merged-commands/production-code-audit.md +540 -0
- package/merged-commands/programmatic-seo.md +351 -0
- package/merged-commands/projection-patterns.md +33 -0
- package/merged-commands/prometheus-configuration.md +404 -0
- package/merged-commands/prompt-caching.md +61 -0
- package/merged-commands/prompt-engineer.md +272 -0
- package/merged-commands/prompt-engineering-patterns.md +213 -0
- package/merged-commands/prompt-engineering.md +171 -0
- package/merged-commands/prompt-library.md +322 -0
- package/merged-commands/protocol-reverse-engineering.md +29 -0
- package/merged-commands/pydantic-models.md +58 -0
- package/merged-commands/pypict-skill.md +22 -0
- package/merged-commands/python-development-python-scaffold.md +331 -0
- package/merged-commands/python-development.md +139 -0
- package/merged-commands/python-packaging.md +36 -0
- package/merged-commands/python-patterns.md +441 -0
- package/merged-commands/python-performance-optimization.md +36 -0
- package/merged-commands/python-pro.md +158 -0
- package/merged-commands/python-testing-patterns.md +37 -0
- package/merged-commands/qa-regression.md +337 -0
- package/merged-commands/quant-analyst.md +53 -0
- package/merged-commands/radix-ui-design-system.md +847 -0
- package/merged-commands/raffle-winner-picker.md +159 -0
- package/merged-commands/rag-architect.md +100 -0
- package/merged-commands/rag-engineer.md +90 -0
- package/merged-commands/rag-implementation.md +421 -0
- package/merged-commands/rails-expert.md +97 -0
- package/merged-commands/react-best-practices.md +121 -0
- package/merged-commands/react-expert.md +98 -0
- package/merged-commands/react-flow-node.md +66 -0
- package/merged-commands/react-modernization.md +34 -0
- package/merged-commands/react-native-architecture.md +33 -0
- package/merged-commands/react-native-expert.md +88 -0
- package/merged-commands/react-patterns.md +198 -0
- package/merged-commands/react-state-management.md +441 -0
- package/merged-commands/react-ui-patterns.md +289 -0
- package/merged-commands/readme.md +775 -0
- package/merged-commands/receiving-code-review.md +213 -0
- package/merged-commands/red-team-tactics.md +199 -0
- package/merged-commands/red-team-tools.md +310 -0
- package/merged-commands/reference-builder.md +188 -0
- package/merged-commands/referral-program.md +602 -0
- package/merged-commands/remotion-best-practices.md +45 -0
- package/merged-commands/repomix.md +275 -0
- package/merged-commands/requesting-code-review.md +105 -0
- package/merged-commands/research-engineer.md +135 -0
- package/merged-commands/research.md +191 -0
- package/merged-commands/reverse-engineer.md +173 -0
- package/merged-commands/risk-manager.md +61 -0
- package/merged-commands/risk-metrics-calculation.md +33 -0
- package/merged-commands/ruby-pro.md +56 -0
- package/merged-commands/rust-async-patterns.md +33 -0
- package/merged-commands/rust-engineer.md +96 -0
- package/merged-commands/rust-pro.md +178 -0
- package/merged-commands/saga-orchestration.md +496 -0
- package/merged-commands/sales-automator.md +55 -0
- package/merged-commands/salesforce-developer.md +105 -0
- package/merged-commands/salesforce-development.md +51 -0
- package/merged-commands/sast-configuration.md +212 -0
- package/merged-commands/scala-pro.md +82 -0
- package/merged-commands/scanning-tools.md +589 -0
- package/merged-commands/schema-markup.md +360 -0
- package/merged-commands/screen-reader-testing.md +33 -0
- package/merged-commands/screenshots.md +401 -0
- package/merged-commands/scroll-experience.md +263 -0
- package/merged-commands/search-specialist.md +80 -0
- package/merged-commands/secrets-management.md +364 -0
- package/merged-commands/secure-code-guardian.md +93 -0
- package/merged-commands/security-auditor.md +169 -0
- package/merged-commands/security-bluebook-builder.md +22 -0
- package/merged-commands/security-compliance-compliance-check.md +55 -0
- package/merged-commands/security-requirement-extraction.md +33 -0
- package/merged-commands/security-reviewer.md +94 -0
- package/merged-commands/security-scanning-security-dependencies.md +43 -0
- package/merged-commands/security-scanning-security-hardening.md +147 -0
- package/merged-commands/security-scanning-security-sast.md +495 -0
- package/merged-commands/segment-cdp.md +50 -0
- package/merged-commands/senior-architect.md +209 -0
- package/merged-commands/senior-backend.md +209 -0
- package/merged-commands/senior-computer-vision.md +226 -0
- package/merged-commands/senior-data-engineer.md +226 -0
- package/merged-commands/senior-data-scientist.md +226 -0
- package/merged-commands/senior-devops.md +209 -0
- package/merged-commands/senior-frontend.md +209 -0
- package/merged-commands/senior-fullstack.md +209 -0
- package/merged-commands/senior-ml-engineer.md +226 -0
- package/merged-commands/senior-prompt-engineer.md +226 -0
- package/merged-commands/senior-qa.md +209 -0
- package/merged-commands/senior-secops.md +209 -0
- package/merged-commands/senior-security.md +209 -0
- package/merged-commands/seo-audit.md +487 -0
- package/merged-commands/seo-authority-builder.md +136 -0
- package/merged-commands/seo-cannibalization-detector.md +123 -0
- package/merged-commands/seo-content-auditor.md +83 -0
- package/merged-commands/seo-content-planner.md +108 -0
- package/merged-commands/seo-content-refresher.md +118 -0
- package/merged-commands/seo-content-writer.md +96 -0
- package/merged-commands/seo-fundamentals.md +173 -0
- package/merged-commands/seo-keyword-strategist.md +95 -0
- package/merged-commands/seo-meta-optimizer.md +92 -0
- package/merged-commands/seo-snippet-hunter.md +114 -0
- package/merged-commands/seo-structure-architect.md +108 -0
- package/merged-commands/sequential-thinking.md +94 -0
- package/merged-commands/server-management.md +161 -0
- package/merged-commands/service-mesh-expert.md +58 -0
- package/merged-commands/service-mesh-observability.md +395 -0
- package/merged-commands/sharp-edges.md +70 -0
- package/merged-commands/shellcheck-configuration.md +466 -0
- package/merged-commands/shodan-reconnaissance.md +503 -0
- package/merged-commands/shopify-apps.md +42 -0
- package/merged-commands/shopify-development.md +366 -0
- package/merged-commands/shopify-expert.md +102 -0
- package/merged-commands/signup-flow-cro.md +355 -0
- package/merged-commands/similarity-search-patterns.md +33 -0
- package/merged-commands/skill-creator.md +356 -0
- package/merged-commands/skill-developer.md +426 -0
- package/merged-commands/skill-rails-upgrade.md +408 -0
- package/merged-commands/skill-seekers.md +22 -0
- package/merged-commands/skill-share.md +80 -0
- package/merged-commands/slack-bot-builder.md +264 -0
- package/merged-commands/slack-gif-creator.md +254 -0
- package/merged-commands/slo-implementation.md +341 -0
- package/merged-commands/smtp-penetration-testing.md +500 -0
- package/merged-commands/social-content.md +807 -0
- package/merged-commands/software-architecture.md +75 -0
- package/merged-commands/solidity-security.md +34 -0
- package/merged-commands/spark-engineer.md +100 -0
- package/merged-commands/spark-optimization.md +427 -0
- package/merged-commands/spec-miner.md +88 -0
- package/merged-commands/spring-boot-engineer.md +104 -0
- package/merged-commands/sql-injection-testing.md +448 -0
- package/merged-commands/sql-optimization-patterns.md +35 -0
- package/merged-commands/sql-pro.md +173 -0
- package/merged-commands/sqlmap-database-pentesting.md +400 -0
- package/merged-commands/sre-engineer.md +98 -0
- package/merged-commands/ssh-penetration-testing.md +488 -0
- package/merged-commands/startup-analyst.md +328 -0
- package/merged-commands/startup-business-analyst-business-case.md +487 -0
- package/merged-commands/startup-business-analyst-financial-projections.md +353 -0
- package/merged-commands/startup-business-analyst-market-opportunity.md +240 -0
- package/merged-commands/startup-financial-modeling.md +467 -0
- package/merged-commands/startup-metrics-framework.md +34 -0
- package/merged-commands/stitch-ui-design.md +378 -0
- package/merged-commands/stride-analysis-patterns.md +33 -0
- package/merged-commands/stripe-integration.md +454 -0
- package/merged-commands/subagent-driven-development.md +240 -0
- package/merged-commands/superpowers-lab.md +22 -0
- package/merged-commands/swift-expert.md +94 -0
- package/merged-commands/swiftui-expert-skill.md +275 -0
- package/merged-commands/systematic-debugging.md +296 -0
- package/merged-commands/systems-programming-rust-project.md +440 -0
- package/merged-commands/tailwind-design-system.md +33 -0
- package/merged-commands/tailwind-patterns.md +269 -0
- package/merged-commands/tavily-web.md +36 -0
- package/merged-commands/tdd-orchestrator.md +205 -0
- package/merged-commands/tdd-workflow.md +149 -0
- package/merged-commands/tdd-workflows-tdd-cycle.md +221 -0
- package/merged-commands/tdd-workflows-tdd-green.md +73 -0
- package/merged-commands/tdd-workflows-tdd-red.md +164 -0
- package/merged-commands/tdd-workflows-tdd-refactor.md +187 -0
- package/merged-commands/team-collaboration-issue.md +37 -0
- package/merged-commands/team-collaboration-standup-notes.md +44 -0
- package/merged-commands/team-composition-analysis.md +413 -0
- package/merged-commands/telegram-bot-builder.md +254 -0
- package/merged-commands/telegram-mini-app.md +279 -0
- package/merged-commands/template-skill.md +6 -0
- package/merged-commands/temporal-python-pro.md +370 -0
- package/merged-commands/temporal-python-testing.md +170 -0
- package/merged-commands/terraform-engineer.md +97 -0
- package/merged-commands/terraform-module-library.md +261 -0
- package/merged-commands/terraform-skill.md +517 -0
- package/merged-commands/terraform-specialist.md +166 -0
- package/merged-commands/test-automator.md +224 -0
- package/merged-commands/test-driven-development.md +371 -0
- package/merged-commands/test-fixing.md +119 -0
- package/merged-commands/test-master.md +104 -0
- package/merged-commands/testing-patterns.md +259 -0
- package/merged-commands/theme-factory.md +59 -0
- package/merged-commands/threat-mitigation-mapping.md +33 -0
- package/merged-commands/threat-modeling-expert.md +60 -0
- package/merged-commands/threejs-skills.md +22 -0
- package/merged-commands/threejs.md +89 -0
- package/merged-commands/tool-design.md +318 -0
- package/merged-commands/top-web-vulnerabilities.md +543 -0
- package/merged-commands/track-management.md +38 -0
- package/merged-commands/trigger-dev.md +67 -0
- package/merged-commands/turborepo-caching.md +419 -0
- package/merged-commands/tutorial-engineer.md +139 -0
- package/merged-commands/twilio-communications.md +295 -0
- package/merged-commands/typescript-advanced-types.md +35 -0
- package/merged-commands/typescript-expert.md +429 -0
- package/merged-commands/typescript-pro.md +55 -0
- package/merged-commands/ui-design-system.md +32 -0
- package/merged-commands/ui-skills.md +22 -0
- package/merged-commands/ui-styling.md +321 -0
- package/merged-commands/ui-ux-designer.md +209 -0
- package/merged-commands/ui-ux-pro-max.md +351 -0
- package/merged-commands/ui-visual-validator.md +214 -0
- package/merged-commands/unit-testing-test-generate.md +319 -0
- package/merged-commands/unity-developer.md +230 -0
- package/merged-commands/unity-ecs-patterns.md +33 -0
- package/merged-commands/unreal-engine-cpp-pro.md +114 -0
- package/merged-commands/upgrading-expo.md +118 -0
- package/merged-commands/upstash-qstash.md +68 -0
- package/merged-commands/using-git-worktrees.md +217 -0
- package/merged-commands/using-neon.md +84 -0
- package/merged-commands/using-superpowers.md +87 -0
- package/merged-commands/uv-package-manager.md +37 -0
- package/merged-commands/ux-researcher-designer.md +30 -0
- package/merged-commands/varlock-claude-skill.md +22 -0
- package/merged-commands/vector-database-engineer.md +60 -0
- package/merged-commands/vector-index-tuning.md +42 -0
- package/merged-commands/vercel-deploy-claimable.md +120 -0
- package/merged-commands/vercel-deploy.md +22 -0
- package/merged-commands/vercel-deployment.md +79 -0
- package/merged-commands/verification-before-completion.md +139 -0
- package/merged-commands/vexor.md +22 -0
- package/merged-commands/video-downloader.md +106 -0
- package/merged-commands/viral-generator-builder.md +199 -0
- package/merged-commands/voice-agents.md +68 -0
- package/merged-commands/voice-ai-development.md +302 -0
- package/merged-commands/voice-ai-engine-development.md +721 -0
- package/merged-commands/vue-expert-js.md +91 -0
- package/merged-commands/vue-expert.md +374 -0
- package/merged-commands/vulnerability-scanner.md +276 -0
- package/merged-commands/wcag-audit-patterns.md +41 -0
- package/merged-commands/web-artifacts-builder.md +74 -0
- package/merged-commands/web-design-guidelines.md +36 -0
- package/merged-commands/web-frameworks.md +324 -0
- package/merged-commands/web-performance-optimization.md +646 -0
- package/merged-commands/web3-testing.md +427 -0
- package/merged-commands/webapp-testing.md +96 -0
- package/merged-commands/websocket-engineer.md +96 -0
- package/merged-commands/windows-privilege-escalation.md +496 -0
- package/merged-commands/wireshark-analysis.md +497 -0
- package/merged-commands/wordpress-penetration-testing.md +485 -0
- package/merged-commands/wordpress-pro.md +105 -0
- package/merged-commands/workflow-automation.md +68 -0
- package/merged-commands/workflow-orchestration-patterns.md +333 -0
- package/merged-commands/workflow-patterns.md +38 -0
- package/merged-commands/writing-plans.md +116 -0
- package/merged-commands/writing-skills.md +125 -0
- package/merged-commands/x-article-publisher-skill.md +22 -0
- package/merged-commands/xlsx-official.md +289 -0
- package/merged-commands/xlsx.md +289 -0
- package/merged-commands/xss-html-injection.md +499 -0
- package/merged-commands/youtube-transcript.md +415 -0
- package/merged-commands/zapier-make-patterns.md +67 -0
- package/merged-commands/zustand-store.md +68 -0
- package/package.json +1 -1
- package/scripts/merge-commands.js +21 -0
|
@@ -0,0 +1,1038 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: hugging-face-jobs
|
|
3
|
+
description: "This skill should be used when users want to run any workload on Hugging Face Jobs infrastructure. Covers UV scripts, Docker-based jobs, hardware selection, cost estimation, authentication with tokens, secrets management, timeout configuration, and result persistence. Designed for general-purpose compute workloads including data processing, inference, experiments, batch jobs, and any Python-based tasks. Should be invoked for tasks involving cloud compute, GPU workloads, or when users mention running jobs on Hugging Face infrastructure without local setup."
|
|
4
|
+
license: "Complete terms in LICENSE.txt"
|
|
5
|
+
source: "https://github.com/huggingface/skills/tree/main/skills/hugging-face-jobs"
|
|
6
|
+
risk: safe
|
|
7
|
+
---
|
|
8
|
+
|
|
9
|
+
# Running Workloads on Hugging Face Jobs
|
|
10
|
+
|
|
11
|
+
## Overview
|
|
12
|
+
|
|
13
|
+
Run any workload on fully managed Hugging Face infrastructure. No local setup required—jobs run on cloud CPUs, GPUs, or TPUs and can persist results to the Hugging Face Hub.
|
|
14
|
+
|
|
15
|
+
**Common use cases:**
|
|
16
|
+
- **Data Processing** - Transform, filter, or analyze large datasets
|
|
17
|
+
- **Batch Inference** - Run inference on thousands of samples
|
|
18
|
+
- **Experiments & Benchmarks** - Reproducible ML experiments
|
|
19
|
+
- **Model Training** - Fine-tune models (see `model-trainer` skill for TRL-specific training)
|
|
20
|
+
- **Synthetic Data Generation** - Generate datasets using LLMs
|
|
21
|
+
- **Development & Testing** - Test code without local GPU setup
|
|
22
|
+
- **Scheduled Jobs** - Automate recurring tasks
|
|
23
|
+
|
|
24
|
+
**For model training specifically:** See the `model-trainer` skill for TRL-based training workflows.
|
|
25
|
+
|
|
26
|
+
## When to Use This Skill
|
|
27
|
+
|
|
28
|
+
Use this skill when users want to:
|
|
29
|
+
- Run Python workloads on cloud infrastructure
|
|
30
|
+
- Execute jobs without local GPU/TPU setup
|
|
31
|
+
- Process data at scale
|
|
32
|
+
- Run batch inference or experiments
|
|
33
|
+
- Schedule recurring tasks
|
|
34
|
+
- Use GPUs/TPUs for any workload
|
|
35
|
+
- Persist results to the Hugging Face Hub
|
|
36
|
+
|
|
37
|
+
## Key Directives
|
|
38
|
+
|
|
39
|
+
When assisting with jobs:
|
|
40
|
+
|
|
41
|
+
1. **ALWAYS use `hf_jobs()` MCP tool** - Submit jobs using `hf_jobs("uv", {...})` or `hf_jobs("run", {...})`. The `script` parameter accepts Python code directly. Do NOT save to local files unless the user explicitly requests it. Pass the script content as a string to `hf_jobs()`.
|
|
42
|
+
|
|
43
|
+
2. **Always handle authentication** - Jobs that interact with the Hub require `HF_TOKEN` via secrets. See Token Usage section below.
|
|
44
|
+
|
|
45
|
+
3. **Provide job details after submission** - After submitting, provide job ID, monitoring URL, estimated time, and note that the user can request status checks later.
|
|
46
|
+
|
|
47
|
+
4. **Set appropriate timeouts** - Default 30min may be insufficient for long-running tasks.
|
|
48
|
+
|
|
49
|
+
## Prerequisites Checklist
|
|
50
|
+
|
|
51
|
+
Before starting any job, verify:
|
|
52
|
+
|
|
53
|
+
### ✅ **Account & Authentication**
|
|
54
|
+
- Hugging Face Account with [Pro](https://hf.co/pro), [Team](https://hf.co/enterprise), or [Enterprise](https://hf.co/enterprise) plan (Jobs require paid plan)
|
|
55
|
+
- Authenticated login: Check with `hf_whoami()`
|
|
56
|
+
- **HF_TOKEN for Hub Access** ⚠️ CRITICAL - Required for any Hub operations (push models/datasets, download private repos, etc.)
|
|
57
|
+
- Token must have appropriate permissions (read for downloads, write for uploads)
|
|
58
|
+
|
|
59
|
+
### ✅ **Token Usage** (See Token Usage section for details)
|
|
60
|
+
|
|
61
|
+
**When tokens are required:**
|
|
62
|
+
- Pushing models/datasets to Hub
|
|
63
|
+
- Accessing private repositories
|
|
64
|
+
- Using Hub APIs in scripts
|
|
65
|
+
- Any authenticated Hub operations
|
|
66
|
+
|
|
67
|
+
**How to provide tokens:**
|
|
68
|
+
```python
|
|
69
|
+
{
|
|
70
|
+
"secrets": {"HF_TOKEN": "$HF_TOKEN"} # Recommended: automatic token
|
|
71
|
+
}
|
|
72
|
+
```
|
|
73
|
+
|
|
74
|
+
**⚠️ CRITICAL:** The `$HF_TOKEN` placeholder is automatically replaced with your logged-in token. Never hardcode tokens in scripts.
|
|
75
|
+
|
|
76
|
+
## Token Usage Guide
|
|
77
|
+
|
|
78
|
+
### Understanding Tokens
|
|
79
|
+
|
|
80
|
+
**What are HF Tokens?**
|
|
81
|
+
- Authentication credentials for Hugging Face Hub
|
|
82
|
+
- Required for authenticated operations (push, private repos, API access)
|
|
83
|
+
- Stored securely on your machine after `hf auth login`
|
|
84
|
+
|
|
85
|
+
**Token Types:**
|
|
86
|
+
- **Read Token** - Can download models/datasets, read private repos
|
|
87
|
+
- **Write Token** - Can push models/datasets, create repos, modify content
|
|
88
|
+
- **Organization Token** - Can act on behalf of an organization
|
|
89
|
+
|
|
90
|
+
### When Tokens Are Required
|
|
91
|
+
|
|
92
|
+
**Always Required:**
|
|
93
|
+
- Pushing models/datasets to Hub
|
|
94
|
+
- Accessing private repositories
|
|
95
|
+
- Creating new repositories
|
|
96
|
+
- Modifying existing repositories
|
|
97
|
+
- Using Hub APIs programmatically
|
|
98
|
+
|
|
99
|
+
**Not Required:**
|
|
100
|
+
- Downloading public models/datasets
|
|
101
|
+
- Running jobs that don't interact with Hub
|
|
102
|
+
- Reading public repository information
|
|
103
|
+
|
|
104
|
+
### How to Provide Tokens to Jobs
|
|
105
|
+
|
|
106
|
+
#### Method 1: Automatic Token (Recommended)
|
|
107
|
+
|
|
108
|
+
```python
|
|
109
|
+
hf_jobs("uv", {
|
|
110
|
+
"script": "your_script.py",
|
|
111
|
+
"secrets": {"HF_TOKEN": "$HF_TOKEN"} # ✅ Automatic replacement
|
|
112
|
+
})
|
|
113
|
+
```
|
|
114
|
+
|
|
115
|
+
**How it works:**
|
|
116
|
+
- `$HF_TOKEN` is a placeholder that gets replaced with your actual token
|
|
117
|
+
- Uses the token from your logged-in session (`hf auth login`)
|
|
118
|
+
- Most secure and convenient method
|
|
119
|
+
- Token is encrypted server-side when passed as a secret
|
|
120
|
+
|
|
121
|
+
**Benefits:**
|
|
122
|
+
- No token exposure in code
|
|
123
|
+
- Uses your current login session
|
|
124
|
+
- Automatically updated if you re-login
|
|
125
|
+
- Works seamlessly with MCP tools
|
|
126
|
+
|
|
127
|
+
#### Method 2: Explicit Token (Not Recommended)
|
|
128
|
+
|
|
129
|
+
```python
|
|
130
|
+
hf_jobs("uv", {
|
|
131
|
+
"script": "your_script.py",
|
|
132
|
+
"secrets": {"HF_TOKEN": "hf_abc123..."} # ⚠️ Hardcoded token
|
|
133
|
+
})
|
|
134
|
+
```
|
|
135
|
+
|
|
136
|
+
**When to use:**
|
|
137
|
+
- Only if automatic token doesn't work
|
|
138
|
+
- Testing with a specific token
|
|
139
|
+
- Organization tokens (use with caution)
|
|
140
|
+
|
|
141
|
+
**Security concerns:**
|
|
142
|
+
- Token visible in code/logs
|
|
143
|
+
- Must manually update if token rotates
|
|
144
|
+
- Risk of token exposure
|
|
145
|
+
|
|
146
|
+
#### Method 3: Environment Variable (Less Secure)
|
|
147
|
+
|
|
148
|
+
```python
|
|
149
|
+
hf_jobs("uv", {
|
|
150
|
+
"script": "your_script.py",
|
|
151
|
+
"env": {"HF_TOKEN": "hf_abc123..."} # ⚠️ Less secure than secrets
|
|
152
|
+
})
|
|
153
|
+
```
|
|
154
|
+
|
|
155
|
+
**Difference from secrets:**
|
|
156
|
+
- `env` variables are visible in job logs
|
|
157
|
+
- `secrets` are encrypted server-side
|
|
158
|
+
- Always prefer `secrets` for tokens
|
|
159
|
+
|
|
160
|
+
### Using Tokens in Scripts
|
|
161
|
+
|
|
162
|
+
**In your Python script, tokens are available as environment variables:**
|
|
163
|
+
|
|
164
|
+
```python
|
|
165
|
+
# /// script
|
|
166
|
+
# dependencies = ["huggingface-hub"]
|
|
167
|
+
# ///
|
|
168
|
+
|
|
169
|
+
import os
|
|
170
|
+
from huggingface_hub import HfApi
|
|
171
|
+
|
|
172
|
+
# Token is automatically available if passed via secrets
|
|
173
|
+
token = os.environ.get("HF_TOKEN")
|
|
174
|
+
|
|
175
|
+
# Use with Hub API
|
|
176
|
+
api = HfApi(token=token)
|
|
177
|
+
|
|
178
|
+
# Or let huggingface_hub auto-detect
|
|
179
|
+
api = HfApi() # Automatically uses HF_TOKEN env var
|
|
180
|
+
```
|
|
181
|
+
|
|
182
|
+
**Best practices:**
|
|
183
|
+
- Don't hardcode tokens in scripts
|
|
184
|
+
- Use `os.environ.get("HF_TOKEN")` to access
|
|
185
|
+
- Let `huggingface_hub` auto-detect when possible
|
|
186
|
+
- Verify token exists before Hub operations
|
|
187
|
+
|
|
188
|
+
### Token Verification
|
|
189
|
+
|
|
190
|
+
**Check if you're logged in:**
|
|
191
|
+
```python
|
|
192
|
+
from huggingface_hub import whoami
|
|
193
|
+
user_info = whoami() # Returns your username if authenticated
|
|
194
|
+
```
|
|
195
|
+
|
|
196
|
+
**Verify token in job:**
|
|
197
|
+
```python
|
|
198
|
+
import os
|
|
199
|
+
assert "HF_TOKEN" in os.environ, "HF_TOKEN not found!"
|
|
200
|
+
token = os.environ["HF_TOKEN"]
|
|
201
|
+
print(f"Token starts with: {token[:7]}...") # Should start with "hf_"
|
|
202
|
+
```
|
|
203
|
+
|
|
204
|
+
### Common Token Issues
|
|
205
|
+
|
|
206
|
+
**Error: 401 Unauthorized**
|
|
207
|
+
- **Cause:** Token missing or invalid
|
|
208
|
+
- **Fix:** Add `secrets={"HF_TOKEN": "$HF_TOKEN"}` to job config
|
|
209
|
+
- **Verify:** Check `hf_whoami()` works locally
|
|
210
|
+
|
|
211
|
+
**Error: 403 Forbidden**
|
|
212
|
+
- **Cause:** Token lacks required permissions
|
|
213
|
+
- **Fix:** Ensure token has write permissions for push operations
|
|
214
|
+
- **Check:** Token type at https://huggingface.co/settings/tokens
|
|
215
|
+
|
|
216
|
+
**Error: Token not found in environment**
|
|
217
|
+
- **Cause:** `secrets` not passed or wrong key name
|
|
218
|
+
- **Fix:** Use `secrets={"HF_TOKEN": "$HF_TOKEN"}` (not `env`)
|
|
219
|
+
- **Verify:** Script checks `os.environ.get("HF_TOKEN")`
|
|
220
|
+
|
|
221
|
+
**Error: Repository access denied**
|
|
222
|
+
- **Cause:** Token doesn't have access to private repo
|
|
223
|
+
- **Fix:** Use token from account with access
|
|
224
|
+
- **Check:** Verify repo visibility and your permissions
|
|
225
|
+
|
|
226
|
+
### Token Security Best Practices
|
|
227
|
+
|
|
228
|
+
1. **Never commit tokens** - Use `$HF_TOKEN` placeholder or environment variables
|
|
229
|
+
2. **Use secrets, not env** - Secrets are encrypted server-side
|
|
230
|
+
3. **Rotate tokens regularly** - Generate new tokens periodically
|
|
231
|
+
4. **Use minimal permissions** - Create tokens with only needed permissions
|
|
232
|
+
5. **Don't share tokens** - Each user should use their own token
|
|
233
|
+
6. **Monitor token usage** - Check token activity in Hub settings
|
|
234
|
+
|
|
235
|
+
### Complete Token Example
|
|
236
|
+
|
|
237
|
+
```python
|
|
238
|
+
# Example: Push results to Hub
|
|
239
|
+
hf_jobs("uv", {
|
|
240
|
+
"script": """
|
|
241
|
+
# /// script
|
|
242
|
+
# dependencies = ["huggingface-hub", "datasets"]
|
|
243
|
+
# ///
|
|
244
|
+
|
|
245
|
+
import os
|
|
246
|
+
from huggingface_hub import HfApi
|
|
247
|
+
from datasets import Dataset
|
|
248
|
+
|
|
249
|
+
# Verify token is available
|
|
250
|
+
assert "HF_TOKEN" in os.environ, "HF_TOKEN required!"
|
|
251
|
+
|
|
252
|
+
# Use token for Hub operations
|
|
253
|
+
api = HfApi(token=os.environ["HF_TOKEN"])
|
|
254
|
+
|
|
255
|
+
# Create and push dataset
|
|
256
|
+
data = {"text": ["Hello", "World"]}
|
|
257
|
+
dataset = Dataset.from_dict(data)
|
|
258
|
+
dataset.push_to_hub("username/my-dataset", token=os.environ["HF_TOKEN"])
|
|
259
|
+
|
|
260
|
+
print("✅ Dataset pushed successfully!")
|
|
261
|
+
""",
|
|
262
|
+
"flavor": "cpu-basic",
|
|
263
|
+
"timeout": "30m",
|
|
264
|
+
"secrets": {"HF_TOKEN": "$HF_TOKEN"} # ✅ Token provided securely
|
|
265
|
+
})
|
|
266
|
+
```
|
|
267
|
+
|
|
268
|
+
## Quick Start: Two Approaches
|
|
269
|
+
|
|
270
|
+
### Approach 1: UV Scripts (Recommended)
|
|
271
|
+
|
|
272
|
+
UV scripts use PEP 723 inline dependencies for clean, self-contained workloads.
|
|
273
|
+
|
|
274
|
+
**MCP Tool:**
|
|
275
|
+
```python
|
|
276
|
+
hf_jobs("uv", {
|
|
277
|
+
"script": """
|
|
278
|
+
# /// script
|
|
279
|
+
# dependencies = ["transformers", "torch"]
|
|
280
|
+
# ///
|
|
281
|
+
|
|
282
|
+
from transformers import pipeline
|
|
283
|
+
import torch
|
|
284
|
+
|
|
285
|
+
# Your workload here
|
|
286
|
+
classifier = pipeline("sentiment-analysis")
|
|
287
|
+
result = classifier("I love Hugging Face!")
|
|
288
|
+
print(result)
|
|
289
|
+
""",
|
|
290
|
+
"flavor": "cpu-basic",
|
|
291
|
+
"timeout": "30m"
|
|
292
|
+
})
|
|
293
|
+
```
|
|
294
|
+
|
|
295
|
+
**CLI Equivalent:**
|
|
296
|
+
```bash
|
|
297
|
+
hf jobs uv run my_script.py --flavor cpu-basic --timeout 30m
|
|
298
|
+
```
|
|
299
|
+
|
|
300
|
+
**Python API:**
|
|
301
|
+
```python
|
|
302
|
+
from huggingface_hub import run_uv_job
|
|
303
|
+
run_uv_job("my_script.py", flavor="cpu-basic", timeout="30m")
|
|
304
|
+
```
|
|
305
|
+
|
|
306
|
+
**Benefits:** Direct MCP tool usage, clean code, dependencies declared inline, no file saving required
|
|
307
|
+
|
|
308
|
+
**When to use:** Default choice for all workloads, custom logic, any scenario requiring `hf_jobs()`
|
|
309
|
+
|
|
310
|
+
#### Custom Docker Images for UV Scripts
|
|
311
|
+
|
|
312
|
+
By default, UV scripts use `ghcr.io/astral-sh/uv:python3.12-bookworm-slim`. For ML workloads with complex dependencies, use pre-built images:
|
|
313
|
+
|
|
314
|
+
```python
|
|
315
|
+
hf_jobs("uv", {
|
|
316
|
+
"script": "inference.py",
|
|
317
|
+
"image": "vllm/vllm-openai:latest", # Pre-built image with vLLM
|
|
318
|
+
"flavor": "a10g-large"
|
|
319
|
+
})
|
|
320
|
+
```
|
|
321
|
+
|
|
322
|
+
**CLI:**
|
|
323
|
+
```bash
|
|
324
|
+
hf jobs uv run --image vllm/vllm-openai:latest --flavor a10g-large inference.py
|
|
325
|
+
```
|
|
326
|
+
|
|
327
|
+
**Benefits:** Faster startup, pre-installed dependencies, optimized for specific frameworks
|
|
328
|
+
|
|
329
|
+
#### Python Version
|
|
330
|
+
|
|
331
|
+
By default, UV scripts use Python 3.12. Specify a different version:
|
|
332
|
+
|
|
333
|
+
```python
|
|
334
|
+
hf_jobs("uv", {
|
|
335
|
+
"script": "my_script.py",
|
|
336
|
+
"python": "3.11", # Use Python 3.11
|
|
337
|
+
"flavor": "cpu-basic"
|
|
338
|
+
})
|
|
339
|
+
```
|
|
340
|
+
|
|
341
|
+
**Python API:**
|
|
342
|
+
```python
|
|
343
|
+
from huggingface_hub import run_uv_job
|
|
344
|
+
run_uv_job("my_script.py", python="3.11")
|
|
345
|
+
```
|
|
346
|
+
|
|
347
|
+
#### Working with Scripts
|
|
348
|
+
|
|
349
|
+
⚠️ **Important:** There are *two* "script path" stories depending on how you run Jobs:
|
|
350
|
+
|
|
351
|
+
- **Using the `hf_jobs()` MCP tool (recommended in this repo)**: the `script` value must be **inline code** (a string) or a **URL**. A local filesystem path (like `"./scripts/foo.py"`) won't exist inside the remote container.
|
|
352
|
+
- **Using the `hf jobs uv run` CLI**: local file paths **do work** (the CLI uploads your script).
|
|
353
|
+
|
|
354
|
+
**Common mistake with `hf_jobs()` MCP tool:**
|
|
355
|
+
|
|
356
|
+
```python
|
|
357
|
+
# ❌ Will fail (remote container can't see your local path)
|
|
358
|
+
hf_jobs("uv", {"script": "./scripts/foo.py"})
|
|
359
|
+
```
|
|
360
|
+
|
|
361
|
+
**Correct patterns with `hf_jobs()` MCP tool:**
|
|
362
|
+
|
|
363
|
+
```python
|
|
364
|
+
# ✅ Inline: read the local script file and pass its *contents*
|
|
365
|
+
from pathlib import Path
|
|
366
|
+
script = Path("hf-jobs/scripts/foo.py").read_text()
|
|
367
|
+
hf_jobs("uv", {"script": script})
|
|
368
|
+
|
|
369
|
+
# ✅ URL: host the script somewhere reachable
|
|
370
|
+
hf_jobs("uv", {"script": "https://huggingface.co/datasets/uv-scripts/.../raw/main/foo.py"})
|
|
371
|
+
|
|
372
|
+
# ✅ URL from GitHub
|
|
373
|
+
hf_jobs("uv", {"script": "https://raw.githubusercontent.com/huggingface/trl/main/trl/scripts/sft.py"})
|
|
374
|
+
```
|
|
375
|
+
|
|
376
|
+
**CLI equivalent (local paths supported):**
|
|
377
|
+
|
|
378
|
+
```bash
|
|
379
|
+
hf jobs uv run ./scripts/foo.py -- --your --args
|
|
380
|
+
```
|
|
381
|
+
|
|
382
|
+
#### Adding Dependencies at Runtime
|
|
383
|
+
|
|
384
|
+
Add extra dependencies beyond what's in the PEP 723 header:
|
|
385
|
+
|
|
386
|
+
```python
|
|
387
|
+
hf_jobs("uv", {
|
|
388
|
+
"script": "inference.py",
|
|
389
|
+
"dependencies": ["transformers", "torch>=2.0"], # Extra deps
|
|
390
|
+
"flavor": "a10g-small"
|
|
391
|
+
})
|
|
392
|
+
```
|
|
393
|
+
|
|
394
|
+
**Python API:**
|
|
395
|
+
```python
|
|
396
|
+
from huggingface_hub import run_uv_job
|
|
397
|
+
run_uv_job("inference.py", dependencies=["transformers", "torch>=2.0"])
|
|
398
|
+
```
|
|
399
|
+
|
|
400
|
+
### Approach 2: Docker-Based Jobs
|
|
401
|
+
|
|
402
|
+
Run jobs with custom Docker images and commands.
|
|
403
|
+
|
|
404
|
+
**MCP Tool:**
|
|
405
|
+
```python
|
|
406
|
+
hf_jobs("run", {
|
|
407
|
+
"image": "python:3.12",
|
|
408
|
+
"command": ["python", "-c", "print('Hello from HF Jobs!')"],
|
|
409
|
+
"flavor": "cpu-basic",
|
|
410
|
+
"timeout": "30m"
|
|
411
|
+
})
|
|
412
|
+
```
|
|
413
|
+
|
|
414
|
+
**CLI Equivalent:**
|
|
415
|
+
```bash
|
|
416
|
+
hf jobs run python:3.12 python -c "print('Hello from HF Jobs!')"
|
|
417
|
+
```
|
|
418
|
+
|
|
419
|
+
**Python API:**
|
|
420
|
+
```python
|
|
421
|
+
from huggingface_hub import run_job
|
|
422
|
+
run_job(image="python:3.12", command=["python", "-c", "print('Hello!')"], flavor="cpu-basic")
|
|
423
|
+
```
|
|
424
|
+
|
|
425
|
+
**Benefits:** Full Docker control, use pre-built images, run any command
|
|
426
|
+
**When to use:** Need specific Docker images, non-Python workloads, complex environments
|
|
427
|
+
|
|
428
|
+
**Example with GPU:**
|
|
429
|
+
```python
|
|
430
|
+
hf_jobs("run", {
|
|
431
|
+
"image": "pytorch/pytorch:2.6.0-cuda12.4-cudnn9-devel",
|
|
432
|
+
"command": ["python", "-c", "import torch; print(torch.cuda.get_device_name())"],
|
|
433
|
+
"flavor": "a10g-small",
|
|
434
|
+
"timeout": "1h"
|
|
435
|
+
})
|
|
436
|
+
```
|
|
437
|
+
|
|
438
|
+
**Using Hugging Face Spaces as Images:**
|
|
439
|
+
|
|
440
|
+
You can use Docker images from HF Spaces:
|
|
441
|
+
```python
|
|
442
|
+
hf_jobs("run", {
|
|
443
|
+
"image": "hf.co/spaces/lhoestq/duckdb", # Space as Docker image
|
|
444
|
+
"command": ["duckdb", "-c", "SELECT 'Hello from DuckDB!'"],
|
|
445
|
+
"flavor": "cpu-basic"
|
|
446
|
+
})
|
|
447
|
+
```
|
|
448
|
+
|
|
449
|
+
**CLI:**
|
|
450
|
+
```bash
|
|
451
|
+
hf jobs run hf.co/spaces/lhoestq/duckdb duckdb -c "SELECT 'Hello!'"
|
|
452
|
+
```
|
|
453
|
+
|
|
454
|
+
### Finding More UV Scripts on Hub
|
|
455
|
+
|
|
456
|
+
The `uv-scripts` organization provides ready-to-use UV scripts stored as datasets on Hugging Face Hub:
|
|
457
|
+
|
|
458
|
+
```python
|
|
459
|
+
# Discover available UV script collections
|
|
460
|
+
dataset_search({"author": "uv-scripts", "sort": "downloads", "limit": 20})
|
|
461
|
+
|
|
462
|
+
# Explore a specific collection
|
|
463
|
+
hub_repo_details(["uv-scripts/classification"], repo_type="dataset", include_readme=True)
|
|
464
|
+
```
|
|
465
|
+
|
|
466
|
+
**Popular collections:** OCR, classification, synthetic-data, vLLM, dataset-creation
|
|
467
|
+
|
|
468
|
+
## Hardware Selection
|
|
469
|
+
|
|
470
|
+
> **Reference:** [HF Jobs Hardware Docs](https://huggingface.co/docs/hub/en/spaces-config-reference) (updated 07/2025)
|
|
471
|
+
|
|
472
|
+
| Workload Type | Recommended Hardware | Use Case |
|
|
473
|
+
|---------------|---------------------|----------|
|
|
474
|
+
| Data processing, testing | `cpu-basic`, `cpu-upgrade` | Lightweight tasks |
|
|
475
|
+
| Small models, demos | `t4-small` | <1B models, quick tests |
|
|
476
|
+
| Medium models | `t4-medium`, `l4x1` | 1-7B models |
|
|
477
|
+
| Large models, production | `a10g-small`, `a10g-large` | 7-13B models |
|
|
478
|
+
| Very large models | `a100-large` | 13B+ models |
|
|
479
|
+
| Batch inference | `a10g-large`, `a100-large` | High-throughput |
|
|
480
|
+
| Multi-GPU workloads | `l4x4`, `a10g-largex2`, `a10g-largex4` | Parallel/large models |
|
|
481
|
+
| TPU workloads | `v5e-1x1`, `v5e-2x2`, `v5e-2x4` | JAX/Flax, TPU-optimized |
|
|
482
|
+
|
|
483
|
+
**All Available Flavors:**
|
|
484
|
+
- **CPU:** `cpu-basic`, `cpu-upgrade`
|
|
485
|
+
- **GPU:** `t4-small`, `t4-medium`, `l4x1`, `l4x4`, `a10g-small`, `a10g-large`, `a10g-largex2`, `a10g-largex4`, `a100-large`
|
|
486
|
+
- **TPU:** `v5e-1x1`, `v5e-2x2`, `v5e-2x4`
|
|
487
|
+
|
|
488
|
+
**Guidelines:**
|
|
489
|
+
- Start with smaller hardware for testing
|
|
490
|
+
- Scale up based on actual needs
|
|
491
|
+
- Use multi-GPU for parallel workloads or large models
|
|
492
|
+
- Use TPUs for JAX/Flax workloads
|
|
493
|
+
- See `references/hardware_guide.md` for detailed specifications
|
|
494
|
+
|
|
495
|
+
## Critical: Saving Results
|
|
496
|
+
|
|
497
|
+
**⚠️ EPHEMERAL ENVIRONMENT—MUST PERSIST RESULTS**
|
|
498
|
+
|
|
499
|
+
The Jobs environment is temporary. All files are deleted when the job ends. If results aren't persisted, **ALL WORK IS LOST**.
|
|
500
|
+
|
|
501
|
+
### Persistence Options
|
|
502
|
+
|
|
503
|
+
**1. Push to Hugging Face Hub (Recommended)**
|
|
504
|
+
|
|
505
|
+
```python
|
|
506
|
+
# Push models
|
|
507
|
+
model.push_to_hub("username/model-name", token=os.environ["HF_TOKEN"])
|
|
508
|
+
|
|
509
|
+
# Push datasets
|
|
510
|
+
dataset.push_to_hub("username/dataset-name", token=os.environ["HF_TOKEN"])
|
|
511
|
+
|
|
512
|
+
# Push artifacts
|
|
513
|
+
api.upload_file(
|
|
514
|
+
path_or_fileobj="results.json",
|
|
515
|
+
path_in_repo="results.json",
|
|
516
|
+
repo_id="username/results",
|
|
517
|
+
token=os.environ["HF_TOKEN"]
|
|
518
|
+
)
|
|
519
|
+
```
|
|
520
|
+
|
|
521
|
+
**2. Use External Storage**
|
|
522
|
+
|
|
523
|
+
```python
|
|
524
|
+
# Upload to S3, GCS, etc.
|
|
525
|
+
import boto3
|
|
526
|
+
s3 = boto3.client('s3')
|
|
527
|
+
s3.upload_file('results.json', 'my-bucket', 'results.json')
|
|
528
|
+
```
|
|
529
|
+
|
|
530
|
+
**3. Send Results via API**
|
|
531
|
+
|
|
532
|
+
```python
|
|
533
|
+
# POST results to your API
|
|
534
|
+
import requests
|
|
535
|
+
requests.post("https://your-api.com/results", json=results)
|
|
536
|
+
```
|
|
537
|
+
|
|
538
|
+
### Required Configuration for Hub Push
|
|
539
|
+
|
|
540
|
+
**In job submission:**
|
|
541
|
+
```python
|
|
542
|
+
{
|
|
543
|
+
"secrets": {"HF_TOKEN": "$HF_TOKEN"} # Enables authentication
|
|
544
|
+
}
|
|
545
|
+
```
|
|
546
|
+
|
|
547
|
+
**In script:**
|
|
548
|
+
```python
|
|
549
|
+
import os
|
|
550
|
+
from huggingface_hub import HfApi
|
|
551
|
+
|
|
552
|
+
# Token automatically available from secrets
|
|
553
|
+
api = HfApi(token=os.environ.get("HF_TOKEN"))
|
|
554
|
+
|
|
555
|
+
# Push your results
|
|
556
|
+
api.upload_file(...)
|
|
557
|
+
```
|
|
558
|
+
|
|
559
|
+
### Verification Checklist
|
|
560
|
+
|
|
561
|
+
Before submitting:
|
|
562
|
+
- [ ] Results persistence method chosen
|
|
563
|
+
- [ ] `secrets={"HF_TOKEN": "$HF_TOKEN"}` if using Hub
|
|
564
|
+
- [ ] Script handles missing token gracefully
|
|
565
|
+
- [ ] Test persistence path works
|
|
566
|
+
|
|
567
|
+
**See:** `references/hub_saving.md` for detailed Hub persistence guide
|
|
568
|
+
|
|
569
|
+
## Timeout Management
|
|
570
|
+
|
|
571
|
+
**⚠️ DEFAULT: 30 MINUTES**
|
|
572
|
+
|
|
573
|
+
Jobs automatically stop after the timeout. For long-running tasks like training, always set a custom timeout.
|
|
574
|
+
|
|
575
|
+
### Setting Timeouts
|
|
576
|
+
|
|
577
|
+
**MCP Tool:**
|
|
578
|
+
```python
|
|
579
|
+
{
|
|
580
|
+
"timeout": "2h" # 2 hours
|
|
581
|
+
}
|
|
582
|
+
```
|
|
583
|
+
|
|
584
|
+
**Supported formats:**
|
|
585
|
+
- Integer/float: seconds (e.g., `300` = 5 minutes)
|
|
586
|
+
- String with suffix: `"5m"` (minutes), `"2h"` (hours), `"1d"` (days)
|
|
587
|
+
- Examples: `"90m"`, `"2h"`, `"1.5h"`, `300`, `"1d"`
|
|
588
|
+
|
|
589
|
+
**Python API:**
|
|
590
|
+
```python
|
|
591
|
+
from huggingface_hub import run_job, run_uv_job
|
|
592
|
+
|
|
593
|
+
run_job(image="python:3.12", command=[...], timeout="2h")
|
|
594
|
+
run_uv_job("script.py", timeout=7200) # 2 hours in seconds
|
|
595
|
+
```
|
|
596
|
+
|
|
597
|
+
### Timeout Guidelines
|
|
598
|
+
|
|
599
|
+
| Scenario | Recommended | Notes |
|
|
600
|
+
|----------|-------------|-------|
|
|
601
|
+
| Quick test | 10-30 min | Verify setup |
|
|
602
|
+
| Data processing | 1-2 hours | Depends on data size |
|
|
603
|
+
| Batch inference | 2-4 hours | Large batches |
|
|
604
|
+
| Experiments | 4-8 hours | Multiple runs |
|
|
605
|
+
| Long-running | 8-24 hours | Production workloads |
|
|
606
|
+
|
|
607
|
+
**Always add 20-30% buffer** for setup, network delays, and cleanup.
|
|
608
|
+
|
|
609
|
+
**On timeout:** Job killed immediately, all unsaved progress lost
|
|
610
|
+
|
|
611
|
+
## Cost Estimation
|
|
612
|
+
|
|
613
|
+
**General guidelines:**
|
|
614
|
+
|
|
615
|
+
```
|
|
616
|
+
Total Cost = (Hours of runtime) × (Cost per hour)
|
|
617
|
+
```
|
|
618
|
+
|
|
619
|
+
**Example calculations:**
|
|
620
|
+
|
|
621
|
+
**Quick test:**
|
|
622
|
+
- Hardware: cpu-basic ($0.10/hour)
|
|
623
|
+
- Time: 15 minutes (0.25 hours)
|
|
624
|
+
- Cost: $0.03
|
|
625
|
+
|
|
626
|
+
**Data processing:**
|
|
627
|
+
- Hardware: l4x1 ($2.50/hour)
|
|
628
|
+
- Time: 2 hours
|
|
629
|
+
- Cost: $5.00
|
|
630
|
+
|
|
631
|
+
**Batch inference:**
|
|
632
|
+
- Hardware: a10g-large ($5/hour)
|
|
633
|
+
- Time: 4 hours
|
|
634
|
+
- Cost: $20.00
|
|
635
|
+
|
|
636
|
+
**Cost optimization tips:**
|
|
637
|
+
1. Start small - Test on cpu-basic or t4-small
|
|
638
|
+
2. Monitor runtime - Set appropriate timeouts
|
|
639
|
+
3. Use checkpoints - Resume if job fails
|
|
640
|
+
4. Optimize code - Reduce unnecessary compute
|
|
641
|
+
5. Choose right hardware - Don't over-provision
|
|
642
|
+
|
|
643
|
+
## Monitoring and Tracking
|
|
644
|
+
|
|
645
|
+
### Check Job Status
|
|
646
|
+
|
|
647
|
+
**MCP Tool:**
|
|
648
|
+
```python
|
|
649
|
+
# List all jobs
|
|
650
|
+
hf_jobs("ps")
|
|
651
|
+
|
|
652
|
+
# Inspect specific job
|
|
653
|
+
hf_jobs("inspect", {"job_id": "your-job-id"})
|
|
654
|
+
|
|
655
|
+
# View logs
|
|
656
|
+
hf_jobs("logs", {"job_id": "your-job-id"})
|
|
657
|
+
|
|
658
|
+
# Cancel a job
|
|
659
|
+
hf_jobs("cancel", {"job_id": "your-job-id"})
|
|
660
|
+
```
|
|
661
|
+
|
|
662
|
+
**Python API:**
|
|
663
|
+
```python
|
|
664
|
+
from huggingface_hub import list_jobs, inspect_job, fetch_job_logs, cancel_job
|
|
665
|
+
|
|
666
|
+
# List your jobs
|
|
667
|
+
jobs = list_jobs()
|
|
668
|
+
|
|
669
|
+
# List running jobs only
|
|
670
|
+
running = [j for j in list_jobs() if j.status.stage == "RUNNING"]
|
|
671
|
+
|
|
672
|
+
# Inspect specific job
|
|
673
|
+
job_info = inspect_job(job_id="your-job-id")
|
|
674
|
+
|
|
675
|
+
# View logs
|
|
676
|
+
for log in fetch_job_logs(job_id="your-job-id"):
|
|
677
|
+
print(log)
|
|
678
|
+
|
|
679
|
+
# Cancel a job
|
|
680
|
+
cancel_job(job_id="your-job-id")
|
|
681
|
+
```
|
|
682
|
+
|
|
683
|
+
**CLI:**
|
|
684
|
+
```bash
|
|
685
|
+
hf jobs ps # List jobs
|
|
686
|
+
hf jobs logs <job-id> # View logs
|
|
687
|
+
hf jobs cancel <job-id> # Cancel job
|
|
688
|
+
```
|
|
689
|
+
|
|
690
|
+
**Remember:** Wait for user to request status checks. Avoid polling repeatedly.
|
|
691
|
+
|
|
692
|
+
### Job URLs
|
|
693
|
+
|
|
694
|
+
After submission, jobs have monitoring URLs:
|
|
695
|
+
```
|
|
696
|
+
https://huggingface.co/jobs/username/job-id
|
|
697
|
+
```
|
|
698
|
+
|
|
699
|
+
View logs, status, and details in the browser.
|
|
700
|
+
|
|
701
|
+
### Wait for Multiple Jobs
|
|
702
|
+
|
|
703
|
+
```python
|
|
704
|
+
import time
|
|
705
|
+
from huggingface_hub import inspect_job, run_job
|
|
706
|
+
|
|
707
|
+
# Run multiple jobs
|
|
708
|
+
jobs = [run_job(image=img, command=cmd) for img, cmd in workloads]
|
|
709
|
+
|
|
710
|
+
# Wait for all to complete
|
|
711
|
+
for job in jobs:
|
|
712
|
+
while inspect_job(job_id=job.id).status.stage not in ("COMPLETED", "ERROR"):
|
|
713
|
+
time.sleep(10)
|
|
714
|
+
```
|
|
715
|
+
|
|
716
|
+
## Scheduled Jobs
|
|
717
|
+
|
|
718
|
+
Run jobs on a schedule using CRON expressions or predefined schedules.
|
|
719
|
+
|
|
720
|
+
**MCP Tool:**
|
|
721
|
+
```python
|
|
722
|
+
# Schedule a UV script that runs every hour
|
|
723
|
+
hf_jobs("scheduled uv", {
|
|
724
|
+
"script": "your_script.py",
|
|
725
|
+
"schedule": "@hourly",
|
|
726
|
+
"flavor": "cpu-basic"
|
|
727
|
+
})
|
|
728
|
+
|
|
729
|
+
# Schedule with CRON syntax
|
|
730
|
+
hf_jobs("scheduled uv", {
|
|
731
|
+
"script": "your_script.py",
|
|
732
|
+
"schedule": "0 9 * * 1", # 9 AM every Monday
|
|
733
|
+
"flavor": "cpu-basic"
|
|
734
|
+
})
|
|
735
|
+
|
|
736
|
+
# Schedule a Docker-based job
|
|
737
|
+
hf_jobs("scheduled run", {
|
|
738
|
+
"image": "python:3.12",
|
|
739
|
+
"command": ["python", "-c", "print('Scheduled!')"],
|
|
740
|
+
"schedule": "@daily",
|
|
741
|
+
"flavor": "cpu-basic"
|
|
742
|
+
})
|
|
743
|
+
```
|
|
744
|
+
|
|
745
|
+
**Python API:**
|
|
746
|
+
```python
|
|
747
|
+
from huggingface_hub import create_scheduled_job, create_scheduled_uv_job
|
|
748
|
+
|
|
749
|
+
# Schedule a Docker job
|
|
750
|
+
create_scheduled_job(
|
|
751
|
+
image="python:3.12",
|
|
752
|
+
command=["python", "-c", "print('Running on schedule!')"],
|
|
753
|
+
schedule="@hourly"
|
|
754
|
+
)
|
|
755
|
+
|
|
756
|
+
# Schedule a UV script
|
|
757
|
+
create_scheduled_uv_job("my_script.py", schedule="@daily", flavor="cpu-basic")
|
|
758
|
+
|
|
759
|
+
# Schedule with GPU
|
|
760
|
+
create_scheduled_uv_job(
|
|
761
|
+
"ml_inference.py",
|
|
762
|
+
schedule="0 */6 * * *", # Every 6 hours
|
|
763
|
+
flavor="a10g-small"
|
|
764
|
+
)
|
|
765
|
+
```
|
|
766
|
+
|
|
767
|
+
**Available schedules:**
|
|
768
|
+
- `@annually`, `@yearly` - Once per year
|
|
769
|
+
- `@monthly` - Once per month
|
|
770
|
+
- `@weekly` - Once per week
|
|
771
|
+
- `@daily` - Once per day
|
|
772
|
+
- `@hourly` - Once per hour
|
|
773
|
+
- CRON expression - Custom schedule (e.g., `"*/5 * * * *"` for every 5 minutes)
|
|
774
|
+
|
|
775
|
+
**Manage scheduled jobs:**
|
|
776
|
+
```python
|
|
777
|
+
# MCP Tool
|
|
778
|
+
hf_jobs("scheduled ps") # List scheduled jobs
|
|
779
|
+
hf_jobs("scheduled inspect", {"job_id": "..."}) # Inspect details
|
|
780
|
+
hf_jobs("scheduled suspend", {"job_id": "..."}) # Pause
|
|
781
|
+
hf_jobs("scheduled resume", {"job_id": "..."}) # Resume
|
|
782
|
+
hf_jobs("scheduled delete", {"job_id": "..."}) # Delete
|
|
783
|
+
```
|
|
784
|
+
|
|
785
|
+
**Python API for management:**
|
|
786
|
+
```python
|
|
787
|
+
from huggingface_hub import (
|
|
788
|
+
list_scheduled_jobs,
|
|
789
|
+
inspect_scheduled_job,
|
|
790
|
+
suspend_scheduled_job,
|
|
791
|
+
resume_scheduled_job,
|
|
792
|
+
delete_scheduled_job
|
|
793
|
+
)
|
|
794
|
+
|
|
795
|
+
# List all scheduled jobs
|
|
796
|
+
scheduled = list_scheduled_jobs()
|
|
797
|
+
|
|
798
|
+
# Inspect a scheduled job
|
|
799
|
+
info = inspect_scheduled_job(scheduled_job_id)
|
|
800
|
+
|
|
801
|
+
# Suspend (pause) a scheduled job
|
|
802
|
+
suspend_scheduled_job(scheduled_job_id)
|
|
803
|
+
|
|
804
|
+
# Resume a scheduled job
|
|
805
|
+
resume_scheduled_job(scheduled_job_id)
|
|
806
|
+
|
|
807
|
+
# Delete a scheduled job
|
|
808
|
+
delete_scheduled_job(scheduled_job_id)
|
|
809
|
+
```
|
|
810
|
+
|
|
811
|
+
## Webhooks: Trigger Jobs on Events
|
|
812
|
+
|
|
813
|
+
Trigger jobs automatically when changes happen in Hugging Face repositories.
|
|
814
|
+
|
|
815
|
+
**Python API:**
|
|
816
|
+
```python
|
|
817
|
+
from huggingface_hub import create_webhook
|
|
818
|
+
|
|
819
|
+
# Create webhook that triggers a job when a repo changes
|
|
820
|
+
webhook = create_webhook(
|
|
821
|
+
job_id=job.id,
|
|
822
|
+
watched=[
|
|
823
|
+
{"type": "user", "name": "your-username"},
|
|
824
|
+
{"type": "org", "name": "your-org-name"}
|
|
825
|
+
],
|
|
826
|
+
domains=["repo", "discussion"],
|
|
827
|
+
secret="your-secret"
|
|
828
|
+
)
|
|
829
|
+
```
|
|
830
|
+
|
|
831
|
+
**How it works:**
|
|
832
|
+
1. Webhook listens for changes in watched repositories
|
|
833
|
+
2. When triggered, the job runs with `WEBHOOK_PAYLOAD` environment variable
|
|
834
|
+
3. Your script can parse the payload to understand what changed
|
|
835
|
+
|
|
836
|
+
**Use cases:**
|
|
837
|
+
- Auto-process new datasets when uploaded
|
|
838
|
+
- Trigger inference when models are updated
|
|
839
|
+
- Run tests when code changes
|
|
840
|
+
- Generate reports on repository activity
|
|
841
|
+
|
|
842
|
+
**Access webhook payload in script:**
|
|
843
|
+
```python
|
|
844
|
+
import os
|
|
845
|
+
import json
|
|
846
|
+
|
|
847
|
+
payload = json.loads(os.environ.get("WEBHOOK_PAYLOAD", "{}"))
|
|
848
|
+
print(f"Event type: {payload.get('event', {}).get('action')}")
|
|
849
|
+
```
|
|
850
|
+
|
|
851
|
+
See [Webhooks Documentation](https://huggingface.co/docs/huggingface_hub/guides/webhooks) for more details.
|
|
852
|
+
|
|
853
|
+
## Common Workload Patterns
|
|
854
|
+
|
|
855
|
+
This repository ships ready-to-run UV scripts in `hf-jobs/scripts/`. Prefer using them instead of inventing new templates.
|
|
856
|
+
|
|
857
|
+
### Pattern 1: Dataset → Model Responses (vLLM) — `scripts/generate-responses.py`
|
|
858
|
+
|
|
859
|
+
**What it does:** loads a Hub dataset (chat `messages` or a `prompt` column), applies a model chat template, generates responses with vLLM, and **pushes** the output dataset + dataset card back to the Hub.
|
|
860
|
+
|
|
861
|
+
**Requires:** GPU + **write** token (it pushes a dataset).
|
|
862
|
+
|
|
863
|
+
```python
|
|
864
|
+
from pathlib import Path
|
|
865
|
+
|
|
866
|
+
script = Path("hf-jobs/scripts/generate-responses.py").read_text()
|
|
867
|
+
hf_jobs("uv", {
|
|
868
|
+
"script": script,
|
|
869
|
+
"script_args": [
|
|
870
|
+
"username/input-dataset",
|
|
871
|
+
"username/output-dataset",
|
|
872
|
+
"--messages-column", "messages",
|
|
873
|
+
"--model-id", "Qwen/Qwen3-30B-A3B-Instruct-2507",
|
|
874
|
+
"--temperature", "0.7",
|
|
875
|
+
"--top-p", "0.8",
|
|
876
|
+
"--max-tokens", "2048",
|
|
877
|
+
],
|
|
878
|
+
"flavor": "a10g-large",
|
|
879
|
+
"timeout": "4h",
|
|
880
|
+
"secrets": {"HF_TOKEN": "$HF_TOKEN"},
|
|
881
|
+
})
|
|
882
|
+
```
|
|
883
|
+
|
|
884
|
+
### Pattern 2: CoT Self-Instruct Synthetic Data — `scripts/cot-self-instruct.py`
|
|
885
|
+
|
|
886
|
+
**What it does:** generates synthetic prompts/answers via CoT Self-Instruct, optionally filters outputs (answer-consistency / RIP), then **pushes** the generated dataset + dataset card to the Hub.
|
|
887
|
+
|
|
888
|
+
**Requires:** GPU + **write** token (it pushes a dataset).
|
|
889
|
+
|
|
890
|
+
```python
|
|
891
|
+
from pathlib import Path
|
|
892
|
+
|
|
893
|
+
script = Path("hf-jobs/scripts/cot-self-instruct.py").read_text()
|
|
894
|
+
hf_jobs("uv", {
|
|
895
|
+
"script": script,
|
|
896
|
+
"script_args": [
|
|
897
|
+
"--seed-dataset", "davanstrien/s1k-reasoning",
|
|
898
|
+
"--output-dataset", "username/synthetic-math",
|
|
899
|
+
"--task-type", "reasoning",
|
|
900
|
+
"--num-samples", "5000",
|
|
901
|
+
"--filter-method", "answer-consistency",
|
|
902
|
+
],
|
|
903
|
+
"flavor": "l4x4",
|
|
904
|
+
"timeout": "8h",
|
|
905
|
+
"secrets": {"HF_TOKEN": "$HF_TOKEN"},
|
|
906
|
+
})
|
|
907
|
+
```
|
|
908
|
+
|
|
909
|
+
### Pattern 3: Streaming Dataset Stats (Polars + HF Hub) — `scripts/finepdfs-stats.py`
|
|
910
|
+
|
|
911
|
+
**What it does:** scans parquet directly from Hub (no 300GB download), computes temporal stats, and (optionally) uploads results to a Hub dataset repo.
|
|
912
|
+
|
|
913
|
+
**Requires:** CPU is often enough; token needed **only** if you pass `--output-repo` (upload).
|
|
914
|
+
|
|
915
|
+
```python
|
|
916
|
+
from pathlib import Path
|
|
917
|
+
|
|
918
|
+
script = Path("hf-jobs/scripts/finepdfs-stats.py").read_text()
|
|
919
|
+
hf_jobs("uv", {
|
|
920
|
+
"script": script,
|
|
921
|
+
"script_args": [
|
|
922
|
+
"--limit", "10000",
|
|
923
|
+
"--show-plan",
|
|
924
|
+
"--output-repo", "username/finepdfs-temporal-stats",
|
|
925
|
+
],
|
|
926
|
+
"flavor": "cpu-upgrade",
|
|
927
|
+
"timeout": "2h",
|
|
928
|
+
"env": {"HF_XET_HIGH_PERFORMANCE": "1"},
|
|
929
|
+
"secrets": {"HF_TOKEN": "$HF_TOKEN"},
|
|
930
|
+
})
|
|
931
|
+
```
|
|
932
|
+
|
|
933
|
+
## Common Failure Modes
|
|
934
|
+
|
|
935
|
+
### Out of Memory (OOM)
|
|
936
|
+
|
|
937
|
+
**Fix:**
|
|
938
|
+
1. Reduce batch size or data chunk size
|
|
939
|
+
2. Process data in smaller batches
|
|
940
|
+
3. Upgrade hardware: cpu → t4 → a10g → a100
|
|
941
|
+
|
|
942
|
+
### Job Timeout
|
|
943
|
+
|
|
944
|
+
**Fix:**
|
|
945
|
+
1. Check logs for actual runtime
|
|
946
|
+
2. Increase timeout with buffer: `"timeout": "3h"`
|
|
947
|
+
3. Optimize code for faster execution
|
|
948
|
+
4. Process data in chunks
|
|
949
|
+
|
|
950
|
+
### Hub Push Failures
|
|
951
|
+
|
|
952
|
+
**Fix:**
|
|
953
|
+
1. Add to job: `secrets={"HF_TOKEN": "$HF_TOKEN"}`
|
|
954
|
+
2. Verify token in script: `assert "HF_TOKEN" in os.environ`
|
|
955
|
+
3. Check token permissions
|
|
956
|
+
4. Verify repo exists or can be created
|
|
957
|
+
|
|
958
|
+
### Missing Dependencies
|
|
959
|
+
|
|
960
|
+
**Fix:**
|
|
961
|
+
Add to PEP 723 header:
|
|
962
|
+
```python
|
|
963
|
+
# /// script
|
|
964
|
+
# dependencies = ["package1", "package2>=1.0.0"]
|
|
965
|
+
# ///
|
|
966
|
+
```
|
|
967
|
+
|
|
968
|
+
### Authentication Errors
|
|
969
|
+
|
|
970
|
+
**Fix:**
|
|
971
|
+
1. Check `hf_whoami()` works locally
|
|
972
|
+
2. Verify `secrets={"HF_TOKEN": "$HF_TOKEN"}` in job config
|
|
973
|
+
3. Re-login: `hf auth login`
|
|
974
|
+
4. Check token has required permissions
|
|
975
|
+
|
|
976
|
+
## Troubleshooting
|
|
977
|
+
|
|
978
|
+
**Common issues:**
|
|
979
|
+
- Job times out → Increase timeout, optimize code
|
|
980
|
+
- Results not saved → Check persistence method, verify HF_TOKEN
|
|
981
|
+
- Out of Memory → Reduce batch size, upgrade hardware
|
|
982
|
+
- Import errors → Add dependencies to PEP 723 header
|
|
983
|
+
- Authentication errors → Check token, verify secrets parameter
|
|
984
|
+
|
|
985
|
+
**See:** `references/troubleshooting.md` for complete troubleshooting guide
|
|
986
|
+
|
|
987
|
+
## Resources
|
|
988
|
+
|
|
989
|
+
### References (In This Skill)
|
|
990
|
+
- `references/token_usage.md` - Complete token usage guide
|
|
991
|
+
- `references/hardware_guide.md` - Hardware specs and selection
|
|
992
|
+
- `references/hub_saving.md` - Hub persistence guide
|
|
993
|
+
- `references/troubleshooting.md` - Common issues and solutions
|
|
994
|
+
|
|
995
|
+
### Scripts (In This Skill)
|
|
996
|
+
- `scripts/generate-responses.py` - vLLM batch generation: dataset → responses → push to Hub
|
|
997
|
+
- `scripts/cot-self-instruct.py` - CoT Self-Instruct synthetic data generation + filtering → push to Hub
|
|
998
|
+
- `scripts/finepdfs-stats.py` - Polars streaming stats over `finepdfs-edu` parquet on Hub (optional push)
|
|
999
|
+
|
|
1000
|
+
### External Links
|
|
1001
|
+
|
|
1002
|
+
**Official Documentation:**
|
|
1003
|
+
- [HF Jobs Guide](https://huggingface.co/docs/huggingface_hub/guides/jobs) - Main documentation
|
|
1004
|
+
- [HF Jobs CLI Reference](https://huggingface.co/docs/huggingface_hub/guides/cli#hf-jobs) - Command line interface
|
|
1005
|
+
- [HF Jobs API Reference](https://huggingface.co/docs/huggingface_hub/package_reference/hf_api) - Python API details
|
|
1006
|
+
- [Hardware Flavors Reference](https://huggingface.co/docs/hub/en/spaces-config-reference) - Available hardware
|
|
1007
|
+
|
|
1008
|
+
**Related Tools:**
|
|
1009
|
+
- [UV Scripts Guide](https://docs.astral.sh/uv/guides/scripts/) - PEP 723 inline dependencies
|
|
1010
|
+
- [UV Scripts Organization](https://huggingface.co/uv-scripts) - Community UV script collection
|
|
1011
|
+
- [HF Hub Authentication](https://huggingface.co/docs/huggingface_hub/quick-start#authentication) - Token setup
|
|
1012
|
+
- [Webhooks Documentation](https://huggingface.co/docs/huggingface_hub/guides/webhooks) - Event triggers
|
|
1013
|
+
|
|
1014
|
+
## Key Takeaways
|
|
1015
|
+
|
|
1016
|
+
1. **Submit scripts inline** - The `script` parameter accepts Python code directly; no file saving required unless user requests
|
|
1017
|
+
2. **Jobs are asynchronous** - Don't wait/poll; let user check when ready
|
|
1018
|
+
3. **Always set timeout** - Default 30 min may be insufficient; set appropriate timeout
|
|
1019
|
+
4. **Always persist results** - Environment is ephemeral; without persistence, all work is lost
|
|
1020
|
+
5. **Use tokens securely** - Always use `secrets={"HF_TOKEN": "$HF_TOKEN"}` for Hub operations
|
|
1021
|
+
6. **Choose appropriate hardware** - Start small, scale up based on needs (see hardware guide)
|
|
1022
|
+
7. **Use UV scripts** - Default to `hf_jobs("uv", {...})` with inline scripts for Python workloads
|
|
1023
|
+
8. **Handle authentication** - Verify tokens are available before Hub operations
|
|
1024
|
+
9. **Monitor jobs** - Provide job URLs and status check commands
|
|
1025
|
+
10. **Optimize costs** - Choose right hardware, set appropriate timeouts
|
|
1026
|
+
|
|
1027
|
+
## Quick Reference: MCP Tool vs CLI vs Python API
|
|
1028
|
+
|
|
1029
|
+
| Operation | MCP Tool | CLI | Python API |
|
|
1030
|
+
|-----------|----------|-----|------------|
|
|
1031
|
+
| Run UV script | `hf_jobs("uv", {...})` | `hf jobs uv run script.py` | `run_uv_job("script.py")` |
|
|
1032
|
+
| Run Docker job | `hf_jobs("run", {...})` | `hf jobs run image cmd` | `run_job(image, command)` |
|
|
1033
|
+
| List jobs | `hf_jobs("ps")` | `hf jobs ps` | `list_jobs()` |
|
|
1034
|
+
| View logs | `hf_jobs("logs", {...})` | `hf jobs logs <id>` | `fetch_job_logs(job_id)` |
|
|
1035
|
+
| Cancel job | `hf_jobs("cancel", {...})` | `hf jobs cancel <id>` | `cancel_job(job_id)` |
|
|
1036
|
+
| Schedule UV | `hf_jobs("scheduled uv", {...})` | - | `create_scheduled_uv_job()` |
|
|
1037
|
+
| Schedule Docker | `hf_jobs("scheduled run", {...})` | - | `create_scheduled_job()` |
|
|
1038
|
+
|