memory-journal-mcp 7.7.0 → 8.0.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 (531) hide show
  1. package/README.md +126 -56
  2. package/dist/chunk-6OHRCNYW.js +3231 -0
  3. package/dist/chunk-JFMITANR.js +5168 -0
  4. package/dist/{chunk-QCQPAF4I.js → chunk-MWNLAEHR.js} +301 -4321
  5. package/dist/{chunk-ARLYSFSI.js → chunk-UHSO65A4.js} +4242 -6092
  6. package/dist/cli.js +21 -3
  7. package/dist/index.d.ts +16 -13
  8. package/dist/index.js +4 -2
  9. package/dist/resources-IJVKDFGS.js +2 -0
  10. package/dist/tools-44DGXE3V.js +2 -0
  11. package/dist/worker-script.js +201 -20
  12. package/package.json +7 -4
  13. package/skills/README.md +62 -25
  14. package/skills/adversarial-performance/SKILL.md +139 -0
  15. package/skills/adversarial-performance/references/audit-categories.md +462 -0
  16. package/skills/adversarial-performance/references/copilot-performance-prompts.md +44 -0
  17. package/skills/adversarial-performance/references/copilot-usage.md +16 -0
  18. package/skills/adversarial-performance/references/feedback-loop.md +177 -0
  19. package/skills/adversarial-performance/references/multi-pass-performance-protocol.md +398 -0
  20. package/skills/adversarial-planner/SKILL.md +23 -54
  21. package/skills/adversarial-planner/references/copilot-integration.md +25 -40
  22. package/skills/adversarial-planner/references/copilot-usage.md +16 -0
  23. package/skills/adversarial-planner/references/multi-pass-protocol.md +4 -0
  24. package/skills/adversarial-security/SKILL.md +149 -0
  25. package/skills/adversarial-security/references/adversarial-base-protocol.md +44 -0
  26. package/skills/adversarial-security/references/audit-categories.md +723 -0
  27. package/skills/adversarial-security/references/copilot-security-prompts.md +142 -0
  28. package/skills/adversarial-security/references/copilot-usage.md +16 -0
  29. package/skills/adversarial-security/references/feedback-loop.md +206 -0
  30. package/skills/adversarial-security/references/journal-opt-out.md +7 -0
  31. package/skills/adversarial-security/references/multi-pass-security-protocol.md +403 -0
  32. package/skills/adversarial-skill-audit/SKILL.md +118 -0
  33. package/skills/adversarial-skill-audit/references/audit-categories.md +308 -0
  34. package/skills/adversarial-skill-audit/references/copilot-skill-prompts.md +68 -0
  35. package/skills/adversarial-skill-audit/references/copilot-usage.md +16 -0
  36. package/skills/adversarial-skill-audit/references/feedback-loop.md +155 -0
  37. package/skills/adversarial-skill-audit/references/multi-pass-skill-protocol.md +367 -0
  38. package/skills/adversarial-skill-audit/scripts/check-skills.ps1 +48 -0
  39. package/skills/adversarial-skill-audit/scripts/run-copilot.ps1 +52 -0
  40. package/skills/adversarial-workflow-audit/SKILL.md +82 -0
  41. package/skills/adversarial-workflow-audit/references/audit-categories.md +28 -0
  42. package/skills/adversarial-workflow-audit/references/copilot-usage.md +16 -0
  43. package/skills/adversarial-workflow-audit/scripts/check-workflows.ps1 +24 -0
  44. package/skills/agents-sdk/SKILL.md +220 -0
  45. package/skills/agents-sdk/references/callable.md +92 -0
  46. package/skills/agents-sdk/references/codemode.md +209 -0
  47. package/skills/agents-sdk/references/email.md +144 -0
  48. package/skills/agents-sdk/references/mcp/SKILL.md +65 -0
  49. package/skills/agents-sdk/references/mcp/code-mode-reference.md +245 -0
  50. package/skills/agents-sdk/references/mcp/oauth-reference.md +359 -0
  51. package/skills/agents-sdk/references/mcp/references/architecture-reference.md +208 -0
  52. package/skills/agents-sdk/references/mcp/references/cloudflare-quickstart.md +156 -0
  53. package/skills/agents-sdk/references/mcp/references/error-handling.md +343 -0
  54. package/skills/agents-sdk/references/mcp/references/http-security.md +164 -0
  55. package/skills/agents-sdk/references/mcp/references/implementation-guide.md +507 -0
  56. package/skills/agents-sdk/references/mcp/references/testing-reference.md +171 -0
  57. package/skills/agents-sdk/references/mcp.md +157 -0
  58. package/skills/agents-sdk/references/state-scheduling.md +164 -0
  59. package/skills/agents-sdk/references/streaming-chat.md +168 -0
  60. package/skills/agents-sdk/references/workflows.md +136 -0
  61. package/skills/auth-identity/SKILL.md +48 -0
  62. package/skills/autonomous-dev/SKILL.md +46 -23
  63. package/skills/autonomous-dev/references/workflow_orchestration.md +22 -0
  64. package/skills/aws/SKILL.md +39 -0
  65. package/skills/azure/SKILL.md +38 -0
  66. package/skills/bin/sync.js +7 -1
  67. package/skills/biome/SKILL.md +59 -0
  68. package/skills/bun/SKILL.md +8 -2
  69. package/skills/cloudflare/SKILL.md +37 -0
  70. package/skills/cloudflare/references/agents-sdk/README.md +95 -0
  71. package/skills/cloudflare/references/agents-sdk/api.md +195 -0
  72. package/skills/cloudflare/references/agents-sdk/configuration.md +178 -0
  73. package/skills/cloudflare/references/agents-sdk/gotchas.md +173 -0
  74. package/skills/cloudflare/references/agents-sdk/patterns.md +215 -0
  75. package/skills/cloudflare/references/ai-gateway/README.md +176 -0
  76. package/skills/cloudflare/references/ai-gateway/configuration.md +117 -0
  77. package/skills/cloudflare/references/ai-gateway/dynamic-routing.md +88 -0
  78. package/skills/cloudflare/references/ai-gateway/features.md +96 -0
  79. package/skills/cloudflare/references/ai-gateway/sdk-integration.md +110 -0
  80. package/skills/cloudflare/references/ai-gateway/troubleshooting.md +90 -0
  81. package/skills/cloudflare/references/ai-search/README.md +145 -0
  82. package/skills/cloudflare/references/ai-search/api.md +87 -0
  83. package/skills/cloudflare/references/ai-search/configuration.md +91 -0
  84. package/skills/cloudflare/references/ai-search/gotchas.md +92 -0
  85. package/skills/cloudflare/references/ai-search/patterns.md +87 -0
  86. package/skills/cloudflare/references/analytics-engine/README.md +96 -0
  87. package/skills/cloudflare/references/analytics-engine/api.md +112 -0
  88. package/skills/cloudflare/references/analytics-engine/configuration.md +107 -0
  89. package/skills/cloudflare/references/analytics-engine/gotchas.md +87 -0
  90. package/skills/cloudflare/references/analytics-engine/patterns.md +83 -0
  91. package/skills/cloudflare/references/api/README.md +66 -0
  92. package/skills/cloudflare/references/api/api.md +205 -0
  93. package/skills/cloudflare/references/api/configuration.md +158 -0
  94. package/skills/cloudflare/references/api/gotchas.md +231 -0
  95. package/skills/cloudflare/references/api/patterns.md +208 -0
  96. package/skills/cloudflare/references/api-shield/README.md +44 -0
  97. package/skills/cloudflare/references/api-shield/api.md +153 -0
  98. package/skills/cloudflare/references/api-shield/configuration.md +210 -0
  99. package/skills/cloudflare/references/api-shield/gotchas.md +132 -0
  100. package/skills/cloudflare/references/api-shield/patterns.md +185 -0
  101. package/skills/cloudflare/references/argo-smart-routing/README.md +96 -0
  102. package/skills/cloudflare/references/argo-smart-routing/api.md +253 -0
  103. package/skills/cloudflare/references/argo-smart-routing/configuration.md +205 -0
  104. package/skills/cloudflare/references/argo-smart-routing/gotchas.md +115 -0
  105. package/skills/cloudflare/references/argo-smart-routing/patterns.md +107 -0
  106. package/skills/cloudflare/references/bindings/README.md +127 -0
  107. package/skills/cloudflare/references/bindings/api.md +214 -0
  108. package/skills/cloudflare/references/bindings/configuration.md +200 -0
  109. package/skills/cloudflare/references/bindings/gotchas.md +210 -0
  110. package/skills/cloudflare/references/bindings/patterns.md +205 -0
  111. package/skills/cloudflare/references/bot-management/README.md +95 -0
  112. package/skills/cloudflare/references/bot-management/api.md +175 -0
  113. package/skills/cloudflare/references/bot-management/configuration.md +175 -0
  114. package/skills/cloudflare/references/bot-management/gotchas.md +116 -0
  115. package/skills/cloudflare/references/bot-management/patterns.md +181 -0
  116. package/skills/cloudflare/references/browser-rendering/README.md +84 -0
  117. package/skills/cloudflare/references/browser-rendering/api.md +108 -0
  118. package/skills/cloudflare/references/browser-rendering/configuration.md +78 -0
  119. package/skills/cloudflare/references/browser-rendering/gotchas.md +91 -0
  120. package/skills/cloudflare/references/browser-rendering/patterns.md +93 -0
  121. package/skills/cloudflare/references/c3/README.md +111 -0
  122. package/skills/cloudflare/references/c3/api.md +71 -0
  123. package/skills/cloudflare/references/c3/configuration.md +85 -0
  124. package/skills/cloudflare/references/c3/gotchas.md +97 -0
  125. package/skills/cloudflare/references/c3/patterns.md +84 -0
  126. package/skills/cloudflare/references/cache-reserve/README.md +150 -0
  127. package/skills/cloudflare/references/cache-reserve/api.md +184 -0
  128. package/skills/cloudflare/references/cache-reserve/configuration.md +170 -0
  129. package/skills/cloudflare/references/cache-reserve/gotchas.md +136 -0
  130. package/skills/cloudflare/references/cache-reserve/patterns.md +197 -0
  131. package/skills/cloudflare/references/containers/README.md +87 -0
  132. package/skills/cloudflare/references/containers/api.md +197 -0
  133. package/skills/cloudflare/references/containers/configuration.md +191 -0
  134. package/skills/cloudflare/references/containers/gotchas.md +182 -0
  135. package/skills/cloudflare/references/containers/patterns.md +204 -0
  136. package/skills/cloudflare/references/cron-triggers/README.md +101 -0
  137. package/skills/cloudflare/references/cron-triggers/api.md +224 -0
  138. package/skills/cloudflare/references/cron-triggers/configuration.md +190 -0
  139. package/skills/cloudflare/references/cron-triggers/gotchas.md +207 -0
  140. package/skills/cloudflare/references/cron-triggers/patterns.md +274 -0
  141. package/skills/cloudflare/references/d1/README.md +137 -0
  142. package/skills/cloudflare/references/d1/api.md +213 -0
  143. package/skills/cloudflare/references/d1/configuration.md +198 -0
  144. package/skills/cloudflare/references/d1/gotchas.md +98 -0
  145. package/skills/cloudflare/references/d1/patterns.md +240 -0
  146. package/skills/cloudflare/references/ddos/README.md +42 -0
  147. package/skills/cloudflare/references/ddos/api.md +158 -0
  148. package/skills/cloudflare/references/ddos/configuration.md +94 -0
  149. package/skills/cloudflare/references/ddos/gotchas.md +114 -0
  150. package/skills/cloudflare/references/ddos/patterns.md +220 -0
  151. package/skills/cloudflare/references/decision-trees.md +95 -0
  152. package/skills/cloudflare/references/do-storage/README.md +79 -0
  153. package/skills/cloudflare/references/do-storage/api.md +107 -0
  154. package/skills/cloudflare/references/do-storage/configuration.md +114 -0
  155. package/skills/cloudflare/references/do-storage/gotchas.md +153 -0
  156. package/skills/cloudflare/references/do-storage/patterns.md +210 -0
  157. package/skills/cloudflare/references/do-storage/testing.md +186 -0
  158. package/skills/cloudflare/references/durable-objects/README.md +194 -0
  159. package/skills/cloudflare/references/durable-objects/api.md +205 -0
  160. package/skills/cloudflare/references/durable-objects/configuration.md +160 -0
  161. package/skills/cloudflare/references/durable-objects/gotchas.md +200 -0
  162. package/skills/cloudflare/references/durable-objects/patterns.md +205 -0
  163. package/skills/cloudflare/references/email-routing/README.md +89 -0
  164. package/skills/cloudflare/references/email-routing/api.md +192 -0
  165. package/skills/cloudflare/references/email-routing/configuration.md +187 -0
  166. package/skills/cloudflare/references/email-routing/gotchas.md +203 -0
  167. package/skills/cloudflare/references/email-routing/patterns.md +241 -0
  168. package/skills/cloudflare/references/email-workers/README.md +153 -0
  169. package/skills/cloudflare/references/email-workers/api.md +227 -0
  170. package/skills/cloudflare/references/email-workers/configuration.md +115 -0
  171. package/skills/cloudflare/references/email-workers/gotchas.md +133 -0
  172. package/skills/cloudflare/references/email-workers/patterns.md +108 -0
  173. package/skills/cloudflare/references/graphql-api/README.md +147 -0
  174. package/skills/cloudflare/references/graphql-api/api.md +175 -0
  175. package/skills/cloudflare/references/graphql-api/configuration.md +151 -0
  176. package/skills/cloudflare/references/graphql-api/gotchas.md +111 -0
  177. package/skills/cloudflare/references/graphql-api/patterns.md +276 -0
  178. package/skills/cloudflare/references/hyperdrive/README.md +84 -0
  179. package/skills/cloudflare/references/hyperdrive/api.md +149 -0
  180. package/skills/cloudflare/references/hyperdrive/configuration.md +166 -0
  181. package/skills/cloudflare/references/hyperdrive/gotchas.md +77 -0
  182. package/skills/cloudflare/references/hyperdrive/patterns.md +203 -0
  183. package/skills/cloudflare/references/images/README.md +65 -0
  184. package/skills/cloudflare/references/images/api.md +101 -0
  185. package/skills/cloudflare/references/images/configuration.md +206 -0
  186. package/skills/cloudflare/references/images/gotchas.md +106 -0
  187. package/skills/cloudflare/references/images/patterns.md +126 -0
  188. package/skills/cloudflare/references/kv/README.md +90 -0
  189. package/skills/cloudflare/references/kv/api.md +163 -0
  190. package/skills/cloudflare/references/kv/configuration.md +148 -0
  191. package/skills/cloudflare/references/kv/gotchas.md +133 -0
  192. package/skills/cloudflare/references/kv/patterns.md +195 -0
  193. package/skills/cloudflare/references/miniflare/README.md +113 -0
  194. package/skills/cloudflare/references/miniflare/api.md +204 -0
  195. package/skills/cloudflare/references/miniflare/configuration.md +174 -0
  196. package/skills/cloudflare/references/miniflare/gotchas.md +179 -0
  197. package/skills/cloudflare/references/miniflare/patterns.md +187 -0
  198. package/skills/cloudflare/references/network-interconnect/README.md +104 -0
  199. package/skills/cloudflare/references/network-interconnect/api.md +220 -0
  200. package/skills/cloudflare/references/network-interconnect/configuration.md +123 -0
  201. package/skills/cloudflare/references/network-interconnect/gotchas.md +175 -0
  202. package/skills/cloudflare/references/network-interconnect/patterns.md +174 -0
  203. package/skills/cloudflare/references/observability/README.md +93 -0
  204. package/skills/cloudflare/references/observability/api.md +168 -0
  205. package/skills/cloudflare/references/observability/configuration.md +178 -0
  206. package/skills/cloudflare/references/observability/gotchas.md +125 -0
  207. package/skills/cloudflare/references/observability/patterns.md +105 -0
  208. package/skills/cloudflare/references/pages/README.md +92 -0
  209. package/skills/cloudflare/references/pages/api.md +205 -0
  210. package/skills/cloudflare/references/pages/configuration.md +216 -0
  211. package/skills/cloudflare/references/pages/gotchas.md +218 -0
  212. package/skills/cloudflare/references/pages/patterns.md +215 -0
  213. package/skills/cloudflare/references/pages-functions/README.md +104 -0
  214. package/skills/cloudflare/references/pages-functions/api.md +159 -0
  215. package/skills/cloudflare/references/pages-functions/configuration.md +130 -0
  216. package/skills/cloudflare/references/pages-functions/gotchas.md +102 -0
  217. package/skills/cloudflare/references/pages-functions/patterns.md +148 -0
  218. package/skills/cloudflare/references/pipelines/README.md +109 -0
  219. package/skills/cloudflare/references/pipelines/api.md +214 -0
  220. package/skills/cloudflare/references/pipelines/configuration.md +98 -0
  221. package/skills/cloudflare/references/pipelines/gotchas.md +84 -0
  222. package/skills/cloudflare/references/pipelines/patterns.md +87 -0
  223. package/skills/cloudflare/references/product-index.md +112 -0
  224. package/skills/cloudflare/references/pulumi/README.md +113 -0
  225. package/skills/cloudflare/references/pulumi/api.md +230 -0
  226. package/skills/cloudflare/references/pulumi/configuration.md +213 -0
  227. package/skills/cloudflare/references/pulumi/gotchas.md +205 -0
  228. package/skills/cloudflare/references/pulumi/patterns.md +260 -0
  229. package/skills/cloudflare/references/queues/README.md +99 -0
  230. package/skills/cloudflare/references/queues/api.md +211 -0
  231. package/skills/cloudflare/references/queues/configuration.md +151 -0
  232. package/skills/cloudflare/references/queues/gotchas.md +210 -0
  233. package/skills/cloudflare/references/queues/patterns.md +220 -0
  234. package/skills/cloudflare/references/r2/README.md +97 -0
  235. package/skills/cloudflare/references/r2/api.md +235 -0
  236. package/skills/cloudflare/references/r2/configuration.md +176 -0
  237. package/skills/cloudflare/references/r2/gotchas.md +190 -0
  238. package/skills/cloudflare/references/r2/patterns.md +203 -0
  239. package/skills/cloudflare/references/r2-data-catalog/README.md +157 -0
  240. package/skills/cloudflare/references/r2-data-catalog/api.md +199 -0
  241. package/skills/cloudflare/references/r2-data-catalog/configuration.md +205 -0
  242. package/skills/cloudflare/references/r2-data-catalog/gotchas.md +170 -0
  243. package/skills/cloudflare/references/r2-data-catalog/patterns.md +191 -0
  244. package/skills/cloudflare/references/r2-sql/README.md +138 -0
  245. package/skills/cloudflare/references/r2-sql/SKILL.md.backup +512 -0
  246. package/skills/cloudflare/references/r2-sql/api.md +159 -0
  247. package/skills/cloudflare/references/r2-sql/configuration.md +152 -0
  248. package/skills/cloudflare/references/r2-sql/gotchas.md +228 -0
  249. package/skills/cloudflare/references/r2-sql/patterns.md +230 -0
  250. package/skills/cloudflare/references/realtime-sfu/README.md +66 -0
  251. package/skills/cloudflare/references/realtime-sfu/api.md +164 -0
  252. package/skills/cloudflare/references/realtime-sfu/configuration.md +141 -0
  253. package/skills/cloudflare/references/realtime-sfu/gotchas.md +138 -0
  254. package/skills/cloudflare/references/realtime-sfu/patterns.md +187 -0
  255. package/skills/cloudflare/references/realtimekit/README.md +118 -0
  256. package/skills/cloudflare/references/realtimekit/api.md +234 -0
  257. package/skills/cloudflare/references/realtimekit/configuration.md +226 -0
  258. package/skills/cloudflare/references/realtimekit/gotchas.md +206 -0
  259. package/skills/cloudflare/references/realtimekit/patterns.md +240 -0
  260. package/skills/cloudflare/references/sandbox/README.md +104 -0
  261. package/skills/cloudflare/references/sandbox/api.md +200 -0
  262. package/skills/cloudflare/references/sandbox/configuration.md +154 -0
  263. package/skills/cloudflare/references/sandbox/gotchas.md +201 -0
  264. package/skills/cloudflare/references/sandbox/patterns.md +195 -0
  265. package/skills/cloudflare/references/secrets-store/README.md +77 -0
  266. package/skills/cloudflare/references/secrets-store/api.md +199 -0
  267. package/skills/cloudflare/references/secrets-store/configuration.md +187 -0
  268. package/skills/cloudflare/references/secrets-store/gotchas.md +97 -0
  269. package/skills/cloudflare/references/secrets-store/patterns.md +218 -0
  270. package/skills/cloudflare/references/smart-placement/README.md +143 -0
  271. package/skills/cloudflare/references/smart-placement/api.md +192 -0
  272. package/skills/cloudflare/references/smart-placement/configuration.md +202 -0
  273. package/skills/cloudflare/references/smart-placement/gotchas.md +180 -0
  274. package/skills/cloudflare/references/smart-placement/patterns.md +190 -0
  275. package/skills/cloudflare/references/snippets/README.md +74 -0
  276. package/skills/cloudflare/references/snippets/api.md +214 -0
  277. package/skills/cloudflare/references/snippets/configuration.md +239 -0
  278. package/skills/cloudflare/references/snippets/gotchas.md +104 -0
  279. package/skills/cloudflare/references/snippets/patterns.md +135 -0
  280. package/skills/cloudflare/references/spectrum/README.md +52 -0
  281. package/skills/cloudflare/references/spectrum/api.md +184 -0
  282. package/skills/cloudflare/references/spectrum/configuration.md +203 -0
  283. package/skills/cloudflare/references/spectrum/gotchas.md +155 -0
  284. package/skills/cloudflare/references/spectrum/patterns.md +206 -0
  285. package/skills/cloudflare/references/static-assets/README.md +65 -0
  286. package/skills/cloudflare/references/static-assets/api.md +201 -0
  287. package/skills/cloudflare/references/static-assets/configuration.md +186 -0
  288. package/skills/cloudflare/references/static-assets/gotchas.md +164 -0
  289. package/skills/cloudflare/references/static-assets/patterns.md +189 -0
  290. package/skills/cloudflare/references/stream/README.md +123 -0
  291. package/skills/cloudflare/references/stream/api-live.md +202 -0
  292. package/skills/cloudflare/references/stream/api.md +206 -0
  293. package/skills/cloudflare/references/stream/configuration.md +151 -0
  294. package/skills/cloudflare/references/stream/gotchas.md +139 -0
  295. package/skills/cloudflare/references/stream/patterns.md +217 -0
  296. package/skills/cloudflare/references/tail-workers/README.md +92 -0
  297. package/skills/cloudflare/references/tail-workers/api.md +203 -0
  298. package/skills/cloudflare/references/tail-workers/configuration.md +178 -0
  299. package/skills/cloudflare/references/tail-workers/gotchas.md +206 -0
  300. package/skills/cloudflare/references/tail-workers/patterns.md +190 -0
  301. package/skills/cloudflare/references/terraform/README.md +100 -0
  302. package/skills/cloudflare/references/terraform/api.md +178 -0
  303. package/skills/cloudflare/references/terraform/configuration.md +197 -0
  304. package/skills/cloudflare/references/terraform/gotchas.md +150 -0
  305. package/skills/cloudflare/references/terraform/patterns.md +174 -0
  306. package/skills/cloudflare/references/tunnel/README.md +137 -0
  307. package/skills/cloudflare/references/tunnel/api.md +205 -0
  308. package/skills/cloudflare/references/tunnel/configuration.md +163 -0
  309. package/skills/cloudflare/references/tunnel/gotchas.md +159 -0
  310. package/skills/cloudflare/references/tunnel/networking.md +174 -0
  311. package/skills/cloudflare/references/tunnel/patterns.md +199 -0
  312. package/skills/cloudflare/references/turn/README.md +86 -0
  313. package/skills/cloudflare/references/turn/api.md +236 -0
  314. package/skills/cloudflare/references/turn/configuration.md +181 -0
  315. package/skills/cloudflare/references/turn/gotchas.md +236 -0
  316. package/skills/cloudflare/references/turn/patterns.md +228 -0
  317. package/skills/cloudflare/references/turnstile/README.md +102 -0
  318. package/skills/cloudflare/references/turnstile/api.md +253 -0
  319. package/skills/cloudflare/references/turnstile/configuration.md +242 -0
  320. package/skills/cloudflare/references/turnstile/gotchas.md +253 -0
  321. package/skills/cloudflare/references/turnstile/patterns.md +195 -0
  322. package/skills/cloudflare/references/vectorize/README.md +133 -0
  323. package/skills/cloudflare/references/vectorize/api.md +89 -0
  324. package/skills/cloudflare/references/vectorize/configuration.md +91 -0
  325. package/skills/cloudflare/references/vectorize/gotchas.md +83 -0
  326. package/skills/cloudflare/references/vectorize/patterns.md +92 -0
  327. package/skills/cloudflare/references/waf/README.md +125 -0
  328. package/skills/cloudflare/references/waf/api.md +203 -0
  329. package/skills/cloudflare/references/waf/configuration.md +215 -0
  330. package/skills/cloudflare/references/waf/gotchas.md +208 -0
  331. package/skills/cloudflare/references/waf/patterns.md +236 -0
  332. package/skills/cloudflare/references/web-analytics/README.md +149 -0
  333. package/skills/cloudflare/references/web-analytics/configuration.md +81 -0
  334. package/skills/cloudflare/references/web-analytics/gotchas.md +86 -0
  335. package/skills/cloudflare/references/web-analytics/integration.md +63 -0
  336. package/skills/cloudflare/references/web-analytics/patterns.md +98 -0
  337. package/skills/cloudflare/references/workerd/README.md +85 -0
  338. package/skills/cloudflare/references/workerd/api.md +219 -0
  339. package/skills/cloudflare/references/workerd/configuration.md +200 -0
  340. package/skills/cloudflare/references/workerd/gotchas.md +151 -0
  341. package/skills/cloudflare/references/workerd/patterns.md +205 -0
  342. package/skills/cloudflare/references/workers/README.md +110 -0
  343. package/skills/cloudflare/references/workers/api.md +197 -0
  344. package/skills/cloudflare/references/workers/configuration.md +184 -0
  345. package/skills/cloudflare/references/workers/frameworks.md +200 -0
  346. package/skills/cloudflare/references/workers/gotchas.md +145 -0
  347. package/skills/cloudflare/references/workers/patterns.md +220 -0
  348. package/skills/cloudflare/references/workers-ai/README.md +206 -0
  349. package/skills/cloudflare/references/workers-ai/api.md +115 -0
  350. package/skills/cloudflare/references/workers-ai/configuration.md +98 -0
  351. package/skills/cloudflare/references/workers-ai/gotchas.md +130 -0
  352. package/skills/cloudflare/references/workers-ai/patterns.md +122 -0
  353. package/skills/cloudflare/references/workers-for-platforms/README.md +95 -0
  354. package/skills/cloudflare/references/workers-for-platforms/api.md +212 -0
  355. package/skills/cloudflare/references/workers-for-platforms/configuration.md +178 -0
  356. package/skills/cloudflare/references/workers-for-platforms/gotchas.md +134 -0
  357. package/skills/cloudflare/references/workers-for-platforms/patterns.md +210 -0
  358. package/skills/cloudflare/references/workers-playground/README.md +131 -0
  359. package/skills/cloudflare/references/workers-playground/api.md +101 -0
  360. package/skills/cloudflare/references/workers-playground/configuration.md +169 -0
  361. package/skills/cloudflare/references/workers-playground/gotchas.md +88 -0
  362. package/skills/cloudflare/references/workers-playground/patterns.md +134 -0
  363. package/skills/cloudflare/references/workers-vpc/README.md +130 -0
  364. package/skills/cloudflare/references/workers-vpc/api.md +196 -0
  365. package/skills/cloudflare/references/workers-vpc/configuration.md +151 -0
  366. package/skills/cloudflare/references/workers-vpc/gotchas.md +171 -0
  367. package/skills/cloudflare/references/workers-vpc/patterns.md +235 -0
  368. package/skills/cloudflare/references/workflows/README.md +72 -0
  369. package/skills/cloudflare/references/workflows/api.md +237 -0
  370. package/skills/cloudflare/references/workflows/configuration.md +158 -0
  371. package/skills/cloudflare/references/workflows/gotchas.md +97 -0
  372. package/skills/cloudflare/references/workflows/patterns.md +245 -0
  373. package/skills/cloudflare/references/wrangler/README.md +143 -0
  374. package/skills/cloudflare/references/wrangler/api.md +188 -0
  375. package/skills/cloudflare/references/wrangler/configuration.md +198 -0
  376. package/skills/cloudflare/references/wrangler/gotchas.md +212 -0
  377. package/skills/cloudflare/references/wrangler/patterns.md +211 -0
  378. package/skills/cloudflare/references/zaraz/IMPLEMENTATION_SUMMARY.md +131 -0
  379. package/skills/cloudflare/references/zaraz/README.md +114 -0
  380. package/skills/cloudflare/references/zaraz/api.md +118 -0
  381. package/skills/cloudflare/references/zaraz/configuration.md +94 -0
  382. package/skills/cloudflare/references/zaraz/gotchas.md +88 -0
  383. package/skills/cloudflare/references/zaraz/patterns.md +77 -0
  384. package/skills/docker/SKILL.md +7 -101
  385. package/skills/docker/references/advanced-examples.md +71 -0
  386. package/skills/docker/references/templates.md +34 -0
  387. package/skills/docs-marketer/SKILL.md +178 -0
  388. package/skills/docs-marketer/references/audit-categories.md +328 -0
  389. package/skills/docs-marketer/references/copilot-docs-prompts.md +88 -0
  390. package/skills/docs-marketer/references/copilot-usage.md +16 -0
  391. package/skills/docs-marketer/references/feedback-loop.md +155 -0
  392. package/skills/docs-marketer/references/multi-pass-docs-protocol.md +410 -0
  393. package/skills/drizzle-orm/SKILL.md +82 -0
  394. package/skills/durable-objects/SKILL.md +167 -0
  395. package/skills/durable-objects/references/advanced_features.md +29 -0
  396. package/skills/durable-objects/references/rules.md +300 -0
  397. package/skills/durable-objects/references/testing.md +261 -0
  398. package/skills/durable-objects/references/workers.md +336 -0
  399. package/skills/gcp/SKILL.md +37 -0
  400. package/skills/github-actions/SKILL.md +5 -58
  401. package/skills/github-actions/references/templates.md +65 -0
  402. package/skills/github-commander/SKILL.md +13 -21
  403. package/skills/github-commander/workflows/copilot-audit.md +12 -12
  404. package/skills/github-copilot-cli/SKILL.md +21 -26
  405. package/skills/github-repo-setup/SKILL.md +136 -0
  406. package/skills/github-repo-setup/references/community-standards.md +136 -0
  407. package/skills/github-repo-setup/references/github-automation.md +490 -0
  408. package/skills/github-repo-setup/references/inline-templates.md +205 -0
  409. package/skills/github-repo-setup/references/project-config.md +320 -0
  410. package/skills/gitlab/SKILL.md +7 -2
  411. package/skills/gitlab/package-lock.json +389 -389
  412. package/skills/golang/SKILL.md +8 -1
  413. package/skills/graphql/SKILL.md +30 -0
  414. package/skills/hono/SKILL.md +82 -0
  415. package/skills/journal-optimizer/SKILL.md +206 -0
  416. package/skills/journal-optimizer/references/optimizer-scripts.md +169 -0
  417. package/skills/llm-app-engineering/SKILL.md +18 -0
  418. package/skills/monorepo/SKILL.md +56 -0
  419. package/skills/multi-agent-orchestration/SKILL.md +14 -0
  420. package/skills/mysql/SKILL.md +6 -2
  421. package/skills/next-best-practices/SKILL.md +86 -0
  422. package/skills/next-best-practices/references/cache-components-examples.md +234 -0
  423. package/skills/next-best-practices/references/cache-components.md +210 -0
  424. package/skills/next-best-practices/references/upgrade-decision-tree.md +33 -0
  425. package/skills/next-best-practices/references/upgrade.md +43 -0
  426. package/skills/next-cache-components/SKILL.md +441 -0
  427. package/skills/next-upgrade/SKILL.md +43 -0
  428. package/skills/next-upgrade/references/decision-tree.md +33 -0
  429. package/skills/nodejs/SKILL.md +46 -0
  430. package/skills/opentelemetry/SKILL.md +62 -0
  431. package/skills/package.json +39 -4
  432. package/skills/playwright-standard/SKILL.md +6 -11
  433. package/skills/playwright-standard/references/locators.md +7 -0
  434. package/skills/postgres/SKILL.md +6 -1
  435. package/skills/python/SKILL.md +8 -70
  436. package/skills/python/references/advanced-patterns.md +37 -0
  437. package/skills/python/references/config-templates.md +48 -0
  438. package/skills/rag-pipelines/SKILL.md +14 -0
  439. package/skills/redis/SKILL.md +31 -0
  440. package/skills/render/SKILL.md +35 -0
  441. package/skills/rust/SKILL.md +15 -25
  442. package/skills/rust/references/borrow-checker.md +13 -0
  443. package/skills/rust/references/ecosystem.md +11 -0
  444. package/skills/sandbox-sdk/SKILL.md +186 -0
  445. package/skills/sandbox-sdk/references/api-quick-ref.md +113 -0
  446. package/skills/sandbox-sdk/references/examples.md +52 -0
  447. package/skills/shadcn-ui/SKILL.md +22 -57
  448. package/skills/skill-builder/SKILL.md +23 -424
  449. package/skills/skill-builder/references/tutorial.md +457 -0
  450. package/skills/sqlite/SKILL.md +16 -5
  451. package/skills/table.md +59 -0
  452. package/skills/tailwind-css/SKILL.md +11 -60
  453. package/skills/tailwind-css/references/component-patterns.md +52 -0
  454. package/skills/trpc/SKILL.md +56 -0
  455. package/skills/typescript/SKILL.md +30 -433
  456. package/skills/typescript/references/tutorial.md +453 -0
  457. package/skills/vercel-ai-sdk/SKILL.md +48 -0
  458. package/skills/vitest-standard/SKILL.md +5 -11
  459. package/skills/vitest-standard/references/assertions.md +11 -0
  460. package/skills/web-perf/SKILL.md +207 -0
  461. package/skills/workers-best-practices/SKILL.md +120 -0
  462. package/skills/workers-best-practices/references/anti-patterns.md +18 -0
  463. package/skills/workers-best-practices/references/review.md +174 -0
  464. package/skills/workers-best-practices/references/rules.md +485 -0
  465. package/skills/wrangler/SKILL.md +43 -0
  466. package/skills/wrangler/references/cli-commands.md +861 -0
  467. package/skills/zod/SKILL.md +48 -0
  468. package/dist/tools-P4VGG4FH.js +0 -1
  469. package/skills/react-best-practices/AGENTS.md +0 -2883
  470. package/skills/react-best-practices/SKILL.md +0 -138
  471. /package/skills/{react-best-practices → next-best-practices}/README.md +0 -0
  472. /package/skills/{react-best-practices → next-best-practices}/metadata.json +0 -0
  473. /package/skills/{react-best-practices → next-best-practices}/rules/_sections.md +0 -0
  474. /package/skills/{react-best-practices → next-best-practices}/rules/_template.md +0 -0
  475. /package/skills/{react-best-practices → next-best-practices}/rules/advanced-event-handler-refs.md +0 -0
  476. /package/skills/{react-best-practices → next-best-practices}/rules/advanced-init-once.md +0 -0
  477. /package/skills/{react-best-practices → next-best-practices}/rules/advanced-use-latest.md +0 -0
  478. /package/skills/{react-best-practices → next-best-practices}/rules/async-api-routes.md +0 -0
  479. /package/skills/{react-best-practices → next-best-practices}/rules/async-defer-await.md +0 -0
  480. /package/skills/{react-best-practices → next-best-practices}/rules/async-dependencies.md +0 -0
  481. /package/skills/{react-best-practices → next-best-practices}/rules/async-parallel.md +0 -0
  482. /package/skills/{react-best-practices → next-best-practices}/rules/async-suspense-boundaries.md +0 -0
  483. /package/skills/{react-best-practices → next-best-practices}/rules/bundle-barrel-imports.md +0 -0
  484. /package/skills/{react-best-practices → next-best-practices}/rules/bundle-conditional.md +0 -0
  485. /package/skills/{react-best-practices → next-best-practices}/rules/bundle-defer-third-party.md +0 -0
  486. /package/skills/{react-best-practices → next-best-practices}/rules/bundle-dynamic-imports.md +0 -0
  487. /package/skills/{react-best-practices → next-best-practices}/rules/bundle-preload.md +0 -0
  488. /package/skills/{react-best-practices → next-best-practices}/rules/client-event-listeners.md +0 -0
  489. /package/skills/{react-best-practices → next-best-practices}/rules/client-localstorage-schema.md +0 -0
  490. /package/skills/{react-best-practices → next-best-practices}/rules/client-passive-event-listeners.md +0 -0
  491. /package/skills/{react-best-practices → next-best-practices}/rules/client-swr-dedup.md +0 -0
  492. /package/skills/{react-best-practices → next-best-practices}/rules/js-batch-dom-css.md +0 -0
  493. /package/skills/{react-best-practices → next-best-practices}/rules/js-cache-function-results.md +0 -0
  494. /package/skills/{react-best-practices → next-best-practices}/rules/js-cache-property-access.md +0 -0
  495. /package/skills/{react-best-practices → next-best-practices}/rules/js-cache-storage.md +0 -0
  496. /package/skills/{react-best-practices → next-best-practices}/rules/js-combine-iterations.md +0 -0
  497. /package/skills/{react-best-practices → next-best-practices}/rules/js-early-exit.md +0 -0
  498. /package/skills/{react-best-practices → next-best-practices}/rules/js-hoist-regexp.md +0 -0
  499. /package/skills/{react-best-practices → next-best-practices}/rules/js-index-maps.md +0 -0
  500. /package/skills/{react-best-practices → next-best-practices}/rules/js-length-check-first.md +0 -0
  501. /package/skills/{react-best-practices → next-best-practices}/rules/js-min-max-loop.md +0 -0
  502. /package/skills/{react-best-practices → next-best-practices}/rules/js-set-map-lookups.md +0 -0
  503. /package/skills/{react-best-practices → next-best-practices}/rules/js-tosorted-immutable.md +0 -0
  504. /package/skills/{react-best-practices → next-best-practices}/rules/rendering-activity.md +0 -0
  505. /package/skills/{react-best-practices → next-best-practices}/rules/rendering-animate-svg-wrapper.md +0 -0
  506. /package/skills/{react-best-practices → next-best-practices}/rules/rendering-conditional-render.md +0 -0
  507. /package/skills/{react-best-practices → next-best-practices}/rules/rendering-content-visibility.md +0 -0
  508. /package/skills/{react-best-practices → next-best-practices}/rules/rendering-hoist-jsx.md +0 -0
  509. /package/skills/{react-best-practices → next-best-practices}/rules/rendering-hydration-no-flicker.md +0 -0
  510. /package/skills/{react-best-practices → next-best-practices}/rules/rendering-hydration-suppress-warning.md +0 -0
  511. /package/skills/{react-best-practices → next-best-practices}/rules/rendering-svg-precision.md +0 -0
  512. /package/skills/{react-best-practices → next-best-practices}/rules/rendering-usetransition-loading.md +0 -0
  513. /package/skills/{react-best-practices → next-best-practices}/rules/rerender-defer-reads.md +0 -0
  514. /package/skills/{react-best-practices → next-best-practices}/rules/rerender-dependencies.md +0 -0
  515. /package/skills/{react-best-practices → next-best-practices}/rules/rerender-derived-state-no-effect.md +0 -0
  516. /package/skills/{react-best-practices → next-best-practices}/rules/rerender-derived-state.md +0 -0
  517. /package/skills/{react-best-practices → next-best-practices}/rules/rerender-functional-setstate.md +0 -0
  518. /package/skills/{react-best-practices → next-best-practices}/rules/rerender-lazy-state-init.md +0 -0
  519. /package/skills/{react-best-practices → next-best-practices}/rules/rerender-memo-with-default-value.md +0 -0
  520. /package/skills/{react-best-practices → next-best-practices}/rules/rerender-memo.md +0 -0
  521. /package/skills/{react-best-practices → next-best-practices}/rules/rerender-move-effect-to-event.md +0 -0
  522. /package/skills/{react-best-practices → next-best-practices}/rules/rerender-simple-expression-in-memo.md +0 -0
  523. /package/skills/{react-best-practices → next-best-practices}/rules/rerender-transitions.md +0 -0
  524. /package/skills/{react-best-practices → next-best-practices}/rules/rerender-use-ref-transient-values.md +0 -0
  525. /package/skills/{react-best-practices → next-best-practices}/rules/server-after-nonblocking.md +0 -0
  526. /package/skills/{react-best-practices → next-best-practices}/rules/server-auth-actions.md +0 -0
  527. /package/skills/{react-best-practices → next-best-practices}/rules/server-cache-lru.md +0 -0
  528. /package/skills/{react-best-practices → next-best-practices}/rules/server-cache-react.md +0 -0
  529. /package/skills/{react-best-practices → next-best-practices}/rules/server-dedup-props.md +0 -0
  530. /package/skills/{react-best-practices → next-best-practices}/rules/server-parallel-fetching.md +0 -0
  531. /package/skills/{react-best-practices → next-best-practices}/rules/server-serialization.md +0 -0
