@remotion/lambda 2.5.0-alpha.be0e6380 → 3.0.0-alpha.192

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 (537) hide show
  1. package/.prettierrc.js +15 -0
  2. package/LICENSE.md +41 -0
  3. package/client.d.ts +1 -0
  4. package/client.js +1 -0
  5. package/dist/admin/bundle-lambda.js +5 -4
  6. package/dist/admin/bundle-lambda.js.map +1 -1
  7. package/dist/admin/make-layer-public.d.ts +1 -1
  8. package/dist/admin/make-layer-public.d.ts.map +1 -1
  9. package/dist/admin/make-layer-public.js +7 -19
  10. package/dist/admin/make-layer-public.js.map +1 -1
  11. package/dist/api/bucket-exists.d.ts +1 -1
  12. package/dist/api/bucket-exists.d.ts.map +1 -1
  13. package/dist/api/bucket-exists.js +1 -1
  14. package/dist/api/bucket-exists.js.map +1 -1
  15. package/dist/api/clean-items.js +2 -2
  16. package/dist/api/clean-items.js.map +1 -1
  17. package/dist/api/convert-to-serve-url.d.ts +2 -0
  18. package/dist/api/convert-to-serve-url.d.ts.map +1 -0
  19. package/dist/api/convert-to-serve-url.js +13 -0
  20. package/dist/api/convert-to-serve-url.js.map +1 -0
  21. package/dist/api/create-bucket.d.ts +1 -1
  22. package/dist/api/create-bucket.d.ts.map +1 -1
  23. package/dist/api/create-bucket.js +1 -1
  24. package/dist/api/create-bucket.js.map +1 -1
  25. package/dist/api/create-function.d.ts +3 -2
  26. package/dist/api/create-function.d.ts.map +1 -1
  27. package/dist/api/create-function.js +21 -5
  28. package/dist/api/create-function.js.map +1 -1
  29. package/dist/api/delete-function.d.ts +1 -1
  30. package/dist/api/delete-function.js +2 -2
  31. package/dist/api/delete-function.js.map +1 -1
  32. package/dist/api/delete-site.d.ts +19 -9
  33. package/dist/api/delete-site.d.ts.map +1 -1
  34. package/dist/api/delete-site.js +21 -10
  35. package/dist/api/delete-site.js.map +1 -1
  36. package/dist/api/deploy-function.d.ts +3 -1
  37. package/dist/api/deploy-function.d.ts.map +1 -1
  38. package/dist/api/deploy-function.js +21 -8
  39. package/dist/api/deploy-function.js.map +1 -1
  40. package/dist/api/deploy-site.d.ts +2 -3
  41. package/dist/api/deploy-site.d.ts.map +1 -1
  42. package/dist/api/deploy-site.js +14 -14
  43. package/dist/api/deploy-site.js.map +1 -1
  44. package/dist/api/download-video.d.ts +3 -1
  45. package/dist/api/download-video.d.ts.map +1 -1
  46. package/dist/api/download-video.js +17 -33
  47. package/dist/api/download-video.js.map +1 -1
  48. package/dist/api/enable-s3-website.d.ts +1 -1
  49. package/dist/api/enable-s3-website.d.ts.map +1 -1
  50. package/dist/api/enable-s3-website.js +3 -4
  51. package/dist/api/enable-s3-website.js.map +1 -1
  52. package/dist/api/get-buckets.d.ts +3 -2
  53. package/dist/api/get-buckets.d.ts.map +1 -1
  54. package/dist/api/get-buckets.js +4 -3
  55. package/dist/api/get-buckets.js.map +1 -1
  56. package/dist/api/get-function-info.d.ts +1 -1
  57. package/dist/api/get-function-info.js +4 -4
  58. package/dist/api/get-function-info.js.map +1 -1
  59. package/dist/api/get-functions.d.ts +1 -1
  60. package/dist/api/get-functions.js +3 -3
  61. package/dist/api/get-functions.js.map +1 -1
  62. package/dist/api/get-or-create-bucket.d.ts +1 -0
  63. package/dist/api/get-or-create-bucket.d.ts.map +1 -1
  64. package/dist/api/get-or-create-bucket.js +13 -5
  65. package/dist/api/get-or-create-bucket.js.map +1 -1
  66. package/dist/api/get-render-progress.d.ts +1 -1
  67. package/dist/api/get-render-progress.js +2 -2
  68. package/dist/api/get-render-progress.js.map +1 -1
  69. package/dist/api/get-sites.d.ts +9 -6
  70. package/dist/api/get-sites.d.ts.map +1 -1
  71. package/dist/api/get-sites.js +20 -11
  72. package/dist/api/get-sites.js.map +1 -1
  73. package/dist/api/iam-validation/role-permissions.d.ts +2 -2
  74. package/dist/api/iam-validation/role-permissions.d.ts.map +1 -1
  75. package/dist/api/iam-validation/role-permissions.js +9 -4
  76. package/dist/api/iam-validation/role-permissions.js.map +1 -1
  77. package/dist/api/iam-validation/simulate-rule.d.ts +1 -0
  78. package/dist/api/iam-validation/simulate-rule.d.ts.map +1 -1
  79. package/dist/api/iam-validation/simulate-rule.js +42 -29
  80. package/dist/api/iam-validation/simulate-rule.js.map +1 -1
  81. package/dist/api/iam-validation/simulate.d.ts +1 -1
  82. package/dist/api/iam-validation/simulate.d.ts.map +1 -1
  83. package/dist/api/iam-validation/simulate.js +6 -6
  84. package/dist/api/iam-validation/simulate.js.map +1 -1
  85. package/dist/api/iam-validation/suggested-policy.d.ts +3 -2
  86. package/dist/api/iam-validation/suggested-policy.d.ts.map +1 -1
  87. package/dist/api/iam-validation/suggested-policy.js +7 -6
  88. package/dist/api/iam-validation/suggested-policy.js.map +1 -1
  89. package/dist/api/iam-validation/user-permissions.d.ts +7 -0
  90. package/dist/api/iam-validation/user-permissions.d.ts.map +1 -0
  91. package/dist/api/iam-validation/{required-permissions.js → user-permissions.js} +30 -13
  92. package/dist/api/iam-validation/user-permissions.js.map +1 -0
  93. package/dist/api/mock-functions.d.ts +1 -1
  94. package/dist/api/mock-functions.d.ts.map +1 -1
  95. package/dist/api/render-still-on-lambda.d.ts +5 -3
  96. package/dist/api/render-still-on-lambda.d.ts.map +1 -1
  97. package/dist/api/render-still-on-lambda.js +10 -5
  98. package/dist/api/render-still-on-lambda.js.map +1 -1
  99. package/dist/api/render-video-on-lambda.d.ts +10 -3
  100. package/dist/api/render-video-on-lambda.d.ts.map +1 -1
  101. package/dist/api/render-video-on-lambda.js +14 -6
  102. package/dist/api/render-video-on-lambda.js.map +1 -1
  103. package/dist/api/upload-dir.d.ts +4 -2
  104. package/dist/api/upload-dir.d.ts.map +1 -1
  105. package/dist/api/upload-dir.js +5 -5
  106. package/dist/api/upload-dir.js.map +1 -1
  107. package/dist/cli/args.d.ts +9 -0
  108. package/dist/cli/args.d.ts.map +1 -1
  109. package/dist/cli/args.js +7 -2
  110. package/dist/cli/args.js.map +1 -1
  111. package/dist/cli/commands/functions/deploy.d.ts.map +1 -1
  112. package/dist/cli/commands/functions/deploy.js +6 -5
  113. package/dist/cli/commands/functions/deploy.js.map +1 -1
  114. package/dist/cli/commands/functions/index.d.ts.map +1 -1
  115. package/dist/cli/commands/functions/index.js +5 -4
  116. package/dist/cli/commands/functions/index.js.map +1 -1
  117. package/dist/cli/commands/functions/ls.d.ts.map +1 -1
  118. package/dist/cli/commands/functions/ls.js +8 -5
  119. package/dist/cli/commands/functions/ls.js.map +1 -1
  120. package/dist/cli/commands/functions/rm.d.ts.map +1 -1
  121. package/dist/cli/commands/functions/rm.js +10 -5
  122. package/dist/cli/commands/functions/rm.js.map +1 -1
  123. package/dist/cli/commands/policies/policies.d.ts.map +1 -1
  124. package/dist/cli/commands/policies/policies.js +5 -4
  125. package/dist/cli/commands/policies/policies.js.map +1 -1
  126. package/dist/cli/commands/policies/role.js +1 -1
  127. package/dist/cli/commands/policies/role.js.map +1 -1
  128. package/dist/cli/commands/policies/user.js +1 -1
  129. package/dist/cli/commands/policies/user.js.map +1 -1
  130. package/dist/cli/commands/policies/validate.js +3 -3
  131. package/dist/cli/commands/policies/validate.js.map +1 -1
  132. package/dist/cli/commands/render/progress.d.ts +14 -5
  133. package/dist/cli/commands/render/progress.d.ts.map +1 -1
  134. package/dist/cli/commands/render/progress.js +93 -37
  135. package/dist/cli/commands/render/progress.js.map +1 -1
  136. package/dist/cli/commands/render/render.d.ts.map +1 -1
  137. package/dist/cli/commands/render/render.js +105 -56
  138. package/dist/cli/commands/render/render.js.map +1 -1
  139. package/dist/cli/commands/sites/create.d.ts.map +1 -1
  140. package/dist/cli/commands/sites/create.js +26 -26
  141. package/dist/cli/commands/sites/create.js.map +1 -1
  142. package/dist/cli/commands/sites/index.d.ts.map +1 -1
  143. package/dist/cli/commands/sites/index.js +5 -4
  144. package/dist/cli/commands/sites/index.js.map +1 -1
  145. package/dist/cli/commands/sites/ls.js +13 -12
  146. package/dist/cli/commands/sites/ls.js.map +1 -1
  147. package/dist/cli/commands/sites/rm.d.ts +1 -1
  148. package/dist/cli/commands/sites/rm.d.ts.map +1 -1
  149. package/dist/cli/commands/sites/rm.js +36 -20
  150. package/dist/cli/commands/sites/rm.js.map +1 -1
  151. package/dist/cli/commands/still.d.ts.map +1 -1
  152. package/dist/cli/commands/still.js +17 -9
  153. package/dist/cli/commands/still.js.map +1 -1
  154. package/dist/cli/get-aws-region.d.ts.map +1 -1
  155. package/dist/cli/get-aws-region.js +4 -4
  156. package/dist/cli/get-aws-region.js.map +1 -1
  157. package/dist/cli/help.d.ts.map +1 -1
  158. package/dist/cli/help.js +4 -4
  159. package/dist/cli/help.js.map +1 -1
  160. package/dist/cli/helpers/confirm.d.ts.map +1 -1
  161. package/dist/cli/helpers/confirm.js +2 -1
  162. package/dist/cli/helpers/confirm.js.map +1 -1
  163. package/dist/cli/helpers/find-function-name.d.ts.map +1 -1
  164. package/dist/cli/helpers/find-function-name.js +8 -6
  165. package/dist/cli/helpers/find-function-name.js.map +1 -1
  166. package/dist/cli/helpers/get-cloudwatch-stream-url.d.ts +9 -0
  167. package/dist/cli/helpers/get-cloudwatch-stream-url.d.ts.map +1 -0
  168. package/dist/cli/helpers/get-cloudwatch-stream-url.js +8 -0
  169. package/dist/cli/helpers/get-cloudwatch-stream-url.js.map +1 -0
  170. package/dist/cli/helpers/progress-bar.js +1 -1
  171. package/dist/cli/helpers/progress-bar.js.map +1 -1
  172. package/dist/cli/helpers/quit.d.ts +2 -0
  173. package/dist/cli/helpers/quit.d.ts.map +1 -0
  174. package/dist/cli/helpers/quit.js +8 -0
  175. package/dist/cli/helpers/quit.js.map +1 -0
  176. package/dist/cli/index.d.ts.map +1 -1
  177. package/dist/cli/index.js +41 -22
  178. package/dist/cli/index.js.map +1 -1
  179. package/dist/client.d.ts +9 -0
  180. package/dist/client.d.ts.map +1 -0
  181. package/dist/client.js +12 -0
  182. package/dist/client.js.map +1 -0
  183. package/dist/functions/chunk-optimization/can-use-optimization.d.ts +2 -2
  184. package/dist/functions/chunk-optimization/can-use-optimization.d.ts.map +1 -1
  185. package/dist/functions/chunk-optimization/can-use-optimization.js +6 -3
  186. package/dist/functions/chunk-optimization/can-use-optimization.js.map +1 -1
  187. package/dist/functions/chunk-optimization/collect-data.js +4 -4
  188. package/dist/functions/chunk-optimization/collect-data.js.map +1 -1
  189. package/dist/functions/chunk-optimization/get-profile-duration.js +1 -1
  190. package/dist/functions/chunk-optimization/get-profile-duration.js.map +1 -1
  191. package/dist/functions/chunk-optimization/optimize-invocation-order.js +1 -1
  192. package/dist/functions/chunk-optimization/optimize-invocation-order.js.map +1 -1
  193. package/dist/functions/chunk-optimization/optimize-profile.js +5 -5
  194. package/dist/functions/chunk-optimization/optimize-profile.js.map +1 -1
  195. package/dist/functions/chunk-optimization/plan-frame-ranges.d.ts +3 -2
  196. package/dist/functions/chunk-optimization/plan-frame-ranges.d.ts.map +1 -1
  197. package/dist/functions/chunk-optimization/plan-frame-ranges.js +11 -5
  198. package/dist/functions/chunk-optimization/plan-frame-ranges.js.map +1 -1
  199. package/dist/functions/chunk-optimization/s3-optimization-file.js +7 -7
  200. package/dist/functions/chunk-optimization/s3-optimization-file.js.map +1 -1
  201. package/dist/functions/chunk-optimization/simulate-frame-ranges.js +2 -2
  202. package/dist/functions/chunk-optimization/simulate-frame-ranges.js.map +1 -1
  203. package/dist/functions/chunk-optimization/sort-by-duration.js +1 -1
  204. package/dist/functions/chunk-optimization/sort-by-duration.js.map +1 -1
  205. package/dist/functions/chunk-optimization/types.d.ts +2 -2
  206. package/dist/functions/chunk-optimization/types.d.ts.map +1 -1
  207. package/dist/functions/fire.js +2 -2
  208. package/dist/functions/fire.js.map +1 -1
  209. package/dist/functions/helpers/calculate-chunk-times.d.ts +7 -0
  210. package/dist/functions/helpers/calculate-chunk-times.d.ts.map +1 -0
  211. package/dist/functions/helpers/calculate-chunk-times.js +31 -0
  212. package/dist/functions/helpers/calculate-chunk-times.js.map +1 -0
  213. package/dist/functions/helpers/calculate-price-from-bucket.d.ts +1 -2
  214. package/dist/functions/helpers/calculate-price-from-bucket.d.ts.map +1 -1
  215. package/dist/functions/helpers/calculate-price-from-bucket.js +14 -13
  216. package/dist/functions/helpers/calculate-price-from-bucket.js.map +1 -1
  217. package/dist/functions/helpers/clean-tmpdir.d.ts.map +1 -1
  218. package/dist/functions/helpers/clean-tmpdir.js +5 -13
  219. package/dist/functions/helpers/clean-tmpdir.js.map +1 -1
  220. package/dist/functions/helpers/concat-videos.d.ts +6 -2
  221. package/dist/functions/helpers/concat-videos.d.ts.map +1 -1
  222. package/dist/functions/helpers/concat-videos.js +19 -20
  223. package/dist/functions/helpers/concat-videos.js.map +1 -1
  224. package/dist/functions/helpers/create-post-render-data.d.ts +6 -2
  225. package/dist/functions/helpers/create-post-render-data.d.ts.map +1 -1
  226. package/dist/functions/helpers/create-post-render-data.js +33 -17
  227. package/dist/functions/helpers/create-post-render-data.js.map +1 -1
  228. package/dist/functions/helpers/delete-chunks.d.ts +4 -4
  229. package/dist/functions/helpers/delete-chunks.d.ts.map +1 -1
  230. package/dist/functions/helpers/delete-chunks.js +7 -10
  231. package/dist/functions/helpers/delete-chunks.js.map +1 -1
  232. package/dist/functions/helpers/expected-out-name.d.ts.map +1 -1
  233. package/dist/functions/helpers/expected-out-name.js +3 -2
  234. package/dist/functions/helpers/expected-out-name.js.map +1 -1
  235. package/dist/functions/helpers/find-output-file-in-bucket.js +2 -2
  236. package/dist/functions/helpers/find-output-file-in-bucket.js.map +1 -1
  237. package/dist/functions/helpers/format-costs-info.d.ts.map +1 -1
  238. package/dist/functions/helpers/format-costs-info.js +12 -4
  239. package/dist/functions/helpers/format-costs-info.js.map +1 -1
  240. package/dist/functions/helpers/get-browser-instance.d.ts +2 -4
  241. package/dist/functions/helpers/get-browser-instance.d.ts.map +1 -1
  242. package/dist/functions/helpers/get-browser-instance.js +14 -19
  243. package/dist/functions/helpers/get-browser-instance.js.map +1 -1
  244. package/dist/functions/helpers/get-cleanup-progress.d.ts.map +1 -1
  245. package/dist/functions/helpers/get-cleanup-progress.js +5 -4
  246. package/dist/functions/helpers/get-cleanup-progress.js.map +1 -1
  247. package/dist/functions/helpers/get-current-region.d.ts +1 -1
  248. package/dist/functions/helpers/get-current-region.d.ts.map +1 -1
  249. package/dist/functions/helpers/get-current-region.js +2 -2
  250. package/dist/functions/helpers/get-current-region.js.map +1 -1
  251. package/dist/functions/helpers/get-encoding-metadata.d.ts.map +1 -1
  252. package/dist/functions/helpers/get-encoding-metadata.js +8 -8
  253. package/dist/functions/helpers/get-encoding-metadata.js.map +1 -1
  254. package/dist/functions/helpers/get-files-to-delete.d.ts +5 -4
  255. package/dist/functions/helpers/get-files-to-delete.d.ts.map +1 -1
  256. package/dist/functions/helpers/get-files-to-delete.js +7 -13
  257. package/dist/functions/helpers/get-files-to-delete.js.map +1 -1
  258. package/dist/functions/helpers/get-final-encoding-status.d.ts +3 -1
  259. package/dist/functions/helpers/get-final-encoding-status.d.ts.map +1 -1
  260. package/dist/functions/helpers/get-final-encoding-status.js +6 -3
  261. package/dist/functions/helpers/get-final-encoding-status.js.map +1 -1
  262. package/dist/functions/helpers/get-folder-size.js +1 -1
  263. package/dist/functions/helpers/get-folder-size.js.map +1 -1
  264. package/dist/functions/helpers/get-lambdas-invoked-stats.d.ts +8 -0
  265. package/dist/functions/helpers/get-lambdas-invoked-stats.d.ts.map +1 -0
  266. package/dist/functions/helpers/get-lambdas-invoked-stats.js +23 -0
  267. package/dist/functions/helpers/get-lambdas-invoked-stats.js.map +1 -0
  268. package/dist/functions/helpers/get-overall-progress.d.ts +7 -0
  269. package/dist/functions/helpers/get-overall-progress.d.ts.map +1 -0
  270. package/dist/functions/helpers/get-overall-progress.js +17 -0
  271. package/dist/functions/helpers/get-overall-progress.js.map +1 -0
  272. package/dist/functions/helpers/get-post-render-data.js +3 -3
  273. package/dist/functions/helpers/get-post-render-data.js.map +1 -1
  274. package/dist/functions/helpers/get-progress.d.ts.map +1 -1
  275. package/dist/functions/helpers/get-progress.js +79 -42
  276. package/dist/functions/helpers/get-progress.js.map +1 -1
  277. package/dist/functions/helpers/get-render-metadata.d.ts +2 -3
  278. package/dist/functions/helpers/get-render-metadata.d.ts.map +1 -1
  279. package/dist/functions/helpers/get-render-metadata.js +4 -7
  280. package/dist/functions/helpers/get-render-metadata.js.map +1 -1
  281. package/dist/functions/helpers/get-retry-stats.d.ts +11 -0
  282. package/dist/functions/helpers/get-retry-stats.d.ts.map +1 -0
  283. package/dist/functions/helpers/get-retry-stats.js +21 -0
  284. package/dist/functions/helpers/get-retry-stats.js.map +1 -0
  285. package/dist/functions/helpers/get-time-to-finish.js +1 -1
  286. package/dist/functions/helpers/get-time-to-finish.js.map +1 -1
  287. package/dist/functions/helpers/inspect-errors.d.ts.map +1 -1
  288. package/dist/functions/helpers/inspect-errors.js +10 -4
  289. package/dist/functions/helpers/inspect-errors.js.map +1 -1
  290. package/dist/functions/helpers/io.d.ts +3 -3
  291. package/dist/functions/helpers/io.d.ts.map +1 -1
  292. package/dist/functions/helpers/io.js +7 -7
  293. package/dist/functions/helpers/io.js.map +1 -1
  294. package/dist/functions/helpers/is-enosp-err.d.ts +1 -0
  295. package/dist/functions/helpers/is-enosp-err.d.ts.map +1 -1
  296. package/dist/functions/helpers/is-enosp-err.js +5 -1
  297. package/dist/functions/helpers/is-enosp-err.js.map +1 -1
  298. package/dist/functions/helpers/min-max.d.ts +3 -0
  299. package/dist/functions/helpers/min-max.d.ts.map +1 -0
  300. package/dist/functions/helpers/min-max.js +34 -0
  301. package/dist/functions/helpers/min-max.js.map +1 -0
  302. package/dist/functions/helpers/print-cloudwatch-helper.d.ts +3 -0
  303. package/dist/functions/helpers/print-cloudwatch-helper.d.ts.map +1 -0
  304. package/dist/functions/helpers/print-cloudwatch-helper.js +12 -0
  305. package/dist/functions/helpers/print-cloudwatch-helper.js.map +1 -0
  306. package/dist/functions/helpers/read-with-progress.d.ts +15 -0
  307. package/dist/functions/helpers/read-with-progress.d.ts.map +1 -0
  308. package/dist/functions/helpers/read-with-progress.js +27 -0
  309. package/dist/functions/helpers/read-with-progress.js.map +1 -0
  310. package/dist/functions/helpers/validate-composition.d.ts +6 -7
  311. package/dist/functions/helpers/validate-composition.d.ts.map +1 -1
  312. package/dist/functions/helpers/validate-composition.js +3 -11
  313. package/dist/functions/helpers/validate-composition.js.map +1 -1
  314. package/dist/functions/helpers/write-lambda-error.d.ts +3 -0
  315. package/dist/functions/helpers/write-lambda-error.d.ts.map +1 -1
  316. package/dist/functions/helpers/write-lambda-error.js +10 -7
  317. package/dist/functions/helpers/write-lambda-error.js.map +1 -1
  318. package/dist/functions/helpers/write-post-render-data.js +3 -3
  319. package/dist/functions/helpers/write-post-render-data.js.map +1 -1
  320. package/dist/functions/index.d.ts.map +1 -1
  321. package/dist/functions/index.js +29 -12
  322. package/dist/functions/index.js.map +1 -1
  323. package/dist/functions/launch.d.ts.map +1 -1
  324. package/dist/functions/launch.js +158 -97
  325. package/dist/functions/launch.js.map +1 -1
  326. package/dist/functions/progress.js +2 -2
  327. package/dist/functions/progress.js.map +1 -1
  328. package/dist/functions/renderer.d.ts.map +1 -1
  329. package/dist/functions/renderer.js +61 -98
  330. package/dist/functions/renderer.js.map +1 -1
  331. package/dist/functions/start.d.ts.map +1 -1
  332. package/dist/functions/start.js +14 -4
  333. package/dist/functions/start.js.map +1 -1
  334. package/dist/functions/still.d.ts +2 -1
  335. package/dist/functions/still.d.ts.map +1 -1
  336. package/dist/functions/still.js +55 -66
  337. package/dist/functions/still.js.map +1 -1
  338. package/dist/index.d.ts +5 -3
  339. package/dist/index.d.ts.map +1 -1
  340. package/dist/index.js.map +1 -1
  341. package/dist/pricing/aws-regions.d.ts +1 -1
  342. package/dist/pricing/aws-regions.d.ts.map +1 -1
  343. package/dist/pricing/aws-regions.js +3 -14
  344. package/dist/pricing/aws-regions.js.map +1 -1
  345. package/dist/pricing/calculate-price.d.ts +1 -1
  346. package/dist/pricing/calculate-price.js +3 -3
  347. package/dist/pricing/calculate-price.js.map +1 -1
  348. package/dist/pricing/price-per-1-s.d.ts +8 -0
  349. package/dist/pricing/price-per-1-s.d.ts.map +1 -1
  350. package/dist/pricing/price-per-1-s.js +72 -190
  351. package/dist/pricing/price-per-1-s.js.map +1 -1
  352. package/dist/shared/aws-clients.d.ts +2 -0
  353. package/dist/shared/aws-clients.d.ts.map +1 -1
  354. package/dist/shared/aws-clients.js +14 -4
  355. package/dist/shared/aws-clients.js.map +1 -1
  356. package/dist/shared/call-lambda.js +1 -1
  357. package/dist/shared/call-lambda.js.map +1 -1
  358. package/dist/shared/check-credentials.d.ts.map +1 -1
  359. package/dist/shared/check-credentials.js +2 -1
  360. package/dist/shared/check-credentials.js.map +1 -1
  361. package/dist/shared/constants.d.ts +45 -12
  362. package/dist/shared/constants.d.ts.map +1 -1
  363. package/dist/shared/constants.js +23 -23
  364. package/dist/shared/constants.js.map +1 -1
  365. package/dist/shared/convert-to-serve-url.d.ts +3 -0
  366. package/dist/shared/convert-to-serve-url.d.ts.map +1 -0
  367. package/dist/shared/convert-to-serve-url.js +19 -0
  368. package/dist/shared/convert-to-serve-url.js.map +1 -0
  369. package/dist/shared/docs-url.d.ts +2 -0
  370. package/dist/shared/docs-url.d.ts.map +1 -0
  371. package/dist/shared/docs-url.js +5 -0
  372. package/dist/shared/docs-url.js.map +1 -0
  373. package/dist/shared/function-zip-path.d.ts +2 -0
  374. package/dist/shared/function-zip-path.d.ts.map +1 -0
  375. package/dist/shared/function-zip-path.js +9 -0
  376. package/dist/shared/function-zip-path.js.map +1 -0
  377. package/dist/shared/get-account-id.js +2 -2
  378. package/dist/shared/get-account-id.js.map +1 -1
  379. package/dist/shared/get-function-version.js +1 -1
  380. package/dist/shared/get-function-version.js.map +1 -1
  381. package/dist/shared/hosted-layers.d.ts +2 -1
  382. package/dist/shared/hosted-layers.d.ts.map +1 -1
  383. package/dist/shared/hosted-layers.js +62 -215
  384. package/dist/shared/hosted-layers.js.map +1 -1
  385. package/dist/shared/make-s3-url.d.ts +1 -1
  386. package/dist/shared/make-s3-url.d.ts.map +1 -1
  387. package/dist/shared/make-s3-url.js +4 -5
  388. package/dist/shared/make-s3-url.js.map +1 -1
  389. package/dist/shared/parse-lambda-initialized-key.d.ts +6 -0
  390. package/dist/shared/parse-lambda-initialized-key.d.ts.map +1 -0
  391. package/dist/shared/parse-lambda-initialized-key.js +16 -0
  392. package/dist/shared/parse-lambda-initialized-key.js.map +1 -0
  393. package/dist/shared/parse-lambda-timings-key.d.ts +1 -1
  394. package/dist/shared/parse-lambda-timings-key.js +2 -2
  395. package/dist/shared/parse-lambda-timings-key.js.map +1 -1
  396. package/dist/shared/validate-privacy.d.ts +3 -0
  397. package/dist/shared/validate-privacy.d.ts.map +1 -0
  398. package/dist/shared/validate-privacy.js +13 -0
  399. package/dist/shared/validate-privacy.js.map +1 -0
  400. package/dist/shared/validate-retries.d.ts +2 -0
  401. package/dist/shared/validate-retries.d.ts.map +1 -0
  402. package/dist/shared/validate-retries.js +22 -0
  403. package/dist/shared/validate-retries.js.map +1 -0
  404. package/package.json +23 -20
  405. package/remotionlambda.zip +0 -0
  406. package/dist/admin/push-layer.d.ts +0 -2
  407. package/dist/admin/push-layer.d.ts.map +0 -1
  408. package/dist/admin/push-layer.js +0 -27
  409. package/dist/admin/push-layer.js.map +0 -1
  410. package/dist/admin/replicate-binaries.d.ts +0 -2
  411. package/dist/admin/replicate-binaries.d.ts.map +0 -1
  412. package/dist/admin/replicate-binaries.js +0 -52
  413. package/dist/admin/replicate-binaries.js.map +0 -1
  414. package/dist/api/__mocks__/mock-functions.d.ts +0 -8
  415. package/dist/api/__mocks__/mock-functions.d.ts.map +0 -1
  416. package/dist/api/__mocks__/mock-functions.js +0 -25
  417. package/dist/api/__mocks__/mock-functions.js.map +0 -1
  418. package/dist/api/bundle-lambda.d.ts +0 -2
  419. package/dist/api/bundle-lambda.d.ts.map +0 -1
  420. package/dist/api/bundle-lambda.js +0 -34
  421. package/dist/api/bundle-lambda.js.map +0 -1
  422. package/dist/api/bundle-remotion.d.ts +0 -6
  423. package/dist/api/bundle-remotion.d.ts.map +0 -1
  424. package/dist/api/bundle-remotion.js +0 -12
  425. package/dist/api/bundle-remotion.js.map +0 -1
  426. package/dist/api/deploy-lambda.d.ts +0 -10
  427. package/dist/api/deploy-lambda.d.ts.map +0 -1
  428. package/dist/api/deploy-lambda.js +0 -45
  429. package/dist/api/deploy-lambda.js.map +0 -1
  430. package/dist/api/deploy-project.d.ts +0 -28
  431. package/dist/api/deploy-project.d.ts.map +0 -1
  432. package/dist/api/deploy-project.js +0 -58
  433. package/dist/api/deploy-project.js.map +0 -1
  434. package/dist/api/ensure-lambda-binaries.d.ts +0 -11
  435. package/dist/api/ensure-lambda-binaries.d.ts.map +0 -1
  436. package/dist/api/ensure-lambda-binaries.js +0 -60
  437. package/dist/api/ensure-lambda-binaries.js.map +0 -1
  438. package/dist/api/get-deployed-lambdas.d.ts +0 -10
  439. package/dist/api/get-deployed-lambdas.d.ts.map +0 -1
  440. package/dist/api/get-deployed-lambdas.js +0 -30
  441. package/dist/api/get-deployed-lambdas.js.map +0 -1
  442. package/dist/api/get-function-version.d.ts +0 -10
  443. package/dist/api/get-function-version.d.ts.map +0 -1
  444. package/dist/api/get-function-version.js +0 -27
  445. package/dist/api/get-function-version.js.map +0 -1
  446. package/dist/api/iam-validation/required-permissions.d.ts +0 -6
  447. package/dist/api/iam-validation/required-permissions.d.ts.map +0 -1
  448. package/dist/api/iam-validation/required-permissions.js.map +0 -1
  449. package/dist/benchmark.d.ts +0 -2
  450. package/dist/benchmark.d.ts.map +0 -1
  451. package/dist/benchmark.js +0 -30
  452. package/dist/benchmark.js.map +0 -1
  453. package/dist/build-render/index.js +0 -135338
  454. package/dist/cleanup/cleanup-lambdas.d.ts +0 -7
  455. package/dist/cleanup/cleanup-lambdas.d.ts.map +0 -1
  456. package/dist/cleanup/cleanup-lambdas.js +0 -22
  457. package/dist/cleanup/cleanup-lambdas.js.map +0 -1
  458. package/dist/cleanup/s3-buckets.d.ts +0 -16
  459. package/dist/cleanup/s3-buckets.d.ts.map +0 -1
  460. package/dist/cleanup/s3-buckets.js +0 -59
  461. package/dist/cleanup/s3-buckets.js.map +0 -1
  462. package/dist/cli/check-credentials.d.ts +0 -2
  463. package/dist/cli/check-credentials.d.ts.map +0 -1
  464. package/dist/cli/check-credentials.js +0 -8
  465. package/dist/cli/check-credentials.js.map +0 -1
  466. package/dist/cli/cleanup.d.ts +0 -4
  467. package/dist/cli/cleanup.d.ts.map +0 -1
  468. package/dist/cli/cleanup.js +0 -76
  469. package/dist/cli/cleanup.js.map +0 -1
  470. package/dist/cli/commands/functions/functions.d.ts +0 -3
  471. package/dist/cli/commands/functions/functions.d.ts.map +0 -1
  472. package/dist/cli/commands/functions/functions.js +0 -50
  473. package/dist/cli/commands/functions/functions.js.map +0 -1
  474. package/dist/cli/commands/render.d.ts +0 -3
  475. package/dist/cli/commands/render.d.ts.map +0 -1
  476. package/dist/cli/commands/render.js +0 -75
  477. package/dist/cli/commands/render.js.map +0 -1
  478. package/dist/cli/commands/sites/upload.d.ts +0 -3
  479. package/dist/cli/commands/sites/upload.d.ts.map +0 -1
  480. package/dist/cli/commands/sites/upload.js +0 -111
  481. package/dist/cli/commands/sites/upload.js.map +0 -1
  482. package/dist/cli/deploy.d.ts +0 -3
  483. package/dist/cli/deploy.d.ts.map +0 -1
  484. package/dist/cli/deploy.js +0 -25
  485. package/dist/cli/deploy.js.map +0 -1
  486. package/dist/cli/functions.d.ts +0 -3
  487. package/dist/cli/functions.d.ts.map +0 -1
  488. package/dist/cli/functions.js +0 -50
  489. package/dist/cli/functions.js.map +0 -1
  490. package/dist/cli/policies.d.ts +0 -3
  491. package/dist/cli/policies.d.ts.map +0 -1
  492. package/dist/cli/policies.js +0 -59
  493. package/dist/cli/policies.js.map +0 -1
  494. package/dist/cli/render.d.ts +0 -3
  495. package/dist/cli/render.d.ts.map +0 -1
  496. package/dist/cli/render.js +0 -99
  497. package/dist/cli/render.js.map +0 -1
  498. package/dist/cli/upload.d.ts +0 -3
  499. package/dist/cli/upload.d.ts.map +0 -1
  500. package/dist/cli/upload.js +0 -112
  501. package/dist/cli/upload.js.map +0 -1
  502. package/dist/functions/chunk-optimization/write-profile.d.ts +0 -8
  503. package/dist/functions/chunk-optimization/write-profile.d.ts.map +0 -1
  504. package/dist/functions/chunk-optimization/write-profile.js +0 -18
  505. package/dist/functions/chunk-optimization/write-profile.js.map +0 -1
  506. package/dist/functions/get-progress.d.ts +0 -32
  507. package/dist/functions/get-progress.d.ts.map +0 -1
  508. package/dist/functions/get-progress.js +0 -137
  509. package/dist/functions/get-progress.js.map +0 -1
  510. package/dist/functions/helpers/is-fatal-error.d.ts +0 -3
  511. package/dist/functions/helpers/is-fatal-error.d.ts.map +0 -1
  512. package/dist/functions/helpers/is-fatal-error.js +0 -8
  513. package/dist/functions/helpers/is-fatal-error.js.map +0 -1
  514. package/dist/items.d.ts +0 -2
  515. package/dist/items.d.ts.map +0 -1
  516. package/dist/items.js +0 -14
  517. package/dist/items.js.map +0 -1
  518. package/dist/run.d.ts +0 -2
  519. package/dist/run.d.ts.map +0 -1
  520. package/dist/run.js +0 -104
  521. package/dist/run.js.map +0 -1
  522. package/dist/shared/get-file-extension-from-codec.d.ts +0 -3
  523. package/dist/shared/get-file-extension-from-codec.d.ts.map +0 -1
  524. package/dist/shared/get-file-extension-from-codec.js +0 -33
  525. package/dist/shared/get-file-extension-from-codec.js.map +0 -1
  526. package/dist/shared/retry.d.ts +0 -1
  527. package/dist/shared/retry.d.ts.map +0 -1
  528. package/dist/shared/retry.js +0 -2
  529. package/dist/shared/retry.js.map +0 -1
  530. package/dist/shared/tmpdir.d.ts +0 -3
  531. package/dist/shared/tmpdir.d.ts.map +0 -1
  532. package/dist/shared/tmpdir.js +0 -23
  533. package/dist/shared/tmpdir.js.map +0 -1
  534. package/dist/shared/validate-region.d.ts +0 -1
  535. package/dist/shared/validate-region.d.ts.map +0 -1
  536. package/dist/shared/validate-region.js +0 -2
  537. package/dist/shared/validate-region.js.map +0 -1
