@webiny/project-aws 0.0.0-unstable.61c048f412

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 (547) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +11 -0
  3. package/_templates/appTemplates/admin/src/App.scss +2 -0
  4. package/_templates/appTemplates/admin/src/App.tsx +13 -0
  5. package/_templates/appTemplates/admin/src/Extensions.tsx +7 -0
  6. package/_templates/appTemplates/admin/src/index.tsx +11 -0
  7. package/_templates/appTemplates/admin/tsconfig.json +7 -0
  8. package/_templates/appTemplates/admin/webiny.application.ts +3 -0
  9. package/_templates/appTemplates/admin/webiny.config.ts +3 -0
  10. package/_templates/appTemplates/api/graphql/package.json +31 -0
  11. package/_templates/appTemplates/api/graphql/src/extensions.ts +9 -0
  12. package/_templates/appTemplates/api/graphql/src/index.ts +80 -0
  13. package/_templates/appTemplates/api/graphql/src/security.ts +43 -0
  14. package/_templates/appTemplates/api/graphql/tsconfig.json +7 -0
  15. package/_templates/appTemplates/api/graphql/webiny.config.ts +8 -0
  16. package/_templates/appTemplates/api/migration/src/index.ts +23 -0
  17. package/_templates/appTemplates/api/migration/tsconfig.json +7 -0
  18. package/_templates/appTemplates/api/migration/webiny.config.ts +8 -0
  19. package/_templates/appTemplates/api/webiny.application.ts +3 -0
  20. package/_templates/appTemplates/blueGreen/webiny.application.ts +3 -0
  21. package/_templates/appTemplates/core/webiny.application.ts +3 -0
  22. package/_templates/appTemplates/syncSystem/webiny.application.ts +3 -0
  23. package/_templates/extensions/OpenSearch/api/graphql/src/index.ts +84 -0
  24. package/_templates/extensions/OpenSearch/api/migration/src/index.ts +33 -0
  25. package/_templates/extensions/OpenSearch/coreDdbToEsHandler/dynamoToElastic/src/index.ts +15 -0
  26. package/_templates/extensions/OpenSearch/coreDdbToEsHandler/dynamoToElastic/tsconfig.json +7 -0
  27. package/_templates/extensions/OpenSearch/coreDdbToEsHandler/dynamoToElastic/webiny.config.ts +8 -0
  28. package/abstractions/ApiGqlClient.d.ts +23 -0
  29. package/abstractions/ApiGqlClient.js +4 -0
  30. package/abstractions/ApiGqlClient.js.map +1 -0
  31. package/abstractions/InvokeLambdaFunction.d.ts +18 -0
  32. package/abstractions/InvokeLambdaFunction.js +4 -0
  33. package/abstractions/InvokeLambdaFunction.js.map +1 -0
  34. package/abstractions/index.d.ts +5 -0
  35. package/abstractions/index.js +7 -0
  36. package/abstractions/index.js.map +1 -0
  37. package/abstractions/services/AdminStackOutputService.d.ts +13 -0
  38. package/abstractions/services/AdminStackOutputService.js +4 -0
  39. package/abstractions/services/AdminStackOutputService.js.map +1 -0
  40. package/abstractions/services/ApiStackOutputService.d.ts +30 -0
  41. package/abstractions/services/ApiStackOutputService.js +4 -0
  42. package/abstractions/services/ApiStackOutputService.js.map +1 -0
  43. package/abstractions/services/CoreStackOutputService.d.ts +16 -0
  44. package/abstractions/services/CoreStackOutputService.js +4 -0
  45. package/abstractions/services/CoreStackOutputService.js.map +1 -0
  46. package/admin.d.ts +22 -0
  47. package/admin.js +7 -0
  48. package/admin.js.map +1 -0
  49. package/api.d.ts +22 -0
  50. package/api.js +7 -0
  51. package/api.js.map +1 -0
  52. package/apps/createAdminApp.d.ts +13 -0
  53. package/apps/createAdminApp.js +15 -0
  54. package/apps/createAdminApp.js.map +1 -0
  55. package/apps/createAdminAppConfig.d.ts +2 -0
  56. package/apps/createAdminAppConfig.js +21 -0
  57. package/apps/createAdminAppConfig.js.map +1 -0
  58. package/apps/createApiApp.d.ts +65 -0
  59. package/apps/createApiApp.js +25 -0
  60. package/apps/createApiApp.js.map +1 -0
  61. package/apps/createBlueGreenApp.d.ts +24 -0
  62. package/apps/createBlueGreenApp.js +20 -0
  63. package/apps/createBlueGreenApp.js.map +1 -0
  64. package/apps/createCoreApp.d.ts +36 -0
  65. package/apps/createCoreApp.js +16 -0
  66. package/apps/createCoreApp.js.map +1 -0
  67. package/apps/createReactAppConfig.d.ts +53 -0
  68. package/apps/createReactAppConfig.js +79 -0
  69. package/apps/createReactAppConfig.js.map +1 -0
  70. package/apps/createSyncSystemApp.d.ts +21 -0
  71. package/apps/createSyncSystemApp.js +11 -0
  72. package/apps/createSyncSystemApp.js.map +1 -0
  73. package/apps/index.d.ts +7 -0
  74. package/apps/index.js +9 -0
  75. package/apps/index.js.map +1 -0
  76. package/cli.d.ts +9 -0
  77. package/cli.js +6 -0
  78. package/cli.js.map +1 -0
  79. package/exports/extensions.d.ts +7 -0
  80. package/exports/extensions.js +9 -0
  81. package/exports/extensions.js.map +1 -0
  82. package/exports/infra/admin.d.ts +1 -0
  83. package/exports/infra/admin.js +3 -0
  84. package/exports/infra/admin.js.map +1 -0
  85. package/exports/infra/api.d.ts +1 -0
  86. package/exports/infra/api.js +3 -0
  87. package/exports/infra/api.js.map +1 -0
  88. package/exports/infra/core.d.ts +1 -0
  89. package/exports/infra/core.js +3 -0
  90. package/exports/infra/core.js.map +1 -0
  91. package/extensions/AwsDefaultRegion.d.ts +5 -0
  92. package/extensions/AwsDefaultRegion.js +10 -0
  93. package/extensions/AwsDefaultRegion.js.map +1 -0
  94. package/extensions/OpenSearch/EnsureOsServiceRoleBeforeCoreDeploy.d.ts +10 -0
  95. package/extensions/OpenSearch/EnsureOsServiceRoleBeforeCoreDeploy.js +40 -0
  96. package/extensions/OpenSearch/EnsureOsServiceRoleBeforeCoreDeploy.js.map +1 -0
  97. package/extensions/OpenSearch/EnsureOsWasDeployed.d.ts +11 -0
  98. package/extensions/OpenSearch/EnsureOsWasDeployed.js +34 -0
  99. package/extensions/OpenSearch/EnsureOsWasDeployed.js.map +1 -0
  100. package/extensions/OpenSearch/InjectDdbEsLambdaFnHandler.d.ts +12 -0
  101. package/extensions/OpenSearch/InjectDdbEsLambdaFnHandler.js +31 -0
  102. package/extensions/OpenSearch/InjectDdbEsLambdaFnHandler.js.map +1 -0
  103. package/extensions/OpenSearch/ReplaceApiLambdaFnHandlers.d.ts +12 -0
  104. package/extensions/OpenSearch/ReplaceApiLambdaFnHandlers.js +32 -0
  105. package/extensions/OpenSearch/ReplaceApiLambdaFnHandlers.js.map +1 -0
  106. package/extensions/OpenSearch.d.ts +17 -0
  107. package/extensions/OpenSearch.js +36 -0
  108. package/extensions/OpenSearch.js.map +1 -0
  109. package/extensions/ProjectAws/AdminStackOutputService.d.ts +1 -0
  110. package/extensions/ProjectAws/AdminStackOutputService.js +3 -0
  111. package/extensions/ProjectAws/AdminStackOutputService.js.map +1 -0
  112. package/extensions/ProjectAws/ApiStackOutputService.d.ts +1 -0
  113. package/extensions/ProjectAws/ApiStackOutputService.js +3 -0
  114. package/extensions/ProjectAws/ApiStackOutputService.js.map +1 -0
  115. package/extensions/ProjectAws/AutoInstall/AutoInstallAfterApiDeploy.d.ts +17 -0
  116. package/extensions/ProjectAws/AutoInstall/AutoInstallAfterApiDeploy.js +108 -0
  117. package/extensions/ProjectAws/AutoInstall/AutoInstallAfterApiDeploy.js.map +1 -0
  118. package/extensions/ProjectAws/AutoInstall.d.ts +33 -0
  119. package/extensions/ProjectAws/AutoInstall.js +19 -0
  120. package/extensions/ProjectAws/AutoInstall.js.map +1 -0
  121. package/extensions/ProjectAws/BlueGreenDeployments/EnsureVariantBeforeDeploy.d.ts +10 -0
  122. package/extensions/ProjectAws/BlueGreenDeployments/EnsureVariantBeforeDeploy.js +27 -0
  123. package/extensions/ProjectAws/BlueGreenDeployments/EnsureVariantBeforeDeploy.js.map +1 -0
  124. package/extensions/ProjectAws/BlueGreenDeployments/PrintDeploymentInfoAfterDeploy.d.ts +20 -0
  125. package/extensions/ProjectAws/BlueGreenDeployments/PrintDeploymentInfoAfterDeploy.js +54 -0
  126. package/extensions/ProjectAws/BlueGreenDeployments/PrintDeploymentInfoAfterDeploy.js.map +1 -0
  127. package/extensions/ProjectAws/BlueGreenDeployments/SetPrimaryVariantCliCommand.d.ts +18 -0
  128. package/extensions/ProjectAws/BlueGreenDeployments/SetPrimaryVariantCliCommand.js +60 -0
  129. package/extensions/ProjectAws/BlueGreenDeployments/SetPrimaryVariantCliCommand.js.map +1 -0
  130. package/extensions/ProjectAws/BuildAppWorkspace.d.ts +12 -0
  131. package/extensions/ProjectAws/BuildAppWorkspace.js +66 -0
  132. package/extensions/ProjectAws/BuildAppWorkspace.js.map +1 -0
  133. package/extensions/ProjectAws/CoreStackOutputService.d.ts +1 -0
  134. package/extensions/ProjectAws/CoreStackOutputService.js +3 -0
  135. package/extensions/ProjectAws/CoreStackOutputService.js.map +1 -0
  136. package/extensions/ProjectAws/ExecuteDataMigrations.d.ts +16 -0
  137. package/extensions/ProjectAws/ExecuteDataMigrations.js +69 -0
  138. package/extensions/ProjectAws/ExecuteDataMigrations.js.map +1 -0
  139. package/extensions/ProjectAws/SetAdminEnvVars/SetAdminEnvVars.d.ts +13 -0
  140. package/extensions/ProjectAws/SetAdminEnvVars/SetAdminEnvVars.js +43 -0
  141. package/extensions/ProjectAws/SetAdminEnvVars/SetAdminEnvVars.js.map +1 -0
  142. package/extensions/ProjectAws/SetAdminEnvVars/SetAdminEnvVarsBeforeBuild.d.ts +13 -0
  143. package/extensions/ProjectAws/SetAdminEnvVars/SetAdminEnvVarsBeforeBuild.js +24 -0
  144. package/extensions/ProjectAws/SetAdminEnvVars/SetAdminEnvVarsBeforeBuild.js.map +1 -0
  145. package/extensions/ProjectAws/SetAdminEnvVars/SetAdminEnvVarsBeforeWatch.d.ts +13 -0
  146. package/extensions/ProjectAws/SetAdminEnvVars/SetAdminEnvVarsBeforeWatch.js +24 -0
  147. package/extensions/ProjectAws/SetAdminEnvVars/SetAdminEnvVarsBeforeWatch.js.map +1 -0
  148. package/extensions/ProjectAws/SetDatabaseSetupOutput.d.ts +10 -0
  149. package/extensions/ProjectAws/SetDatabaseSetupOutput.js +29 -0
  150. package/extensions/ProjectAws/SetDatabaseSetupOutput.js.map +1 -0
  151. package/extensions/ProjectAws/UploadAdminAppToS3.d.ts +13 -0
  152. package/extensions/ProjectAws/UploadAdminAppToS3.js +69 -0
  153. package/extensions/ProjectAws/UploadAdminAppToS3.js.map +1 -0
  154. package/extensions/ProjectAws/definitions.d.ts +3 -0
  155. package/extensions/ProjectAws/definitions.js +11 -0
  156. package/extensions/ProjectAws/definitions.js.map +1 -0
  157. package/extensions/ProjectAws.d.ts +2 -0
  158. package/extensions/ProjectAws.js +49 -0
  159. package/extensions/ProjectAws.js.map +1 -0
  160. package/extensions/index.d.ts +4 -0
  161. package/extensions/index.js +6 -0
  162. package/extensions/index.js.map +1 -0
  163. package/features/ApiGqlClient.d.ts +21 -0
  164. package/features/ApiGqlClient.js +59 -0
  165. package/features/ApiGqlClient.js.map +1 -0
  166. package/features/InvokeLambdaFunction.d.ts +10 -0
  167. package/features/InvokeLambdaFunction.js +38 -0
  168. package/features/InvokeLambdaFunction.js.map +1 -0
  169. package/features/index.d.ts +2 -0
  170. package/features/index.js +4 -0
  171. package/features/index.js.map +1 -0
  172. package/index.d.ts +7 -0
  173. package/index.js +9 -0
  174. package/index.js.map +1 -0
  175. package/infra.d.ts +399 -0
  176. package/infra.js +49 -0
  177. package/infra.js.map +1 -0
  178. package/package.json +63 -0
  179. package/project.d.ts +48 -0
  180. package/project.js +9 -0
  181. package/project.js.map +1 -0
  182. package/pulumi/apps/admin/createAdminPulumiApp.d.ts +10 -0
  183. package/pulumi/apps/admin/createAdminPulumiApp.js +52 -0
  184. package/pulumi/apps/admin/createAdminPulumiApp.js.map +1 -0
  185. package/pulumi/apps/admin/index.d.ts +1 -0
  186. package/pulumi/apps/admin/index.js +3 -0
  187. package/pulumi/apps/admin/index.js.map +1 -0
  188. package/pulumi/apps/api/ApiBackgroundTask.d.ts +12 -0
  189. package/pulumi/apps/api/ApiBackgroundTask.js +148 -0
  190. package/pulumi/apps/api/ApiBackgroundTask.js.map +1 -0
  191. package/pulumi/apps/api/ApiCloudfront.d.ts +3 -0
  192. package/pulumi/apps/api/ApiCloudfront.js +136 -0
  193. package/pulumi/apps/api/ApiCloudfront.js.map +1 -0
  194. package/pulumi/apps/api/ApiFileManager.d.ts +11 -0
  195. package/pulumi/apps/api/ApiFileManager.js +39 -0
  196. package/pulumi/apps/api/ApiFileManager.js.map +1 -0
  197. package/pulumi/apps/api/ApiGateway.d.ts +18 -0
  198. package/pulumi/apps/api/ApiGateway.js +80 -0
  199. package/pulumi/apps/api/ApiGateway.js.map +1 -0
  200. package/pulumi/apps/api/ApiGraphql.d.ts +22 -0
  201. package/pulumi/apps/api/ApiGraphql.js +164 -0
  202. package/pulumi/apps/api/ApiGraphql.js.map +1 -0
  203. package/pulumi/apps/api/ApiMigration.d.ts +5 -0
  204. package/pulumi/apps/api/ApiMigration.js +83 -0
  205. package/pulumi/apps/api/ApiMigration.js.map +1 -0
  206. package/pulumi/apps/api/ApiOutput.d.ts +23 -0
  207. package/pulumi/apps/api/ApiOutput.js +36 -0
  208. package/pulumi/apps/api/ApiOutput.js.map +1 -0
  209. package/pulumi/apps/api/ApiScheduler.d.ts +8 -0
  210. package/pulumi/apps/api/ApiScheduler.js +100 -0
  211. package/pulumi/apps/api/ApiScheduler.js.map +1 -0
  212. package/pulumi/apps/api/ApiWebsocket.d.ts +14 -0
  213. package/pulumi/apps/api/ApiWebsocket.js +138 -0
  214. package/pulumi/apps/api/ApiWebsocket.js.map +1 -0
  215. package/pulumi/apps/api/backgroundTask/definition.d.ts +7 -0
  216. package/pulumi/apps/api/backgroundTask/definition.js +149 -0
  217. package/pulumi/apps/api/backgroundTask/definition.js.map +1 -0
  218. package/pulumi/apps/api/backgroundTask/policy.d.ts +8 -0
  219. package/pulumi/apps/api/backgroundTask/policy.js +26 -0
  220. package/pulumi/apps/api/backgroundTask/policy.js.map +1 -0
  221. package/pulumi/apps/api/backgroundTask/role.d.ts +9 -0
  222. package/pulumi/apps/api/backgroundTask/role.js +32 -0
  223. package/pulumi/apps/api/backgroundTask/role.js.map +1 -0
  224. package/pulumi/apps/api/backgroundTask/types.d.ts +91 -0
  225. package/pulumi/apps/api/backgroundTask/types.js +14 -0
  226. package/pulumi/apps/api/backgroundTask/types.js.map +1 -0
  227. package/pulumi/apps/api/createApiPulumiApp.d.ts +57 -0
  228. package/pulumi/apps/api/createApiPulumiApp.js +282 -0
  229. package/pulumi/apps/api/createApiPulumiApp.js.map +1 -0
  230. package/pulumi/apps/api/handleGuardDutyEvents.d.ts +2 -0
  231. package/pulumi/apps/api/handleGuardDutyEvents.js +55 -0
  232. package/pulumi/apps/api/handleGuardDutyEvents.js.map +1 -0
  233. package/pulumi/apps/api/index.d.ts +9 -0
  234. package/pulumi/apps/api/index.js +11 -0
  235. package/pulumi/apps/api/index.js.map +1 -0
  236. package/pulumi/apps/awsUtils.d.ts +5 -0
  237. package/pulumi/apps/awsUtils.js +34 -0
  238. package/pulumi/apps/awsUtils.js.map +1 -0
  239. package/pulumi/apps/blueGreen/BlueGreenRouterApiGateway.d.ts +11 -0
  240. package/pulumi/apps/blueGreen/BlueGreenRouterApiGateway.js +44 -0
  241. package/pulumi/apps/blueGreen/BlueGreenRouterApiGateway.js.map +1 -0
  242. package/pulumi/apps/blueGreen/BlueGreenRouterCloudFront.d.ts +17 -0
  243. package/pulumi/apps/blueGreen/BlueGreenRouterCloudFront.js +100 -0
  244. package/pulumi/apps/blueGreen/BlueGreenRouterCloudFront.js.map +1 -0
  245. package/pulumi/apps/blueGreen/BlueGreenRouterCloudFrontStore.d.ts +10 -0
  246. package/pulumi/apps/blueGreen/BlueGreenRouterCloudFrontStore.js +20 -0
  247. package/pulumi/apps/blueGreen/BlueGreenRouterCloudFrontStore.js.map +1 -0
  248. package/pulumi/apps/blueGreen/cloudfront/createCloudFrontDefaultCacheBehaviorPolicies.d.ts +7 -0
  249. package/pulumi/apps/blueGreen/cloudfront/createCloudFrontDefaultCacheBehaviorPolicies.js +15 -0
  250. package/pulumi/apps/blueGreen/cloudfront/createCloudFrontDefaultCacheBehaviorPolicies.js.map +1 -0
  251. package/pulumi/apps/blueGreen/cloudfront/createCloudFrontFunctionDomainMap.d.ts +14 -0
  252. package/pulumi/apps/blueGreen/cloudfront/createCloudFrontFunctionDomainMap.js +23 -0
  253. package/pulumi/apps/blueGreen/cloudfront/createCloudFrontFunctionDomainMap.js.map +1 -0
  254. package/pulumi/apps/blueGreen/cloudfront/createOriginId.d.ts +11 -0
  255. package/pulumi/apps/blueGreen/cloudfront/createOriginId.js +10 -0
  256. package/pulumi/apps/blueGreen/cloudfront/createOriginId.js.map +1 -0
  257. package/pulumi/apps/blueGreen/constants.d.ts +3 -0
  258. package/pulumi/apps/blueGreen/constants.js +5 -0
  259. package/pulumi/apps/blueGreen/constants.js.map +1 -0
  260. package/pulumi/apps/blueGreen/createBlueGreenPulumiApp.d.ts +15 -0
  261. package/pulumi/apps/blueGreen/createBlueGreenPulumiApp.js +122 -0
  262. package/pulumi/apps/blueGreen/createBlueGreenPulumiApp.js.map +1 -0
  263. package/pulumi/apps/blueGreen/domains/attachDomainsToOutput.d.ts +9 -0
  264. package/pulumi/apps/blueGreen/domains/attachDomainsToOutput.js +30 -0
  265. package/pulumi/apps/blueGreen/domains/attachDomainsToOutput.js.map +1 -0
  266. package/pulumi/apps/blueGreen/domains/convertApplicationDomains.d.ts +6 -0
  267. package/pulumi/apps/blueGreen/domains/convertApplicationDomains.js +23 -0
  268. package/pulumi/apps/blueGreen/domains/convertApplicationDomains.js.map +1 -0
  269. package/pulumi/apps/blueGreen/domains/getApplicationDomains.d.ts +18 -0
  270. package/pulumi/apps/blueGreen/domains/getApplicationDomains.js +73 -0
  271. package/pulumi/apps/blueGreen/domains/getApplicationDomains.js.map +1 -0
  272. package/pulumi/apps/blueGreen/domains/resolveDomains.d.ts +6 -0
  273. package/pulumi/apps/blueGreen/domains/resolveDomains.js +41 -0
  274. package/pulumi/apps/blueGreen/domains/resolveDomains.js.map +1 -0
  275. package/pulumi/apps/blueGreen/functions/buildHandlerFunction.d.ts +15 -0
  276. package/pulumi/apps/blueGreen/functions/buildHandlerFunction.js +18 -0
  277. package/pulumi/apps/blueGreen/functions/buildHandlerFunction.js.map +1 -0
  278. package/pulumi/apps/blueGreen/functions/handler.d.ts +1 -0
  279. package/pulumi/apps/blueGreen/functions/handler.js +60 -0
  280. package/pulumi/apps/blueGreen/functions/handler.js.map +1 -0
  281. package/pulumi/apps/blueGreen/types.d.ts +77 -0
  282. package/pulumi/apps/blueGreen/types.js +3 -0
  283. package/pulumi/apps/blueGreen/types.js.map +1 -0
  284. package/pulumi/apps/blueGreen/validation/validateDeployments.d.ts +2 -0
  285. package/pulumi/apps/blueGreen/validation/validateDeployments.js +33 -0
  286. package/pulumi/apps/blueGreen/validation/validateDeployments.js.map +1 -0
  287. package/pulumi/apps/common/CoreOutput.d.ts +38 -0
  288. package/pulumi/apps/common/CoreOutput.js +46 -0
  289. package/pulumi/apps/common/CoreOutput.js.map +1 -0
  290. package/pulumi/apps/common/VpcConfig.d.ts +8 -0
  291. package/pulumi/apps/common/VpcConfig.js +25 -0
  292. package/pulumi/apps/common/VpcConfig.js.map +1 -0
  293. package/pulumi/apps/common/index.d.ts +2 -0
  294. package/pulumi/apps/common/index.js +4 -0
  295. package/pulumi/apps/common/index.js.map +1 -0
  296. package/pulumi/apps/core/CoreAuditLogsDynamo.d.ts +5 -0
  297. package/pulumi/apps/core/CoreAuditLogsDynamo.js +138 -0
  298. package/pulumi/apps/core/CoreAuditLogsDynamo.js.map +1 -0
  299. package/pulumi/apps/core/CoreCognito.d.ts +10 -0
  300. package/pulumi/apps/core/CoreCognito.js +110 -0
  301. package/pulumi/apps/core/CoreCognito.js.map +1 -0
  302. package/pulumi/apps/core/CoreDynamo.d.ts +5 -0
  303. package/pulumi/apps/core/CoreDynamo.js +61 -0
  304. package/pulumi/apps/core/CoreDynamo.js.map +1 -0
  305. package/pulumi/apps/core/CoreEventBus.d.ts +1 -0
  306. package/pulumi/apps/core/CoreEventBus.js +13 -0
  307. package/pulumi/apps/core/CoreEventBus.js.map +1 -0
  308. package/pulumi/apps/core/CoreFileManager.d.ts +8 -0
  309. package/pulumi/apps/core/CoreFileManager.js +44 -0
  310. package/pulumi/apps/core/CoreFileManager.js.map +1 -0
  311. package/pulumi/apps/core/CoreOpenSearch.d.ts +16 -0
  312. package/pulumi/apps/core/CoreOpenSearch.js +299 -0
  313. package/pulumi/apps/core/CoreOpenSearch.js.map +1 -0
  314. package/pulumi/apps/core/CoreVpc.d.ts +13 -0
  315. package/pulumi/apps/core/CoreVpc.js +160 -0
  316. package/pulumi/apps/core/CoreVpc.js.map +1 -0
  317. package/pulumi/apps/core/LogDynamo.d.ts +5 -0
  318. package/pulumi/apps/core/LogDynamo.js +94 -0
  319. package/pulumi/apps/core/LogDynamo.js.map +1 -0
  320. package/pulumi/apps/core/WatchCommand.d.ts +7 -0
  321. package/pulumi/apps/core/WatchCommand.js +105 -0
  322. package/pulumi/apps/core/WatchCommand.js.map +1 -0
  323. package/pulumi/apps/core/cognitoIdentityProviders/amazon.d.ts +9 -0
  324. package/pulumi/apps/core/cognitoIdentityProviders/amazon.js +24 -0
  325. package/pulumi/apps/core/cognitoIdentityProviders/amazon.js.map +1 -0
  326. package/pulumi/apps/core/cognitoIdentityProviders/apple.d.ts +4 -0
  327. package/pulumi/apps/core/cognitoIdentityProviders/apple.js +19 -0
  328. package/pulumi/apps/core/cognitoIdentityProviders/apple.js.map +1 -0
  329. package/pulumi/apps/core/cognitoIdentityProviders/configure.d.ts +28 -0
  330. package/pulumi/apps/core/cognitoIdentityProviders/configure.js +57 -0
  331. package/pulumi/apps/core/cognitoIdentityProviders/configure.js.map +1 -0
  332. package/pulumi/apps/core/cognitoIdentityProviders/facebook.d.ts +4 -0
  333. package/pulumi/apps/core/cognitoIdentityProviders/facebook.js +19 -0
  334. package/pulumi/apps/core/cognitoIdentityProviders/facebook.js.map +1 -0
  335. package/pulumi/apps/core/cognitoIdentityProviders/getIdpConfig.d.ts +3 -0
  336. package/pulumi/apps/core/cognitoIdentityProviders/getIdpConfig.js +17 -0
  337. package/pulumi/apps/core/cognitoIdentityProviders/getIdpConfig.js.map +1 -0
  338. package/pulumi/apps/core/cognitoIdentityProviders/google.d.ts +4 -0
  339. package/pulumi/apps/core/cognitoIdentityProviders/google.js +19 -0
  340. package/pulumi/apps/core/cognitoIdentityProviders/google.js.map +1 -0
  341. package/pulumi/apps/core/cognitoIdentityProviders/index.d.ts +1 -0
  342. package/pulumi/apps/core/cognitoIdentityProviders/index.js +3 -0
  343. package/pulumi/apps/core/cognitoIdentityProviders/index.js.map +1 -0
  344. package/pulumi/apps/core/cognitoIdentityProviders/oidc.d.ts +4 -0
  345. package/pulumi/apps/core/cognitoIdentityProviders/oidc.js +20 -0
  346. package/pulumi/apps/core/cognitoIdentityProviders/oidc.js.map +1 -0
  347. package/pulumi/apps/core/configureS3BucketMalwareProtection.d.ts +2 -0
  348. package/pulumi/apps/core/configureS3BucketMalwareProtection.js +195 -0
  349. package/pulumi/apps/core/configureS3BucketMalwareProtection.js.map +1 -0
  350. package/pulumi/apps/core/createCorePulumiApp.d.ts +32 -0
  351. package/pulumi/apps/core/createCorePulumiApp.js +296 -0
  352. package/pulumi/apps/core/createCorePulumiApp.js.map +1 -0
  353. package/pulumi/apps/core/index.d.ts +8 -0
  354. package/pulumi/apps/core/index.js +10 -0
  355. package/pulumi/apps/core/index.js.map +1 -0
  356. package/pulumi/apps/core/webinyWatchCommand/handler.d.ts +28 -0
  357. package/pulumi/apps/core/webinyWatchCommand/handler.js +37 -0
  358. package/pulumi/apps/core/webinyWatchCommand/handler.js.map +1 -0
  359. package/pulumi/apps/createAppBucket.d.ts +13 -0
  360. package/pulumi/apps/createAppBucket.js +112 -0
  361. package/pulumi/apps/createAppBucket.js.map +1 -0
  362. package/pulumi/apps/customDomain.d.ts +9 -0
  363. package/pulumi/apps/customDomain.js +9 -0
  364. package/pulumi/apps/customDomain.js.map +1 -0
  365. package/pulumi/apps/extensions/getAwsTagsFromExtension.d.ts +2 -0
  366. package/pulumi/apps/extensions/getAwsTagsFromExtension.js +10 -0
  367. package/pulumi/apps/extensions/getAwsTagsFromExtension.js.map +1 -0
  368. package/pulumi/apps/extensions/getBgDeploymentsConfigFromExtension.d.ts +23 -0
  369. package/pulumi/apps/extensions/getBgDeploymentsConfigFromExtension.js +10 -0
  370. package/pulumi/apps/extensions/getBgDeploymentsConfigFromExtension.js.map +1 -0
  371. package/pulumi/apps/extensions/getOsConfigFromExtension.d.ts +7 -0
  372. package/pulumi/apps/extensions/getOsConfigFromExtension.js +33 -0
  373. package/pulumi/apps/extensions/getOsConfigFromExtension.js.map +1 -0
  374. package/pulumi/apps/extensions/getVpcConfigFromExtension.d.ts +15 -0
  375. package/pulumi/apps/extensions/getVpcConfigFromExtension.js +29 -0
  376. package/pulumi/apps/extensions/getVpcConfigFromExtension.js.map +1 -0
  377. package/pulumi/apps/index.d.ts +6 -0
  378. package/pulumi/apps/index.js +8 -0
  379. package/pulumi/apps/index.js.map +1 -0
  380. package/pulumi/apps/lambdaUtils.d.ts +11 -0
  381. package/pulumi/apps/lambdaUtils.js +70 -0
  382. package/pulumi/apps/lambdaUtils.js.map +1 -0
  383. package/pulumi/apps/react/createReactPulumiApp.d.ts +30 -0
  384. package/pulumi/apps/react/createReactPulumiApp.js +150 -0
  385. package/pulumi/apps/react/createReactPulumiApp.js.map +1 -0
  386. package/pulumi/apps/react/index.d.ts +1 -0
  387. package/pulumi/apps/react/index.js +3 -0
  388. package/pulumi/apps/react/index.js.map +1 -0
  389. package/pulumi/apps/syncSystem/SyncSystemDynamo.d.ts +5 -0
  390. package/pulumi/apps/syncSystem/SyncSystemDynamo.js +56 -0
  391. package/pulumi/apps/syncSystem/SyncSystemDynamo.js.map +1 -0
  392. package/pulumi/apps/syncSystem/SyncSystemDynamoDb.d.ts +3 -0
  393. package/pulumi/apps/syncSystem/SyncSystemDynamoDb.js +52 -0
  394. package/pulumi/apps/syncSystem/SyncSystemDynamoDb.js.map +1 -0
  395. package/pulumi/apps/syncSystem/SyncSystemEventBus.d.ts +6 -0
  396. package/pulumi/apps/syncSystem/SyncSystemEventBus.js +77 -0
  397. package/pulumi/apps/syncSystem/SyncSystemEventBus.js.map +1 -0
  398. package/pulumi/apps/syncSystem/SyncSystemLambda.d.ts +11 -0
  399. package/pulumi/apps/syncSystem/SyncSystemLambda.js +99 -0
  400. package/pulumi/apps/syncSystem/SyncSystemLambda.js.map +1 -0
  401. package/pulumi/apps/syncSystem/SyncSystemOutput.d.ts +3 -0
  402. package/pulumi/apps/syncSystem/SyncSystemOutput.js +18 -0
  403. package/pulumi/apps/syncSystem/SyncSystemOutput.js.map +1 -0
  404. package/pulumi/apps/syncSystem/SyncSystemResolverLambda.d.ts +8 -0
  405. package/pulumi/apps/syncSystem/SyncSystemResolverLambda.js +73 -0
  406. package/pulumi/apps/syncSystem/SyncSystemResolverLambda.js.map +1 -0
  407. package/pulumi/apps/syncSystem/SyncSystemSQS.d.ts +3 -0
  408. package/pulumi/apps/syncSystem/SyncSystemSQS.js +54 -0
  409. package/pulumi/apps/syncSystem/SyncSystemSQS.js.map +1 -0
  410. package/pulumi/apps/syncSystem/SyncSystemWorkerLambda.d.ts +7 -0
  411. package/pulumi/apps/syncSystem/SyncSystemWorkerLambda.js +52 -0
  412. package/pulumi/apps/syncSystem/SyncSystemWorkerLambda.js.map +1 -0
  413. package/pulumi/apps/syncSystem/addTableItems.d.ts +8 -0
  414. package/pulumi/apps/syncSystem/addTableItems.js +51 -0
  415. package/pulumi/apps/syncSystem/addTableItems.js.map +1 -0
  416. package/pulumi/apps/syncSystem/api/addServiceManifest.d.ts +8 -0
  417. package/pulumi/apps/syncSystem/api/addServiceManifest.js +18 -0
  418. package/pulumi/apps/syncSystem/api/addServiceManifest.js.map +1 -0
  419. package/pulumi/apps/syncSystem/api/attachCognitoPermissions.d.ts +14 -0
  420. package/pulumi/apps/syncSystem/api/attachCognitoPermissions.js +59 -0
  421. package/pulumi/apps/syncSystem/api/attachCognitoPermissions.js.map +1 -0
  422. package/pulumi/apps/syncSystem/api/attachDynamoDbPermissions.d.ts +13 -0
  423. package/pulumi/apps/syncSystem/api/attachDynamoDbPermissions.js +44 -0
  424. package/pulumi/apps/syncSystem/api/attachDynamoDbPermissions.js.map +1 -0
  425. package/pulumi/apps/syncSystem/api/attachEventBusPermissions.d.ts +17 -0
  426. package/pulumi/apps/syncSystem/api/attachEventBusPermissions.js +48 -0
  427. package/pulumi/apps/syncSystem/api/attachEventBusPermissions.js.map +1 -0
  428. package/pulumi/apps/syncSystem/api/attachS3Permissions.d.ts +14 -0
  429. package/pulumi/apps/syncSystem/api/attachS3Permissions.js +51 -0
  430. package/pulumi/apps/syncSystem/api/attachS3Permissions.js.map +1 -0
  431. package/pulumi/apps/syncSystem/api/index.d.ts +8 -0
  432. package/pulumi/apps/syncSystem/api/index.js +55 -0
  433. package/pulumi/apps/syncSystem/api/index.js.map +1 -0
  434. package/pulumi/apps/syncSystem/constants.d.ts +1 -0
  435. package/pulumi/apps/syncSystem/constants.js +3 -0
  436. package/pulumi/apps/syncSystem/constants.js.map +1 -0
  437. package/pulumi/apps/syncSystem/createSyncResourceName.d.ts +4 -0
  438. package/pulumi/apps/syncSystem/createSyncResourceName.js +10 -0
  439. package/pulumi/apps/syncSystem/createSyncResourceName.js.map +1 -0
  440. package/pulumi/apps/syncSystem/createSyncSystemPulumiApp.d.ts +26 -0
  441. package/pulumi/apps/syncSystem/createSyncSystemPulumiApp.js +181 -0
  442. package/pulumi/apps/syncSystem/createSyncSystemPulumiApp.js.map +1 -0
  443. package/pulumi/apps/syncSystem/customApp.d.ts +6 -0
  444. package/pulumi/apps/syncSystem/customApp.js +19 -0
  445. package/pulumi/apps/syncSystem/customApp.js.map +1 -0
  446. package/pulumi/apps/syncSystem/getSyncSystemOutput.d.ts +3 -0
  447. package/pulumi/apps/syncSystem/getSyncSystemOutput.js +10 -0
  448. package/pulumi/apps/syncSystem/getSyncSystemOutput.js.map +1 -0
  449. package/pulumi/apps/syncSystem/lambda/createSyncSystemResolverLambdaPolicy.d.ts +7 -0
  450. package/pulumi/apps/syncSystem/lambda/createSyncSystemResolverLambdaPolicy.js +48 -0
  451. package/pulumi/apps/syncSystem/lambda/createSyncSystemResolverLambdaPolicy.js.map +1 -0
  452. package/pulumi/apps/syncSystem/types.d.ts +56 -0
  453. package/pulumi/apps/syncSystem/types.js +3 -0
  454. package/pulumi/apps/syncSystem/types.js.map +1 -0
  455. package/pulumi/constants.d.ts +1 -0
  456. package/pulumi/constants.js +4 -0
  457. package/pulumi/constants.js.map +1 -0
  458. package/pulumi/env/awsRegion.d.ts +1 -0
  459. package/pulumi/env/awsRegion.js +6 -0
  460. package/pulumi/env/awsRegion.js.map +1 -0
  461. package/pulumi/env/base.d.ts +15 -0
  462. package/pulumi/env/base.js +29 -0
  463. package/pulumi/env/base.js.map +1 -0
  464. package/pulumi/env/env.d.ts +1 -0
  465. package/pulumi/env/env.js +6 -0
  466. package/pulumi/env/env.js.map +1 -0
  467. package/pulumi/env/projectName.d.ts +1 -0
  468. package/pulumi/env/projectName.js +6 -0
  469. package/pulumi/env/projectName.js.map +1 -0
  470. package/pulumi/env/variant.d.ts +1 -0
  471. package/pulumi/env/variant.js +7 -0
  472. package/pulumi/env/variant.js.map +1 -0
  473. package/pulumi/extensions/AdminCustomDomains.d.ts +14 -0
  474. package/pulumi/extensions/AdminCustomDomains.js +16 -0
  475. package/pulumi/extensions/AdminCustomDomains.js.map +1 -0
  476. package/pulumi/extensions/AwsTags.d.ts +8 -0
  477. package/pulumi/extensions/AwsTags.js +15 -0
  478. package/pulumi/extensions/AwsTags.js.map +1 -0
  479. package/pulumi/extensions/BlueGreenDeployments.d.ts +134 -0
  480. package/pulumi/extensions/BlueGreenDeployments.js +34 -0
  481. package/pulumi/extensions/BlueGreenDeployments.js.map +1 -0
  482. package/pulumi/extensions/OpenSearch.d.ts +17 -0
  483. package/pulumi/extensions/OpenSearch.js +17 -0
  484. package/pulumi/extensions/OpenSearch.js.map +1 -0
  485. package/pulumi/extensions/Vpc.d.ts +71 -0
  486. package/pulumi/extensions/Vpc.js +25 -0
  487. package/pulumi/extensions/Vpc.js.map +1 -0
  488. package/pulumi/extensions/index.d.ts +220 -0
  489. package/pulumi/extensions/index.js +13 -0
  490. package/pulumi/extensions/index.js.map +1 -0
  491. package/pulumi/index.d.ts +3 -0
  492. package/pulumi/index.js +5 -0
  493. package/pulumi/index.js.map +1 -0
  494. package/pulumi/types.d.ts +44 -0
  495. package/pulumi/types.js +3 -0
  496. package/pulumi/types.js.map +1 -0
  497. package/pulumi/utils/addDomainsUrlsOutputs.d.ts +18 -0
  498. package/pulumi/utils/addDomainsUrlsOutputs.js +40 -0
  499. package/pulumi/utils/addDomainsUrlsOutputs.js.map +1 -0
  500. package/pulumi/utils/addServiceManifestTableItem.d.ts +12 -0
  501. package/pulumi/utils/addServiceManifestTableItem.js +28 -0
  502. package/pulumi/utils/addServiceManifestTableItem.js.map +1 -0
  503. package/pulumi/utils/crawlDirectory.d.ts +1 -0
  504. package/pulumi/utils/crawlDirectory.js +19 -0
  505. package/pulumi/utils/crawlDirectory.js.map +1 -0
  506. package/pulumi/utils/createAssetArchive.d.ts +2 -0
  507. package/pulumi/utils/createAssetArchive.js +8 -0
  508. package/pulumi/utils/createAssetArchive.js.map +1 -0
  509. package/pulumi/utils/dynamodb.d.ts +14 -0
  510. package/pulumi/utils/dynamodb.js +29 -0
  511. package/pulumi/utils/dynamodb.js.map +1 -0
  512. package/pulumi/utils/getPresignedPost.d.ts +11 -0
  513. package/pulumi/utils/getPresignedPost.js +34 -0
  514. package/pulumi/utils/getPresignedPost.js.map +1 -0
  515. package/pulumi/utils/index.d.ts +5 -0
  516. package/pulumi/utils/index.js +7 -0
  517. package/pulumi/utils/index.js.map +1 -0
  518. package/pulumi/utils/lambdaEnvVariables.d.ts +20 -0
  519. package/pulumi/utils/lambdaEnvVariables.js +62 -0
  520. package/pulumi/utils/lambdaEnvVariables.js.map +1 -0
  521. package/pulumi/utils/tagResources.d.ts +5 -0
  522. package/pulumi/utils/tagResources.js +33 -0
  523. package/pulumi/utils/tagResources.js.map +1 -0
  524. package/pulumi/utils/uploadFolderToS3.d.ts +26 -0
  525. package/pulumi/utils/uploadFolderToS3.js +147 -0
  526. package/pulumi/utils/uploadFolderToS3.js.map +1 -0
  527. package/pulumi/utils/withServiceManifest.d.ts +14 -0
  528. package/pulumi/utils/withServiceManifest.js +45 -0
  529. package/pulumi/utils/withServiceManifest.js.map +1 -0
  530. package/security.d.ts +356 -0
  531. package/security.js +53 -0
  532. package/security.js.map +1 -0
  533. package/services/AdminStackOutputService.d.ts +10 -0
  534. package/services/AdminStackOutputService.js +16 -0
  535. package/services/AdminStackOutputService.js.map +1 -0
  536. package/services/ApiStackOutputService.d.ts +10 -0
  537. package/services/ApiStackOutputService.js +16 -0
  538. package/services/ApiStackOutputService.js.map +1 -0
  539. package/services/CoreStackOutputService.d.ts +10 -0
  540. package/services/CoreStackOutputService.js +16 -0
  541. package/services/CoreStackOutputService.js.map +1 -0
  542. package/utils/getTemplatesFolderPath.d.ts +1 -0
  543. package/utils/getTemplatesFolderPath.js +16 -0
  544. package/utils/getTemplatesFolderPath.js.map +1 -0
  545. package/utils/index.d.ts +1 -0
  546. package/utils/index.js +3 -0
  547. package/utils/index.js.map +1 -0
