alchemy-effect 0.1.0 → 0.3.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 (590) hide show
  1. package/bin/alchemy-effect.js +55038 -8
  2. package/bin/alchemy-effect.js.map +1 -1
  3. package/bin/alchemy-effect.ts +266 -10
  4. package/lib/$.d.ts +5 -0
  5. package/lib/$.d.ts.map +1 -0
  6. package/lib/$.js +9 -0
  7. package/lib/$.js.map +1 -0
  8. package/lib/app.d.ts +7 -15
  9. package/lib/app.d.ts.map +1 -1
  10. package/lib/app.js +1 -20
  11. package/lib/app.js.map +1 -1
  12. package/lib/apply.d.ts +15 -19
  13. package/lib/apply.d.ts.map +1 -1
  14. package/lib/apply.js +173 -82
  15. package/lib/apply.js.map +1 -1
  16. package/lib/assert-never.d.ts +12 -0
  17. package/lib/assert-never.d.ts.map +1 -0
  18. package/lib/assert-never.js +11 -0
  19. package/lib/assert-never.js.map +1 -0
  20. package/lib/aws/account.d.ts +13 -3
  21. package/lib/aws/account.d.ts.map +1 -1
  22. package/lib/aws/account.js +19 -4
  23. package/lib/aws/account.js.map +1 -1
  24. package/lib/aws/arn.d.ts +1 -5
  25. package/lib/aws/arn.d.ts.map +1 -1
  26. package/lib/aws/client.d.ts.map +1 -1
  27. package/lib/aws/client.js +8 -1
  28. package/lib/aws/client.js.map +1 -1
  29. package/lib/aws/config.d.ts +15 -0
  30. package/lib/aws/config.d.ts.map +1 -0
  31. package/lib/aws/config.js +1 -0
  32. package/lib/aws/config.js.map +1 -0
  33. package/lib/aws/credentials.d.ts +11 -1
  34. package/lib/aws/credentials.d.ts.map +1 -1
  35. package/lib/aws/credentials.js +73 -47
  36. package/lib/aws/credentials.js.map +1 -1
  37. package/lib/aws/dynamodb/attribute-value.d.ts +20 -0
  38. package/lib/aws/dynamodb/attribute-value.d.ts.map +1 -0
  39. package/lib/aws/dynamodb/attribute-value.js +217 -0
  40. package/lib/aws/dynamodb/attribute-value.js.map +1 -0
  41. package/lib/aws/dynamodb/client.d.ts +12 -0
  42. package/lib/aws/dynamodb/client.d.ts.map +1 -0
  43. package/lib/aws/{sqs/queue.client.js → dynamodb/client.js} +6 -6
  44. package/lib/aws/dynamodb/client.js.map +1 -0
  45. package/lib/aws/dynamodb/expr.d.ts +41 -0
  46. package/lib/aws/dynamodb/expr.d.ts.map +1 -0
  47. package/lib/aws/dynamodb/expr.js +1 -0
  48. package/lib/aws/dynamodb/expr.js.map +1 -0
  49. package/lib/aws/dynamodb/index.d.ts +10 -0
  50. package/lib/aws/dynamodb/index.d.ts.map +1 -0
  51. package/lib/aws/dynamodb/index.js +9 -0
  52. package/lib/aws/dynamodb/index.js.map +1 -0
  53. package/lib/aws/dynamodb/projection.d.ts +25 -0
  54. package/lib/aws/dynamodb/projection.d.ts.map +1 -0
  55. package/lib/aws/dynamodb/projection.js +1 -0
  56. package/lib/aws/dynamodb/projection.js.map +1 -0
  57. package/lib/aws/dynamodb/secondary-index.d.ts +26 -0
  58. package/lib/aws/dynamodb/secondary-index.d.ts.map +1 -0
  59. package/lib/aws/dynamodb/secondary-index.js +4 -0
  60. package/lib/aws/dynamodb/secondary-index.js.map +1 -0
  61. package/lib/aws/dynamodb/table.d.ts +59 -0
  62. package/lib/aws/dynamodb/table.d.ts.map +1 -0
  63. package/lib/aws/dynamodb/table.get-item.d.ts +57 -0
  64. package/lib/aws/dynamodb/table.get-item.d.ts.map +1 -0
  65. package/lib/aws/dynamodb/table.get-item.js +77 -0
  66. package/lib/aws/dynamodb/table.get-item.js.map +1 -0
  67. package/lib/aws/dynamodb/table.js +4 -0
  68. package/lib/aws/dynamodb/table.js.map +1 -0
  69. package/lib/aws/dynamodb/table.provider.d.ts +7 -0
  70. package/lib/aws/dynamodb/table.provider.d.ts.map +1 -0
  71. package/lib/aws/dynamodb/table.provider.js +187 -0
  72. package/lib/aws/dynamodb/table.provider.js.map +1 -0
  73. package/lib/aws/ec2/client.d.ts +12 -0
  74. package/lib/aws/ec2/client.d.ts.map +1 -0
  75. package/lib/aws/ec2/client.js +11 -0
  76. package/lib/aws/ec2/client.js.map +1 -0
  77. package/lib/aws/ec2/index.d.ts +7 -0
  78. package/lib/aws/ec2/index.d.ts.map +1 -0
  79. package/lib/aws/ec2/index.js +7 -0
  80. package/lib/aws/ec2/index.js.map +1 -0
  81. package/lib/aws/ec2/subnet.d.ts +175 -0
  82. package/lib/aws/ec2/subnet.d.ts.map +1 -0
  83. package/lib/aws/ec2/subnet.js +4 -0
  84. package/lib/aws/ec2/subnet.js.map +1 -0
  85. package/lib/aws/ec2/subnet.provider.d.ts +4 -0
  86. package/lib/aws/ec2/subnet.provider.d.ts.map +1 -0
  87. package/lib/aws/ec2/subnet.provider.js +250 -0
  88. package/lib/aws/ec2/subnet.provider.js.map +1 -0
  89. package/lib/aws/ec2/vpc.d.ts +135 -0
  90. package/lib/aws/ec2/vpc.d.ts.map +1 -0
  91. package/lib/aws/ec2/vpc.js +4 -0
  92. package/lib/aws/ec2/vpc.js.map +1 -0
  93. package/lib/aws/ec2/vpc.provider.d.ts +6 -0
  94. package/lib/aws/ec2/vpc.provider.d.ts.map +1 -0
  95. package/lib/aws/ec2/vpc.provider.js +183 -0
  96. package/lib/aws/ec2/vpc.provider.js.map +1 -0
  97. package/lib/aws/index.d.ts +23 -16
  98. package/lib/aws/index.d.ts.map +1 -1
  99. package/lib/aws/index.js +10 -18
  100. package/lib/aws/index.js.map +1 -1
  101. package/lib/aws/lambda/client.d.ts +8 -0
  102. package/lib/aws/lambda/client.d.ts.map +1 -0
  103. package/lib/aws/lambda/client.js +7 -0
  104. package/lib/aws/lambda/client.js.map +1 -0
  105. package/lib/aws/lambda/consume.d.ts +10 -11
  106. package/lib/aws/lambda/consume.d.ts.map +1 -1
  107. package/lib/aws/lambda/consume.js +3 -3
  108. package/lib/aws/lambda/consume.js.map +1 -1
  109. package/lib/aws/lambda/function.d.ts +18 -15
  110. package/lib/aws/lambda/function.d.ts.map +1 -1
  111. package/lib/aws/lambda/function.handler.d.ts +1 -1
  112. package/lib/aws/lambda/function.handler.d.ts.map +1 -1
  113. package/lib/aws/lambda/function.handler.js.map +1 -1
  114. package/lib/aws/lambda/function.invoke.d.ts +7 -5
  115. package/lib/aws/lambda/function.invoke.d.ts.map +1 -1
  116. package/lib/aws/lambda/function.invoke.js +5 -3
  117. package/lib/aws/lambda/function.invoke.js.map +1 -1
  118. package/lib/aws/lambda/function.js +1 -1
  119. package/lib/aws/lambda/function.js.map +1 -1
  120. package/lib/aws/lambda/function.provider.d.ts +6 -5
  121. package/lib/aws/lambda/function.provider.d.ts.map +1 -1
  122. package/lib/aws/lambda/function.provider.js +150 -58
  123. package/lib/aws/lambda/function.provider.js.map +1 -1
  124. package/lib/aws/lambda/index.d.ts +2 -2
  125. package/lib/aws/lambda/index.d.ts.map +1 -1
  126. package/lib/aws/lambda/index.js +2 -1
  127. package/lib/aws/lambda/index.js.map +1 -1
  128. package/lib/aws/lambda/serve.d.ts +2 -4
  129. package/lib/aws/lambda/serve.d.ts.map +1 -1
  130. package/lib/aws/lambda/serve.js.map +1 -1
  131. package/lib/aws/profile.d.ts +2 -2
  132. package/lib/aws/profile.d.ts.map +1 -1
  133. package/lib/aws/profile.js +1 -1
  134. package/lib/aws/profile.js.map +1 -1
  135. package/lib/aws/region.d.ts +14 -1
  136. package/lib/aws/region.d.ts.map +1 -1
  137. package/lib/aws/region.js +26 -1
  138. package/lib/aws/region.js.map +1 -1
  139. package/lib/aws/sqs/client.d.ts +12 -0
  140. package/lib/aws/sqs/client.d.ts.map +1 -0
  141. package/lib/aws/sqs/client.js +11 -0
  142. package/lib/aws/sqs/client.js.map +1 -0
  143. package/lib/aws/sqs/index.d.ts +3 -1
  144. package/lib/aws/sqs/index.d.ts.map +1 -1
  145. package/lib/aws/sqs/index.js +3 -1
  146. package/lib/aws/sqs/index.js.map +1 -1
  147. package/lib/aws/sqs/queue.consume.d.ts +1 -10
  148. package/lib/aws/sqs/queue.consume.d.ts.map +1 -1
  149. package/lib/aws/sqs/queue.consume.js +0 -19
  150. package/lib/aws/sqs/queue.consume.js.map +1 -1
  151. package/lib/aws/sqs/queue.d.ts +6 -12
  152. package/lib/aws/sqs/queue.d.ts.map +1 -1
  153. package/lib/aws/sqs/queue.event-source.d.ts +22 -0
  154. package/lib/aws/sqs/queue.event-source.d.ts.map +1 -0
  155. package/lib/aws/sqs/queue.event-source.js +130 -0
  156. package/lib/aws/sqs/queue.event-source.js.map +1 -0
  157. package/lib/aws/sqs/queue.js +1 -1
  158. package/lib/aws/sqs/queue.js.map +1 -1
  159. package/lib/aws/sqs/queue.provider.d.ts +5 -4
  160. package/lib/aws/sqs/queue.provider.d.ts.map +1 -1
  161. package/lib/aws/sqs/queue.provider.js +6 -6
  162. package/lib/aws/sqs/queue.provider.js.map +1 -1
  163. package/lib/aws/sqs/queue.send-message.d.ts +8 -6
  164. package/lib/aws/sqs/queue.send-message.d.ts.map +1 -1
  165. package/lib/aws/sqs/queue.send-message.js +6 -4
  166. package/lib/aws/sqs/queue.send-message.js.map +1 -1
  167. package/lib/binding.d.ts +74 -26
  168. package/lib/binding.d.ts.map +1 -1
  169. package/lib/binding.js.map +1 -1
  170. package/lib/capability.d.ts +38 -0
  171. package/lib/capability.d.ts.map +1 -1
  172. package/lib/cli/components/ApprovePlan.d.ts +2 -2
  173. package/lib/cli/components/ApprovePlan.d.ts.map +1 -1
  174. package/lib/cli/components/ApprovePlan.js.map +1 -1
  175. package/lib/cli/components/Plan.d.ts +2 -2
  176. package/lib/cli/components/Plan.d.ts.map +1 -1
  177. package/lib/cli/components/Plan.js +3 -1
  178. package/lib/cli/components/Plan.js.map +1 -1
  179. package/lib/cli/components/PlanProgress.d.ts +8 -4
  180. package/lib/cli/components/PlanProgress.d.ts.map +1 -1
  181. package/lib/cli/components/PlanProgress.js +11 -1
  182. package/lib/cli/components/PlanProgress.js.map +1 -1
  183. package/lib/cli/index.d.ts +342 -213
  184. package/lib/cli/index.d.ts.map +1 -1
  185. package/lib/cli/index.js +26047 -11403
  186. package/lib/cli/index.js.map +1 -1
  187. package/lib/cli/ink-service.d.ts +4 -0
  188. package/lib/cli/ink-service.d.ts.map +1 -0
  189. package/lib/cli/ink-service.js +43 -0
  190. package/lib/cli/ink-service.js.map +1 -0
  191. package/lib/cli/service.d.ts +21 -0
  192. package/lib/cli/service.d.ts.map +1 -0
  193. package/lib/cli/service.js +5 -0
  194. package/lib/cli/service.js.map +1 -0
  195. package/lib/cloudflare/account.d.ts +10 -0
  196. package/lib/cloudflare/account.d.ts.map +1 -0
  197. package/lib/cloudflare/account.js +24 -0
  198. package/lib/cloudflare/account.js.map +1 -0
  199. package/lib/cloudflare/api.d.ts +31 -19
  200. package/lib/cloudflare/api.d.ts.map +1 -1
  201. package/lib/cloudflare/api.js +95 -29
  202. package/lib/cloudflare/api.js.map +1 -1
  203. package/lib/cloudflare/config.d.ts +9 -0
  204. package/lib/cloudflare/config.d.ts.map +1 -0
  205. package/lib/cloudflare/config.js +1 -0
  206. package/lib/cloudflare/config.js.map +1 -0
  207. package/lib/cloudflare/context.d.ts +27 -0
  208. package/lib/cloudflare/context.d.ts.map +1 -0
  209. package/lib/cloudflare/context.js +24 -0
  210. package/lib/cloudflare/context.js.map +1 -0
  211. package/lib/cloudflare/index.d.ts +7 -4
  212. package/lib/cloudflare/index.d.ts.map +1 -1
  213. package/lib/cloudflare/index.js +7 -4
  214. package/lib/cloudflare/index.js.map +1 -1
  215. package/lib/cloudflare/kv/index.d.ts +4 -0
  216. package/lib/cloudflare/kv/index.d.ts.map +1 -0
  217. package/lib/cloudflare/kv/index.js +4 -0
  218. package/lib/cloudflare/kv/index.js.map +1 -0
  219. package/lib/cloudflare/kv/namespace.binding.d.ts +10 -0
  220. package/lib/cloudflare/kv/namespace.binding.d.ts.map +1 -0
  221. package/lib/cloudflare/kv/namespace.binding.js +15 -0
  222. package/lib/cloudflare/kv/namespace.binding.js.map +1 -0
  223. package/lib/cloudflare/kv/namespace.client.d.ts +11 -0
  224. package/lib/cloudflare/kv/namespace.client.d.ts.map +1 -0
  225. package/lib/cloudflare/kv/namespace.client.js +31 -0
  226. package/lib/cloudflare/kv/namespace.client.js.map +1 -0
  227. package/lib/cloudflare/kv/namespace.d.ts +24 -0
  228. package/lib/cloudflare/kv/namespace.d.ts.map +1 -0
  229. package/lib/cloudflare/kv/namespace.js +3 -0
  230. package/lib/cloudflare/kv/namespace.js.map +1 -0
  231. package/lib/cloudflare/kv/namespace.provider.d.ts +6 -0
  232. package/lib/cloudflare/kv/namespace.provider.d.ts.map +1 -0
  233. package/lib/cloudflare/kv/namespace.provider.js +81 -0
  234. package/lib/cloudflare/kv/namespace.provider.js.map +1 -0
  235. package/lib/cloudflare/live.d.ts +11 -0
  236. package/lib/cloudflare/live.d.ts.map +1 -0
  237. package/lib/cloudflare/live.js +15 -0
  238. package/lib/cloudflare/live.js.map +1 -0
  239. package/lib/cloudflare/r2/bucket.binding.d.ts +10 -0
  240. package/lib/cloudflare/r2/bucket.binding.d.ts.map +1 -0
  241. package/lib/cloudflare/r2/bucket.binding.js +18 -0
  242. package/lib/cloudflare/r2/bucket.binding.js.map +1 -0
  243. package/lib/cloudflare/r2/bucket.client.d.ts +8 -0
  244. package/lib/cloudflare/r2/bucket.client.d.ts.map +1 -0
  245. package/lib/cloudflare/r2/bucket.client.js +9 -0
  246. package/lib/cloudflare/r2/bucket.client.js.map +1 -0
  247. package/lib/cloudflare/r2/bucket.d.ts +33 -0
  248. package/lib/cloudflare/r2/bucket.d.ts.map +1 -0
  249. package/lib/cloudflare/r2/bucket.del.d.ts +4 -0
  250. package/lib/cloudflare/r2/bucket.del.d.ts.map +1 -0
  251. package/lib/cloudflare/r2/bucket.del.js +7 -0
  252. package/lib/cloudflare/r2/bucket.del.js.map +1 -0
  253. package/lib/cloudflare/r2/bucket.get.d.ts +5 -0
  254. package/lib/cloudflare/r2/bucket.get.d.ts.map +1 -0
  255. package/lib/cloudflare/r2/bucket.get.js +7 -0
  256. package/lib/cloudflare/r2/bucket.get.js.map +1 -0
  257. package/lib/cloudflare/r2/bucket.head.d.ts +4 -0
  258. package/lib/cloudflare/r2/bucket.head.d.ts.map +1 -0
  259. package/lib/cloudflare/r2/bucket.head.js +7 -0
  260. package/lib/cloudflare/r2/bucket.head.js.map +1 -0
  261. package/lib/cloudflare/r2/bucket.js +3 -0
  262. package/lib/cloudflare/r2/bucket.js.map +1 -0
  263. package/lib/cloudflare/r2/bucket.list.d.ts +5 -0
  264. package/lib/cloudflare/r2/bucket.list.d.ts.map +1 -0
  265. package/lib/cloudflare/r2/bucket.list.js +7 -0
  266. package/lib/cloudflare/r2/bucket.list.js.map +1 -0
  267. package/lib/cloudflare/r2/bucket.multipart.d.ts +19 -0
  268. package/lib/cloudflare/r2/bucket.multipart.d.ts.map +1 -0
  269. package/lib/cloudflare/r2/bucket.multipart.js +25 -0
  270. package/lib/cloudflare/r2/bucket.multipart.js.map +1 -0
  271. package/lib/cloudflare/r2/bucket.provider.d.ts +6 -0
  272. package/lib/cloudflare/r2/bucket.provider.d.ts.map +1 -0
  273. package/lib/cloudflare/r2/bucket.provider.js +67 -0
  274. package/lib/cloudflare/r2/bucket.provider.js.map +1 -0
  275. package/lib/cloudflare/r2/bucket.put.d.ts +6 -0
  276. package/lib/cloudflare/r2/bucket.put.d.ts.map +1 -0
  277. package/lib/cloudflare/r2/bucket.put.js +8 -0
  278. package/lib/cloudflare/r2/bucket.put.js.map +1 -0
  279. package/lib/cloudflare/r2/index.d.ts +10 -0
  280. package/lib/cloudflare/r2/index.d.ts.map +1 -0
  281. package/lib/cloudflare/r2/index.js +10 -0
  282. package/lib/cloudflare/r2/index.js.map +1 -0
  283. package/lib/cloudflare/stream.d.ts +10 -0
  284. package/lib/cloudflare/stream.d.ts.map +1 -0
  285. package/lib/cloudflare/stream.js +16 -0
  286. package/lib/cloudflare/stream.js.map +1 -0
  287. package/lib/cloudflare/worker/assets.fetch.d.ts +9 -0
  288. package/lib/cloudflare/worker/assets.fetch.d.ts.map +1 -0
  289. package/lib/cloudflare/worker/assets.fetch.js +12 -0
  290. package/lib/cloudflare/worker/assets.fetch.js.map +1 -0
  291. package/lib/cloudflare/worker/assets.provider.d.ts +66 -0
  292. package/lib/cloudflare/worker/assets.provider.d.ts.map +1 -0
  293. package/lib/cloudflare/worker/assets.provider.js +145 -0
  294. package/lib/cloudflare/worker/assets.provider.js.map +1 -0
  295. package/lib/cloudflare/worker/index.d.ts +5 -0
  296. package/lib/cloudflare/worker/index.d.ts.map +1 -0
  297. package/lib/cloudflare/worker/index.js +5 -0
  298. package/lib/cloudflare/worker/index.js.map +1 -0
  299. package/lib/cloudflare/worker/worker.d.ts +66 -0
  300. package/lib/cloudflare/worker/worker.d.ts.map +1 -0
  301. package/lib/cloudflare/worker/worker.handler.d.ts +11 -0
  302. package/lib/cloudflare/worker/worker.handler.d.ts.map +1 -0
  303. package/lib/cloudflare/worker/worker.handler.js +15 -0
  304. package/lib/cloudflare/worker/worker.handler.js.map +1 -0
  305. package/lib/cloudflare/worker/worker.js +4 -0
  306. package/lib/cloudflare/worker/worker.js.map +1 -0
  307. package/lib/cloudflare/worker/worker.provider.d.ts +11 -0
  308. package/lib/cloudflare/worker/worker.provider.d.ts.map +1 -0
  309. package/lib/cloudflare/worker/worker.provider.js +194 -0
  310. package/lib/cloudflare/worker/worker.provider.js.map +1 -0
  311. package/lib/cloudflare/worker/worker.serve.d.ts +39 -0
  312. package/lib/cloudflare/worker/worker.serve.d.ts.map +1 -0
  313. package/lib/cloudflare/worker/worker.serve.js +4 -0
  314. package/lib/cloudflare/worker/worker.serve.js.map +1 -0
  315. package/lib/data.d.ts +3 -0
  316. package/lib/data.d.ts.map +1 -0
  317. package/lib/data.js +8 -0
  318. package/lib/data.js.map +1 -0
  319. package/lib/destroy.d.ts +1 -3
  320. package/lib/destroy.d.ts.map +1 -1
  321. package/lib/destroy.js +2 -0
  322. package/lib/destroy.js.map +1 -1
  323. package/lib/diff.d.ts +16 -0
  324. package/lib/diff.d.ts.map +1 -0
  325. package/lib/diff.js +9 -0
  326. package/lib/diff.js.map +1 -0
  327. package/lib/dot-alchemy.d.ts +3 -2
  328. package/lib/dot-alchemy.d.ts.map +1 -1
  329. package/lib/dot-alchemy.js +3 -2
  330. package/lib/dot-alchemy.js.map +1 -1
  331. package/lib/env.d.ts +5 -0
  332. package/lib/env.d.ts.map +1 -1
  333. package/lib/env.js +15 -29
  334. package/lib/env.js.map +1 -1
  335. package/lib/esbuild.d.ts +28 -0
  336. package/lib/esbuild.d.ts.map +1 -0
  337. package/lib/esbuild.js +63 -0
  338. package/lib/esbuild.js.map +1 -0
  339. package/lib/exports.d.ts +9 -0
  340. package/lib/exports.d.ts.map +1 -0
  341. package/lib/exports.js +13 -0
  342. package/lib/exports.js.map +1 -0
  343. package/lib/index.d.ts +11 -5
  344. package/lib/index.d.ts.map +1 -1
  345. package/lib/index.js +11 -5
  346. package/lib/index.js.map +1 -1
  347. package/lib/input.d.ts +32 -0
  348. package/lib/input.d.ts.map +1 -0
  349. package/lib/input.js +1 -0
  350. package/lib/input.js.map +1 -0
  351. package/lib/output.d.ts +143 -0
  352. package/lib/output.d.ts.map +1 -0
  353. package/lib/output.js +269 -0
  354. package/lib/output.js.map +1 -0
  355. package/lib/plan.d.ts +59 -29
  356. package/lib/plan.d.ts.map +1 -1
  357. package/lib/plan.js +347 -169
  358. package/lib/plan.js.map +1 -1
  359. package/lib/policy.d.ts +22 -5
  360. package/lib/policy.d.ts.map +1 -1
  361. package/lib/policy.js +10 -2
  362. package/lib/policy.js.map +1 -1
  363. package/lib/provider.d.ts +16 -18
  364. package/lib/provider.d.ts.map +1 -1
  365. package/lib/ref.d.ts +14 -0
  366. package/lib/ref.d.ts.map +1 -0
  367. package/lib/ref.js +21 -0
  368. package/lib/ref.js.map +1 -0
  369. package/lib/resource.d.ts +13 -16
  370. package/lib/resource.d.ts.map +1 -1
  371. package/lib/resource.js +1 -0
  372. package/lib/resource.js.map +1 -1
  373. package/lib/runtime.d.ts +8 -7
  374. package/lib/runtime.d.ts.map +1 -1
  375. package/lib/runtime.js.map +1 -1
  376. package/lib/schema.d.ts +37 -0
  377. package/lib/schema.d.ts.map +1 -0
  378. package/lib/schema.js +61 -0
  379. package/lib/schema.js.map +1 -0
  380. package/lib/service.d.ts +9 -6
  381. package/lib/service.d.ts.map +1 -1
  382. package/lib/service.js.map +1 -1
  383. package/lib/sha256.d.ts +5 -0
  384. package/lib/sha256.d.ts.map +1 -0
  385. package/lib/sha256.js +16 -0
  386. package/lib/sha256.js.map +1 -0
  387. package/lib/stack.d.ts +60 -0
  388. package/lib/stack.d.ts.map +1 -0
  389. package/lib/stack.js +11 -0
  390. package/lib/stack.js.map +1 -0
  391. package/lib/stage.d.ts +39 -0
  392. package/lib/stage.d.ts.map +1 -0
  393. package/lib/stage.js +32 -0
  394. package/lib/stage.js.map +1 -0
  395. package/lib/state.d.ts +53 -11
  396. package/lib/state.d.ts.map +1 -1
  397. package/lib/state.js +33 -31
  398. package/lib/state.js.map +1 -1
  399. package/lib/tags.d.ts +17 -0
  400. package/lib/tags.d.ts.map +1 -0
  401. package/lib/tags.js +22 -0
  402. package/lib/tags.js.map +1 -0
  403. package/lib/test.d.ts +35 -0
  404. package/lib/test.d.ts.map +1 -0
  405. package/lib/test.js +68 -0
  406. package/lib/test.js.map +1 -0
  407. package/lib/tsconfig.test.tsbuildinfo +1 -0
  408. package/lib/type.d.ts +6 -0
  409. package/lib/type.d.ts.map +1 -0
  410. package/lib/type.js +3 -0
  411. package/lib/type.js.map +1 -0
  412. package/lib/unknown.d.ts +4 -0
  413. package/lib/unknown.d.ts.map +1 -0
  414. package/lib/unknown.js +4 -0
  415. package/lib/unknown.js.map +1 -0
  416. package/lib/user.d.ts +3 -0
  417. package/lib/user.d.ts.map +1 -0
  418. package/lib/user.js +3 -0
  419. package/lib/user.js.map +1 -0
  420. package/lib/util.d.ts +6 -0
  421. package/lib/util.d.ts.map +1 -0
  422. package/lib/util.js +9 -0
  423. package/lib/util.js.map +1 -0
  424. package/package.json +58 -7
  425. package/src/$.ts +17 -0
  426. package/src/app.ts +9 -37
  427. package/src/apply.ts +435 -289
  428. package/src/assert-never.ts +18 -0
  429. package/src/aws/account.ts +29 -7
  430. package/src/aws/arn.ts +1 -7
  431. package/src/aws/client.ts +14 -1
  432. package/src/aws/config.ts +16 -0
  433. package/src/aws/credentials.ts +213 -177
  434. package/src/aws/dynamodb/attribute-value.ts +240 -0
  435. package/src/aws/{sqs/queue.client.ts → dynamodb/client.ts} +9 -9
  436. package/src/aws/dynamodb/expr.ts +90 -0
  437. package/src/aws/dynamodb/index.ts +12 -0
  438. package/src/aws/dynamodb/projection.ts +159 -0
  439. package/src/aws/dynamodb/secondary-index.ts +45 -0
  440. package/src/aws/dynamodb/table.get-item.ts +173 -0
  441. package/src/aws/dynamodb/table.provider.ts +276 -0
  442. package/src/aws/dynamodb/table.ts +101 -0
  443. package/src/aws/ec2/client.ts +20 -0
  444. package/src/aws/ec2/index.ts +7 -0
  445. package/src/aws/ec2/subnet.provider.ts +358 -0
  446. package/src/aws/ec2/subnet.ts +213 -0
  447. package/src/aws/ec2/vpc.provider.ts +269 -0
  448. package/src/aws/ec2/vpc.ts +163 -0
  449. package/src/aws/index.ts +50 -45
  450. package/src/aws/lambda/client.ts +14 -0
  451. package/src/aws/lambda/consume.ts +8 -8
  452. package/src/aws/lambda/function.handler.ts +1 -1
  453. package/src/aws/lambda/function.invoke.ts +8 -4
  454. package/src/aws/lambda/function.provider.ts +208 -109
  455. package/src/aws/lambda/function.ts +21 -12
  456. package/src/aws/lambda/index.ts +3 -4
  457. package/src/aws/lambda/serve.ts +1 -1
  458. package/src/aws/profile.ts +1 -4
  459. package/src/aws/region.ts +43 -2
  460. package/src/aws/sqs/client.ts +20 -0
  461. package/src/aws/sqs/index.ts +4 -1
  462. package/src/aws/sqs/queue.consume.ts +1 -34
  463. package/src/aws/sqs/queue.event-source.ts +227 -0
  464. package/src/aws/sqs/queue.provider.ts +14 -7
  465. package/src/aws/sqs/queue.send-message.ts +7 -10
  466. package/src/aws/sqs/queue.ts +9 -4
  467. package/src/binding.ts +130 -34
  468. package/src/capability.ts +44 -0
  469. package/src/cli/components/ApprovePlan.tsx +2 -2
  470. package/src/cli/components/Plan.tsx +6 -3
  471. package/src/cli/components/PlanProgress.tsx +32 -14
  472. package/src/cli/index.ts +2 -6
  473. package/src/cli/ink-service.tsx +61 -0
  474. package/src/cli/service.ts +23 -0
  475. package/src/cloudflare/account.ts +37 -0
  476. package/src/cloudflare/api.ts +147 -63
  477. package/src/cloudflare/config.ts +7 -0
  478. package/src/cloudflare/context.ts +49 -0
  479. package/src/cloudflare/index.ts +8 -4
  480. package/src/cloudflare/kv/index.ts +3 -0
  481. package/src/cloudflare/kv/namespace.binding.ts +27 -0
  482. package/src/cloudflare/kv/namespace.client.ts +70 -0
  483. package/src/cloudflare/kv/namespace.provider.ts +100 -0
  484. package/src/cloudflare/kv/namespace.ts +30 -0
  485. package/src/cloudflare/live.ts +32 -0
  486. package/src/cloudflare/r2/bucket.binding.ts +29 -0
  487. package/src/cloudflare/r2/bucket.client.ts +22 -0
  488. package/src/cloudflare/r2/bucket.del.ts +11 -0
  489. package/src/cloudflare/r2/bucket.get.ts +13 -0
  490. package/src/cloudflare/r2/bucket.head.ts +11 -0
  491. package/src/cloudflare/r2/bucket.list.ts +12 -0
  492. package/src/cloudflare/r2/bucket.multipart.ts +55 -0
  493. package/src/cloudflare/r2/bucket.provider.ts +84 -0
  494. package/src/cloudflare/r2/bucket.put.ts +17 -0
  495. package/src/cloudflare/r2/bucket.ts +44 -0
  496. package/src/cloudflare/r2/index.ts +9 -0
  497. package/src/cloudflare/stream.ts +21 -0
  498. package/src/cloudflare/worker/assets.fetch.ts +29 -0
  499. package/src/cloudflare/worker/assets.provider.ts +249 -0
  500. package/src/cloudflare/worker/index.ts +4 -0
  501. package/src/cloudflare/worker/worker.handler.ts +39 -0
  502. package/src/cloudflare/worker/worker.provider.ts +249 -0
  503. package/src/cloudflare/worker/worker.serve.ts +22 -0
  504. package/src/cloudflare/worker/worker.ts +77 -0
  505. package/src/data.ts +18 -0
  506. package/src/destroy.ts +2 -3
  507. package/src/diff.ts +30 -0
  508. package/src/dot-alchemy.ts +3 -2
  509. package/src/env.ts +20 -32
  510. package/src/esbuild.ts +98 -0
  511. package/src/exports.ts +21 -0
  512. package/src/index.ts +12 -6
  513. package/src/input.ts +81 -0
  514. package/src/output.ts +518 -0
  515. package/src/plan.ts +544 -243
  516. package/src/policy.ts +58 -7
  517. package/src/provider.ts +27 -25
  518. package/src/ref.ts +48 -0
  519. package/src/resource.ts +23 -8
  520. package/src/runtime.ts +16 -9
  521. package/src/schema.ts +102 -0
  522. package/src/service.ts +11 -7
  523. package/src/sha256.ts +23 -0
  524. package/src/stack.ts +116 -0
  525. package/src/stage.ts +85 -0
  526. package/src/state.ts +141 -62
  527. package/src/tags.ts +38 -0
  528. package/src/test.ts +172 -0
  529. package/src/type.ts +6 -0
  530. package/src/unknown.ts +6 -0
  531. package/src/user.ts +4 -0
  532. package/src/util.ts +21 -0
  533. package/lib/approve.d.ts +0 -15
  534. package/lib/approve.d.ts.map +0 -1
  535. package/lib/approve.js +0 -7
  536. package/lib/approve.js.map +0 -1
  537. package/lib/aws/lambda/function.client.d.ts +0 -8
  538. package/lib/aws/lambda/function.client.d.ts.map +0 -1
  539. package/lib/aws/lambda/function.client.js +0 -7
  540. package/lib/aws/lambda/function.client.js.map +0 -1
  541. package/lib/aws/sqs/queue.client.d.ts +0 -12
  542. package/lib/aws/sqs/queue.client.d.ts.map +0 -1
  543. package/lib/aws/sqs/queue.client.js.map +0 -1
  544. package/lib/cli/approve.d.ts +0 -4
  545. package/lib/cli/approve.d.ts.map +0 -1
  546. package/lib/cli/approve.js +0 -18
  547. package/lib/cli/approve.js.map +0 -1
  548. package/lib/cli/clack.d.ts +0 -14
  549. package/lib/cli/clack.d.ts.map +0 -1
  550. package/lib/cli/clack.js +0 -12
  551. package/lib/cli/clack.js.map +0 -1
  552. package/lib/cli/main.d.ts +0 -2
  553. package/lib/cli/main.d.ts.map +0 -1
  554. package/lib/cli/main.js +0 -1
  555. package/lib/cli/main.js.map +0 -1
  556. package/lib/cli/plan.d.ts +0 -13
  557. package/lib/cli/plan.d.ts.map +0 -1
  558. package/lib/cli/plan.js +0 -1
  559. package/lib/cli/plan.js.map +0 -1
  560. package/lib/cli/progress.d.ts +0 -7
  561. package/lib/cli/progress.d.ts.map +0 -1
  562. package/lib/cli/progress.js +0 -29
  563. package/lib/cli/progress.js.map +0 -1
  564. package/lib/cli/spinner.d.ts +0 -2
  565. package/lib/cli/spinner.d.ts.map +0 -1
  566. package/lib/cli/spinner.js +0 -13
  567. package/lib/cli/spinner.js.map +0 -1
  568. package/lib/cloudflare/kv.d.ts +0 -29
  569. package/lib/cloudflare/kv.d.ts.map +0 -1
  570. package/lib/cloudflare/kv.js +0 -3
  571. package/lib/cloudflare/kv.js.map +0 -1
  572. package/lib/cloudflare/kv.provider.d.ts +0 -4
  573. package/lib/cloudflare/kv.provider.d.ts.map +0 -1
  574. package/lib/cloudflare/kv.provider.js +0 -39
  575. package/lib/cloudflare/kv.provider.js.map +0 -1
  576. package/lib/cloudflare/worker.d.ts +0 -33
  577. package/lib/cloudflare/worker.d.ts.map +0 -1
  578. package/lib/cloudflare/worker.js +0 -4
  579. package/lib/cloudflare/worker.js.map +0 -1
  580. package/src/approve.ts +0 -13
  581. package/src/aws/lambda/function.client.ts +0 -14
  582. package/src/cli/approve.tsx +0 -30
  583. package/src/cli/clack.ts +0 -22
  584. package/src/cli/main.ts +0 -0
  585. package/src/cli/plan.ts +0 -16
  586. package/src/cli/progress.tsx +0 -45
  587. package/src/cli/spinner.ts +0 -14
  588. package/src/cloudflare/kv.provider.ts +0 -51
  589. package/src/cloudflare/kv.ts +0 -20
  590. package/src/cloudflare/worker.ts +0 -34
