devstack 0.1.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 (1450) hide show
  1. package/README.md +253 -0
  2. package/bin/audit-template-deps.ts +267 -0
  3. package/bin/cli.ts +5 -0
  4. package/bin/validate-tanstack-scaffold.ts +67 -0
  5. package/package.json +85 -0
  6. package/src/builders/index.ts +1 -0
  7. package/src/builders/separated.ts +1 -0
  8. package/src/builders/shared.ts +608 -0
  9. package/src/builders/tanstack-start.ts +2683 -0
  10. package/src/builders/types.ts +10 -0
  11. package/src/cli.ts +106 -0
  12. package/src/generator.ts +2946 -0
  13. package/src/index.ts +23 -0
  14. package/src/modules/auth.ts +33 -0
  15. package/src/modules/email.ts +38 -0
  16. package/src/modules/index.ts +30 -0
  17. package/src/modules/inngest.ts +58 -0
  18. package/src/modules/observability.ts +30 -0
  19. package/src/modules/organizations.ts +23 -0
  20. package/src/modules/redis.ts +35 -0
  21. package/src/modules/storage.ts +39 -0
  22. package/src/modules/storybook.ts +33 -0
  23. package/src/modules/stripe.ts +39 -0
  24. package/src/modules/types.ts +368 -0
  25. package/src/utils/files.ts +198 -0
  26. package/src/utils/packages.ts +59 -0
  27. package/src/utils/template-dependency-audit.ts +218 -0
  28. package/src/utils/template.ts +31 -0
  29. package/templates/base/backend/drizzle.config.ts +12 -0
  30. package/templates/base/backend/src/app.ts +65 -0
  31. package/templates/base/backend/src/db/index.ts +10 -0
  32. package/templates/base/backend/src/db/schema/index.ts +2 -0
  33. package/templates/base/backend/src/db/schema/items.ts +18 -0
  34. package/templates/base/backend/src/env.ts +78 -0
  35. package/templates/base/backend/src/index.ts +23 -0
  36. package/templates/base/backend/src/lib/errors.ts +205 -0
  37. package/templates/base/backend/src/lib/id.ts +5 -0
  38. package/templates/base/backend/src/lib/lazy.ts +14 -0
  39. package/templates/base/backend/src/lib/logger.ts +168 -0
  40. package/templates/base/backend/src/lib/openapi-schemas.ts +123 -0
  41. package/templates/base/backend/src/lib/openapi.ts +113 -0
  42. package/templates/base/backend/src/lib/pagination.ts +75 -0
  43. package/templates/base/backend/src/lib/response.ts +23 -0
  44. package/templates/base/backend/src/modules/items/index.ts +1 -0
  45. package/templates/base/backend/src/modules/items/model.ts +26 -0
  46. package/templates/base/backend/src/modules/items/repository.ts +30 -0
  47. package/templates/base/backend/src/modules/items/route.ts +93 -0
  48. package/templates/base/backend/src/modules/items/usecases.ts +67 -0
  49. package/templates/base/backend/src/plugins/error.ts +40 -0
  50. package/templates/base/backend/src/plugins/index.ts +7 -0
  51. package/templates/base/backend/src/plugins/logging.ts +20 -0
  52. package/templates/base/backend/src/plugins/metrics.ts +155 -0
  53. package/templates/base/backend/src/plugins/openapi.ts +17 -0
  54. package/templates/base/backend/src/plugins/request-id.ts +35 -0
  55. package/templates/base/backend/src/routes/health.ts +72 -0
  56. package/templates/base/backend/src/test-setup.ts +36 -0
  57. package/templates/base/backend/src/test-utils/db.ts +212 -0
  58. package/templates/base/backend/src/test-utils/factories.ts +16 -0
  59. package/templates/base/backend/src/test-utils/index.ts +3 -0
  60. package/templates/base/backend/src/test-utils/request.ts +72 -0
  61. package/templates/base/backend/src/types/index.ts +1 -0
  62. package/templates/base/backend/tsconfig.json +21 -0
  63. package/templates/base/backend/vitest.config.ts +26 -0
  64. package/templates/base/claude/skills/agent-browser/SKILL.md +629 -0
  65. package/templates/base/claude/skills/agent-browser/references/authentication.md +306 -0
  66. package/templates/base/claude/skills/agent-browser/references/commands.md +264 -0
  67. package/templates/base/claude/skills/agent-browser/references/profiling.md +120 -0
  68. package/templates/base/claude/skills/agent-browser/references/proxy-support.md +194 -0
  69. package/templates/base/claude/skills/agent-browser/references/session-management.md +194 -0
  70. package/templates/base/claude/skills/agent-browser/references/snapshot-refs.md +196 -0
  71. package/templates/base/claude/skills/agent-browser/references/video-recording.md +173 -0
  72. package/templates/base/claude/skills/agent-browser/templates/authenticated-session.sh +105 -0
  73. package/templates/base/claude/skills/agent-browser/templates/capture-workflow.sh +69 -0
  74. package/templates/base/claude/skills/agent-browser/templates/form-automation.sh +62 -0
  75. package/templates/base/claude/skills/alpine-js/SKILL.md +107 -0
  76. package/templates/base/claude/skills/better-auth-best-practices/SKILL.md +183 -0
  77. package/templates/base/claude/skills/es-toolkit/SKILL.md +281 -0
  78. package/templates/base/claude/skills/es-toolkit/references/api-catalog.md +234 -0
  79. package/templates/base/claude/skills/es-toolkit/references/lodash-migration.md +131 -0
  80. package/templates/base/claude/skills/hono/SKILL.md +90 -0
  81. package/templates/base/claude/skills/organization-best-practices/SKILL.md +478 -0
  82. package/templates/base/claude/skills/stripe-best-practices/SKILL.md +30 -0
  83. package/templates/base/claude/skills/stripe-integration/SKILL.md +492 -0
  84. package/templates/base/claude/skills/stripe-subscriptions/SKILL.md +54 -0
  85. package/templates/base/claude/skills/stripe-webhooks/SKILL.md +163 -0
  86. package/templates/base/claude/skills/stripe-webhooks/examples/express/.env.example +5 -0
  87. package/templates/base/claude/skills/stripe-webhooks/examples/express/README.md +64 -0
  88. package/templates/base/claude/skills/stripe-webhooks/examples/express/package.json +19 -0
  89. package/templates/base/claude/skills/stripe-webhooks/examples/express/src/index.js +75 -0
  90. package/templates/base/claude/skills/stripe-webhooks/examples/express/test/webhook.test.js +129 -0
  91. package/templates/base/claude/skills/stripe-webhooks/examples/fastapi/.env.example +5 -0
  92. package/templates/base/claude/skills/stripe-webhooks/examples/fastapi/README.md +69 -0
  93. package/templates/base/claude/skills/stripe-webhooks/examples/fastapi/main.py +75 -0
  94. package/templates/base/claude/skills/stripe-webhooks/examples/fastapi/requirements.txt +6 -0
  95. package/templates/base/claude/skills/stripe-webhooks/examples/fastapi/test_webhook.py +121 -0
  96. package/templates/base/claude/skills/stripe-webhooks/examples/nextjs/.env.example +5 -0
  97. package/templates/base/claude/skills/stripe-webhooks/examples/nextjs/README.md +62 -0
  98. package/templates/base/claude/skills/stripe-webhooks/examples/nextjs/app/webhooks/stripe/route.ts +63 -0
  99. package/templates/base/claude/skills/stripe-webhooks/examples/nextjs/package.json +23 -0
  100. package/templates/base/claude/skills/stripe-webhooks/examples/nextjs/test/webhook.test.ts +139 -0
  101. package/templates/base/claude/skills/stripe-webhooks/examples/nextjs/vitest.config.ts +8 -0
  102. package/templates/base/claude/skills/stripe-webhooks/references/overview.md +62 -0
  103. package/templates/base/claude/skills/stripe-webhooks/references/setup.md +99 -0
  104. package/templates/base/claude/skills/stripe-webhooks/references/verification.md +154 -0
  105. package/templates/base/claude/skills/svelte-code-writer/SKILL.md +66 -0
  106. package/templates/base/claude/skills/zod/AGENTS.md +97 -0
  107. package/templates/base/claude/skills/zod/README.md +79 -0
  108. package/templates/base/claude/skills/zod/SKILL.md +128 -0
  109. package/templates/base/claude/skills/zod/references/compose-intersection.md +143 -0
  110. package/templates/base/claude/skills/zod/references/compose-lazy-recursive.md +138 -0
  111. package/templates/base/claude/skills/zod/references/compose-pipe.md +114 -0
  112. package/templates/base/claude/skills/zod/references/compose-preprocess.md +131 -0
  113. package/templates/base/claude/skills/zod/references/compose-shared-schemas.md +142 -0
  114. package/templates/base/claude/skills/zod/references/error-avoid-throwing-in-refine.md +134 -0
  115. package/templates/base/claude/skills/zod/references/error-custom-messages.md +127 -0
  116. package/templates/base/claude/skills/zod/references/error-i18n.md +140 -0
  117. package/templates/base/claude/skills/zod/references/error-path-for-nested.md +135 -0
  118. package/templates/base/claude/skills/zod/references/error-use-flatten.md +135 -0
  119. package/templates/base/claude/skills/zod/references/object-discriminated-unions.md +136 -0
  120. package/templates/base/claude/skills/zod/references/object-extend-for-composition.md +146 -0
  121. package/templates/base/claude/skills/zod/references/object-optional-vs-nullable.md +120 -0
  122. package/templates/base/claude/skills/zod/references/object-partial-for-updates.md +124 -0
  123. package/templates/base/claude/skills/zod/references/object-pick-omit.md +147 -0
  124. package/templates/base/claude/skills/zod/references/object-strict-vs-strip.md +122 -0
  125. package/templates/base/claude/skills/zod/references/parse-async-for-async-refinements.md +127 -0
  126. package/templates/base/claude/skills/zod/references/parse-avoid-double-validation.md +130 -0
  127. package/templates/base/claude/skills/zod/references/parse-handle-all-issues.md +126 -0
  128. package/templates/base/claude/skills/zod/references/parse-never-trust-json.md +116 -0
  129. package/templates/base/claude/skills/zod/references/parse-use-safeparse.md +103 -0
  130. package/templates/base/claude/skills/zod/references/parse-validate-early.md +125 -0
  131. package/templates/base/claude/skills/zod/references/perf-arrays.md +154 -0
  132. package/templates/base/claude/skills/zod/references/perf-avoid-dynamic-creation.md +142 -0
  133. package/templates/base/claude/skills/zod/references/perf-cache-schemas.md +143 -0
  134. package/templates/base/claude/skills/zod/references/perf-lazy-loading.md +136 -0
  135. package/templates/base/claude/skills/zod/references/perf-zod-mini.md +118 -0
  136. package/templates/base/claude/skills/zod/references/refine-add-path.md +149 -0
  137. package/templates/base/claude/skills/zod/references/refine-catch.md +138 -0
  138. package/templates/base/claude/skills/zod/references/refine-defaults.md +132 -0
  139. package/templates/base/claude/skills/zod/references/refine-transform-coerce.md +103 -0
  140. package/templates/base/claude/skills/zod/references/refine-vs-superrefine.md +159 -0
  141. package/templates/base/claude/skills/zod/references/schema-avoid-optional-abuse.md +94 -0
  142. package/templates/base/claude/skills/zod/references/schema-coercion-for-form-data.md +89 -0
  143. package/templates/base/claude/skills/zod/references/schema-string-validations.md +87 -0
  144. package/templates/base/claude/skills/zod/references/schema-use-enums.md +106 -0
  145. package/templates/base/claude/skills/zod/references/schema-use-primitives-correctly.md +63 -0
  146. package/templates/base/claude/skills/zod/references/schema-use-unknown-not-any.md +86 -0
  147. package/templates/base/claude/skills/zod/references/type-branded-types.md +106 -0
  148. package/templates/base/claude/skills/zod/references/type-enable-strict-mode.md +132 -0
  149. package/templates/base/claude/skills/zod/references/type-export-schemas-and-types.md +117 -0
  150. package/templates/base/claude/skills/zod/references/type-input-vs-output.md +116 -0
  151. package/templates/base/claude/skills/zod/references/type-use-z-infer.md +113 -0
  152. package/templates/base/frontend/components.json +25 -0
  153. package/templates/base/frontend/index.html +17 -0
  154. package/templates/base/frontend/src/App.test.tsx +13 -0
  155. package/templates/base/frontend/src/App.tsx +11 -0
  156. package/templates/base/frontend/src/components/app-sidebar.tsx +89 -0
  157. package/templates/base/frontend/src/components/app-topbar.tsx +28 -0
  158. package/templates/base/frontend/src/components/nav-secondary.tsx +38 -0
  159. package/templates/base/frontend/src/components/nav-user.tsx +93 -0
  160. package/templates/base/frontend/src/components/theme-toggle.tsx +29 -0
  161. package/templates/base/frontend/src/components/ui/accordion.tsx +72 -0
  162. package/templates/base/frontend/src/components/ui/alert-dialog.tsx +160 -0
  163. package/templates/base/frontend/src/components/ui/alert.tsx +69 -0
  164. package/templates/base/frontend/src/components/ui/aspect-ratio.tsx +22 -0
  165. package/templates/base/frontend/src/components/ui/avatar.tsx +91 -0
  166. package/templates/base/frontend/src/components/ui/badge.tsx +50 -0
  167. package/templates/base/frontend/src/components/ui/banner.tsx +34 -0
  168. package/templates/base/frontend/src/components/ui/breadcrumb.tsx +103 -0
  169. package/templates/base/frontend/src/components/ui/button-group.tsx +78 -0
  170. package/templates/base/frontend/src/components/ui/button.tsx +61 -0
  171. package/templates/base/frontend/src/components/ui/calendar.tsx +185 -0
  172. package/templates/base/frontend/src/components/ui/card.tsx +92 -0
  173. package/templates/base/frontend/src/components/ui/carousel.tsx +229 -0
  174. package/templates/base/frontend/src/components/ui/chart.tsx +323 -0
  175. package/templates/base/frontend/src/components/ui/checkbox.tsx +28 -0
  176. package/templates/base/frontend/src/components/ui/collapsible.tsx +15 -0
  177. package/templates/base/frontend/src/components/ui/combobox.tsx +273 -0
  178. package/templates/base/frontend/src/components/ui/command.tsx +179 -0
  179. package/templates/base/frontend/src/components/ui/context-menu.tsx +245 -0
  180. package/templates/base/frontend/src/components/ui/dialog.tsx +138 -0
  181. package/templates/base/frontend/src/components/ui/direction.tsx +1 -0
  182. package/templates/base/frontend/src/components/ui/drawer.tsx +118 -0
  183. package/templates/base/frontend/src/components/ui/dropdown-menu.tsx +258 -0
  184. package/templates/base/frontend/src/components/ui/empty.tsx +94 -0
  185. package/templates/base/frontend/src/components/ui/field.tsx +224 -0
  186. package/templates/base/frontend/src/components/ui/hover-card.tsx +44 -0
  187. package/templates/base/frontend/src/components/ui/input-group.tsx +146 -0
  188. package/templates/base/frontend/src/components/ui/input-otp.tsx +86 -0
  189. package/templates/base/frontend/src/components/ui/input.tsx +20 -0
  190. package/templates/base/frontend/src/components/ui/item.tsx +188 -0
  191. package/templates/base/frontend/src/components/ui/kbd.tsx +26 -0
  192. package/templates/base/frontend/src/components/ui/label.tsx +20 -0
  193. package/templates/base/frontend/src/components/ui/menubar.tsx +265 -0
  194. package/templates/base/frontend/src/components/ui/native-select.tsx +43 -0
  195. package/templates/base/frontend/src/components/ui/navigation-menu.tsx +161 -0
  196. package/templates/base/frontend/src/components/ui/pagination.tsx +118 -0
  197. package/templates/base/frontend/src/components/ui/popover.tsx +77 -0
  198. package/templates/base/frontend/src/components/ui/progress.tsx +64 -0
  199. package/templates/base/frontend/src/components/ui/radio-group.tsx +38 -0
  200. package/templates/base/frontend/src/components/ui/resizable.tsx +40 -0
  201. package/templates/base/frontend/src/components/ui/scroll-area.tsx +50 -0
  202. package/templates/base/frontend/src/components/ui/select.tsx +188 -0
  203. package/templates/base/frontend/src/components/ui/separator.tsx +19 -0
  204. package/templates/base/frontend/src/components/ui/sheet.tsx +123 -0
  205. package/templates/base/frontend/src/components/ui/sidebar.tsx +694 -0
  206. package/templates/base/frontend/src/components/ui/skeleton.tsx +13 -0
  207. package/templates/base/frontend/src/components/ui/slider.tsx +52 -0
  208. package/templates/base/frontend/src/components/ui/sonner.tsx +43 -0
  209. package/templates/base/frontend/src/components/ui/spinner.tsx +15 -0
  210. package/templates/base/frontend/src/components/ui/surface.tsx +15 -0
  211. package/templates/base/frontend/src/components/ui/switch.tsx +30 -0
  212. package/templates/base/frontend/src/components/ui/table.tsx +98 -0
  213. package/templates/base/frontend/src/components/ui/tabs.tsx +75 -0
  214. package/templates/base/frontend/src/components/ui/textarea.tsx +18 -0
  215. package/templates/base/frontend/src/components/ui/toggle-group.tsx +87 -0
  216. package/templates/base/frontend/src/components/ui/toggle.tsx +42 -0
  217. package/templates/base/frontend/src/components/ui/tooltip.tsx +54 -0
  218. package/templates/base/frontend/src/hooks/use-mobile.ts +19 -0
  219. package/templates/base/frontend/src/integrations/tanstack-query/devtools.tsx +6 -0
  220. package/templates/base/frontend/src/integrations/tanstack-query/root-provider.tsx +18 -0
  221. package/templates/base/frontend/src/lib/utils.ts +6 -0
  222. package/templates/base/frontend/src/main.tsx +39 -0
  223. package/templates/base/frontend/src/routeTree.gen.ts +102 -0
  224. package/templates/base/frontend/src/routes/__root.tsx +16 -0
  225. package/templates/base/frontend/src/routes/_app/index.tsx +122 -0
  226. package/templates/base/frontend/src/routes/_app/settings.tsx +137 -0
  227. package/templates/base/frontend/src/routes/_app.tsx +19 -0
  228. package/templates/base/frontend/src/stores/use-theme-store.ts +92 -0
  229. package/templates/base/frontend/src/styles.css +146 -0
  230. package/templates/base/frontend/src/test-setup.ts +24 -0
  231. package/templates/base/frontend/tsconfig.json +27 -0
  232. package/templates/base/frontend/vite.config.ts +30 -0
  233. package/templates/base/frontend/vitest.config.ts +20 -0
  234. package/templates/base/root/.editorconfig +35 -0
  235. package/templates/base/root/.github/actions/setup-bun/action.yml +48 -0
  236. package/templates/base/root/.github/workflows/ci.yaml +66 -0
  237. package/templates/base/root/.husky/commit-msg +4 -0
  238. package/templates/base/root/.husky/pre-commit +4 -0
  239. package/templates/base/root/.nvmrc +2 -0
  240. package/templates/base/root/.oxfmtrc.json +33 -0
  241. package/templates/base/root/.oxlintrc.json +179 -0
  242. package/templates/base/root/CLAUDE.md +40 -0
  243. package/templates/base/root/Makefile +57 -0
  244. package/templates/base/root/commitlint.config.ts +3 -0
  245. package/templates/base/root/docker/postgres/init-test-db.sh +12 -0
  246. package/templates/base/root/lint-plugins/react-component-complexity.mjs +282 -0
  247. package/templates/base/root/lint-plugins/react-hooks-separation-codemod.mjs +1078 -0
  248. package/templates/base/root/lint-plugins/react-hooks-separation.mjs +243 -0
  249. package/templates/base/root/lint-plugins/test-file-location.mjs +104 -0
  250. package/templates/base/root/tsconfig.base.json +15 -0
  251. package/templates/base/root/tsconfig.json +16 -0
  252. package/templates/modules/auth/packages/backend/src/db/schema/auth.ts +145 -0
  253. package/templates/modules/auth/packages/backend/src/lib/auth/auth-context.ts +28 -0
  254. package/templates/modules/auth/packages/backend/src/lib/auth/auth.ts +97 -0
  255. package/templates/modules/auth/packages/backend/src/plugins/auth.ts +82 -0
  256. package/templates/modules/auth/src/db/schema/auth.ts +87 -0
  257. package/templates/modules/auth/src/lib/auth/auth-context.ts +23 -0
  258. package/templates/modules/auth/src/lib/auth/auth.ts +53 -0
  259. package/templates/modules/auth/src/lib/auth/index.ts +2 -0
  260. package/templates/modules/auth/src/plugins/auth.ts +52 -0
  261. package/templates/modules/email/packages/backend/src/lib/emails/send.tsx +58 -0
  262. package/templates/modules/email/packages/backend/src/lib/emails/templates/base.tsx +26 -0
  263. package/templates/modules/email/src/lib/emails/index.ts +1 -0
  264. package/templates/modules/email/src/lib/emails/send.ts +63 -0
  265. package/templates/modules/email/src/lib/emails/templates/layout.tsx +34 -0
  266. package/templates/modules/email/src/lib/integrations/resend.ts +10 -0
  267. package/templates/modules/inngest/packages/backend/src/jobs/example.ts +12 -0
  268. package/templates/modules/inngest/packages/backend/src/jobs/index.ts +3 -0
  269. package/templates/modules/inngest/packages/backend/src/lib/inngest.ts +39 -0
  270. package/templates/modules/inngest/src/jobs/example.ts +12 -0
  271. package/templates/modules/inngest/src/jobs/index.ts +3 -0
  272. package/templates/modules/inngest/src/lib/inngest.ts +28 -0
  273. package/templates/modules/observability/packages/backend/src/lib/sentry.ts +25 -0
  274. package/templates/modules/observability/packages/backend/src/lib/tracing.ts +125 -0
  275. package/templates/modules/observability/src/lib/sentry.ts +20 -0
  276. package/templates/modules/observability/src/lib/tracing.ts +77 -0
  277. package/templates/modules/organizations/packages/backend/src/lib/auth/org-context.ts +33 -0
  278. package/templates/modules/organizations/packages/backend/src/lib/auth/permissions.ts +43 -0
  279. package/templates/modules/organizations/src/db/schema/auth.ts +147 -0
  280. package/templates/modules/organizations/src/lib/auth/auth.ts +90 -0
  281. package/templates/modules/organizations/src/lib/auth/org-context.ts +33 -0
  282. package/templates/modules/organizations/src/lib/auth/permissions.ts +47 -0
  283. package/templates/modules/organizations/src/plugins/auth.ts +68 -0
  284. package/templates/modules/redis/packages/backend/src/lib/redis.ts +65 -0
  285. package/templates/modules/redis/packages/backend/src/plugins/rate-limiter.ts +51 -0
  286. package/templates/modules/redis/src/lib/redis.ts +30 -0
  287. package/templates/modules/redis/src/plugins/rate-limiter.ts +60 -0
  288. package/templates/modules/storage/packages/backend/src/lib/storage/client.ts +64 -0
  289. package/templates/modules/storage/packages/backend/src/lib/storage/index.ts +2 -0
  290. package/templates/modules/storage/packages/backend/src/lib/storage/init.ts +30 -0
  291. package/templates/modules/storage/src/lib/storage/client.ts +42 -0
  292. package/templates/modules/storage/src/lib/storage/index.ts +1 -0
  293. package/templates/modules/storybook/packages/frontend/.storybook/main.ts +17 -0
  294. package/templates/modules/storybook/packages/frontend/.storybook/preview.tsx +17 -0
  295. package/templates/modules/storybook/packages/frontend/src/components/ui/button.stories.tsx +17 -0
  296. package/templates/modules/stripe/packages/backend/src/db/schema/billing.ts +102 -0
  297. package/templates/modules/stripe/packages/backend/src/lib/billing.ts +31 -0
  298. package/templates/modules/stripe/packages/backend/src/lib/integrations/stripe.ts +52 -0
  299. package/templates/modules/stripe/packages/backend/src/modules/billing/index.ts +1 -0
  300. package/templates/modules/stripe/packages/backend/src/modules/billing/model.ts +45 -0
  301. package/templates/modules/stripe/packages/backend/src/modules/billing/repository.ts +87 -0
  302. package/templates/modules/stripe/packages/backend/src/modules/billing/route.ts +42 -0
  303. package/templates/modules/stripe/packages/backend/src/modules/billing/usecases.ts +97 -0
  304. package/templates/modules/stripe/packages/backend/src/routes/webhooks.ts +25 -0
  305. package/templates/modules/stripe/src/db/schema/billing.ts +90 -0
  306. package/templates/modules/stripe/src/lib/billing.ts +33 -0
  307. package/templates/modules/stripe/src/lib/integrations/stripe.ts +46 -0
  308. package/templates/modules/stripe/src/modules/billing/index.ts +1 -0
  309. package/templates/modules/stripe/src/modules/billing/model.ts +55 -0
  310. package/templates/modules/stripe/src/modules/billing/repository.ts +48 -0
  311. package/templates/modules/stripe/src/modules/billing/route.ts +97 -0
  312. package/templates/modules/stripe/src/modules/billing/usecases.ts +92 -0
  313. package/templates/modules/stripe/src/routes/webhooks.ts +57 -0
  314. package/vendor/skills/README.md +244 -0
  315. package/vendor/skills/skills/a11y-testing/SKILL.md +169 -0
  316. package/vendor/skills/skills/a11y-testing/checklists/a11y-testing-checklist.md +298 -0
  317. package/vendor/skills/skills/a11y-testing/examples/a11y-testing-examples.md +615 -0
  318. package/vendor/skills/skills/a11y-testing/references/a11y-testing-tools.md +383 -0
  319. package/vendor/skills/skills/a11y-testing/templates/a11y-test-template.ts +470 -0
  320. package/vendor/skills/skills/adversarial-review/SKILL.md +140 -0
  321. package/vendor/skills/skills/adversarial-review/references/reviewer-lenses.md +38 -0
  322. package/vendor/skills/skills/agent-browser/SKILL.md +151 -0
  323. package/vendor/skills/skills/agent-identifier/SKILL.md +438 -0
  324. package/vendor/skills/skills/agent-identifier/examples/agent-creation-prompt.md +250 -0
  325. package/vendor/skills/skills/agent-identifier/examples/complete-agent-examples.md +458 -0
  326. package/vendor/skills/skills/agent-identifier/references/agent-creation-system-prompt.md +216 -0
  327. package/vendor/skills/skills/agent-identifier/references/system-prompt-design.md +464 -0
  328. package/vendor/skills/skills/agent-identifier/references/triggering-examples.md +508 -0
  329. package/vendor/skills/skills/agent-identifier/scripts/validate-agent.sh +217 -0
  330. package/vendor/skills/skills/agent-md-refactor/README.md +234 -0
  331. package/vendor/skills/skills/agent-md-refactor/SKILL.md +309 -0
  332. package/vendor/skills/skills/ai-pdf-builder/README.md +40 -0
  333. package/vendor/skills/skills/ai-pdf-builder/SKILL.md +210 -0
  334. package/vendor/skills/skills/ai-pdf-builder/_meta.json +22 -0
  335. package/vendor/skills/skills/ai-sdk/SKILL.md +53 -0
  336. package/vendor/skills/skills/ai-sdk/references/ai-gateway.md +41 -0
  337. package/vendor/skills/skills/ai-sdk/references/common-errors.md +167 -0
  338. package/vendor/skills/skills/alex-hormozi-pitch/SKILL.md +69 -0
  339. package/vendor/skills/skills/alex-hormozi-pitch/metadata.json +14 -0
  340. package/vendor/skills/skills/app-renderer-systems/SKILL.md +177 -0
  341. package/vendor/skills/skills/app-renderer-systems/references/directory-layout.md +120 -0
  342. package/vendor/skills/skills/app-renderer-systems/references/patterns.md +509 -0
  343. package/vendor/skills/skills/architectural-analysis/SKILL.md +720 -0
  344. package/vendor/skills/skills/argocd-expert/SKILL.md +767 -0
  345. package/vendor/skills/skills/bencium-innovative-ux-designer/ACCESSIBILITY.md +112 -0
  346. package/vendor/skills/skills/bencium-innovative-ux-designer/DESIGN-SYSTEM-TEMPLATE.md +631 -0
  347. package/vendor/skills/skills/bencium-innovative-ux-designer/MOTION-SPEC.md +74 -0
  348. package/vendor/skills/skills/bencium-innovative-ux-designer/RESPONSIVE-DESIGN.md +95 -0
  349. package/vendor/skills/skills/bencium-innovative-ux-designer/SKILL.md +772 -0
  350. package/vendor/skills/skills/better-auth-best-practices/SKILL.md +174 -0
  351. package/vendor/skills/skills/brainstorming/SKILL.md +101 -0
  352. package/vendor/skills/skills/brand-storytelling/SKILL.md +86 -0
  353. package/vendor/skills/skills/brand-storytelling/references/guest-insights.md +722 -0
  354. package/vendor/skills/skills/building-components/SKILL.md +37 -0
  355. package/vendor/skills/skills/building-components/references/accessibility.mdx +794 -0
  356. package/vendor/skills/skills/building-components/references/as-child.mdx +318 -0
  357. package/vendor/skills/skills/building-components/references/composition.mdx +229 -0
  358. package/vendor/skills/skills/building-components/references/data-attributes.mdx +409 -0
  359. package/vendor/skills/skills/building-components/references/definitions.mdx +256 -0
  360. package/vendor/skills/skills/building-components/references/design-tokens.mdx +57 -0
  361. package/vendor/skills/skills/building-components/references/docs.mdx +153 -0
  362. package/vendor/skills/skills/building-components/references/marketplaces.mdx +144 -0
  363. package/vendor/skills/skills/building-components/references/npm.mdx +166 -0
  364. package/vendor/skills/skills/building-components/references/polymorphism.mdx +576 -0
  365. package/vendor/skills/skills/building-components/references/principles.mdx +61 -0
  366. package/vendor/skills/skills/building-components/references/registry.mdx +169 -0
  367. package/vendor/skills/skills/building-components/references/state.mdx +95 -0
  368. package/vendor/skills/skills/building-components/references/styling.mdx +271 -0
  369. package/vendor/skills/skills/building-components/references/types.mdx +189 -0
  370. package/vendor/skills/skills/centrifugo/SKILL.md +362 -0
  371. package/vendor/skills/skills/centrifugo/references/authentication.md +187 -0
  372. package/vendor/skills/skills/centrifugo/references/channels.md +172 -0
  373. package/vendor/skills/skills/centrifugo/references/client-sdk.md +242 -0
  374. package/vendor/skills/skills/centrifugo/references/configuration.md +201 -0
  375. package/vendor/skills/skills/centrifugo/references/engines.md +203 -0
  376. package/vendor/skills/skills/centrifugo/references/proxy.md +301 -0
  377. package/vendor/skills/skills/centrifugo/references/server-api.md +209 -0
  378. package/vendor/skills/skills/cloudflare/SKILL.md +238 -0
  379. package/vendor/skills/skills/cloudflare/references/agents-sdk/README.md +95 -0
  380. package/vendor/skills/skills/cloudflare/references/agents-sdk/api.md +195 -0
  381. package/vendor/skills/skills/cloudflare/references/agents-sdk/configuration.md +178 -0
  382. package/vendor/skills/skills/cloudflare/references/agents-sdk/gotchas.md +173 -0
  383. package/vendor/skills/skills/cloudflare/references/agents-sdk/patterns.md +215 -0
  384. package/vendor/skills/skills/cloudflare/references/ai-gateway/README.md +176 -0
  385. package/vendor/skills/skills/cloudflare/references/ai-gateway/configuration.md +117 -0
  386. package/vendor/skills/skills/cloudflare/references/ai-gateway/dynamic-routing.md +88 -0
  387. package/vendor/skills/skills/cloudflare/references/ai-gateway/features.md +96 -0
  388. package/vendor/skills/skills/cloudflare/references/ai-gateway/sdk-integration.md +110 -0
  389. package/vendor/skills/skills/cloudflare/references/ai-gateway/troubleshooting.md +90 -0
  390. package/vendor/skills/skills/cloudflare/references/ai-search/README.md +145 -0
  391. package/vendor/skills/skills/cloudflare/references/ai-search/api.md +87 -0
  392. package/vendor/skills/skills/cloudflare/references/ai-search/configuration.md +91 -0
  393. package/vendor/skills/skills/cloudflare/references/ai-search/gotchas.md +92 -0
  394. package/vendor/skills/skills/cloudflare/references/ai-search/patterns.md +87 -0
  395. package/vendor/skills/skills/cloudflare/references/analytics-engine/README.md +96 -0
  396. package/vendor/skills/skills/cloudflare/references/analytics-engine/api.md +112 -0
  397. package/vendor/skills/skills/cloudflare/references/analytics-engine/configuration.md +107 -0
  398. package/vendor/skills/skills/cloudflare/references/analytics-engine/gotchas.md +87 -0
  399. package/vendor/skills/skills/cloudflare/references/analytics-engine/patterns.md +83 -0
  400. package/vendor/skills/skills/cloudflare/references/api/README.md +66 -0
  401. package/vendor/skills/skills/cloudflare/references/api/api.md +205 -0
  402. package/vendor/skills/skills/cloudflare/references/api/configuration.md +158 -0
  403. package/vendor/skills/skills/cloudflare/references/api/gotchas.md +231 -0
  404. package/vendor/skills/skills/cloudflare/references/api/patterns.md +208 -0
  405. package/vendor/skills/skills/cloudflare/references/api-shield/README.md +44 -0
  406. package/vendor/skills/skills/cloudflare/references/api-shield/api.md +153 -0
  407. package/vendor/skills/skills/cloudflare/references/api-shield/configuration.md +210 -0
  408. package/vendor/skills/skills/cloudflare/references/api-shield/gotchas.md +132 -0
  409. package/vendor/skills/skills/cloudflare/references/api-shield/patterns.md +185 -0
  410. package/vendor/skills/skills/cloudflare/references/argo-smart-routing/README.md +96 -0
  411. package/vendor/skills/skills/cloudflare/references/argo-smart-routing/api.md +253 -0
  412. package/vendor/skills/skills/cloudflare/references/argo-smart-routing/configuration.md +205 -0
  413. package/vendor/skills/skills/cloudflare/references/argo-smart-routing/gotchas.md +115 -0
  414. package/vendor/skills/skills/cloudflare/references/argo-smart-routing/patterns.md +107 -0
  415. package/vendor/skills/skills/cloudflare/references/bindings/README.md +127 -0
  416. package/vendor/skills/skills/cloudflare/references/bindings/api.md +214 -0
  417. package/vendor/skills/skills/cloudflare/references/bindings/configuration.md +200 -0
  418. package/vendor/skills/skills/cloudflare/references/bindings/gotchas.md +210 -0
  419. package/vendor/skills/skills/cloudflare/references/bindings/patterns.md +205 -0
  420. package/vendor/skills/skills/cloudflare/references/bot-management/README.md +95 -0
  421. package/vendor/skills/skills/cloudflare/references/bot-management/api.md +175 -0
  422. package/vendor/skills/skills/cloudflare/references/bot-management/configuration.md +175 -0
  423. package/vendor/skills/skills/cloudflare/references/bot-management/gotchas.md +116 -0
  424. package/vendor/skills/skills/cloudflare/references/bot-management/patterns.md +181 -0
  425. package/vendor/skills/skills/cloudflare/references/browser-rendering/README.md +84 -0
  426. package/vendor/skills/skills/cloudflare/references/browser-rendering/api.md +108 -0
  427. package/vendor/skills/skills/cloudflare/references/browser-rendering/configuration.md +78 -0
  428. package/vendor/skills/skills/cloudflare/references/browser-rendering/gotchas.md +91 -0
  429. package/vendor/skills/skills/cloudflare/references/browser-rendering/patterns.md +94 -0
  430. package/vendor/skills/skills/cloudflare/references/c3/README.md +111 -0
  431. package/vendor/skills/skills/cloudflare/references/c3/api.md +71 -0
  432. package/vendor/skills/skills/cloudflare/references/c3/configuration.md +85 -0
  433. package/vendor/skills/skills/cloudflare/references/c3/gotchas.md +97 -0
  434. package/vendor/skills/skills/cloudflare/references/c3/patterns.md +84 -0
  435. package/vendor/skills/skills/cloudflare/references/cache-reserve/README.md +150 -0
  436. package/vendor/skills/skills/cloudflare/references/cache-reserve/api.md +184 -0
  437. package/vendor/skills/skills/cloudflare/references/cache-reserve/configuration.md +170 -0
  438. package/vendor/skills/skills/cloudflare/references/cache-reserve/gotchas.md +136 -0
  439. package/vendor/skills/skills/cloudflare/references/cache-reserve/patterns.md +197 -0
  440. package/vendor/skills/skills/cloudflare/references/containers/README.md +87 -0
  441. package/vendor/skills/skills/cloudflare/references/containers/api.md +197 -0
  442. package/vendor/skills/skills/cloudflare/references/containers/configuration.md +191 -0
  443. package/vendor/skills/skills/cloudflare/references/containers/gotchas.md +182 -0
  444. package/vendor/skills/skills/cloudflare/references/containers/patterns.md +204 -0
  445. package/vendor/skills/skills/cloudflare/references/cron-triggers/README.md +101 -0
  446. package/vendor/skills/skills/cloudflare/references/cron-triggers/api.md +224 -0
  447. package/vendor/skills/skills/cloudflare/references/cron-triggers/configuration.md +190 -0
  448. package/vendor/skills/skills/cloudflare/references/cron-triggers/gotchas.md +207 -0
  449. package/vendor/skills/skills/cloudflare/references/cron-triggers/patterns.md +277 -0
  450. package/vendor/skills/skills/cloudflare/references/d1/README.md +137 -0
  451. package/vendor/skills/skills/cloudflare/references/d1/api.md +213 -0
  452. package/vendor/skills/skills/cloudflare/references/d1/configuration.md +198 -0
  453. package/vendor/skills/skills/cloudflare/references/d1/gotchas.md +98 -0
  454. package/vendor/skills/skills/cloudflare/references/d1/patterns.md +242 -0
  455. package/vendor/skills/skills/cloudflare/references/ddos/README.md +42 -0
  456. package/vendor/skills/skills/cloudflare/references/ddos/api.md +158 -0
  457. package/vendor/skills/skills/cloudflare/references/ddos/configuration.md +94 -0
  458. package/vendor/skills/skills/cloudflare/references/ddos/gotchas.md +114 -0
  459. package/vendor/skills/skills/cloudflare/references/ddos/patterns.md +222 -0
  460. package/vendor/skills/skills/cloudflare/references/do-storage/README.md +79 -0
  461. package/vendor/skills/skills/cloudflare/references/do-storage/api.md +107 -0
  462. package/vendor/skills/skills/cloudflare/references/do-storage/configuration.md +114 -0
  463. package/vendor/skills/skills/cloudflare/references/do-storage/gotchas.md +153 -0
  464. package/vendor/skills/skills/cloudflare/references/do-storage/patterns.md +210 -0
  465. package/vendor/skills/skills/cloudflare/references/do-storage/testing.md +186 -0
  466. package/vendor/skills/skills/cloudflare/references/durable-objects/README.md +194 -0
  467. package/vendor/skills/skills/cloudflare/references/durable-objects/api.md +205 -0
  468. package/vendor/skills/skills/cloudflare/references/durable-objects/configuration.md +160 -0
  469. package/vendor/skills/skills/cloudflare/references/durable-objects/gotchas.md +200 -0
  470. package/vendor/skills/skills/cloudflare/references/durable-objects/patterns.md +205 -0
  471. package/vendor/skills/skills/cloudflare/references/email-routing/README.md +89 -0
  472. package/vendor/skills/skills/cloudflare/references/email-routing/api.md +192 -0
  473. package/vendor/skills/skills/cloudflare/references/email-routing/configuration.md +187 -0
  474. package/vendor/skills/skills/cloudflare/references/email-routing/gotchas.md +203 -0
  475. package/vendor/skills/skills/cloudflare/references/email-routing/patterns.md +241 -0
  476. package/vendor/skills/skills/cloudflare/references/email-workers/README.md +153 -0
  477. package/vendor/skills/skills/cloudflare/references/email-workers/api.md +227 -0
  478. package/vendor/skills/skills/cloudflare/references/email-workers/configuration.md +115 -0
  479. package/vendor/skills/skills/cloudflare/references/email-workers/gotchas.md +133 -0
  480. package/vendor/skills/skills/cloudflare/references/email-workers/patterns.md +108 -0
  481. package/vendor/skills/skills/cloudflare/references/graphql-api/README.md +147 -0
  482. package/vendor/skills/skills/cloudflare/references/graphql-api/api.md +175 -0
  483. package/vendor/skills/skills/cloudflare/references/graphql-api/configuration.md +151 -0
  484. package/vendor/skills/skills/cloudflare/references/graphql-api/gotchas.md +111 -0
  485. package/vendor/skills/skills/cloudflare/references/graphql-api/patterns.md +276 -0
  486. package/vendor/skills/skills/cloudflare/references/hyperdrive/README.md +84 -0
  487. package/vendor/skills/skills/cloudflare/references/hyperdrive/api.md +149 -0
  488. package/vendor/skills/skills/cloudflare/references/hyperdrive/configuration.md +166 -0
  489. package/vendor/skills/skills/cloudflare/references/hyperdrive/gotchas.md +77 -0
  490. package/vendor/skills/skills/cloudflare/references/hyperdrive/patterns.md +203 -0
  491. package/vendor/skills/skills/cloudflare/references/images/README.md +65 -0
  492. package/vendor/skills/skills/cloudflare/references/images/api.md +101 -0
  493. package/vendor/skills/skills/cloudflare/references/images/configuration.md +206 -0
  494. package/vendor/skills/skills/cloudflare/references/images/gotchas.md +106 -0
  495. package/vendor/skills/skills/cloudflare/references/images/patterns.md +126 -0
  496. package/vendor/skills/skills/cloudflare/references/kv/README.md +90 -0
  497. package/vendor/skills/skills/cloudflare/references/kv/api.md +163 -0
  498. package/vendor/skills/skills/cloudflare/references/kv/configuration.md +148 -0
  499. package/vendor/skills/skills/cloudflare/references/kv/gotchas.md +133 -0
  500. package/vendor/skills/skills/cloudflare/references/kv/patterns.md +195 -0
  501. package/vendor/skills/skills/cloudflare/references/miniflare/README.md +113 -0
  502. package/vendor/skills/skills/cloudflare/references/miniflare/api.md +204 -0
  503. package/vendor/skills/skills/cloudflare/references/miniflare/configuration.md +174 -0
  504. package/vendor/skills/skills/cloudflare/references/miniflare/gotchas.md +179 -0
  505. package/vendor/skills/skills/cloudflare/references/miniflare/patterns.md +187 -0
  506. package/vendor/skills/skills/cloudflare/references/network-interconnect/README.md +104 -0
  507. package/vendor/skills/skills/cloudflare/references/network-interconnect/api.md +220 -0
  508. package/vendor/skills/skills/cloudflare/references/network-interconnect/configuration.md +123 -0
  509. package/vendor/skills/skills/cloudflare/references/network-interconnect/gotchas.md +175 -0
  510. package/vendor/skills/skills/cloudflare/references/network-interconnect/patterns.md +174 -0
  511. package/vendor/skills/skills/cloudflare/references/observability/README.md +93 -0
  512. package/vendor/skills/skills/cloudflare/references/observability/api.md +168 -0
  513. package/vendor/skills/skills/cloudflare/references/observability/configuration.md +178 -0
  514. package/vendor/skills/skills/cloudflare/references/observability/gotchas.md +125 -0
  515. package/vendor/skills/skills/cloudflare/references/observability/patterns.md +105 -0
  516. package/vendor/skills/skills/cloudflare/references/pages/README.md +92 -0
  517. package/vendor/skills/skills/cloudflare/references/pages/api.md +205 -0
  518. package/vendor/skills/skills/cloudflare/references/pages/configuration.md +216 -0
  519. package/vendor/skills/skills/cloudflare/references/pages/gotchas.md +218 -0
  520. package/vendor/skills/skills/cloudflare/references/pages/patterns.md +215 -0
  521. package/vendor/skills/skills/cloudflare/references/pages-functions/README.md +104 -0
  522. package/vendor/skills/skills/cloudflare/references/pages-functions/api.md +159 -0
  523. package/vendor/skills/skills/cloudflare/references/pages-functions/configuration.md +130 -0
  524. package/vendor/skills/skills/cloudflare/references/pages-functions/gotchas.md +102 -0
  525. package/vendor/skills/skills/cloudflare/references/pages-functions/patterns.md +148 -0
  526. package/vendor/skills/skills/cloudflare/references/pipelines/README.md +109 -0
  527. package/vendor/skills/skills/cloudflare/references/pipelines/api.md +214 -0
  528. package/vendor/skills/skills/cloudflare/references/pipelines/configuration.md +98 -0
  529. package/vendor/skills/skills/cloudflare/references/pipelines/gotchas.md +84 -0
  530. package/vendor/skills/skills/cloudflare/references/pipelines/patterns.md +87 -0
  531. package/vendor/skills/skills/cloudflare/references/pulumi/README.md +113 -0
  532. package/vendor/skills/skills/cloudflare/references/pulumi/api.md +230 -0
  533. package/vendor/skills/skills/cloudflare/references/pulumi/configuration.md +213 -0
  534. package/vendor/skills/skills/cloudflare/references/pulumi/gotchas.md +205 -0
  535. package/vendor/skills/skills/cloudflare/references/pulumi/patterns.md +260 -0
  536. package/vendor/skills/skills/cloudflare/references/queues/README.md +99 -0
  537. package/vendor/skills/skills/cloudflare/references/queues/api.md +211 -0
  538. package/vendor/skills/skills/cloudflare/references/queues/configuration.md +151 -0
  539. package/vendor/skills/skills/cloudflare/references/queues/gotchas.md +210 -0
  540. package/vendor/skills/skills/cloudflare/references/queues/patterns.md +220 -0
  541. package/vendor/skills/skills/cloudflare/references/r2/README.md +97 -0
  542. package/vendor/skills/skills/cloudflare/references/r2/api.md +235 -0
  543. package/vendor/skills/skills/cloudflare/references/r2/configuration.md +176 -0
  544. package/vendor/skills/skills/cloudflare/references/r2/gotchas.md +190 -0
  545. package/vendor/skills/skills/cloudflare/references/r2/patterns.md +203 -0
  546. package/vendor/skills/skills/cloudflare/references/r2-data-catalog/README.md +157 -0
  547. package/vendor/skills/skills/cloudflare/references/r2-data-catalog/api.md +199 -0
  548. package/vendor/skills/skills/cloudflare/references/r2-data-catalog/configuration.md +205 -0
  549. package/vendor/skills/skills/cloudflare/references/r2-data-catalog/gotchas.md +170 -0
  550. package/vendor/skills/skills/cloudflare/references/r2-data-catalog/patterns.md +191 -0
  551. package/vendor/skills/skills/cloudflare/references/r2-sql/README.md +138 -0
  552. package/vendor/skills/skills/cloudflare/references/r2-sql/SKILL.md.backup +512 -0
  553. package/vendor/skills/skills/cloudflare/references/r2-sql/api.md +159 -0
  554. package/vendor/skills/skills/cloudflare/references/r2-sql/configuration.md +152 -0
  555. package/vendor/skills/skills/cloudflare/references/r2-sql/gotchas.md +228 -0
  556. package/vendor/skills/skills/cloudflare/references/r2-sql/patterns.md +230 -0
  557. package/vendor/skills/skills/cloudflare/references/realtime-sfu/README.md +66 -0
  558. package/vendor/skills/skills/cloudflare/references/realtime-sfu/api.md +164 -0
  559. package/vendor/skills/skills/cloudflare/references/realtime-sfu/configuration.md +141 -0
  560. package/vendor/skills/skills/cloudflare/references/realtime-sfu/gotchas.md +138 -0
  561. package/vendor/skills/skills/cloudflare/references/realtime-sfu/patterns.md +187 -0
  562. package/vendor/skills/skills/cloudflare/references/realtimekit/README.md +118 -0
  563. package/vendor/skills/skills/cloudflare/references/realtimekit/api.md +237 -0
  564. package/vendor/skills/skills/cloudflare/references/realtimekit/configuration.md +226 -0
  565. package/vendor/skills/skills/cloudflare/references/realtimekit/gotchas.md +206 -0
  566. package/vendor/skills/skills/cloudflare/references/realtimekit/patterns.md +240 -0
  567. package/vendor/skills/skills/cloudflare/references/sandbox/README.md +104 -0
  568. package/vendor/skills/skills/cloudflare/references/sandbox/api.md +200 -0
  569. package/vendor/skills/skills/cloudflare/references/sandbox/configuration.md +154 -0
  570. package/vendor/skills/skills/cloudflare/references/sandbox/gotchas.md +201 -0
  571. package/vendor/skills/skills/cloudflare/references/sandbox/patterns.md +195 -0
  572. package/vendor/skills/skills/cloudflare/references/secrets-store/README.md +77 -0
  573. package/vendor/skills/skills/cloudflare/references/secrets-store/api.md +199 -0
  574. package/vendor/skills/skills/cloudflare/references/secrets-store/configuration.md +187 -0
  575. package/vendor/skills/skills/cloudflare/references/secrets-store/gotchas.md +97 -0
  576. package/vendor/skills/skills/cloudflare/references/secrets-store/patterns.md +218 -0
  577. package/vendor/skills/skills/cloudflare/references/smart-placement/README.md +143 -0
  578. package/vendor/skills/skills/cloudflare/references/smart-placement/api.md +192 -0
  579. package/vendor/skills/skills/cloudflare/references/smart-placement/configuration.md +202 -0
  580. package/vendor/skills/skills/cloudflare/references/smart-placement/gotchas.md +180 -0
  581. package/vendor/skills/skills/cloudflare/references/smart-placement/patterns.md +194 -0
  582. package/vendor/skills/skills/cloudflare/references/snippets/README.md +74 -0
  583. package/vendor/skills/skills/cloudflare/references/snippets/api.md +214 -0
  584. package/vendor/skills/skills/cloudflare/references/snippets/configuration.md +239 -0
  585. package/vendor/skills/skills/cloudflare/references/snippets/gotchas.md +104 -0
  586. package/vendor/skills/skills/cloudflare/references/snippets/patterns.md +135 -0
  587. package/vendor/skills/skills/cloudflare/references/spectrum/README.md +52 -0
  588. package/vendor/skills/skills/cloudflare/references/spectrum/api.md +184 -0
  589. package/vendor/skills/skills/cloudflare/references/spectrum/configuration.md +203 -0
  590. package/vendor/skills/skills/cloudflare/references/spectrum/gotchas.md +155 -0
  591. package/vendor/skills/skills/cloudflare/references/spectrum/patterns.md +206 -0
  592. package/vendor/skills/skills/cloudflare/references/static-assets/README.md +65 -0
  593. package/vendor/skills/skills/cloudflare/references/static-assets/api.md +201 -0
  594. package/vendor/skills/skills/cloudflare/references/static-assets/configuration.md +186 -0
  595. package/vendor/skills/skills/cloudflare/references/static-assets/gotchas.md +164 -0
  596. package/vendor/skills/skills/cloudflare/references/static-assets/patterns.md +189 -0
  597. package/vendor/skills/skills/cloudflare/references/stream/README.md +123 -0
  598. package/vendor/skills/skills/cloudflare/references/stream/api-live.md +202 -0
  599. package/vendor/skills/skills/cloudflare/references/stream/api.md +206 -0
  600. package/vendor/skills/skills/cloudflare/references/stream/configuration.md +151 -0
  601. package/vendor/skills/skills/cloudflare/references/stream/gotchas.md +139 -0
  602. package/vendor/skills/skills/cloudflare/references/stream/patterns.md +217 -0
  603. package/vendor/skills/skills/cloudflare/references/tail-workers/README.md +92 -0
  604. package/vendor/skills/skills/cloudflare/references/tail-workers/api.md +203 -0
  605. package/vendor/skills/skills/cloudflare/references/tail-workers/configuration.md +178 -0
  606. package/vendor/skills/skills/cloudflare/references/tail-workers/gotchas.md +206 -0
  607. package/vendor/skills/skills/cloudflare/references/tail-workers/patterns.md +190 -0
  608. package/vendor/skills/skills/cloudflare/references/terraform/README.md +100 -0
  609. package/vendor/skills/skills/cloudflare/references/terraform/api.md +178 -0
  610. package/vendor/skills/skills/cloudflare/references/terraform/configuration.md +197 -0
  611. package/vendor/skills/skills/cloudflare/references/terraform/gotchas.md +150 -0
  612. package/vendor/skills/skills/cloudflare/references/terraform/patterns.md +174 -0
  613. package/vendor/skills/skills/cloudflare/references/tunnel/README.md +137 -0
  614. package/vendor/skills/skills/cloudflare/references/tunnel/api.md +205 -0
  615. package/vendor/skills/skills/cloudflare/references/tunnel/configuration.md +163 -0
  616. package/vendor/skills/skills/cloudflare/references/tunnel/gotchas.md +159 -0
  617. package/vendor/skills/skills/cloudflare/references/tunnel/networking.md +174 -0
  618. package/vendor/skills/skills/cloudflare/references/tunnel/patterns.md +199 -0
  619. package/vendor/skills/skills/cloudflare/references/turn/README.md +86 -0
  620. package/vendor/skills/skills/cloudflare/references/turn/api.md +236 -0
  621. package/vendor/skills/skills/cloudflare/references/turn/configuration.md +181 -0
  622. package/vendor/skills/skills/cloudflare/references/turn/gotchas.md +236 -0
  623. package/vendor/skills/skills/cloudflare/references/turn/patterns.md +228 -0
  624. package/vendor/skills/skills/cloudflare/references/turnstile/README.md +102 -0
  625. package/vendor/skills/skills/cloudflare/references/turnstile/api.md +253 -0
  626. package/vendor/skills/skills/cloudflare/references/turnstile/configuration.md +243 -0
  627. package/vendor/skills/skills/cloudflare/references/turnstile/gotchas.md +253 -0
  628. package/vendor/skills/skills/cloudflare/references/turnstile/patterns.md +195 -0
  629. package/vendor/skills/skills/cloudflare/references/vectorize/README.md +133 -0
  630. package/vendor/skills/skills/cloudflare/references/vectorize/api.md +89 -0
  631. package/vendor/skills/skills/cloudflare/references/vectorize/configuration.md +91 -0
  632. package/vendor/skills/skills/cloudflare/references/vectorize/gotchas.md +83 -0
  633. package/vendor/skills/skills/cloudflare/references/vectorize/patterns.md +92 -0
  634. package/vendor/skills/skills/cloudflare/references/waf/README.md +125 -0
  635. package/vendor/skills/skills/cloudflare/references/waf/api.md +203 -0
  636. package/vendor/skills/skills/cloudflare/references/waf/configuration.md +215 -0
  637. package/vendor/skills/skills/cloudflare/references/waf/gotchas.md +208 -0
  638. package/vendor/skills/skills/cloudflare/references/waf/patterns.md +236 -0
  639. package/vendor/skills/skills/cloudflare/references/web-analytics/README.md +149 -0
  640. package/vendor/skills/skills/cloudflare/references/web-analytics/configuration.md +81 -0
  641. package/vendor/skills/skills/cloudflare/references/web-analytics/gotchas.md +86 -0
  642. package/vendor/skills/skills/cloudflare/references/web-analytics/integration.md +63 -0
  643. package/vendor/skills/skills/cloudflare/references/web-analytics/patterns.md +98 -0
  644. package/vendor/skills/skills/cloudflare/references/workerd/README.md +85 -0
  645. package/vendor/skills/skills/cloudflare/references/workerd/api.md +219 -0
  646. package/vendor/skills/skills/cloudflare/references/workerd/configuration.md +200 -0
  647. package/vendor/skills/skills/cloudflare/references/workerd/gotchas.md +151 -0
  648. package/vendor/skills/skills/cloudflare/references/workerd/patterns.md +205 -0
  649. package/vendor/skills/skills/cloudflare/references/workers/README.md +110 -0
  650. package/vendor/skills/skills/cloudflare/references/workers/api.md +197 -0
  651. package/vendor/skills/skills/cloudflare/references/workers/configuration.md +184 -0
  652. package/vendor/skills/skills/cloudflare/references/workers/frameworks.md +200 -0
  653. package/vendor/skills/skills/cloudflare/references/workers/gotchas.md +145 -0
  654. package/vendor/skills/skills/cloudflare/references/workers/patterns.md +220 -0
  655. package/vendor/skills/skills/cloudflare/references/workers-ai/README.md +206 -0
  656. package/vendor/skills/skills/cloudflare/references/workers-ai/api.md +115 -0
  657. package/vendor/skills/skills/cloudflare/references/workers-ai/configuration.md +98 -0
  658. package/vendor/skills/skills/cloudflare/references/workers-ai/gotchas.md +130 -0
  659. package/vendor/skills/skills/cloudflare/references/workers-ai/patterns.md +122 -0
  660. package/vendor/skills/skills/cloudflare/references/workers-for-platforms/README.md +95 -0
  661. package/vendor/skills/skills/cloudflare/references/workers-for-platforms/api.md +212 -0
  662. package/vendor/skills/skills/cloudflare/references/workers-for-platforms/configuration.md +178 -0
  663. package/vendor/skills/skills/cloudflare/references/workers-for-platforms/gotchas.md +134 -0
  664. package/vendor/skills/skills/cloudflare/references/workers-for-platforms/patterns.md +210 -0
  665. package/vendor/skills/skills/cloudflare/references/workers-playground/README.md +131 -0
  666. package/vendor/skills/skills/cloudflare/references/workers-playground/api.md +101 -0
  667. package/vendor/skills/skills/cloudflare/references/workers-playground/configuration.md +169 -0
  668. package/vendor/skills/skills/cloudflare/references/workers-playground/gotchas.md +88 -0
  669. package/vendor/skills/skills/cloudflare/references/workers-playground/patterns.md +134 -0
  670. package/vendor/skills/skills/cloudflare/references/workers-vpc/README.md +130 -0
  671. package/vendor/skills/skills/cloudflare/references/workers-vpc/api.md +196 -0
  672. package/vendor/skills/skills/cloudflare/references/workers-vpc/configuration.md +151 -0
  673. package/vendor/skills/skills/cloudflare/references/workers-vpc/gotchas.md +171 -0
  674. package/vendor/skills/skills/cloudflare/references/workers-vpc/patterns.md +235 -0
  675. package/vendor/skills/skills/cloudflare/references/workflows/README.md +72 -0
  676. package/vendor/skills/skills/cloudflare/references/workflows/api.md +240 -0
  677. package/vendor/skills/skills/cloudflare/references/workflows/configuration.md +160 -0
  678. package/vendor/skills/skills/cloudflare/references/workflows/gotchas.md +97 -0
  679. package/vendor/skills/skills/cloudflare/references/workflows/patterns.md +245 -0
  680. package/vendor/skills/skills/cloudflare/references/wrangler/README.md +143 -0
  681. package/vendor/skills/skills/cloudflare/references/wrangler/api.md +188 -0
  682. package/vendor/skills/skills/cloudflare/references/wrangler/configuration.md +198 -0
  683. package/vendor/skills/skills/cloudflare/references/wrangler/gotchas.md +212 -0
  684. package/vendor/skills/skills/cloudflare/references/wrangler/patterns.md +211 -0
  685. package/vendor/skills/skills/cloudflare/references/zaraz/IMPLEMENTATION_SUMMARY.md +131 -0
  686. package/vendor/skills/skills/cloudflare/references/zaraz/README.md +114 -0
  687. package/vendor/skills/skills/cloudflare/references/zaraz/api.md +118 -0
  688. package/vendor/skills/skills/cloudflare/references/zaraz/configuration.md +94 -0
  689. package/vendor/skills/skills/cloudflare/references/zaraz/gotchas.md +88 -0
  690. package/vendor/skills/skills/cloudflare/references/zaraz/patterns.md +77 -0
  691. package/vendor/skills/skills/content-research-writer/SKILL.md +595 -0
  692. package/vendor/skills/skills/copywriting/SKILL.md +287 -0
  693. package/vendor/skills/skills/copywriting/references/copy-frameworks.md +385 -0
  694. package/vendor/skills/skills/copywriting/references/natural-transitions.md +255 -0
  695. package/vendor/skills/skills/crafting-effective-readmes/README.md +180 -0
  696. package/vendor/skills/skills/crafting-effective-readmes/SKILL.md +82 -0
  697. package/vendor/skills/skills/crafting-effective-readmes/references/art-of-readme.md +518 -0
  698. package/vendor/skills/skills/crafting-effective-readmes/references/make-a-readme.md +119 -0
  699. package/vendor/skills/skills/crafting-effective-readmes/references/standard-readme-example-maximal.md +70 -0
  700. package/vendor/skills/skills/crafting-effective-readmes/references/standard-readme-example-minimal.md +23 -0
  701. package/vendor/skills/skills/crafting-effective-readmes/references/standard-readme-spec.md +290 -0
  702. package/vendor/skills/skills/crafting-effective-readmes/section-checklist.md +17 -0
  703. package/vendor/skills/skills/crafting-effective-readmes/style-guide.md +13 -0
  704. package/vendor/skills/skills/crafting-effective-readmes/templates/internal.md +106 -0
  705. package/vendor/skills/skills/crafting-effective-readmes/templates/oss.md +77 -0
  706. package/vendor/skills/skills/crafting-effective-readmes/templates/personal.md +51 -0
  707. package/vendor/skills/skills/crafting-effective-readmes/templates/xdg-config.md +71 -0
  708. package/vendor/skills/skills/crafting-effective-readmes/using-references.md +37 -0
  709. package/vendor/skills/skills/creating-spec/SKILL.md +343 -0
  710. package/vendor/skills/skills/deep-research/SKILL.md +96 -0
  711. package/vendor/skills/skills/design-spec-extraction/SKILL.md +1402 -0
  712. package/vendor/skills/skills/design-spec-extraction/references/design-tokens-schema.json +1145 -0
  713. package/vendor/skills/skills/design-spec-extraction/references/extraction-patterns.md +1044 -0
  714. package/vendor/skills/skills/develop-ai-functions-example/SKILL.md +225 -0
  715. package/vendor/skills/skills/devops-engineer/SKILL.md +147 -0
  716. package/vendor/skills/skills/devops-engineer/references/deployment-strategies.md +245 -0
  717. package/vendor/skills/skills/devops-engineer/references/docker-patterns.md +113 -0
  718. package/vendor/skills/skills/devops-engineer/references/github-actions.md +142 -0
  719. package/vendor/skills/skills/devops-engineer/references/incident-response.md +345 -0
  720. package/vendor/skills/skills/devops-engineer/references/kubernetes.md +154 -0
  721. package/vendor/skills/skills/devops-engineer/references/platform-engineering.md +417 -0
  722. package/vendor/skills/skills/devops-engineer/references/release-automation.md +527 -0
  723. package/vendor/skills/skills/devops-engineer/references/terraform-iac.md +141 -0
  724. package/vendor/skills/skills/dispatching-parallel-agents/SKILL.md +191 -0
  725. package/vendor/skills/skills/drizzle-orm/SKILL.md +116 -0
  726. package/vendor/skills/skills/drizzle-orm/references/patterns.md +750 -0
  727. package/vendor/skills/skills/drizzle-safe-migrations/SKILL.md +68 -0
  728. package/vendor/skills/skills/drizzle-safe-migrations/agents/openai.yaml +4 -0
  729. package/vendor/skills/skills/drizzle-safe-migrations/references/production-playbook.md +47 -0
  730. package/vendor/skills/skills/effect-ts/SKILL.md +232 -0
  731. package/vendor/skills/skills/effect-ts/references/api-platform-observability.md +194 -0
  732. package/vendor/skills/skills/effect-ts/references/batching-and-caching.md +208 -0
  733. package/vendor/skills/skills/effect-ts/references/class-patterns.md +711 -0
  734. package/vendor/skills/skills/effect-ts/references/concurrency-and-resources.md +199 -0
  735. package/vendor/skills/skills/effect-ts/references/construction-and-style.md +138 -0
  736. package/vendor/skills/skills/effect-ts/references/control-flow-and-runtime.md +216 -0
  737. package/vendor/skills/skills/effect-ts/references/core-patterns.md +48 -0
  738. package/vendor/skills/skills/effect-ts/references/data-and-testing.md +200 -0
  739. package/vendor/skills/skills/effect-ts/references/data-types.md +705 -0
  740. package/vendor/skills/skills/effect-ts/references/error-handling-patterns.md +498 -0
  741. package/vendor/skills/skills/effect-ts/references/foundations.md +171 -0
  742. package/vendor/skills/skills/effect-ts/references/library-development-patterns.md +441 -0
  743. package/vendor/skills/skills/effect-ts/references/pattern-matching.md +363 -0
  744. package/vendor/skills/skills/effect-ts/references/quality-tooling-and-resources.md +240 -0
  745. package/vendor/skills/skills/effect-ts/references/schema-errors-config.md +486 -0
  746. package/vendor/skills/skills/effect-ts/references/schema-transforms-and-filters.md +293 -0
  747. package/vendor/skills/skills/effect-ts/references/sink.md +282 -0
  748. package/vendor/skills/skills/effect-ts/references/streams-deep-dive.md +649 -0
  749. package/vendor/skills/skills/effect-ts/references/testing-patterns.md +566 -0
  750. package/vendor/skills/skills/electron-builder/SKILL.md +447 -0
  751. package/vendor/skills/skills/electron-builder/references/auto-update.md +250 -0
  752. package/vendor/skills/skills/electron-builder/references/code-signing.md +213 -0
  753. package/vendor/skills/skills/electron-builder/references/configuration.md +229 -0
  754. package/vendor/skills/skills/electron-builder/references/hooks-and-programmatic.md +337 -0
  755. package/vendor/skills/skills/electron-builder/references/platform-targets.md +324 -0
  756. package/vendor/skills/skills/electron-builder/references/publishing.md +263 -0
  757. package/vendor/skills/skills/electron-dev/SKILL.md +195 -0
  758. package/vendor/skills/skills/electron-dev/references/patterns.md +825 -0
  759. package/vendor/skills/skills/electron-release/SKILL.md +216 -0
  760. package/vendor/skills/skills/electron-release/references/patterns.md +464 -0
  761. package/vendor/skills/skills/elysia/SKILL.md +155 -0
  762. package/vendor/skills/skills/elysia/references/patterns.md +569 -0
  763. package/vendor/skills/skills/es-toolkit/SKILL.md +45 -0
  764. package/vendor/skills/skills/es-toolkit/references/patterns.md +136 -0
  765. package/vendor/skills/skills/evolution-api/SKILL.md +312 -0
  766. package/vendor/skills/skills/evolution-api/references/api-endpoints.md +174 -0
  767. package/vendor/skills/skills/evolution-api/references/environment-variables.md +156 -0
  768. package/vendor/skills/skills/evolution-api/references/events.md +101 -0
  769. package/vendor/skills/skills/exa-web-search-free/.clawhub/origin.json +7 -0
  770. package/vendor/skills/skills/exa-web-search-free/SKILL.md +96 -0
  771. package/vendor/skills/skills/exa-web-search-free/references/examples.md +156 -0
  772. package/vendor/skills/skills/executing-plans/SKILL.md +87 -0
  773. package/vendor/skills/skills/find-rules/SKILL.md +184 -0
  774. package/vendor/skills/skills/find-skills/SKILL.md +133 -0
  775. package/vendor/skills/skills/firecrawl/SKILL.md +126 -0
  776. package/vendor/skills/skills/firecrawl/rules/install.md +63 -0
  777. package/vendor/skills/skills/firecrawl/rules/security.md +26 -0
  778. package/vendor/skills/skills/fix-coderabbit-review/SKILL.md +116 -0
  779. package/vendor/skills/skills/fix-coderabbit-review/agents/openai.yaml +3 -0
  780. package/vendor/skills/skills/fix-coderabbit-review/scripts/pr-review.ts +1182 -0
  781. package/vendor/skills/skills/fix-coderabbit-review/scripts/resolve_pr_issues.sh +228 -0
  782. package/vendor/skills/skills/fixing-motion-performance/SKILL.md +128 -0
  783. package/vendor/skills/skills/frontend-design/SKILL.md +45 -0
  784. package/vendor/skills/skills/fundraising/README.md +14 -0
  785. package/vendor/skills/skills/fundraising/SKILL.md +136 -0
  786. package/vendor/skills/skills/fundraising/references/CHECKLISTS.md +49 -0
  787. package/vendor/skills/skills/fundraising/references/EXAMPLES.md +10 -0
  788. package/vendor/skills/skills/fundraising/references/INTAKE.md +38 -0
  789. package/vendor/skills/skills/fundraising/references/RUBRIC.md +39 -0
  790. package/vendor/skills/skills/fundraising/references/SOURCE_SUMMARY.md +23 -0
  791. package/vendor/skills/skills/fundraising/references/TEMPLATES.md +201 -0
  792. package/vendor/skills/skills/fundraising/references/WORKFLOW.md +84 -0
  793. package/vendor/skills/skills/fundraising/skillpack.json +13 -0
  794. package/vendor/skills/skills/game-changing-features/README.md +230 -0
  795. package/vendor/skills/skills/game-changing-features/SKILL.md +287 -0
  796. package/vendor/skills/skills/git-rebase/SKILL.md +422 -0
  797. package/vendor/skills/skills/git-rebase/references/automation.md +25 -0
  798. package/vendor/skills/skills/git-rebase/references/resolution-patterns.md +76 -0
  799. package/vendor/skills/skills/git-rebase/references/scripts-tools.md +49 -0
  800. package/vendor/skills/skills/git-rebase/references/strategies.md +367 -0
  801. package/vendor/skills/skills/git-rebase/references/troubleshooting.md +70 -0
  802. package/vendor/skills/skills/git-rebase/scripts/analyze-conflicts.sh +107 -0
  803. package/vendor/skills/skills/git-rebase/scripts/pre-rebase-backup.sh +94 -0
  804. package/vendor/skills/skills/git-rebase/scripts/validate-merge.sh +106 -0
  805. package/vendor/skills/skills/google-ads/SKILL.md +197 -0
  806. package/vendor/skills/skills/google-ads/_meta.json +22 -0
  807. package/vendor/skills/skills/google-ads/references/api-setup.md +337 -0
  808. package/vendor/skills/skills/google-ads/references/browser-workflows.md +294 -0
  809. package/vendor/skills/skills/helm-chart-scaffolding/SKILL.md +566 -0
  810. package/vendor/skills/skills/helm-chart-scaffolding/assets/Chart.yaml.template +42 -0
  811. package/vendor/skills/skills/helm-chart-scaffolding/assets/values.yaml.template +185 -0
  812. package/vendor/skills/skills/helm-chart-scaffolding/references/chart-structure.md +509 -0
  813. package/vendor/skills/skills/helm-chart-scaffolding/scripts/validate-chart.sh +244 -0
  814. package/vendor/skills/skills/hetzner-server/SKILL.md +278 -0
  815. package/vendor/skills/skills/hono/SKILL.md +90 -0
  816. package/vendor/skills/skills/hormozi-ad-factory/SKILL.md +153 -0
  817. package/vendor/skills/skills/hormozi-ad-factory/assets/output-template.md +132 -0
  818. package/vendor/skills/skills/hormozi-ad-factory/references/cta-templates.md +84 -0
  819. package/vendor/skills/skills/hormozi-ad-factory/references/hook-formulas.md +137 -0
  820. package/vendor/skills/skills/hormozi-ad-factory/references/meat-formats.md +133 -0
  821. package/vendor/skills/skills/humanizer/README.md +122 -0
  822. package/vendor/skills/skills/humanizer/SKILL.md +493 -0
  823. package/vendor/skills/skills/inngest/SKILL.md +62 -0
  824. package/vendor/skills/skills/interface-design/SKILL.md +402 -0
  825. package/vendor/skills/skills/interface-design/references/critique.md +67 -0
  826. package/vendor/skills/skills/interface-design/references/example.md +87 -0
  827. package/vendor/skills/skills/interface-design/references/principles.md +235 -0
  828. package/vendor/skills/skills/interface-design/references/validation.md +51 -0
  829. package/vendor/skills/skills/k8s-security-policies/SKILL.md +352 -0
  830. package/vendor/skills/skills/k8s-security-policies/assets/network-policy-template.yaml +176 -0
  831. package/vendor/skills/skills/k8s-security-policies/references/rbac-patterns.md +199 -0
  832. package/vendor/skills/skills/kubernetes-specialist/SKILL.md +244 -0
  833. package/vendor/skills/skills/kubernetes-specialist/references/configuration.md +452 -0
  834. package/vendor/skills/skills/kubernetes-specialist/references/cost-optimization.md +458 -0
  835. package/vendor/skills/skills/kubernetes-specialist/references/custom-operators.md +563 -0
  836. package/vendor/skills/skills/kubernetes-specialist/references/gitops.md +531 -0
  837. package/vendor/skills/skills/kubernetes-specialist/references/helm-charts.md +912 -0
  838. package/vendor/skills/skills/kubernetes-specialist/references/multi-cluster.md +507 -0
  839. package/vendor/skills/skills/kubernetes-specialist/references/networking.md +447 -0
  840. package/vendor/skills/skills/kubernetes-specialist/references/service-mesh.md +459 -0
  841. package/vendor/skills/skills/kubernetes-specialist/references/storage.md +535 -0
  842. package/vendor/skills/skills/kubernetes-specialist/references/troubleshooting.md +416 -0
  843. package/vendor/skills/skills/kubernetes-specialist/references/workloads.md +377 -0
  844. package/vendor/skills/skills/landing-page-design/SKILL.md +243 -0
  845. package/vendor/skills/skills/lesson-learned/README.md +65 -0
  846. package/vendor/skills/skills/lesson-learned/SKILL.md +107 -0
  847. package/vendor/skills/skills/lesson-learned/references/anti-patterns.md +55 -0
  848. package/vendor/skills/skills/lesson-learned/references/se-principles.md +109 -0
  849. package/vendor/skills/skills/mastra/SKILL.md +173 -0
  850. package/vendor/skills/skills/mastra/references/common-errors.md +535 -0
  851. package/vendor/skills/skills/mastra/references/create-mastra.md +220 -0
  852. package/vendor/skills/skills/mastra/references/embedded-docs.md +99 -0
  853. package/vendor/skills/skills/mastra/references/migration-guide.md +180 -0
  854. package/vendor/skills/skills/mastra/references/remote-docs.md +193 -0
  855. package/vendor/skills/skills/mermaid-diagrams/README.md +246 -0
  856. package/vendor/skills/skills/mermaid-diagrams/SKILL.md +228 -0
  857. package/vendor/skills/skills/mermaid-diagrams/references/advanced-features.md +567 -0
  858. package/vendor/skills/skills/mermaid-diagrams/references/architecture-diagrams.md +192 -0
  859. package/vendor/skills/skills/mermaid-diagrams/references/c4-diagrams.md +416 -0
  860. package/vendor/skills/skills/mermaid-diagrams/references/class-diagrams.md +376 -0
  861. package/vendor/skills/skills/mermaid-diagrams/references/erd-diagrams.md +519 -0
  862. package/vendor/skills/skills/mermaid-diagrams/references/flowcharts.md +478 -0
  863. package/vendor/skills/skills/mermaid-diagrams/references/sequence-diagrams.md +406 -0
  864. package/vendor/skills/skills/motion/.claude-plugin/plugin.json +12 -0
  865. package/vendor/skills/skills/motion/SKILL.md +874 -0
  866. package/vendor/skills/skills/motion/references/common-patterns.md +247 -0
  867. package/vendor/skills/skills/motion/references/motion-vs-auto-animate.md +714 -0
  868. package/vendor/skills/skills/motion/references/nextjs-integration.md +694 -0
  869. package/vendor/skills/skills/motion/references/performance-optimization.md +898 -0
  870. package/vendor/skills/skills/motion/rules/motion.md +91 -0
  871. package/vendor/skills/skills/motion/scripts/init-motion.sh +241 -0
  872. package/vendor/skills/skills/motion/scripts/optimize-bundle.sh +215 -0
  873. package/vendor/skills/skills/motion/templates/layout-transitions.tsx +608 -0
  874. package/vendor/skills/skills/motion/templates/motion-nextjs-client.tsx +490 -0
  875. package/vendor/skills/skills/motion/templates/motion-vite-basic.tsx +366 -0
  876. package/vendor/skills/skills/motion/templates/scroll-parallax.tsx +506 -0
  877. package/vendor/skills/skills/motion/templates/ui-components.tsx +723 -0
  878. package/vendor/skills/skills/motion-react/SKILL.md +376 -0
  879. package/vendor/skills/skills/motion-react/references/animation-api.md +231 -0
  880. package/vendor/skills/skills/motion-react/references/gestures-and-drag.md +179 -0
  881. package/vendor/skills/skills/motion-react/references/hooks-and-motion-values.md +333 -0
  882. package/vendor/skills/skills/motion-react/references/layout-animations.md +208 -0
  883. package/vendor/skills/skills/motion-react/references/scroll-animations.md +229 -0
  884. package/vendor/skills/skills/motion-react/references/transitions-api.md +162 -0
  885. package/vendor/skills/skills/nano-banana-pro/SKILL.md +58 -0
  886. package/vendor/skills/skills/nano-banana-pro/scripts/generate_image.py +184 -0
  887. package/vendor/skills/skills/nano-banana-prompting/SKILL.md +149 -0
  888. package/vendor/skills/skills/nano-banana-prompting/references/guide.md +403 -0
  889. package/vendor/skills/skills/next-best-practices/SKILL.md +171 -0
  890. package/vendor/skills/skills/next-best-practices/async-patterns.md +84 -0
  891. package/vendor/skills/skills/next-best-practices/bundling.md +182 -0
  892. package/vendor/skills/skills/next-best-practices/data-patterns.md +300 -0
  893. package/vendor/skills/skills/next-best-practices/debug-tricks.md +122 -0
  894. package/vendor/skills/skills/next-best-practices/directives.md +74 -0
  895. package/vendor/skills/skills/next-best-practices/error-handling.md +228 -0
  896. package/vendor/skills/skills/next-best-practices/file-conventions.md +141 -0
  897. package/vendor/skills/skills/next-best-practices/font.md +246 -0
  898. package/vendor/skills/skills/next-best-practices/functions.md +108 -0
  899. package/vendor/skills/skills/next-best-practices/hydration-error.md +86 -0
  900. package/vendor/skills/skills/next-best-practices/image.md +173 -0
  901. package/vendor/skills/skills/next-best-practices/metadata.md +292 -0
  902. package/vendor/skills/skills/next-best-practices/parallel-routes.md +286 -0
  903. package/vendor/skills/skills/next-best-practices/route-handlers.md +143 -0
  904. package/vendor/skills/skills/next-best-practices/rsc-boundaries.md +160 -0
  905. package/vendor/skills/skills/next-best-practices/runtime-selection.md +40 -0
  906. package/vendor/skills/skills/next-best-practices/scripts.md +137 -0
  907. package/vendor/skills/skills/next-best-practices/self-hosting.md +375 -0
  908. package/vendor/skills/skills/next-best-practices/suspense-boundaries.md +67 -0
  909. package/vendor/skills/skills/no-workarounds/SKILL.md +447 -0
  910. package/vendor/skills/skills/no-workarounds/references/philosophical-foundations.md +111 -0
  911. package/vendor/skills/skills/no-workarounds/references/workaround-catalog.md +565 -0
  912. package/vendor/skills/skills/organization-best-practices/SKILL.md +478 -0
  913. package/vendor/skills/skills/outside-to-issue/SKILL.md +105 -0
  914. package/vendor/skills/skills/pal/SKILL.md +184 -0
  915. package/vendor/skills/skills/pal/references/analyze.md +77 -0
  916. package/vendor/skills/skills/pal/references/debug.md +78 -0
  917. package/vendor/skills/skills/pal/references/planner.md +101 -0
  918. package/vendor/skills/skills/pal/references/refactor.md +88 -0
  919. package/vendor/skills/skills/pal/references/review.md +61 -0
  920. package/vendor/skills/skills/pal/references/tracer.md +66 -0
  921. package/vendor/skills/skills/perplexity/README.md +212 -0
  922. package/vendor/skills/skills/perplexity/SKILL.md +143 -0
  923. package/vendor/skills/skills/pitch-deck/SKILL.md +259 -0
  924. package/vendor/skills/skills/pitch-deck/index.js +9 -0
  925. package/vendor/skills/skills/pitch-deck/package.json +11 -0
  926. package/vendor/skills/skills/pitch-deck/references/pitch_deck_best_practices.md +241 -0
  927. package/vendor/skills/skills/pitch-deck/scripts/create_pitch_deck.py +298 -0
  928. package/vendor/skills/skills/pitch-deck-visuals/SKILL.md +215 -0
  929. package/vendor/skills/skills/pitch-deck-visuals/_meta.json +11 -0
  930. package/vendor/skills/skills/pitch-gen/README.md +22 -0
  931. package/vendor/skills/skills/pitch-gen/SKILL.md +78 -0
  932. package/vendor/skills/skills/pitch-gen/_meta.json +11 -0
  933. package/vendor/skills/skills/pitch-gen/package-lock.json +876 -0
  934. package/vendor/skills/skills/pitch-gen/package.json +35 -0
  935. package/vendor/skills/skills/pitch-gen/src/cli.ts +26 -0
  936. package/vendor/skills/skills/pitch-gen/src/index.ts +18 -0
  937. package/vendor/skills/skills/pitch-gen/tsconfig.json +13 -0
  938. package/vendor/skills/skills/postgres-drizzle/SKILL.md +190 -0
  939. package/vendor/skills/skills/postgres-drizzle/references/CHEATSHEET.md +424 -0
  940. package/vendor/skills/skills/postgres-drizzle/references/MIGRATIONS.md +545 -0
  941. package/vendor/skills/skills/postgres-drizzle/references/PERFORMANCE.md +564 -0
  942. package/vendor/skills/skills/postgres-drizzle/references/POSTGRES.md +590 -0
  943. package/vendor/skills/skills/postgres-drizzle/references/QUERIES.md +701 -0
  944. package/vendor/skills/skills/postgres-drizzle/references/RELATIONS.md +651 -0
  945. package/vendor/skills/skills/postgres-drizzle/references/SCHEMA.md +574 -0
  946. package/vendor/skills/skills/pptx-creator/SKILL.md +239 -0
  947. package/vendor/skills/skills/pptx-creator/_meta.json +11 -0
  948. package/vendor/skills/skills/pptx-creator/references/outline-format.md +127 -0
  949. package/vendor/skills/skills/pptx-creator/scripts/analyze_template.py +182 -0
  950. package/vendor/skills/skills/pptx-creator/scripts/create_pptx.py +488 -0
  951. package/vendor/skills/skills/pptx-creator/scripts/create_template.py +427 -0
  952. package/vendor/skills/skills/pptx-creator/scripts/use_template.py +195 -0
  953. package/vendor/skills/skills/pptx-creator/templates/templates.json +70 -0
  954. package/vendor/skills/skills/professional-communication/README.md +234 -0
  955. package/vendor/skills/skills/professional-communication/SKILL.md +272 -0
  956. package/vendor/skills/skills/professional-communication/references/email-templates.md +300 -0
  957. package/vendor/skills/skills/professional-communication/references/jargon-simplification.md +164 -0
  958. package/vendor/skills/skills/professional-communication/references/meeting-structures.md +333 -0
  959. package/vendor/skills/skills/professional-communication/references/remote-async-communication.md +310 -0
  960. package/vendor/skills/skills/promo-video/SKILL.md +465 -0
  961. package/vendor/skills/skills/promo-video/metallic-swoosh.md +94 -0
  962. package/vendor/skills/skills/promo-video/music/inspired-ambient-141686.mp3 +0 -0
  963. package/vendor/skills/skills/promo-video/music/motivational-day-112790.mp3 +0 -0
  964. package/vendor/skills/skills/promo-video/music/the-upbeat-inspiring-corporate-142313.mp3 +0 -0
  965. package/vendor/skills/skills/promo-video/promo-patterns.md +184 -0
  966. package/vendor/skills/skills/promo-video/scripts/generate_voiceover.py +266 -0
  967. package/vendor/skills/skills/promo-video/voiceover.md +358 -0
  968. package/vendor/skills/skills/qa-test-planner/README.md +394 -0
  969. package/vendor/skills/skills/qa-test-planner/SKILL.md +827 -0
  970. package/vendor/skills/skills/qa-test-planner/references/bug_report_templates.md +457 -0
  971. package/vendor/skills/skills/qa-test-planner/references/figma_validation.md +381 -0
  972. package/vendor/skills/skills/qa-test-planner/references/regression_testing.md +406 -0
  973. package/vendor/skills/skills/qa-test-planner/references/test_case_templates.md +457 -0
  974. package/vendor/skills/skills/qa-test-planner/scripts/create_bug_report.sh +276 -0
  975. package/vendor/skills/skills/qa-test-planner/scripts/generate_test_cases.sh +302 -0
  976. package/vendor/skills/skills/ratatui-tui/SKILL.md +422 -0
  977. package/vendor/skills/skills/ratatui-tui/assets/templates/async-app/Cargo.lock +1914 -0
  978. package/vendor/skills/skills/ratatui-tui/assets/templates/async-app/Cargo.toml +11 -0
  979. package/vendor/skills/skills/ratatui-tui/assets/templates/async-app/src/main.rs +122 -0
  980. package/vendor/skills/skills/ratatui-tui/assets/templates/component-app/Cargo.lock +2433 -0
  981. package/vendor/skills/skills/ratatui-tui/assets/templates/component-app/Cargo.toml +24 -0
  982. package/vendor/skills/skills/ratatui-tui/assets/templates/component-app/src/action.rs +16 -0
  983. package/vendor/skills/skills/ratatui-tui/assets/templates/component-app/src/app.rs +97 -0
  984. package/vendor/skills/skills/ratatui-tui/assets/templates/component-app/src/config.rs +67 -0
  985. package/vendor/skills/skills/ratatui-tui/assets/templates/component-app/src/event.rs +44 -0
  986. package/vendor/skills/skills/ratatui-tui/assets/templates/component-app/src/logging.rs +34 -0
  987. package/vendor/skills/skills/ratatui-tui/assets/templates/component-app/src/main.rs +51 -0
  988. package/vendor/skills/skills/ratatui-tui/assets/templates/component-app/src/tui.rs +59 -0
  989. package/vendor/skills/skills/ratatui-tui/assets/templates/component-app/src/ui.rs +65 -0
  990. package/vendor/skills/skills/ratatui-tui/assets/templates/hello-world/Cargo.lock +1511 -0
  991. package/vendor/skills/skills/ratatui-tui/assets/templates/hello-world/Cargo.toml +8 -0
  992. package/vendor/skills/skills/ratatui-tui/assets/templates/hello-world/src/main.rs +23 -0
  993. package/vendor/skills/skills/ratatui-tui/assets/templates/simple-app/Cargo.lock +1692 -0
  994. package/vendor/skills/skills/ratatui-tui/assets/templates/simple-app/Cargo.toml +9 -0
  995. package/vendor/skills/skills/ratatui-tui/assets/templates/simple-app/src/main.rs +100 -0
  996. package/vendor/skills/skills/ratatui-tui/references/architecture-patterns.md +448 -0
  997. package/vendor/skills/skills/ratatui-tui/references/async-patterns.md +426 -0
  998. package/vendor/skills/skills/ratatui-tui/references/image-integration.md +395 -0
  999. package/vendor/skills/skills/ratatui-tui/references/style-guide.md +249 -0
  1000. package/vendor/skills/skills/react/SKILL.md +195 -0
  1001. package/vendor/skills/skills/react/references/best-practices.md +1093 -0
  1002. package/vendor/skills/skills/react/references/useeffect-patterns.md +620 -0
  1003. package/vendor/skills/skills/receiving-code-review/SKILL.md +226 -0
  1004. package/vendor/skills/skills/remotion-best-practices/SKILL.md +61 -0
  1005. package/vendor/skills/skills/remotion-best-practices/rules/3d.md +86 -0
  1006. package/vendor/skills/skills/remotion-best-practices/rules/animations.md +27 -0
  1007. package/vendor/skills/skills/remotion-best-practices/rules/assets/charts-bar-chart.tsx +165 -0
  1008. package/vendor/skills/skills/remotion-best-practices/rules/assets/text-animations-typewriter.tsx +89 -0
  1009. package/vendor/skills/skills/remotion-best-practices/rules/assets/text-animations-word-highlight.tsx +101 -0
  1010. package/vendor/skills/skills/remotion-best-practices/rules/assets.md +78 -0
  1011. package/vendor/skills/skills/remotion-best-practices/rules/audio-visualization.md +195 -0
  1012. package/vendor/skills/skills/remotion-best-practices/rules/audio.md +167 -0
  1013. package/vendor/skills/skills/remotion-best-practices/rules/calculate-metadata.md +118 -0
  1014. package/vendor/skills/skills/remotion-best-practices/rules/can-decode.md +75 -0
  1015. package/vendor/skills/skills/remotion-best-practices/rules/charts.md +116 -0
  1016. package/vendor/skills/skills/remotion-best-practices/rules/compositions.md +153 -0
  1017. package/vendor/skills/skills/remotion-best-practices/rules/display-captions.md +176 -0
  1018. package/vendor/skills/skills/remotion-best-practices/rules/extract-frames.md +217 -0
  1019. package/vendor/skills/skills/remotion-best-practices/rules/ffmpeg.md +34 -0
  1020. package/vendor/skills/skills/remotion-best-practices/rules/fonts.md +152 -0
  1021. package/vendor/skills/skills/remotion-best-practices/rules/get-audio-duration.md +58 -0
  1022. package/vendor/skills/skills/remotion-best-practices/rules/get-video-dimensions.md +68 -0
  1023. package/vendor/skills/skills/remotion-best-practices/rules/get-video-duration.md +60 -0
  1024. package/vendor/skills/skills/remotion-best-practices/rules/gifs.md +135 -0
  1025. package/vendor/skills/skills/remotion-best-practices/rules/images.md +130 -0
  1026. package/vendor/skills/skills/remotion-best-practices/rules/import-srt-captions.md +69 -0
  1027. package/vendor/skills/skills/remotion-best-practices/rules/light-leaks.md +73 -0
  1028. package/vendor/skills/skills/remotion-best-practices/rules/lottie.md +67 -0
  1029. package/vendor/skills/skills/remotion-best-practices/rules/maps.md +405 -0
  1030. package/vendor/skills/skills/remotion-best-practices/rules/measuring-dom-nodes.md +34 -0
  1031. package/vendor/skills/skills/remotion-best-practices/rules/measuring-text.md +140 -0
  1032. package/vendor/skills/skills/remotion-best-practices/rules/parameters.md +109 -0
  1033. package/vendor/skills/skills/remotion-best-practices/rules/sequencing.md +118 -0
  1034. package/vendor/skills/skills/remotion-best-practices/rules/sfx.md +26 -0
  1035. package/vendor/skills/skills/remotion-best-practices/rules/subtitles.md +36 -0
  1036. package/vendor/skills/skills/remotion-best-practices/rules/tailwind.md +11 -0
  1037. package/vendor/skills/skills/remotion-best-practices/rules/text-animations.md +20 -0
  1038. package/vendor/skills/skills/remotion-best-practices/rules/timing.md +179 -0
  1039. package/vendor/skills/skills/remotion-best-practices/rules/transcribe-captions.md +70 -0
  1040. package/vendor/skills/skills/remotion-best-practices/rules/transitions.md +193 -0
  1041. package/vendor/skills/skills/remotion-best-practices/rules/transparent-videos.md +102 -0
  1042. package/vendor/skills/skills/remotion-best-practices/rules/trimming.md +51 -0
  1043. package/vendor/skills/skills/remotion-best-practices/rules/videos.md +169 -0
  1044. package/vendor/skills/skills/remotion-best-practices/rules/voiceover.md +94 -0
  1045. package/vendor/skills/skills/requirements-clarity/README.md +275 -0
  1046. package/vendor/skills/skills/requirements-clarity/SKILL.md +358 -0
  1047. package/vendor/skills/skills/rivetkit/SKILL.md +1058 -0
  1048. package/vendor/skills/skills/rivetkit/index.json +540 -0
  1049. package/vendor/skills/skills/rivetkit/openapi.json +1223 -0
  1050. package/vendor/skills/skills/rivetkit/reference/actors/access-control.md +133 -0
  1051. package/vendor/skills/skills/rivetkit/reference/actors/actions.md +386 -0
  1052. package/vendor/skills/skills/rivetkit/reference/actors/ai-and-user-generated-actors.md +309 -0
  1053. package/vendor/skills/skills/rivetkit/reference/actors/appearance.md +186 -0
  1054. package/vendor/skills/skills/rivetkit/reference/actors/authentication.md +598 -0
  1055. package/vendor/skills/skills/rivetkit/reference/actors/communicating-between-actors.md +335 -0
  1056. package/vendor/skills/skills/rivetkit/reference/actors/connections.md +444 -0
  1057. package/vendor/skills/skills/rivetkit/reference/actors/debugging.md +378 -0
  1058. package/vendor/skills/skills/rivetkit/reference/actors/design-patterns.md +630 -0
  1059. package/vendor/skills/skills/rivetkit/reference/actors/destroy.md +116 -0
  1060. package/vendor/skills/skills/rivetkit/reference/actors/ephemeral-variables.md +178 -0
  1061. package/vendor/skills/skills/rivetkit/reference/actors/errors.md +442 -0
  1062. package/vendor/skills/skills/rivetkit/reference/actors/events.md +393 -0
  1063. package/vendor/skills/skills/rivetkit/reference/actors/fetch-and-websocket-handler.md +9 -0
  1064. package/vendor/skills/skills/rivetkit/reference/actors/helper-types.md +9 -0
  1065. package/vendor/skills/skills/rivetkit/reference/actors/http-api.md +11 -0
  1066. package/vendor/skills/skills/rivetkit/reference/actors/input.md +308 -0
  1067. package/vendor/skills/skills/rivetkit/reference/actors/keys.md +269 -0
  1068. package/vendor/skills/skills/rivetkit/reference/actors/kv.md +126 -0
  1069. package/vendor/skills/skills/rivetkit/reference/actors/lifecycle.md +1052 -0
  1070. package/vendor/skills/skills/rivetkit/reference/actors/limits.md +143 -0
  1071. package/vendor/skills/skills/rivetkit/reference/actors/metadata.md +149 -0
  1072. package/vendor/skills/skills/rivetkit/reference/actors/postgres.md +262 -0
  1073. package/vendor/skills/skills/rivetkit/reference/actors/queues.md +414 -0
  1074. package/vendor/skills/skills/rivetkit/reference/actors/quickstart/backend.md +164 -0
  1075. package/vendor/skills/skills/rivetkit/reference/actors/quickstart/cloudflare-workers.md +412 -0
  1076. package/vendor/skills/skills/rivetkit/reference/actors/quickstart/next-js.md +122 -0
  1077. package/vendor/skills/skills/rivetkit/reference/actors/quickstart/react.md +144 -0
  1078. package/vendor/skills/skills/rivetkit/reference/actors/request-handler.md +241 -0
  1079. package/vendor/skills/skills/rivetkit/reference/actors/scaling.md +9 -0
  1080. package/vendor/skills/skills/rivetkit/reference/actors/schedule.md +102 -0
  1081. package/vendor/skills/skills/rivetkit/reference/actors/sharing-and-joining-state.md +9 -0
  1082. package/vendor/skills/skills/rivetkit/reference/actors/sqlite-drizzle.md +245 -0
  1083. package/vendor/skills/skills/rivetkit/reference/actors/sqlite.md +237 -0
  1084. package/vendor/skills/skills/rivetkit/reference/actors/state.md +204 -0
  1085. package/vendor/skills/skills/rivetkit/reference/actors/testing.md +237 -0
  1086. package/vendor/skills/skills/rivetkit/reference/actors/types.md +106 -0
  1087. package/vendor/skills/skills/rivetkit/reference/actors/versions.md +109 -0
  1088. package/vendor/skills/skills/rivetkit/reference/actors/websocket-handler.md +320 -0
  1089. package/vendor/skills/skills/rivetkit/reference/actors/workflows.md +1958 -0
  1090. package/vendor/skills/skills/rivetkit/reference/clients/javascript.md +236 -0
  1091. package/vendor/skills/skills/rivetkit/reference/clients/react.md +270 -0
  1092. package/vendor/skills/skills/rivetkit/reference/clients/swift.md +459 -0
  1093. package/vendor/skills/skills/rivetkit/reference/clients/swiftui.md +364 -0
  1094. package/vendor/skills/skills/rivetkit/reference/connect/aws-ecs.md +14 -0
  1095. package/vendor/skills/skills/rivetkit/reference/connect/aws-lambda.md +9 -0
  1096. package/vendor/skills/skills/rivetkit/reference/connect/cloudflare-workers.md +125 -0
  1097. package/vendor/skills/skills/rivetkit/reference/connect/freestyle.md +132 -0
  1098. package/vendor/skills/skills/rivetkit/reference/connect/gcp-cloud-run.md +75 -0
  1099. package/vendor/skills/skills/rivetkit/reference/connect/hetzner.md +9 -0
  1100. package/vendor/skills/skills/rivetkit/reference/connect/kubernetes.md +109 -0
  1101. package/vendor/skills/skills/rivetkit/reference/connect/railway.md +44 -0
  1102. package/vendor/skills/skills/rivetkit/reference/connect/supabase.md +9 -0
  1103. package/vendor/skills/skills/rivetkit/reference/connect/vercel.md +158 -0
  1104. package/vendor/skills/skills/rivetkit/reference/connect/vm-and-bare-metal.md +89 -0
  1105. package/vendor/skills/skills/rivetkit/reference/cookbook/multiplayer-game.md +714 -0
  1106. package/vendor/skills/skills/rivetkit/reference/general/actor-configuration.md +42 -0
  1107. package/vendor/skills/skills/rivetkit/reference/general/architecture.md +452 -0
  1108. package/vendor/skills/skills/rivetkit/reference/general/cors.md +71 -0
  1109. package/vendor/skills/skills/rivetkit/reference/general/docs-for-llms.md +56 -0
  1110. package/vendor/skills/skills/rivetkit/reference/general/edge.md +40 -0
  1111. package/vendor/skills/skills/rivetkit/reference/general/endpoints.md +129 -0
  1112. package/vendor/skills/skills/rivetkit/reference/general/environment-variables.md +73 -0
  1113. package/vendor/skills/skills/rivetkit/reference/general/http-server.md +144 -0
  1114. package/vendor/skills/skills/rivetkit/reference/general/logging.md +153 -0
  1115. package/vendor/skills/skills/rivetkit/reference/general/registry-configuration.md +98 -0
  1116. package/vendor/skills/skills/rivetkit/reference/general/runtime-modes.md +156 -0
  1117. package/vendor/skills/skills/rivetkit/reference/self-hosting/configuration.md +53 -0
  1118. package/vendor/skills/skills/rivetkit/reference/self-hosting/docker-compose.md +148 -0
  1119. package/vendor/skills/skills/rivetkit/reference/self-hosting/docker-container.md +93 -0
  1120. package/vendor/skills/skills/rivetkit/reference/self-hosting/filesystem.md +48 -0
  1121. package/vendor/skills/skills/rivetkit/reference/self-hosting/install.md +33 -0
  1122. package/vendor/skills/skills/rivetkit/reference/self-hosting/kubernetes.md +496 -0
  1123. package/vendor/skills/skills/rivetkit/reference/self-hosting/multi-region.md +11 -0
  1124. package/vendor/skills/skills/rivetkit/reference/self-hosting/postgres.md +193 -0
  1125. package/vendor/skills/skills/rivetkit/reference/self-hosting/railway.md +71 -0
  1126. package/vendor/skills/skills/rivetkit-client-javascript/SKILL.md +259 -0
  1127. package/vendor/skills/skills/rivetkit-client-javascript/index.json +7 -0
  1128. package/vendor/skills/skills/rivetkit-client-react/SKILL.md +293 -0
  1129. package/vendor/skills/skills/rivetkit-client-react/index.json +7 -0
  1130. package/vendor/skills/skills/rust-async-patterns/SKILL.md +519 -0
  1131. package/vendor/skills/skills/rust-best-practices/SKILL.md +104 -0
  1132. package/vendor/skills/skills/rust-best-practices/references/chapter_01.md +591 -0
  1133. package/vendor/skills/skills/rust-best-practices/references/chapter_02.md +119 -0
  1134. package/vendor/skills/skills/rust-best-practices/references/chapter_03.md +226 -0
  1135. package/vendor/skills/skills/rust-best-practices/references/chapter_04.md +187 -0
  1136. package/vendor/skills/skills/rust-best-practices/references/chapter_05.md +406 -0
  1137. package/vendor/skills/skills/rust-best-practices/references/chapter_06.md +168 -0
  1138. package/vendor/skills/skills/rust-best-practices/references/chapter_07.md +231 -0
  1139. package/vendor/skills/skills/rust-best-practices/references/chapter_08.md +276 -0
  1140. package/vendor/skills/skills/rust-best-practices/references/chapter_09.md +259 -0
  1141. package/vendor/skills/skills/rust-coding-guidelines/SKILL.md +95 -0
  1142. package/vendor/skills/skills/rust-coding-guidelines/index/rules-index.md +7 -0
  1143. package/vendor/skills/skills/rust-engineer/SKILL.md +89 -0
  1144. package/vendor/skills/skills/rust-engineer/references/async.md +458 -0
  1145. package/vendor/skills/skills/rust-engineer/references/error-handling.md +334 -0
  1146. package/vendor/skills/skills/rust-engineer/references/ownership.md +278 -0
  1147. package/vendor/skills/skills/rust-engineer/references/testing.md +470 -0
  1148. package/vendor/skills/skills/rust-engineer/references/traits.md +413 -0
  1149. package/vendor/skills/skills/sales-methodology-implementer/SKILL.md +735 -0
  1150. package/vendor/skills/skills/sentry-cli/SKILL.md +459 -0
  1151. package/vendor/skills/skills/shadcn/SKILL.md +141 -0
  1152. package/vendor/skills/skills/shadcn/references/patterns.md +587 -0
  1153. package/vendor/skills/skills/shadcn-ui/SKILL.md +1911 -0
  1154. package/vendor/skills/skills/shadcn-ui/references/chart.md +303 -0
  1155. package/vendor/skills/skills/shadcn-ui/references/learn.md +150 -0
  1156. package/vendor/skills/skills/shadcn-ui/references/official-ui-reference.md +1721 -0
  1157. package/vendor/skills/skills/shadcn-ui/references/reference.md +608 -0
  1158. package/vendor/skills/skills/shadcn-ui/references/ui-reference.md +1588 -0
  1159. package/vendor/skills/skills/ship-learn-next/README.md +191 -0
  1160. package/vendor/skills/skills/ship-learn-next/SKILL.md +359 -0
  1161. package/vendor/skills/skills/skill-writter/SKILL.md +408 -0
  1162. package/vendor/skills/skills/skills-best-practices/SKILL.md +51 -0
  1163. package/vendor/skills/skills/skills-best-practices/assets/SKILL.template.md +24 -0
  1164. package/vendor/skills/skills/skills-best-practices/references/checklist.md +37 -0
  1165. package/vendor/skills/skills/skills-best-practices/scripts/validate-metadata.py +46 -0
  1166. package/vendor/skills/skills/sourcebot/SKILL.md +89 -0
  1167. package/vendor/skills/skills/startup-validator/SKILL.md +425 -0
  1168. package/vendor/skills/skills/startup-validator/index.js +9 -0
  1169. package/vendor/skills/skills/startup-validator/package.json +11 -0
  1170. package/vendor/skills/skills/startup-validator/references/frameworks.md +134 -0
  1171. package/vendor/skills/skills/startup-validator/references/research_templates.md +191 -0
  1172. package/vendor/skills/skills/startup-validator/scripts/market_analyzer.py +290 -0
  1173. package/vendor/skills/skills/storybook/SKILL.md +440 -0
  1174. package/vendor/skills/skills/storybook-stories/SKILL.md +359 -0
  1175. package/vendor/skills/skills/storybook-stories/references/patterns.md +60 -0
  1176. package/vendor/skills/skills/stripe-best-practices/SKILL.md +30 -0
  1177. package/vendor/skills/skills/stripe-integration/SKILL.md +492 -0
  1178. package/vendor/skills/skills/stripe-subscriptions/SKILL.md +54 -0
  1179. package/vendor/skills/skills/stripe-webhooks/SKILL.md +163 -0
  1180. package/vendor/skills/skills/stripe-webhooks/examples/express/.env.example +5 -0
  1181. package/vendor/skills/skills/stripe-webhooks/examples/express/README.md +64 -0
  1182. package/vendor/skills/skills/stripe-webhooks/examples/express/package.json +19 -0
  1183. package/vendor/skills/skills/stripe-webhooks/examples/express/src/index.js +75 -0
  1184. package/vendor/skills/skills/stripe-webhooks/examples/express/test/webhook.test.js +129 -0
  1185. package/vendor/skills/skills/stripe-webhooks/examples/fastapi/.env.example +5 -0
  1186. package/vendor/skills/skills/stripe-webhooks/examples/fastapi/README.md +69 -0
  1187. package/vendor/skills/skills/stripe-webhooks/examples/fastapi/main.py +75 -0
  1188. package/vendor/skills/skills/stripe-webhooks/examples/fastapi/requirements.txt +6 -0
  1189. package/vendor/skills/skills/stripe-webhooks/examples/fastapi/test_webhook.py +121 -0
  1190. package/vendor/skills/skills/stripe-webhooks/examples/nextjs/.env.example +5 -0
  1191. package/vendor/skills/skills/stripe-webhooks/examples/nextjs/README.md +62 -0
  1192. package/vendor/skills/skills/stripe-webhooks/examples/nextjs/app/webhooks/stripe/route.ts +63 -0
  1193. package/vendor/skills/skills/stripe-webhooks/examples/nextjs/package.json +23 -0
  1194. package/vendor/skills/skills/stripe-webhooks/examples/nextjs/test/webhook.test.ts +139 -0
  1195. package/vendor/skills/skills/stripe-webhooks/examples/nextjs/vitest.config.ts +8 -0
  1196. package/vendor/skills/skills/stripe-webhooks/references/overview.md +62 -0
  1197. package/vendor/skills/skills/stripe-webhooks/references/setup.md +99 -0
  1198. package/vendor/skills/skills/stripe-webhooks/references/verification.md +154 -0
  1199. package/vendor/skills/skills/sync-provider/SKILL.md +348 -0
  1200. package/vendor/skills/skills/systematic-debugging/CREATION-LOG.md +133 -0
  1201. package/vendor/skills/skills/systematic-debugging/SKILL.md +305 -0
  1202. package/vendor/skills/skills/systematic-debugging/condition-based-waiting-example.ts +158 -0
  1203. package/vendor/skills/skills/systematic-debugging/condition-based-waiting.md +120 -0
  1204. package/vendor/skills/skills/systematic-debugging/defense-in-depth.md +128 -0
  1205. package/vendor/skills/skills/systematic-debugging/find-polluter.sh +63 -0
  1206. package/vendor/skills/skills/systematic-debugging/root-cause-tracing.md +183 -0
  1207. package/vendor/skills/skills/systematic-debugging/test-academic.md +14 -0
  1208. package/vendor/skills/skills/systematic-debugging/test-pressure-1.md +65 -0
  1209. package/vendor/skills/skills/systematic-debugging/test-pressure-2.md +75 -0
  1210. package/vendor/skills/skills/systematic-debugging/test-pressure-3.md +75 -0
  1211. package/vendor/skills/skills/tailwindcss/SKILL.md +122 -0
  1212. package/vendor/skills/skills/tailwindcss/references/patterns.md +439 -0
  1213. package/vendor/skills/skills/tanstack/SKILL.md +278 -0
  1214. package/vendor/skills/skills/tanstack/references/form-patterns.md +638 -0
  1215. package/vendor/skills/skills/tanstack/references/query-patterns.md +343 -0
  1216. package/vendor/skills/skills/tanstack/references/router-patterns.md +373 -0
  1217. package/vendor/skills/skills/tanstack-query-best-practices/SKILL.md +115 -0
  1218. package/vendor/skills/skills/tanstack-query-best-practices/rules/cache-gc-time.md +93 -0
  1219. package/vendor/skills/skills/tanstack-query-best-practices/rules/cache-invalidation.md +114 -0
  1220. package/vendor/skills/skills/tanstack-query-best-practices/rules/cache-placeholder-vs-initial.md +152 -0
  1221. package/vendor/skills/skills/tanstack-query-best-practices/rules/cache-stale-time.md +80 -0
  1222. package/vendor/skills/skills/tanstack-query-best-practices/rules/err-error-boundaries.md +147 -0
  1223. package/vendor/skills/skills/tanstack-query-best-practices/rules/inf-page-params.md +119 -0
  1224. package/vendor/skills/skills/tanstack-query-best-practices/rules/mut-invalidate-queries.md +118 -0
  1225. package/vendor/skills/skills/tanstack-query-best-practices/rules/mut-mutation-state.md +164 -0
  1226. package/vendor/skills/skills/tanstack-query-best-practices/rules/mut-optimistic-updates.md +131 -0
  1227. package/vendor/skills/skills/tanstack-query-best-practices/rules/network-mode.md +168 -0
  1228. package/vendor/skills/skills/tanstack-query-best-practices/rules/parallel-use-queries.md +154 -0
  1229. package/vendor/skills/skills/tanstack-query-best-practices/rules/perf-select-transform.md +144 -0
  1230. package/vendor/skills/skills/tanstack-query-best-practices/rules/persist-queries.md +192 -0
  1231. package/vendor/skills/skills/tanstack-query-best-practices/rules/pf-intent-prefetch.md +137 -0
  1232. package/vendor/skills/skills/tanstack-query-best-practices/rules/qk-array-structure.md +50 -0
  1233. package/vendor/skills/skills/tanstack-query-best-practices/rules/qk-factory-pattern.md +104 -0
  1234. package/vendor/skills/skills/tanstack-query-best-practices/rules/qk-hierarchical-organization.md +76 -0
  1235. package/vendor/skills/skills/tanstack-query-best-practices/rules/qk-include-dependencies.md +62 -0
  1236. package/vendor/skills/skills/tanstack-query-best-practices/rules/qk-serializable.md +97 -0
  1237. package/vendor/skills/skills/tanstack-query-best-practices/rules/query-cancellation.md +168 -0
  1238. package/vendor/skills/skills/tanstack-query-best-practices/rules/ssr-dehydration.md +154 -0
  1239. package/vendor/skills/skills/tanstack-router-best-practices/SKILL.md +114 -0
  1240. package/vendor/skills/skills/tanstack-router-best-practices/rules/ctx-root-context.md +170 -0
  1241. package/vendor/skills/skills/tanstack-router-best-practices/rules/err-not-found.md +194 -0
  1242. package/vendor/skills/skills/tanstack-router-best-practices/rules/load-ensure-query-data.md +147 -0
  1243. package/vendor/skills/skills/tanstack-router-best-practices/rules/load-parallel.md +186 -0
  1244. package/vendor/skills/skills/tanstack-router-best-practices/rules/load-use-loaders.md +148 -0
  1245. package/vendor/skills/skills/tanstack-router-best-practices/rules/nav-link-component.md +171 -0
  1246. package/vendor/skills/skills/tanstack-router-best-practices/rules/nav-route-masks.md +195 -0
  1247. package/vendor/skills/skills/tanstack-router-best-practices/rules/org-virtual-routes.md +133 -0
  1248. package/vendor/skills/skills/tanstack-router-best-practices/rules/preload-intent.md +133 -0
  1249. package/vendor/skills/skills/tanstack-router-best-practices/rules/router-default-options.md +159 -0
  1250. package/vendor/skills/skills/tanstack-router-best-practices/rules/search-custom-serializer.md +198 -0
  1251. package/vendor/skills/skills/tanstack-router-best-practices/rules/search-validation.md +154 -0
  1252. package/vendor/skills/skills/tanstack-router-best-practices/rules/split-lazy-routes.md +148 -0
  1253. package/vendor/skills/skills/tanstack-router-best-practices/rules/ts-register-router.md +113 -0
  1254. package/vendor/skills/skills/tanstack-router-best-practices/rules/ts-use-from-param.md +130 -0
  1255. package/vendor/skills/skills/tanstack-start-best-practices/SKILL.md +110 -0
  1256. package/vendor/skills/skills/tanstack-start-best-practices/rules/api-routes.md +236 -0
  1257. package/vendor/skills/skills/tanstack-start-best-practices/rules/auth-route-protection.md +188 -0
  1258. package/vendor/skills/skills/tanstack-start-best-practices/rules/auth-session-management.md +189 -0
  1259. package/vendor/skills/skills/tanstack-start-best-practices/rules/deploy-adapters.md +197 -0
  1260. package/vendor/skills/skills/tanstack-start-best-practices/rules/env-functions.md +207 -0
  1261. package/vendor/skills/skills/tanstack-start-best-practices/rules/err-server-errors.md +189 -0
  1262. package/vendor/skills/skills/tanstack-start-best-practices/rules/file-separation.md +151 -0
  1263. package/vendor/skills/skills/tanstack-start-best-practices/rules/mw-request-middleware.md +157 -0
  1264. package/vendor/skills/skills/tanstack-start-best-practices/rules/sf-create-server-fn.md +146 -0
  1265. package/vendor/skills/skills/tanstack-start-best-practices/rules/sf-input-validation.md +168 -0
  1266. package/vendor/skills/skills/tanstack-start-best-practices/rules/ssr-hydration-safety.md +184 -0
  1267. package/vendor/skills/skills/tanstack-start-best-practices/rules/ssr-prerender.md +190 -0
  1268. package/vendor/skills/skills/tanstack-start-best-practices/rules/ssr-streaming.md +201 -0
  1269. package/vendor/skills/skills/tauri-v2/README.md +157 -0
  1270. package/vendor/skills/skills/tauri-v2/SKILL.md +378 -0
  1271. package/vendor/skills/skills/tauri-v2/assets/README.md +18 -0
  1272. package/vendor/skills/skills/tauri-v2/references/README.md +10 -0
  1273. package/vendor/skills/skills/tauri-v2/references/capabilities-reference.md +310 -0
  1274. package/vendor/skills/skills/tauri-v2/references/ipc-patterns.md +484 -0
  1275. package/vendor/skills/skills/tauri-v2/scripts/README.md +31 -0
  1276. package/vendor/skills/skills/tech-logos/SKILL.md +88 -0
  1277. package/vendor/skills/skills/terraform-style-guide/SKILL.md +357 -0
  1278. package/vendor/skills/skills/test-antipatterns/SKILL.md +309 -0
  1279. package/vendor/skills/skills/to-prompt/SKILL.md +90 -0
  1280. package/vendor/skills/skills/typescript-advanced/SKILL.md +760 -0
  1281. package/vendor/skills/skills/typescript-advanced/references/best-practices.md +358 -0
  1282. package/vendor/skills/skills/ui-ux-pro-max/SKILL.md +404 -0
  1283. package/vendor/skills/skills/ui-ux-pro-max/data/charts.csv +26 -0
  1284. package/vendor/skills/skills/ui-ux-pro-max/data/colors.csv +97 -0
  1285. package/vendor/skills/skills/ui-ux-pro-max/data/icons.csv +101 -0
  1286. package/vendor/skills/skills/ui-ux-pro-max/data/landing.csv +31 -0
  1287. package/vendor/skills/skills/ui-ux-pro-max/data/products.csv +97 -0
  1288. package/vendor/skills/skills/ui-ux-pro-max/data/react-performance.csv +45 -0
  1289. package/vendor/skills/skills/ui-ux-pro-max/data/stacks/astro.csv +54 -0
  1290. package/vendor/skills/skills/ui-ux-pro-max/data/stacks/flutter.csv +53 -0
  1291. package/vendor/skills/skills/ui-ux-pro-max/data/stacks/html-tailwind.csv +56 -0
  1292. package/vendor/skills/skills/ui-ux-pro-max/data/stacks/jetpack-compose.csv +53 -0
  1293. package/vendor/skills/skills/ui-ux-pro-max/data/stacks/nextjs.csv +53 -0
  1294. package/vendor/skills/skills/ui-ux-pro-max/data/stacks/nuxt-ui.csv +51 -0
  1295. package/vendor/skills/skills/ui-ux-pro-max/data/stacks/nuxtjs.csv +59 -0
  1296. package/vendor/skills/skills/ui-ux-pro-max/data/stacks/react-native.csv +52 -0
  1297. package/vendor/skills/skills/ui-ux-pro-max/data/stacks/react.csv +54 -0
  1298. package/vendor/skills/skills/ui-ux-pro-max/data/stacks/shadcn.csv +61 -0
  1299. package/vendor/skills/skills/ui-ux-pro-max/data/stacks/svelte.csv +54 -0
  1300. package/vendor/skills/skills/ui-ux-pro-max/data/stacks/swiftui.csv +51 -0
  1301. package/vendor/skills/skills/ui-ux-pro-max/data/stacks/vue.csv +50 -0
  1302. package/vendor/skills/skills/ui-ux-pro-max/data/styles.csv +68 -0
  1303. package/vendor/skills/skills/ui-ux-pro-max/data/typography.csv +58 -0
  1304. package/vendor/skills/skills/ui-ux-pro-max/data/ui-reasoning.csv +101 -0
  1305. package/vendor/skills/skills/ui-ux-pro-max/data/ux-guidelines.csv +100 -0
  1306. package/vendor/skills/skills/ui-ux-pro-max/data/web-interface.csv +31 -0
  1307. package/vendor/skills/skills/ui-ux-pro-max/scripts/core.py +253 -0
  1308. package/vendor/skills/skills/ui-ux-pro-max/scripts/design_system.py +1067 -0
  1309. package/vendor/skills/skills/ui-ux-pro-max/scripts/search.py +114 -0
  1310. package/vendor/skills/skills/vercel-composition-patterns/AGENTS.md +917 -0
  1311. package/vendor/skills/skills/vercel-composition-patterns/SKILL.md +88 -0
  1312. package/vendor/skills/skills/vercel-composition-patterns/rules/architecture-avoid-boolean-props.md +94 -0
  1313. package/vendor/skills/skills/vercel-composition-patterns/rules/architecture-compound-components.md +108 -0
  1314. package/vendor/skills/skills/vercel-composition-patterns/rules/patterns-children-over-render-props.md +84 -0
  1315. package/vendor/skills/skills/vercel-composition-patterns/rules/patterns-explicit-variants.md +94 -0
  1316. package/vendor/skills/skills/vercel-composition-patterns/rules/react19-no-forwardref.md +42 -0
  1317. package/vendor/skills/skills/vercel-composition-patterns/rules/state-context-interface.md +191 -0
  1318. package/vendor/skills/skills/vercel-composition-patterns/rules/state-decouple-implementation.md +103 -0
  1319. package/vendor/skills/skills/vercel-composition-patterns/rules/state-lift-state.md +125 -0
  1320. package/vendor/skills/skills/vercel-react-best-practices/AGENTS.md +2367 -0
  1321. package/vendor/skills/skills/vercel-react-best-practices/SKILL.md +127 -0
  1322. package/vendor/skills/skills/vercel-react-best-practices/rules/advanced-event-handler-refs.md +55 -0
  1323. package/vendor/skills/skills/vercel-react-best-practices/rules/advanced-use-latest.md +49 -0
  1324. package/vendor/skills/skills/vercel-react-best-practices/rules/async-api-routes.md +35 -0
  1325. package/vendor/skills/skills/vercel-react-best-practices/rules/async-defer-await.md +80 -0
  1326. package/vendor/skills/skills/vercel-react-best-practices/rules/async-dependencies.md +37 -0
  1327. package/vendor/skills/skills/vercel-react-best-practices/rules/async-parallel.md +24 -0
  1328. package/vendor/skills/skills/vercel-react-best-practices/rules/async-suspense-boundaries.md +99 -0
  1329. package/vendor/skills/skills/vercel-react-best-practices/rules/bundle-barrel-imports.md +59 -0
  1330. package/vendor/skills/skills/vercel-react-best-practices/rules/bundle-conditional.md +37 -0
  1331. package/vendor/skills/skills/vercel-react-best-practices/rules/bundle-defer-third-party.md +48 -0
  1332. package/vendor/skills/skills/vercel-react-best-practices/rules/bundle-dynamic-imports.md +34 -0
  1333. package/vendor/skills/skills/vercel-react-best-practices/rules/bundle-preload.md +44 -0
  1334. package/vendor/skills/skills/vercel-react-best-practices/rules/client-event-listeners.md +78 -0
  1335. package/vendor/skills/skills/vercel-react-best-practices/rules/client-localstorage-schema.md +74 -0
  1336. package/vendor/skills/skills/vercel-react-best-practices/rules/client-passive-event-listeners.md +48 -0
  1337. package/vendor/skills/skills/vercel-react-best-practices/rules/client-swr-dedup.md +56 -0
  1338. package/vendor/skills/skills/vercel-react-best-practices/rules/js-batch-dom-css.md +57 -0
  1339. package/vendor/skills/skills/vercel-react-best-practices/rules/js-cache-function-results.md +80 -0
  1340. package/vendor/skills/skills/vercel-react-best-practices/rules/js-cache-property-access.md +28 -0
  1341. package/vendor/skills/skills/vercel-react-best-practices/rules/js-cache-storage.md +68 -0
  1342. package/vendor/skills/skills/vercel-react-best-practices/rules/js-combine-iterations.md +32 -0
  1343. package/vendor/skills/skills/vercel-react-best-practices/rules/js-early-exit.md +50 -0
  1344. package/vendor/skills/skills/vercel-react-best-practices/rules/js-hoist-regexp.md +45 -0
  1345. package/vendor/skills/skills/vercel-react-best-practices/rules/js-index-maps.md +37 -0
  1346. package/vendor/skills/skills/vercel-react-best-practices/rules/js-length-check-first.md +50 -0
  1347. package/vendor/skills/skills/vercel-react-best-practices/rules/js-min-max-loop.md +82 -0
  1348. package/vendor/skills/skills/vercel-react-best-practices/rules/js-set-map-lookups.md +24 -0
  1349. package/vendor/skills/skills/vercel-react-best-practices/rules/js-tosorted-immutable.md +57 -0
  1350. package/vendor/skills/skills/vercel-react-best-practices/rules/rendering-activity.md +26 -0
  1351. package/vendor/skills/skills/vercel-react-best-practices/rules/rendering-animate-svg-wrapper.md +38 -0
  1352. package/vendor/skills/skills/vercel-react-best-practices/rules/rendering-conditional-render.md +32 -0
  1353. package/vendor/skills/skills/vercel-react-best-practices/rules/rendering-content-visibility.md +38 -0
  1354. package/vendor/skills/skills/vercel-react-best-practices/rules/rendering-hoist-jsx.md +36 -0
  1355. package/vendor/skills/skills/vercel-react-best-practices/rules/rendering-hydration-no-flicker.md +72 -0
  1356. package/vendor/skills/skills/vercel-react-best-practices/rules/rendering-svg-precision.md +28 -0
  1357. package/vendor/skills/skills/vercel-react-best-practices/rules/rerender-defer-reads.md +39 -0
  1358. package/vendor/skills/skills/vercel-react-best-practices/rules/rerender-dependencies.md +45 -0
  1359. package/vendor/skills/skills/vercel-react-best-practices/rules/rerender-derived-state.md +29 -0
  1360. package/vendor/skills/skills/vercel-react-best-practices/rules/rerender-functional-setstate.md +77 -0
  1361. package/vendor/skills/skills/vercel-react-best-practices/rules/rerender-lazy-state-init.md +56 -0
  1362. package/vendor/skills/skills/vercel-react-best-practices/rules/rerender-memo.md +44 -0
  1363. package/vendor/skills/skills/vercel-react-best-practices/rules/rerender-transitions.md +40 -0
  1364. package/vendor/skills/skills/vercel-react-best-practices/rules/server-after-nonblocking.md +73 -0
  1365. package/vendor/skills/skills/vercel-react-best-practices/rules/server-cache-lru.md +41 -0
  1366. package/vendor/skills/skills/vercel-react-best-practices/rules/server-cache-react.md +76 -0
  1367. package/vendor/skills/skills/vercel-react-best-practices/rules/server-parallel-fetching.md +83 -0
  1368. package/vendor/skills/skills/vercel-react-best-practices/rules/server-serialization.md +38 -0
  1369. package/vendor/skills/skills/verification-before-completion/SKILL.md +147 -0
  1370. package/vendor/skills/skills/vitest/GENERATION.md +5 -0
  1371. package/vendor/skills/skills/vitest/SKILL.md +53 -0
  1372. package/vendor/skills/skills/vitest/references/advanced-environments.md +264 -0
  1373. package/vendor/skills/skills/vitest/references/advanced-projects.md +300 -0
  1374. package/vendor/skills/skills/vitest/references/advanced-type-testing.md +242 -0
  1375. package/vendor/skills/skills/vitest/references/advanced-vi.md +249 -0
  1376. package/vendor/skills/skills/vitest/references/core-cli.md +167 -0
  1377. package/vendor/skills/skills/vitest/references/core-config.md +177 -0
  1378. package/vendor/skills/skills/vitest/references/core-describe.md +193 -0
  1379. package/vendor/skills/skills/vitest/references/core-expect.md +207 -0
  1380. package/vendor/skills/skills/vitest/references/core-hooks.md +245 -0
  1381. package/vendor/skills/skills/vitest/references/core-test-api.md +237 -0
  1382. package/vendor/skills/skills/vitest/references/features-concurrency.md +250 -0
  1383. package/vendor/skills/skills/vitest/references/features-context.md +240 -0
  1384. package/vendor/skills/skills/vitest/references/features-coverage.md +202 -0
  1385. package/vendor/skills/skills/vitest/references/features-filtering.md +208 -0
  1386. package/vendor/skills/skills/vitest/references/features-mocking.md +272 -0
  1387. package/vendor/skills/skills/vitest/references/features-snapshots.md +207 -0
  1388. package/vendor/skills/skills/web-design-guidelines/SKILL.md +40 -0
  1389. package/vendor/skills/skills/workflow/SKILL.md +373 -0
  1390. package/vendor/skills/skills/wrangler/SKILL.md +871 -0
  1391. package/vendor/skills/skills/writing-clearly-and-concisely/README.md +167 -0
  1392. package/vendor/skills/skills/writing-clearly-and-concisely/SKILL.md +93 -0
  1393. package/vendor/skills/skills/writing-clearly-and-concisely/elements-of-style/01-introductory.md +3 -0
  1394. package/vendor/skills/skills/writing-clearly-and-concisely/elements-of-style/02-elementary-rules-of-usage.md +214 -0
  1395. package/vendor/skills/skills/writing-clearly-and-concisely/elements-of-style/03-elementary-principles-of-composition.md +398 -0
  1396. package/vendor/skills/skills/writing-clearly-and-concisely/elements-of-style/04-a-few-matters-of-form.md +89 -0
  1397. package/vendor/skills/skills/writing-clearly-and-concisely/elements-of-style/05-words-and-expressions-commonly-misused.md +348 -0
  1398. package/vendor/skills/skills/writing-clearly-and-concisely/signs-of-ai-writing.md +900 -0
  1399. package/vendor/skills/skills/xstate/SKILL.md +374 -0
  1400. package/vendor/skills/skills/xstate/references/machine-patterns.md +914 -0
  1401. package/vendor/skills/skills/xstate/references/query-patterns.md +661 -0
  1402. package/vendor/skills/skills/xstate/references/store-patterns.md +1032 -0
  1403. package/vendor/skills/skills/zod/AGENTS.md +97 -0
  1404. package/vendor/skills/skills/zod/README.md +79 -0
  1405. package/vendor/skills/skills/zod/SKILL.md +128 -0
  1406. package/vendor/skills/skills/zod/references/compose-intersection.md +143 -0
  1407. package/vendor/skills/skills/zod/references/compose-lazy-recursive.md +138 -0
  1408. package/vendor/skills/skills/zod/references/compose-pipe.md +114 -0
  1409. package/vendor/skills/skills/zod/references/compose-preprocess.md +131 -0
  1410. package/vendor/skills/skills/zod/references/compose-shared-schemas.md +142 -0
  1411. package/vendor/skills/skills/zod/references/error-avoid-throwing-in-refine.md +134 -0
  1412. package/vendor/skills/skills/zod/references/error-custom-messages.md +127 -0
  1413. package/vendor/skills/skills/zod/references/error-i18n.md +140 -0
  1414. package/vendor/skills/skills/zod/references/error-path-for-nested.md +135 -0
  1415. package/vendor/skills/skills/zod/references/error-use-flatten.md +135 -0
  1416. package/vendor/skills/skills/zod/references/object-discriminated-unions.md +136 -0
  1417. package/vendor/skills/skills/zod/references/object-extend-for-composition.md +146 -0
  1418. package/vendor/skills/skills/zod/references/object-optional-vs-nullable.md +120 -0
  1419. package/vendor/skills/skills/zod/references/object-partial-for-updates.md +124 -0
  1420. package/vendor/skills/skills/zod/references/object-pick-omit.md +147 -0
  1421. package/vendor/skills/skills/zod/references/object-strict-vs-strip.md +122 -0
  1422. package/vendor/skills/skills/zod/references/parse-async-for-async-refinements.md +127 -0
  1423. package/vendor/skills/skills/zod/references/parse-avoid-double-validation.md +130 -0
  1424. package/vendor/skills/skills/zod/references/parse-handle-all-issues.md +126 -0
  1425. package/vendor/skills/skills/zod/references/parse-never-trust-json.md +116 -0
  1426. package/vendor/skills/skills/zod/references/parse-use-safeparse.md +103 -0
  1427. package/vendor/skills/skills/zod/references/parse-validate-early.md +125 -0
  1428. package/vendor/skills/skills/zod/references/perf-arrays.md +154 -0
  1429. package/vendor/skills/skills/zod/references/perf-avoid-dynamic-creation.md +142 -0
  1430. package/vendor/skills/skills/zod/references/perf-cache-schemas.md +143 -0
  1431. package/vendor/skills/skills/zod/references/perf-lazy-loading.md +136 -0
  1432. package/vendor/skills/skills/zod/references/perf-zod-mini.md +118 -0
  1433. package/vendor/skills/skills/zod/references/refine-add-path.md +149 -0
  1434. package/vendor/skills/skills/zod/references/refine-catch.md +138 -0
  1435. package/vendor/skills/skills/zod/references/refine-defaults.md +132 -0
  1436. package/vendor/skills/skills/zod/references/refine-transform-coerce.md +103 -0
  1437. package/vendor/skills/skills/zod/references/refine-vs-superrefine.md +159 -0
  1438. package/vendor/skills/skills/zod/references/schema-avoid-optional-abuse.md +94 -0
  1439. package/vendor/skills/skills/zod/references/schema-coercion-for-form-data.md +89 -0
  1440. package/vendor/skills/skills/zod/references/schema-string-validations.md +87 -0
  1441. package/vendor/skills/skills/zod/references/schema-use-enums.md +106 -0
  1442. package/vendor/skills/skills/zod/references/schema-use-primitives-correctly.md +63 -0
  1443. package/vendor/skills/skills/zod/references/schema-use-unknown-not-any.md +86 -0
  1444. package/vendor/skills/skills/zod/references/type-branded-types.md +106 -0
  1445. package/vendor/skills/skills/zod/references/type-enable-strict-mode.md +132 -0
  1446. package/vendor/skills/skills/zod/references/type-export-schemas-and-types.md +117 -0
  1447. package/vendor/skills/skills/zod/references/type-input-vs-output.md +116 -0
  1448. package/vendor/skills/skills/zod/references/type-use-z-infer.md +113 -0
  1449. package/vendor/skills/skills/zustand/SKILL.md +154 -0
  1450. package/vendor/skills/skills/zustand/references/patterns.md +924 -0