@@ -0,0 +1,205 @@
1
+ # Troubleshooting & Best Practices
2
+
3
+ ## Common Errors
4
+
5
+ ### "No bundler/build step" - Pulumi uploads raw code
6
+
7
+ **Problem:** Worker fails with "Cannot use import statement outside a module"
8
+ **Cause:** Pulumi doesn't bundle Worker code - uploads exactly what you provide
9
+ **Solution:** Build Worker BEFORE Pulumi deploy
10
+
11
+ ```typescript
12
+ // WRONG: Pulumi won't bundle this
13
+ const worker = new cloudflare.WorkerScript('worker', {
14
+ content: fs.readFileSync('./src/index.ts', 'utf8'), // Raw TS file
15
+ })
16
+
17
+ // RIGHT: Build first, then deploy
18
+ import * as command from '@pulumi/command'
19
+ const build = new command.local.Command('build', {
20
+ create: 'npm run build',
21
+ dir: './worker',
22
+ })
23
+ const worker = new cloudflare.WorkerScript(
24
+ 'worker',
25
+ {
26
+ content: build.stdout.apply(() => fs.readFileSync('./worker/dist/index.js', 'utf8')),
27
+ },
28
+ { dependsOn: [build] }
29
+ )
30
+ ```
31
+
32
+ ### "wrangler.toml not consumed" - Config drift
33
+
34
+ **Problem:** Local wrangler dev works, Pulumi deploy fails
35
+ **Cause:** Pulumi ignores wrangler.toml - must duplicate config
36
+ **Solution:** Generate wrangler.toml from Pulumi or keep synced manually
37
+
38
+ ```typescript
39
+ // Pattern: Export Pulumi config to wrangler.toml
40
+ const workerConfig = {
41
+ name: 'my-worker',
42
+ compatibilityDate: '2025-01-01',
43
+ compatibilityFlags: ['nodejs_compat'],
44
+ }
45
+
46
+ new command.local.Command('generate-wrangler', {
47
+ create: pulumi.interpolate`cat > wrangler.toml <<EOF
48
+ name = "${workerConfig.name}"
49
+ compatibility_date = "${workerConfig.compatibilityDate}"
50
+ compatibility_flags = ${JSON.stringify(workerConfig.compatibilityFlags)}
51
+ EOF`,
52
+ })
53
+ ```
54
+
55
+ ### "False no-changes detection" - Content SHA unchanged
56
+
57
+ **Problem:** Worker code updated, Pulumi says "no changes"
58
+ **Cause:** Content hash identical (whitespace/comment-only change)
59
+ **Solution:** Add build timestamp or version to force update
60
+
61
+ ```typescript
62
+ const version = Date.now().toString()
63
+ const worker = new cloudflare.WorkerScript('worker', {
64
+ content: code,
65
+ plainTextBindings: [{ name: 'VERSION', text: version }], // Forces new deployment
66
+ })
67
+ ```
68
+
69
+ ### "D1 migrations don't run on pulumi up"
70
+
71
+ **Problem:** Database schema not applied after D1 database created
72
+ **Cause:** Pulumi creates database but doesn't run migrations
73
+ **Solution:** Use Command resource with dependsOn
74
+
75
+ ```typescript
76
+ const db = new cloudflare.D1Database('db', { accountId, name: 'mydb' })
77
+
78
+ // Run migrations after DB created
79
+ const migration = new command.local.Command(
80
+ 'migrate',
81
+ {
82
+ create: pulumi.interpolate`wrangler d1 execute ${db.name} --file ./schema.sql`,
83
+ },
84
+ { dependsOn: [db] }
85
+ )
86
+
87
+ // Worker depends on migrations
88
+ const worker = new cloudflare.WorkerScript(
89
+ 'worker',
90
+ {
91
+ d1DatabaseBindings: [{ name: 'DB', databaseId: db.id }],
92
+ },
93
+ { dependsOn: [migration] }
94
+ )
95
+ ```
96
+
97
+ ### "Missing required property 'accountId'"
98
+
99
+ **Problem:** `Error: Missing required property 'accountId'`
100
+ **Cause:** Account ID not provided in resource configuration
101
+ **Solution:** Add to stack config
102
+
103
+ ```yaml
104
+ # Pulumi.<stack>.yaml
105
+ config:
106
+ cloudflare:accountId: 'abc123...'
107
+ ```
108
+
109
+ ### "Binding name mismatch"
110
+
111
+ **Problem:** Worker fails with "env.MY_KV is undefined"
112
+ **Cause:** Binding name in Pulumi != name in Worker code
113
+ **Solution:** Match exactly (case-sensitive)
114
+
115
+ ```typescript
116
+ // Pulumi
117
+ kvNamespaceBindings: [{ name: 'MY_KV', namespaceId: kv.id }]
118
+
119
+ // Worker code
120
+ export default {
121
+ async fetch(request, env) {
122
+ await env.MY_KV.get('key')
123
+ },
124
+ }
125
+ ```
126
+
127
+ ### "API token permissions insufficient"
128
+
129
+ **Problem:** `Error: authentication error (10000)`
130
+ **Cause:** Token lacks required permissions
131
+ **Solution:** Grant token permissions: Account.Workers Scripts:Edit, Account.Account Settings:Read
132
+
133
+ ### "Resource not found after import"
134
+
135
+ **Problem:** Imported resource shows as changed on next `pulumi up`
136
+ **Cause:** State mismatch between actual resource and Pulumi config
137
+ **Solution:** Check property names/types match exactly
138
+
139
+ ```bash
140
+ pulumi import cloudflare:index/workerScript:WorkerScript my-worker <account_id>/<worker_name>
141
+ pulumi preview # If shows changes, adjust Pulumi code to match actual resource
142
+ ```
143
+
144
+ ### "v6.x Worker versioning confusion"
145
+
146
+ **Problem:** Worker deployed but not receiving traffic
147
+ **Cause:** v6.x requires Worker + WorkerVersion + WorkersDeployment (3 resources)
148
+ **Solution:** Use WorkerScript (auto-versioning) OR full versioning pattern
149
+
150
+ ```typescript
151
+ // SIMPLE: WorkerScript auto-versions (default behavior)
152
+ const worker = new cloudflare.WorkerScript('worker', {
153
+ accountId,
154
+ name: 'my-worker',
155
+ content: code,
156
+ })
157
+
158
+ // ADVANCED: Manual versioning for gradual rollouts (v6.x)
159
+ const worker = new cloudflare.Worker('worker', { accountId, name: 'my-worker' })
160
+ const version = new cloudflare.WorkerVersion('v1', {
161
+ accountId,
162
+ workerId: worker.id,
163
+ content: code,
164
+ compatibilityDate: '2025-01-01',
165
+ })
166
+ const deployment = new cloudflare.WorkersDeployment('prod', {
167
+ accountId,
168
+ workerId: worker.id,
169
+ versionId: version.id,
170
+ })
171
+ ```
172
+
173
+ ## Best Practices
174
+
175
+ 1. **Always set compatibilityDate** - Locks Worker behavior, prevents breaking changes
176
+ 2. **Build before deploy** - Pulumi doesn't bundle; use Command resource or CI build step
177
+ 3. **Match binding names** - Case-sensitive, must match between Pulumi and Worker code
178
+ 4. **Use dependsOn for migrations** - Ensure D1 migrations run before Worker deploys
179
+ 5. **Version Worker content** - Add VERSION binding to force redeployment on content changes
180
+ 6. **Store secrets in stack config** - Use `pulumi config set --secret` for API keys
181
+
182
+ ## Limits
183
+
184
+ | Resource | Limit | Notes |
185
+ | --------------------- | ----------------------- | --------------------------------------------- |
186
+ | Worker script size | 10 MB | Includes all dependencies, after compression |
187
+ | Worker CPU time | 50ms (free), 30s (paid) | Per request |
188
+ | KV keys per namespace | Unlimited | 1000 ops/sec write, 100k ops/sec read |
189
+ | R2 storage | Unlimited | Class A ops: 1M/mo free, Class B: 10M/mo free |
190
+ | D1 databases | 50,000 per account | Free: 10 per account, 5 GB each |
191
+ | Queues | 10,000 per account | Free: 1M ops/day |
192
+ | Pages projects | 500 per account | Free: 100 projects |
193
+ | API requests | Varies by plan | ~1200 req/5min on free |
194
+
195
+ ## Resources
196
+
197
+ - **Pulumi Registry:** https://www.pulumi.com/registry/packages/cloudflare/
198
+ - **API Docs:** https://www.pulumi.com/registry/packages/cloudflare/api-docs/
199
+ - **GitHub:** https://github.com/pulumi/pulumi-cloudflare
200
+ - **Cloudflare Docs:** https://developers.cloudflare.com/
201
+ - **Workers Docs:** https://developers.cloudflare.com/workers/
202
+
203
+ ---
204
+
205
+ See: [README.md](./README.md), [configuration.md](./configuration.md), [api.md](./api.md), [patterns.md](./patterns.md)
@@ -0,0 +1,260 @@
1
+ # Architecture Patterns
2
+
3
+ ## Component Resources
4
+
5
+ ```typescript
6
+ class WorkerApp extends pulumi.ComponentResource {
7
+ constructor(name: string, args: WorkerAppArgs, opts?) {
8
+ super('custom:cloudflare:WorkerApp', name, {}, opts)
9
+ const defaultOpts = { parent: this }
10
+
11
+ this.kv = new cloudflare.WorkersKvNamespace(
12
+ `${name}-kv`,
13
+ { accountId: args.accountId, title: `${name}-kv` },
14
+ defaultOpts
15
+ )
16
+ this.worker = new cloudflare.WorkerScript(
17
+ `${name}-worker`,
18
+ {
19
+ accountId: args.accountId,
20
+ name: `${name}-worker`,
21
+ content: args.workerCode,
22
+ module: true,
23
+ kvNamespaceBindings: [{ name: 'KV', namespaceId: this.kv.id }],
24
+ },
25
+ defaultOpts
26
+ )
27
+ this.domain = new cloudflare.WorkersDomain(
28
+ `${name}-domain`,
29
+ {
30
+ accountId: args.accountId,
31
+ hostname: args.domain,
32
+ service: this.worker.name,
33
+ },
34
+ defaultOpts
35
+ )
36
+ }
37
+ }
38
+ ```
39
+
40
+ ## Full-Stack Worker App
41
+
42
+ ```typescript
43
+ const kv = new cloudflare.WorkersKvNamespace('cache', { accountId, title: 'api-cache' })
44
+ const db = new cloudflare.D1Database('db', { accountId, name: 'app-database' })
45
+ const bucket = new cloudflare.R2Bucket('assets', { accountId, name: 'app-assets' })
46
+
47
+ const apiWorker = new cloudflare.WorkerScript('api', {
48
+ accountId,
49
+ name: 'api-worker',
50
+ content: fs.readFileSync('./dist/api.js', 'utf8'),
51
+ module: true,
52
+ kvNamespaceBindings: [{ name: 'CACHE', namespaceId: kv.id }],
53
+ d1DatabaseBindings: [{ name: 'DB', databaseId: db.id }],
54
+ r2BucketBindings: [{ name: 'ASSETS', bucketName: bucket.name }],
55
+ })
56
+ ```
57
+
58
+ ## Multi-Environment Setup
59
+
60
+ ```typescript
61
+ const stack = pulumi.getStack()
62
+ const worker = new cloudflare.WorkerScript(`worker-${stack}`, {
63
+ accountId,
64
+ name: `my-worker-${stack}`,
65
+ content: code,
66
+ plainTextBindings: [{ name: 'ENVIRONMENT', text: stack }],
67
+ })
68
+ ```
69
+
70
+ ## Queue-Based Processing
71
+
72
+ ```typescript
73
+ const queue = new cloudflare.Queue('processing-queue', { accountId, name: 'image-processing' })
74
+
75
+ // Producer: API receives requests
76
+ const apiWorker = new cloudflare.WorkerScript('api', {
77
+ accountId,
78
+ name: 'api-worker',
79
+ content: apiCode,
80
+ queueBindings: [{ name: 'PROCESSING_QUEUE', queue: queue.id }],
81
+ })
82
+
83
+ // Consumer: Process async
84
+ const processorWorker = new cloudflare.WorkerScript('processor', {
85
+ accountId,
86
+ name: 'processor-worker',
87
+ content: processorCode,
88
+ queueConsumers: [{ queue: queue.name, maxBatchSize: 10, maxRetries: 3, maxWaitTimeMs: 5000 }],
89
+ r2BucketBindings: [{ name: 'OUTPUT_BUCKET', bucketName: outputBucket.name }],
90
+ })
91
+ ```
92
+
93
+ ## Microservices with Service Bindings
94
+
95
+ ```typescript
96
+ const authWorker = new cloudflare.WorkerScript('auth', {
97
+ accountId,
98
+ name: 'auth-service',
99
+ content: authCode,
100
+ })
101
+ const apiWorker = new cloudflare.WorkerScript('api', {
102
+ accountId,
103
+ name: 'api-service',
104
+ content: apiCode,
105
+ serviceBindings: [{ name: 'AUTH', service: authWorker.name }],
106
+ })
107
+ ```
108
+
109
+ ## Event-Driven Architecture
110
+
111
+ ```typescript
112
+ const eventQueue = new cloudflare.Queue('events', { accountId, name: 'event-bus' })
113
+ const producer = new cloudflare.WorkerScript('producer', {
114
+ accountId,
115
+ name: 'api-producer',
116
+ content: producerCode,
117
+ queueBindings: [{ name: 'EVENTS', queue: eventQueue.id }],
118
+ })
119
+ const consumer = new cloudflare.WorkerScript('consumer', {
120
+ accountId,
121
+ name: 'email-consumer',
122
+ content: consumerCode,
123
+ queueConsumers: [{ queue: eventQueue.name, maxBatchSize: 10 }],
124
+ })
125
+ ```
126
+
127
+ ## v6.x Versioned Deployments (Blue-Green/Canary)
128
+
129
+ ```typescript
130
+ const worker = new cloudflare.Worker('api', { accountId, name: 'api-worker' })
131
+ const v1 = new cloudflare.WorkerVersion('v1', {
132
+ accountId,
133
+ workerId: worker.id,
134
+ content: fs.readFileSync('./dist/v1.js', 'utf8'),
135
+ compatibilityDate: '2025-01-01',
136
+ })
137
+ const v2 = new cloudflare.WorkerVersion('v2', {
138
+ accountId,
139
+ workerId: worker.id,
140
+ content: fs.readFileSync('./dist/v2.js', 'utf8'),
141
+ compatibilityDate: '2025-01-01',
142
+ })
143
+
144
+ // Gradual rollout: 10% v2, 90% v1
145
+ const deployment = new cloudflare.WorkersDeployment('canary', {
146
+ accountId,
147
+ workerId: worker.id,
148
+ versions: [
149
+ { versionId: v2.id, percentage: 10 },
150
+ { versionId: v1.id, percentage: 90 },
151
+ ],
152
+ kvNamespaceBindings: [{ name: 'MY_KV', namespaceId: kv.id }],
153
+ })
154
+ ```
155
+
156
+ **Use:** Canary releases, A/B testing, blue-green. Most apps use `WorkerScript` (auto-versioning).
157
+
158
+ ## Wrangler.toml Generation (Bridge IaC with Local Dev)
159
+
160
+ Generate wrangler.toml from Pulumi config to keep local dev in sync:
161
+
162
+ ```typescript
163
+ import * as command from '@pulumi/command'
164
+
165
+ const workerConfig = {
166
+ name: 'my-worker',
167
+ compatibilityDate: '2025-01-01',
168
+ compatibilityFlags: ['nodejs_compat'],
169
+ }
170
+
171
+ // Create resources
172
+ const kv = new cloudflare.WorkersKvNamespace('kv', { accountId, title: 'my-kv' })
173
+ const db = new cloudflare.D1Database('db', { accountId, name: 'my-db' })
174
+ const bucket = new cloudflare.R2Bucket('bucket', { accountId, name: 'my-bucket' })
175
+
176
+ // Generate wrangler.toml after resources created
177
+ const wranglerGen = new command.local.Command(
178
+ 'gen-wrangler',
179
+ {
180
+ create: pulumi.interpolate`cat > wrangler.toml <<EOF
181
+ name = "${workerConfig.name}"
182
+ main = "src/index.ts"
183
+ compatibility_date = "${workerConfig.compatibilityDate}"
184
+ compatibility_flags = ${JSON.stringify(workerConfig.compatibilityFlags)}
185
+
186
+ [[kv_namespaces]]
187
+ binding = "MY_KV"
188
+ id = "${kv.id}"
189
+
190
+ [[d1_databases]]
191
+ binding = "DB"
192
+ database_id = "${db.id}"
193
+ database_name = "${db.name}"
194
+
195
+ [[r2_buckets]]
196
+ binding = "MY_BUCKET"
197
+ bucket_name = "${bucket.name}"
198
+ EOF`,
199
+ },
200
+ { dependsOn: [kv, db, bucket] }
201
+ )
202
+
203
+ // Deploy worker after wrangler.toml generated
204
+ const worker = new cloudflare.WorkerScript(
205
+ 'worker',
206
+ {
207
+ accountId,
208
+ name: workerConfig.name,
209
+ content: code,
210
+ compatibilityDate: workerConfig.compatibilityDate,
211
+ compatibilityFlags: workerConfig.compatibilityFlags,
212
+ kvNamespaceBindings: [{ name: 'MY_KV', namespaceId: kv.id }],
213
+ d1DatabaseBindings: [{ name: 'DB', databaseId: db.id }],
214
+ r2BucketBindings: [{ name: 'MY_BUCKET', bucketName: bucket.name }],
215
+ },
216
+ { dependsOn: [wranglerGen] }
217
+ )
218
+ ```
219
+
220
+ **Benefits:**
221
+
222
+ - `wrangler dev` uses same bindings as production
223
+ - No config drift between Pulumi and local dev
224
+ - Single source of truth (Pulumi config)
225
+
226
+ **Alternative:** Read wrangler.toml in Pulumi (reverse direction) if wrangler is source of truth
227
+
228
+ ## Build + Deploy Pattern
229
+
230
+ ```typescript
231
+ import * as command from '@pulumi/command'
232
+ const build = new command.local.Command('build', { create: 'npm run build', dir: './worker' })
233
+ const worker = new cloudflare.WorkerScript(
234
+ 'worker',
235
+ {
236
+ accountId,
237
+ name: 'my-worker',
238
+ content: build.stdout.apply(() => fs.readFileSync('./worker/dist/index.js', 'utf8')),
239
+ },
240
+ { dependsOn: [build] }
241
+ )
242
+ ```
243
+
244
+ ## Content SHA Pattern (Force Updates)
245
+
246
+ Prevent false "no changes" detections:
247
+
248
+ ```typescript
249
+ const version = Date.now().toString()
250
+ const worker = new cloudflare.WorkerScript('worker', {
251
+ accountId,
252
+ name: 'my-worker',
253
+ content: code,
254
+ plainTextBindings: [{ name: 'VERSION', text: version }], // Forces deployment
255
+ })
256
+ ```
257
+
258
+ ---
259
+
260
+ See: [README.md](./README.md), [configuration.md](./configuration.md), [api.md](./api.md), [gotchas.md](./gotchas.md)
@@ -0,0 +1,99 @@
1
+ # Cloudflare Queues
2
+
3
+ Flexible message queuing for async task processing with guaranteed at-least-once delivery and configurable batching.
4
+
5
+ ## Overview
6
+
7
+ Queues provide:
8
+
9
+ - At-least-once delivery guarantee
10
+ - Push-based (Worker) and pull-based (HTTP) consumers
11
+ - Configurable batching and retries
12
+ - Dead Letter Queues (DLQ)
13
+ - Delays up to 12 hours
14
+
15
+ **Use cases:** Async processing, API buffering, rate limiting, event workflows, deferred jobs
16
+
17
+ ## Quick Start
18
+
19
+ ```bash
20
+ wrangler queues create my-queue
21
+ wrangler queues consumer add my-queue my-worker
22
+ ```
23
+
24
+ ```typescript
25
+ // Producer
26
+ await env.MY_QUEUE.send({ userId: 123, action: 'notify' })
27
+
28
+ // Consumer (with proper error handling)
29
+ export default {
30
+ async queue(batch: MessageBatch, env: Env): Promise<void> {
31
+ for (const msg of batch.messages) {
32
+ try {
33
+ await process(msg.body)
34
+ msg.ack()
35
+ } catch (error) {
36
+ msg.retry({ delaySeconds: 60 })
37
+ }
38
+ }
39
+ },
40
+ }
41
+ ```
42
+
43
+ ## Critical Warnings
44
+
45
+ **Before using Queues, understand these production mistakes:**
46
+
47
+ 1. **Uncaught errors retry ENTIRE batch** (not just failed message). Always use per-message try/catch.
48
+ 2. **Messages not ack'd/retry'd will auto-retry forever** until max_retries. Always explicitly handle each message.
49
+
50
+ See [gotchas.md](./gotchas.md) for detailed solutions.
51
+
52
+ ## Core Operations
53
+
54
+ | Operation | Purpose | Limit |
55
+ | ------------------------- | ------------------- | --------------- |
56
+ | `send(body, options?)` | Publish message | 128 KB |
57
+ | `sendBatch(messages)` | Bulk publish | 100 msgs/256 KB |
58
+ | `message.ack()` | Acknowledge success | - |
59
+ | `message.retry(options?)` | Retry with delay | - |
60
+ | `batch.ackAll()` | Ack entire batch | - |
61
+
62
+ ## Architecture
63
+
64
+ ```
65
+ [Producer Worker] → [Queue] → [Consumer Worker/HTTP] → [Processing]
66
+ ```
67
+
68
+ - Max 10,000 queues per account
69
+ - 5,000 msgs/second per queue
70
+ - 4-14 day retention (configurable)
71
+
72
+ ## Reading Order
73
+
74
+ **New to Queues?** Start here:
75
+
76
+ 1. [configuration.md](./configuration.md) - Set up queues, bindings, consumers
77
+ 2. [api.md](./api.md) - Send messages, handle batches, ack/retry patterns
78
+ 3. [patterns.md](./patterns.md) - Real-world examples and integrations
79
+ 4. [gotchas.md](./gotchas.md) - Critical warnings and troubleshooting
80
+
81
+ **Task-based routing:**
82
+
83
+ - Setup queue → [configuration.md](./configuration.md)
84
+ - Send/receive messages → [api.md](./api.md)
85
+ - Implement specific pattern → [patterns.md](./patterns.md)
86
+ - Debug/troubleshoot → [gotchas.md](./gotchas.md)
87
+
88
+ ## In This Reference
89
+
90
+ - [configuration.md](./configuration.md) - wrangler.jsonc setup, producer/consumer config, DLQ, content types
91
+ - [api.md](./api.md) - Send/batch methods, queue handler, ack/retry rules, type-safe patterns
92
+ - [patterns.md](./patterns.md) - Async tasks, buffering, rate limiting, D1/Workflows/DO integrations
93
+ - [gotchas.md](./gotchas.md) - Critical batch error handling, idempotency, error classification
94
+
95
+ ## See Also
96
+
97
+ - [workers](../workers/) - Worker runtime for producers/consumers
98
+ - [r2](../r2/) - Process R2 event notifications via queues
99
+ - [d1](../d1/) - Batch write to D1 from queue consumers