@@ -0,0 +1,164 @@
1
+ import path from "path";
2
+ import * as pulumi from "@pulumi/pulumi";
3
+ import * as aws from "@pulumi/aws";
4
+ import toKebabCase from "lodash/kebabCase.js";
5
+ import { createAppModule } from "@webiny/pulumi";
6
+ import { createLambdaRole, getCommonLambdaEnvVariables } from "../lambdaUtils.js";
7
+ import { CoreOutput, VpcConfig } from "../index.js";
8
+ import { getAwsAccountId, getAwsRegion } from "../awsUtils.js";
9
+ import { LAMBDA_RUNTIME } from "../../constants.js";
10
+ const EMPTY_TRASH_BIN_EVENT_RULE_NAME = `empty-trash-bin-event-rule`;
11
+ const EMPTY_TRASH_BIN_EVENT_PERMISSION_NAME = `empty-trash-bin-event-target-permission`;
12
+ const EMPTY_TRASH_BIN_EVENT_RULE_TARGET = `empty-trash-bin-event-rule-target`;
13
+ export const ApiGraphql = createAppModule({
14
+ name: "ApiGraphql",
15
+ config(app, params) {
16
+ const policy = createGraphqlLambdaPolicy(app);
17
+ const role = createLambdaRole(app, {
18
+ name: "api-lambda-role",
19
+ policy: policy.output
20
+ });
21
+ const graphql = app.addResource(aws.lambda.Function, {
22
+ name: "graphql",
23
+ config: {
24
+ description: "Webiny's GraphQL APIs",
25
+ runtime: LAMBDA_RUNTIME,
26
+ handler: "handler.handler",
27
+ role: role.output.arn,
28
+ timeout: 30,
29
+ memorySize: 1024,
30
+ code: new pulumi.asset.AssetArchive({
31
+ ".": new pulumi.asset.FileArchive(path.join(app.paths.workspace, "graphql/build"))
32
+ }),
33
+ environment: {
34
+ variables: getCommonLambdaEnvVariables().apply(value => ({
35
+ ...value,
36
+ ...params.env,
37
+ AWS_NODEJS_CONNECTION_REUSE_ENABLED: "1"
38
+ }))
39
+ },
40
+ vpcConfig: app.getModule(VpcConfig).functionVpcConfig,
41
+ loggingConfig: {
42
+ logFormat: "JSON"
43
+ }
44
+ }
45
+ });
46
+
47
+ // Create event rule.
48
+ const eventRule = app.addResource(aws.cloudwatch.EventRule, {
49
+ name: EMPTY_TRASH_BIN_EVENT_RULE_NAME,
50
+ config: {
51
+ description: "Enable us to empty the trash-bin ever day",
52
+ scheduleExpression: "cron(0 3 * * ? *)"
53
+ }
54
+ });
55
+
56
+ // Add required permission to the target lambda.
57
+ app.addResource(aws.lambda.Permission, {
58
+ name: EMPTY_TRASH_BIN_EVENT_PERMISSION_NAME,
59
+ config: {
60
+ action: "lambda:InvokeFunction",
61
+ function: graphql.output.arn,
62
+ principal: "events.amazonaws.com",
63
+ statementId: "allow-rule-invoke-" + EMPTY_TRASH_BIN_EVENT_RULE_NAME
64
+ }
65
+ });
66
+
67
+ // Target the main graphql lambda.
68
+ app.addResource(aws.cloudwatch.EventTarget, {
69
+ name: EMPTY_TRASH_BIN_EVENT_RULE_TARGET,
70
+ config: {
71
+ rule: eventRule.output.name,
72
+ arn: graphql.output.arn,
73
+ input: JSON.stringify({
74
+ source: "webiny.events",
75
+ "detail-type": "WebinyEmptyTrashBin"
76
+ })
77
+ }
78
+ });
79
+ return {
80
+ role,
81
+ policy,
82
+ functions: {
83
+ graphql
84
+ },
85
+ addRoute: routeParams => {
86
+ const apiGateway = app.resources.apiGateway;
87
+ if (!apiGateway) {
88
+ console.log("Could not add route because there is no apiGateway in the resources.");
89
+ return;
90
+ }
91
+ const kebabName = toKebabCase(routeParams.name);
92
+ if (kebabName !== routeParams.name) {
93
+ console.log(`Route name is not allowed: "${routeParams.name}".`);
94
+ return;
95
+ }
96
+ return apiGateway.addRoute(routeParams.name, {
97
+ path: routeParams.path,
98
+ method: routeParams.method,
99
+ function: graphql.output.arn
100
+ });
101
+ }
102
+ };
103
+ }
104
+ });
105
+ function createGraphqlLambdaPolicy(app) {
106
+ const coreOutput = app.getModule(CoreOutput);
107
+ const awsAccountId = getAwsAccountId(app);
108
+ const awsRegion = getAwsRegion(app);
109
+ return app.addResource(aws.iam.Policy, {
110
+ name: "ApiGraphqlLambdaPolicy",
111
+ config: {
112
+ description: "This policy enables access to Dynamodb, S3, Lambda and Cognito IDP",
113
+ // Core is pulumi.Output, so we need to run apply() to resolve policy based on it
114
+ policy: pulumi.all([coreOutput]).apply(([core]) => {
115
+ const policy = {
116
+ Version: "2012-10-17",
117
+ Statement: [{
118
+ Sid: "PermissionForDynamodb",
119
+ Effect: "Allow",
120
+ Action: ["dynamodb:BatchGetItem", "dynamodb:BatchWriteItem", "dynamodb:ConditionCheckItem", "dynamodb:CreateBackup", "dynamodb:CreateTable", "dynamodb:CreateTableReplica", "dynamodb:DeleteBackup", "dynamodb:DeleteItem", "dynamodb:DeleteTable", "dynamodb:DeleteTableReplica", "dynamodb:DescribeBackup", "dynamodb:DescribeContinuousBackups", "dynamodb:DescribeContributorInsights", "dynamodb:DescribeExport", "dynamodb:DescribeKinesisStreamingDestination", "dynamodb:DescribeLimits", "dynamodb:DescribeReservedCapacity", "dynamodb:DescribeReservedCapacityOfferings", "dynamodb:DescribeStream", "dynamodb:DescribeTable", "dynamodb:DescribeTableReplicaAutoScaling", "dynamodb:DescribeTimeToLive", "dynamodb:DisableKinesisStreamingDestination", "dynamodb:EnableKinesisStreamingDestination", "dynamodb:ExportTableToPointInTime", "dynamodb:GetItem", "dynamodb:GetRecords", "dynamodb:GetShardIterator", "dynamodb:ListBackups", "dynamodb:ListContributorInsights", "dynamodb:ListExports", "dynamodb:ListStreams", "dynamodb:ListTables", "dynamodb:ListTagsOfResource", "dynamodb:PartiQLDelete", "dynamodb:PartiQLInsert", "dynamodb:PartiQLSelect", "dynamodb:PartiQLUpdate", "dynamodb:PurchaseReservedCapacityOfferings", "dynamodb:PutItem", "dynamodb:Query", "dynamodb:RestoreTableFromBackup", "dynamodb:RestoreTableToPointInTime", "dynamodb:Scan", "dynamodb:UpdateContinuousBackups", "dynamodb:UpdateContributorInsights", "dynamodb:UpdateItem", "dynamodb:UpdateTable", "dynamodb:UpdateTableReplicaAutoScaling", "dynamodb:UpdateTimeToLive"],
121
+ Resource: [`${core.primaryDynamodbTableArn}`, `${core.primaryDynamodbTableArn}/*`, `${core.logDynamodbTableArn}`, `${core.logDynamodbTableArn}/*`, `${core.auditLogsDynamodbTableArn}`, `${core.auditLogsDynamodbTableArn}/*`,
122
+ // Attach permissions for elastic search dynamo as well (if ES is enabled).
123
+ ...(core.opensearchDynamodbTableArn ? [`${core.opensearchDynamodbTableArn}`, `${core.opensearchDynamodbTableArn}/*`] : [])]
124
+ }, {
125
+ Sid: "PermissionForS3",
126
+ Effect: "Allow",
127
+ Action: ["s3:ListBucket", "s3:GetObjectAcl", "s3:DeleteObject", "s3:PutObjectAcl", "s3:PutObject", "s3:GetObject"],
128
+ Resource: [pulumi.interpolate`arn:aws:s3:::${core.fileManagerBucketId}`, pulumi.interpolate`arn:aws:s3:::${core.fileManagerBucketId}/*`]
129
+ }, {
130
+ Sid: "PermissionForLambda",
131
+ Effect: "Allow",
132
+ Action: ["lambda:InvokeFunction"],
133
+ Resource: pulumi.interpolate`arn:aws:lambda:${awsRegion}:${awsAccountId}:function:*`
134
+ }, {
135
+ Sid: "PermissionForCognitoIdp",
136
+ Effect: "Allow",
137
+ Action: "cognito-idp:*",
138
+ Resource: `${core.cognitoUserPoolArn}`
139
+ }, {
140
+ Sid: "PermissionForEventBus",
141
+ Effect: "Allow",
142
+ Action: "events:PutEvents",
143
+ Resource: core.eventBusArn
144
+ }, {
145
+ Sid: "PermissionForCloudfront",
146
+ Effect: "Allow",
147
+ Action: "cloudfront:CreateInvalidation",
148
+ Resource: pulumi.interpolate`arn:aws:cloudfront::${awsAccountId}:distribution/*`
149
+ },
150
+ // Attach permissions for elastic search domain as well (if ES is enabled).
151
+ ...(core.opensearchDomainArn ? [{
152
+ Sid: "PermissionForOS",
153
+ Effect: "Allow",
154
+ Action: "es:*",
155
+ Resource: [`${core.opensearchDomainArn}`, `${core.opensearchDomainArn}/*`]
156
+ }] : [])]
157
+ };
158
+ return policy;
159
+ })
160
+ }
161
+ });
162
+ }
163
+
164
+ //# sourceMappingURL=ApiGraphql.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["path","pulumi","aws","toKebabCase","createAppModule","createLambdaRole","getCommonLambdaEnvVariables","CoreOutput","VpcConfig","getAwsAccountId","getAwsRegion","LAMBDA_RUNTIME","EMPTY_TRASH_BIN_EVENT_RULE_NAME","EMPTY_TRASH_BIN_EVENT_PERMISSION_NAME","EMPTY_TRASH_BIN_EVENT_RULE_TARGET","ApiGraphql","name","config","app","params","policy","createGraphqlLambdaPolicy","role","output","graphql","addResource","lambda","Function","description","runtime","handler","arn","timeout","memorySize","code","asset","AssetArchive","FileArchive","join","paths","workspace","environment","variables","apply","value","env","AWS_NODEJS_CONNECTION_REUSE_ENABLED","vpcConfig","getModule","functionVpcConfig","loggingConfig","logFormat","eventRule","cloudwatch","EventRule","scheduleExpression","Permission","action","function","principal","statementId","EventTarget","rule","input","JSON","stringify","source","functions","addRoute","routeParams","apiGateway","resources","console","log","kebabName","method","coreOutput","awsAccountId","awsRegion","iam","Policy","all","core","Version","Statement","Sid","Effect","Action","Resource","primaryDynamodbTableArn","logDynamodbTableArn","auditLogsDynamodbTableArn","opensearchDynamodbTableArn","interpolate","fileManagerBucketId","cognitoUserPoolArn","eventBusArn","opensearchDomainArn"],"sources":["ApiGraphql.ts"],"sourcesContent":["import path from \"path\";\nimport * as pulumi from \"@pulumi/pulumi\";\nimport * as aws from \"@pulumi/aws\";\nimport toKebabCase from \"lodash/kebabCase.js\";\nimport type { PulumiApp, PulumiAppModule } from \"@webiny/pulumi\";\nimport { createAppModule } from \"@webiny/pulumi\";\nimport { createLambdaRole, getCommonLambdaEnvVariables } from \"../lambdaUtils.js\";\nimport { CoreOutput, VpcConfig } from \"~/pulumi/apps/index.js\";\nimport { getAwsAccountId, getAwsRegion } from \"../awsUtils.js\";\nimport { LAMBDA_RUNTIME } from \"~/pulumi/constants.js\";\n\ninterface GraphqlParams {\n env: Record<string, any>;\n}\n\nexport interface AddRouteParams {\n /**\n * Must be in kebab case (a-z and -)\n */\n name: string;\n path: `/${string}`;\n method: \"DELETE\" | \"GET\" | \"HEAD\" | \"PATCH\" | \"POST\" | \"PUT\" | \"OPTIONS\" | \"ANY\";\n}\n\nconst EMPTY_TRASH_BIN_EVENT_RULE_NAME = `empty-trash-bin-event-rule`;\nconst EMPTY_TRASH_BIN_EVENT_PERMISSION_NAME = `empty-trash-bin-event-target-permission`;\nconst EMPTY_TRASH_BIN_EVENT_RULE_TARGET = `empty-trash-bin-event-rule-target`;\n\nexport type ApiGraphql = PulumiAppModule<typeof ApiGraphql>;\n\nexport const ApiGraphql = createAppModule({\n name: \"ApiGraphql\",\n config(app: PulumiApp, params: GraphqlParams) {\n const policy = createGraphqlLambdaPolicy(app);\n const role = createLambdaRole(app, {\n name: \"api-lambda-role\",\n policy: policy.output\n });\n\n const graphql = app.addResource(aws.lambda.Function, {\n name: \"graphql\",\n config: {\n description: \"Webiny's GraphQL APIs\",\n runtime: LAMBDA_RUNTIME,\n handler: \"handler.handler\",\n role: role.output.arn,\n timeout: 30,\n memorySize: 1024,\n code: new pulumi.asset.AssetArchive({\n \".\": new pulumi.asset.FileArchive(\n path.join(app.paths.workspace, \"graphql/build\")\n )\n }),\n environment: {\n variables: getCommonLambdaEnvVariables().apply(value => ({\n ...value,\n ...params.env,\n AWS_NODEJS_CONNECTION_REUSE_ENABLED: \"1\"\n }))\n },\n vpcConfig: app.getModule(VpcConfig).functionVpcConfig,\n loggingConfig: {\n logFormat: \"JSON\"\n }\n }\n });\n\n // Create event rule.\n const eventRule = app.addResource(aws.cloudwatch.EventRule, {\n name: EMPTY_TRASH_BIN_EVENT_RULE_NAME,\n config: {\n description: \"Enable us to empty the trash-bin ever day\",\n scheduleExpression: \"cron(0 3 * * ? *)\"\n }\n });\n\n // Add required permission to the target lambda.\n app.addResource(aws.lambda.Permission, {\n name: EMPTY_TRASH_BIN_EVENT_PERMISSION_NAME,\n config: {\n action: \"lambda:InvokeFunction\",\n function: graphql.output.arn,\n principal: \"events.amazonaws.com\",\n statementId: \"allow-rule-invoke-\" + EMPTY_TRASH_BIN_EVENT_RULE_NAME\n }\n });\n\n // Target the main graphql lambda.\n app.addResource(aws.cloudwatch.EventTarget, {\n name: EMPTY_TRASH_BIN_EVENT_RULE_TARGET,\n config: {\n rule: eventRule.output.name,\n arn: graphql.output.arn,\n input: JSON.stringify({\n source: \"webiny.events\",\n \"detail-type\": \"WebinyEmptyTrashBin\"\n })\n }\n });\n\n return {\n role,\n policy,\n functions: {\n graphql\n },\n addRoute: (routeParams: AddRouteParams) => {\n const apiGateway: any = app.resources.apiGateway;\n if (!apiGateway) {\n console.log(\n \"Could not add route because there is no apiGateway in the resources.\"\n );\n return;\n }\n const kebabName = toKebabCase(routeParams.name);\n if (kebabName !== routeParams.name) {\n console.log(`Route name is not allowed: \"${routeParams.name}\".`);\n return;\n }\n return apiGateway.addRoute(routeParams.name, {\n path: routeParams.path,\n method: routeParams.method,\n function: graphql.output.arn\n });\n }\n };\n }\n});\n\nfunction createGraphqlLambdaPolicy(app: PulumiApp) {\n const coreOutput = app.getModule(CoreOutput);\n const awsAccountId = getAwsAccountId(app);\n const awsRegion = getAwsRegion(app);\n\n return app.addResource(aws.iam.Policy, {\n name: \"ApiGraphqlLambdaPolicy\",\n config: {\n description: \"This policy enables access to Dynamodb, S3, Lambda and Cognito IDP\",\n // Core is pulumi.Output, so we need to run apply() to resolve policy based on it\n policy: pulumi.all([coreOutput]).apply(([core]) => {\n const policy: aws.iam.PolicyDocument = {\n Version: \"2012-10-17\",\n Statement: [\n {\n Sid: \"PermissionForDynamodb\",\n Effect: \"Allow\",\n Action: [\n \"dynamodb:BatchGetItem\",\n \"dynamodb:BatchWriteItem\",\n \"dynamodb:ConditionCheckItem\",\n \"dynamodb:CreateBackup\",\n \"dynamodb:CreateTable\",\n \"dynamodb:CreateTableReplica\",\n \"dynamodb:DeleteBackup\",\n \"dynamodb:DeleteItem\",\n \"dynamodb:DeleteTable\",\n \"dynamodb:DeleteTableReplica\",\n \"dynamodb:DescribeBackup\",\n \"dynamodb:DescribeContinuousBackups\",\n \"dynamodb:DescribeContributorInsights\",\n \"dynamodb:DescribeExport\",\n \"dynamodb:DescribeKinesisStreamingDestination\",\n \"dynamodb:DescribeLimits\",\n \"dynamodb:DescribeReservedCapacity\",\n \"dynamodb:DescribeReservedCapacityOfferings\",\n \"dynamodb:DescribeStream\",\n \"dynamodb:DescribeTable\",\n \"dynamodb:DescribeTableReplicaAutoScaling\",\n \"dynamodb:DescribeTimeToLive\",\n \"dynamodb:DisableKinesisStreamingDestination\",\n \"dynamodb:EnableKinesisStreamingDestination\",\n \"dynamodb:ExportTableToPointInTime\",\n \"dynamodb:GetItem\",\n \"dynamodb:GetRecords\",\n \"dynamodb:GetShardIterator\",\n \"dynamodb:ListBackups\",\n \"dynamodb:ListContributorInsights\",\n \"dynamodb:ListExports\",\n \"dynamodb:ListStreams\",\n \"dynamodb:ListTables\",\n \"dynamodb:ListTagsOfResource\",\n \"dynamodb:PartiQLDelete\",\n \"dynamodb:PartiQLInsert\",\n \"dynamodb:PartiQLSelect\",\n \"dynamodb:PartiQLUpdate\",\n \"dynamodb:PurchaseReservedCapacityOfferings\",\n \"dynamodb:PutItem\",\n \"dynamodb:Query\",\n \"dynamodb:RestoreTableFromBackup\",\n \"dynamodb:RestoreTableToPointInTime\",\n \"dynamodb:Scan\",\n \"dynamodb:UpdateContinuousBackups\",\n \"dynamodb:UpdateContributorInsights\",\n \"dynamodb:UpdateItem\",\n \"dynamodb:UpdateTable\",\n \"dynamodb:UpdateTableReplicaAutoScaling\",\n \"dynamodb:UpdateTimeToLive\"\n ],\n Resource: [\n `${core.primaryDynamodbTableArn}`,\n `${core.primaryDynamodbTableArn}/*`,\n `${core.logDynamodbTableArn}`,\n `${core.logDynamodbTableArn}/*`,\n `${core.auditLogsDynamodbTableArn}`,\n `${core.auditLogsDynamodbTableArn}/*`,\n // Attach permissions for elastic search dynamo as well (if ES is enabled).\n ...(core.opensearchDynamodbTableArn\n ? [\n `${core.opensearchDynamodbTableArn}`,\n `${core.opensearchDynamodbTableArn}/*`\n ]\n : [])\n ]\n },\n {\n Sid: \"PermissionForS3\",\n Effect: \"Allow\",\n Action: [\n \"s3:ListBucket\",\n \"s3:GetObjectAcl\",\n \"s3:DeleteObject\",\n \"s3:PutObjectAcl\",\n \"s3:PutObject\",\n \"s3:GetObject\"\n ],\n Resource: [\n pulumi.interpolate`arn:aws:s3:::${core.fileManagerBucketId}`,\n pulumi.interpolate`arn:aws:s3:::${core.fileManagerBucketId}/*`\n ]\n },\n {\n Sid: \"PermissionForLambda\",\n Effect: \"Allow\",\n Action: [\"lambda:InvokeFunction\"],\n Resource: pulumi.interpolate`arn:aws:lambda:${awsRegion}:${awsAccountId}:function:*`\n },\n {\n Sid: \"PermissionForCognitoIdp\",\n Effect: \"Allow\",\n Action: \"cognito-idp:*\",\n Resource: `${core.cognitoUserPoolArn}`\n },\n {\n Sid: \"PermissionForEventBus\",\n Effect: \"Allow\",\n Action: \"events:PutEvents\",\n Resource: core.eventBusArn\n },\n {\n Sid: \"PermissionForCloudfront\",\n Effect: \"Allow\",\n Action: \"cloudfront:CreateInvalidation\",\n Resource: pulumi.interpolate`arn:aws:cloudfront::${awsAccountId}:distribution/*`\n },\n // Attach permissions for elastic search domain as well (if ES is enabled).\n ...(core.opensearchDomainArn\n ? [\n {\n Sid: \"PermissionForOS\",\n Effect: \"Allow\" as const,\n Action: \"es:*\",\n Resource: [\n `${core.opensearchDomainArn}`,\n `${core.opensearchDomainArn}/*`\n ]\n }\n ]\n : [])\n ]\n };\n\n return policy;\n })\n }\n });\n}\n"],"mappings":"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","ignoreList":[]}
@@ -0,0 +1,5 @@
1
+ import type { PulumiAppModule } from "@webiny/pulumi";
2
+ export type ApiMigration = PulumiAppModule<typeof ApiMigration>;
3
+ export declare const ApiMigration: import("@webiny/pulumi").PulumiAppModuleDefinition<{
4
+ function: import("@webiny/pulumi").PulumiAppResource<typeof import("@pulumi/aws/lambda/function.js").Function>;
5
+ }, void>;
@@ -0,0 +1,83 @@
1
+ import path from "path";
2
+ import * as pulumi from "@pulumi/pulumi";
3
+ import * as aws from "@pulumi/aws";
4
+ import { createAppModule } from "@webiny/pulumi";
5
+ import { createLambdaRole, getCommonLambdaEnvVariables } from "../lambdaUtils.js";
6
+ import { CoreOutput, VpcConfig } from "../common/index.js";
7
+ import { ApiBackgroundTask, ApiGraphql } from "../index.js";
8
+ import { LAMBDA_RUNTIME } from "../../constants.js";
9
+ import { getEnvVariableAwsRegion } from "../../env/awsRegion.js";
10
+ export const ApiMigration = createAppModule({
11
+ name: "ApiMigration",
12
+ config(app) {
13
+ const core = app.getModule(CoreOutput);
14
+ const graphql = app.getModule(ApiGraphql);
15
+ const backgroundTask = app.getModule(ApiBackgroundTask);
16
+ const role = createLambdaRole(app, {
17
+ name: "migration-lambda-role",
18
+ policy: graphql.policy.output
19
+ });
20
+ const migration = app.addResource(aws.lambda.Function, {
21
+ name: "data-migration",
22
+ config: {
23
+ handler: "handler.handler",
24
+ timeout: 900,
25
+ runtime: LAMBDA_RUNTIME,
26
+ memorySize: 3008,
27
+ role: role.output.arn,
28
+ description: "Performs data migrations.",
29
+ code: new pulumi.asset.AssetArchive({
30
+ ".": new pulumi.asset.FileArchive(path.join(app.paths.workspace, "migration/build"))
31
+ }),
32
+ environment: {
33
+ variables: getCommonLambdaEnvVariables().apply(value => ({
34
+ ...value,
35
+ COGNITO_REGION: getEnvVariableAwsRegion(),
36
+ COGNITO_USER_POOL_ID: core.cognitoUserPoolId,
37
+ DB_TABLE: core.primaryDynamodbTableName,
38
+ DB_TABLE_LOG: core.logDynamodbTableName,
39
+ DB_TABLE_AUDIT_LOGS: core.auditLogsDynamodbTableName,
40
+ DB_TABLE_OPENSEARCH: core.opensearchDynamodbTableName,
41
+ OPENSEARCH_ENDPOINT: core.opensearchDomainEndpoint,
42
+ OPENSEARCH_INDEX_PREFIX: process.env.OPENSEARCH_INDEX_PREFIX,
43
+ OPENSEARCH_SHARED_INDEXES: process.env.OPENSEARCH_SHARED_INDEXES,
44
+ S3_BUCKET: core.fileManagerBucketId
45
+ }))
46
+ },
47
+ vpcConfig: app.getModule(VpcConfig).functionVpcConfig,
48
+ loggingConfig: {
49
+ logFormat: "JSON"
50
+ }
51
+ }
52
+ });
53
+
54
+ // Add IAM policy to allow states:StartExecution for the background task Step Function
55
+ const stepFunctionPolicy = app.addResource(aws.iam.Policy, {
56
+ name: "migration-lambda-step-function-policy",
57
+ config: {
58
+ policy: {
59
+ Version: "2012-10-17",
60
+ Statement: [{
61
+ Effect: "Allow",
62
+ Action: ["states:StartExecution"],
63
+ Resource: [pulumi.interpolate`${backgroundTask.stepFunction.output.arn}`, pulumi.interpolate`${backgroundTask.stepFunction.output.arn}/*`]
64
+ }]
65
+ }
66
+ }
67
+ });
68
+
69
+ // Attach policy to the Lambda role
70
+ app.addResource(aws.iam.RolePolicyAttachment, {
71
+ name: "migration-lambda-attach-step-function-policy",
72
+ config: {
73
+ role: role.output.name,
74
+ policyArn: stepFunctionPolicy.output.arn
75
+ }
76
+ });
77
+ return {
78
+ function: migration
79
+ };
80
+ }
81
+ });
82
+
83
+ //# sourceMappingURL=ApiMigration.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["path","pulumi","aws","createAppModule","createLambdaRole","getCommonLambdaEnvVariables","CoreOutput","VpcConfig","ApiBackgroundTask","ApiGraphql","LAMBDA_RUNTIME","getEnvVariableAwsRegion","ApiMigration","name","config","app","core","getModule","graphql","backgroundTask","role","policy","output","migration","addResource","lambda","Function","handler","timeout","runtime","memorySize","arn","description","code","asset","AssetArchive","FileArchive","join","paths","workspace","environment","variables","apply","value","COGNITO_REGION","COGNITO_USER_POOL_ID","cognitoUserPoolId","DB_TABLE","primaryDynamodbTableName","DB_TABLE_LOG","logDynamodbTableName","DB_TABLE_AUDIT_LOGS","auditLogsDynamodbTableName","DB_TABLE_OPENSEARCH","opensearchDynamodbTableName","OPENSEARCH_ENDPOINT","opensearchDomainEndpoint","OPENSEARCH_INDEX_PREFIX","process","env","OPENSEARCH_SHARED_INDEXES","S3_BUCKET","fileManagerBucketId","vpcConfig","functionVpcConfig","loggingConfig","logFormat","stepFunctionPolicy","iam","Policy","Version","Statement","Effect","Action","Resource","interpolate","stepFunction","RolePolicyAttachment","policyArn","function"],"sources":["ApiMigration.ts"],"sourcesContent":["import path from \"path\";\nimport * as pulumi from \"@pulumi/pulumi\";\nimport * as aws from \"@pulumi/aws\";\nimport type { PulumiApp, PulumiAppModule } from \"@webiny/pulumi\";\nimport { createAppModule } from \"@webiny/pulumi\";\nimport { createLambdaRole, getCommonLambdaEnvVariables } from \"../lambdaUtils.js\";\nimport { CoreOutput, VpcConfig } from \"../common/index.js\";\nimport { ApiBackgroundTask, ApiGraphql } from \"~/pulumi/apps/index.js\";\nimport { LAMBDA_RUNTIME } from \"~/pulumi/constants.js\";\nimport { getEnvVariableAwsRegion } from \"~/pulumi/env/awsRegion.js\";\n\nexport type ApiMigration = PulumiAppModule<typeof ApiMigration>;\n\nexport const ApiMigration = createAppModule({\n name: \"ApiMigration\",\n config(app: PulumiApp) {\n const core = app.getModule(CoreOutput);\n const graphql = app.getModule(ApiGraphql);\n const backgroundTask = app.getModule(ApiBackgroundTask);\n\n const role = createLambdaRole(app, {\n name: \"migration-lambda-role\",\n policy: graphql.policy.output\n });\n\n const migration = app.addResource(aws.lambda.Function, {\n name: \"data-migration\",\n config: {\n handler: \"handler.handler\",\n timeout: 900,\n runtime: LAMBDA_RUNTIME,\n memorySize: 3008,\n role: role.output.arn,\n description: \"Performs data migrations.\",\n code: new pulumi.asset.AssetArchive({\n \".\": new pulumi.asset.FileArchive(\n path.join(app.paths.workspace, \"migration/build\")\n )\n }),\n environment: {\n variables: getCommonLambdaEnvVariables().apply(value => ({\n ...value,\n COGNITO_REGION: getEnvVariableAwsRegion(),\n COGNITO_USER_POOL_ID: core.cognitoUserPoolId,\n DB_TABLE: core.primaryDynamodbTableName,\n DB_TABLE_LOG: core.logDynamodbTableName,\n DB_TABLE_AUDIT_LOGS: core.auditLogsDynamodbTableName,\n DB_TABLE_OPENSEARCH: core.opensearchDynamodbTableName,\n OPENSEARCH_ENDPOINT: core.opensearchDomainEndpoint,\n OPENSEARCH_INDEX_PREFIX: process.env.OPENSEARCH_INDEX_PREFIX,\n OPENSEARCH_SHARED_INDEXES: process.env.OPENSEARCH_SHARED_INDEXES,\n S3_BUCKET: core.fileManagerBucketId\n })) as Record<string, any>\n },\n vpcConfig: app.getModule(VpcConfig).functionVpcConfig,\n loggingConfig: {\n logFormat: \"JSON\"\n }\n }\n });\n\n // Add IAM policy to allow states:StartExecution for the background task Step Function\n const stepFunctionPolicy = app.addResource(aws.iam.Policy, {\n name: \"migration-lambda-step-function-policy\",\n config: {\n policy: {\n Version: \"2012-10-17\",\n Statement: [\n {\n Effect: \"Allow\",\n Action: [\"states:StartExecution\"],\n Resource: [\n pulumi.interpolate`${backgroundTask.stepFunction.output.arn}`,\n pulumi.interpolate`${backgroundTask.stepFunction.output.arn}/*`\n ]\n }\n ]\n }\n }\n });\n\n // Attach policy to the Lambda role\n app.addResource(aws.iam.RolePolicyAttachment, {\n name: \"migration-lambda-attach-step-function-policy\",\n config: {\n role: role.output.name,\n policyArn: stepFunctionPolicy.output.arn\n }\n });\n\n return {\n function: migration\n };\n }\n});\n"],"mappings":"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","ignoreList":[]}
@@ -0,0 +1,23 @@
1
+ import type { PulumiAppModule } from "@webiny/pulumi";
2
+ export type ApiOutput = PulumiAppModule<typeof ApiOutput>;
3
+ export declare const ApiOutput: import("@webiny/pulumi").PulumiAppModuleDefinition<import("@pulumi/pulumi").Output<import("@pulumi/pulumi").UnwrappedObject<{
4
+ apiDomain: string;
5
+ apiUrl: string;
6
+ graphqlLambdaRole: string;
7
+ graphqlLambdaRoleName: string;
8
+ cognitoAppClientId: string;
9
+ cognitoUserPoolId: string;
10
+ cognitoUserPoolPasswordPolicy: string;
11
+ dynamoDbTable: string;
12
+ region: string;
13
+ websocketApiId: string | number | boolean | string[] | number[] | undefined;
14
+ websocketApiUrl: string;
15
+ migrationLambdaArn: string;
16
+ graphqlLambdaName: string | number | boolean | string[] | number[] | undefined;
17
+ backgroundTaskLambdaArn: string | number | boolean | string[] | number[] | undefined;
18
+ backgroundTaskStepFunctionArn: string | number | boolean | string[] | number[] | undefined;
19
+ fileManagerManageLambdaArn: string;
20
+ fileManagerManageLambdaRole: string;
21
+ fileManagerManageLambdaRoleName: string;
22
+ fileManagerDownloadLambdaArn: string | number | boolean | string[] | number[] | undefined;
23
+ }>>, void>;
@@ -0,0 +1,36 @@
1
+ import { createAppModule } from "@webiny/pulumi";
2
+ import { getStackOutput } from "@webiny/project";
3
+ export const ApiOutput = createAppModule({
4
+ name: "ApiOutput",
5
+ config(app) {
6
+ return app.addHandler(async () => {
7
+ const output = await getStackOutput("api");
8
+ if (!output) {
9
+ throw new Error("API application is not deployed.");
10
+ }
11
+ return {
12
+ apiDomain: output["apiDomain"],
13
+ apiUrl: output["apiUrl"],
14
+ graphqlLambdaRole: output["graphqlLambdaRole"],
15
+ graphqlLambdaRoleName: output["graphqlLambdaRoleName"],
16
+ cognitoAppClientId: output["cognitoAppClientId"],
17
+ cognitoUserPoolId: output["cognitoUserPoolId"],
18
+ cognitoUserPoolPasswordPolicy: output["cognitoUserPoolPasswordPolicy"],
19
+ dynamoDbTable: output["dynamoDbTable"],
20
+ region: output["region"],
21
+ websocketApiId: output["websocketApiId"],
22
+ websocketApiUrl: output["websocketApiUrl"],
23
+ migrationLambdaArn: output["migrationLambdaArn"],
24
+ graphqlLambdaName: output["graphqlLambdaName"],
25
+ backgroundTaskLambdaArn: output["backgroundTaskLambdaArn"],
26
+ backgroundTaskStepFunctionArn: output["backgroundTaskStepFunctionArn"],
27
+ fileManagerManageLambdaArn: output["fileManagerManageLambdaArn"],
28
+ fileManagerManageLambdaRole: output["fileManagerManageLambdaRole"],
29
+ fileManagerManageLambdaRoleName: output["fileManagerManageLambdaRoleName"],
30
+ fileManagerDownloadLambdaArn: output["fileManagerDownloadLambdaArn"]
31
+ };
32
+ });
33
+ }
34
+ });
35
+
36
+ //# sourceMappingURL=ApiOutput.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["createAppModule","getStackOutput","ApiOutput","name","config","app","addHandler","output","Error","apiDomain","apiUrl","graphqlLambdaRole","graphqlLambdaRoleName","cognitoAppClientId","cognitoUserPoolId","cognitoUserPoolPasswordPolicy","dynamoDbTable","region","websocketApiId","websocketApiUrl","migrationLambdaArn","graphqlLambdaName","backgroundTaskLambdaArn","backgroundTaskStepFunctionArn","fileManagerManageLambdaArn","fileManagerManageLambdaRole","fileManagerManageLambdaRoleName","fileManagerDownloadLambdaArn"],"sources":["ApiOutput.ts"],"sourcesContent":["import type { PulumiAppModule } from \"@webiny/pulumi\";\nimport { createAppModule } from \"@webiny/pulumi\";\nimport { getStackOutput } from \"@webiny/project\";\nimport { type IDefaultStackOutput } from \"~/pulumi/types.js\";\n\nexport type ApiOutput = PulumiAppModule<typeof ApiOutput>;\n\nexport const ApiOutput = createAppModule({\n name: \"ApiOutput\",\n config(app) {\n return app.addHandler(async () => {\n const output = await getStackOutput<IDefaultStackOutput>(\"api\");\n\n if (!output) {\n throw new Error(\"API application is not deployed.\");\n }\n\n return {\n apiDomain: output[\"apiDomain\"],\n apiUrl: output[\"apiUrl\"],\n graphqlLambdaRole: output[\"graphqlLambdaRole\"],\n graphqlLambdaRoleName: output[\"graphqlLambdaRoleName\"],\n cognitoAppClientId: output[\"cognitoAppClientId\"],\n cognitoUserPoolId: output[\"cognitoUserPoolId\"],\n cognitoUserPoolPasswordPolicy: output[\"cognitoUserPoolPasswordPolicy\"],\n dynamoDbTable: output[\"dynamoDbTable\"],\n region: output[\"region\"],\n websocketApiId: output[\"websocketApiId\"],\n websocketApiUrl: output[\"websocketApiUrl\"],\n migrationLambdaArn: output[\"migrationLambdaArn\"],\n graphqlLambdaName: output[\"graphqlLambdaName\"],\n backgroundTaskLambdaArn: output[\"backgroundTaskLambdaArn\"],\n backgroundTaskStepFunctionArn: output[\"backgroundTaskStepFunctionArn\"],\n fileManagerManageLambdaArn: output[\"fileManagerManageLambdaArn\"],\n fileManagerManageLambdaRole: output[\"fileManagerManageLambdaRole\"],\n fileManagerManageLambdaRoleName: output[\"fileManagerManageLambdaRoleName\"],\n fileManagerDownloadLambdaArn: output[\"fileManagerDownloadLambdaArn\"]\n };\n });\n }\n});\n"],"mappings":"AACA,SAASA,eAAe,QAAQ,gBAAgB;AAChD,SAASC,cAAc,QAAQ,iBAAiB;AAKhD,OAAO,MAAMC,SAAS,GAAGF,eAAe,CAAC;EACrCG,IAAI,EAAE,WAAW;EACjBC,MAAMA,CAACC,GAAG,EAAE;IACR,OAAOA,GAAG,CAACC,UAAU,CAAC,YAAY;MAC9B,MAAMC,MAAM,GAAG,MAAMN,cAAc,CAAsB,KAAK,CAAC;MAE/D,IAAI,CAACM,MAAM,EAAE;QACT,MAAM,IAAIC,KAAK,CAAC,kCAAkC,CAAC;MACvD;MAEA,OAAO;QACHC,SAAS,EAAEF,MAAM,CAAC,WAAW,CAAC;QAC9BG,MAAM,EAAEH,MAAM,CAAC,QAAQ,CAAC;QACxBI,iBAAiB,EAAEJ,MAAM,CAAC,mBAAmB,CAAC;QAC9CK,qBAAqB,EAAEL,MAAM,CAAC,uBAAuB,CAAC;QACtDM,kBAAkB,EAAEN,MAAM,CAAC,oBAAoB,CAAC;QAChDO,iBAAiB,EAAEP,MAAM,CAAC,mBAAmB,CAAC;QAC9CQ,6BAA6B,EAAER,MAAM,CAAC,+BAA+B,CAAC;QACtES,aAAa,EAAET,MAAM,CAAC,eAAe,CAAC;QACtCU,MAAM,EAAEV,MAAM,CAAC,QAAQ,CAAC;QACxBW,cAAc,EAAEX,MAAM,CAAC,gBAAgB,CAAC;QACxCY,eAAe,EAAEZ,MAAM,CAAC,iBAAiB,CAAC;QAC1Ca,kBAAkB,EAAEb,MAAM,CAAC,oBAAoB,CAAC;QAChDc,iBAAiB,EAAEd,MAAM,CAAC,mBAAmB,CAAC;QAC9Ce,uBAAuB,EAAEf,MAAM,CAAC,yBAAyB,CAAC;QAC1DgB,6BAA6B,EAAEhB,MAAM,CAAC,+BAA+B,CAAC;QACtEiB,0BAA0B,EAAEjB,MAAM,CAAC,4BAA4B,CAAC;QAChEkB,2BAA2B,EAAElB,MAAM,CAAC,6BAA6B,CAAC;QAClEmB,+BAA+B,EAAEnB,MAAM,CAAC,iCAAiC,CAAC;QAC1EoB,4BAA4B,EAAEpB,MAAM,CAAC,8BAA8B;MACvE,CAAC;IACL,CAAC,CAAC;EACN;AACJ,CAAC,CAAC","ignoreList":[]}
@@ -0,0 +1,8 @@
1
+ import type { PulumiAppModule } from "@webiny/pulumi";
2
+ export type ApiScheduler = PulumiAppModule<typeof ApiScheduler>;
3
+ export declare const ApiSchedulerBaseName = "scheduler-resolver";
4
+ export declare const ApiScheduler: import("@webiny/pulumi").PulumiAppModuleDefinition<{
5
+ invokeRole: import("@webiny/pulumi").PulumiAppResource<typeof import("@pulumi/aws/iam/role").Role>;
6
+ invokePolicy: import("@webiny/pulumi").PulumiAppResource<typeof import("@pulumi/aws/iam/rolePolicy").RolePolicy>;
7
+ policyAttachment: import("@webiny/pulumi").PulumiAppResource<typeof import("@pulumi/aws/iam/rolePolicyAttachment").RolePolicyAttachment>;
8
+ }, void>;
@@ -0,0 +1,100 @@
1
+ import * as aws from "@pulumi/aws";
2
+ import * as pulumi from "@pulumi/pulumi";
3
+ import { createAppModule } from "@webiny/pulumi";
4
+ import { ApiGraphql } from "../index.js";
5
+ import { getAwsAccountId, getAwsRegion } from "../awsUtils.js";
6
+ import kebabCase from "lodash/kebabCase.js";
7
+ export const ApiSchedulerBaseName = "scheduler-resolver";
8
+ const createResourceName = name => {
9
+ return `${ApiSchedulerBaseName}-${kebabCase(name)}`;
10
+ };
11
+ export const ApiScheduler = createAppModule({
12
+ name: "ApiScheduler",
13
+ config(app) {
14
+ const awsRegion = getAwsRegion(app);
15
+ const awsAccountId = getAwsAccountId(app);
16
+ const graphql = app.getModule(ApiGraphql);
17
+ // const baseConfig = graphql.functions.graphql.config.clone();
18
+ /*
19
+ const schedulerResolverLambda = app.addResource(aws.lambda.Function, {
20
+ name: createResourceName("lambda"),
21
+ config: {
22
+ ...baseConfig,
23
+ layers: graphql.functions.graphql.output.layers.apply(arns => {
24
+ return Array.from(new Set([...(arns || []), getLayerArn("sharp")]));
25
+ }),
26
+ description: "Performs scheduled operations on Headless CMS entries.",
27
+ loggingConfig: {
28
+ logFormat: "JSON"
29
+ }
30
+ }
31
+ });
32
+ */
33
+
34
+ const schedulerResolverInvokeRole = app.addResource(aws.iam.Role, {
35
+ name: createResourceName("invokeRole"),
36
+ config: {
37
+ assumeRolePolicy: JSON.stringify({
38
+ Version: "2012-10-17",
39
+ Statement: [{
40
+ Effect: "Allow",
41
+ Principal: {
42
+ Service: "scheduler.amazonaws.com"
43
+ },
44
+ Action: "sts:AssumeRole"
45
+ }]
46
+ })
47
+ }
48
+ });
49
+ const schedulerResolverInvokeLambdaPolicy = app.addResource(aws.iam.RolePolicy, {
50
+ name: createResourceName("invokeLambdaPolicy"),
51
+ config: {
52
+ role: schedulerResolverInvokeRole.output.id,
53
+ policy: graphql.functions.graphql.output.arn.apply(resolverArn => {
54
+ return JSON.stringify({
55
+ Version: "2012-10-17",
56
+ Statement: [{
57
+ Effect: "Allow",
58
+ Action: ["lambda:InvokeFunction"],
59
+ Resource: resolverArn
60
+ }]
61
+ });
62
+ })
63
+ }
64
+ });
65
+ const schedulerControlPolicy = app.addResource(aws.iam.Policy, {
66
+ name: createResourceName("controlPolicy"),
67
+ config: {
68
+ description: "Allow GraphQL Lambda to manage EventBridge Scheduler",
69
+ policy: pulumi.all([schedulerResolverInvokeRole.output.arn, awsRegion, awsAccountId]).apply(([invokeRoleArn, region, accountId]) => {
70
+ return JSON.stringify({
71
+ Version: "2012-10-17",
72
+ Statement: [{
73
+ Effect: "Allow",
74
+ Action: ["scheduler:CreateSchedule", "scheduler:UpdateSchedule", "scheduler:DeleteSchedule", "scheduler:GetSchedule", "scheduler:ListSchedules"],
75
+ Resource: [`arn:aws:scheduler:${region}:${accountId}:schedule/default/*`]
76
+ }, {
77
+ Effect: "Allow",
78
+ Action: "iam:PassRole",
79
+ Resource: [invokeRoleArn, `${invokeRoleArn}/*`]
80
+ }]
81
+ });
82
+ })
83
+ }
84
+ });
85
+ const schedulerResolverPolicyAttachment = app.addResource(aws.iam.RolePolicyAttachment, {
86
+ name: createResourceName("graphqlSchedulerPolicyAttachment"),
87
+ config: {
88
+ role: graphql.role.output.name,
89
+ policyArn: schedulerControlPolicy.output.arn
90
+ }
91
+ });
92
+ return {
93
+ invokeRole: schedulerResolverInvokeRole,
94
+ invokePolicy: schedulerResolverInvokeLambdaPolicy,
95
+ policyAttachment: schedulerResolverPolicyAttachment
96
+ };
97
+ }
98
+ });
99
+
100
+ //# sourceMappingURL=ApiScheduler.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["aws","pulumi","createAppModule","ApiGraphql","getAwsAccountId","getAwsRegion","kebabCase","ApiSchedulerBaseName","createResourceName","name","ApiScheduler","config","app","awsRegion","awsAccountId","graphql","getModule","schedulerResolverInvokeRole","addResource","iam","Role","assumeRolePolicy","JSON","stringify","Version","Statement","Effect","Principal","Service","Action","schedulerResolverInvokeLambdaPolicy","RolePolicy","role","output","id","policy","functions","arn","apply","resolverArn","Resource","schedulerControlPolicy","Policy","description","all","invokeRoleArn","region","accountId","schedulerResolverPolicyAttachment","RolePolicyAttachment","policyArn","invokeRole","invokePolicy","policyAttachment"],"sources":["ApiScheduler.ts"],"sourcesContent":["import * as aws from \"@pulumi/aws\";\nimport * as pulumi from \"@pulumi/pulumi\";\nimport type { PulumiApp, PulumiAppModule } from \"@webiny/pulumi\";\nimport { createAppModule } from \"@webiny/pulumi\";\nimport { ApiGraphql } from \"~/pulumi/apps/index.js\";\nimport { getAwsAccountId, getAwsRegion } from \"~/pulumi/apps/awsUtils.js\";\nimport kebabCase from \"lodash/kebabCase.js\";\n\nexport type ApiScheduler = PulumiAppModule<typeof ApiScheduler>;\n\nexport const ApiSchedulerBaseName = \"scheduler-resolver\";\n\nconst createResourceName = (name: string): string => {\n return `${ApiSchedulerBaseName}-${kebabCase(name)}`;\n};\n\nexport const ApiScheduler = createAppModule({\n name: \"ApiScheduler\",\n config(app: PulumiApp) {\n const awsRegion = getAwsRegion(app);\n const awsAccountId = getAwsAccountId(app);\n const graphql = app.getModule(ApiGraphql);\n // const baseConfig = graphql.functions.graphql.config.clone();\n /*\n const schedulerResolverLambda = app.addResource(aws.lambda.Function, {\n name: createResourceName(\"lambda\"),\n config: {\n ...baseConfig,\n layers: graphql.functions.graphql.output.layers.apply(arns => {\n return Array.from(new Set([...(arns || []), getLayerArn(\"sharp\")]));\n }),\n description: \"Performs scheduled operations on Headless CMS entries.\",\n loggingConfig: {\n logFormat: \"JSON\"\n }\n }\n });\n */\n\n const schedulerResolverInvokeRole = app.addResource(aws.iam.Role, {\n name: createResourceName(\"invokeRole\"),\n config: {\n assumeRolePolicy: JSON.stringify({\n Version: \"2012-10-17\",\n Statement: [\n {\n Effect: \"Allow\",\n Principal: {\n Service: \"scheduler.amazonaws.com\"\n },\n Action: \"sts:AssumeRole\"\n }\n ]\n })\n }\n });\n\n const schedulerResolverInvokeLambdaPolicy = app.addResource(aws.iam.RolePolicy, {\n name: createResourceName(\"invokeLambdaPolicy\"),\n config: {\n role: schedulerResolverInvokeRole.output.id,\n policy: graphql.functions.graphql.output.arn.apply(resolverArn => {\n return JSON.stringify({\n Version: \"2012-10-17\",\n Statement: [\n {\n Effect: \"Allow\",\n Action: [\"lambda:InvokeFunction\"],\n Resource: resolverArn\n }\n ]\n });\n })\n }\n });\n\n const schedulerControlPolicy = app.addResource(aws.iam.Policy, {\n name: createResourceName(\"controlPolicy\"),\n config: {\n description: \"Allow GraphQL Lambda to manage EventBridge Scheduler\",\n policy: pulumi\n .all([schedulerResolverInvokeRole.output.arn, awsRegion, awsAccountId])\n .apply(([invokeRoleArn, region, accountId]) => {\n return JSON.stringify({\n Version: \"2012-10-17\",\n Statement: [\n {\n Effect: \"Allow\",\n Action: [\n \"scheduler:CreateSchedule\",\n \"scheduler:UpdateSchedule\",\n \"scheduler:DeleteSchedule\",\n \"scheduler:GetSchedule\",\n \"scheduler:ListSchedules\"\n ],\n Resource: [\n `arn:aws:scheduler:${region}:${accountId}:schedule/default/*`\n ]\n },\n {\n Effect: \"Allow\",\n Action: \"iam:PassRole\",\n Resource: [invokeRoleArn, `${invokeRoleArn}/*`]\n }\n ]\n });\n })\n }\n });\n\n const schedulerResolverPolicyAttachment = app.addResource(aws.iam.RolePolicyAttachment, {\n name: createResourceName(\"graphqlSchedulerPolicyAttachment\"),\n config: {\n role: graphql.role.output.name,\n policyArn: schedulerControlPolicy.output.arn\n }\n });\n\n return {\n invokeRole: schedulerResolverInvokeRole,\n invokePolicy: schedulerResolverInvokeLambdaPolicy,\n policyAttachment: schedulerResolverPolicyAttachment\n };\n }\n});\n"],"mappings":"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","ignoreList":[]}
@@ -0,0 +1,14 @@
1
+ import * as pulumi from "@pulumi/pulumi";
2
+ import type { PulumiAppModule } from "@webiny/pulumi";
3
+ export type ApiWebsocket = PulumiAppModule<typeof ApiWebsocket>;
4
+ export declare const ApiWebsocket: import("@webiny/pulumi").PulumiAppModuleDefinition<{
5
+ websocketApi: import("@webiny/pulumi").PulumiAppResource<typeof import("@pulumi/aws/apigatewayv2/api").Api>;
6
+ websocketApiStage: import("@webiny/pulumi").PulumiAppResource<typeof import("@pulumi/aws/apigatewayv2/stage").Stage>;
7
+ websocketApiConnectRoute: import("@webiny/pulumi").PulumiAppResource<typeof import("@pulumi/aws/apigatewayv2/route").Route>;
8
+ websocketApiDisconnectRoute: import("@webiny/pulumi").PulumiAppResource<typeof import("@pulumi/aws/apigatewayv2/route").Route>;
9
+ websocketApiDefaultRoute: import("@webiny/pulumi").PulumiAppResource<typeof import("@pulumi/aws/apigatewayv2/route").Route>;
10
+ websocketLambdaPermission: import("@webiny/pulumi").PulumiAppResource<typeof import("@pulumi/aws/lambda/permission").Permission>;
11
+ lambdaWebsocketPolicy: import("@webiny/pulumi").PulumiAppResource<typeof import("@pulumi/aws/iam/policy").Policy>;
12
+ lambdaWebsocketRolePolicyAttachment: import("@webiny/pulumi").PulumiAppResource<typeof import("@pulumi/aws/iam/rolePolicyAttachment").RolePolicyAttachment>;
13
+ websocketApiUrl: pulumi.Output<string>;
14
+ }, void>;