@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.
Files changed (769) hide show
  1. package/merged-commands/3d-web-experience.md +254 -0
  2. package/merged-commands/ab-test-setup.md +232 -0
  3. package/merged-commands/accessibility-compliance-accessibility-audit.md +42 -0
  4. package/merged-commands/active-directory-attacks.md +383 -0
  5. package/merged-commands/address-github-comments.md +55 -0
  6. package/merged-commands/aesthetic.md +134 -0
  7. package/merged-commands/agent-evaluation.md +64 -0
  8. package/merged-commands/agent-framework-azure-hosted-agents.md +332 -0
  9. package/merged-commands/agent-manager-skill.md +40 -0
  10. package/merged-commands/agent-memory-mcp.md +82 -0
  11. package/merged-commands/agent-memory-systems.md +67 -0
  12. package/merged-commands/agent-orchestration-improve-agent.md +349 -0
  13. package/merged-commands/agent-orchestration-multi-agent-optimize.md +239 -0
  14. package/merged-commands/agent-tool-builder.md +53 -0
  15. package/merged-commands/agile-product-owner.md +31 -0
  16. package/merged-commands/ai-agents-architect.md +90 -0
  17. package/merged-commands/ai-artist.md +75 -0
  18. package/merged-commands/ai-engineer.md +171 -0
  19. package/merged-commands/ai-multimodal.md +109 -0
  20. package/merged-commands/ai-product.md +54 -0
  21. package/merged-commands/ai-wrapper-product.md +273 -0
  22. package/merged-commands/airflow-dag-patterns.md +41 -0
  23. package/merged-commands/algolia-search.md +66 -0
  24. package/merged-commands/algorithmic-art.md +405 -0
  25. package/merged-commands/analytics-tracking.md +404 -0
  26. package/merged-commands/angular-architect.md +97 -0
  27. package/merged-commands/angular-migration.md +428 -0
  28. package/merged-commands/anti-reversing-techniques.md +42 -0
  29. package/merged-commands/api-design-principles.md +37 -0
  30. package/merged-commands/api-designer.md +101 -0
  31. package/merged-commands/api-documentation-generator.md +484 -0
  32. package/merged-commands/api-documenter.md +184 -0
  33. package/merged-commands/api-fuzzing-bug-bounty.md +433 -0
  34. package/merged-commands/api-patterns.md +81 -0
  35. package/merged-commands/api-security-best-practices.md +907 -0
  36. package/merged-commands/api-testing-observability-api-mock.md +46 -0
  37. package/merged-commands/app-builder.md +75 -0
  38. package/merged-commands/app-store-optimization.md +403 -0
  39. package/merged-commands/application-performance-performance-optimization.md +154 -0
  40. package/merged-commands/architect-review.md +174 -0
  41. package/merged-commands/architecture-decision-records.md +441 -0
  42. package/merged-commands/architecture-designer.md +89 -0
  43. package/merged-commands/architecture-patterns.md +37 -0
  44. package/merged-commands/architecture.md +55 -0
  45. package/merged-commands/arm-cortex-expert.md +306 -0
  46. package/merged-commands/artifacts-builder.md +74 -0
  47. package/merged-commands/ask-questions-if-underspecified.md +81 -0
  48. package/merged-commands/async-python-patterns.md +39 -0
  49. package/merged-commands/atlassian-mcp.md +100 -0
  50. package/merged-commands/attack-tree-construction.md +38 -0
  51. package/merged-commands/auth-implementation-patterns.md +39 -0
  52. package/merged-commands/automate-whatsapp.md +257 -0
  53. package/merged-commands/autonomous-agent-patterns.md +761 -0
  54. package/merged-commands/autonomous-agents.md +68 -0
  55. package/merged-commands/avalonia-layout-zafiro.md +59 -0
  56. package/merged-commands/avalonia-viewmodels-zafiro.md +29 -0
  57. package/merged-commands/avalonia-zafiro-development.md +29 -0
  58. package/merged-commands/aws-agentic-ai.md +117 -0
  59. package/merged-commands/aws-cdk-development.md +278 -0
  60. package/merged-commands/aws-cost-operations.md +317 -0
  61. package/merged-commands/aws-penetration-testing.md +405 -0
  62. package/merged-commands/aws-serverless-eda.md +757 -0
  63. package/merged-commands/aws-serverless.md +323 -0
  64. package/merged-commands/aws-skills.md +22 -0
  65. package/merged-commands/azd-deployment.md +296 -0
  66. package/merged-commands/azure-ai-agents-python.md +277 -0
  67. package/merged-commands/azure-ai-search-python.md +198 -0
  68. package/merged-commands/azure-ai-voicelive-skill.md +294 -0
  69. package/merged-commands/azure-functions.md +42 -0
  70. package/merged-commands/backend-architect.md +333 -0
  71. package/merged-commands/backend-dev-guidelines.md +342 -0
  72. package/merged-commands/backend-development-feature-development.md +180 -0
  73. package/merged-commands/backend-development.md +155 -0
  74. package/merged-commands/backend-security-coder.md +156 -0
  75. package/merged-commands/backtesting-frameworks.md +39 -0
  76. package/merged-commands/bash-defensive-patterns.md +43 -0
  77. package/merged-commands/bash-linux.md +199 -0
  78. package/merged-commands/bash-pro.md +310 -0
  79. package/merged-commands/bats-testing-patterns.md +34 -0
  80. package/merged-commands/bazel-build-optimization.md +397 -0
  81. package/merged-commands/beautiful-prose.md +22 -0
  82. package/merged-commands/behavioral-modes.md +242 -0
  83. package/merged-commands/best-practices.md +500 -0
  84. package/merged-commands/better-auth.md +204 -0
  85. package/merged-commands/billing-automation.md +42 -0
  86. package/merged-commands/binary-analysis-patterns.md +450 -0
  87. package/merged-commands/blockchain-developer.md +208 -0
  88. package/merged-commands/blockrun.md +292 -0
  89. package/merged-commands/brainstorming.md +230 -0
  90. package/merged-commands/brand-guidelines-anthropic.md +73 -0
  91. package/merged-commands/brand-guidelines-community.md +73 -0
  92. package/merged-commands/brand-guidelines.md +73 -0
  93. package/merged-commands/broken-authentication.md +476 -0
  94. package/merged-commands/browser-automation.md +70 -0
  95. package/merged-commands/browser-extension-builder.md +261 -0
  96. package/merged-commands/building-ai-agent-on-cloudflare.md +391 -0
  97. package/merged-commands/building-mcp-server-on-cloudflare.md +265 -0
  98. package/merged-commands/bullmq-specialist.md +57 -0
  99. package/merged-commands/bun-development.md +691 -0
  100. package/merged-commands/burp-suite-testing.md +380 -0
  101. package/merged-commands/business-analyst.md +182 -0
  102. package/merged-commands/busybox-on-windows.md +30 -0
  103. package/merged-commands/c-pro.md +56 -0
  104. package/merged-commands/c4-architecture-c4-architecture.md +389 -0
  105. package/merged-commands/c4-code.md +244 -0
  106. package/merged-commands/c4-component.md +153 -0
  107. package/merged-commands/c4-container.md +171 -0
  108. package/merged-commands/c4-context.md +150 -0
  109. package/merged-commands/canvas-design.md +130 -0
  110. package/merged-commands/cc-skill-backend-patterns.md +584 -0
  111. package/merged-commands/cc-skill-clickhouse-io.md +431 -0
  112. package/merged-commands/cc-skill-coding-standards.md +522 -0
  113. package/merged-commands/cc-skill-continuous-learning.md +10 -0
  114. package/merged-commands/cc-skill-frontend-patterns.md +633 -0
  115. package/merged-commands/cc-skill-project-guidelines-example.md +352 -0
  116. package/merged-commands/cc-skill-security-review.md +496 -0
  117. package/merged-commands/cc-skill-strategic-compact.md +10 -0
  118. package/merged-commands/changelog-automation.md +38 -0
  119. package/merged-commands/changelog-generator.md +104 -0
  120. package/merged-commands/chaos-engineer.md +98 -0
  121. package/merged-commands/chrome-devtools.md +407 -0
  122. package/merged-commands/cicd-automation-workflow-automate.md +51 -0
  123. package/merged-commands/clarity-gate.md +22 -0
  124. package/merged-commands/claude-ally-health.md +22 -0
  125. package/merged-commands/claude-code-guide.md +68 -0
  126. package/merged-commands/claude-d3js-skill.md +820 -0
  127. package/merged-commands/claude-scientific-skills.md +22 -0
  128. package/merged-commands/claude-speed-reader.md +22 -0
  129. package/merged-commands/claude-win11-speckit-update-skill.md +22 -0
  130. package/merged-commands/clean-code.md +201 -0
  131. package/merged-commands/clerk-auth.md +56 -0
  132. package/merged-commands/cli-developer.md +97 -0
  133. package/merged-commands/cloud-architect.md +135 -0
  134. package/merged-commands/cloud-penetration-testing.md +501 -0
  135. package/merged-commands/cloudflare-expert.md +227 -0
  136. package/merged-commands/code-documentation-code-explain.md +46 -0
  137. package/merged-commands/code-documentation-doc-generate.md +48 -0
  138. package/merged-commands/code-documentation.md +263 -0
  139. package/merged-commands/code-documenter.md +95 -0
  140. package/merged-commands/code-refactoring-context-restore.md +179 -0
  141. package/merged-commands/code-refactoring-refactor-clean.md +51 -0
  142. package/merged-commands/code-refactoring-tech-debt.md +386 -0
  143. package/merged-commands/code-refactoring.md +209 -0
  144. package/merged-commands/code-review-ai-ai-review.md +450 -0
  145. package/merged-commands/code-review-checklist.md +444 -0
  146. package/merged-commands/code-review-excellence.md +40 -0
  147. package/merged-commands/code-review.md +121 -0
  148. package/merged-commands/code-reviewer.md +178 -0
  149. package/merged-commands/codebase-cleanup-deps-audit.md +51 -0
  150. package/merged-commands/codebase-cleanup-refactor-clean.md +51 -0
  151. package/merged-commands/codebase-cleanup-tech-debt.md +386 -0
  152. package/merged-commands/codex-review.md +37 -0
  153. package/merged-commands/commit.md +171 -0
  154. package/merged-commands/competitive-ads-extractor.md +293 -0
  155. package/merged-commands/competitive-landscape.md +34 -0
  156. package/merged-commands/competitor-alternatives.md +750 -0
  157. package/merged-commands/comprehensive-review-full-review.md +146 -0
  158. package/merged-commands/comprehensive-review-pr-enhance.md +46 -0
  159. package/merged-commands/computer-use-agents.md +315 -0
  160. package/merged-commands/concise-planning.md +62 -0
  161. package/merged-commands/conductor-implement.md +388 -0
  162. package/merged-commands/conductor-manage.md +39 -0
  163. package/merged-commands/conductor-new-track.md +433 -0
  164. package/merged-commands/conductor-revert.md +372 -0
  165. package/merged-commands/conductor-setup.md +426 -0
  166. package/merged-commands/conductor-status.md +338 -0
  167. package/merged-commands/conductor-validator.md +62 -0
  168. package/merged-commands/content-creator.md +248 -0
  169. package/merged-commands/content-marketer.md +170 -0
  170. package/merged-commands/content-research-writer.md +538 -0
  171. package/merged-commands/context-compression.md +266 -0
  172. package/merged-commands/context-degradation.md +238 -0
  173. package/merged-commands/context-driven-development.md +400 -0
  174. package/merged-commands/context-engineering.md +107 -0
  175. package/merged-commands/context-fundamentals.md +192 -0
  176. package/merged-commands/context-management-context-restore.md +179 -0
  177. package/merged-commands/context-management-context-save.md +177 -0
  178. package/merged-commands/context-manager.md +185 -0
  179. package/merged-commands/context-optimization.md +186 -0
  180. package/merged-commands/context-window-management.md +53 -0
  181. package/merged-commands/context7-auto-research.md +36 -0
  182. package/merged-commands/conversation-memory.md +61 -0
  183. package/merged-commands/copy-editing.md +439 -0
  184. package/merged-commands/copywriting.md +225 -0
  185. package/merged-commands/core-components.md +264 -0
  186. package/merged-commands/cosmos-db-python-skill.md +198 -0
  187. package/merged-commands/cost-optimization.md +286 -0
  188. package/merged-commands/cpp-pro.md +59 -0
  189. package/merged-commands/cqrs-implementation.md +35 -0
  190. package/merged-commands/create-pr.md +192 -0
  191. package/merged-commands/crewai.md +243 -0
  192. package/merged-commands/csharp-developer.md +94 -0
  193. package/merged-commands/csharp-pro.md +59 -0
  194. package/merged-commands/culture-index.md +43 -0
  195. package/merged-commands/customer-support.md +170 -0
  196. package/merged-commands/daily-news-report.md +356 -0
  197. package/merged-commands/data-engineer.md +224 -0
  198. package/merged-commands/data-engineering-data-driven-feature.md +182 -0
  199. package/merged-commands/data-engineering-data-pipeline.md +201 -0
  200. package/merged-commands/data-quality-frameworks.md +40 -0
  201. package/merged-commands/data-scientist.md +199 -0
  202. package/merged-commands/data-storytelling.md +465 -0
  203. package/merged-commands/database-admin.md +165 -0
  204. package/merged-commands/database-architect.md +268 -0
  205. package/merged-commands/database-cloud-optimization-cost-optimize.md +44 -0
  206. package/merged-commands/database-design.md +52 -0
  207. package/merged-commands/database-migration.md +436 -0
  208. package/merged-commands/database-migrations-migration-observability.md +420 -0
  209. package/merged-commands/database-migrations-sql-migrations.md +53 -0
  210. package/merged-commands/database-optimizer.md +167 -0
  211. package/merged-commands/databases.md +232 -0
  212. package/merged-commands/dbt-transformation-patterns.md +34 -0
  213. package/merged-commands/debugger.md +49 -0
  214. package/merged-commands/debugging-strategies.md +34 -0
  215. package/merged-commands/debugging-toolkit-smart-debug.md +197 -0
  216. package/merged-commands/debugging-wizard.md +93 -0
  217. package/merged-commands/debugging.md +84 -0
  218. package/merged-commands/deep-research.md +114 -0
  219. package/merged-commands/defi-protocol-templates.md +466 -0
  220. package/merged-commands/dependency-management-deps-audit.md +44 -0
  221. package/merged-commands/dependency-upgrade.md +421 -0
  222. package/merged-commands/deployment-engineer.md +170 -0
  223. package/merged-commands/deployment-pipeline-design.md +371 -0
  224. package/merged-commands/deployment-procedures.md +241 -0
  225. package/merged-commands/deployment-validation-config-validate.md +496 -0
  226. package/merged-commands/design-md.md +178 -0
  227. package/merged-commands/design-orchestration.md +167 -0
  228. package/merged-commands/developer-growth-analysis.md +322 -0
  229. package/merged-commands/devops-engineer.md +92 -0
  230. package/merged-commands/devops-troubleshooter.md +161 -0
  231. package/merged-commands/devops.md +285 -0
  232. package/merged-commands/discord-bot-architect.md +277 -0
  233. package/merged-commands/dispatching-parallel-agents.md +180 -0
  234. package/merged-commands/distributed-debugging-debug-trace.md +44 -0
  235. package/merged-commands/distributed-tracing.md +450 -0
  236. package/merged-commands/django-expert.md +89 -0
  237. package/merged-commands/django-pro.md +180 -0
  238. package/merged-commands/doc-coauthoring.md +375 -0
  239. package/merged-commands/docker-expert.md +409 -0
  240. package/merged-commands/docs-architect.md +98 -0
  241. package/merged-commands/docs-seeker.md +102 -0
  242. package/merged-commands/documentation-generation-doc-generate.md +48 -0
  243. package/merged-commands/documentation-templates.md +194 -0
  244. package/merged-commands/docx-official.md +197 -0
  245. package/merged-commands/docx.md +197 -0
  246. package/merged-commands/domain-name-brainstormer.md +212 -0
  247. package/merged-commands/dotnet-architect.md +197 -0
  248. package/merged-commands/dotnet-backend-patterns.md +37 -0
  249. package/merged-commands/dotnet-core-expert.md +96 -0
  250. package/merged-commands/dx-optimizer.md +83 -0
  251. package/merged-commands/e2e-testing-patterns.md +41 -0
  252. package/merged-commands/elixir-pro.md +59 -0
  253. package/merged-commands/email-sequence.md +925 -0
  254. package/merged-commands/email-systems.md +54 -0
  255. package/merged-commands/embedded-systems.md +98 -0
  256. package/merged-commands/embedding-strategies.md +491 -0
  257. package/merged-commands/employment-contract-templates.md +39 -0
  258. package/merged-commands/environment-setup-guide.md +479 -0
  259. package/merged-commands/error-debugging-error-analysis.md +47 -0
  260. package/merged-commands/error-debugging-error-trace.md +43 -0
  261. package/merged-commands/error-debugging-multi-agent-review.md +216 -0
  262. package/merged-commands/error-detective.md +53 -0
  263. package/merged-commands/error-diagnostics-error-analysis.md +47 -0
  264. package/merged-commands/error-diagnostics-error-trace.md +48 -0
  265. package/merged-commands/error-diagnostics-smart-debug.md +197 -0
  266. package/merged-commands/error-handling-patterns.md +35 -0
  267. package/merged-commands/ethical-hacking-methodology.md +466 -0
  268. package/merged-commands/evaluation.md +238 -0
  269. package/merged-commands/event-sourcing-architect.md +58 -0
  270. package/merged-commands/event-store-design.md +449 -0
  271. package/merged-commands/exa-search.md +36 -0
  272. package/merged-commands/executing-plans.md +76 -0
  273. package/merged-commands/expo-app-design.md +22 -0
  274. package/merged-commands/expo-deployment.md +72 -0
  275. package/merged-commands/fal-audio.md +22 -0
  276. package/merged-commands/fal-generate.md +22 -0
  277. package/merged-commands/fal-image-edit.md +22 -0
  278. package/merged-commands/fal-platform.md +22 -0
  279. package/merged-commands/fal-upscale.md +22 -0
  280. package/merged-commands/fal-workflow.md +22 -0
  281. package/merged-commands/fastapi-expert.md +93 -0
  282. package/merged-commands/fastapi-pro.md +192 -0
  283. package/merged-commands/fastapi-router.md +52 -0
  284. package/merged-commands/fastapi-templates.md +32 -0
  285. package/merged-commands/feature-forge.md +90 -0
  286. package/merged-commands/ffuf-claude-skill.md +22 -0
  287. package/merged-commands/file-organizer.md +250 -0
  288. package/merged-commands/file-path-traversal.md +486 -0
  289. package/merged-commands/file-uploads.md +22 -0
  290. package/merged-commands/find-bugs.md +86 -0
  291. package/merged-commands/fine-tuning-expert.md +98 -0
  292. package/merged-commands/finishing-a-development-branch.md +200 -0
  293. package/merged-commands/firebase.md +56 -0
  294. package/merged-commands/firecrawl-scraper.md +37 -0
  295. package/merged-commands/firmware-analyst.md +320 -0
  296. package/merged-commands/fix-review.md +53 -0
  297. package/merged-commands/fixing.md +72 -0
  298. package/merged-commands/flutter-expert.md +200 -0
  299. package/merged-commands/form-cro.md +441 -0
  300. package/merged-commands/foundry-iq-agent.md +15 -0
  301. package/merged-commands/foundry-iq-python.md +275 -0
  302. package/merged-commands/foundry-nextgen-frontend.md +555 -0
  303. package/merged-commands/foundry-sdk-python.md +290 -0
  304. package/merged-commands/fp-ts-errors.md +856 -0
  305. package/merged-commands/fp-ts-pragmatic.md +598 -0
  306. package/merged-commands/fp-ts-react.md +796 -0
  307. package/merged-commands/framework-migration-code-migrate.md +48 -0
  308. package/merged-commands/framework-migration-deps-upgrade.md +48 -0
  309. package/merged-commands/framework-migration-legacy-modernize.md +132 -0
  310. package/merged-commands/free-tool-strategy.md +576 -0
  311. package/merged-commands/frontend-design.md +272 -0
  312. package/merged-commands/frontend-dev-guidelines.md +359 -0
  313. package/merged-commands/frontend-developer.md +171 -0
  314. package/merged-commands/frontend-development.md +399 -0
  315. package/merged-commands/frontend-mobile-development-component-scaffold.md +403 -0
  316. package/merged-commands/frontend-mobile-security-xss-scan.md +322 -0
  317. package/merged-commands/frontend-security-coder.md +170 -0
  318. package/merged-commands/frontend-slides.md +770 -0
  319. package/merged-commands/full-stack-orchestration-full-stack-feature.md +135 -0
  320. package/merged-commands/fullstack-guardian.md +99 -0
  321. package/merged-commands/game-developer.md +94 -0
  322. package/merged-commands/game-development.md +167 -0
  323. package/merged-commands/gcp-cloud-run.md +288 -0
  324. package/merged-commands/gdpr-data-handling.md +33 -0
  325. package/merged-commands/geo-fundamentals.md +156 -0
  326. package/merged-commands/git-advanced-workflows.md +412 -0
  327. package/merged-commands/git-pr-workflows-git-workflow.md +140 -0
  328. package/merged-commands/git-pr-workflows-onboard.md +416 -0
  329. package/merged-commands/git-pr-workflows-pr-enhance.md +48 -0
  330. package/merged-commands/git-pushing.md +33 -0
  331. package/merged-commands/github-actions-templates.md +345 -0
  332. package/merged-commands/github-workflow-automation.md +846 -0
  333. package/merged-commands/gitlab-ci-patterns.md +283 -0
  334. package/merged-commands/gitops-workflow.md +303 -0
  335. package/merged-commands/go-concurrency-patterns.md +33 -0
  336. package/merged-commands/godot-gdscript-patterns.md +33 -0
  337. package/merged-commands/golang-pro.md +179 -0
  338. package/merged-commands/google-adk-python.md +243 -0
  339. package/merged-commands/grafana-dashboards.md +381 -0
  340. package/merged-commands/graphql-architect.md +182 -0
  341. package/merged-commands/graphql.md +68 -0
  342. package/merged-commands/haskell-pro.md +56 -0
  343. package/merged-commands/helm-chart-scaffolding.md +34 -0
  344. package/merged-commands/hr-pro.md +126 -0
  345. package/merged-commands/html-injection-testing.md +498 -0
  346. package/merged-commands/hubspot-integration.md +42 -0
  347. package/merged-commands/hugging-face-cli.md +198 -0
  348. package/merged-commands/hugging-face-jobs.md +1038 -0
  349. package/merged-commands/hybrid-cloud-architect.md +168 -0
  350. package/merged-commands/hybrid-cloud-networking.md +238 -0
  351. package/merged-commands/hybrid-search-implementation.md +32 -0
  352. package/merged-commands/i18n-localization.md +154 -0
  353. package/merged-commands/idor-testing.md +442 -0
  354. package/merged-commands/image-enhancer.md +99 -0
  355. package/merged-commands/imagen.md +77 -0
  356. package/merged-commands/incident-responder.md +213 -0
  357. package/merged-commands/incident-response-incident-response.md +168 -0
  358. package/merged-commands/incident-response-smart-fix.md +29 -0
  359. package/merged-commands/incident-runbook-templates.md +395 -0
  360. package/merged-commands/infinite-gratitude.md +26 -0
  361. package/merged-commands/inngest.md +55 -0
  362. package/merged-commands/interactive-portfolio.md +223 -0
  363. package/merged-commands/internal-comms-anthropic.md +32 -0
  364. package/merged-commands/internal-comms-community.md +32 -0
  365. package/merged-commands/internal-comms.md +32 -0
  366. package/merged-commands/invoice-organizer.md +446 -0
  367. package/merged-commands/ios-developer.md +219 -0
  368. package/merged-commands/issue-creator.md +137 -0
  369. package/merged-commands/istio-traffic-management.md +337 -0
  370. package/merged-commands/iterate-pr.md +150 -0
  371. package/merged-commands/java-architect.md +95 -0
  372. package/merged-commands/java-pro.md +177 -0
  373. package/merged-commands/javascript-mastery.md +645 -0
  374. package/merged-commands/javascript-pro.md +57 -0
  375. package/merged-commands/javascript-testing-patterns.md +35 -0
  376. package/merged-commands/javascript-typescript-typescript-scaffold.md +361 -0
  377. package/merged-commands/javascript-typescript.md +142 -0
  378. package/merged-commands/jira-issues.md +181 -0
  379. package/merged-commands/job-application.md +90 -0
  380. package/merged-commands/julia-pro.md +209 -0
  381. package/merged-commands/k8s-manifest-generator.md +35 -0
  382. package/merged-commands/k8s-security-policies.md +346 -0
  383. package/merged-commands/kaizen.md +730 -0
  384. package/merged-commands/kotlin-specialist.md +94 -0
  385. package/merged-commands/kpi-dashboard-design.md +440 -0
  386. package/merged-commands/kubernetes-architect.md +170 -0
  387. package/merged-commands/kubernetes-specialist.md +117 -0
  388. package/merged-commands/langchain-architecture.md +350 -0
  389. package/merged-commands/langfuse.md +238 -0
  390. package/merged-commands/langgraph.md +287 -0
  391. package/merged-commands/laravel-specialist.md +101 -0
  392. package/merged-commands/last30days.md +421 -0
  393. package/merged-commands/launch-strategy.md +344 -0
  394. package/merged-commands/lead-research-assistant.md +199 -0
  395. package/merged-commands/learn.md +476 -0
  396. package/merged-commands/legacy-modernizer.md +53 -0
  397. package/merged-commands/legal-advisor.md +70 -0
  398. package/merged-commands/linear-claude-skill.md +543 -0
  399. package/merged-commands/linkerd-patterns.md +321 -0
  400. package/merged-commands/lint-and-validate.md +45 -0
  401. package/merged-commands/linux-privilege-escalation.md +504 -0
  402. package/merged-commands/linux-shell-scripting.md +504 -0
  403. package/merged-commands/llm-app-patterns.md +760 -0
  404. package/merged-commands/llm-application-dev-ai-assistant.md +35 -0
  405. package/merged-commands/llm-application-dev-langchain-agent.md +246 -0
  406. package/merged-commands/llm-application-dev-prompt-optimize.md +37 -0
  407. package/merged-commands/llm-application-dev.md +216 -0
  408. package/merged-commands/llm-evaluation.md +483 -0
  409. package/merged-commands/loki-mode.md +721 -0
  410. package/merged-commands/machine-learning-ops-ml-pipeline.md +314 -0
  411. package/merged-commands/makepad-skills.md +22 -0
  412. package/merged-commands/malware-analyst.md +247 -0
  413. package/merged-commands/markdown-novel-viewer.md +281 -0
  414. package/merged-commands/market-sizing-analysis.md +425 -0
  415. package/merged-commands/marketing-ideas.md +221 -0
  416. package/merged-commands/marketing-psychology.md +255 -0
  417. package/merged-commands/mcp-builder.md +236 -0
  418. package/merged-commands/mcp-developer.md +94 -0
  419. package/merged-commands/mcp-management.md +209 -0
  420. package/merged-commands/media-processing.md +358 -0
  421. package/merged-commands/meeting-insights-analyzer.md +327 -0
  422. package/merged-commands/memory-forensics.md +491 -0
  423. package/merged-commands/memory-safety-patterns.md +33 -0
  424. package/merged-commands/memory-systems.md +228 -0
  425. package/merged-commands/mermaid-expert.md +59 -0
  426. package/merged-commands/mermaidjs-v11.md +115 -0
  427. package/merged-commands/metasploit-framework.md +478 -0
  428. package/merged-commands/micro-saas-launcher.md +212 -0
  429. package/merged-commands/microservices-architect.md +102 -0
  430. package/merged-commands/microservices-patterns.md +35 -0
  431. package/merged-commands/minecraft-bukkit-pro.md +126 -0
  432. package/merged-commands/ml-engineer.md +168 -0
  433. package/merged-commands/ml-pipeline-workflow.md +257 -0
  434. package/merged-commands/ml-pipeline.md +111 -0
  435. package/merged-commands/mlops-engineer.md +219 -0
  436. package/merged-commands/mobile-design.md +284 -0
  437. package/merged-commands/mobile-developer.md +205 -0
  438. package/merged-commands/mobile-development.md +212 -0
  439. package/merged-commands/mobile-security-coder.md +184 -0
  440. package/merged-commands/modern-javascript-patterns.md +35 -0
  441. package/merged-commands/monitoring-expert.md +92 -0
  442. package/merged-commands/monorepo-architect.md +61 -0
  443. package/merged-commands/monorepo-management.md +35 -0
  444. package/merged-commands/moodle-external-api-development.md +597 -0
  445. package/merged-commands/mtls-configuration.md +359 -0
  446. package/merged-commands/multi-agent-brainstorming.md +256 -0
  447. package/merged-commands/multi-agent-patterns.md +262 -0
  448. package/merged-commands/multi-cloud-architecture.md +189 -0
  449. package/merged-commands/multi-platform-apps-multi-platform.md +203 -0
  450. package/merged-commands/n8n-code-python.md +750 -0
  451. package/merged-commands/n8n-mcp-tools-expert.md +654 -0
  452. package/merged-commands/n8n-node-configuration.md +796 -0
  453. package/merged-commands/nanobanana-ppt-skills.md +22 -0
  454. package/merged-commands/neon-postgres.md +56 -0
  455. package/merged-commands/nestjs-expert.md +552 -0
  456. package/merged-commands/network-101.md +342 -0
  457. package/merged-commands/network-engineer.md +169 -0
  458. package/merged-commands/nextjs-app-router-patterns.md +33 -0
  459. package/merged-commands/nextjs-best-practices.md +203 -0
  460. package/merged-commands/nextjs-developer.md +97 -0
  461. package/merged-commands/nextjs-supabase-auth.md +56 -0
  462. package/merged-commands/nft-standards.md +395 -0
  463. package/merged-commands/nodejs-backend-patterns.md +35 -0
  464. package/merged-commands/nodejs-best-practices.md +333 -0
  465. package/merged-commands/nosql-expert.md +111 -0
  466. package/merged-commands/notebooklm-skill.md +269 -0
  467. package/merged-commands/notebooklm.md +269 -0
  468. package/merged-commands/notion-template-business.md +216 -0
  469. package/merged-commands/nx-workspace-patterns.md +464 -0
  470. package/merged-commands/observability-engineer.md +237 -0
  471. package/merged-commands/observability-monitoring-monitor-setup.md +48 -0
  472. package/merged-commands/observability-monitoring-slo-implement.md +43 -0
  473. package/merged-commands/observe-whatsapp.md +109 -0
  474. package/merged-commands/obsidian-clipper-template-creator.md +64 -0
  475. package/merged-commands/on-call-handoff-patterns.md +453 -0
  476. package/merged-commands/onboarding-cro.md +433 -0
  477. package/merged-commands/openapi-spec-generation.md +33 -0
  478. package/merged-commands/page-cro.md +343 -0
  479. package/merged-commands/paid-ads.md +551 -0
  480. package/merged-commands/pandas-pro.md +96 -0
  481. package/merged-commands/parallel-agents.md +175 -0
  482. package/merged-commands/payment-integration.md +77 -0
  483. package/merged-commands/paypal-integration.md +479 -0
  484. package/merged-commands/paywall-upgrade-cro.md +570 -0
  485. package/merged-commands/pci-compliance.md +478 -0
  486. package/merged-commands/pdf-official.md +294 -0
  487. package/merged-commands/pdf.md +294 -0
  488. package/merged-commands/pentest-checklist.md +334 -0
  489. package/merged-commands/pentest-commands.md +438 -0
  490. package/merged-commands/performance-engineer.md +180 -0
  491. package/merged-commands/performance-profiling.md +143 -0
  492. package/merged-commands/performance-testing-review-ai-review.md +450 -0
  493. package/merged-commands/performance-testing-review-multi-agent-review.md +216 -0
  494. package/merged-commands/personal-tool-builder.md +289 -0
  495. package/merged-commands/php-pro.md +63 -0
  496. package/merged-commands/plaid-fintech.md +50 -0
  497. package/merged-commands/plan-writing.md +152 -0
  498. package/merged-commands/planning-with-files.md +211 -0
  499. package/merged-commands/planning.md +95 -0
  500. package/merged-commands/plans-kanban.md +166 -0
  501. package/merged-commands/playwright-expert.md +87 -0
  502. package/merged-commands/playwright-skill.md +453 -0
  503. package/merged-commands/podcast-generation.md +121 -0
  504. package/merged-commands/popup-cro.md +346 -0
  505. package/merged-commands/posix-shell-pro.md +304 -0
  506. package/merged-commands/postgres-best-practices.md +57 -0
  507. package/merged-commands/postgres-pro.md +98 -0
  508. package/merged-commands/postgresql.md +230 -0
  509. package/merged-commands/postmortem-writing.md +386 -0
  510. package/merged-commands/powershell-windows.md +167 -0
  511. package/merged-commands/pptx-official.md +484 -0
  512. package/merged-commands/pptx.md +484 -0
  513. package/merged-commands/pricing-strategy.md +356 -0
  514. package/merged-commands/prisma-expert.md +355 -0
  515. package/merged-commands/privilege-escalation-methods.md +333 -0
  516. package/merged-commands/problem-solving.md +96 -0
  517. package/merged-commands/product-manager-toolkit.md +351 -0
  518. package/merged-commands/product-strategist.md +26 -0
  519. package/merged-commands/production-code-audit.md +540 -0
  520. package/merged-commands/programmatic-seo.md +351 -0
  521. package/merged-commands/projection-patterns.md +33 -0
  522. package/merged-commands/prometheus-configuration.md +404 -0
  523. package/merged-commands/prompt-caching.md +61 -0
  524. package/merged-commands/prompt-engineer.md +272 -0
  525. package/merged-commands/prompt-engineering-patterns.md +213 -0
  526. package/merged-commands/prompt-engineering.md +171 -0
  527. package/merged-commands/prompt-library.md +322 -0
  528. package/merged-commands/protocol-reverse-engineering.md +29 -0
  529. package/merged-commands/pydantic-models.md +58 -0
  530. package/merged-commands/pypict-skill.md +22 -0
  531. package/merged-commands/python-development-python-scaffold.md +331 -0
  532. package/merged-commands/python-development.md +139 -0
  533. package/merged-commands/python-packaging.md +36 -0
  534. package/merged-commands/python-patterns.md +441 -0
  535. package/merged-commands/python-performance-optimization.md +36 -0
  536. package/merged-commands/python-pro.md +158 -0
  537. package/merged-commands/python-testing-patterns.md +37 -0
  538. package/merged-commands/qa-regression.md +337 -0
  539. package/merged-commands/quant-analyst.md +53 -0
  540. package/merged-commands/radix-ui-design-system.md +847 -0
  541. package/merged-commands/raffle-winner-picker.md +159 -0
  542. package/merged-commands/rag-architect.md +100 -0
  543. package/merged-commands/rag-engineer.md +90 -0
  544. package/merged-commands/rag-implementation.md +421 -0
  545. package/merged-commands/rails-expert.md +97 -0
  546. package/merged-commands/react-best-practices.md +121 -0
  547. package/merged-commands/react-expert.md +98 -0
  548. package/merged-commands/react-flow-node.md +66 -0
  549. package/merged-commands/react-modernization.md +34 -0
  550. package/merged-commands/react-native-architecture.md +33 -0
  551. package/merged-commands/react-native-expert.md +88 -0
  552. package/merged-commands/react-patterns.md +198 -0
  553. package/merged-commands/react-state-management.md +441 -0
  554. package/merged-commands/react-ui-patterns.md +289 -0
  555. package/merged-commands/readme.md +775 -0
  556. package/merged-commands/receiving-code-review.md +213 -0
  557. package/merged-commands/red-team-tactics.md +199 -0
  558. package/merged-commands/red-team-tools.md +310 -0
  559. package/merged-commands/reference-builder.md +188 -0
  560. package/merged-commands/referral-program.md +602 -0
  561. package/merged-commands/remotion-best-practices.md +45 -0
  562. package/merged-commands/repomix.md +275 -0
  563. package/merged-commands/requesting-code-review.md +105 -0
  564. package/merged-commands/research-engineer.md +135 -0
  565. package/merged-commands/research.md +191 -0
  566. package/merged-commands/reverse-engineer.md +173 -0
  567. package/merged-commands/risk-manager.md +61 -0
  568. package/merged-commands/risk-metrics-calculation.md +33 -0
  569. package/merged-commands/ruby-pro.md +56 -0
  570. package/merged-commands/rust-async-patterns.md +33 -0
  571. package/merged-commands/rust-engineer.md +96 -0
  572. package/merged-commands/rust-pro.md +178 -0
  573. package/merged-commands/saga-orchestration.md +496 -0
  574. package/merged-commands/sales-automator.md +55 -0
  575. package/merged-commands/salesforce-developer.md +105 -0
  576. package/merged-commands/salesforce-development.md +51 -0
  577. package/merged-commands/sast-configuration.md +212 -0
  578. package/merged-commands/scala-pro.md +82 -0
  579. package/merged-commands/scanning-tools.md +589 -0
  580. package/merged-commands/schema-markup.md +360 -0
  581. package/merged-commands/screen-reader-testing.md +33 -0
  582. package/merged-commands/screenshots.md +401 -0
  583. package/merged-commands/scroll-experience.md +263 -0
  584. package/merged-commands/search-specialist.md +80 -0
  585. package/merged-commands/secrets-management.md +364 -0
  586. package/merged-commands/secure-code-guardian.md +93 -0
  587. package/merged-commands/security-auditor.md +169 -0
  588. package/merged-commands/security-bluebook-builder.md +22 -0
  589. package/merged-commands/security-compliance-compliance-check.md +55 -0
  590. package/merged-commands/security-requirement-extraction.md +33 -0
  591. package/merged-commands/security-reviewer.md +94 -0
  592. package/merged-commands/security-scanning-security-dependencies.md +43 -0
  593. package/merged-commands/security-scanning-security-hardening.md +147 -0
  594. package/merged-commands/security-scanning-security-sast.md +495 -0
  595. package/merged-commands/segment-cdp.md +50 -0
  596. package/merged-commands/senior-architect.md +209 -0
  597. package/merged-commands/senior-backend.md +209 -0
  598. package/merged-commands/senior-computer-vision.md +226 -0
  599. package/merged-commands/senior-data-engineer.md +226 -0
  600. package/merged-commands/senior-data-scientist.md +226 -0
  601. package/merged-commands/senior-devops.md +209 -0
  602. package/merged-commands/senior-frontend.md +209 -0
  603. package/merged-commands/senior-fullstack.md +209 -0
  604. package/merged-commands/senior-ml-engineer.md +226 -0
  605. package/merged-commands/senior-prompt-engineer.md +226 -0
  606. package/merged-commands/senior-qa.md +209 -0
  607. package/merged-commands/senior-secops.md +209 -0
  608. package/merged-commands/senior-security.md +209 -0
  609. package/merged-commands/seo-audit.md +487 -0
  610. package/merged-commands/seo-authority-builder.md +136 -0
  611. package/merged-commands/seo-cannibalization-detector.md +123 -0
  612. package/merged-commands/seo-content-auditor.md +83 -0
  613. package/merged-commands/seo-content-planner.md +108 -0
  614. package/merged-commands/seo-content-refresher.md +118 -0
  615. package/merged-commands/seo-content-writer.md +96 -0
  616. package/merged-commands/seo-fundamentals.md +173 -0
  617. package/merged-commands/seo-keyword-strategist.md +95 -0
  618. package/merged-commands/seo-meta-optimizer.md +92 -0
  619. package/merged-commands/seo-snippet-hunter.md +114 -0
  620. package/merged-commands/seo-structure-architect.md +108 -0
  621. package/merged-commands/sequential-thinking.md +94 -0
  622. package/merged-commands/server-management.md +161 -0
  623. package/merged-commands/service-mesh-expert.md +58 -0
  624. package/merged-commands/service-mesh-observability.md +395 -0
  625. package/merged-commands/sharp-edges.md +70 -0
  626. package/merged-commands/shellcheck-configuration.md +466 -0
  627. package/merged-commands/shodan-reconnaissance.md +503 -0
  628. package/merged-commands/shopify-apps.md +42 -0
  629. package/merged-commands/shopify-development.md +366 -0
  630. package/merged-commands/shopify-expert.md +102 -0
  631. package/merged-commands/signup-flow-cro.md +355 -0
  632. package/merged-commands/similarity-search-patterns.md +33 -0
  633. package/merged-commands/skill-creator.md +356 -0
  634. package/merged-commands/skill-developer.md +426 -0
  635. package/merged-commands/skill-rails-upgrade.md +408 -0
  636. package/merged-commands/skill-seekers.md +22 -0
  637. package/merged-commands/skill-share.md +80 -0
  638. package/merged-commands/slack-bot-builder.md +264 -0
  639. package/merged-commands/slack-gif-creator.md +254 -0
  640. package/merged-commands/slo-implementation.md +341 -0
  641. package/merged-commands/smtp-penetration-testing.md +500 -0
  642. package/merged-commands/social-content.md +807 -0
  643. package/merged-commands/software-architecture.md +75 -0
  644. package/merged-commands/solidity-security.md +34 -0
  645. package/merged-commands/spark-engineer.md +100 -0
  646. package/merged-commands/spark-optimization.md +427 -0
  647. package/merged-commands/spec-miner.md +88 -0
  648. package/merged-commands/spring-boot-engineer.md +104 -0
  649. package/merged-commands/sql-injection-testing.md +448 -0
  650. package/merged-commands/sql-optimization-patterns.md +35 -0
  651. package/merged-commands/sql-pro.md +173 -0
  652. package/merged-commands/sqlmap-database-pentesting.md +400 -0
  653. package/merged-commands/sre-engineer.md +98 -0
  654. package/merged-commands/ssh-penetration-testing.md +488 -0
  655. package/merged-commands/startup-analyst.md +328 -0
  656. package/merged-commands/startup-business-analyst-business-case.md +487 -0
  657. package/merged-commands/startup-business-analyst-financial-projections.md +353 -0
  658. package/merged-commands/startup-business-analyst-market-opportunity.md +240 -0
  659. package/merged-commands/startup-financial-modeling.md +467 -0
  660. package/merged-commands/startup-metrics-framework.md +34 -0
  661. package/merged-commands/stitch-ui-design.md +378 -0
  662. package/merged-commands/stride-analysis-patterns.md +33 -0
  663. package/merged-commands/stripe-integration.md +454 -0
  664. package/merged-commands/subagent-driven-development.md +240 -0
  665. package/merged-commands/superpowers-lab.md +22 -0
  666. package/merged-commands/swift-expert.md +94 -0
  667. package/merged-commands/swiftui-expert-skill.md +275 -0
  668. package/merged-commands/systematic-debugging.md +296 -0
  669. package/merged-commands/systems-programming-rust-project.md +440 -0
  670. package/merged-commands/tailwind-design-system.md +33 -0
  671. package/merged-commands/tailwind-patterns.md +269 -0
  672. package/merged-commands/tavily-web.md +36 -0
  673. package/merged-commands/tdd-orchestrator.md +205 -0
  674. package/merged-commands/tdd-workflow.md +149 -0
  675. package/merged-commands/tdd-workflows-tdd-cycle.md +221 -0
  676. package/merged-commands/tdd-workflows-tdd-green.md +73 -0
  677. package/merged-commands/tdd-workflows-tdd-red.md +164 -0
  678. package/merged-commands/tdd-workflows-tdd-refactor.md +187 -0
  679. package/merged-commands/team-collaboration-issue.md +37 -0
  680. package/merged-commands/team-collaboration-standup-notes.md +44 -0
  681. package/merged-commands/team-composition-analysis.md +413 -0
  682. package/merged-commands/telegram-bot-builder.md +254 -0
  683. package/merged-commands/telegram-mini-app.md +279 -0
  684. package/merged-commands/template-skill.md +6 -0
  685. package/merged-commands/temporal-python-pro.md +370 -0
  686. package/merged-commands/temporal-python-testing.md +170 -0
  687. package/merged-commands/terraform-engineer.md +97 -0
  688. package/merged-commands/terraform-module-library.md +261 -0
  689. package/merged-commands/terraform-skill.md +517 -0
  690. package/merged-commands/terraform-specialist.md +166 -0
  691. package/merged-commands/test-automator.md +224 -0
  692. package/merged-commands/test-driven-development.md +371 -0
  693. package/merged-commands/test-fixing.md +119 -0
  694. package/merged-commands/test-master.md +104 -0
  695. package/merged-commands/testing-patterns.md +259 -0
  696. package/merged-commands/theme-factory.md +59 -0
  697. package/merged-commands/threat-mitigation-mapping.md +33 -0
  698. package/merged-commands/threat-modeling-expert.md +60 -0
  699. package/merged-commands/threejs-skills.md +22 -0
  700. package/merged-commands/threejs.md +89 -0
  701. package/merged-commands/tool-design.md +318 -0
  702. package/merged-commands/top-web-vulnerabilities.md +543 -0
  703. package/merged-commands/track-management.md +38 -0
  704. package/merged-commands/trigger-dev.md +67 -0
  705. package/merged-commands/turborepo-caching.md +419 -0
  706. package/merged-commands/tutorial-engineer.md +139 -0
  707. package/merged-commands/twilio-communications.md +295 -0
  708. package/merged-commands/typescript-advanced-types.md +35 -0
  709. package/merged-commands/typescript-expert.md +429 -0
  710. package/merged-commands/typescript-pro.md +55 -0
  711. package/merged-commands/ui-design-system.md +32 -0
  712. package/merged-commands/ui-skills.md +22 -0
  713. package/merged-commands/ui-styling.md +321 -0
  714. package/merged-commands/ui-ux-designer.md +209 -0
  715. package/merged-commands/ui-ux-pro-max.md +351 -0
  716. package/merged-commands/ui-visual-validator.md +214 -0
  717. package/merged-commands/unit-testing-test-generate.md +319 -0
  718. package/merged-commands/unity-developer.md +230 -0
  719. package/merged-commands/unity-ecs-patterns.md +33 -0
  720. package/merged-commands/unreal-engine-cpp-pro.md +114 -0
  721. package/merged-commands/upgrading-expo.md +118 -0
  722. package/merged-commands/upstash-qstash.md +68 -0
  723. package/merged-commands/using-git-worktrees.md +217 -0
  724. package/merged-commands/using-neon.md +84 -0
  725. package/merged-commands/using-superpowers.md +87 -0
  726. package/merged-commands/uv-package-manager.md +37 -0
  727. package/merged-commands/ux-researcher-designer.md +30 -0
  728. package/merged-commands/varlock-claude-skill.md +22 -0
  729. package/merged-commands/vector-database-engineer.md +60 -0
  730. package/merged-commands/vector-index-tuning.md +42 -0
  731. package/merged-commands/vercel-deploy-claimable.md +120 -0
  732. package/merged-commands/vercel-deploy.md +22 -0
  733. package/merged-commands/vercel-deployment.md +79 -0
  734. package/merged-commands/verification-before-completion.md +139 -0
  735. package/merged-commands/vexor.md +22 -0
  736. package/merged-commands/video-downloader.md +106 -0
  737. package/merged-commands/viral-generator-builder.md +199 -0
  738. package/merged-commands/voice-agents.md +68 -0
  739. package/merged-commands/voice-ai-development.md +302 -0
  740. package/merged-commands/voice-ai-engine-development.md +721 -0
  741. package/merged-commands/vue-expert-js.md +91 -0
  742. package/merged-commands/vue-expert.md +374 -0
  743. package/merged-commands/vulnerability-scanner.md +276 -0
  744. package/merged-commands/wcag-audit-patterns.md +41 -0
  745. package/merged-commands/web-artifacts-builder.md +74 -0
  746. package/merged-commands/web-design-guidelines.md +36 -0
  747. package/merged-commands/web-frameworks.md +324 -0
  748. package/merged-commands/web-performance-optimization.md +646 -0
  749. package/merged-commands/web3-testing.md +427 -0
  750. package/merged-commands/webapp-testing.md +96 -0
  751. package/merged-commands/websocket-engineer.md +96 -0
  752. package/merged-commands/windows-privilege-escalation.md +496 -0
  753. package/merged-commands/wireshark-analysis.md +497 -0
  754. package/merged-commands/wordpress-penetration-testing.md +485 -0
  755. package/merged-commands/wordpress-pro.md +105 -0
  756. package/merged-commands/workflow-automation.md +68 -0
  757. package/merged-commands/workflow-orchestration-patterns.md +333 -0
  758. package/merged-commands/workflow-patterns.md +38 -0
  759. package/merged-commands/writing-plans.md +116 -0
  760. package/merged-commands/writing-skills.md +125 -0
  761. package/merged-commands/x-article-publisher-skill.md +22 -0
  762. package/merged-commands/xlsx-official.md +289 -0
  763. package/merged-commands/xlsx.md +289 -0
  764. package/merged-commands/xss-html-injection.md +499 -0
  765. package/merged-commands/youtube-transcript.md +415 -0
  766. package/merged-commands/zapier-make-patterns.md +67 -0
  767. package/merged-commands/zustand-store.md +68 -0
  768. package/package.json +1 -1
  769. 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
+