@remotion/lambda 4.0.0-webhook.26 → 4.1.0-alpha2

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 (409) hide show
  1. package/LICENSE.md +8 -8
  2. package/dist/admin/bundle-lambda.d.ts +0 -0
  3. package/dist/admin/bundle-lambda.js +24 -13
  4. package/dist/admin/generate-etag-list.d.ts +1 -0
  5. package/dist/admin/generate-etag-list.js +14 -0
  6. package/dist/admin/make-layer-public.d.ts +0 -0
  7. package/dist/admin/make-layer-public.js +59 -65
  8. package/dist/api/bucket-exists.d.ts +0 -0
  9. package/dist/api/bucket-exists.js +0 -0
  10. package/dist/api/clean-items.d.ts +0 -0
  11. package/dist/api/clean-items.js +1 -1
  12. package/dist/api/create-bucket.d.ts +0 -0
  13. package/dist/api/create-bucket.js +34 -1
  14. package/dist/api/create-function.d.ts +1 -3
  15. package/dist/api/create-function.js +27 -6
  16. package/dist/api/delete-function.d.ts +4 -4
  17. package/dist/api/delete-function.js +3 -3
  18. package/dist/api/delete-render.d.ts +2 -2
  19. package/dist/api/delete-render.js +1 -1
  20. package/dist/api/delete-site.d.ts +7 -7
  21. package/dist/api/delete-site.js +9 -7
  22. package/dist/api/deploy-function.d.ts +11 -13
  23. package/dist/api/deploy-function.js +28 -31
  24. package/dist/api/deploy-site.d.ts +13 -5
  25. package/dist/api/deploy-site.js +61 -25
  26. package/dist/api/download-media.d.ts +4 -8
  27. package/dist/api/download-media.js +5 -9
  28. package/dist/api/estimate-price.d.ts +3 -5
  29. package/dist/api/estimate-price.js +4 -10
  30. package/dist/api/get-aws-client.d.ts +6 -4
  31. package/dist/api/get-aws-client.js +3 -1
  32. package/dist/api/get-buckets.d.ts +1 -1
  33. package/dist/api/get-buckets.js +26 -9
  34. package/dist/api/get-compositions-on-lambda.d.ts +31 -0
  35. package/dist/api/get-compositions-on-lambda.js +56 -0
  36. package/dist/api/get-function-info.d.ts +3 -3
  37. package/dist/api/get-function-info.js +1 -1
  38. package/dist/api/get-functions.d.ts +5 -7
  39. package/dist/api/get-functions.js +8 -10
  40. package/dist/api/get-or-create-bucket.d.ts +6 -6
  41. package/dist/api/get-or-create-bucket.js +10 -18
  42. package/dist/api/get-regions.d.ts +6 -2
  43. package/dist/api/get-regions.js +6 -3
  44. package/dist/api/get-render-progress.d.ts +3 -3
  45. package/dist/api/get-render-progress.js +6 -11
  46. package/dist/api/get-sites.d.ts +4 -5
  47. package/dist/api/get-sites.js +1 -2
  48. package/dist/api/iam-validation/role-permissions.d.ts +0 -0
  49. package/dist/api/iam-validation/role-permissions.js +0 -0
  50. package/dist/api/iam-validation/simulate-rule.d.ts +2 -2
  51. package/dist/api/iam-validation/simulate-rule.js +0 -22
  52. package/dist/api/iam-validation/simulate.d.ts +3 -3
  53. package/dist/api/iam-validation/simulate.js +27 -6
  54. package/dist/api/iam-validation/suggested-policy.d.ts +0 -0
  55. package/dist/api/iam-validation/suggested-policy.js +0 -0
  56. package/dist/api/iam-validation/user-permissions.d.ts +1 -1
  57. package/dist/api/iam-validation/user-permissions.js +3 -8
  58. package/dist/api/make-lambda-payload.d.ts +5 -0
  59. package/dist/api/make-lambda-payload.js +77 -0
  60. package/dist/api/mock-functions.d.ts +0 -0
  61. package/dist/api/mock-functions.js +0 -0
  62. package/dist/api/presign-url.d.ts +4 -5
  63. package/dist/api/presign-url.js +3 -3
  64. package/dist/api/render-media-on-lambda.d.ts +25 -11
  65. package/dist/api/render-media-on-lambda.js +16 -49
  66. package/dist/api/render-still-on-lambda.d.ts +15 -6
  67. package/dist/api/render-still-on-lambda.js +23 -9
  68. package/dist/api/speculate-function-name.d.ts +14 -0
  69. package/dist/api/speculate-function-name.js +22 -0
  70. package/dist/api/upload-dir.d.ts +6 -5
  71. package/dist/api/upload-dir.js +54 -51
  72. package/dist/api/validate-webhook-signature.d.ts +2 -2
  73. package/dist/api/validate-webhook-signature.js +1 -1
  74. package/dist/cli/args.d.ts +7 -5
  75. package/dist/cli/args.js +1 -5
  76. package/dist/cli/commands/compositions/index.d.ts +2 -0
  77. package/dist/cli/commands/compositions/index.js +44 -0
  78. package/dist/cli/commands/functions/deploy.d.ts +0 -0
  79. package/dist/cli/commands/functions/deploy.js +15 -15
  80. package/dist/cli/commands/functions/index.d.ts +0 -0
  81. package/dist/cli/commands/functions/index.js +16 -17
  82. package/dist/cli/commands/functions/ls.d.ts +0 -0
  83. package/dist/cli/commands/functions/ls.js +17 -10
  84. package/dist/cli/commands/functions/rm.d.ts +0 -0
  85. package/dist/cli/commands/functions/rm.js +20 -7
  86. package/dist/cli/commands/functions/rmall.d.ts +0 -0
  87. package/dist/cli/commands/functions/rmall.js +20 -8
  88. package/dist/cli/commands/policies/policies.d.ts +0 -0
  89. package/dist/cli/commands/policies/policies.js +0 -0
  90. package/dist/cli/commands/policies/role.d.ts +0 -0
  91. package/dist/cli/commands/policies/role.js +0 -0
  92. package/dist/cli/commands/policies/user.d.ts +0 -0
  93. package/dist/cli/commands/policies/user.js +0 -0
  94. package/dist/cli/commands/policies/validate.d.ts +0 -0
  95. package/dist/cli/commands/policies/validate.js +0 -0
  96. package/dist/cli/commands/quotas/increase.d.ts +0 -0
  97. package/dist/cli/commands/quotas/increase.js +30 -10
  98. package/dist/cli/commands/quotas/index.d.ts +0 -0
  99. package/dist/cli/commands/quotas/index.js +8 -9
  100. package/dist/cli/commands/quotas/list.d.ts +0 -0
  101. package/dist/cli/commands/quotas/list.js +0 -0
  102. package/dist/cli/commands/regions.d.ts +0 -0
  103. package/dist/cli/commands/regions.js +6 -2
  104. package/dist/cli/commands/render/progress.d.ts +11 -7
  105. package/dist/cli/commands/render/progress.js +55 -45
  106. package/dist/cli/commands/render/render.d.ts +1 -1
  107. package/dist/cli/commands/render/render.js +99 -27
  108. package/dist/cli/commands/sites/create.d.ts +1 -1
  109. package/dist/cli/commands/sites/create.js +36 -33
  110. package/dist/cli/commands/sites/index.d.ts +1 -1
  111. package/dist/cli/commands/sites/index.js +18 -16
  112. package/dist/cli/commands/sites/ls.d.ts +0 -0
  113. package/dist/cli/commands/sites/ls.js +9 -10
  114. package/dist/cli/commands/sites/rm.d.ts +0 -0
  115. package/dist/cli/commands/sites/rm.js +6 -16
  116. package/dist/cli/commands/sites/rmall.d.ts +0 -0
  117. package/dist/cli/commands/sites/rmall.js +5 -16
  118. package/dist/cli/commands/still.d.ts +1 -1
  119. package/dist/cli/commands/still.js +49 -20
  120. package/dist/cli/get-aws-region.d.ts +0 -0
  121. package/dist/cli/get-aws-region.js +0 -0
  122. package/dist/cli/help.d.ts +0 -0
  123. package/dist/cli/help.js +4 -0
  124. package/dist/cli/helpers/confirm.d.ts +0 -0
  125. package/dist/cli/helpers/confirm.js +0 -0
  126. package/dist/cli/helpers/date-string.d.ts +0 -0
  127. package/dist/cli/helpers/date-string.js +0 -0
  128. package/dist/cli/helpers/find-function-name.d.ts +0 -0
  129. package/dist/cli/helpers/find-function-name.js +35 -6
  130. package/dist/cli/helpers/progress-bar.d.ts +12 -7
  131. package/dist/cli/helpers/progress-bar.js +20 -11
  132. package/dist/cli/helpers/quit.d.ts +0 -0
  133. package/dist/cli/helpers/quit.js +0 -0
  134. package/dist/cli/helpers/yes-or-no.d.ts +0 -0
  135. package/dist/cli/helpers/yes-or-no.js +0 -0
  136. package/dist/cli/index.d.ts +1 -1
  137. package/dist/cli/index.js +23 -12
  138. package/dist/cli/is-cli.d.ts +0 -0
  139. package/dist/cli/is-cli.js +0 -0
  140. package/dist/cli/log.d.ts +15 -0
  141. package/dist/cli/log.js +0 -0
  142. package/dist/client.d.ts +8 -2
  143. package/dist/client.js +9 -1
  144. package/dist/defaults.d.ts +0 -0
  145. package/dist/defaults.js +0 -0
  146. package/dist/functions/chunk-optimization/plan-frame-ranges.d.ts +1 -5
  147. package/dist/functions/chunk-optimization/plan-frame-ranges.js +2 -15
  148. package/dist/functions/chunk-optimization/types.d.ts +2 -13
  149. package/dist/functions/chunk-optimization/types.js +0 -0
  150. package/dist/functions/compositions.d.ts +8 -0
  151. package/dist/functions/compositions.js +60 -0
  152. package/dist/functions/helpers/best-frames-per-lambda-param.d.ts +0 -0
  153. package/dist/functions/helpers/best-frames-per-lambda-param.js +0 -0
  154. package/dist/functions/helpers/calculate-chunk-times.d.ts +0 -0
  155. package/dist/functions/helpers/calculate-chunk-times.js +0 -0
  156. package/dist/functions/helpers/calculate-price-from-bucket.d.ts +1 -3
  157. package/dist/functions/helpers/calculate-price-from-bucket.js +1 -2
  158. package/dist/functions/helpers/check-if-render-exists.d.ts +0 -0
  159. package/dist/functions/helpers/check-if-render-exists.js +0 -0
  160. package/dist/functions/helpers/clean-tmpdir.d.ts +0 -0
  161. package/dist/functions/helpers/clean-tmpdir.js +8 -8
  162. package/dist/functions/helpers/concat-videos.d.ts +13 -5
  163. package/dist/functions/helpers/concat-videos.js +38 -39
  164. package/dist/functions/helpers/create-post-render-data.d.ts +0 -0
  165. package/dist/functions/helpers/create-post-render-data.js +1 -15
  166. package/dist/functions/helpers/delete-chunks.d.ts +0 -0
  167. package/dist/functions/helpers/delete-chunks.js +0 -0
  168. package/dist/functions/helpers/expected-out-name.d.ts +0 -0
  169. package/dist/functions/helpers/expected-out-name.js +2 -2
  170. package/dist/functions/helpers/find-output-file-in-bucket.d.ts +1 -1
  171. package/dist/functions/helpers/find-output-file-in-bucket.js +0 -0
  172. package/dist/functions/helpers/format-costs-info.d.ts +0 -0
  173. package/dist/functions/helpers/format-costs-info.js +0 -0
  174. package/dist/functions/helpers/get-browser-instance.d.ts +1 -2
  175. package/dist/functions/helpers/get-browser-instance.js +7 -3
  176. package/dist/functions/helpers/get-chromium-executable-path.d.ts +1 -1
  177. package/dist/functions/helpers/get-chromium-executable-path.js +8 -6
  178. package/dist/functions/helpers/get-cleanup-progress.d.ts +0 -0
  179. package/dist/functions/helpers/get-cleanup-progress.js +0 -0
  180. package/dist/functions/helpers/get-current-region.d.ts +1 -1
  181. package/dist/functions/helpers/get-current-region.js +0 -0
  182. package/dist/functions/helpers/get-custom-out-name.d.ts +0 -0
  183. package/dist/functions/helpers/get-custom-out-name.js +1 -1
  184. package/dist/functions/helpers/get-encoding-metadata.d.ts +5 -8
  185. package/dist/functions/helpers/get-encoding-metadata.js +7 -17
  186. package/dist/functions/helpers/get-files-in-folder.d.ts +1 -1
  187. package/dist/functions/helpers/get-files-in-folder.js +5 -5
  188. package/dist/functions/helpers/get-files-to-delete.d.ts +1 -1
  189. package/dist/functions/helpers/get-files-to-delete.js +0 -0
  190. package/dist/functions/helpers/get-final-encoding-status.d.ts +2 -4
  191. package/dist/functions/helpers/get-final-encoding-status.js +1 -4
  192. package/dist/functions/helpers/get-folder-size.d.ts +0 -0
  193. package/dist/functions/helpers/get-folder-size.js +0 -0
  194. package/dist/functions/helpers/get-lambdas-invoked-stats.d.ts +2 -6
  195. package/dist/functions/helpers/get-lambdas-invoked-stats.js +1 -9
  196. package/dist/functions/helpers/get-output-url-from-metadata.d.ts +0 -0
  197. package/dist/functions/helpers/get-output-url-from-metadata.js +0 -0
  198. package/dist/functions/helpers/get-overall-progress.d.ts +2 -1
  199. package/dist/functions/helpers/get-overall-progress.js +7 -5
  200. package/dist/functions/helpers/get-post-render-data.d.ts +0 -0
  201. package/dist/functions/helpers/get-post-render-data.js +0 -0
  202. package/dist/functions/helpers/get-progress.d.ts +0 -0
  203. package/dist/functions/helpers/get-progress.js +43 -42
  204. package/dist/functions/helpers/get-render-metadata.d.ts +0 -0
  205. package/dist/functions/helpers/get-render-metadata.js +0 -0
  206. package/dist/functions/helpers/get-rendered-frames-progress.d.ts +8 -0
  207. package/dist/functions/helpers/get-rendered-frames-progress.js +37 -0
  208. package/dist/functions/helpers/get-retry-stats.d.ts +1 -1
  209. package/dist/functions/helpers/get-retry-stats.js +0 -0
  210. package/dist/functions/helpers/get-time-to-finish.d.ts +0 -0
  211. package/dist/functions/helpers/get-time-to-finish.js +0 -0
  212. package/dist/functions/helpers/inspect-errors.d.ts +0 -0
  213. package/dist/functions/helpers/inspect-errors.js +0 -0
  214. package/dist/functions/helpers/io.d.ts +10 -4
  215. package/dist/functions/helpers/io.js +25 -3
  216. package/dist/functions/helpers/is-enosp-err.d.ts +0 -0
  217. package/dist/functions/helpers/is-enosp-err.js +1 -1
  218. package/dist/functions/helpers/is-warm.d.ts +0 -0
  219. package/dist/functions/helpers/is-warm.js +0 -0
  220. package/dist/functions/helpers/make-timeout-error.d.ts +8 -0
  221. package/dist/functions/helpers/make-timeout-error.js +35 -0
  222. package/dist/functions/helpers/make-timeout-message.d.ts +6 -0
  223. package/dist/functions/helpers/make-timeout-message.js +31 -0
  224. package/dist/functions/helpers/min-max.d.ts +0 -0
  225. package/dist/functions/helpers/min-max.js +0 -0
  226. package/dist/functions/helpers/print-cloudwatch-helper.d.ts +0 -0
  227. package/dist/functions/helpers/print-cloudwatch-helper.js +0 -0
  228. package/dist/functions/helpers/print-concurrency-curve.d.ts +0 -0
  229. package/dist/functions/helpers/print-concurrency-curve.js +0 -0
  230. package/dist/functions/helpers/read-with-progress.d.ts +1 -1
  231. package/dist/functions/helpers/read-with-progress.js +1 -1
  232. package/dist/functions/helpers/streamify-response.d.ts +16 -0
  233. package/dist/functions/helpers/streamify-response.js +67 -0
  234. package/dist/functions/helpers/timer.d.ts +0 -0
  235. package/dist/functions/helpers/timer.js +0 -0
  236. package/dist/functions/helpers/validate-composition.d.ts +10 -9
  237. package/dist/functions/helpers/validate-composition.js +16 -13
  238. package/dist/functions/helpers/write-lambda-error.d.ts +2 -2
  239. package/dist/functions/helpers/write-lambda-error.js +0 -0
  240. package/dist/functions/helpers/write-post-render-data.d.ts +0 -0
  241. package/dist/functions/helpers/write-post-render-data.js +0 -0
  242. package/dist/functions/index.d.ts +1 -7
  243. package/dist/functions/index.js +43 -10
  244. package/dist/functions/info.d.ts +0 -0
  245. package/dist/functions/info.js +0 -0
  246. package/dist/functions/launch.d.ts +2 -1
  247. package/dist/functions/launch.js +152 -134
  248. package/dist/functions/progress.d.ts +1 -1
  249. package/dist/functions/progress.js +2 -2
  250. package/dist/functions/renderer.d.ts +1 -1
  251. package/dist/functions/renderer.js +73 -42
  252. package/dist/functions/start.d.ts +1 -1
  253. package/dist/functions/start.js +22 -8
  254. package/dist/functions/still.d.ts +1 -1
  255. package/dist/functions/still.js +80 -37
  256. package/dist/index.d.ts +24 -8
  257. package/dist/index.js +23 -6
  258. package/dist/internals.d.ts +3 -1
  259. package/dist/internals.js +3 -0
  260. package/dist/pricing/aws-regions.d.ts +3 -2
  261. package/dist/pricing/aws-regions.js +31 -1
  262. package/dist/pricing/price-per-1-s.d.ts +0 -0
  263. package/dist/pricing/price-per-1-s.js +413 -39
  264. package/dist/regions.d.ts +0 -0
  265. package/dist/regions.js +0 -0
  266. package/dist/shared/await.d.ts +1 -1
  267. package/dist/shared/await.js +0 -0
  268. package/dist/shared/aws-clients.d.ts +6 -3
  269. package/dist/shared/aws-clients.js +75 -13
  270. package/dist/shared/bundle-site.d.ts +0 -0
  271. package/dist/shared/bundle-site.js +0 -0
  272. package/dist/shared/call-lambda.d.ts +0 -0
  273. package/dist/shared/call-lambda.js +27 -2
  274. package/dist/shared/check-credentials.d.ts +0 -0
  275. package/dist/shared/check-credentials.js +3 -0
  276. package/dist/shared/chunk-progress.d.ts +9 -0
  277. package/dist/shared/chunk-progress.js +2034 -0
  278. package/dist/shared/cleanup-serialized-input-props.d.ts +7 -0
  279. package/dist/shared/cleanup-serialized-input-props.js +19 -0
  280. package/dist/shared/constants.d.ts +140 -89
  281. package/dist/shared/constants.js +7 -4
  282. package/dist/shared/content-disposition-header.d.ts +1 -1
  283. package/dist/shared/content-disposition-header.js +0 -0
  284. package/dist/shared/convert-to-serve-url.d.ts +5 -1
  285. package/dist/shared/convert-to-serve-url.js +1 -5
  286. package/dist/shared/deserialize-input-props.d.ts +8 -0
  287. package/dist/shared/deserialize-input-props.js +26 -0
  288. package/dist/shared/docs-url.d.ts +0 -0
  289. package/dist/shared/docs-url.js +0 -0
  290. package/dist/shared/function-zip-path.d.ts +1 -1
  291. package/dist/shared/function-zip-path.js +3 -3
  292. package/dist/shared/get-account-id.d.ts +0 -0
  293. package/dist/shared/get-account-id.js +4 -6
  294. package/dist/shared/{get-cloudwatch-stream-url.d.ts → get-aws-urls.d.ts} +7 -1
  295. package/dist/shared/get-aws-urls.js +12 -0
  296. package/dist/shared/get-etag.d.ts +1 -0
  297. package/dist/shared/get-etag.js +24 -0
  298. package/dist/shared/get-function-version.d.ts +0 -0
  299. package/dist/shared/get-function-version.js +0 -0
  300. package/dist/shared/get-most-expensive-chunks.d.ts +2 -2
  301. package/dist/shared/get-most-expensive-chunks.js +3 -2
  302. package/dist/shared/get-s3-operations.d.ts +10 -0
  303. package/dist/shared/get-s3-operations.js +36 -0
  304. package/dist/shared/hosted-layers.d.ts +5 -8
  305. package/dist/shared/hosted-layers.js +210 -284
  306. package/dist/shared/invoke-webhook.d.ts +5 -18
  307. package/dist/shared/invoke-webhook.js +5 -19
  308. package/dist/shared/is-in-lambda.d.ts +0 -0
  309. package/dist/shared/is-in-lambda.js +0 -0
  310. package/dist/shared/lambda-version-string.d.ts +0 -0
  311. package/dist/shared/lambda-version-string.js +0 -0
  312. package/dist/shared/make-s3-key.d.ts +0 -0
  313. package/dist/shared/make-s3-key.js +2 -2
  314. package/dist/shared/make-s3-url.d.ts +0 -0
  315. package/dist/shared/make-s3-url.js +2 -2
  316. package/dist/shared/p-limit.d.ts +0 -0
  317. package/dist/shared/p-limit.js +0 -0
  318. package/dist/shared/parse-chunk-key.d.ts +4 -0
  319. package/dist/shared/parse-chunk-key.js +14 -0
  320. package/dist/shared/parse-lambda-initialized-key.d.ts +0 -0
  321. package/dist/shared/parse-lambda-initialized-key.js +0 -0
  322. package/dist/shared/parse-lambda-timings-key.d.ts +1 -1
  323. package/dist/shared/parse-lambda-timings-key.js +0 -0
  324. package/dist/shared/random-hash.d.ts +0 -0
  325. package/dist/shared/random-hash.js +0 -0
  326. package/dist/shared/read-dir.d.ts +9 -0
  327. package/dist/shared/read-dir.js +57 -0
  328. package/dist/shared/return-values.d.ts +7 -0
  329. package/dist/shared/return-values.js +0 -0
  330. package/dist/shared/serialize-input-props.d.ts +8 -0
  331. package/dist/shared/serialize-input-props.js +42 -0
  332. package/dist/shared/sleep.d.ts +0 -0
  333. package/dist/shared/sleep.js +0 -0
  334. package/dist/shared/stream-to-string.d.ts +0 -0
  335. package/dist/shared/stream-to-string.js +0 -0
  336. package/dist/shared/truthy.d.ts +1 -1
  337. package/dist/shared/truthy.js +0 -0
  338. package/dist/shared/validate-aws-region.d.ts +0 -0
  339. package/dist/shared/validate-aws-region.js +0 -0
  340. package/dist/shared/validate-bucketname.d.ts +5 -0
  341. package/dist/shared/validate-bucketname.js +19 -1
  342. package/dist/shared/validate-custom-role-arn.d.ts +0 -0
  343. package/dist/shared/validate-custom-role-arn.js +0 -0
  344. package/dist/shared/validate-disk-size-in-mb.d.ts +0 -0
  345. package/dist/shared/validate-disk-size-in-mb.js +0 -0
  346. package/dist/shared/validate-download-behavior.d.ts +0 -0
  347. package/dist/shared/validate-download-behavior.js +0 -0
  348. package/dist/shared/validate-frames-per-lambda.d.ts +0 -0
  349. package/dist/shared/validate-frames-per-lambda.js +0 -0
  350. package/dist/shared/validate-lambda-codec.d.ts +2 -2
  351. package/dist/shared/validate-lambda-codec.js +1 -1
  352. package/dist/shared/validate-memory-size.d.ts +0 -0
  353. package/dist/shared/validate-memory-size.js +0 -0
  354. package/dist/shared/validate-outname.d.ts +2 -2
  355. package/dist/shared/validate-outname.js +16 -10
  356. package/dist/shared/validate-presign-expiration.d.ts +0 -0
  357. package/dist/shared/validate-presign-expiration.js +0 -0
  358. package/dist/shared/validate-privacy.d.ts +1 -1
  359. package/dist/shared/validate-privacy.js +5 -2
  360. package/dist/shared/validate-retention-period.d.ts +0 -0
  361. package/dist/shared/validate-retention-period.js +0 -0
  362. package/dist/shared/validate-retries.d.ts +0 -0
  363. package/dist/shared/validate-retries.js +0 -0
  364. package/dist/shared/validate-serveurl.d.ts +0 -0
  365. package/dist/shared/validate-serveurl.js +0 -0
  366. package/dist/shared/validate-site-name.d.ts +0 -0
  367. package/dist/shared/validate-site-name.js +0 -0
  368. package/dist/shared/validate-timeout.d.ts +0 -0
  369. package/dist/shared/validate-timeout.js +0 -0
  370. package/package.json +89 -65
  371. package/remotionlambda-arm64.zip +0 -0
  372. package/.prettierrc.js +0 -14
  373. package/client.d.ts +0 -1
  374. package/client.js +0 -1
  375. package/dist/api/enable-s3-website.d.ts +0 -5
  376. package/dist/api/enable-s3-website.js +0 -16
  377. package/dist/cli/helpers/determine-image-format.d.ts +0 -10
  378. package/dist/cli/helpers/determine-image-format.js +0 -47
  379. package/dist/cli/helpers/get-cloudwatch-stream-url.d.ts +0 -8
  380. package/dist/cli/helpers/get-cloudwatch-stream-url.js +0 -7
  381. package/dist/cli/helpers/webhook-types.d.ts +0 -6
  382. package/dist/cli/helpers/webhook-types.js +0 -2
  383. package/dist/functions/chunk-optimization/can-use-optimization.d.ts +0 -6
  384. package/dist/functions/chunk-optimization/can-use-optimization.js +0 -23
  385. package/dist/functions/chunk-optimization/collect-data.d.ts +0 -9
  386. package/dist/functions/chunk-optimization/collect-data.js +0 -27
  387. package/dist/functions/chunk-optimization/get-frame-ranges-from-profile.d.ts +0 -3
  388. package/dist/functions/chunk-optimization/get-frame-ranges-from-profile.js +0 -11
  389. package/dist/functions/chunk-optimization/get-profile-duration.d.ts +0 -3
  390. package/dist/functions/chunk-optimization/get-profile-duration.js +0 -18
  391. package/dist/functions/chunk-optimization/is-valid-profile.d.ts +0 -2
  392. package/dist/functions/chunk-optimization/is-valid-profile.js +0 -12
  393. package/dist/functions/chunk-optimization/optimize-invocation-order.d.ts +0 -2
  394. package/dist/functions/chunk-optimization/optimize-invocation-order.js +0 -19
  395. package/dist/functions/chunk-optimization/optimize-profile.d.ts +0 -9
  396. package/dist/functions/chunk-optimization/optimize-profile.js +0 -74
  397. package/dist/functions/chunk-optimization/s3-optimization-file.d.ts +0 -17
  398. package/dist/functions/chunk-optimization/s3-optimization-file.js +0 -47
  399. package/dist/functions/chunk-optimization/simulate-frame-ranges.d.ts +0 -7
  400. package/dist/functions/chunk-optimization/simulate-frame-ranges.js +0 -47
  401. package/dist/functions/chunk-optimization/sort-by-duration.d.ts +0 -2
  402. package/dist/functions/chunk-optimization/sort-by-duration.js +0 -25
  403. package/dist/functions/helpers/get-current-architecture.d.ts +0 -2
  404. package/dist/functions/helpers/get-current-architecture.js +0 -11
  405. package/dist/shared/get-cloudwatch-stream-url.js +0 -7
  406. package/dist/shared/validate-architecture.d.ts +0 -4
  407. package/dist/shared/validate-architecture.js +0 -14
  408. package/remotionlambda.zip +0 -0
  409. package/tsconfig.json +0 -16