@@ -3,31 +3,40 @@ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.getSites = void 0;
4
4
  const io_1 = require("../functions/helpers/io");
5
5
  const constants_1 = require("../shared/constants");
6
+ const get_account_id_1 = require("../shared/get-account-id");
7
+ const make_s3_url_1 = require("../shared/make-s3-url");
6
8
  const get_buckets_1 = require("./get-buckets");
9
+ // TODO: Return the `serveUrl` as well
7
10
  // TODO: Add JSDoc comments
8
- const getSites = async ({ region }) => {
11
+ const getSites = async ({ region, }) => {
9
12
  var _a;
10
- const { remotionBuckets } = await get_buckets_1.getRemotionS3Buckets(region);
13
+ const { remotionBuckets } = await (0, get_buckets_1.getRemotionS3Buckets)(region);
14
+ const accountId = await (0, get_account_id_1.getAccountId)({ region });
11
15
  const sites = {};
12
16
  for (const bucket of remotionBuckets) {
13
- const ls = await io_1.lambdaLs({
14
- bucketName: bucket.Name,
15
- prefix: constants_1.getSitesKey(''),
17
+ const ls = await (0, io_1.lambdaLs)({
18
+ bucketName: bucket.name,
19
+ prefix: (0, constants_1.getSitesKey)(''),
16
20
  region,
17
- expectedBucketOwner: null,
21
+ expectedBucketOwner: accountId,
18
22
  });
19
23
  for (const file of ls) {
20
- const siteKeyMatch = (_a = file.Key) === null || _a === void 0 ? void 0 : _a.match(/sites\/(.*)\/(.*)$/);
24
+ const siteKeyMatch = (_a = file.Key) === null || _a === void 0 ? void 0 : _a.match(/sites\/([0-9a-zA-Z]+)\/(.*)$/);
21
25
  if (!siteKeyMatch) {
22
- throw new Error(`An file was found in the bucket "${bucket.Name}" with the key ${file.Key} which is an unexpected folder structure. Delete this file.`);
26
+ throw new Error(`A file was found in the bucket "${bucket.name}" with the key ${file.Key} which is an unexpected folder structure. Delete this file.`);
23
27
  }
24
28
  const [, siteId] = siteKeyMatch;
25
29
  if (!sites[siteId]) {
26
30
  sites[siteId] = {
27
- size: 0,
28
- bucketName: bucket.Name,
31
+ sizeInBytes: 0,
32
+ bucketName: bucket.name,
29
33
  lastModified: null,
30
34
  id: siteId,
35
+ serveUrl: (0, make_s3_url_1.makeS3ServeUrl)({
36
+ bucketName: bucket.name,
37
+ region,
38
+ subFolder: (0, constants_1.getSitesKey)(siteId),
39
+ }),
31
40
  };
32
41
  }
33
42
  if (file.LastModified) {
@@ -38,7 +47,7 @@ const getSites = async ({ region }) => {
38
47
  }
39
48
  }
40
49
  if (file.Size) {
41
- sites[siteId].size += file.Size;
50
+ sites[siteId].sizeInBytes += file.Size;
42
51
  }
43
52
  }
44
53
  }
@@ -1 +1 @@
1
- {"version":3,"file":"get-sites.js","sourceRoot":"","sources":["../../src/api/get-sites.ts"],"names":[],"mappings":";;;AAAA,gDAAiD;AAEjD,mDAAgD;AAChD,+CAAmD;AASnD,2BAA2B;AACpB,MAAM,QAAQ,GAAG,KAAK,EAAE,EAAC,MAAM,EAAsB,EAAE,EAAE;;IAC/D,MAAM,EAAC,eAAe,EAAC,GAAG,MAAM,kCAAoB,CAAC,MAAM,CAAC,CAAC;IAE7D,MAAM,KAAK,GAA0B,EAAE,CAAC;IAExC,KAAK,MAAM,MAAM,IAAI,eAAe,EAAE;QACrC,MAAM,EAAE,GAAG,MAAM,aAAQ,CAAC;YACzB,UAAU,EAAE,MAAM,CAAC,IAAc;YACjC,MAAM,EAAE,uBAAW,CAAC,EAAE,CAAC;YACvB,MAAM;YACN,mBAAmB,EAAE,IAAI;SACzB,CAAC,CAAC;QAEH,KAAK,MAAM,IAAI,IAAI,EAAE,EAAE;YACtB,MAAM,YAAY,GAAG,MAAA,IAAI,CAAC,GAAG,0CAAE,KAAK,CAAC,oBAAoB,CAAC,CAAC;YAC3D,IAAI,CAAC,YAAY,EAAE;gBAClB,MAAM,IAAI,KAAK,CACd,oCAAoC,MAAM,CAAC,IAAI,kBAAkB,IAAI,CAAC,GAAG,6DAA6D,CACtI,CAAC;aACF;YAED,MAAM,CAAC,EAAE,MAAM,CAAC,GAAG,YAAY,CAAC;YAChC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE;gBACnB,KAAK,CAAC,MAAM,CAAC,GAAG;oBACf,IAAI,EAAE,CAAC;oBACP,UAAU,EAAE,MAAM,CAAC,IAAc;oBACjC,YAAY,EAAE,IAAI;oBAClB,EAAE,EAAE,MAAM;iBACV,CAAC;aACF;YAED,IAAI,IAAI,CAAC,YAAY,EAAE;gBACtB,MAAM,mBAAmB,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,YAAY,CAAC;gBACvD,IACC,mBAAmB,KAAK,IAAI;oBAC5B,IAAI,CAAC,YAAY,CAAC,OAAO,EAAE,GAAG,mBAAmB,EAChD;oBACD,KAAK,CAAC,MAAM,CAAC,CAAC,YAAY,GAAG,IAAI,CAAC,YAAY,CAAC,OAAO,EAAE,CAAC;iBACzD;aACD;YAED,IAAI,IAAI,CAAC,IAAI,EAAE;gBACd,KAAK,CAAC,MAAM,CAAC,CAAC,IAAI,IAAI,IAAI,CAAC,IAAI,CAAC;aAChC;SACD;KACD;IAED,MAAM,UAAU,GAAW,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE;QAC5D,OAAO,KAAK,CAAC,MAAM,CAAC,CAAC;IACtB,CAAC,CAAC,CAAC;IACH,OAAO,EAAC,KAAK,EAAE,UAAU,EAAE,OAAO,EAAE,eAAe,EAAC,CAAC;AACtD,CAAC,CAAC;AAnDW,QAAA,QAAQ,YAmDnB"}
1
+ {"version":3,"file":"get-sites.js","sourceRoot":"","sources":["../../src/api/get-sites.ts"],"names":[],"mappings":";;;AAAA,gDAAiD;AAEjD,mDAAgD;AAChD,6DAAsD;AACtD,uDAAqD;AACrD,+CAAuE;AAevE,sCAAsC;AACtC,2BAA2B;AACpB,MAAM,QAAQ,GAAG,KAAK,EAAE,EAC9B,MAAM,GAGN,EAAgC,EAAE;;IAClC,MAAM,EAAC,eAAe,EAAC,GAAG,MAAM,IAAA,kCAAoB,EAAC,MAAM,CAAC,CAAC;IAC7D,MAAM,SAAS,GAAG,MAAM,IAAA,6BAAY,EAAC,EAAC,MAAM,EAAC,CAAC,CAAC;IAE/C,MAAM,KAAK,GAA0B,EAAE,CAAC;IAExC,KAAK,MAAM,MAAM,IAAI,eAAe,EAAE;QACrC,MAAM,EAAE,GAAG,MAAM,IAAA,aAAQ,EAAC;YACzB,UAAU,EAAE,MAAM,CAAC,IAAI;YACvB,MAAM,EAAE,IAAA,uBAAW,EAAC,EAAE,CAAC;YACvB,MAAM;YACN,mBAAmB,EAAE,SAAS;SAC9B,CAAC,CAAC;QAEH,KAAK,MAAM,IAAI,IAAI,EAAE,EAAE;YACtB,MAAM,YAAY,GAAG,MAAA,IAAI,CAAC,GAAG,0CAAE,KAAK,CAAC,8BAA8B,CAAC,CAAC;YACrE,IAAI,CAAC,YAAY,EAAE;gBAClB,MAAM,IAAI,KAAK,CACd,mCAAmC,MAAM,CAAC,IAAI,kBAAkB,IAAI,CAAC,GAAG,6DAA6D,CACrI,CAAC;aACF;YAED,MAAM,CAAC,EAAE,MAAM,CAAC,GAAG,YAAY,CAAC;YAChC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE;gBACnB,KAAK,CAAC,MAAM,CAAC,GAAG;oBACf,WAAW,EAAE,CAAC;oBACd,UAAU,EAAE,MAAM,CAAC,IAAI;oBACvB,YAAY,EAAE,IAAI;oBAClB,EAAE,EAAE,MAAM;oBACV,QAAQ,EAAE,IAAA,4BAAc,EAAC;wBACxB,UAAU,EAAE,MAAM,CAAC,IAAI;wBACvB,MAAM;wBACN,SAAS,EAAE,IAAA,uBAAW,EAAC,MAAM,CAAC;qBAC9B,CAAC;iBACF,CAAC;aACF;YAED,IAAI,IAAI,CAAC,YAAY,EAAE;gBACtB,MAAM,mBAAmB,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,YAAY,CAAC;gBACvD,IACC,mBAAmB,KAAK,IAAI;oBAC5B,IAAI,CAAC,YAAY,CAAC,OAAO,EAAE,GAAG,mBAAmB,EAChD;oBACD,KAAK,CAAC,MAAM,CAAC,CAAC,YAAY,GAAG,IAAI,CAAC,YAAY,CAAC,OAAO,EAAE,CAAC;iBACzD;aACD;YAED,IAAI,IAAI,CAAC,IAAI,EAAE;gBACd,KAAK,CAAC,MAAM,CAAC,CAAC,WAAW,IAAI,IAAI,CAAC,IAAI,CAAC;aACvC;SACD;KACD;IAED,MAAM,UAAU,GAAW,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE;QAC5D,OAAO,KAAK,CAAC,MAAM,CAAC,CAAC;IACtB,CAAC,CAAC,CAAC;IACH,OAAO,EAAC,KAAK,EAAE,UAAU,EAAE,OAAO,EAAE,eAAe,EAAC,CAAC;AACtD,CAAC,CAAC;AA7DW,QAAA,QAAQ,YA6DnB"}
@@ -1,6 +1,6 @@
1
- import { iam, lambda, s3 } from 'aws-policies';
1
+ import { iam, lambda, logs, s3 } from 'aws-policies';
2
2
  export declare const rolePermissions: {
3
- actions: (s3 | iam | lambda)[];
3
+ actions: (s3 | iam | lambda | logs)[];
4
4
  resource: string[];
5
5
  }[];
6
6
  //# sourceMappingURL=role-permissions.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"role-permissions.d.ts","sourceRoot":"","sources":["../../../src/api/iam-validation/role-permissions.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,GAAG,EAAE,MAAM,EAAE,EAAE,EAAC,MAAM,cAAc,CAAC;AAG7C,eAAO,MAAM,eAAe,EAAE;IAC7B,OAAO,EAAE,CAAC,EAAE,GAAG,GAAG,GAAG,MAAM,CAAC,EAAE,CAAC;IAC/B,QAAQ,EAAE,MAAM,EAAE,CAAC;CACnB,EAuBA,CAAC"}
1
+ {"version":3,"file":"role-permissions.d.ts","sourceRoot":"","sources":["../../../src/api/iam-validation/role-permissions.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,GAAG,EAAE,MAAM,EAAE,IAAI,EAAE,EAAE,EAAC,MAAM,cAAc,CAAC;AAOnD,eAAO,MAAM,eAAe,EAAE;IAC7B,OAAO,EAAE,CAAC,EAAE,GAAG,GAAG,GAAG,MAAM,GAAG,IAAI,CAAC,EAAE,CAAC;IACtC,QAAQ,EAAE,MAAM,EAAE,CAAC;CACnB,EA4BA,CAAC"}
@@ -8,12 +8,11 @@ exports.rolePermissions = [
8
8
  actions: [aws_policies_1.s3.ListAllMyBuckets],
9
9
  resource: ['*'],
10
10
  },
11
- {
12
- actions: [aws_policies_1.s3.CreateBucket, aws_policies_1.s3.ListBucket, aws_policies_1.s3.PutBucketAcl],
13
- resource: [`arn:aws:s3:::*`],
14
- },
15
11
  {
16
12
  actions: [
13
+ aws_policies_1.s3.CreateBucket,
14
+ aws_policies_1.s3.ListBucket,
15
+ aws_policies_1.s3.PutBucketAcl,
17
16
  aws_policies_1.s3.GetObject,
18
17
  aws_policies_1.s3.DeleteObject,
19
18
  aws_policies_1.s3.PutObjectAcl,
@@ -26,5 +25,11 @@ exports.rolePermissions = [
26
25
  actions: [aws_policies_1.lambda.InvokeFunction],
27
26
  resource: [`arn:aws:lambda:*:*:function:${constants_1.RENDER_FN_PREFIX}*`],
28
27
  },
28
+ {
29
+ actions: [aws_policies_1.logs.CreateLogStream, aws_policies_1.logs.PutLogEvents],
30
+ resource: [
31
+ `arn:aws:logs:*:*:log-group:${constants_1.LOG_GROUP_PREFIX}${constants_1.RENDER_FN_PREFIX}*`,
32
+ ],
33
+ },
29
34
  ];
30
35
  //# sourceMappingURL=role-permissions.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"role-permissions.js","sourceRoot":"","sources":["../../../src/api/iam-validation/role-permissions.ts"],"names":[],"mappings":";;;AAAA,+CAA6C;AAC7C,sDAAgF;AAEnE,QAAA,eAAe,GAGtB;IACL;QACC,OAAO,EAAE,CAAC,iBAAE,CAAC,gBAAgB,CAAC;QAC9B,QAAQ,EAAE,CAAC,GAAG,CAAC;KACf;IACD;QACC,OAAO,EAAE,CAAC,iBAAE,CAAC,YAAY,EAAE,iBAAE,CAAC,UAAU,EAAE,iBAAE,CAAC,YAAY,CAAC;QAC1D,QAAQ,EAAE,CAAC,gBAAgB,CAAC;KAC5B;IACD;QACC,OAAO,EAAE;YACR,iBAAE,CAAC,SAAS;YACZ,iBAAE,CAAC,YAAY;YACf,iBAAE,CAAC,YAAY;YACf,iBAAE,CAAC,SAAS;YACZ,iBAAE,CAAC,iBAAiB;SACpB;QACD,QAAQ,EAAE,CAAC,gBAAgB,kCAAsB,GAAG,CAAC;KACrD;IACD;QACC,OAAO,EAAE,CAAC,qBAAM,CAAC,cAAc,CAAC;QAChC,QAAQ,EAAE,CAAC,+BAA+B,4BAAgB,GAAG,CAAC;KAC9D;CACD,CAAC"}
1
+ {"version":3,"file":"role-permissions.js","sourceRoot":"","sources":["../../../src/api/iam-validation/role-permissions.ts"],"names":[],"mappings":";;;AAAA,+CAAmD;AACnD,sDAIgC;AAEnB,QAAA,eAAe,GAGtB;IACL;QACC,OAAO,EAAE,CAAC,iBAAE,CAAC,gBAAgB,CAAC;QAC9B,QAAQ,EAAE,CAAC,GAAG,CAAC;KACf;IACD;QACC,OAAO,EAAE;YACR,iBAAE,CAAC,YAAY;YACf,iBAAE,CAAC,UAAU;YACb,iBAAE,CAAC,YAAY;YACf,iBAAE,CAAC,SAAS;YACZ,iBAAE,CAAC,YAAY;YACf,iBAAE,CAAC,YAAY;YACf,iBAAE,CAAC,SAAS;YACZ,iBAAE,CAAC,iBAAiB;SACpB;QACD,QAAQ,EAAE,CAAC,gBAAgB,kCAAsB,GAAG,CAAC;KACrD;IACD;QACC,OAAO,EAAE,CAAC,qBAAM,CAAC,cAAc,CAAC;QAChC,QAAQ,EAAE,CAAC,+BAA+B,4BAAgB,GAAG,CAAC;KAC9D;IACD;QACC,OAAO,EAAE,CAAC,mBAAI,CAAC,eAAe,EAAE,mBAAI,CAAC,YAAY,CAAC;QAClD,QAAQ,EAAE;YACT,8BAA8B,4BAAgB,GAAG,4BAAgB,GAAG;SACpE;KACD;CACD,CAAC"}
@@ -9,5 +9,6 @@ export declare const simulateRule: (options: {
9
9
  actionNames: string[];
10
10
  arn: string;
11
11
  resource: string[];
12
+ retries: number;
12
13
  }) => Promise<SimulationResult[]>;
13
14
  //# sourceMappingURL=simulate-rule.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"simulate-rule.d.ts","sourceRoot":"","sources":["../../../src/api/iam-validation/simulate-rule.ts"],"names":[],"mappings":"AAKA,OAAO,EAAC,SAAS,EAAC,MAAM,2BAA2B,CAAC;AAGpD,oBAAY,YAAY,GAAG,SAAS,GAAG,cAAc,GAAG,cAAc,CAAC;AAEvE,oBAAY,gBAAgB,GAAG;IAC9B,QAAQ,EAAE,YAAY,CAAC;IACvB,IAAI,EAAE,MAAM,CAAC;CACb,CAAC;AAEF,eAAO,MAAM,YAAY,YAAmB;IAC3C,MAAM,EAAE,SAAS,CAAC;IAClB,WAAW,EAAE,MAAM,EAAE,CAAC;IACtB,GAAG,EAAE,MAAM,CAAC;IACZ,QAAQ,EAAE,MAAM,EAAE,CAAC;CACnB,KAAG,QAAQ,gBAAgB,EAAE,CAoC7B,CAAC"}
1
+ {"version":3,"file":"simulate-rule.d.ts","sourceRoot":"","sources":["../../../src/api/iam-validation/simulate-rule.ts"],"names":[],"mappings":"AAKA,OAAO,EAAC,SAAS,EAAC,MAAM,2BAA2B,CAAC;AAGpD,oBAAY,YAAY,GAAG,SAAS,GAAG,cAAc,GAAG,cAAc,CAAC;AAEvE,oBAAY,gBAAgB,GAAG;IAC9B,QAAQ,EAAE,YAAY,CAAC;IACvB,IAAI,EAAE,MAAM,CAAC;CACb,CAAC;AAEF,eAAO,MAAM,YAAY,YAAmB;IAC3C,MAAM,EAAE,SAAS,CAAC;IAClB,WAAW,EAAE,MAAM,EAAE,CAAC;IACtB,GAAG,EAAE,MAAM,CAAC;IACZ,QAAQ,EAAE,MAAM,EAAE,CAAC;IACnB,OAAO,EAAE,MAAM,CAAC;CAChB,KAAG,QAAQ,gBAAgB,EAAE,CAiD7B,CAAC"}
@@ -6,38 +6,51 @@ const aws_policies_1 = require("aws-policies");
6
6
  const aws_clients_1 = require("../../shared/aws-clients");
7
7
  const simulateRule = async (options) => {
8
8
  var _a;
9
- if (options.actionNames.includes(aws_policies_1.iam.GetUser)) {
10
- try {
11
- await aws_clients_1.getIamClient(options.region).send(new client_iam_1.GetUserCommand({}));
12
- const result = [
13
- {
14
- decision: 'allowed',
15
- name: aws_policies_1.iam.GetUser,
16
- },
17
- ];
18
- return result;
9
+ try {
10
+ if (options.actionNames.includes(aws_policies_1.iam.GetUser)) {
11
+ try {
12
+ await (0, aws_clients_1.getIamClient)(options.region).send(new client_iam_1.GetUserCommand({}));
13
+ const result = [
14
+ {
15
+ decision: 'allowed',
16
+ name: aws_policies_1.iam.GetUser,
17
+ },
18
+ ];
19
+ return result;
20
+ }
21
+ catch (err) {
22
+ const result = [
23
+ {
24
+ decision: 'explicitDeny',
25
+ name: aws_policies_1.iam.GetUser,
26
+ },
27
+ ];
28
+ return result;
29
+ }
19
30
  }
20
- catch (err) {
21
- const result = [
22
- {
23
- decision: 'explicitDeny',
24
- name: aws_policies_1.iam.GetUser,
25
- },
26
- ];
27
- return result;
31
+ const res = await (0, aws_clients_1.getIamClient)(options.region).send(new client_iam_1.SimulatePrincipalPolicyCommand({
32
+ ActionNames: options.actionNames,
33
+ PolicySourceArn: options.arn,
34
+ ResourceArns: options.resource,
35
+ }));
36
+ return ((_a = res.EvaluationResults) !== null && _a !== void 0 ? _a : []).map((pol) => {
37
+ return {
38
+ decision: pol.EvalDecision,
39
+ name: pol.EvalActionName,
40
+ };
41
+ });
42
+ }
43
+ catch (err) {
44
+ // Sometimes the AWS Rate limit hits. In that case we retry up to two times
45
+ // after waiting for 2 seconds.
46
+ if (options.retries <= 0) {
47
+ throw err;
28
48
  }
49
+ await new Promise((resolve) => {
50
+ setTimeout(() => resolve, 2000);
51
+ });
52
+ return (0, exports.simulateRule)({ ...options, retries: options.retries - 1 });
29
53
  }
30
- const res = await aws_clients_1.getIamClient(options.region).send(new client_iam_1.SimulatePrincipalPolicyCommand({
31
- ActionNames: options.actionNames,
32
- PolicySourceArn: options.arn,
33
- ResourceArns: options.resource,
34
- }));
35
- return ((_a = res.EvaluationResults) !== null && _a !== void 0 ? _a : []).map((pol) => {
36
- return {
37
- decision: pol.EvalDecision,
38
- name: pol.EvalActionName,
39
- };
40
- });
41
54
  };
42
55
  exports.simulateRule = simulateRule;
43
56
  //# sourceMappingURL=simulate-rule.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"simulate-rule.js","sourceRoot":"","sources":["../../../src/api/iam-validation/simulate-rule.ts"],"names":[],"mappings":";;;AAAA,oDAG6B;AAC7B,+CAAiC;AAEjC,0DAAsD;AAS/C,MAAM,YAAY,GAAG,KAAK,EAAE,OAKlC,EAA+B,EAAE;;IACjC,IAAI,OAAO,CAAC,WAAW,CAAC,QAAQ,CAAC,kBAAG,CAAC,OAAO,CAAC,EAAE;QAC9C,IAAI;YACH,MAAM,0BAAY,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,IAAI,2BAAc,CAAC,EAAE,CAAC,CAAC,CAAC;YAChE,MAAM,MAAM,GAAuB;gBAClC;oBACC,QAAQ,EAAE,SAAS;oBACnB,IAAI,EAAE,kBAAG,CAAC,OAAO;iBACjB;aACD,CAAC;YACF,OAAO,MAAM,CAAC;SACd;QAAC,OAAO,GAAG,EAAE;YACb,MAAM,MAAM,GAAuB;gBAClC;oBACC,QAAQ,EAAE,cAAc;oBACxB,IAAI,EAAE,kBAAG,CAAC,OAAO;iBACjB;aACD,CAAC;YACF,OAAO,MAAM,CAAC;SACd;KACD;IAED,MAAM,GAAG,GAAG,MAAM,0BAAY,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,IAAI,CAClD,IAAI,2CAA8B,CAAC;QAClC,WAAW,EAAE,OAAO,CAAC,WAAW;QAChC,eAAe,EAAE,OAAO,CAAC,GAAG;QAC5B,YAAY,EAAE,OAAO,CAAC,QAAQ;KAC9B,CAAC,CACF,CAAC;IAEF,OAAO,CAAC,MAAA,GAAG,CAAC,iBAAiB,mCAAI,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,EAAoB,EAAE;QAClE,OAAO;YACN,QAAQ,EAAE,GAAG,CAAC,YAA4B;YAC1C,IAAI,EAAE,GAAG,CAAC,cAAwB;SAClC,CAAC;IACH,CAAC,CAAC,CAAC;AACJ,CAAC,CAAC;AAzCW,QAAA,YAAY,gBAyCvB"}
1
+ {"version":3,"file":"simulate-rule.js","sourceRoot":"","sources":["../../../src/api/iam-validation/simulate-rule.ts"],"names":[],"mappings":";;;AAAA,oDAG6B;AAC7B,+CAAiC;AAEjC,0DAAsD;AAS/C,MAAM,YAAY,GAAG,KAAK,EAAE,OAMlC,EAA+B,EAAE;;IACjC,IAAI;QACH,IAAI,OAAO,CAAC,WAAW,CAAC,QAAQ,CAAC,kBAAG,CAAC,OAAO,CAAC,EAAE;YAC9C,IAAI;gBACH,MAAM,IAAA,0BAAY,EAAC,OAAO,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,IAAI,2BAAc,CAAC,EAAE,CAAC,CAAC,CAAC;gBAChE,MAAM,MAAM,GAAuB;oBAClC;wBACC,QAAQ,EAAE,SAAS;wBACnB,IAAI,EAAE,kBAAG,CAAC,OAAO;qBACjB;iBACD,CAAC;gBACF,OAAO,MAAM,CAAC;aACd;YAAC,OAAO,GAAG,EAAE;gBACb,MAAM,MAAM,GAAuB;oBAClC;wBACC,QAAQ,EAAE,cAAc;wBACxB,IAAI,EAAE,kBAAG,CAAC,OAAO;qBACjB;iBACD,CAAC;gBACF,OAAO,MAAM,CAAC;aACd;SACD;QAED,MAAM,GAAG,GAAG,MAAM,IAAA,0BAAY,EAAC,OAAO,CAAC,MAAM,CAAC,CAAC,IAAI,CAClD,IAAI,2CAA8B,CAAC;YAClC,WAAW,EAAE,OAAO,CAAC,WAAW;YAChC,eAAe,EAAE,OAAO,CAAC,GAAG;YAC5B,YAAY,EAAE,OAAO,CAAC,QAAQ;SAC9B,CAAC,CACF,CAAC;QAEF,OAAO,CAAC,MAAA,GAAG,CAAC,iBAAiB,mCAAI,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,EAAoB,EAAE;YAClE,OAAO;gBACN,QAAQ,EAAE,GAAG,CAAC,YAA4B;gBAC1C,IAAI,EAAE,GAAG,CAAC,cAAwB;aAClC,CAAC;QACH,CAAC,CAAC,CAAC;KACH;IAAC,OAAO,GAAG,EAAE;QACb,2EAA2E;QAC3E,+BAA+B;QAC/B,IAAI,OAAO,CAAC,OAAO,IAAI,CAAC,EAAE;YACzB,MAAM,GAAG,CAAC;SACV;QAED,MAAM,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE;YAC7B,UAAU,CAAC,GAAG,EAAE,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;QACjC,CAAC,CAAC,CAAC;QACH,OAAO,IAAA,oBAAY,EAAC,EAAC,GAAG,OAAO,EAAE,OAAO,EAAE,OAAO,CAAC,OAAO,GAAG,CAAC,EAAC,CAAC,CAAC;KAChE;AACF,CAAC,CAAC;AAvDW,QAAA,YAAY,gBAuDvB"}
@@ -1,6 +1,6 @@
1
1
  import { AwsRegion } from '../../pricing/aws-regions';
2
2
  import { SimulationResult } from './simulate-rule';
3
- export declare const logPermissionOutput: (output: SimulationResult) => void;
3
+ export declare const logPermissionOutput: (output: SimulationResult) => string;
4
4
  export declare const simulatePermissions: (options: {
5
5
  region: AwsRegion;
6
6
  onSimulation?: ((result: SimulationResult) => void) | undefined;
@@ -1 +1 @@
1
- {"version":3,"file":"simulate.d.ts","sourceRoot":"","sources":["../../../src/api/iam-validation/simulate.ts"],"names":[],"mappings":"AAEA,OAAO,EAAC,SAAS,EAAC,MAAM,2BAA2B,CAAC;AAGpD,OAAO,EAA6B,gBAAgB,EAAC,MAAM,iBAAiB,CAAC;AAW7E,eAAO,MAAM,mBAAmB,WAAY,gBAAgB,SAE3D,CAAC;AAEF,eAAO,MAAM,mBAAmB;YACvB,SAAS;6BACO,gBAAgB,KAAK,IAAI;;aAExC,gBAAgB,EAAE;EAwB3B,CAAC"}
1
+ {"version":3,"file":"simulate.d.ts","sourceRoot":"","sources":["../../../src/api/iam-validation/simulate.ts"],"names":[],"mappings":"AACA,OAAO,EAAC,SAAS,EAAC,MAAM,2BAA2B,CAAC;AAEpD,OAAO,EAA6B,gBAAgB,EAAC,MAAM,iBAAiB,CAAC;AAY7E,eAAO,MAAM,mBAAmB,WAAY,gBAAgB,WAE3D,CAAC;AAEF,eAAO,MAAM,mBAAmB;YACvB,SAAS;6BACO,gBAAgB,KAAK,IAAI;;aAExC,gBAAgB,EAAE;EAyB3B,CAAC"}
@@ -2,10 +2,9 @@
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.simulatePermissions = exports.logPermissionOutput = void 0;
4
4
  const client_iam_1 = require("@aws-sdk/client-iam");
5
- const log_1 = require("../../cli/log");
6
5
  const aws_clients_1 = require("../../shared/aws-clients");
7
- const required_permissions_1 = require("./required-permissions");
8
6
  const simulate_rule_1 = require("./simulate-rule");
7
+ const user_permissions_1 = require("./user-permissions");
9
8
  const getEmojiForStatus = (decision) => {
10
9
  switch (decision) {
11
10
  case 'allowed':
@@ -15,22 +14,23 @@ const getEmojiForStatus = (decision) => {
15
14
  }
16
15
  };
17
16
  const logPermissionOutput = (output) => {
18
- log_1.Log.info([getEmojiForStatus(output.decision), output.name].join(' '));
17
+ return [getEmojiForStatus(output.decision), output.name].join(' ');
19
18
  };
20
19
  exports.logPermissionOutput = logPermissionOutput;
21
20
  const simulatePermissions = async (options) => {
22
21
  var _a;
23
- const user = await aws_clients_1.getIamClient(options.region).send(new client_iam_1.GetUserCommand({}));
22
+ const user = await (0, aws_clients_1.getIamClient)(options.region).send(new client_iam_1.GetUserCommand({}));
24
23
  if (!user || !user.User) {
25
24
  throw new Error('No valid AWS user detected');
26
25
  }
27
26
  const results = [];
28
- for (const per of required_permissions_1.requiredPermissions) {
29
- const result = await simulate_rule_1.simulateRule({
27
+ for (const per of user_permissions_1.requiredPermissions) {
28
+ const result = await (0, simulate_rule_1.simulateRule)({
30
29
  actionNames: per.actions,
31
30
  arn: user.User.Arn,
32
31
  region: options.region,
33
32
  resource: per.resource,
33
+ retries: 2,
34
34
  });
35
35
  for (const res of result) {
36
36
  results.push(res);
@@ -1 +1 @@
1
- {"version":3,"file":"simulate.js","sourceRoot":"","sources":["../../../src/api/iam-validation/simulate.ts"],"names":[],"mappings":";;;AAAA,oDAAmD;AACnD,uCAAkC;AAElC,0DAAsD;AACtD,iEAA2D;AAC3D,mDAA6E;AAE7E,MAAM,iBAAiB,GAAG,CAAC,QAAsB,EAAE,EAAE;IACpD,QAAQ,QAAQ,EAAE;QACjB,KAAK,SAAS;YACb,OAAO,GAAG,CAAC;QACZ;YACC,OAAO,GAAG,CAAC;KACZ;AACF,CAAC,CAAC;AAEK,MAAM,mBAAmB,GAAG,CAAC,MAAwB,EAAE,EAAE;IAC/D,SAAG,CAAC,IAAI,CAAC,CAAC,iBAAiB,CAAC,MAAM,CAAC,QAAQ,CAAC,EAAE,MAAM,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC;AACvE,CAAC,CAAC;AAFW,QAAA,mBAAmB,uBAE9B;AAEK,MAAM,mBAAmB,GAAG,KAAK,EAAE,OAGzC,EAEE,EAAE;;IACJ,MAAM,IAAI,GAAG,MAAM,0BAAY,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,IAAI,2BAAc,CAAC,EAAE,CAAC,CAAC,CAAC;IAE7E,IAAI,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE;QACxB,MAAM,IAAI,KAAK,CAAC,4BAA4B,CAAC,CAAC;KAC9C;IAED,MAAM,OAAO,GAAuB,EAAE,CAAC;IAEvC,KAAK,MAAM,GAAG,IAAI,0CAAmB,EAAE;QACtC,MAAM,MAAM,GAAG,MAAM,4BAAY,CAAC;YACjC,WAAW,EAAE,GAAG,CAAC,OAAO;YACxB,GAAG,EAAE,IAAI,CAAC,IAAI,CAAC,GAAa;YAC5B,MAAM,EAAE,OAAO,CAAC,MAAM;YACtB,QAAQ,EAAE,GAAG,CAAC,QAAQ;SACtB,CAAC,CAAC;QACH,KAAK,MAAM,GAAG,IAAI,MAAM,EAAE;YACzB,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YAClB,MAAA,OAAO,CAAC,YAAY,+CAApB,OAAO,EAAgB,GAAG,CAAC,CAAC;SAC5B;KACD;IAED,OAAO,EAAC,OAAO,EAAC,CAAC;AAClB,CAAC,CAAC;AA5BW,QAAA,mBAAmB,uBA4B9B"}
1
+ {"version":3,"file":"simulate.js","sourceRoot":"","sources":["../../../src/api/iam-validation/simulate.ts"],"names":[],"mappings":";;;AAAA,oDAAmD;AAEnD,0DAAsD;AACtD,mDAA6E;AAC7E,yDAAuD;AAEvD,MAAM,iBAAiB,GAAG,CAAC,QAAsB,EAAE,EAAE;IACpD,QAAQ,QAAQ,EAAE;QACjB,KAAK,SAAS;YACb,OAAO,GAAG,CAAC;QACZ;YACC,OAAO,GAAG,CAAC;KACZ;AACF,CAAC,CAAC;AAEK,MAAM,mBAAmB,GAAG,CAAC,MAAwB,EAAE,EAAE;IAC/D,OAAO,CAAC,iBAAiB,CAAC,MAAM,CAAC,QAAQ,CAAC,EAAE,MAAM,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;AACpE,CAAC,CAAC;AAFW,QAAA,mBAAmB,uBAE9B;AAEK,MAAM,mBAAmB,GAAG,KAAK,EAAE,OAGzC,EAEE,EAAE;;IACJ,MAAM,IAAI,GAAG,MAAM,IAAA,0BAAY,EAAC,OAAO,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,IAAI,2BAAc,CAAC,EAAE,CAAC,CAAC,CAAC;IAE7E,IAAI,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE;QACxB,MAAM,IAAI,KAAK,CAAC,4BAA4B,CAAC,CAAC;KAC9C;IAED,MAAM,OAAO,GAAuB,EAAE,CAAC;IAEvC,KAAK,MAAM,GAAG,IAAI,sCAAmB,EAAE;QACtC,MAAM,MAAM,GAAG,MAAM,IAAA,4BAAY,EAAC;YACjC,WAAW,EAAE,GAAG,CAAC,OAAO;YACxB,GAAG,EAAE,IAAI,CAAC,IAAI,CAAC,GAAa;YAC5B,MAAM,EAAE,OAAO,CAAC,MAAM;YACtB,QAAQ,EAAE,GAAG,CAAC,QAAQ;YACtB,OAAO,EAAE,CAAC;SACV,CAAC,CAAC;QACH,KAAK,MAAM,GAAG,IAAI,MAAM,EAAE;YACzB,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YAClB,MAAA,OAAO,CAAC,YAAY,+CAApB,OAAO,EAAgB,GAAG,CAAC,CAAC;SAC5B;KACD;IAED,OAAO,EAAC,OAAO,EAAC,CAAC;AAClB,CAAC,CAAC;AA7BW,QAAA,mBAAmB,uBA6B9B"}
@@ -1,11 +1,12 @@
1
1
  /**
2
2
  * @description Returns an inline JSON policy to be assigned to the AWS user whose credentials are being used for excuting CLI commands or calling Node.JS functions.
3
- * @link https://remotion.dev/docs/lambda/getuserpolicy
3
+ * @link https://remotion-lambda-alpha.netlify.app/docs/lambda/getuserpolicy
4
4
  */
5
5
  export declare const getUserPolicy: () => string;
6
+ export declare const ROLE_NAME = "remotion-lambda-role";
6
7
  /**
7
8
  * @description Returns an inline JSON policy to be assigned to the 'remotion-lambda-role' role that needs to be created in your AWS account.
8
- * @link https://remotion.dev/docs/lambda/getrolepolicy
9
+ * @link https://remotion-lambda-alpha.netlify.app/docs/lambda/getrolepolicy
9
10
  */
10
11
  export declare const getRolePolicy: () => string;
11
12
  //# sourceMappingURL=suggested-policy.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"suggested-policy.d.ts","sourceRoot":"","sources":["../../../src/api/iam-validation/suggested-policy.ts"],"names":[],"mappings":"AA+BA;;;GAGG;AAEH,eAAO,MAAM,aAAa,cAAiD,CAAC;AAE5E;;;GAGG;AACH,eAAO,MAAM,aAAa,cAAqD,CAAC"}
1
+ {"version":3,"file":"suggested-policy.d.ts","sourceRoot":"","sources":["../../../src/api/iam-validation/suggested-policy.ts"],"names":[],"mappings":"AA+BA;;;GAGG;AAEH,eAAO,MAAM,aAAa,cAAiD,CAAC;AAE5E,eAAO,MAAM,SAAS,yBAAyB,CAAC;AAEhD;;;GAGG;AACH,eAAO,MAAM,aAAa,cAAqD,CAAC"}
@@ -1,14 +1,14 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.getRolePolicy = exports.getUserPolicy = void 0;
4
- const required_permissions_1 = require("./required-permissions");
3
+ exports.getRolePolicy = exports.ROLE_NAME = exports.getUserPolicy = void 0;
5
4
  const role_permissions_1 = require("./role-permissions");
5
+ const user_permissions_1 = require("./user-permissions");
6
6
  const suggestedPolicy = {
7
7
  Version: '2012-10-17',
8
8
  Statement: [
9
- ...required_permissions_1.requiredPermissions.map((per, i) => {
9
+ ...user_permissions_1.requiredPermissions.map((per) => {
10
10
  return {
11
- Sid: String(i),
11
+ Sid: per.id,
12
12
  Effect: 'Allow',
13
13
  Action: per.actions,
14
14
  Resource: per.resource,
@@ -31,13 +31,14 @@ const suggestedRolePolicy = {
31
31
  };
32
32
  /**
33
33
  * @description Returns an inline JSON policy to be assigned to the AWS user whose credentials are being used for excuting CLI commands or calling Node.JS functions.
34
- * @link https://remotion.dev/docs/lambda/getuserpolicy
34
+ * @link https://remotion-lambda-alpha.netlify.app/docs/lambda/getuserpolicy
35
35
  */
36
36
  const getUserPolicy = () => JSON.stringify(suggestedPolicy, null, 2);
37
37
  exports.getUserPolicy = getUserPolicy;
38
+ exports.ROLE_NAME = 'remotion-lambda-role';
38
39
  /**
39
40
  * @description Returns an inline JSON policy to be assigned to the 'remotion-lambda-role' role that needs to be created in your AWS account.
40
- * @link https://remotion.dev/docs/lambda/getrolepolicy
41
+ * @link https://remotion-lambda-alpha.netlify.app/docs/lambda/getrolepolicy
41
42
  */
42
43
  const getRolePolicy = () => JSON.stringify(suggestedRolePolicy, null, 2);
43
44
  exports.getRolePolicy = getRolePolicy;
@@ -1 +1 @@
1
- {"version":3,"file":"suggested-policy.js","sourceRoot":"","sources":["../../../src/api/iam-validation/suggested-policy.ts"],"names":[],"mappings":";;;AAAA,iEAA2D;AAC3D,yDAAmD;AAEnD,MAAM,eAAe,GAAG;IACvB,OAAO,EAAE,YAAY;IACrB,SAAS,EAAE;QACV,GAAG,0CAAmB,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,CAAC,EAAE,EAAE;YACrC,OAAO;gBACN,GAAG,EAAE,MAAM,CAAC,CAAC,CAAC;gBACd,MAAM,EAAE,OAAO;gBACf,MAAM,EAAE,GAAG,CAAC,OAAO;gBACnB,QAAQ,EAAE,GAAG,CAAC,QAAQ;aACtB,CAAC;QACH,CAAC,CAAC;KACF;CACD,CAAC;AAEF,MAAM,mBAAmB,GAAG;IAC3B,OAAO,EAAE,YAAY;IACrB,SAAS,EAAE;QACV,GAAG,kCAAe,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,CAAC,EAAE,EAAE;YACjC,OAAO;gBACN,GAAG,EAAE,MAAM,CAAC,CAAC,CAAC;gBACd,MAAM,EAAE,OAAO;gBACf,MAAM,EAAE,GAAG,CAAC,OAAO;gBACnB,QAAQ,EAAE,GAAG,CAAC,QAAQ;aACtB,CAAC;QACH,CAAC,CAAC;KACF;CACD,CAAC;AAEF;;;GAGG;AAEI,MAAM,aAAa,GAAG,GAAG,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,eAAe,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC;AAA/D,QAAA,aAAa,iBAAkD;AAE5E;;;GAGG;AACI,MAAM,aAAa,GAAG,GAAG,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,mBAAmB,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC;AAAnE,QAAA,aAAa,iBAAsD"}
1
+ {"version":3,"file":"suggested-policy.js","sourceRoot":"","sources":["../../../src/api/iam-validation/suggested-policy.ts"],"names":[],"mappings":";;;AAAA,yDAAmD;AACnD,yDAAuD;AAEvD,MAAM,eAAe,GAAG;IACvB,OAAO,EAAE,YAAY;IACrB,SAAS,EAAE;QACV,GAAG,sCAAmB,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE;YAClC,OAAO;gBACN,GAAG,EAAE,GAAG,CAAC,EAAE;gBACX,MAAM,EAAE,OAAO;gBACf,MAAM,EAAE,GAAG,CAAC,OAAO;gBACnB,QAAQ,EAAE,GAAG,CAAC,QAAQ;aACtB,CAAC;QACH,CAAC,CAAC;KACF;CACD,CAAC;AAEF,MAAM,mBAAmB,GAAG;IAC3B,OAAO,EAAE,YAAY;IACrB,SAAS,EAAE;QACV,GAAG,kCAAe,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,CAAC,EAAE,EAAE;YACjC,OAAO;gBACN,GAAG,EAAE,MAAM,CAAC,CAAC,CAAC;gBACd,MAAM,EAAE,OAAO;gBACf,MAAM,EAAE,GAAG,CAAC,OAAO;gBACnB,QAAQ,EAAE,GAAG,CAAC,QAAQ;aACtB,CAAC;QACH,CAAC,CAAC;KACF;CACD,CAAC;AAEF;;;GAGG;AAEI,MAAM,aAAa,GAAG,GAAG,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,eAAe,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC;AAA/D,QAAA,aAAa,iBAAkD;AAE/D,QAAA,SAAS,GAAG,sBAAsB,CAAC;AAEhD;;;GAGG;AACI,MAAM,aAAa,GAAG,GAAG,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,mBAAmB,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC;AAAnE,QAAA,aAAa,iBAAsD"}
@@ -0,0 +1,7 @@
1
+ import { iam, lambda, logs, s3 } from 'aws-policies';
2
+ export declare const requiredPermissions: {
3
+ actions: (s3 | iam | lambda | logs)[];
4
+ resource: string[];
5
+ id: string;
6
+ }[];
7
+ //# sourceMappingURL=user-permissions.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"user-permissions.d.ts","sourceRoot":"","sources":["../../../src/api/iam-validation/user-permissions.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,GAAG,EAAE,MAAM,EAAE,IAAI,EAAE,EAAE,EAAC,MAAM,cAAc,CAAC;AAQnD,eAAO,MAAM,mBAAmB,EAAE;IACjC,OAAO,EAAE,CAAC,EAAE,GAAG,GAAG,GAAG,MAAM,GAAG,IAAI,CAAC,EAAE,CAAC;IACtC,QAAQ,EAAE,MAAM,EAAE,CAAC;IACnB,EAAE,EAAE,MAAM,CAAC;CACX,EAmEA,CAAC"}
@@ -3,56 +3,73 @@ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.requiredPermissions = void 0;
4
4
  const aws_policies_1 = require("aws-policies");
5
5
  const constants_1 = require("../../shared/constants");
6
- // TODO: Update docs before release
6
+ const hosted_layers_1 = require("../../shared/hosted-layers");
7
7
  exports.requiredPermissions = [
8
8
  {
9
+ id: 'Identity',
9
10
  actions: [aws_policies_1.iam.GetUser],
10
11
  // eslint-disable-next-line no-template-curly-in-string
11
12
  resource: ['arn:aws:iam::*:user/${aws:username}'],
12
13
  },
13
14
  {
15
+ id: 'PermissionValidation',
14
16
  actions: [aws_policies_1.iam.SimulatePrincipalPolicy],
15
17
  resource: ['*'],
16
18
  },
17
19
  {
18
- // TODO: arn:aws:iam::976210361945:role/lambda-admin, can it be locked down more?
20
+ id: 'LambdaInvokation',
19
21
  actions: [aws_policies_1.iam.PassRole],
20
- resource: ['*'],
22
+ resource: ['arn:aws:iam::*:role/remotion-lambda-role'],
21
23
  },
22
24
  {
25
+ id: 'Storage',
23
26
  actions: [
24
27
  aws_policies_1.s3.GetObject,
25
28
  aws_policies_1.s3.DeleteObject,
26
- aws_policies_1.s3.DeleteBucket,
27
- aws_policies_1.s3.PutBucketWebsite,
28
- aws_policies_1.s3.DeleteBucketWebsite,
29
29
  aws_policies_1.s3.PutObjectAcl,
30
30
  aws_policies_1.s3.PutObject,
31
+ aws_policies_1.s3.CreateBucket,
32
+ aws_policies_1.s3.ListBucket,
31
33
  aws_policies_1.s3.GetBucketLocation,
34
+ aws_policies_1.s3.PutBucketAcl,
35
+ aws_policies_1.s3.DeleteBucket,
36
+ aws_policies_1.s3.PutBucketWebsite,
37
+ aws_policies_1.s3.DeleteBucketWebsite,
32
38
  ],
33
39
  resource: [`arn:aws:s3:::${constants_1.REMOTION_BUCKET_PREFIX}*`],
34
40
  },
35
41
  {
36
- actions: [aws_policies_1.s3.CreateBucket, aws_policies_1.s3.ListBucket, aws_policies_1.s3.PutBucketAcl],
37
- resource: [`arn:aws:s3:::*`],
42
+ id: 'BucketListing',
43
+ actions: [aws_policies_1.s3.ListAllMyBuckets],
44
+ resource: ['*'],
38
45
  },
39
46
  {
40
- actions: [aws_policies_1.s3.ListAllMyBuckets],
47
+ id: 'FunctionListing',
48
+ actions: [aws_policies_1.lambda.ListFunctions, aws_policies_1.lambda.GetFunction],
41
49
  resource: ['*'],
42
50
  },
43
51
  {
52
+ id: 'FunctionManagement',
44
53
  actions: [
45
- aws_policies_1.lambda.GetFunction,
46
54
  aws_policies_1.lambda.InvokeAsync,
47
55
  aws_policies_1.lambda.InvokeFunction,
48
56
  aws_policies_1.lambda.CreateFunction,
49
57
  aws_policies_1.lambda.DeleteFunction,
58
+ aws_policies_1.lambda.PutFunctionEventInvokeConfig,
50
59
  ],
51
60
  resource: [`arn:aws:lambda:*:*:function:${constants_1.RENDER_FN_PREFIX}*`],
52
61
  },
53
62
  {
54
- actions: [aws_policies_1.lambda.ListFunctions],
55
- resource: ['*'],
63
+ id: 'logs.PutRetentionPolicy',
64
+ actions: [aws_policies_1.logs.CreateLogGroup, aws_policies_1.logs.PutRetentionPolicy],
65
+ resource: [
66
+ `arn:aws:logs:*:*:log-group:${constants_1.LOG_GROUP_PREFIX}${constants_1.RENDER_FN_PREFIX}*`,
67
+ ],
68
+ },
69
+ {
70
+ id: 'FetchBinaries',
71
+ actions: [aws_policies_1.lambda.GetLayerVersion],
72
+ resource: [hosted_layers_1.REMOTION_HOSTED_LAYER_ARN],
56
73
  },
57
74
  ];
58
- //# sourceMappingURL=required-permissions.js.map
75
+ //# sourceMappingURL=user-permissions.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"user-permissions.js","sourceRoot":"","sources":["../../../src/api/iam-validation/user-permissions.ts"],"names":[],"mappings":";;;AAAA,+CAAmD;AACnD,sDAIgC;AAChC,8DAAqE;AAExD,QAAA,mBAAmB,GAI1B;IACL;QACC,EAAE,EAAE,UAAU;QACd,OAAO,EAAE,CAAC,kBAAG,CAAC,OAAO,CAAC;QACtB,uDAAuD;QACvD,QAAQ,EAAE,CAAC,qCAAqC,CAAC;KACjD;IACD;QACC,EAAE,EAAE,sBAAsB;QAC1B,OAAO,EAAE,CAAC,kBAAG,CAAC,uBAAuB,CAAC;QACtC,QAAQ,EAAE,CAAC,GAAG,CAAC;KACf;IACD;QACC,EAAE,EAAE,kBAAkB;QACtB,OAAO,EAAE,CAAC,kBAAG,CAAC,QAAQ,CAAC;QACvB,QAAQ,EAAE,CAAC,0CAA0C,CAAC;KACtD;IACD;QACC,EAAE,EAAE,SAAS;QACb,OAAO,EAAE;YACR,iBAAE,CAAC,SAAS;YACZ,iBAAE,CAAC,YAAY;YACf,iBAAE,CAAC,YAAY;YACf,iBAAE,CAAC,SAAS;YACZ,iBAAE,CAAC,YAAY;YACf,iBAAE,CAAC,UAAU;YACb,iBAAE,CAAC,iBAAiB;YACpB,iBAAE,CAAC,YAAY;YACf,iBAAE,CAAC,YAAY;YACf,iBAAE,CAAC,gBAAgB;YACnB,iBAAE,CAAC,mBAAmB;SACtB;QACD,QAAQ,EAAE,CAAC,gBAAgB,kCAAsB,GAAG,CAAC;KACrD;IACD;QACC,EAAE,EAAE,eAAe;QACnB,OAAO,EAAE,CAAC,iBAAE,CAAC,gBAAgB,CAAC;QAC9B,QAAQ,EAAE,CAAC,GAAG,CAAC;KACf;IACD;QACC,EAAE,EAAE,iBAAiB;QACrB,OAAO,EAAE,CAAC,qBAAM,CAAC,aAAa,EAAE,qBAAM,CAAC,WAAW,CAAC;QACnD,QAAQ,EAAE,CAAC,GAAG,CAAC;KACf;IACD;QACC,EAAE,EAAE,oBAAoB;QACxB,OAAO,EAAE;YACR,qBAAM,CAAC,WAAW;YAClB,qBAAM,CAAC,cAAc;YACrB,qBAAM,CAAC,cAAc;YACrB,qBAAM,CAAC,cAAc;YACrB,qBAAM,CAAC,4BAA4B;SACnC;QACD,QAAQ,EAAE,CAAC,+BAA+B,4BAAgB,GAAG,CAAC;KAC9D;IACD;QACC,EAAE,EAAE,yBAAyB;QAC7B,OAAO,EAAE,CAAC,mBAAI,CAAC,cAAc,EAAE,mBAAI,CAAC,kBAAkB,CAAC;QACvD,QAAQ,EAAE;YACT,8BAA8B,4BAAgB,GAAG,4BAAgB,GAAG;SACpE;KACD;IACD;QACC,EAAE,EAAE,eAAe;QACnB,OAAO,EAAE,CAAC,qBAAM,CAAC,eAAe,CAAC;QACjC,QAAQ,EAAE,CAAC,yCAAyB,CAAC;KACrC;CACD,CAAC"}
@@ -1,4 +1,4 @@
1
- import { AwsRegion } from '..';
1
+ import { AwsRegion } from '../pricing/aws-regions';
2
2
  import { LambdaVersions } from '../shared/constants';
3
3
  import { FunctionInfo } from './get-function-info';
4
4
  export declare let mockFunctionsStore: (FunctionInfo & {
@@ -1 +1 @@
1
- {"version":3,"file":"mock-functions.d.ts","sourceRoot":"","sources":["../../src/api/mock-functions.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,SAAS,EAAC,MAAM,IAAI,CAAC;AAC7B,OAAO,EAAC,cAAc,EAAC,MAAM,qBAAqB,CAAC;AACnD,OAAO,EAAC,YAAY,EAAC,MAAM,qBAAqB,CAAC;AAEjD,eAAO,IAAI,kBAAkB,EAAE,CAAC,YAAY,GAAG;IAC9C,MAAM,EAAE,SAAS,CAAC;IAClB,OAAO,EAAE,cAAc,CAAC;CACxB,CAAC,EAAO,CAAC;AAEV,eAAO,MAAM,WAAW,OAAQ,YAAY,UAAU,SAAS,SAM9D,CAAC;AAEF,eAAO,MAAM,kBAAkB,SAAU,MAAM,UAAU,MAAM,SAI9D,CAAC;AAEF,eAAO,MAAM,YAAY,SAAU,MAAM,UAAU,MAAM;YAlBhD,SAAS;aACR,cAAc;cAqBvB,CAAC;AAEF,eAAO,MAAM,mBAAmB,WACvB,MAAM,WACL,cAAc,GAAG,IAAI;YA1BtB,SAAS;aACR,cAAc;IA8BvB,CAAC;AAEF,eAAO,MAAM,YAAY,YAExB,CAAC;AAEF,eAAO,MAAM,0BAA0B,iBAAkB,MAAM,SAM9D,CAAC"}
1
+ {"version":3,"file":"mock-functions.d.ts","sourceRoot":"","sources":["../../src/api/mock-functions.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,SAAS,EAAC,MAAM,wBAAwB,CAAC;AACjD,OAAO,EAAC,cAAc,EAAC,MAAM,qBAAqB,CAAC;AACnD,OAAO,EAAC,YAAY,EAAC,MAAM,qBAAqB,CAAC;AAEjD,eAAO,IAAI,kBAAkB,EAAE,CAAC,YAAY,GAAG;IAC9C,MAAM,EAAE,SAAS,CAAC;IAClB,OAAO,EAAE,cAAc,CAAC;CACxB,CAAC,EAAO,CAAC;AAEV,eAAO,MAAM,WAAW,OAAQ,YAAY,UAAU,SAAS,SAM9D,CAAC;AAEF,eAAO,MAAM,kBAAkB,SAAU,MAAM,UAAU,MAAM,SAI9D,CAAC;AAEF,eAAO,MAAM,YAAY,SAAU,MAAM,UAAU,MAAM;YAlBhD,SAAS;aACR,cAAc;cAqBvB,CAAC;AAEF,eAAO,MAAM,mBAAmB,WACvB,MAAM,WACL,cAAc,GAAG,IAAI;YA1BtB,SAAS;aACR,cAAc;IA8BvB,CAAC;AAEF,eAAO,MAAM,YAAY,YAExB,CAAC;AAEF,eAAO,MAAM,0BAA0B,iBAAkB,MAAM,SAM9D,CAAC"}
@@ -1,8 +1,8 @@
1
- import { StillImageFormat } from 'remotion';
1
+ import { LogLevel, StillImageFormat } from 'remotion';
2
2
  import { AwsRegion } from '../pricing/aws-regions';
3
3
  /**
4
4
  * @description Renders a still frame on Lambda
5
- * @link https://remotion.dev/docs/lambda/renderstillonlambda
5
+ * @link https://remotion-lambda-alpha.netlify.app/docs/lambda/renderstillonlambda
6
6
  * @param params.functionName The name of the Lambda function that should be used
7
7
  * @param params.serveUrl The URL of the deployed project
8
8
  * @param params.composition The ID of the composition which should be rendered.
@@ -16,7 +16,7 @@ import { AwsRegion } from '../pricing/aws-regions';
16
16
  * @param params.privacy Whether the item in the S3 bucket should be public. Possible values: `"private"` and `"public"`
17
17
  * @returns `Promise<{estimatedPrice: CostsInfo; url: string; size: number}>`
18
18
  */
19
- export declare const renderStillOnLambda: ({ functionName, serveUrl, inputProps, imageFormat, envVariables, quality, region, maxRetries, composition, privacy, frame, }: {
19
+ export declare const renderStillOnLambda: ({ functionName, serveUrl, inputProps, imageFormat, envVariables, quality, region, maxRetries, composition, privacy, frame, logLevel, }: {
20
20
  region: AwsRegion;
21
21
  functionName: string;
22
22
  serveUrl: string;
@@ -28,10 +28,12 @@ export declare const renderStillOnLambda: ({ functionName, serveUrl, inputProps,
28
28
  envVariables?: Record<string, string> | undefined;
29
29
  quality?: number | undefined;
30
30
  frame?: number | undefined;
31
+ logLevel?: "verbose" | "info" | "warn" | "error" | undefined;
31
32
  }) => Promise<{
32
33
  estimatedPrice: import("../shared/constants").CostsInfo;
33
34
  url: string;
34
35
  size: number;
35
36
  bucketName: string;
37
+ renderId: string;
36
38
  }>;
37
39
  //# sourceMappingURL=render-still-on-lambda.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"render-still-on-lambda.d.ts","sourceRoot":"","sources":["../../src/api/render-still-on-lambda.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,gBAAgB,EAAC,MAAM,UAAU,CAAC;AAC1C,OAAO,EAAC,SAAS,EAAC,MAAM,wBAAwB,CAAC;AAGjD;;;;;;;;;;;;;;;GAeG;AAEH,eAAO,MAAM,mBAAmB;YAavB,SAAS;kBACH,MAAM;cACV,MAAM;iBACH,MAAM;gBACP,OAAO;iBACN,gBAAgB;aACpB,SAAS,GAAG,QAAQ;;;;;;;;;;EA4B7B,CAAC"}
1
+ {"version":3,"file":"render-still-on-lambda.d.ts","sourceRoot":"","sources":["../../src/api/render-still-on-lambda.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,QAAQ,EAAE,gBAAgB,EAAC,MAAM,UAAU,CAAC;AACpD,OAAO,EAAC,SAAS,EAAC,MAAM,wBAAwB,CAAC;AAIjD;;;;;;;;;;;;;;;GAeG;AAEH,eAAO,MAAM,mBAAmB;YAcvB,SAAS;kBACH,MAAM;cACV,MAAM;iBACH,MAAM;gBACP,OAAO;iBACN,gBAAgB;aACpB,SAAS,GAAG,QAAQ;;;;;;;;;;;;EAkC7B,CAAC"}
@@ -3,9 +3,10 @@ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.renderStillOnLambda = void 0;
4
4
  const call_lambda_1 = require("../shared/call-lambda");
5
5
  const constants_1 = require("../shared/constants");
6
+ const convert_to_serve_url_1 = require("../shared/convert-to-serve-url");
6
7
  /**
7
8
  * @description Renders a still frame on Lambda
8
- * @link https://remotion.dev/docs/lambda/renderstillonlambda
9
+ * @link https://remotion-lambda-alpha.netlify.app/docs/lambda/renderstillonlambda
9
10
  * @param params.functionName The name of the Lambda function that should be used
10
11
  * @param params.serveUrl The URL of the deployed project
11
12
  * @param params.composition The ID of the composition which should be rendered.
@@ -19,20 +20,23 @@ const constants_1 = require("../shared/constants");
19
20
  * @param params.privacy Whether the item in the S3 bucket should be public. Possible values: `"private"` and `"public"`
20
21
  * @returns `Promise<{estimatedPrice: CostsInfo; url: string; size: number}>`
21
22
  */
22
- const renderStillOnLambda = async ({ functionName, serveUrl, inputProps, imageFormat, envVariables, quality, region, maxRetries, composition, privacy, frame, }) => {
23
- const res = await call_lambda_1.callLambda({
23
+ const renderStillOnLambda = async ({ functionName, serveUrl, inputProps, imageFormat, envVariables, quality, region, maxRetries, composition, privacy, frame, logLevel, }) => {
24
+ const realServeUrl = await (0, convert_to_serve_url_1.convertToServeUrl)(serveUrl, region);
25
+ const res = await (0, call_lambda_1.callLambda)({
24
26
  functionName,
25
27
  type: constants_1.LambdaRoutines.still,
26
28
  payload: {
27
29
  composition,
28
- serveUrl,
30
+ serveUrl: realServeUrl,
29
31
  inputProps,
30
32
  imageFormat,
31
33
  envVariables,
32
34
  quality,
33
- maxRetries: maxRetries !== null && maxRetries !== void 0 ? maxRetries : 3,
35
+ maxRetries: maxRetries !== null && maxRetries !== void 0 ? maxRetries : constants_1.DEFAULT_MAX_RETRIES,
34
36
  frame: frame !== null && frame !== void 0 ? frame : 0,
35
37
  privacy,
38
+ attempt: 1,
39
+ logLevel,
36
40
  },
37
41
  region,
38
42
  });
@@ -41,6 +45,7 @@ const renderStillOnLambda = async ({ functionName, serveUrl, inputProps, imageFo
41
45
  url: res.output,
42
46
  size: res.size,
43
47
  bucketName: res.bucketName,
48
+ renderId: res.renderId,
44
49
  };
45
50
  };
46
51
  exports.renderStillOnLambda = renderStillOnLambda;
@@ -1 +1 @@
1
- {"version":3,"file":"render-still-on-lambda.js","sourceRoot":"","sources":["../../src/api/render-still-on-lambda.ts"],"names":[],"mappings":";;;AAEA,uDAAiD;AACjD,mDAAmD;AACnD;;;;;;;;;;;;;;;GAeG;AAEI,MAAM,mBAAmB,GAAG,KAAK,EAAE,EACzC,YAAY,EACZ,QAAQ,EACR,UAAU,EACV,WAAW,EACX,YAAY,EACZ,OAAO,EACP,MAAM,EACN,UAAU,EACV,WAAW,EACX,OAAO,EACP,KAAK,GAaL,EAAE,EAAE;IACJ,MAAM,GAAG,GAAG,MAAM,wBAAU,CAAC;QAC5B,YAAY;QACZ,IAAI,EAAE,0BAAc,CAAC,KAAK;QAC1B,OAAO,EAAE;YACR,WAAW;YACX,QAAQ;YACR,UAAU;YACV,WAAW;YACX,YAAY;YACZ,OAAO;YACP,UAAU,EAAE,UAAU,aAAV,UAAU,cAAV,UAAU,GAAI,CAAC;YAC3B,KAAK,EAAE,KAAK,aAAL,KAAK,cAAL,KAAK,GAAI,CAAC;YACjB,OAAO;SACP;QACD,MAAM;KACN,CAAC,CAAC;IACH,OAAO;QACN,cAAc,EAAE,GAAG,CAAC,cAAc;QAClC,GAAG,EAAE,GAAG,CAAC,MAAM;QACf,IAAI,EAAE,GAAG,CAAC,IAAI;QACd,UAAU,EAAE,GAAG,CAAC,UAAU;KAC1B,CAAC;AACH,CAAC,CAAC;AA/CW,QAAA,mBAAmB,uBA+C9B"}
1
+ {"version":3,"file":"render-still-on-lambda.js","sourceRoot":"","sources":["../../src/api/render-still-on-lambda.ts"],"names":[],"mappings":";;;AAEA,uDAAiD;AACjD,mDAAwE;AACxE,yEAAiE;AACjE;;;;;;;;;;;;;;;GAeG;AAEI,MAAM,mBAAmB,GAAG,KAAK,EAAE,EACzC,YAAY,EACZ,QAAQ,EACR,UAAU,EACV,WAAW,EACX,YAAY,EACZ,OAAO,EACP,MAAM,EACN,UAAU,EACV,WAAW,EACX,OAAO,EACP,KAAK,EACL,QAAQ,GAcR,EAAE,EAAE;IACJ,MAAM,YAAY,GAAG,MAAM,IAAA,wCAAiB,EAAC,QAAQ,EAAE,MAAM,CAAC,CAAC;IAE/D,MAAM,GAAG,GAAG,MAAM,IAAA,wBAAU,EAAC;QAC5B,YAAY;QACZ,IAAI,EAAE,0BAAc,CAAC,KAAK;QAC1B,OAAO,EAAE;YACR,WAAW;YACX,QAAQ,EAAE,YAAY;YACtB,UAAU;YACV,WAAW;YACX,YAAY;YACZ,OAAO;YACP,UAAU,EAAE,UAAU,aAAV,UAAU,cAAV,UAAU,GAAI,+BAAmB;YAC7C,KAAK,EAAE,KAAK,aAAL,KAAK,cAAL,KAAK,GAAI,CAAC;YACjB,OAAO;YACP,OAAO,EAAE,CAAC;YACV,QAAQ;SACR;QACD,MAAM;KACN,CAAC,CAAC;IACH,OAAO;QACN,cAAc,EAAE,GAAG,CAAC,cAAc;QAClC,GAAG,EAAE,GAAG,CAAC,MAAM;QACf,IAAI,EAAE,GAAG,CAAC,IAAI;QACd,UAAU,EAAE,GAAG,CAAC,UAAU;QAC1B,QAAQ,EAAE,GAAG,CAAC,QAAQ;KACtB,CAAC;AACH,CAAC,CAAC;AAtDW,QAAA,mBAAmB,uBAsD9B"}
@@ -1,8 +1,9 @@
1
- import { ImageFormat, PixelFormat, ProResProfile } from 'remotion';
1
+ import { FrameRange, ImageFormat, LogLevel, PixelFormat, ProResProfile } from 'remotion';
2
2
  import { AwsRegion } from '../pricing/aws-regions';
3
+ import { Privacy } from '../shared/constants';
3
4
  /**
4
5
  * @description Triggers a render on a lambda given a composition and a lambda function.
5
- * @link https://remotion.dev/docs/lambda/rendervideoonlambda
6
+ * @link https://remotion-lambda-alpha.netlify.app/docs/lambda/rendervideoonlambda
6
7
  * @param params.functionName The name of the Lambda function that should be used
7
8
  * @param params.serveUrl The URL of the deployed project
8
9
  * @param params.composition The ID of the composition which should be rendered.
@@ -15,9 +16,11 @@ import { AwsRegion } from '../pricing/aws-regions';
15
16
  * @param params.quality JPEG quality if JPEG was selected as the image format.
16
17
  * @param params.region The AWS region in which the video should be rendered.
17
18
  * @param params.maxRetries How often rendering a chunk may fail before the video render gets aborted.
19
+ * @param params.enableChunkOptimization Whether Remotion should restructure and optimize chunks for subsequent renders. Default true.
20
+ * @param params.logLevel Level of logging that Lambda function should perform. Default "info".
18
21
  * @returns `Promise<{renderId: string; bucketName: string}>`
19
22
  */
20
- export declare const renderVideoOnLambda: ({ functionName, serveUrl, inputProps, codec, imageFormat, crf, envVariables, pixelFormat, proResProfile, quality, region, maxRetries, composition, framesPerLambda, }: {
23
+ export declare const renderVideoOnLambda: ({ functionName, serveUrl, inputProps, codec, imageFormat, crf, envVariables, pixelFormat, proResProfile, quality, region, maxRetries, composition, framesPerLambda, privacy, enableChunkOptimization, logLevel, frameRange, }: {
21
24
  region: AwsRegion;
22
25
  functionName: string;
23
26
  serveUrl: string;
@@ -29,9 +32,13 @@ export declare const renderVideoOnLambda: ({ functionName, serveUrl, inputProps,
29
32
  envVariables?: Record<string, string> | undefined;
30
33
  pixelFormat?: "yuv420p" | "yuva420p" | "yuv422p" | "yuv444p" | "yuv420p10le" | "yuv422p10le" | "yuv444p10le" | "yuva444p10le" | undefined;
31
34
  proResProfile?: "4444-xq" | "4444" | "hq" | "standard" | "light" | "proxy" | undefined;
35
+ privacy: Privacy;
32
36
  quality?: number | undefined;
33
37
  maxRetries: number;
34
38
  framesPerLambda?: number | undefined;
39
+ enableChunkOptimization?: boolean | undefined;
40
+ logLevel?: "verbose" | "info" | "warn" | "error" | undefined;
41
+ frameRange?: FrameRange | undefined;
35
42
  }) => Promise<{
36
43
  renderId: string;
37
44
  bucketName: string;