@@ -0,0 +1,249 @@
1
+ import { FileSystem, Path } from "@effect/platform";
2
+ import type { PlatformError } from "@effect/platform/Error";
3
+ import { Context, Data, Layer } from "effect";
4
+ import * as Effect from "effect/Effect";
5
+ import type { ScopedPlanStatusSession } from "../../cli/service.ts";
6
+ import { sha256 } from "../../sha256.ts";
7
+ import { CloudflareApi, CloudflareApiError } from "../api.ts";
8
+ import type { Worker } from "./worker.ts";
9
+
10
+ const MAX_ASSET_SIZE = 1024 * 1024 * 25; // 25MB
11
+ const MAX_ASSET_COUNT = 20_000;
12
+
13
+ export declare namespace Assets {
14
+ export interface ReadResult {
15
+ directory: string;
16
+ config: Worker.AssetsConfig | undefined;
17
+ manifest: Record<string, { hash: string; size: number }>;
18
+ _headers: string | undefined;
19
+ _redirects: string | undefined;
20
+ }
21
+ }
22
+
23
+ export class Assets extends Context.Tag("Assets")<
24
+ Assets,
25
+ {
26
+ read(
27
+ directory: Worker.AssetsProps,
28
+ ): Effect.Effect<Assets.ReadResult, PlatformError | ValidationError>;
29
+ upload(
30
+ accountId: string,
31
+ workerName: string,
32
+ assets: Assets.ReadResult,
33
+ session: ScopedPlanStatusSession,
34
+ ): Effect.Effect<
35
+ { jwt: string | undefined },
36
+ PlatformError | ValidationError | CloudflareApiError
37
+ >;
38
+ }
39
+ >() {}
40
+
41
+ export class AssetTooLargeError extends Data.TaggedError("AssetTooLargeError")<{
42
+ message: string;
43
+ name: string;
44
+ size: number;
45
+ }> {}
46
+
47
+ export class TooManyAssetsError extends Data.TaggedError("TooManyAssetsError")<{
48
+ message: string;
49
+ directory: string;
50
+ count: number;
51
+ }> {}
52
+
53
+ export class AssetNotFoundError extends Data.TaggedError("AssetNotFoundError")<{
54
+ message: string;
55
+ hash: string;
56
+ }> {}
57
+
58
+ export class FailedToReadAssetError extends Data.TaggedError(
59
+ "FailedToReadAssetError",
60
+ )<{
61
+ message: string;
62
+ name: string;
63
+ cause: PlatformError;
64
+ }> {}
65
+
66
+ export type ValidationError =
67
+ | AssetTooLargeError
68
+ | TooManyAssetsError
69
+ | AssetNotFoundError
70
+ | FailedToReadAssetError;
71
+
72
+ export const assetsProvider = () =>
73
+ Layer.effect(
74
+ Assets,
75
+ Effect.gen(function* () {
76
+ const fs = yield* FileSystem.FileSystem;
77
+ const path = yield* Path.Path;
78
+ const api = yield* CloudflareApi;
79
+
80
+ const maybeReadString = Effect.fnUntraced(function* (file: string) {
81
+ return yield* fs.readFileString(file).pipe(
82
+ Effect.catchIf(
83
+ (error) =>
84
+ error._tag === "SystemError" && error.reason === "NotFound",
85
+ () => Effect.succeed(undefined),
86
+ ),
87
+ );
88
+ });
89
+
90
+ const createIgnoreMatcher = Effect.fnUntraced(function* (
91
+ patterns: string[],
92
+ ) {
93
+ const matcher = yield* Effect.promise(() =>
94
+ import("ignore").then(({ default: ignore }) =>
95
+ ignore().add(patterns),
96
+ ),
97
+ );
98
+ return (file: string) => matcher.ignores(file);
99
+ });
100
+
101
+ return {
102
+ read: Effect.fnUntraced(function* (props: Worker.AssetsProps) {
103
+ const resolvedDirectory = path.resolve(props.directory);
104
+ const [files, ignore, _headers, _redirects] = yield* Effect.all([
105
+ fs.readDirectory(resolvedDirectory, { recursive: true }),
106
+ maybeReadString(path.join(resolvedDirectory, ".assetsignore")),
107
+ maybeReadString(path.join(resolvedDirectory, "_headers")),
108
+ maybeReadString(path.join(resolvedDirectory, "_redirects")),
109
+ ]);
110
+ const ignores = yield* createIgnoreMatcher([
111
+ ".assetsignore",
112
+ "_headers",
113
+ "_redirects",
114
+ ...(ignore
115
+ ?.split("\n")
116
+ .map((line) => line.trim())
117
+ .filter((line) => line.length > 0 && !line.startsWith("#")) ??
118
+ []),
119
+ ]);
120
+ const manifest = new Map<string, { hash: string; size: number }>();
121
+ let count = 0;
122
+ yield* Effect.forEach(
123
+ files,
124
+ Effect.fnUntraced(function* (name) {
125
+ if (ignores(name)) {
126
+ return;
127
+ }
128
+ const file = path.join(resolvedDirectory, name);
129
+ const stat = yield* fs.stat(file);
130
+ if (stat.type !== "File") {
131
+ return;
132
+ }
133
+ const size = Number(stat.size);
134
+ if (size > MAX_ASSET_SIZE) {
135
+ return yield* new AssetTooLargeError({
136
+ message: `Asset ${name} is too large (the maximum size is ${MAX_ASSET_SIZE / 1024 / 1024} MB; this asset is ${size / 1024 / 1024} MB)`,
137
+ name,
138
+ size,
139
+ });
140
+ }
141
+ const hash = yield* fs.readFile(file).pipe(
142
+ Effect.flatMap(sha256),
143
+ Effect.map((hash) => hash.slice(0, 32)),
144
+ );
145
+ count++;
146
+ if (count > MAX_ASSET_COUNT) {
147
+ return yield* new TooManyAssetsError({
148
+ message: `Too many assets (the maximum count is ${MAX_ASSET_COUNT}; this directory has ${count} assets)`,
149
+ directory: props.directory,
150
+ count,
151
+ });
152
+ }
153
+ manifest.set(name.startsWith("/") ? name : `/${name}`, {
154
+ hash,
155
+ size,
156
+ });
157
+ }),
158
+ );
159
+ return {
160
+ directory: props.directory,
161
+ config: props.config,
162
+ manifest: Object.fromEntries(
163
+ Array.from(manifest.entries()).sort((a, b) =>
164
+ a[0].localeCompare(b[0]),
165
+ ),
166
+ ),
167
+ _headers,
168
+ _redirects,
169
+ };
170
+ }),
171
+ upload: Effect.fnUntraced(function* (
172
+ accountId: string,
173
+ workerName: string,
174
+ assets: Assets.ReadResult,
175
+ { note }: ScopedPlanStatusSession,
176
+ ) {
177
+ yield* note("Checking assets...");
178
+ const session = yield* api.workers.scripts.assets.upload.create(
179
+ workerName,
180
+ {
181
+ account_id: accountId,
182
+ manifest: assets.manifest,
183
+ },
184
+ );
185
+ if (!session.buckets?.length) {
186
+ return { jwt: session.jwt };
187
+ }
188
+ let uploaded = 0;
189
+ const total = session.buckets.flat().length;
190
+ yield* note(`Uploaded ${uploaded} of ${total} assets...`);
191
+ const assetsByHash = new Map<string, string>();
192
+ for (const [name, { hash }] of Object.entries(assets.manifest)) {
193
+ assetsByHash.set(hash, name);
194
+ }
195
+ let jwt: string | undefined;
196
+ const directory = path.resolve(assets.directory);
197
+ yield* Effect.forEach(
198
+ session.buckets,
199
+ Effect.fnUntraced(function* (bucket) {
200
+ const body: Record<string, string> = {};
201
+ yield* Effect.forEach(
202
+ bucket,
203
+ Effect.fnUntraced(function* (hash) {
204
+ const name = assetsByHash.get(hash);
205
+ if (!name) {
206
+ return yield* new AssetNotFoundError({
207
+ message: `Asset ${hash} not found in manifest`,
208
+ hash,
209
+ });
210
+ }
211
+ const file = yield* fs
212
+ .readFile(path.join(directory, name))
213
+ .pipe(
214
+ Effect.mapError(
215
+ (error) =>
216
+ new FailedToReadAssetError({
217
+ message: `Failed to read asset ${name}: ${error.message}`,
218
+ name,
219
+ cause: error,
220
+ }),
221
+ ),
222
+ );
223
+ body[hash] = Buffer.from(file).toString("base64");
224
+ }),
225
+ );
226
+ const result = yield* api.workers.assets.upload.create(
227
+ {
228
+ account_id: accountId,
229
+ base64: true,
230
+ body,
231
+ },
232
+ {
233
+ headers: {
234
+ Authorization: `Bearer ${session.jwt}`,
235
+ },
236
+ },
237
+ );
238
+ uploaded += bucket.length;
239
+ yield* note(`Uploaded ${uploaded} of ${total} assets...`);
240
+ if (result.jwt) {
241
+ jwt = result.jwt;
242
+ }
243
+ }),
244
+ );
245
+ return { jwt };
246
+ }),
247
+ };
248
+ }),
249
+ );
@@ -0,0 +1,4 @@
1
+ export * from "./assets.fetch.ts";
2
+ export * from "./worker.handler.ts";
3
+ export * from "./worker.serve.ts";
4
+ export * from "./worker.ts";
@@ -0,0 +1,39 @@
1
+ import type * as runtime from "@cloudflare/workers-types";
2
+ import * as Effect from "effect/Effect";
3
+ import * as Layer from "effect/Layer";
4
+ import type { Capability } from "../../capability.ts";
5
+ import { CloudflareContext } from "../context.ts";
6
+
7
+ type Handler = (
8
+ request: Request,
9
+ env: unknown,
10
+ ctx: runtime.ExecutionContext,
11
+ ) => Effect.Effect<Response, any, CloudflareContext>;
12
+ type HandlerFactory<H extends Handler, Req = Capability> = Effect.Effect<
13
+ H,
14
+ any,
15
+ Req
16
+ >;
17
+
18
+ export const toHandler = <H extends Handler>(
19
+ factory: HandlerFactory<H, Capability>,
20
+ ) => {
21
+ return {
22
+ fetch: async (
23
+ request: Request,
24
+ env: unknown,
25
+ ctx: runtime.ExecutionContext,
26
+ ) => {
27
+ const exit = await Effect.runPromiseExit(
28
+ (factory as HandlerFactory<H, never>).pipe(
29
+ Effect.flatMap((handler) => handler(request, env, ctx)),
30
+ Effect.provide(Layer.succeed(CloudflareContext, { env, ctx })),
31
+ ),
32
+ );
33
+ if (exit._tag === "Success") {
34
+ return exit.value;
35
+ }
36
+ return Response.json(exit, { status: 500 });
37
+ },
38
+ };
39
+ };
@@ -0,0 +1,249 @@
1
+ import * as FileSystem from "@effect/platform/FileSystem";
2
+ import * as Path from "@effect/platform/Path";
3
+ import type { Workers } from "cloudflare/resources.mjs";
4
+ import * as Effect from "effect/Effect";
5
+ import { App } from "../../app.ts";
6
+ import type { ScopedPlanStatusSession } from "../../cli/service.ts";
7
+ import { DotAlchemy } from "../../dot-alchemy.ts";
8
+ import { ESBuild } from "../../esbuild.ts";
9
+ import { sha256 } from "../../sha256.ts";
10
+ import { CloudflareApi } from "../api.ts";
11
+ import { Account } from "../account.ts";
12
+ import { Assets } from "./assets.provider.ts";
13
+ import { Worker, type WorkerAttr, type WorkerProps } from "./worker.ts";
14
+
15
+ export const workerProvider = () =>
16
+ Worker.provider.effect(
17
+ Effect.gen(function* () {
18
+ const app = yield* App;
19
+ const api = yield* CloudflareApi;
20
+ const accountId = yield* Account;
21
+ const { read, upload } = yield* Assets;
22
+ const { build } = yield* ESBuild;
23
+ const fs = yield* FileSystem.FileSystem;
24
+ const path = yield* Path.Path;
25
+ const dotAlchemy = yield* DotAlchemy;
26
+
27
+ const getAccountSubdomain = yield* Effect.cachedFunction(
28
+ Effect.fnUntraced(function* (accountId: string) {
29
+ const { subdomain } = yield* api.workers.subdomains.get({
30
+ account_id: accountId,
31
+ });
32
+ return subdomain;
33
+ }),
34
+ );
35
+
36
+ // pre-fetch subdomain in background
37
+ yield* Effect.forkDaemon(getAccountSubdomain(accountId));
38
+
39
+ const setWorkerSubdomain = Effect.fnUntraced(function* (
40
+ name: string,
41
+ enabled: boolean,
42
+ ) {
43
+ const subdomain = yield* api.workers.scripts.subdomain.create(name, {
44
+ account_id: accountId,
45
+ enabled,
46
+ });
47
+ yield* Effect.logDebug("setWorkerSubdomain", subdomain);
48
+ });
49
+
50
+ const createWorkerName = (id: string, name: string | undefined) =>
51
+ name ?? `${app.name}-${id}-${app.stage}`.toLowerCase();
52
+
53
+ const prepareAssets = Effect.fnUntraced(function* (
54
+ assets: WorkerProps["assets"],
55
+ ) {
56
+ if (!assets) return undefined;
57
+ const result = yield* read(
58
+ typeof assets === "string" ? { directory: assets } : assets,
59
+ );
60
+ return {
61
+ ...result,
62
+ hash: yield* sha256(JSON.stringify(result)),
63
+ };
64
+ });
65
+
66
+ const prepareBundle = Effect.fnUntraced(function* (
67
+ id: string,
68
+ main: string,
69
+ ) {
70
+ const outfile = path.join(dotAlchemy, "out", `${id}.js`);
71
+ yield* build({
72
+ entryPoints: [path.relative(process.cwd(), main)],
73
+ outfile,
74
+ write: true,
75
+ bundle: true,
76
+ format: "esm",
77
+ sourcemap: false,
78
+ treeShaking: true,
79
+ });
80
+ const code = yield* fs.readFileString(outfile);
81
+ return {
82
+ code,
83
+ hash: yield* sha256(code),
84
+ };
85
+ });
86
+
87
+ const prepareMetadata = Effect.fnUntraced(function* (
88
+ props: WorkerProps<any>,
89
+ ) {
90
+ const metadata: Workers.ScriptUpdateParams.Metadata = {
91
+ assets: undefined,
92
+ bindings: [],
93
+ body_part: undefined,
94
+ compatibility_date: props.compatibility?.date,
95
+ compatibility_flags: props.compatibility?.flags,
96
+ keep_assets: undefined,
97
+ keep_bindings: undefined,
98
+ limits: props.limits,
99
+ logpush: props.logpush,
100
+ main_module: "worker.js",
101
+ migrations: undefined,
102
+ observability: props.observability ?? {
103
+ enabled: true,
104
+ logs: {
105
+ enabled: true,
106
+ invocation_logs: true,
107
+ },
108
+ },
109
+ placement: props.placement,
110
+ tags: props.tags,
111
+ tail_consumers: undefined,
112
+ usage_model: undefined,
113
+ };
114
+ return metadata;
115
+ });
116
+
117
+ const putWorker = Effect.fnUntraced(function* (
118
+ id: string,
119
+ news: WorkerProps<any>,
120
+ bindings: Worker["binding"][],
121
+ olds: WorkerProps<any> | undefined,
122
+ output: WorkerAttr<WorkerProps<any>> | undefined,
123
+ session: ScopedPlanStatusSession,
124
+ ) {
125
+ const name = createWorkerName(id, news.name);
126
+ const [assets, bundle, metadata] = yield* Effect.all([
127
+ prepareAssets(news.assets),
128
+ prepareBundle(id, news.main),
129
+ prepareMetadata(news),
130
+ ]).pipe(Effect.orDie);
131
+ metadata.bindings = bindings.flatMap((binding) => binding.bindings);
132
+ if (assets) {
133
+ if (output?.hash.assets !== assets.hash) {
134
+ const { jwt } = yield* upload(accountId, name, assets, session);
135
+ metadata.assets = {
136
+ jwt,
137
+ config: assets.config,
138
+ };
139
+ } else {
140
+ metadata.assets = {
141
+ config: assets.config,
142
+ };
143
+ metadata.keep_assets = true;
144
+ }
145
+ metadata.bindings.push({
146
+ type: "assets",
147
+ name: "ASSETS",
148
+ });
149
+ }
150
+ yield* session.note("Uploading worker...");
151
+ const worker = yield* api.workers.scripts.update(name, {
152
+ account_id: accountId,
153
+ metadata: metadata,
154
+ files: [
155
+ new File([bundle.code], "worker.js", {
156
+ type: "application/javascript+module",
157
+ }),
158
+ ],
159
+ });
160
+ if (!olds || news.subdomain?.enabled !== olds.subdomain?.enabled) {
161
+ const enable = news.subdomain?.enabled !== false;
162
+ yield* session.note(
163
+ `${enable ? "Enabling" : "Disabling"} workers.dev subdomain...`,
164
+ );
165
+ yield* setWorkerSubdomain(name, enable);
166
+ }
167
+ return {
168
+ id: worker.id,
169
+ name,
170
+ logpush: worker.logpush,
171
+ observability: metadata.observability,
172
+ subdomain: news.subdomain ?? {
173
+ enabled: true,
174
+ previews_enabled: true,
175
+ },
176
+ url:
177
+ news.subdomain?.enabled !== false
178
+ ? `https://${name}.${yield* getAccountSubdomain(accountId)}.workers.dev`
179
+ : undefined,
180
+ tags: metadata.tags,
181
+ accountId,
182
+ hash: {
183
+ assets: assets?.hash,
184
+ bundle: bundle.hash,
185
+ },
186
+ } as WorkerAttr<WorkerProps<any>>;
187
+ });
188
+
189
+ return {
190
+ diff: Effect.fnUntraced(function* ({ id, olds, news, output }) {
191
+ if (output.accountId !== accountId) {
192
+ return { action: "replace" };
193
+ }
194
+ const workerName = createWorkerName(id, news.name);
195
+ if (workerName !== output.name) {
196
+ return { action: "replace" };
197
+ }
198
+ const [assets, bundle] = yield* Effect.all([
199
+ prepareAssets(news.assets),
200
+ prepareBundle(id, news.main),
201
+ ]).pipe(Effect.orDie);
202
+ if (
203
+ assets?.hash !== output.hash.assets ||
204
+ bundle.hash !== output.hash.bundle
205
+ ) {
206
+ return { action: "update" };
207
+ }
208
+ }),
209
+ create: Effect.fnUntraced(function* ({ id, news, bindings, session }) {
210
+ const name = createWorkerName(id, news.name);
211
+ const existing = yield* api.workers.beta.workers
212
+ .get(name, {
213
+ account_id: accountId,
214
+ })
215
+ .pipe(Effect.catchTag("NotFound", () => Effect.void));
216
+ if (existing) {
217
+ return yield* Effect.fail(
218
+ new Error(`Worker "${name}" already exists`),
219
+ );
220
+ }
221
+ return yield* putWorker(
222
+ id,
223
+ news,
224
+ bindings,
225
+ undefined,
226
+ undefined,
227
+ session,
228
+ );
229
+ }),
230
+ update: Effect.fnUntraced(function* ({
231
+ id,
232
+ olds,
233
+ news,
234
+ output,
235
+ bindings,
236
+ session,
237
+ }) {
238
+ return yield* putWorker(id, news, bindings, olds, output, session);
239
+ }),
240
+ delete: Effect.fnUntraced(function* ({ output }) {
241
+ yield* api.workers.scripts
242
+ .delete(output.id, {
243
+ account_id: output.accountId,
244
+ })
245
+ .pipe(Effect.catchTag("NotFound", () => Effect.void));
246
+ }),
247
+ };
248
+ }),
249
+ );
@@ -0,0 +1,22 @@
1
+ import type { ExecutionContext } from "@cloudflare/workers-types";
2
+ import * as Effect from "effect/Effect";
3
+ import * as Worker from "./worker.ts";
4
+
5
+ export type { ExecutionContext };
6
+ export type * from "../../exports.ts";
7
+
8
+ export const serve =
9
+ <const ID extends string, Req>(
10
+ id: ID,
11
+ {
12
+ fetch,
13
+ }: {
14
+ fetch: (
15
+ request: Request,
16
+ env: unknown,
17
+ ctx: ExecutionContext,
18
+ ) => Effect.Effect<Response, never, Req>;
19
+ },
20
+ ) =>
21
+ <const Props extends Worker.WorkerProps<Req>>(props: Props) =>
22
+ Worker.Worker(id, { handle: fetch })(props);
@@ -0,0 +1,77 @@
1
+ import type { Workers } from "cloudflare/resources";
2
+ import { Runtime, type RuntimeProps } from "../../runtime.ts";
3
+ import type * as Assets from "./assets.fetch.ts";
4
+
5
+ export const WorkerType = "Cloudflare.Worker" as const;
6
+ export type WorkerType = typeof WorkerType;
7
+
8
+ export type WorkerProps<Req = any> = RuntimeProps<
9
+ Worker,
10
+ Exclude<Req, Assets.Fetch>
11
+ > & {
12
+ name?: string;
13
+ logpush?: boolean;
14
+ observability?: Worker.Observability;
15
+ subdomain?: Worker.Subdomain;
16
+ tags?: string[];
17
+ main: string;
18
+ compatibility?: {
19
+ date?: string;
20
+ flags?: string[];
21
+ };
22
+ limits?: Worker.Limits;
23
+ placement?: Worker.Placement;
24
+ } & (Extract<Req, Assets.Fetch> extends never
25
+ ? {
26
+ assets?: string | Worker.AssetsProps;
27
+ }
28
+ : {
29
+ assets: string | Worker.AssetsProps;
30
+ });
31
+
32
+ export type WorkerAttr<Props extends WorkerProps<any>> = {
33
+ id: string;
34
+ name: Props["name"] extends string ? Props["name"] : string;
35
+ logpush: Props["logpush"] extends boolean ? Props["logpush"] : boolean;
36
+ observability: Props["observability"] extends Worker.Observability
37
+ ? Props["observability"]
38
+ : {
39
+ // whatever cloudflare's (or our, probably ours) default is
40
+ };
41
+ url: Props["subdomain"] extends { enabled: false } ? undefined : string;
42
+ subdomain: Props["subdomain"] extends Worker.Subdomain
43
+ ? Props["subdomain"]
44
+ : { enabled: true; previews_enabled: true };
45
+ tags: Props["tags"] extends string[] ? Props["tags"] : string[];
46
+ accountId: string;
47
+ hash: { assets: string | undefined; bundle: string };
48
+ };
49
+
50
+ export interface Worker extends Runtime<WorkerType> {
51
+ base: Worker;
52
+ props: WorkerProps<any>;
53
+ attr: WorkerAttr<Extract<this["props"], WorkerProps<any>>>;
54
+ binding: {
55
+ bindings: Worker.Binding[];
56
+ };
57
+ }
58
+
59
+ export const Worker = Runtime(WorkerType)<Worker>();
60
+
61
+ export declare namespace Worker {
62
+ export type Observability = Workers.ScriptUpdateParams.Metadata.Observability;
63
+ export type Subdomain = Workers.Beta.Worker.Subdomain;
64
+ export type Binding = NonNullable<
65
+ Workers.Beta.Workers.VersionCreateParams["bindings"]
66
+ >[number];
67
+ export type Limits = Workers.Beta.Workers.Version.Limits;
68
+ export type Placement = Workers.Beta.Workers.Version.Placement;
69
+ export type Assets = Workers.Beta.Workers.Version.Assets;
70
+ export type AssetsConfig = Workers.Beta.Workers.Version.Assets.Config;
71
+ export type Module = Workers.Beta.Workers.Version.Module;
72
+
73
+ export interface AssetsProps {
74
+ directory: string;
75
+ config?: AssetsConfig;
76
+ }
77
+ }
package/src/data.ts ADDED
@@ -0,0 +1,18 @@
1
+ export type Primitive =
2
+ | never
3
+ | undefined
4
+ | null
5
+ | boolean
6
+ | number
7
+ | string
8
+ | bigint
9
+ | symbol;
10
+
11
+ export const isPrimitive = (value: any): value is Primitive =>
12
+ value === undefined ||
13
+ value === null ||
14
+ typeof value === "boolean" ||
15
+ typeof value === "number" ||
16
+ typeof value === "string" ||
17
+ typeof value === "symbol" ||
18
+ typeof value === "bigint";
package/src/destroy.ts CHANGED
@@ -1,4 +1,3 @@
1
- import type * as Effect from "effect/Effect";
2
- import type { App } from "./app.ts";
1
+ import { apply } from "./apply.ts";
3
2
 
4
- export declare const destroy: () => Effect.Effect<void, never, App>;
3
+ export const destroy = () => apply();
package/src/diff.ts ADDED
@@ -0,0 +1,30 @@
1
+ export type Diff =
2
+ | {
3
+ action: "noop";
4
+ deleteFirst?: undefined;
5
+ stables?: undefined;
6
+ }
7
+ | {
8
+ action: "update";
9
+ deleteFirst?: undefined;
10
+ /** properties that won't change as part of this update */
11
+ stables?: string[];
12
+ }
13
+ | {
14
+ action: "replace";
15
+ deleteFirst?: boolean;
16
+ stables?: undefined;
17
+ };
18
+
19
+ export const somePropsAreDifferent = <Props extends Record<string, any>>(
20
+ olds: Props,
21
+ news: Props,
22
+ props: (keyof Props)[],
23
+ ) => {
24
+ for (const prop of props) {
25
+ if (olds[prop] !== news[prop]) {
26
+ return true;
27
+ }
28
+ }
29
+ return false;
30
+ };