package/LICENSE.md CHANGED
@@ -1,34 +1,34 @@
1
1
  # Remotion License
2
2
 
3
- Depending on the type of your legal entity, you are granted permission to use Remotion for your project. Individuals and small companies are allowed to use Remotion create videos for free (even commercial), while a company license is required for for-profit organisations of a certain size. This two-tier system was designed to ensure funding for this project while still allowing the source code to be available and the program to be free for most. Read below for the exact terms of use.
3
+ Depending on the type of your legal entity, you are granted permission to use Remotion for your project. Individuals and small companies are allowed to use Remotion to create videos for free (even commercial), while a company license is required for for-profit organizations of a certain size. This two-tier system was designed to ensure funding for this project while still allowing the source code to be available and the program to be free for most. Read below for the exact terms of use.
4
4
 
5
5
  - [Free license](#free-license)
6
6
  - [Company license](#company-license)
7
7
 
8
8
  ## Free license
9
9
 
10
- Copyright © 2022 [Jonny Burger](https://jonny.io)
10
+ Copyright © 2023 [Remotion](https://www.remotion.dev/)
11
11
 
12
12
  ### Eligibility
13
13
 
14
14
  You are eligible to use Remotion for free if you are:
15
15
 
16
16
  - an individual
17
- - a for-profit organisation with up to 3 employees
18
- - a non-profit or not-for-profit organisation
17
+ - a for-profit organization with up to 3 employees
18
+ - a non-profit or not-for-profit organization
19
19
  - evaluating whether Remotion is a good fit, and are not yet using it in a commercial way
20
20
 
21
21
  ### Allowed use cases
22
22
 
23
- Permission is hereby granted, free of charge, to any person eligible for the "Free license", to use the software non-commercially or commercially for the purpose of creating videos and images and to modify and the software to their own liking, for the purpose of fulfilling their custom use case or to contribute bug fixes or improvements back to Remotion.
23
+ Permission is hereby granted, free of charge, to any person eligible for the "Free license", to use the software non-commercially or commercially for the purpose of creating videos and images and to modify the software to their own liking, for the purpose of fulfilling their custom use case or to contribute bug fixes or improvements back to Remotion.
24
24
 
25
25
  ### Disallowed use cases
26
26
 
27
- It is not allowed to copy or modify Remotion code for the purpose of selling, renting, licensing, relicensing, sublicensing your own derivate of Remotion.
27
+ It is not allowed to copy or modify Remotion code for the purpose of selling, renting, licensing, relicensing, or sublicensing your own derivate of Remotion.
28
28
 
29
29
  ### Warranty notice
30
30
 
31
- The software is provided "as is", without warranty of any kind, express or implied, including but not limited to the warranties of merchantability, fitness for a particular purpose and noninfringement. In no event shall the author or copyright holders be liable for any claim, damages or other liability, whether in an action of contract, tort or otherwise, arising from, out of or in connection with the software or the use or other dealings in the software.
31
+ The software is provided "as is", without warranty of any kind, express or implied, including but not limited to the warranties of merchantability, fitness for a particular purpose, and non-infringement. In no event shall the author or copyright holders be liable for any claim, damages or other liability, whether in an action of contract, tort or otherwise, arising from, out of or in connection with the software or the use or other dealings in the software.
32
32
 
33
33
  ### Support
34
34
 
@@ -36,6 +36,6 @@ Support is provided on a best-we-can-do basis via GitHub Issues and Discord.
36
36
 
37
37
  ## Company license
38
38
 
39
- You are required to obtain a company license to use Remotion if you are not within the group of entities eligible for a free license. This license will enable you to use Remotion for the allowed use cases specified in the free license, and give you access to prioritized support.
39
+ You are required to obtain a company license to use Remotion if you are not within the group of entities eligible for a free license. This license will enable you to use Remotion for the allowed use cases specified in the free license, and give you access to prioritized support (read the [Support Policy](/docs/support)).
40
40
 
41
41
  Visit [companies.remotion.dev](https://companies.remotion.dev) for pricing and to buy a license.
File without changes
@@ -4,35 +4,46 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
4
4
  };
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
6
  const bundler_1 = require("@remotion/bundler");
7
- const fs_1 = __importDefault(require("fs"));
8
- const path_1 = __importDefault(require("path"));
7
+ const compositor_linux_arm64_gnu_1 = require("@remotion/compositor-linux-arm64-gnu");
8
+ const node_fs_1 = __importDefault(require("node:fs"));
9
+ const node_path_1 = __importDefault(require("node:path"));
9
10
  const quit_1 = require("../cli/helpers/quit");
10
11
  const function_zip_path_1 = require("../shared/function-zip-path");
11
12
  const zl = require("zip-lib");
12
13
  const bundleLambda = async () => {
13
- var _a;
14
- const outdir = path_1.default.join(__dirname, '..', `build-render`);
15
- fs_1.default.mkdirSync(outdir, {
14
+ const outdir = node_path_1.default.join(__dirname, '..', `build-render`);
15
+ node_fs_1.default.mkdirSync(outdir, {
16
16
  recursive: true,
17
17
  });
18
- const outfile = path_1.default.join(outdir, 'index.js');
19
- ((_a = fs_1.default.rmSync) !== null && _a !== void 0 ? _a : fs_1.default.rmdirSync)(outdir, { recursive: true });
20
- fs_1.default.mkdirSync(outdir, { recursive: true });
21
- const template = require.resolve(path_1.default.join(__dirname, '..', 'functions', 'index'));
18
+ const outfile = node_path_1.default.join(outdir, 'index.js');
19
+ node_fs_1.default.rmSync(outdir, { recursive: true });
20
+ node_fs_1.default.mkdirSync(outdir, { recursive: true });
21
+ const template = require.resolve(node_path_1.default.join(__dirname, '..', 'functions', 'index'));
22
22
  await bundler_1.BundlerInternals.esbuild.build({
23
23
  platform: 'node',
24
- target: 'node14',
24
+ target: 'node16',
25
25
  bundle: true,
26
26
  outfile,
27
27
  entryPoints: [template],
28
28
  treeShaking: true,
29
+ external: [
30
+ './compositor',
31
+ './compositor.exe',
32
+ './ffmpeg/remotion/bin/ffprobe',
33
+ './ffmpeg/remotion/bin/ffprobe.exe',
34
+ './ffmpeg/remotion/bin/ffmpeg',
35
+ './ffmpeg/remotion/bin/ffmpeg.exe',
36
+ ],
29
37
  });
30
- await zl.archiveFolder(outdir, function_zip_path_1.FUNCTION_ZIP);
31
- fs_1.default.unlinkSync(outfile);
38
+ const compositorFile = `${outdir}/compositor`;
39
+ node_fs_1.default.copyFileSync(compositor_linux_arm64_gnu_1.binaryPath, compositorFile);
40
+ node_fs_1.default.cpSync(compositor_linux_arm64_gnu_1.ffmpegCwd, `${outdir}/ffmpeg`, { recursive: true });
41
+ await zl.archiveFolder(outdir, function_zip_path_1.FUNCTION_ZIP_ARM64);
42
+ node_fs_1.default.rmSync(outdir, { recursive: true });
32
43
  };
33
44
  bundleLambda()
34
45
  .then(() => {
35
- console.log('Lambda bundled');
46
+ console.log('Bundled Lambda');
36
47
  })
37
48
  .catch((err) => {
38
49
  console.log(err);
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,14 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ const node_crypto_1 = __importDefault(require("node:crypto"));
7
+ const node_fs_1 = require("node:fs");
8
+ const md5 = (data) => node_crypto_1.default.createHash('md5').update(data).digest('hex');
9
+ const chunks = [];
10
+ for (let i = 0; i < 2000; i++) {
11
+ const etag = `"${md5(String(i))}"`;
12
+ chunks.push(etag);
13
+ }
14
+ (0, node_fs_1.writeFileSync)('etags.json', JSON.stringify(chunks));
File without changes
@@ -6,76 +6,70 @@ const version_1 = require("remotion/version");
6
6
  const get_regions_1 = require("../api/get-regions");
7
7
  const quit_1 = require("../cli/helpers/quit");
8
8
  const aws_clients_1 = require("../shared/aws-clients");
9
- const runtimes = ['nodejs14.x'];
10
- const archictures = ['arm64', 'x86_64'];
9
+ const runtimes = ['nodejs18.x'];
11
10
  const layerInfo = {
12
- arm64: {
13
- 'ap-northeast-1': [],
14
- 'ap-south-1': [],
15
- 'ap-southeast-1': [],
16
- 'ap-southeast-2': [],
17
- 'eu-central-1': [],
18
- 'eu-west-1': [],
19
- 'eu-west-2': [],
20
- 'us-east-1': [],
21
- 'us-east-2': [],
22
- 'us-west-2': [],
23
- },
24
- x86_64: {
25
- 'ap-northeast-1': [],
26
- 'ap-south-1': [],
27
- 'ap-southeast-1': [],
28
- 'ap-southeast-2': [],
29
- 'eu-central-1': [],
30
- 'eu-west-1': [],
31
- 'eu-west-2': [],
32
- 'us-east-1': [],
33
- 'us-east-2': [],
34
- 'us-west-2': [],
35
- },
11
+ 'ap-northeast-1': [],
12
+ 'ap-south-1': [],
13
+ 'ap-southeast-1': [],
14
+ 'ap-southeast-2': [],
15
+ 'eu-central-1': [],
16
+ 'eu-west-1': [],
17
+ 'eu-west-2': [],
18
+ 'us-east-1': [],
19
+ 'us-east-2': [],
20
+ 'us-west-2': [],
21
+ 'af-south-1': [],
22
+ 'ap-east-1': [],
23
+ 'ap-northeast-2': [],
24
+ 'ap-northeast-3': [],
25
+ 'ca-central-1': [],
26
+ 'eu-north-1': [],
27
+ 'eu-south-1': [],
28
+ 'eu-west-3': [],
29
+ 'me-south-1': [],
30
+ 'sa-east-1': [],
31
+ 'us-west-1': [],
36
32
  };
37
33
  const makeLayerPublic = async () => {
38
34
  const layers = ['fonts', 'ffmpeg', 'chromium'];
39
- for (const architecture of archictures) {
40
- for (const region of (0, get_regions_1.getRegions)()) {
41
- for (const layer of layers) {
42
- const layerName = `remotion-binaries-${layer}-${architecture}`;
43
- const { Version, LayerArn } = await (0, aws_clients_1.getLambdaClient)(region).send(new client_lambda_1.PublishLayerVersionCommand({
44
- Content: {
45
- S3Bucket: 'remotionlambda-binaries-' + region,
46
- S3Key: `remotion-layer-${layer}-v8-${architecture}.zip`,
47
- },
48
- LayerName: layerName,
49
- LicenseInfo: layer === 'chromium'
50
- ? 'Chromium 104, compiled from source. Read Chromium License: https://chromium.googlesource.com/chromium/src/+/refs/heads/main/LICENSE'
51
- : layer === 'ffmpeg'
52
- ? 'Compiled from FFMPEG source. Read FFMPEG license: https://ffmpeg.org/legal.html'
53
- : 'Contains Noto Sans font. Read Noto Sans License: https://fonts.google.com/noto/specimen/Noto+Sans/about',
54
- CompatibleRuntimes: runtimes,
55
- Description: version_1.VERSION,
56
- }));
57
- await (0, aws_clients_1.getLambdaClient)(region).send(new client_lambda_1.AddLayerVersionPermissionCommand({
58
- Action: aws_policies_1.lambda.GetLayerVersion,
59
- LayerName: layerName,
60
- Principal: '*',
61
- VersionNumber: Version,
62
- StatementId: 'public-layer',
63
- }));
64
- if (!layerInfo[architecture][region]) {
65
- layerInfo[architecture][region] = [];
66
- }
67
- if (!LayerArn) {
68
- throw new Error('layerArn is null');
69
- }
70
- if (!Version) {
71
- throw new Error('Version is null');
72
- }
73
- layerInfo[architecture][region].push({
74
- layerArn: LayerArn,
75
- version: Version,
76
- });
77
- console.log({ LayerArn, Version });
35
+ for (const region of (0, get_regions_1.getRegions)()) {
36
+ for (const layer of layers) {
37
+ const layerName = `remotion-binaries-${layer}-arm64`;
38
+ const { Version, LayerArn } = await (0, aws_clients_1.getLambdaClient)(region).send(new client_lambda_1.PublishLayerVersionCommand({
39
+ Content: {
40
+ S3Bucket: 'remotionlambda-binaries-' + region,
41
+ S3Key: `remotion-layer-${layer}-v10-arm64.zip`,
42
+ },
43
+ LayerName: layerName,
44
+ LicenseInfo: layer === 'chromium'
45
+ ? 'Chromium 114, compiled from source. Read Chromium License: https://chromium.googlesource.com/chromium/src/+/refs/heads/main/LICENSE'
46
+ : layer === 'ffmpeg'
47
+ ? 'FFmpeg 6.0, compiled from source. Read FFMPEG license: https://ffmpeg.org/legal.html'
48
+ : 'Contains Noto Sans font. Read Noto Sans License: https://fonts.google.com/noto/specimen/Noto+Sans/about',
49
+ CompatibleRuntimes: runtimes,
50
+ Description: version_1.VERSION,
51
+ }));
52
+ await (0, aws_clients_1.getLambdaClient)(region).send(new client_lambda_1.AddLayerVersionPermissionCommand({
53
+ Action: aws_policies_1.lambda.GetLayerVersion,
54
+ LayerName: layerName,
55
+ Principal: '*',
56
+ VersionNumber: Version,
57
+ StatementId: 'public-layer',
58
+ }));
59
+ if (!layerInfo[region]) {
60
+ layerInfo[region] = [];
78
61
  }
62
+ if (!LayerArn) {
63
+ throw new Error('layerArn is null');
64
+ }
65
+ if (!Version) {
66
+ throw new Error('Version is null');
67
+ }
68
+ layerInfo[region].push({
69
+ layerArn: LayerArn,
70
+ version: Version,
71
+ });
72
+ console.log({ LayerArn, Version });
79
73
  }
80
74
  }
81
75
  };
File without changes
File without changes
File without changes
@@ -5,7 +5,7 @@ const client_s3_1 = require("@aws-sdk/client-s3");
5
5
  const aws_clients_1 = require("../shared/aws-clients");
6
6
  const p_limit_1 = require("../shared/p-limit");
7
7
  const limit = (0, p_limit_1.pLimit)(10);
8
- const cleanItems = async ({ bucket, onAfterItemDeleted, onBeforeItemDeleted, region, list, }) => {
8
+ const cleanItems = ({ bucket, onAfterItemDeleted, onBeforeItemDeleted, region, list, }) => {
9
9
  return Promise.all(list.map((object) => limit(async () => {
10
10
  onBeforeItemDeleted({
11
11
  bucketName: bucket,
File without changes
@@ -6,7 +6,40 @@ const aws_clients_1 = require("../shared/aws-clients");
6
6
  const createBucket = async ({ region, bucketName, }) => {
7
7
  await (0, aws_clients_1.getS3Client)(region, null).send(new client_s3_1.CreateBucketCommand({
8
8
  Bucket: bucketName,
9
- ACL: 'public-read',
10
9
  }));
10
+ try {
11
+ await (0, aws_clients_1.getS3Client)(region, null).send(new client_s3_1.DeleteBucketOwnershipControlsCommand({
12
+ Bucket: bucketName,
13
+ }));
14
+ }
15
+ catch (err) {
16
+ if (err.message.includes('Access Denied')) {
17
+ throw new Error('Since April 2023, more AWS permissions are required to create an S3 bucket. You need to update your user policy to continue. See https://remotion.dev/docs/lambda/s3-public-access for instructions on how to resolve this issue.');
18
+ }
19
+ throw err;
20
+ }
21
+ try {
22
+ await (0, aws_clients_1.getS3Client)(region, null).send(new client_s3_1.DeletePublicAccessBlockCommand({
23
+ Bucket: bucketName,
24
+ }));
25
+ }
26
+ catch (err) {
27
+ if (err.message.includes('Access Denied')) {
28
+ throw new Error('PARTIAL SUCCESS: The s3:PutBucketOwnershipControls was found, but the s3:PutBucketPublicAccessBlock permission is not given. Since April 2023, more AWS permissions are required to create an S3 bucket. You need to update your user policy to continue. You need to update your user policy to continue. See https://remotion.dev/docs/lambda/s3-public-access for instructions on how to resolve this issue.');
29
+ }
30
+ throw err;
31
+ }
32
+ try {
33
+ await (0, aws_clients_1.getS3Client)(region, null).send(new client_s3_1.PutBucketAclCommand({
34
+ Bucket: bucketName,
35
+ ACL: 'public-read',
36
+ }));
37
+ }
38
+ catch (err) {
39
+ if (err.message.includes('The bucket does not allow ACLs')) {
40
+ throw new Error(`Could not add an ACL to the bucket. This might have happened because the bucket was already successfully created before but then failed to configure correctly. We recommend to delete the bucket (${bucketName}) if it is empty and start over to fix the problem.`);
41
+ }
42
+ throw err;
43
+ }
11
44
  };
12
45
  exports.createBucket = createBucket;
@@ -1,6 +1,5 @@
1
1
  import type { AwsRegion } from '../pricing/aws-regions';
2
- import type { LambdaArchitecture } from '../shared/validate-architecture';
3
- export declare const createFunction: ({ createCloudWatchLogGroup, region, zipFile, functionName, accountId, memorySizeInMb, timeoutInSeconds, alreadyCreated, retentionInDays, architecture, ephemerealStorageInMb, customRoleArn, }: {
2
+ export declare const createFunction: ({ createCloudWatchLogGroup, region, zipFile, functionName, accountId, memorySizeInMb, timeoutInSeconds, alreadyCreated, retentionInDays, ephemerealStorageInMb, customRoleArn, }: {
4
3
  createCloudWatchLogGroup: boolean;
5
4
  region: AwsRegion;
6
5
  zipFile: string;
@@ -11,7 +10,6 @@ export declare const createFunction: ({ createCloudWatchLogGroup, region, zipFil
11
10
  alreadyCreated: boolean;
12
11
  retentionInDays: number;
13
12
  ephemerealStorageInMb: number;
14
- architecture: LambdaArchitecture;
15
13
  customRoleArn: string;
16
14
  }) => Promise<{
17
15
  FunctionName: string;
@@ -3,12 +3,13 @@ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.createFunction = void 0;
4
4
  const client_cloudwatch_logs_1 = require("@aws-sdk/client-cloudwatch-logs");
5
5
  const client_lambda_1 = require("@aws-sdk/client-lambda");
6
- const fs_1 = require("fs");
6
+ const node_fs_1 = require("node:fs");
7
7
  const defaults_1 = require("../defaults");
8
8
  const aws_clients_1 = require("../shared/aws-clients");
9
9
  const hosted_layers_1 = require("../shared/hosted-layers");
10
10
  const suggested_policy_1 = require("./iam-validation/suggested-policy");
11
- const createFunction = async ({ createCloudWatchLogGroup, region, zipFile, functionName, accountId, memorySizeInMb, timeoutInSeconds, alreadyCreated, retentionInDays, architecture, ephemerealStorageInMb, customRoleArn, }) => {
11
+ const createFunction = async ({ createCloudWatchLogGroup, region, zipFile, functionName, accountId, memorySizeInMb, timeoutInSeconds, alreadyCreated, retentionInDays, ephemerealStorageInMb, customRoleArn, }) => {
12
+ var _a;
12
13
  if (createCloudWatchLogGroup) {
13
14
  try {
14
15
  await (0, aws_clients_1.getCloudWatchLogsClient)(region).send(new client_cloudwatch_logs_1.CreateLogGroupCommand({
@@ -32,17 +33,17 @@ const createFunction = async ({ createCloudWatchLogGroup, region, zipFile, funct
32
33
  const defaultRoleName = `arn:aws:iam::${accountId}:role/${suggested_policy_1.ROLE_NAME}`;
33
34
  const { FunctionName } = await (0, aws_clients_1.getLambdaClient)(region).send(new client_lambda_1.CreateFunctionCommand({
34
35
  Code: {
35
- ZipFile: (0, fs_1.readFileSync)(zipFile),
36
+ ZipFile: (0, node_fs_1.readFileSync)(zipFile),
36
37
  },
37
38
  FunctionName: functionName,
38
39
  Handler: 'index.handler',
39
40
  Role: customRoleArn !== null && customRoleArn !== void 0 ? customRoleArn : defaultRoleName,
40
- Runtime: 'nodejs14.x',
41
+ Runtime: 'nodejs18.x',
41
42
  Description: 'Renders a Remotion video.',
42
43
  MemorySize: memorySizeInMb,
43
44
  Timeout: timeoutInSeconds,
44
- Layers: hosted_layers_1.hostedLayers[architecture][region].map(({ layerArn, version }) => `${layerArn}:${version}`),
45
- Architectures: [architecture],
45
+ Layers: hosted_layers_1.hostedLayers[region].map(({ layerArn, version }) => `${layerArn}:${version}`),
46
+ Architectures: ['arm64'],
46
47
  EphemeralStorage: {
47
48
  Size: ephemerealStorageInMb,
48
49
  },
@@ -51,6 +52,26 @@ const createFunction = async ({ createCloudWatchLogGroup, region, zipFile, funct
51
52
  MaximumRetryAttempts: 0,
52
53
  FunctionName,
53
54
  }));
55
+ let state = 'Pending';
56
+ while (state === 'Pending') {
57
+ const getFn = await (0, aws_clients_1.getLambdaClient)(region).send(new client_lambda_1.GetFunctionCommand({
58
+ FunctionName,
59
+ }));
60
+ await new Promise((resolve) => {
61
+ setTimeout(() => resolve(), 1000);
62
+ });
63
+ state = (_a = getFn.Configuration) === null || _a === void 0 ? void 0 : _a.State;
64
+ }
65
+ try {
66
+ await (0, aws_clients_1.getLambdaClient)(region).send(new client_lambda_1.PutRuntimeManagementConfigCommand({
67
+ FunctionName,
68
+ UpdateRuntimeOn: 'Manual',
69
+ RuntimeVersionArn: `arn:aws:lambda:${region}::runtime:b97ad873eb5228db2e7d5727cd116734cc24c92ff1381739c4400c095404a2d3`,
70
+ }));
71
+ }
72
+ catch (err) {
73
+ console.warn('⚠️ Could not lock the runtime version. We recommend to update your policies to prevent your functions from breaking in the future in case the AWS runtime changes. See https://remotion.dev/docs/lambda/feb-2023-incident for an example on how to update your policy.');
74
+ }
54
75
  return { FunctionName: FunctionName };
55
76
  };
56
77
  exports.createFunction = createFunction;
@@ -1,13 +1,13 @@
1
1
  import type { AwsRegion } from '../pricing/aws-regions';
2
- export declare type DeleteFunctionInput = {
2
+ export type DeleteFunctionInput = {
3
3
  region: AwsRegion;
4
4
  functionName: string;
5
5
  };
6
6
  /**
7
7
  * @description Deletes a function from AWS Lambda.
8
- * @link https://remotion.dev/docs/lambda/deletefunction
9
- * @param options.region The region the function was deployed to.
10
- * @param options.functionName The name of the function.
8
+ * @see [Documentation](https://remotion.dev/docs/lambda/deletefunction)
9
+ * @param params.region The region the function was deployed to.
10
+ * @param params.functionName The name of the function.
11
11
  * @returns {Promise<void>} Nothing. Throws if the function failed to delete.
12
12
  */
13
13
  export declare const deleteFunction: ({ region, functionName, }: DeleteFunctionInput) => Promise<void>;
@@ -5,9 +5,9 @@ const client_lambda_1 = require("@aws-sdk/client-lambda");
5
5
  const aws_clients_1 = require("../shared/aws-clients");
6
6
  /**
7
7
  * @description Deletes a function from AWS Lambda.
8
- * @link https://remotion.dev/docs/lambda/deletefunction
9
- * @param options.region The region the function was deployed to.
10
- * @param options.functionName The name of the function.
8
+ * @see [Documentation](https://remotion.dev/docs/lambda/deletefunction)
9
+ * @param params.region The region the function was deployed to.
10
+ * @param params.functionName The name of the function.
11
11
  * @returns {Promise<void>} Nothing. Throws if the function failed to delete.
12
12
  */
13
13
  const deleteFunction = async ({ region, functionName, }) => {
@@ -1,6 +1,6 @@
1
1
  import type { AwsRegion } from '../client';
2
2
  import type { CustomCredentials } from '../shared/aws-clients';
3
- export declare type DeleteRenderInput = {
3
+ export type DeleteRenderInput = {
4
4
  region: AwsRegion;
5
5
  bucketName: string;
6
6
  renderId: string;
@@ -8,7 +8,7 @@ export declare type DeleteRenderInput = {
8
8
  };
9
9
  /**
10
10
  * @description Deletes a render artifact and it's metadata given it's renderId.
11
- * @link https://remotion.dev/docs/lambda/deleterender
11
+ * @see [Documentation](https://remotion.dev/docs/lambda/deleterender)
12
12
  * @param params.region The AWS region in which the media resides.
13
13
  * @param params.bucketName The `bucketName` that was specified during the render
14
14
  * @param params.renderId The `renderId` that was obtained after triggering the render.
@@ -9,7 +9,7 @@ const get_account_id_1 = require("../shared/get-account-id");
9
9
  const clean_items_1 = require("./clean-items");
10
10
  /**
11
11
  * @description Deletes a render artifact and it's metadata given it's renderId.
12
- * @link https://remotion.dev/docs/lambda/deleterender
12
+ * @see [Documentation](https://remotion.dev/docs/lambda/deleterender)
13
13
  * @param params.region The AWS region in which the media resides.
14
14
  * @param params.bucketName The `bucketName` that was specified during the render
15
15
  * @param params.renderId The `renderId` that was obtained after triggering the render.
@@ -1,5 +1,5 @@
1
1
  import type { AwsRegion } from '../pricing/aws-regions';
2
- export declare type DeleteSiteInput = {
2
+ export type DeleteSiteInput = {
3
3
  bucketName: string;
4
4
  siteName: string;
5
5
  region: AwsRegion;
@@ -8,17 +8,17 @@ export declare type DeleteSiteInput = {
8
8
  itemName: string;
9
9
  }) => void;
10
10
  };
11
- export declare type DeleteSiteOutput = {
11
+ export type DeleteSiteOutput = {
12
12
  totalSizeInBytes: number;
13
13
  };
14
14
  /**
15
15
  *
16
16
  * @description Deletes a deployed site from your S3 bucket. The opposite of deploySite().
17
- * @link https://remotion.dev/docs/lambda/deletesite
18
- * @param options.bucketName The S3 bucket name where the site resides in.
19
- * @param options.siteName The ID of the site that you want to delete.
20
- * @param {AwsRegion} options.region The region in where the S3 bucket resides in.
21
- * @param options.onAfterItemDeleted Function that gets called after each file that gets deleted, useful for showing progress.
17
+ * @see [Documentation](https://remotion.dev/docs/lambda/deletesite)
18
+ * @param params.bucketName The S3 bucket name where the site resides in.
19
+ * @param params.siteName The ID of the site that you want to delete.
20
+ * @param {AwsRegion} params.region The region in where the S3 bucket resides in.
21
+ * @param params.onAfterItemDeleted Function that gets called after each file that gets deleted, useful for showing progress.
22
22
  * @returns {Promise<DeleteSiteOutput>} Object containing info about how much space was freed.
23
23
  */
24
24
  export declare const deleteSite: ({ bucketName, siteName, region, onAfterItemDeleted, }: DeleteSiteInput) => Promise<DeleteSiteOutput>;
@@ -8,18 +8,19 @@ const clean_items_1 = require("./clean-items");
8
8
  /**
9
9
  *
10
10
  * @description Deletes a deployed site from your S3 bucket. The opposite of deploySite().
11
- * @link https://remotion.dev/docs/lambda/deletesite
12
- * @param options.bucketName The S3 bucket name where the site resides in.
13
- * @param options.siteName The ID of the site that you want to delete.
14
- * @param {AwsRegion} options.region The region in where the S3 bucket resides in.
15
- * @param options.onAfterItemDeleted Function that gets called after each file that gets deleted, useful for showing progress.
11
+ * @see [Documentation](https://remotion.dev/docs/lambda/deletesite)
12
+ * @param params.bucketName The S3 bucket name where the site resides in.
13
+ * @param params.siteName The ID of the site that you want to delete.
14
+ * @param {AwsRegion} params.region The region in where the S3 bucket resides in.
15
+ * @param params.onAfterItemDeleted Function that gets called after each file that gets deleted, useful for showing progress.
16
16
  * @returns {Promise<DeleteSiteOutput>} Object containing info about how much space was freed.
17
17
  */
18
18
  const deleteSite = async ({ bucketName, siteName, region, onAfterItemDeleted, }) => {
19
19
  const accountId = await (0, get_account_id_1.getAccountId)({ region });
20
20
  let files = await (0, io_1.lambdaLs)({
21
21
  bucketName,
22
- prefix: (0, defaults_1.getSitesKey)(siteName),
22
+ // The `/` is important to not accidentially delete sites with the same name but containing a suffix.
23
+ prefix: `${(0, defaults_1.getSitesKey)(siteName)}/`,
23
24
  region,
24
25
  expectedBucketOwner: accountId,
25
26
  });
@@ -38,7 +39,8 @@ const deleteSite = async ({ bucketName, siteName, region, onAfterItemDeleted, })
38
39
  });
39
40
  files = await (0, io_1.lambdaLs)({
40
41
  bucketName,
41
- prefix: (0, defaults_1.getSitesKey)(siteName),
42
+ // The `/` is important to not accidentially delete sites with the same name but containing a suffix.
43
+ prefix: `${(0, defaults_1.getSitesKey)(siteName)}/`,
42
44
  region,
43
45
  expectedBucketOwner: accountId,
44
46
  });
@@ -1,29 +1,27 @@
1
1
  import type { AwsRegion } from '../pricing/aws-regions';
2
- import type { LambdaArchitecture } from '../shared/validate-architecture';
3
- export declare type DeployFunctionInput = {
2
+ export type DeployFunctionInput = {
4
3
  createCloudWatchLogGroup: boolean;
5
4
  cloudWatchLogRetentionPeriodInDays?: number;
6
5
  region: AwsRegion;
7
6
  timeoutInSeconds: number;
8
7
  memorySizeInMb: number;
9
- architecture: LambdaArchitecture;
10
8
  diskSizeInMb?: number;
11
9
  customRoleArn?: string;
12
10
  };
13
- export declare type DeployFunctionOutput = {
11
+ export type DeployFunctionOutput = {
14
12
  functionName: string;
15
13
  alreadyExisted: boolean;
16
14
  };
17
15
  /**
18
16
  * @description Creates an AWS Lambda function in your account that will be able to render a video in the cloud.
19
- * @link https://remotion.dev/docs/lambda/deployfunction
20
- * @param options.createCloudWatchLogGroup Whether you'd like to create a CloudWatch Log Group to store the logs for this function.
21
- * @param options.cloudWatchLogRetentionPeriodInDays (optional) The number of days to retain the CloudWatch logs for this function. Default is 14 days.
22
- * @param options.region The region you want to deploy your function to.
23
- * @param options.timeoutInSeconds After how many seconds the lambda function should be killed if it does not end itself.
24
- * @param options.memorySizeInMb How much memory should be allocated to the Lambda function.
25
- * @param options.architecture The architecture Lambda should run on. One of x86_64 and x64
26
- * @param options.diskSizeInMb The amount of storage the function should be allocated. The higher, the longer videos you can render. Default 512.
17
+ * @see [Documentation](https://www.remotion.dev/docs/lambda/deployfunction)
18
+ * @param params.createCloudWatchLogGroup Whether you'd like to create a CloudWatch Log Group to store the logs for this function.
19
+ * @param params.cloudWatchLogRetentionPeriodInDays (optional) The number of days to retain the CloudWatch logs for this function. Default is 14 days.
20
+ * @param params.region The region you want to deploy your function to.
21
+ * @param params.timeoutInSeconds After how many seconds the lambda function should be killed if it does not end itself.
22
+ * @param params.memorySizeInMb How much memory should be allocated to the Lambda function.
23
+ * @param params.architecture The architecture Lambda should run on. One of x86_64 and x64
24
+ * @param params.diskSizeInMb The amount of storage the function should be allocated. The higher, the longer videos you can render. Default 512.
27
25
  * @returns {Promise<DeployFunctionOutput>} An object that contains the `functionName` property
28
26
  */
29
- export declare const deployFunction: (options: DeployFunctionInput) => Promise<DeployFunctionOutput>;
27
+ export declare const deployFunction: (params: DeployFunctionInput) => Promise<DeployFunctionOutput>;