@@ -0,0 +1,1958 @@
1
+ # Workflows
2
+
3
+ > Source: `src/content/docs/actors/workflows.mdx`
4
+ > Canonical URL: https://rivet.dev/docs/actors/workflows
5
+ > Description: Build durable, replayable run loops in Rivet Actors with steps, queue waits, timers, and rollback.
6
+
7
+ ---
8
+
9
+ Use workflows for durable, multi-step execution with replay safety.
10
+
11
+ ## What are workflows?
12
+
13
+ A workflow is a durable, replayable run handler for a Rivet Actor.
14
+
15
+ - Survives restarts: workflow progress is saved automatically.
16
+ - Re-runs safely: replay follows the same recorded steps.
17
+ - Event-driven: workflows can pause for queue messages, then continue.
18
+
19
+ ## Getting started
20
+
21
+ ### Simple workflow
22
+
23
+ Use this when you need a short multi-step sequence.
24
+
25
+ ```ts actors.ts
26
+ import { actor, setup } from "rivetkit";
27
+ import {
28
+ type WorkflowContextOf,
29
+ type WorkflowLoopContextOf,
30
+ type WorkflowBranchContextOf,
31
+ workflow,
32
+ } from "rivetkit/workflow";
33
+
34
+ export const invoiceActor = actor({
35
+ state: {
36
+ invoiceId: null as string | null,
37
+ subtotal: 0,
38
+ tax: 0,
39
+ total: 0,
40
+ status: "idle" as "idle" | "complete",
41
+ },
42
+ run: workflow(async ctx => {
43
+ const subtotal = await ctx.step("load-subtotal", async () => loadSubtotal());
44
+
45
+ const tax = await ctx.step("calculate-tax", async () => calculateTax(subtotal));
46
+
47
+ await ctx.step("save-invoice", async () => saveInvoice(ctx, subtotal, tax));
48
+ }),
49
+ actions: {
50
+ getState: c => c.state,
51
+ },
52
+ });
53
+
54
+ async function loadSubtotal(): Promise<number> {
55
+ const response = await fetch("https://api.example.com/carts/main");
56
+ if (!response.ok) {
57
+ throw new Error(`load subtotal failed: ${response.status}`);
58
+ }
59
+ const cart = (await response.json()) as { subtotal: number };
60
+ return cart.subtotal;
61
+ }
62
+
63
+ async function calculateTax(subtotal: number): Promise<number> {
64
+ const response = await fetch("https://api.example.com/tax/quote", {
65
+ method: "POST",
66
+ headers: {
67
+ "content-type": "application/json",
68
+ },
69
+ body: JSON.stringify({ subtotal }),
70
+ });
71
+ if (!response.ok) {
72
+ throw new Error(`tax quote failed: ${response.status}`);
73
+ }
74
+ const quote = (await response.json()) as { tax: number };
75
+ return quote.tax;
76
+ }
77
+
78
+ async function saveInvoice(
79
+ ctx: WorkflowContextOf<typeof invoiceActor>,
80
+ subtotal: number,
81
+ tax: number
82
+ ): Promise<void> {
83
+ const total = subtotal + tax;
84
+ const response = await fetch("https://api.example.com/invoices", {
85
+ method: "POST",
86
+ headers: {
87
+ "content-type": "application/json",
88
+ },
89
+ body: JSON.stringify({ subtotal, tax, total }),
90
+ });
91
+ if (!response.ok) {
92
+ throw new Error(`save invoice failed: ${response.status}`);
93
+ }
94
+ const invoice = (await response.json()) as { id: string };
95
+ ctx.state.invoiceId = invoice.id;
96
+ ctx.state.subtotal = subtotal;
97
+ ctx.state.tax = tax;
98
+ ctx.state.total = total;
99
+ ctx.state.status = "complete";
100
+ }
101
+
102
+ export const registry = setup({ use: { invoiceActor } });
103
+ ```
104
+
105
+ ```ts client.ts
106
+ import { createClient } from "rivetkit/client";
107
+ import type { registry } from "./actors";
108
+
109
+ const client = createClient<typeof registry>();
110
+ const handle = client.invoiceActor.getOrCreate(["main"]);
111
+
112
+ const state = await handle.getState();
113
+ console.log(state.status, state.total);
114
+ ```
115
+
116
+ ### Loops
117
+
118
+ This is the recommended workflow shape for most actor workloads.
119
+
120
+ - Use a queue wait inside the loop to receive the next unit of work.
121
+ - Keep actor state changes in a single workflow loop.
122
+ - This gives you one durable workflow that manages all actor progress.
123
+
124
+ ```ts actors.ts
125
+ import { actor, queue, setup } from "rivetkit";
126
+ import {
127
+ type WorkflowContextOf,
128
+ type WorkflowLoopContextOf,
129
+ type WorkflowBranchContextOf,
130
+ workflow,
131
+ } from "rivetkit/workflow";
132
+
133
+ export const workflowCounter = actor({
134
+ state: {
135
+ value: 0,
136
+ processed: 0,
137
+ lastOperationId: null as string | null,
138
+ },
139
+ queues: {
140
+ counter: queue<{ delta: number }>(),
141
+ },
142
+ run: workflow(async ctx => {
143
+ await ctx.loop("counter-loop", async loopCtx => {
144
+ const message = await loopCtx.queue.next("wait-counter-command");
145
+
146
+ await loopCtx.step("apply-counter-command", async () =>
147
+ applyCounterCommand(loopCtx, message.body.delta)
148
+ );
149
+ });
150
+ }),
151
+ actions: {
152
+ getState: c => c.state,
153
+ },
154
+ });
155
+
156
+ async function applyCounterCommand(
157
+ ctx: WorkflowLoopContextOf<typeof workflowCounter>,
158
+ delta: number
159
+ ): Promise<void> {
160
+ const response = await fetch("https://api.example.com/counter/apply", {
161
+ method: "POST",
162
+ headers: {
163
+ "content-type": "application/json",
164
+ },
165
+ body: JSON.stringify({ delta }),
166
+ });
167
+ if (!response.ok) {
168
+ throw new Error(`counter apply failed: ${response.status}`);
169
+ }
170
+ const result = (await response.json()) as {
171
+ nextValue: number;
172
+ operationId: string;
173
+ };
174
+ ctx.state.value = result.nextValue;
175
+ ctx.state.lastOperationId = result.operationId;
176
+ ctx.state.processed += 1;
177
+ }
178
+
179
+ export const registry = setup({ use: { workflowCounter } });
180
+ ```
181
+
182
+ ```ts client.ts
183
+ import { createClient } from "rivetkit/client";
184
+ import type { registry } from "./actors";
185
+
186
+ const client = createClient<typeof registry>();
187
+ const handle = client.workflowCounter.getOrCreate(["main"]);
188
+
189
+ await handle.send("counter", { delta: 1 });
190
+ await handle.send("counter", { delta: 2 });
191
+
192
+ const state = await handle.getState();
193
+ console.log(state.value, state.processed);
194
+ ```
195
+
196
+ ### Setup & teardown
197
+
198
+ Use this when the workflow should initialize resources, process queued commands, then clean up.
199
+
200
+ ```ts actors.ts
201
+ import { actor, queue, setup } from "rivetkit";
202
+ import {
203
+ Loop,
204
+ type WorkflowContextOf,
205
+ type WorkflowLoopContextOf,
206
+ type WorkflowBranchContextOf,
207
+ workflow,
208
+ } from "rivetkit/workflow";
209
+
210
+ type WorkMessage = { amount: number };
211
+ type ControlMessage = { type: "stop"; reason: string };
212
+
213
+ export const setupRunTeardownActor = actor({
214
+ state: {
215
+ phase: "idle" as "idle" | "running" | "stopped",
216
+ total: 0,
217
+ processed: 0,
218
+ stopReason: null as string | null,
219
+ workerSessionId: null as string | null,
220
+ },
221
+ queues: {
222
+ work: queue<WorkMessage>(),
223
+ control: queue<ControlMessage>(),
224
+ },
225
+ run: workflow(async ctx => {
226
+ await ctx.step("setup", async () => setupWorkerSession(ctx));
227
+
228
+ const stopReason = await ctx.loop("worker-loop", async loopCtx => {
229
+ const message = await loopCtx.queue.next("wait-command", {
230
+ names: ["work", "control"],
231
+ });
232
+
233
+ if (message.name === "work") {
234
+ const work = message.body as WorkMessage;
235
+ await loopCtx.step("apply-work", async () => applyWorkerMessage(loopCtx, work));
236
+ return;
237
+ }
238
+
239
+ const control = message.body as ControlMessage;
240
+ if (control.type === "stop") {
241
+ return Loop.break(control.reason);
242
+ }
243
+ });
244
+
245
+ await ctx.step("teardown", async () => teardownWorkerSession(ctx, stopReason));
246
+ }),
247
+ actions: {
248
+ getState: c => c.state,
249
+ },
250
+ });
251
+
252
+ async function setupWorkerSession(
253
+ ctx: WorkflowContextOf<typeof setupRunTeardownActor>
254
+ ): Promise<void> {
255
+ const response = await fetch("https://api.example.com/workers/session", {
256
+ method: "POST",
257
+ });
258
+ if (!response.ok) {
259
+ throw new Error(`worker setup failed: ${response.status}`);
260
+ }
261
+ const session = (await response.json()) as { sessionId: string };
262
+ ctx.state.workerSessionId = session.sessionId;
263
+ ctx.state.phase = "running";
264
+ ctx.state.stopReason = null;
265
+ }
266
+
267
+ async function applyWorkerMessage(
268
+ ctx: WorkflowLoopContextOf<typeof setupRunTeardownActor>,
269
+ work: WorkMessage
270
+ ): Promise<void> {
271
+ const response = await fetch("https://api.example.com/workers/process", {
272
+ method: "POST",
273
+ headers: {
274
+ "content-type": "application/json",
275
+ },
276
+ body: JSON.stringify({
277
+ sessionId: ctx.state.workerSessionId,
278
+ amount: work.amount,
279
+ }),
280
+ });
281
+ if (!response.ok) {
282
+ throw new Error(`worker process failed: ${response.status}`);
283
+ }
284
+ const result = (await response.json()) as { appliedAmount: number };
285
+ ctx.state.total += result.appliedAmount;
286
+ ctx.state.processed += 1;
287
+ }
288
+
289
+ async function teardownWorkerSession(
290
+ ctx: WorkflowContextOf<typeof setupRunTeardownActor>,
291
+ stopReason: string
292
+ ): Promise<void> {
293
+ if (ctx.state.workerSessionId) {
294
+ const response = await fetch(
295
+ `https://api.example.com/workers/session/${ctx.state.workerSessionId}`,
296
+ { method: "DELETE" }
297
+ );
298
+ if (!response.ok) {
299
+ throw new Error(`worker teardown failed: ${response.status}`);
300
+ }
301
+ }
302
+ ctx.state.phase = "stopped";
303
+ ctx.state.stopReason = stopReason;
304
+ }
305
+
306
+ export const registry = setup({ use: { setupRunTeardownActor } });
307
+ ```
308
+
309
+ ```ts client.ts
310
+ import { createClient } from "rivetkit/client";
311
+ import type { registry } from "./actors";
312
+
313
+ const client = createClient<typeof registry>();
314
+ const handle = client.setupRunTeardownActor.getOrCreate(["main"]);
315
+
316
+ await handle.send("work", { amount: 5 });
317
+ await handle.send("work", { amount: 3 });
318
+ await handle.send("control", { type: "stop", reason: "maintenance" });
319
+
320
+ const state = await handle.getState();
321
+ console.log(state.phase, state.total, state.stopReason);
322
+ ```
323
+
324
+ ## Features
325
+
326
+ ### Queue
327
+
328
+ Use this for fire-and-forget commands where the client does not need a reply.
329
+
330
+ Use the `Loops` example above as the baseline pattern.
331
+
332
+ ### Request/response (using queue)
333
+
334
+ Use this when the caller needs a response from queued processing.
335
+
336
+ ```ts actors.ts
337
+ import { actor, queue, setup } from "rivetkit";
338
+ import {
339
+ type WorkflowContextOf,
340
+ type WorkflowLoopContextOf,
341
+ type WorkflowBranchContextOf,
342
+ workflow,
343
+ } from "rivetkit/workflow";
344
+
345
+ export const requestResponseActor = actor({
346
+ state: {
347
+ handled: 0,
348
+ },
349
+ queues: {
350
+ requests: queue<{ value: number }, { doubled: number }>(),
351
+ },
352
+ run: workflow(async ctx => {
353
+ await ctx.loop("request-loop", async loopCtx => {
354
+ const message = await loopCtx.queue.next("wait-request", {
355
+ completable: true,
356
+ });
357
+
358
+ if (!message.complete) return;
359
+
360
+ const doubled = await loopCtx.step("handle-request", async () => {
361
+ loopCtx.state.handled += 1;
362
+ return message.body.value * 2;
363
+ });
364
+
365
+ await message.complete({ doubled });
366
+ });
367
+ }),
368
+ });
369
+
370
+ export const registry = setup({ use: { requestResponseActor } });
371
+ ```
372
+
373
+ ```ts client.ts
374
+ import { createClient } from "rivetkit/client";
375
+ import type { registry } from "./actors";
376
+
377
+ const client = createClient<typeof registry>();
378
+ const handle = client.requestResponseActor.getOrCreate(["main"]);
379
+
380
+ const result = await handle.send("requests", { value: 21 }, { wait: true, timeout: 1_000 });
381
+
382
+ if (result.status === "completed") {
383
+ const response = result.response as { doubled: number };
384
+ console.log(response.doubled);
385
+ }
386
+ ```
387
+
388
+ ### Timers
389
+
390
+ Use queue messages as the trigger source, then sleep durably inside the workflow.
391
+
392
+ ```ts actors.ts
393
+ import { actor, queue, setup } from "rivetkit";
394
+ import {
395
+ type WorkflowContextOf,
396
+ type WorkflowLoopContextOf,
397
+ type WorkflowBranchContextOf,
398
+ workflow,
399
+ } from "rivetkit/workflow";
400
+
401
+ type Reminder = {
402
+ text: string;
403
+ at: number;
404
+ };
405
+
406
+ export const reminderActor = actor({
407
+ state: {
408
+ fired: [] as string[],
409
+ },
410
+ queues: {
411
+ reminders: queue<Reminder>(),
412
+ },
413
+ run: workflow(async ctx => {
414
+ await ctx.loop("reminder-loop", async loopCtx => {
415
+ const message = await loopCtx.queue.next("wait-reminder");
416
+
417
+ const runAt = Math.max(Date.now(), message.body.at);
418
+ await loopCtx.sleepUntil("wait-until-reminder", runAt);
419
+
420
+ await loopCtx.step("record-reminder", async () => {
421
+ loopCtx.state.fired.push(message.body.text);
422
+ });
423
+ });
424
+ }),
425
+ actions: {
426
+ getState: c => c.state,
427
+ },
428
+ });
429
+
430
+ export const registry = setup({ use: { reminderActor } });
431
+ ```
432
+
433
+ ```ts client.ts
434
+ import { createClient } from "rivetkit/client";
435
+ import type { registry } from "./actors";
436
+
437
+ const client = createClient<typeof registry>();
438
+ const handle = client.reminderActor.getOrCreate(["main"]);
439
+
440
+ await handle.send("reminders", {
441
+ text: "send weekly report",
442
+ at: Date.now() + 1_000,
443
+ });
444
+
445
+ await new Promise(resolve => setTimeout(resolve, 1_300));
446
+ console.log(await handle.getState());
447
+ ```
448
+
449
+ ### Join
450
+
451
+ Use `join` when several independent tasks can run in parallel.
452
+
453
+ ```ts actors.ts
454
+ import { actor, queue, setup } from "rivetkit";
455
+ import {
456
+ type WorkflowContextOf,
457
+ type WorkflowLoopContextOf,
458
+ type WorkflowBranchContextOf,
459
+ workflow,
460
+ } from "rivetkit/workflow";
461
+
462
+ export const dashboardActor = actor({
463
+ state: {
464
+ summary: null as null | {
465
+ users: number;
466
+ orders: number;
467
+ revenue: number;
468
+ },
469
+ },
470
+ queues: {
471
+ refresh: queue<Record<string, never>>(),
472
+ },
473
+ run: workflow(async ctx => {
474
+ await ctx.loop("dashboard-loop", async loopCtx => {
475
+ await loopCtx.queue.next("wait-refresh");
476
+
477
+ const summary = await loopCtx.join("fetch-summary", {
478
+ users: {
479
+ run: async branchCtx => {
480
+ return await branchCtx.step("fetch-users", () => fetchCount("/users"));
481
+ },
482
+ },
483
+ orders: {
484
+ run: async branchCtx => {
485
+ return await branchCtx.step("fetch-orders", () => fetchCount("/orders"));
486
+ },
487
+ },
488
+ revenue: {
489
+ run: async branchCtx => {
490
+ return await branchCtx.step("fetch-revenue", () => fetchCount("/revenue"));
491
+ },
492
+ },
493
+ });
494
+
495
+ await loopCtx.step("save-summary", async () => {
496
+ loopCtx.state.summary = summary;
497
+ });
498
+ });
499
+ }),
500
+ actions: {
501
+ getState: c => c.state,
502
+ },
503
+ });
504
+
505
+ async function fetchCount(path: string): Promise<number> {
506
+ const res = await fetch(`https://api.example.com${path}`);
507
+ if (!res.ok) throw new Error(`fetch ${path} failed: ${res.status}`);
508
+ return ((await res.json()) as { count: number }).count;
509
+ }
510
+
511
+ export const registry = setup({ use: { dashboardActor } });
512
+ ```
513
+
514
+ ```ts client.ts
515
+ import { createClient } from "rivetkit/client";
516
+ import type { registry } from "./actors";
517
+
518
+ const client = createClient<typeof registry>();
519
+ const handle = client.dashboardActor.getOrCreate(["main"]);
520
+
521
+ await handle.send("refresh", {});
522
+ console.log(await handle.getState());
523
+ ```
524
+
525
+ ### Race
526
+
527
+ Use `race` when you need first-winner behavior.
528
+
529
+ ```ts actors.ts
530
+ import { actor, queue, setup } from "rivetkit";
531
+ import {
532
+ type WorkflowContextOf,
533
+ type WorkflowLoopContextOf,
534
+ type WorkflowBranchContextOf,
535
+ workflow,
536
+ } from "rivetkit/workflow";
537
+
538
+ export const auctionActor = actor({
539
+ state: { result: null as "sold" | "expired" | null },
540
+ queues: {
541
+ bids: queue<{ amount: number }>(),
542
+ },
543
+ run: workflow(async ctx => {
544
+ await ctx.step("list-item", () => listItem("item-123"));
545
+
546
+ const { winner } = await ctx.race("bid-or-expire", [
547
+ {
548
+ name: "bid",
549
+ run: async branchCtx => {
550
+ const bid = await branchCtx.queue.next("wait-bid");
551
+ return bid.body.amount;
552
+ },
553
+ },
554
+ {
555
+ name: "expire",
556
+ run: async branchCtx => {
557
+ await branchCtx.sleep("auction-timeout", 24 * 60 * 60 * 1000);
558
+ return 0;
559
+ },
560
+ },
561
+ ]);
562
+
563
+ await ctx.step("finalize", async () => {
564
+ await finalizeAuction("item-123", winner);
565
+ ctx.state.result = winner === "bid" ? "sold" : "expired";
566
+ });
567
+ }),
568
+ actions: {
569
+ getState: c => c.state,
570
+ },
571
+ });
572
+
573
+ async function listItem(itemId: string): Promise<void> {
574
+ await fetch(`https://api.example.com/auctions/${itemId}`, {
575
+ method: "POST",
576
+ });
577
+ }
578
+
579
+ async function finalizeAuction(itemId: string, outcome: string): Promise<void> {
580
+ await fetch(`https://api.example.com/auctions/${itemId}/finalize`, {
581
+ method: "POST",
582
+ body: JSON.stringify({ outcome }),
583
+ });
584
+ }
585
+
586
+ export const registry = setup({ use: { auctionActor } });
587
+ ```
588
+
589
+ ```ts client.ts
590
+ import { createClient } from "rivetkit/client";
591
+ import type { registry } from "./actors";
592
+
593
+ const client = createClient<typeof registry>();
594
+ const handle = client.auctionActor.getOrCreate(["item-123"]);
595
+
596
+ await handle.send("bids", { amount: 100 });
597
+ console.log(await handle.getState());
598
+ ```
599
+
600
+ ### Timeouts
601
+
602
+ Use step timeouts and retries for slow or flaky dependencies.
603
+
604
+ ```ts
605
+ import { actor, queue, setup } from "rivetkit";
606
+ import {
607
+ type WorkflowContextOf,
608
+ type WorkflowLoopContextOf,
609
+ type WorkflowBranchContextOf,
610
+ workflow,
611
+ } from "rivetkit/workflow";
612
+
613
+ async function chargeCard(orderId: string): Promise<string> {
614
+ return `charge-${orderId}`;
615
+ }
616
+
617
+ export const timeoutActor = actor({
618
+ state: {
619
+ lastChargeId: null as string | null,
620
+ },
621
+ queues: {
622
+ charge: queue<{ orderId: string }>(),
623
+ },
624
+ run: workflow(async ctx => {
625
+ await ctx.loop("charge-loop", async loopCtx => {
626
+ const message = await loopCtx.queue.next("wait-charge");
627
+
628
+ const chargeId = await loopCtx.step<string>({
629
+ name: "charge-card",
630
+ timeout: 5_000,
631
+ maxRetries: 5,
632
+ retryBackoffBase: 200,
633
+ retryBackoffMax: 2_000,
634
+ run: async () => await chargeCard(message.body.orderId),
635
+ });
636
+
637
+ await loopCtx.step("save-charge", async () => {
638
+ loopCtx.state.lastChargeId = chargeId;
639
+ });
640
+ });
641
+ }),
642
+ });
643
+
644
+ export const registry = setup({ use: { timeoutActor } });
645
+ ```
646
+
647
+ ### Rollback
648
+
649
+ Use rollback checkpoints before steps that have compensating actions.
650
+
651
+ ```ts
652
+ import { actor, queue, setup } from "rivetkit";
653
+ import {
654
+ type WorkflowContextOf,
655
+ type WorkflowLoopContextOf,
656
+ type WorkflowBranchContextOf,
657
+ workflow,
658
+ } from "rivetkit/workflow";
659
+
660
+ export const checkoutActor = actor({
661
+ state: { status: "pending" as string },
662
+ queues: {
663
+ orders: queue<{ orderId: string }>(),
664
+ },
665
+ run: workflow(async ctx => {
666
+ await ctx.loop("checkout-loop", async loopCtx => {
667
+ const message = await loopCtx.queue.next("wait-order");
668
+
669
+ await loopCtx.rollbackCheckpoint("checkout-checkpoint");
670
+
671
+ await loopCtx.step<string>({
672
+ name: "reserve-inventory",
673
+ run: () => reserveInventory(message.body.orderId),
674
+ rollback: async (_rollbackCtx, id) => {
675
+ await releaseInventory(id as string);
676
+ },
677
+ });
678
+
679
+ await loopCtx.step<string>({
680
+ name: "charge-card",
681
+ run: () => chargeCard(message.body.orderId),
682
+ rollback: async (_rollbackCtx, chargeId) => {
683
+ await refundCharge(chargeId as string);
684
+ },
685
+ });
686
+
687
+ await loopCtx.step("confirm", async () => {
688
+ loopCtx.state.status = "confirmed";
689
+ });
690
+ });
691
+ }),
692
+ actions: {
693
+ getState: c => c.state,
694
+ },
695
+ });
696
+
697
+ async function reserveInventory(orderId: string): Promise<string> {
698
+ const res = await fetch("https://api.example.com/inventory/reserve", {
699
+ method: "POST",
700
+ body: JSON.stringify({ orderId }),
701
+ });
702
+ return ((await res.json()) as { reservationId: string }).reservationId;
703
+ }
704
+
705
+ async function releaseInventory(reservationId: string): Promise<void> {
706
+ await fetch(`https://api.example.com/inventory/${reservationId}/release`, {
707
+ method: "POST",
708
+ });
709
+ }
710
+
711
+ async function chargeCard(orderId: string): Promise<string> {
712
+ const res = await fetch("https://api.stripe.com/v1/charges", {
713
+ method: "POST",
714
+ headers: { Authorization: `Bearer ${process.env.STRIPE_KEY}` },
715
+ body: JSON.stringify({ orderId }),
716
+ });
717
+ return ((await res.json()) as { id: string }).id;
718
+ }
719
+
720
+ async function refundCharge(chargeId: string): Promise<void> {
721
+ await fetch("https://api.stripe.com/v1/refunds", {
722
+ method: "POST",
723
+ headers: { Authorization: `Bearer ${process.env.STRIPE_KEY}` },
724
+ body: JSON.stringify({ charge: chargeId }),
725
+ });
726
+ }
727
+
728
+ export const registry = setup({ use: { checkoutActor } });
729
+ ```
730
+
731
+ ## Patterns
732
+
733
+ ### Store workflow progress in state + broadcast
734
+
735
+ Store progress in `state` so replay and recovery always restore it. Broadcast state changes so clients can render progress in realtime.
736
+
737
+ ```ts actors.ts
738
+ import { actor, event, queue, setup } from "rivetkit";
739
+ import {
740
+ type WorkflowContextOf,
741
+ type WorkflowLoopContextOf,
742
+ type WorkflowBranchContextOf,
743
+ workflow,
744
+ } from "rivetkit/workflow";
745
+
746
+ type Progress = {
747
+ stage: "idle" | "running" | "completed";
748
+ completed: number;
749
+ total: number;
750
+ };
751
+
752
+ export const progressActor = actor({
753
+ state: {
754
+ progress: {
755
+ stage: "idle",
756
+ completed: 0,
757
+ total: 0,
758
+ } as Progress,
759
+ sum: 0,
760
+ },
761
+ events: {
762
+ progressUpdated: event<Progress>(),
763
+ },
764
+ queues: {
765
+ jobs: queue<{ value: number }>(),
766
+ },
767
+ run: workflow(async ctx => {
768
+ await ctx.loop("progress-loop", async loopCtx => {
769
+ const message = await loopCtx.queue.next("wait-job");
770
+
771
+ await loopCtx.step("mark-running", async () => markProgressRunning(loopCtx));
772
+
773
+ await loopCtx.step("apply-job", async () => applyProgressJob(loopCtx, message.body.value));
774
+ });
775
+ }),
776
+ actions: {
777
+ getState: c => c.state,
778
+ },
779
+ });
780
+
781
+ function markProgressRunning(ctx: WorkflowLoopContextOf<typeof progressActor>): void {
782
+ ctx.state.progress = {
783
+ stage: "running",
784
+ completed: ctx.state.progress.completed,
785
+ total: ctx.state.progress.total + 1,
786
+ };
787
+ ctx.broadcast("progressUpdated", ctx.state.progress);
788
+ }
789
+
790
+ function applyProgressJob(ctx: WorkflowLoopContextOf<typeof progressActor>, value: number): void {
791
+ ctx.state.sum += value;
792
+ ctx.state.progress = {
793
+ stage: "completed",
794
+ completed: ctx.state.progress.completed + 1,
795
+ total: ctx.state.progress.total,
796
+ };
797
+ ctx.broadcast("progressUpdated", ctx.state.progress);
798
+ }
799
+
800
+ export const registry = setup({ use: { progressActor } });
801
+ ```
802
+
803
+ ```ts client.ts
804
+ import { createClient } from "rivetkit/client";
805
+ import type { registry } from "./actors";
806
+
807
+ const client = createClient<typeof registry>();
808
+ const handle = client.progressActor.getOrCreate(["main"]);
809
+ const conn = handle.connect();
810
+
811
+ conn.on("progressUpdated", progress => {
812
+ console.log("progress", progress);
813
+ });
814
+
815
+ await handle.send("jobs", { value: 5 });
816
+ await handle.send("jobs", { value: 7 });
817
+
818
+ console.log(await handle.getState());
819
+ ```
820
+
821
+ ### Cron (queue-driven)
822
+
823
+ Rivet scheduling triggers actions. For cron-like workflows, use a small scheduled action as a bridge that enqueues work, then process that work in the workflow loop.
824
+
825
+ ```ts
826
+ import { actor, queue, setup } from "rivetkit";
827
+ import {
828
+ type WorkflowContextOf,
829
+ type WorkflowLoopContextOf,
830
+ type WorkflowBranchContextOf,
831
+ workflow,
832
+ } from "rivetkit/workflow";
833
+
834
+ function nextMinute(timestamp: number): number {
835
+ const minuteMs = 60_000;
836
+ return Math.floor(timestamp / minuteMs) * minuteMs + minuteMs;
837
+ }
838
+
839
+ export const cronActor = actor({
840
+ state: {
841
+ runs: 0,
842
+ lastRunAt: null as number | null,
843
+ },
844
+ queues: {
845
+ "cron-tick": queue<{ scheduledAt: number }>(),
846
+ },
847
+ onCreate: async c => {
848
+ const firstTickAt = nextMinute(Date.now());
849
+ await c.schedule.at(firstTickAt, "enqueueCronTick", firstTickAt);
850
+ },
851
+ actions: {
852
+ enqueueCronTick: async (c, scheduledAt: number) => {
853
+ await c.queue.send("cron-tick", { scheduledAt });
854
+
855
+ const nextTickAt = nextMinute(scheduledAt + 1);
856
+ await c.schedule.at(nextTickAt, "enqueueCronTick", nextTickAt);
857
+ },
858
+ getState: c => c.state,
859
+ },
860
+ run: workflow(async ctx => {
861
+ await ctx.loop("cron-loop", async loopCtx => {
862
+ const message = await loopCtx.queue.next("wait-cron-tick");
863
+
864
+ await loopCtx.step("run-cron-job", async () => {
865
+ loopCtx.state.runs += 1;
866
+ loopCtx.state.lastRunAt = message.body.scheduledAt;
867
+ });
868
+ });
869
+ }),
870
+ });
871
+
872
+ export const registry = setup({ use: { cronActor } });
873
+ ```
874
+
875
+ These are common workflow shapes used in production systems.
876
+
877
+ ### Queue-driven worker
878
+
879
+ Use this when external systems enqueue work and the actor should process each item durably.
880
+
881
+ ```ts
882
+ import { actor, setup } from "rivetkit";
883
+ import {
884
+ type WorkflowContextOf,
885
+ type WorkflowLoopContextOf,
886
+ type WorkflowBranchContextOf,
887
+ workflow,
888
+ } from "rivetkit/workflow";
889
+
890
+ type Job = { id: string; amount: number };
891
+
892
+ export const queueWorkerActor = actor({
893
+ state: {
894
+ processed: 0,
895
+ totalAmount: 0,
896
+ },
897
+ run: workflow(async ctx => {
898
+ await ctx.loop("worker-loop", async loopCtx => {
899
+ const [message] = await loopCtx.queue.nextBatch("wait-job", {
900
+ timeout: 30_000,
901
+ });
902
+
903
+ if (!message) return;
904
+ const job = message.body as Job;
905
+
906
+ await loopCtx.step("process-job", async () => {
907
+ loopCtx.state.processed += 1;
908
+ loopCtx.state.totalAmount += job.amount;
909
+ });
910
+ });
911
+ }),
912
+ actions: {
913
+ getState: c => c.state,
914
+ },
915
+ });
916
+
917
+ export const registry = setup({ use: { queueWorkerActor } });
918
+ ```
919
+
920
+ ### Setup & teardown
921
+
922
+ Use this when you need one-time initialization before a long-lived loop, plus cleanup when the actor stops sleeping or is destroyed.
923
+
924
+ ```ts
925
+ import { actor, setup } from "rivetkit";
926
+ import {
927
+ type WorkflowContextOf,
928
+ type WorkflowLoopContextOf,
929
+ type WorkflowBranchContextOf,
930
+ workflow,
931
+ } from "rivetkit/workflow";
932
+
933
+ function openResource(): string {
934
+ return "connected";
935
+ }
936
+
937
+ function closeResource(_resource: string): void {}
938
+
939
+ export const setupRunTeardownActor = actor({
940
+ vars: {
941
+ resource: null as string | null,
942
+ },
943
+ state: {
944
+ initialized: false,
945
+ ticks: 0,
946
+ },
947
+ onWake: c => {
948
+ c.vars.resource = openResource();
949
+ },
950
+ onSleep: c => {
951
+ if (!c.vars.resource) return;
952
+ closeResource(c.vars.resource);
953
+ c.vars.resource = null;
954
+ },
955
+ run: workflow(async ctx => {
956
+ await ctx.step("setup", async () => {
957
+ if (!ctx.vars.resource) ctx.vars.resource = openResource();
958
+ ctx.state.initialized = true;
959
+ });
960
+
961
+ await ctx.loop("main-loop", async loopCtx => {
962
+ await loopCtx.sleep("tick", 1_000);
963
+ await loopCtx.step("tick-step", async () => {
964
+ loopCtx.state.ticks += 1;
965
+ });
966
+ });
967
+ }),
968
+ actions: {
969
+ getState: c => c.state,
970
+ },
971
+ });
972
+
973
+ export const registry = setup({ use: { setupRunTeardownActor } });
974
+ ```
975
+
976
+ ### Human approval gate
977
+
978
+ Use this when an operation must pause for a user or system decision before continuing.
979
+
980
+ ```ts
981
+ import { actor, queue, setup } from "rivetkit";
982
+ import {
983
+ type WorkflowContextOf,
984
+ type WorkflowLoopContextOf,
985
+ type WorkflowBranchContextOf,
986
+ workflow,
987
+ } from "rivetkit/workflow";
988
+
989
+ export const approvalGateActor = actor({
990
+ state: { status: "pending" as string },
991
+ queues: {
992
+ approval: queue<{ approved: boolean }>(),
993
+ },
994
+ run: workflow(async ctx => {
995
+ await ctx.step("validate-order", async () => {
996
+ await validateOrder("order-123");
997
+ ctx.state.status = "awaiting_approval";
998
+ });
999
+
1000
+ const decision = await ctx.queue.next("wait-approval");
1001
+
1002
+ if (decision.body.approved) {
1003
+ await ctx.step("fulfill-order", async () => {
1004
+ await fulfillOrder("order-123");
1005
+ ctx.state.status = "fulfilled";
1006
+ });
1007
+ } else {
1008
+ await ctx.step("cancel-order", async () => {
1009
+ await cancelOrder("order-123");
1010
+ ctx.state.status = "cancelled";
1011
+ });
1012
+ }
1013
+ }),
1014
+ actions: {
1015
+ getState: c => c.state,
1016
+ },
1017
+ });
1018
+
1019
+ async function validateOrder(orderId: string): Promise<void> {
1020
+ const res = await fetch(`https://api.example.com/orders/${orderId}/validate`, { method: "POST" });
1021
+ if (!res.ok) throw new Error("Order validation failed");
1022
+ }
1023
+
1024
+ async function fulfillOrder(orderId: string): Promise<void> {
1025
+ await fetch(`https://api.example.com/orders/${orderId}/fulfill`, {
1026
+ method: "POST",
1027
+ });
1028
+ }
1029
+
1030
+ async function cancelOrder(orderId: string): Promise<void> {
1031
+ await fetch(`https://api.example.com/orders/${orderId}/cancel`, {
1032
+ method: "POST",
1033
+ });
1034
+ }
1035
+
1036
+ export const registry = setup({ use: { approvalGateActor } });
1037
+ ```
1038
+
1039
+ ### Fan-out / fan-in (join)
1040
+
1041
+ Use this when independent work items can run in parallel and you need a single merged result.
1042
+
1043
+ ```ts
1044
+ import { actor, setup } from "rivetkit";
1045
+ import {
1046
+ type WorkflowContextOf,
1047
+ type WorkflowLoopContextOf,
1048
+ type WorkflowBranchContextOf,
1049
+ workflow,
1050
+ } from "rivetkit/workflow";
1051
+
1052
+ export const fanInOutActor = actor({
1053
+ state: {
1054
+ total: 0,
1055
+ },
1056
+ run: workflow(async ctx => {
1057
+ await ctx.loop("join-loop", async loopCtx => {
1058
+ const [message] = await loopCtx.queue.nextBatch("wait-refresh", {
1059
+ timeout: 30_000,
1060
+ });
1061
+
1062
+ if (!message) return;
1063
+
1064
+ const joined = await loopCtx.join("parallel-work", {
1065
+ users: {
1066
+ run: async branchCtx => await branchCtx.step("fetch-users", () => fetchCount("/users")),
1067
+ },
1068
+ orders: {
1069
+ run: async branchCtx => await branchCtx.step("fetch-orders", () => fetchCount("/orders")),
1070
+ },
1071
+ invoices: {
1072
+ run: async branchCtx =>
1073
+ await branchCtx.step("fetch-invoices", () => fetchCount("/invoices")),
1074
+ },
1075
+ });
1076
+
1077
+ await loopCtx.step("merge-results", async () => {
1078
+ loopCtx.state.total = joined.users + joined.orders + joined.invoices;
1079
+ });
1080
+ });
1081
+ }),
1082
+ actions: {
1083
+ getState: c => c.state,
1084
+ },
1085
+ });
1086
+
1087
+ async function fetchCount(path: string): Promise<number> {
1088
+ const res = await fetch(`https://api.example.com${path}`);
1089
+ if (!res.ok) throw new Error(`fetch ${path} failed: ${res.status}`);
1090
+ return ((await res.json()) as { count: number }).count;
1091
+ }
1092
+
1093
+ export const registry = setup({ use: { fanInOutActor } });
1094
+ ```
1095
+
1096
+ ### Batch drainer
1097
+
1098
+ Use this when throughput matters and handling one message at a time is too expensive.
1099
+
1100
+ ```ts
1101
+ import { actor, setup } from "rivetkit";
1102
+ import {
1103
+ type WorkflowContextOf,
1104
+ type WorkflowLoopContextOf,
1105
+ type WorkflowBranchContextOf,
1106
+ workflow,
1107
+ } from "rivetkit/workflow";
1108
+
1109
+ type MetricMessage = { value: number };
1110
+
1111
+ export const batchDrainerActor = actor({
1112
+ state: {
1113
+ pending: [] as number[],
1114
+ flushedBatches: 0,
1115
+ lastBatchTotal: 0,
1116
+ },
1117
+ run: workflow(async ctx => {
1118
+ await ctx.loop("drain-loop", async loopCtx => {
1119
+ const [message] = await loopCtx.queue.nextBatch("wait-metric", {
1120
+ timeout: 5_000,
1121
+ });
1122
+
1123
+ if (message) {
1124
+ const metric = message.body as MetricMessage;
1125
+ await loopCtx.step("buffer-message", async () => {
1126
+ loopCtx.state.pending.push(metric.value);
1127
+ });
1128
+ }
1129
+
1130
+ if (loopCtx.state.pending.length < 5) return;
1131
+
1132
+ await loopCtx.step("flush-batch", async () => flushBatch(loopCtx));
1133
+ });
1134
+ }),
1135
+ actions: {
1136
+ getState: c => c.state,
1137
+ },
1138
+ });
1139
+
1140
+ function flushBatch(ctx: WorkflowLoopContextOf<typeof batchDrainerActor>): void {
1141
+ const total = ctx.state.pending.reduce((sum: number, value: number) => sum + value, 0);
1142
+ ctx.state.lastBatchTotal = total;
1143
+ ctx.state.flushedBatches += 1;
1144
+ ctx.state.pending = [];
1145
+ }
1146
+
1147
+ export const registry = setup({ use: { batchDrainerActor } });
1148
+ ```
1149
+
1150
+ ### Coordinator -> worker RPC
1151
+
1152
+ Use this when one actor orchestrates work by calling actions on other actors.
1153
+
1154
+ ```ts
1155
+ import { actor, setup } from "rivetkit";
1156
+ import {
1157
+ type WorkflowContextOf,
1158
+ type WorkflowLoopContextOf,
1159
+ type WorkflowBranchContextOf,
1160
+ workflow,
1161
+ } from "rivetkit/workflow";
1162
+
1163
+ type TaskMessage = {
1164
+ taskId: string;
1165
+ workerId: string;
1166
+ value: number;
1167
+ };
1168
+
1169
+ export const workerActor = actor({
1170
+ actions: {
1171
+ runTask: async (_c, value: number) => value * 2,
1172
+ },
1173
+ });
1174
+
1175
+ export const coordinatorActor = actor({
1176
+ state: {
1177
+ lastTaskId: null as string | null,
1178
+ lastResult: 0,
1179
+ },
1180
+ run: workflow(async ctx => {
1181
+ await ctx.loop("orchestrator-loop", async loopCtx => {
1182
+ const [message] = await loopCtx.queue.nextBatch("wait-task", {
1183
+ timeout: 30_000,
1184
+ });
1185
+
1186
+ if (!message) return;
1187
+ const task = message.body as TaskMessage;
1188
+
1189
+ const result = await loopCtx.step("dispatch-rpc", async () => dispatchTask(loopCtx, task));
1190
+
1191
+ await loopCtx.step("record-result", async () => {
1192
+ loopCtx.state.lastTaskId = task.taskId;
1193
+ loopCtx.state.lastResult = result as number;
1194
+ });
1195
+ });
1196
+ }),
1197
+ actions: {
1198
+ getState: c => c.state,
1199
+ },
1200
+ });
1201
+
1202
+ async function dispatchTask(
1203
+ ctx: WorkflowLoopContextOf<typeof coordinatorActor>,
1204
+ task: TaskMessage
1205
+ ): Promise<number> {
1206
+ const client = ctx.client();
1207
+ const worker = client.workerActor.getOrCreate([task.workerId]);
1208
+ return await worker.runTask(task.value);
1209
+ }
1210
+
1211
+ export const registry = setup({ use: { coordinatorActor, workerActor } });
1212
+ ```
1213
+
1214
+ ### Request/response over queue (async RPC)
1215
+
1216
+ Use this when you want decoupled actor-to-actor communication with durable waits and explicit completion.
1217
+
1218
+ ```ts actors.ts
1219
+ import { actor, queue, setup } from "rivetkit";
1220
+ import {
1221
+ type WorkflowContextOf,
1222
+ type WorkflowLoopContextOf,
1223
+ type WorkflowBranchContextOf,
1224
+ workflow,
1225
+ } from "rivetkit/workflow";
1226
+
1227
+ type RequestMessage = { value: number };
1228
+
1229
+ export const requestResponseActor = actor({
1230
+ state: {
1231
+ handled: 0,
1232
+ },
1233
+ queues: {
1234
+ requests: queue<RequestMessage, { doubled: number }>(),
1235
+ },
1236
+ run: workflow(async ctx => {
1237
+ await ctx.loop("request-response-loop", async loopCtx => {
1238
+ const message = await loopCtx.queue.next("wait-request", {
1239
+ completable: true,
1240
+ });
1241
+
1242
+ if (!message.complete) return;
1243
+
1244
+ const doubled = await loopCtx.step("handle-request", async () => {
1245
+ loopCtx.state.handled += 1;
1246
+ return message.body.value * 2;
1247
+ });
1248
+
1249
+ await message.complete({ doubled });
1250
+ });
1251
+ }),
1252
+ });
1253
+
1254
+ export const registry = setup({ use: { requestResponseActor } });
1255
+ ```
1256
+
1257
+ ```ts client.ts
1258
+ import { createClient } from "rivetkit/client";
1259
+ import type { registry } from "./actors";
1260
+
1261
+ const client = createClient<typeof registry>();
1262
+ const handle = client.requestResponseActor.getOrCreate(["main"]);
1263
+
1264
+ const result = await handle.send("requests", { value: 21 }, { wait: true });
1265
+
1266
+ if (result.status === "completed") {
1267
+ const response = result.response as { doubled: number };
1268
+ console.log(response.doubled);
1269
+ }
1270
+ ```
1271
+
1272
+ ### Scatter-gather across actors
1273
+
1274
+ Use this when multiple actors can process independent parts of a request in parallel, then return a merged response.
1275
+
1276
+ ```ts
1277
+ import { actor, setup } from "rivetkit";
1278
+ import {
1279
+ type WorkflowContextOf,
1280
+ type WorkflowLoopContextOf,
1281
+ type WorkflowBranchContextOf,
1282
+ workflow,
1283
+ } from "rivetkit/workflow";
1284
+
1285
+ type ScatterMessage = { input: number };
1286
+
1287
+ export const shardActor = actor({
1288
+ actions: {
1289
+ compute: async (_c, input: number) => input * 10,
1290
+ },
1291
+ });
1292
+
1293
+ export const scatterGatherActor = actor({
1294
+ state: {
1295
+ lastSum: 0,
1296
+ },
1297
+ run: workflow(async ctx => {
1298
+ await ctx.loop("scatter-gather-loop", async loopCtx => {
1299
+ const [message] = await loopCtx.queue.nextBatch("wait-scatter", {
1300
+ timeout: 30_000,
1301
+ });
1302
+
1303
+ if (!message) return;
1304
+ const scatter = message.body as ScatterMessage;
1305
+
1306
+ const gathered = await loopCtx.join("gather", {
1307
+ shardA: {
1308
+ run: async joinCtx =>
1309
+ await joinCtx.step("call-shard-a", async () => callShard(joinCtx, "a", scatter.input)),
1310
+ },
1311
+ shardB: {
1312
+ run: async joinCtx =>
1313
+ await joinCtx.step("call-shard-b", async () => callShard(joinCtx, "b", scatter.input)),
1314
+ },
1315
+ shardC: {
1316
+ run: async joinCtx =>
1317
+ await joinCtx.step("call-shard-c", async () => callShard(joinCtx, "c", scatter.input)),
1318
+ },
1319
+ });
1320
+
1321
+ await loopCtx.step("aggregate", async () => {
1322
+ loopCtx.state.lastSum = gathered.shardA + gathered.shardB + gathered.shardC;
1323
+ });
1324
+ });
1325
+ }),
1326
+ actions: {
1327
+ getState: c => c.state,
1328
+ },
1329
+ });
1330
+
1331
+ async function callShard(
1332
+ ctx: WorkflowLoopContextOf<typeof scatterGatherActor>,
1333
+ shardId: "a" | "b" | "c",
1334
+ input: number
1335
+ ): Promise<number> {
1336
+ const client = ctx.client();
1337
+ const handle = client.shardActor.getOrCreate([shardId]);
1338
+ return await handle.compute(input);
1339
+ }
1340
+
1341
+ export const registry = setup({ use: { scatterGatherActor, shardActor } });
1342
+ ```
1343
+
1344
+ ### Timeout + fallback actor
1345
+
1346
+ Use this when a primary actor call might be slow or unavailable and you need a deterministic fallback path.
1347
+
1348
+ ```ts
1349
+ import { actor, setup } from "rivetkit";
1350
+ import {
1351
+ type WorkflowContextOf,
1352
+ type WorkflowLoopContextOf,
1353
+ type WorkflowBranchContextOf,
1354
+ workflow,
1355
+ } from "rivetkit/workflow";
1356
+
1357
+ export const primaryServiceActor = actor({
1358
+ actions: {
1359
+ fetchValue: async () => {
1360
+ await new Promise(resolve => setTimeout(resolve, 500));
1361
+ return "primary";
1362
+ },
1363
+ },
1364
+ });
1365
+
1366
+ export const fallbackServiceActor = actor({
1367
+ actions: {
1368
+ fetchValue: async () => "fallback",
1369
+ },
1370
+ });
1371
+
1372
+ export const timeoutFallbackActor = actor({
1373
+ state: {
1374
+ lastSource: "none" as "none" | "primary" | "fallback",
1375
+ lastValue: "",
1376
+ },
1377
+ run: workflow(async ctx => {
1378
+ await ctx.loop("timeout-loop", async loopCtx => {
1379
+ await loopCtx.queue.nextBatch("wait-request", {
1380
+ timeout: 30_000,
1381
+ });
1382
+
1383
+ const winner = await loopCtx.race("primary-vs-timeout", [
1384
+ {
1385
+ name: "primary",
1386
+ run: async raceCtx =>
1387
+ await raceCtx.step("call-primary", async () => callPrimaryValue(raceCtx)),
1388
+ },
1389
+ {
1390
+ name: "timeout",
1391
+ run: async raceCtx => {
1392
+ await raceCtx.sleep("primary-timeout", 200);
1393
+ return "timeout";
1394
+ },
1395
+ },
1396
+ ]);
1397
+
1398
+ let value = winner.value as string;
1399
+ let source: "primary" | "fallback" = "primary";
1400
+
1401
+ if (winner.winner === "timeout") {
1402
+ value = (await loopCtx.step("fallback-call", async () =>
1403
+ callFallbackValue(loopCtx)
1404
+ )) as string;
1405
+ source = "fallback";
1406
+ }
1407
+
1408
+ await loopCtx.step("record-choice", async () => {
1409
+ loopCtx.state.lastSource = source;
1410
+ loopCtx.state.lastValue = value;
1411
+ });
1412
+ });
1413
+ }),
1414
+ actions: {
1415
+ getState: c => c.state,
1416
+ },
1417
+ });
1418
+
1419
+ async function callPrimaryValue(
1420
+ ctx: WorkflowLoopContextOf<typeof timeoutFallbackActor>
1421
+ ): Promise<string> {
1422
+ const client = ctx.client();
1423
+ const primary = client.primaryServiceActor.getOrCreate(["main"]);
1424
+ return await primary.fetchValue();
1425
+ }
1426
+
1427
+ async function callFallbackValue(
1428
+ ctx: WorkflowLoopContextOf<typeof timeoutFallbackActor>
1429
+ ): Promise<string> {
1430
+ const client = ctx.client();
1431
+ const fallback = client.fallbackServiceActor.getOrCreate(["main"]);
1432
+ return await fallback.fetchValue();
1433
+ }
1434
+
1435
+ export const registry = setup({
1436
+ use: { timeoutFallbackActor, primaryServiceActor, fallbackServiceActor },
1437
+ });
1438
+ ```
1439
+
1440
+ ### Cross-actor saga (compensating actions)
1441
+
1442
+ Use this when a workflow spans multiple actors and each side effect may need compensation.
1443
+
1444
+ ```ts
1445
+ import { actor, setup } from "rivetkit";
1446
+ import {
1447
+ type WorkflowContextOf,
1448
+ type WorkflowLoopContextOf,
1449
+ type WorkflowBranchContextOf,
1450
+ workflow,
1451
+ } from "rivetkit/workflow";
1452
+
1453
+ type CheckoutMessage = {
1454
+ orderId: string;
1455
+ amount: number;
1456
+ };
1457
+
1458
+ export const inventoryActor = actor({
1459
+ actions: {
1460
+ reserve: async (_c, orderId: string) => `reserve-${orderId}`,
1461
+ release: async (_c, reservationId: string) => reservationId,
1462
+ },
1463
+ });
1464
+
1465
+ export const billingActor = actor({
1466
+ actions: {
1467
+ charge: async (_c, amount: number) => `charge-${amount}`,
1468
+ refund: async (_c, chargeId: string) => chargeId,
1469
+ },
1470
+ });
1471
+
1472
+ export const checkoutSagaActor = actor({
1473
+ state: {
1474
+ completedOrders: 0,
1475
+ },
1476
+ run: workflow(async ctx => {
1477
+ await ctx.loop("checkout-loop", async loopCtx => {
1478
+ const [message] = await loopCtx.queue.nextBatch("wait-order", {
1479
+ timeout: 30_000,
1480
+ });
1481
+
1482
+ if (!message) return;
1483
+ const checkout = message.body as CheckoutMessage;
1484
+
1485
+ await loopCtx.rollbackCheckpoint("checkout-saga");
1486
+
1487
+ await loopCtx.step({
1488
+ name: "reserve-inventory",
1489
+ run: async () => reserveInventoryForCheckout(loopCtx, checkout.orderId),
1490
+ rollback: async (_rollbackCtx, output) => {
1491
+ await releaseInventoryForCheckout(loopCtx, output as string);
1492
+ },
1493
+ });
1494
+
1495
+ await loopCtx.step({
1496
+ name: "charge-card",
1497
+ run: async () => chargeCheckout(loopCtx, checkout.amount),
1498
+ rollback: async (_rollbackCtx, output) => {
1499
+ await refundCheckout(loopCtx, output as string);
1500
+ },
1501
+ });
1502
+
1503
+ await loopCtx.step("mark-complete", async () => markOrderComplete(loopCtx));
1504
+ });
1505
+ }),
1506
+ actions: {
1507
+ getState: c => c.state,
1508
+ },
1509
+ });
1510
+
1511
+ async function reserveInventoryForCheckout(
1512
+ ctx: WorkflowLoopContextOf<typeof checkoutSagaActor>,
1513
+ orderId: string
1514
+ ): Promise<string> {
1515
+ const client = ctx.client();
1516
+ const inventory = client.inventoryActor.getOrCreate(["main"]);
1517
+ return await inventory.reserve(orderId);
1518
+ }
1519
+
1520
+ async function releaseInventoryForCheckout(
1521
+ ctx: WorkflowLoopContextOf<typeof checkoutSagaActor>,
1522
+ reservationId: string
1523
+ ): Promise<void> {
1524
+ const client = ctx.client();
1525
+ const inventory = client.inventoryActor.getOrCreate(["main"]);
1526
+ await inventory.release(reservationId);
1527
+ }
1528
+
1529
+ async function chargeCheckout(
1530
+ ctx: WorkflowLoopContextOf<typeof checkoutSagaActor>,
1531
+ amount: number
1532
+ ): Promise<string> {
1533
+ const client = ctx.client();
1534
+ const billing = client.billingActor.getOrCreate(["main"]);
1535
+ return await billing.charge(amount);
1536
+ }
1537
+
1538
+ async function refundCheckout(
1539
+ ctx: WorkflowLoopContextOf<typeof checkoutSagaActor>,
1540
+ chargeId: string
1541
+ ): Promise<void> {
1542
+ const client = ctx.client();
1543
+ const billing = client.billingActor.getOrCreate(["main"]);
1544
+ await billing.refund(chargeId);
1545
+ }
1546
+
1547
+ function markOrderComplete(ctx: WorkflowLoopContextOf<typeof checkoutSagaActor>): void {
1548
+ ctx.state.completedOrders += 1;
1549
+ }
1550
+
1551
+ export const registry = setup({
1552
+ use: { checkoutSagaActor, inventoryActor, billingActor },
1553
+ });
1554
+ ```
1555
+
1556
+ ### Signal-driven control loop
1557
+
1558
+ Use this when workflow progress should be triggered by commands/events instead of fixed polling intervals.
1559
+
1560
+ ```ts
1561
+ import { actor, setup } from "rivetkit";
1562
+ import {
1563
+ type WorkflowContextOf,
1564
+ type WorkflowLoopContextOf,
1565
+ type WorkflowBranchContextOf,
1566
+ workflow,
1567
+ } from "rivetkit/workflow";
1568
+
1569
+ type ControlSignal = { kind: "pause" | "resume" | "stop" };
1570
+
1571
+ export const controlLoopActor = actor({
1572
+ state: {
1573
+ mode: "running" as "running" | "paused" | "stopped",
1574
+ handledSignals: 0,
1575
+ },
1576
+ run: workflow(async ctx => {
1577
+ await ctx.loop("control-loop", async loopCtx => {
1578
+ const [message] = await loopCtx.queue.nextBatch("wait-signal", {
1579
+ timeout: 30_000,
1580
+ });
1581
+
1582
+ if (!message) return;
1583
+ const signal = message.body as ControlSignal;
1584
+
1585
+ await loopCtx.step("apply-signal", async () => applyControlSignal(loopCtx, signal.kind));
1586
+ });
1587
+ }),
1588
+ actions: {
1589
+ getState: c => c.state,
1590
+ },
1591
+ });
1592
+
1593
+ function applyControlSignal(
1594
+ ctx: WorkflowLoopContextOf<typeof controlLoopActor>,
1595
+ kind: ControlSignal["kind"]
1596
+ ): void {
1597
+ ctx.state.handledSignals += 1;
1598
+ if (kind === "pause") ctx.state.mode = "paused";
1599
+ if (kind === "resume") ctx.state.mode = "running";
1600
+ if (kind === "stop") ctx.state.mode = "stopped";
1601
+ }
1602
+
1603
+ export const registry = setup({ use: { controlLoopActor } });
1604
+ ```
1605
+
1606
+ ### Poll + backoff loop
1607
+
1608
+ Use this when an external dependency has variable availability and retries should slow down after failures.
1609
+
1610
+ ```ts
1611
+ import { actor, setup } from "rivetkit";
1612
+ import {
1613
+ type WorkflowContextOf,
1614
+ type WorkflowLoopContextOf,
1615
+ type WorkflowBranchContextOf,
1616
+ workflow,
1617
+ } from "rivetkit/workflow";
1618
+
1619
+ async function pollExternal(attempt: number): Promise<boolean> {
1620
+ return attempt % 3 === 0;
1621
+ }
1622
+
1623
+ export const pollBackoffActor = actor({
1624
+ state: {
1625
+ attempts: 0,
1626
+ backoffMs: 100,
1627
+ status: "unknown" as "unknown" | "healthy" | "retrying",
1628
+ },
1629
+ run: workflow(async ctx => {
1630
+ await ctx.loop("poll-loop", async loopCtx => {
1631
+ const success = await loopCtx.step("poll-target", async () => {
1632
+ loopCtx.state.attempts += 1;
1633
+ return pollExternal(loopCtx.state.attempts);
1634
+ });
1635
+
1636
+ if (success) {
1637
+ await loopCtx.step("reset-backoff", async () => {
1638
+ loopCtx.state.status = "healthy";
1639
+ loopCtx.state.backoffMs = 100;
1640
+ });
1641
+ await loopCtx.sleep("healthy-interval", 1_000);
1642
+ return;
1643
+ }
1644
+
1645
+ await loopCtx.step("grow-backoff", async () => {
1646
+ loopCtx.state.status = "retrying";
1647
+ loopCtx.state.backoffMs = Math.min(loopCtx.state.backoffMs * 2, 5_000);
1648
+ });
1649
+
1650
+ await loopCtx.sleep("retry-delay", loopCtx.state.backoffMs);
1651
+ });
1652
+ }),
1653
+ actions: {
1654
+ getState: c => c.state,
1655
+ },
1656
+ });
1657
+
1658
+ export const registry = setup({ use: { pollBackoffActor } });
1659
+ ```
1660
+
1661
+ ### Child worker orchestration
1662
+
1663
+ Use this when one workflow coordinates many child workers (actors or worker workflows) and manages their lifecycle.
1664
+
1665
+ ```ts
1666
+ import { actor, setup } from "rivetkit";
1667
+ import {
1668
+ type WorkflowContextOf,
1669
+ type WorkflowLoopContextOf,
1670
+ type WorkflowBranchContextOf,
1671
+ workflow,
1672
+ } from "rivetkit/workflow";
1673
+
1674
+ type BatchMessage = { payload: number };
1675
+
1676
+ export const childWorkerActor = actor({
1677
+ actions: {
1678
+ process: async (_c, payload: number) => payload * 3,
1679
+ },
1680
+ });
1681
+
1682
+ export const orchestratorActor = actor({
1683
+ state: {
1684
+ lastTotal: 0,
1685
+ },
1686
+ run: workflow(async ctx => {
1687
+ await ctx.step("start-children", async () => startChildren(ctx));
1688
+
1689
+ await ctx.loop("orchestrate-loop", async loopCtx => {
1690
+ const [message] = await loopCtx.queue.nextBatch("wait-batch", {
1691
+ timeout: 30_000,
1692
+ });
1693
+
1694
+ if (!message) return;
1695
+ const batch = message.body as BatchMessage;
1696
+
1697
+ const results = await loopCtx.join("collect-updates", {
1698
+ a: {
1699
+ run: async joinCtx =>
1700
+ await joinCtx.step("run-child-a", async () =>
1701
+ runChildWorker(joinCtx, "child-a", batch.payload)
1702
+ ),
1703
+ },
1704
+ b: {
1705
+ run: async joinCtx =>
1706
+ await joinCtx.step("run-child-b", async () =>
1707
+ runChildWorker(joinCtx, "child-b", batch.payload)
1708
+ ),
1709
+ },
1710
+ c: {
1711
+ run: async joinCtx =>
1712
+ await joinCtx.step("run-child-c", async () =>
1713
+ runChildWorker(joinCtx, "child-c", batch.payload)
1714
+ ),
1715
+ },
1716
+ });
1717
+
1718
+ await loopCtx.step("reconcile", async () => {
1719
+ loopCtx.state.lastTotal = results.a + results.b + results.c;
1720
+ });
1721
+ });
1722
+ }),
1723
+ actions: {
1724
+ getState: c => c.state,
1725
+ },
1726
+ });
1727
+
1728
+ async function startChildren(ctx: WorkflowContextOf<typeof orchestratorActor>): Promise<void> {
1729
+ const client = ctx.client();
1730
+ await client.childWorkerActor.getOrCreate(["child-a"]).process(0);
1731
+ await client.childWorkerActor.getOrCreate(["child-b"]).process(0);
1732
+ await client.childWorkerActor.getOrCreate(["child-c"]).process(0);
1733
+ }
1734
+
1735
+ async function runChildWorker(
1736
+ ctx: WorkflowBranchContextOf<typeof orchestratorActor>,
1737
+ workerId: "child-a" | "child-b" | "child-c",
1738
+ payload: number
1739
+ ): Promise<number> {
1740
+ const client = ctx.client();
1741
+ return await client.childWorkerActor.getOrCreate([workerId]).process(payload);
1742
+ }
1743
+
1744
+ export const registry = setup({ use: { orchestratorActor, childWorkerActor } });
1745
+ ```
1746
+
1747
+ ### Bounded drain + concurrency cap
1748
+
1749
+ Use this when inbound work can spike and you need predictable per-iteration limits.
1750
+
1751
+ ```ts
1752
+ import { actor, setup } from "rivetkit";
1753
+ import {
1754
+ type WorkflowContextOf,
1755
+ type WorkflowLoopContextOf,
1756
+ type WorkflowBranchContextOf,
1757
+ workflow,
1758
+ } from "rivetkit/workflow";
1759
+
1760
+ type WorkMessage = { id: string; value: number };
1761
+
1762
+ const MAX_PER_ITERATION = 10;
1763
+ const CONCURRENCY_LIMIT = 3;
1764
+
1765
+ async function processWork(value: number): Promise<number> {
1766
+ return value * 2;
1767
+ }
1768
+
1769
+ async function runWithLimit<T>(
1770
+ limit: number,
1771
+ items: T[],
1772
+ fn: (item: T) => Promise<void>
1773
+ ): Promise<void> {
1774
+ let nextIndex = 0;
1775
+ const workers = Array.from({ length: limit }, async () => {
1776
+ while (nextIndex < items.length) {
1777
+ const current = items[nextIndex];
1778
+ nextIndex += 1;
1779
+ await fn(current);
1780
+ }
1781
+ });
1782
+ await Promise.all(workers);
1783
+ }
1784
+
1785
+ export const boundedDrainActor = actor({
1786
+ state: {
1787
+ processed: 0,
1788
+ lastWindowSize: 0,
1789
+ lastWindowTotal: 0,
1790
+ },
1791
+ run: workflow(async ctx => {
1792
+ await ctx.loop("bounded-drain-loop", async loopCtx => {
1793
+ const window: WorkMessage[] = [];
1794
+
1795
+ for (let i = 0; i < MAX_PER_ITERATION; i += 1) {
1796
+ const [message] = await loopCtx.queue.nextBatch("wait-work", {
1797
+ timeout: i === 0 ? 30_000 : 10,
1798
+ });
1799
+ if (!message) break;
1800
+ window.push(message.body as WorkMessage);
1801
+ }
1802
+
1803
+ if (window.length === 0) return;
1804
+
1805
+ await loopCtx.step("process-window", async () => processWindow(loopCtx, window));
1806
+ });
1807
+ }),
1808
+ actions: {
1809
+ getState: c => c.state,
1810
+ },
1811
+ });
1812
+
1813
+ async function processWindow(
1814
+ ctx: WorkflowLoopContextOf<typeof boundedDrainActor>,
1815
+ window: WorkMessage[]
1816
+ ): Promise<void> {
1817
+ let windowTotal = 0;
1818
+ await runWithLimit(CONCURRENCY_LIMIT, window, async work => {
1819
+ const result = await processWork(work.value);
1820
+ windowTotal += result;
1821
+ });
1822
+
1823
+ ctx.state.processed += window.length;
1824
+ ctx.state.lastWindowSize = window.length;
1825
+ ctx.state.lastWindowTotal = windowTotal;
1826
+ }
1827
+
1828
+ export const registry = setup({ use: { boundedDrainActor } });
1829
+ ```
1830
+
1831
+ ### Versioned workflow evolution
1832
+
1833
+ Use this when workflow structure changes across deployments and old histories must still replay.
1834
+
1835
+ ```ts
1836
+ import { actor, setup } from "rivetkit";
1837
+ import {
1838
+ type WorkflowContextOf,
1839
+ type WorkflowLoopContextOf,
1840
+ type WorkflowBranchContextOf,
1841
+ workflow,
1842
+ } from "rivetkit/workflow";
1843
+
1844
+ export const versionedWorkflowActor = actor({
1845
+ state: {
1846
+ runs: 0,
1847
+ },
1848
+ run: workflow(async ctx => {
1849
+ await ctx.step("validate-v2", async () => {
1850
+ ctx.state.runs += 1;
1851
+ });
1852
+
1853
+ await ctx.removed("validate-v1", "step");
1854
+
1855
+ await ctx.loop("main-loop-v2", async loopCtx => {
1856
+ await loopCtx.sleep("idle", 500);
1857
+ await loopCtx.step("heartbeat-v2", async () => {
1858
+ loopCtx.state.runs += 1;
1859
+ });
1860
+ });
1861
+ }),
1862
+ actions: {
1863
+ getState: c => c.state,
1864
+ },
1865
+ });
1866
+
1867
+ export const registry = setup({ use: { versionedWorkflowActor } });
1868
+ ```
1869
+
1870
+ ### Checkpoint-friendly loop design
1871
+
1872
+ Use this when you need reliable replay and resume semantics across crashes and restarts.
1873
+
1874
+ ```ts
1875
+ import { actor, setup } from "rivetkit";
1876
+ import {
1877
+ type WorkflowContextOf,
1878
+ type WorkflowLoopContextOf,
1879
+ type WorkflowBranchContextOf,
1880
+ workflow,
1881
+ } from "rivetkit/workflow";
1882
+
1883
+ type PaymentMessage = { id: string; amount: number };
1884
+
1885
+ export const checkpointFriendlyActor = actor({
1886
+ state: {
1887
+ appliedCount: 0,
1888
+ totalAmount: 0,
1889
+ lastPaymentId: null as string | null,
1890
+ },
1891
+ run: workflow(async ctx => {
1892
+ await ctx.loop("payment-loop", async loopCtx => {
1893
+ const [message] = await loopCtx.queue.nextBatch("wait-payment", {
1894
+ timeout: 30_000,
1895
+ });
1896
+
1897
+ if (!message) return;
1898
+ const payment = message.body as PaymentMessage;
1899
+
1900
+ await loopCtx.rollbackCheckpoint("apply-payment-checkpoint");
1901
+
1902
+ const plan = (await loopCtx.step("build-plan", async () => buildPaymentPlan(payment))) as {
1903
+ paymentId: string;
1904
+ amount: number;
1905
+ };
1906
+
1907
+ await loopCtx.step("apply-side-effects", async () => {
1908
+ loopCtx.state.appliedCount += 1;
1909
+ loopCtx.state.totalAmount += plan.amount;
1910
+ loopCtx.state.lastPaymentId = plan.paymentId;
1911
+ });
1912
+ });
1913
+ }),
1914
+ actions: {
1915
+ getState: c => c.state,
1916
+ },
1917
+ });
1918
+
1919
+ function buildPaymentPlan(payment: PaymentMessage): {
1920
+ paymentId: string;
1921
+ amount: number;
1922
+ } {
1923
+ return {
1924
+ paymentId: payment.id,
1925
+ amount: payment.amount,
1926
+ };
1927
+ }
1928
+
1929
+ export const registry = setup({ use: { checkpointFriendlyActor } });
1930
+ ```
1931
+
1932
+ ## Migrations
1933
+
1934
+ - Keep workflow entry names stable once deployed.
1935
+ - If an old entry was removed or renamed, call `ctx.removed(name, originalType)`.
1936
+ - This keeps replay compatible across deployments.
1937
+
1938
+ ## Step-only access to actor APIs
1939
+
1940
+ `state`, `vars`, `db`, `client()`, and connection/event APIs are only valid inside `ctx.step(...)` callbacks.
1941
+
1942
+ Use non-step workflow code for orchestration only: queue waits, sleeps, loops, joins, races, and rollback boundaries. Keep actor-local side effects in steps.
1943
+
1944
+ ## Debugging
1945
+
1946
+ - `GET /inspector/workflow-history` returns workflow history status for an actor.
1947
+ - Response includes `isWorkflowEnabled` and `history`.
1948
+ - In non-dev mode, inspector endpoints require authorization.
1949
+
1950
+ ## Recommendations
1951
+
1952
+ - Prefer queue-driven loops for long-lived workflows.
1953
+ - Structure long-lived workflows with setup and teardown around the main loop.
1954
+ - Keep actor state changes and side effects inside steps.
1955
+ - Store workflow progress in `state` and broadcast updates as progress changes.
1956
+ - Use timeouts and rollback for external side effects.
1957
+
1958
+ _Source doc path: /docs/actors/workflows_