@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,14 @@
1
+ import type { PulumiApp } from "@webiny/pulumi";
2
+ import type { WithServiceManifest } from "../../../../pulumi/utils/withServiceManifest.js";
3
+ import type { IGetSyncSystemOutputResult } from "../../../../pulumi/apps/syncSystem/types.js";
4
+ import type { CoreOutput } from "../../../../apps/index.js";
5
+ export interface IAttachCognitoPermissionsParams {
6
+ app: PulumiApp & WithServiceManifest;
7
+ syncSystem: IGetSyncSystemOutputResult;
8
+ core: CoreOutput;
9
+ }
10
+ export declare const attachCognitoPermissions: (params: IAttachCognitoPermissionsParams) => {
11
+ cognitoPolicy: import("@webiny/pulumi").PulumiAppResource<typeof import("@pulumi/aws/iam/policy").Policy>;
12
+ workerLambdaS3PolicyAttachment: import("@webiny/pulumi").PulumiAppResource<typeof import("@pulumi/aws/iam/rolePolicyAttachment").RolePolicyAttachment>;
13
+ resolverLambdaS3PolicyAttachment: import("@webiny/pulumi").PulumiAppResource<typeof import("@pulumi/aws/iam/rolePolicyAttachment").RolePolicyAttachment>;
14
+ } | null;
@@ -0,0 +1,59 @@
1
+ import * as aws from "@pulumi/aws";
2
+ import { createSyncResourceName } from "../createSyncResourceName.js";
3
+ export const attachCognitoPermissions = params => {
4
+ const {
5
+ app,
6
+ syncSystem,
7
+ core
8
+ } = params;
9
+ /**
10
+ * TODO there must be a way to skip this if Cognito is not used in the Webiny deployment.
11
+ */
12
+ if (!core.cognitoUserPoolArn) {
13
+ return null;
14
+ }
15
+ const {
16
+ resolverLambdaRoleName,
17
+ workerLambdaRoleName
18
+ } = syncSystem;
19
+ const resolverLambdaToS3ResourceName = createSyncResourceName(`resolver-lambda-to-cognito`);
20
+ const workerLambdaToS3ResourceName = createSyncResourceName(`worker-lambda-to-cognito`);
21
+ const cognitoPolicy = app.addResource(aws.iam.Policy, {
22
+ name: `${resolverLambdaToS3ResourceName}-policy`,
23
+ config: {
24
+ description: "This policy enables access from Sync System Resolver and Worker Lambda to Webiny Cognito.",
25
+ policy: {
26
+ Version: "2012-10-17",
27
+ Statement: [{
28
+ Sid: "PermissionForSyncLambdaToCognito",
29
+ Effect: "Allow",
30
+ Action: ["cognito-idp:*"],
31
+ Resource: core.cognitoUserPoolArn.apply(arn => {
32
+ return [arn, `${arn}/*`];
33
+ })
34
+ }]
35
+ }
36
+ }
37
+ });
38
+ const resolverLambdaS3PolicyAttachment = app.addResource(aws.iam.RolePolicyAttachment, {
39
+ name: `${resolverLambdaToS3ResourceName}-policy-attachment`,
40
+ config: {
41
+ role: resolverLambdaRoleName,
42
+ policyArn: cognitoPolicy.output.arn
43
+ }
44
+ });
45
+ const workerLambdaS3PolicyAttachment = app.addResource(aws.iam.RolePolicyAttachment, {
46
+ name: `${workerLambdaToS3ResourceName}-policy-attachment`,
47
+ config: {
48
+ role: workerLambdaRoleName,
49
+ policyArn: cognitoPolicy.output.arn
50
+ }
51
+ });
52
+ return {
53
+ cognitoPolicy,
54
+ workerLambdaS3PolicyAttachment,
55
+ resolverLambdaS3PolicyAttachment
56
+ };
57
+ };
58
+
59
+ //# sourceMappingURL=attachCognitoPermissions.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["aws","createSyncResourceName","attachCognitoPermissions","params","app","syncSystem","core","cognitoUserPoolArn","resolverLambdaRoleName","workerLambdaRoleName","resolverLambdaToS3ResourceName","workerLambdaToS3ResourceName","cognitoPolicy","addResource","iam","Policy","name","config","description","policy","Version","Statement","Sid","Effect","Action","Resource","apply","arn","resolverLambdaS3PolicyAttachment","RolePolicyAttachment","role","policyArn","output","workerLambdaS3PolicyAttachment"],"sources":["attachCognitoPermissions.ts"],"sourcesContent":["import * as aws from \"@pulumi/aws\";\nimport type { PulumiApp } from \"@webiny/pulumi\";\nimport type { WithServiceManifest } from \"~/pulumi/utils/withServiceManifest.js\";\nimport type { IGetSyncSystemOutputResult } from \"~/pulumi/apps/syncSystem/types.js\";\nimport type { CoreOutput } from \"~/apps/index.js\";\nimport { createSyncResourceName } from \"~/pulumi/apps/syncSystem/createSyncResourceName.js\";\n\nexport interface IAttachCognitoPermissionsParams {\n app: PulumiApp & WithServiceManifest;\n syncSystem: IGetSyncSystemOutputResult;\n core: CoreOutput;\n}\n\nexport const attachCognitoPermissions = (params: IAttachCognitoPermissionsParams) => {\n const { app, syncSystem, core } = params;\n /**\n * TODO there must be a way to skip this if Cognito is not used in the Webiny deployment.\n */\n if (!core.cognitoUserPoolArn) {\n return null;\n }\n\n const { resolverLambdaRoleName, workerLambdaRoleName } = syncSystem;\n\n const resolverLambdaToS3ResourceName = createSyncResourceName(`resolver-lambda-to-cognito`);\n const workerLambdaToS3ResourceName = createSyncResourceName(`worker-lambda-to-cognito`);\n\n const cognitoPolicy = app.addResource(aws.iam.Policy, {\n name: `${resolverLambdaToS3ResourceName}-policy`,\n config: {\n description:\n \"This policy enables access from Sync System Resolver and Worker Lambda to Webiny Cognito.\",\n policy: {\n Version: \"2012-10-17\",\n Statement: [\n {\n Sid: \"PermissionForSyncLambdaToCognito\",\n Effect: \"Allow\",\n Action: [\"cognito-idp:*\"],\n Resource: core.cognitoUserPoolArn.apply(arn => {\n return [arn, `${arn}/*`];\n })\n }\n ]\n }\n }\n });\n\n const resolverLambdaS3PolicyAttachment = app.addResource(aws.iam.RolePolicyAttachment, {\n name: `${resolverLambdaToS3ResourceName}-policy-attachment`,\n config: {\n role: resolverLambdaRoleName,\n policyArn: cognitoPolicy.output.arn\n }\n });\n\n const workerLambdaS3PolicyAttachment = app.addResource(aws.iam.RolePolicyAttachment, {\n name: `${workerLambdaToS3ResourceName}-policy-attachment`,\n config: {\n role: workerLambdaRoleName,\n policyArn: cognitoPolicy.output.arn\n }\n });\n\n return {\n cognitoPolicy,\n workerLambdaS3PolicyAttachment,\n resolverLambdaS3PolicyAttachment\n };\n};\n"],"mappings":"AAAA,OAAO,KAAKA,GAAG,MAAM,aAAa;AAKlC,SAASC,sBAAsB;AAQ/B,OAAO,MAAMC,wBAAwB,GAAIC,MAAuC,IAAK;EACjF,MAAM;IAAEC,GAAG;IAAEC,UAAU;IAAEC;EAAK,CAAC,GAAGH,MAAM;EACxC;AACJ;AACA;EACI,IAAI,CAACG,IAAI,CAACC,kBAAkB,EAAE;IAC1B,OAAO,IAAI;EACf;EAEA,MAAM;IAAEC,sBAAsB;IAAEC;EAAqB,CAAC,GAAGJ,UAAU;EAEnE,MAAMK,8BAA8B,GAAGT,sBAAsB,CAAC,4BAA4B,CAAC;EAC3F,MAAMU,4BAA4B,GAAGV,sBAAsB,CAAC,0BAA0B,CAAC;EAEvF,MAAMW,aAAa,GAAGR,GAAG,CAACS,WAAW,CAACb,GAAG,CAACc,GAAG,CAACC,MAAM,EAAE;IAClDC,IAAI,EAAE,GAAGN,8BAA8B,SAAS;IAChDO,MAAM,EAAE;MACJC,WAAW,EACP,2FAA2F;MAC/FC,MAAM,EAAE;QACJC,OAAO,EAAE,YAAY;QACrBC,SAAS,EAAE,CACP;UACIC,GAAG,EAAE,kCAAkC;UACvCC,MAAM,EAAE,OAAO;UACfC,MAAM,EAAE,CAAC,eAAe,CAAC;UACzBC,QAAQ,EAAEnB,IAAI,CAACC,kBAAkB,CAACmB,KAAK,CAACC,GAAG,IAAI;YAC3C,OAAO,CAACA,GAAG,EAAE,GAAGA,GAAG,IAAI,CAAC;UAC5B,CAAC;QACL,CAAC;MAET;IACJ;EACJ,CAAC,CAAC;EAEF,MAAMC,gCAAgC,GAAGxB,GAAG,CAACS,WAAW,CAACb,GAAG,CAACc,GAAG,CAACe,oBAAoB,EAAE;IACnFb,IAAI,EAAE,GAAGN,8BAA8B,oBAAoB;IAC3DO,MAAM,EAAE;MACJa,IAAI,EAAEtB,sBAAsB;MAC5BuB,SAAS,EAAEnB,aAAa,CAACoB,MAAM,CAACL;IACpC;EACJ,CAAC,CAAC;EAEF,MAAMM,8BAA8B,GAAG7B,GAAG,CAACS,WAAW,CAACb,GAAG,CAACc,GAAG,CAACe,oBAAoB,EAAE;IACjFb,IAAI,EAAE,GAAGL,4BAA4B,oBAAoB;IACzDM,MAAM,EAAE;MACJa,IAAI,EAAErB,oBAAoB;MAC1BsB,SAAS,EAAEnB,aAAa,CAACoB,MAAM,CAACL;IACpC;EACJ,CAAC,CAAC;EAEF,OAAO;IACHf,aAAa;IACbqB,8BAA8B;IAC9BL;EACJ,CAAC;AACL,CAAC","ignoreList":[]}
@@ -0,0 +1,13 @@
1
+ import type { PulumiApp } from "@webiny/pulumi";
2
+ import type { IGetSyncSystemOutputResult } from "../../../../pulumi/apps/syncSystem/types.js";
3
+ import type { CoreOutput } from "../../../../pulumi/apps/common/CoreOutput.js";
4
+ import type { WithServiceManifest } from "../../../../pulumi/utils/withServiceManifest.js";
5
+ export interface IAttachDynamoDbPermissionsParams {
6
+ app: PulumiApp & WithServiceManifest;
7
+ syncSystem: IGetSyncSystemOutputResult;
8
+ core: CoreOutput;
9
+ }
10
+ export declare const attachDynamoDbPermissions: (params: IAttachDynamoDbPermissionsParams) => {
11
+ dynamoDbPolicy: import("@webiny/pulumi").PulumiAppResource<typeof import("@pulumi/aws/iam/policy").Policy>;
12
+ lambdaRolePolicyAttachment: import("@webiny/pulumi").PulumiAppResource<typeof import("@pulumi/aws/iam/rolePolicyAttachment").RolePolicyAttachment>;
13
+ };
@@ -0,0 +1,44 @@
1
+ /**
2
+ * We need to attach Sync System Lambda policy to access DynamoDB in the Webiny system.
3
+ */
4
+ import * as aws from "@pulumi/aws";
5
+ import { createSyncResourceName } from "../createSyncResourceName.js";
6
+ export const attachDynamoDbPermissions = params => {
7
+ const {
8
+ app,
9
+ syncSystem,
10
+ core
11
+ } = params;
12
+ const {
13
+ resolverLambdaRoleName
14
+ } = syncSystem;
15
+ const lambdaToDynamoDbResourceName = createSyncResourceName(`resolver-lambda-to-dynamodb`);
16
+ const dynamoDbPolicy = app.addResource(aws.iam.Policy, {
17
+ name: `${lambdaToDynamoDbResourceName}-policy`,
18
+ config: {
19
+ description: "This policy enables access from Sync System Lambda to Webiny DynamoDB.",
20
+ policy: {
21
+ Version: "2012-10-17",
22
+ Statement: [{
23
+ Sid: "PermissionForSyncLambdaToDynamoDb",
24
+ Effect: "Allow",
25
+ 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"],
26
+ Resource: [core.primaryDynamodbTableArn.apply(arn => arn), core.primaryDynamodbTableArn.apply(arn => `${arn}/*`)]
27
+ }]
28
+ }
29
+ }
30
+ });
31
+ const lambdaRolePolicyAttachment = app.addResource(aws.iam.RolePolicyAttachment, {
32
+ name: `${lambdaToDynamoDbResourceName}-role-policy-attachment`,
33
+ config: {
34
+ role: resolverLambdaRoleName,
35
+ policyArn: dynamoDbPolicy.output.arn
36
+ }
37
+ });
38
+ return {
39
+ dynamoDbPolicy,
40
+ lambdaRolePolicyAttachment
41
+ };
42
+ };
43
+
44
+ //# sourceMappingURL=attachDynamoDbPermissions.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["aws","createSyncResourceName","attachDynamoDbPermissions","params","app","syncSystem","core","resolverLambdaRoleName","lambdaToDynamoDbResourceName","dynamoDbPolicy","addResource","iam","Policy","name","config","description","policy","Version","Statement","Sid","Effect","Action","Resource","primaryDynamodbTableArn","apply","arn","lambdaRolePolicyAttachment","RolePolicyAttachment","role","policyArn","output"],"sources":["attachDynamoDbPermissions.ts"],"sourcesContent":["/**\n * We need to attach Sync System Lambda policy to access DynamoDB in the Webiny system.\n */\nimport * as aws from \"@pulumi/aws\";\nimport type { PulumiApp } from \"@webiny/pulumi\";\nimport type { IGetSyncSystemOutputResult } from \"~/pulumi/apps/syncSystem/types.js\";\nimport { createSyncResourceName } from \"~/pulumi/apps/syncSystem/createSyncResourceName.js\";\nimport type { CoreOutput } from \"~/pulumi/apps/common/CoreOutput.js\";\nimport type { WithServiceManifest } from \"~/pulumi/utils/withServiceManifest.js\";\n\nexport interface IAttachDynamoDbPermissionsParams {\n app: PulumiApp & WithServiceManifest;\n syncSystem: IGetSyncSystemOutputResult;\n core: CoreOutput;\n}\n\nexport const attachDynamoDbPermissions = (params: IAttachDynamoDbPermissionsParams) => {\n const { app, syncSystem, core } = params;\n\n const { resolverLambdaRoleName } = syncSystem;\n\n const lambdaToDynamoDbResourceName = createSyncResourceName(`resolver-lambda-to-dynamodb`);\n\n const dynamoDbPolicy = app.addResource(aws.iam.Policy, {\n name: `${lambdaToDynamoDbResourceName}-policy`,\n config: {\n description: \"This policy enables access from Sync System Lambda to Webiny DynamoDB.\",\n policy: {\n Version: \"2012-10-17\",\n Statement: [\n {\n Sid: \"PermissionForSyncLambdaToDynamoDb\",\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.apply(arn => arn),\n core.primaryDynamodbTableArn.apply(arn => `${arn}/*`)\n ]\n }\n ]\n }\n }\n });\n\n const lambdaRolePolicyAttachment = app.addResource(aws.iam.RolePolicyAttachment, {\n name: `${lambdaToDynamoDbResourceName}-role-policy-attachment`,\n config: {\n role: resolverLambdaRoleName,\n policyArn: dynamoDbPolicy.output.arn\n }\n });\n\n return {\n dynamoDbPolicy,\n lambdaRolePolicyAttachment\n };\n};\n"],"mappings":"AAAA;AACA;AACA;AACA,OAAO,KAAKA,GAAG,MAAM,aAAa;AAGlC,SAASC,sBAAsB;AAU/B,OAAO,MAAMC,yBAAyB,GAAIC,MAAwC,IAAK;EACnF,MAAM;IAAEC,GAAG;IAAEC,UAAU;IAAEC;EAAK,CAAC,GAAGH,MAAM;EAExC,MAAM;IAAEI;EAAuB,CAAC,GAAGF,UAAU;EAE7C,MAAMG,4BAA4B,GAAGP,sBAAsB,CAAC,6BAA6B,CAAC;EAE1F,MAAMQ,cAAc,GAAGL,GAAG,CAACM,WAAW,CAACV,GAAG,CAACW,GAAG,CAACC,MAAM,EAAE;IACnDC,IAAI,EAAE,GAAGL,4BAA4B,SAAS;IAC9CM,MAAM,EAAE;MACJC,WAAW,EAAE,wEAAwE;MACrFC,MAAM,EAAE;QACJC,OAAO,EAAE,YAAY;QACrBC,SAAS,EAAE,CACP;UACIC,GAAG,EAAE,mCAAmC;UACxCC,MAAM,EAAE,OAAO;UACfC,MAAM,EAAE,CACJ,uBAAuB,EACvB,yBAAyB,EACzB,6BAA6B,EAC7B,uBAAuB,EACvB,sBAAsB,EACtB,6BAA6B,EAC7B,uBAAuB,EACvB,qBAAqB,EACrB,sBAAsB,EACtB,6BAA6B,EAC7B,yBAAyB,EACzB,oCAAoC,EACpC,sCAAsC,EACtC,yBAAyB,EACzB,8CAA8C,EAC9C,yBAAyB,EACzB,mCAAmC,EACnC,4CAA4C,EAC5C,yBAAyB,EACzB,wBAAwB,EACxB,0CAA0C,EAC1C,6BAA6B,EAC7B,6CAA6C,EAC7C,4CAA4C,EAC5C,mCAAmC,EACnC,kBAAkB,EAClB,qBAAqB,EACrB,2BAA2B,EAC3B,sBAAsB,EACtB,kCAAkC,EAClC,sBAAsB,EACtB,sBAAsB,EACtB,qBAAqB,EACrB,6BAA6B,EAC7B,wBAAwB,EACxB,wBAAwB,EACxB,wBAAwB,EACxB,wBAAwB,EACxB,4CAA4C,EAC5C,kBAAkB,EAClB,gBAAgB,EAChB,iCAAiC,EACjC,oCAAoC,EACpC,eAAe,EACf,kCAAkC,EAClC,oCAAoC,EACpC,qBAAqB,EACrB,sBAAsB,EACtB,wCAAwC,EACxC,2BAA2B,CAC9B;UACDC,QAAQ,EAAE,CACNhB,IAAI,CAACiB,uBAAuB,CAACC,KAAK,CAACC,GAAG,IAAIA,GAAG,CAAC,EAC9CnB,IAAI,CAACiB,uBAAuB,CAACC,KAAK,CAACC,GAAG,IAAI,GAAGA,GAAG,IAAI,CAAC;QAE7D,CAAC;MAET;IACJ;EACJ,CAAC,CAAC;EAEF,MAAMC,0BAA0B,GAAGtB,GAAG,CAACM,WAAW,CAACV,GAAG,CAACW,GAAG,CAACgB,oBAAoB,EAAE;IAC7Ed,IAAI,EAAE,GAAGL,4BAA4B,yBAAyB;IAC9DM,MAAM,EAAE;MACJc,IAAI,EAAErB,sBAAsB;MAC5BsB,SAAS,EAAEpB,cAAc,CAACqB,MAAM,CAACL;IACrC;EACJ,CAAC,CAAC;EAEF,OAAO;IACHhB,cAAc;IACdiB;EACJ,CAAC;AACL,CAAC","ignoreList":[]}
@@ -0,0 +1,17 @@
1
+ import type { PulumiApp } from "@webiny/pulumi/types.js";
2
+ import type { IGetSyncSystemOutputResult } from "../types.js";
3
+ import type { WithServiceManifest } from "../../../../pulumi/utils/withServiceManifest.js";
4
+ export interface IAttachEventBusPermissionsParam {
5
+ app: PulumiApp & WithServiceManifest;
6
+ syncSystem: IGetSyncSystemOutputResult;
7
+ }
8
+ /**
9
+ * We need to attach the policy to:
10
+ * * GraphQL Lambda Role
11
+ * * File Manager Manage Lambda Role
12
+ * TODO determine if any other are required
13
+ */
14
+ export declare const attachEventBusPermissions: (params: IAttachEventBusPermissionsParam) => {
15
+ eventBridgePolicy: import("@webiny/pulumi/PulumiAppResource.js").PulumiAppResource<typeof import("@pulumi/aws/iam/policy.js").Policy>;
16
+ graphQlPolicyAttachment: import("@webiny/pulumi/PulumiAppResource.js").PulumiAppResource<typeof import("@pulumi/aws/iam/rolePolicyAttachment.js").RolePolicyAttachment>;
17
+ };
@@ -0,0 +1,48 @@
1
+ import * as aws from "@pulumi/aws";
2
+ import { createSyncResourceName } from "../createSyncResourceName.js";
3
+ import { ApiGraphql } from "../../api/ApiGraphql.js";
4
+ /**
5
+ * We need to attach the policy to:
6
+ * * GraphQL Lambda Role
7
+ * * File Manager Manage Lambda Role
8
+ * TODO determine if any other are required
9
+ */
10
+ export const attachEventBusPermissions = params => {
11
+ const {
12
+ app,
13
+ syncSystem
14
+ } = params;
15
+ const {
16
+ eventBusArn
17
+ } = syncSystem;
18
+ const graphql = app.getModule(ApiGraphql);
19
+ const lambdaToEventBridgeResourceName = createSyncResourceName(`lambda-to-event-bridge`);
20
+ const eventBridgePolicy = app.addResource(aws.iam.Policy, {
21
+ name: `${lambdaToEventBridgeResourceName}-policy`,
22
+ config: {
23
+ description: "This policy enables access from Webiny Lambdas to Sync System EventBridge.",
24
+ policy: {
25
+ Version: "2012-10-17",
26
+ Statement: [{
27
+ Sid: "PermissionForSyncLambdaToEventBridge",
28
+ Effect: "Allow",
29
+ Action: "events:PutEvents",
30
+ Resource: [eventBusArn]
31
+ }]
32
+ }
33
+ }
34
+ });
35
+ const graphQlPolicyAttachment = app.addResource(aws.iam.RolePolicyAttachment, {
36
+ name: `${lambdaToEventBridgeResourceName}-graphql-role-policy-attachment`,
37
+ config: {
38
+ role: graphql.role.output.name,
39
+ policyArn: eventBridgePolicy.output.arn
40
+ }
41
+ });
42
+ return {
43
+ eventBridgePolicy,
44
+ graphQlPolicyAttachment
45
+ };
46
+ };
47
+
48
+ //# sourceMappingURL=attachEventBusPermissions.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["aws","createSyncResourceName","ApiGraphql","attachEventBusPermissions","params","app","syncSystem","eventBusArn","graphql","getModule","lambdaToEventBridgeResourceName","eventBridgePolicy","addResource","iam","Policy","name","config","description","policy","Version","Statement","Sid","Effect","Action","Resource","graphQlPolicyAttachment","RolePolicyAttachment","role","output","policyArn","arn"],"sources":["attachEventBusPermissions.ts"],"sourcesContent":["import * as aws from \"@pulumi/aws\";\nimport type { PulumiApp } from \"@webiny/pulumi/types.js\";\nimport type { IGetSyncSystemOutputResult } from \"../types.js\";\nimport { createSyncResourceName } from \"../createSyncResourceName.js\";\nimport { ApiGraphql } from \"~/pulumi/apps/api/ApiGraphql.js\";\nimport type { WithServiceManifest } from \"~/pulumi/utils/withServiceManifest.js\";\n\nexport interface IAttachEventBusPermissionsParam {\n app: PulumiApp & WithServiceManifest;\n syncSystem: IGetSyncSystemOutputResult;\n}\n\n/**\n * We need to attach the policy to:\n * * GraphQL Lambda Role\n * * File Manager Manage Lambda Role\n * TODO determine if any other are required\n */\nexport const attachEventBusPermissions = (params: IAttachEventBusPermissionsParam) => {\n const { app, syncSystem } = params;\n\n const { eventBusArn } = syncSystem;\n\n const graphql = app.getModule(ApiGraphql);\n\n const lambdaToEventBridgeResourceName = createSyncResourceName(`lambda-to-event-bridge`);\n const eventBridgePolicy = app.addResource(aws.iam.Policy, {\n name: `${lambdaToEventBridgeResourceName}-policy`,\n config: {\n description:\n \"This policy enables access from Webiny Lambdas to Sync System EventBridge.\",\n policy: {\n Version: \"2012-10-17\",\n Statement: [\n {\n Sid: \"PermissionForSyncLambdaToEventBridge\",\n Effect: \"Allow\",\n Action: \"events:PutEvents\",\n Resource: [eventBusArn]\n }\n ]\n }\n }\n });\n\n const graphQlPolicyAttachment = app.addResource(aws.iam.RolePolicyAttachment, {\n name: `${lambdaToEventBridgeResourceName}-graphql-role-policy-attachment`,\n config: {\n role: graphql.role.output.name,\n policyArn: eventBridgePolicy.output.arn\n }\n });\n\n return {\n eventBridgePolicy,\n graphQlPolicyAttachment\n };\n};\n"],"mappings":"AAAA,OAAO,KAAKA,GAAG,MAAM,aAAa;AAGlC,SAASC,sBAAsB;AAC/B,SAASC,UAAU;AAQnB;AACA;AACA;AACA;AACA;AACA;AACA,OAAO,MAAMC,yBAAyB,GAAIC,MAAuC,IAAK;EAClF,MAAM;IAAEC,GAAG;IAAEC;EAAW,CAAC,GAAGF,MAAM;EAElC,MAAM;IAAEG;EAAY,CAAC,GAAGD,UAAU;EAElC,MAAME,OAAO,GAAGH,GAAG,CAACI,SAAS,CAACP,UAAU,CAAC;EAEzC,MAAMQ,+BAA+B,GAAGT,sBAAsB,CAAC,wBAAwB,CAAC;EACxF,MAAMU,iBAAiB,GAAGN,GAAG,CAACO,WAAW,CAACZ,GAAG,CAACa,GAAG,CAACC,MAAM,EAAE;IACtDC,IAAI,EAAE,GAAGL,+BAA+B,SAAS;IACjDM,MAAM,EAAE;MACJC,WAAW,EACP,4EAA4E;MAChFC,MAAM,EAAE;QACJC,OAAO,EAAE,YAAY;QACrBC,SAAS,EAAE,CACP;UACIC,GAAG,EAAE,sCAAsC;UAC3CC,MAAM,EAAE,OAAO;UACfC,MAAM,EAAE,kBAAkB;UAC1BC,QAAQ,EAAE,CAACjB,WAAW;QAC1B,CAAC;MAET;IACJ;EACJ,CAAC,CAAC;EAEF,MAAMkB,uBAAuB,GAAGpB,GAAG,CAACO,WAAW,CAACZ,GAAG,CAACa,GAAG,CAACa,oBAAoB,EAAE;IAC1EX,IAAI,EAAE,GAAGL,+BAA+B,iCAAiC;IACzEM,MAAM,EAAE;MACJW,IAAI,EAAEnB,OAAO,CAACmB,IAAI,CAACC,MAAM,CAACb,IAAI;MAC9Bc,SAAS,EAAElB,iBAAiB,CAACiB,MAAM,CAACE;IACxC;EACJ,CAAC,CAAC;EAEF,OAAO;IACHnB,iBAAiB;IACjBc;EACJ,CAAC;AACL,CAAC","ignoreList":[]}
@@ -0,0 +1,14 @@
1
+ import type { PulumiApp } from "@webiny/pulumi";
2
+ import type { IGetSyncSystemOutputResult } from "../../../../pulumi/apps/syncSystem/types.js";
3
+ import type { CoreOutput } from "../../../../pulumi/apps/common/CoreOutput.js";
4
+ import type { WithServiceManifest } from "../../../../pulumi/utils/withServiceManifest.js";
5
+ export interface IAttachS3PermissionsParams {
6
+ app: PulumiApp & WithServiceManifest;
7
+ syncSystem: IGetSyncSystemOutputResult;
8
+ core: CoreOutput;
9
+ }
10
+ export declare const attachS3Permissions: (params: IAttachS3PermissionsParams) => {
11
+ s3Policy: import("@webiny/pulumi").PulumiAppResource<typeof import("@pulumi/aws/iam/policy").Policy>;
12
+ workerLambdaS3PolicyAttachment: import("@webiny/pulumi").PulumiAppResource<typeof import("@pulumi/aws/iam/rolePolicyAttachment").RolePolicyAttachment>;
13
+ resolverLambdaS3PolicyAttachment: import("@webiny/pulumi").PulumiAppResource<typeof import("@pulumi/aws/iam/rolePolicyAttachment").RolePolicyAttachment>;
14
+ };
@@ -0,0 +1,51 @@
1
+ import * as aws from "@pulumi/aws";
2
+ import { createSyncResourceName } from "../createSyncResourceName.js";
3
+ export const attachS3Permissions = params => {
4
+ const {
5
+ app,
6
+ syncSystem,
7
+ core
8
+ } = params;
9
+ const {
10
+ resolverLambdaRoleName,
11
+ workerLambdaRoleName
12
+ } = syncSystem;
13
+ const resolverLambdaToS3ResourceName = createSyncResourceName(`resolver-lambda-to-s3-fm`);
14
+ const workerLambdaToS3ResourceName = createSyncResourceName(`worker-lambda-to-s3-fm`);
15
+ const s3Policy = app.addResource(aws.iam.Policy, {
16
+ name: `${resolverLambdaToS3ResourceName}-policy`,
17
+ config: {
18
+ description: "This policy enables access from Sync System Resolver and Worker Lambda to Webiny S3.",
19
+ policy: {
20
+ Version: "2012-10-17",
21
+ Statement: [{
22
+ Sid: "PermissionForSyncLambdaToS3",
23
+ Effect: "Allow",
24
+ Action: ["s3:DeleteObject", "s3:PutObject", "s3:GetObject", "s3:ListBucket"],
25
+ Resource: [core.fileManagerBucketArn.apply(arn => arn), core.fileManagerBucketArn.apply(arn => `${arn}/*`)]
26
+ }]
27
+ }
28
+ }
29
+ });
30
+ const resolverLambdaS3PolicyAttachment = app.addResource(aws.iam.RolePolicyAttachment, {
31
+ name: `${resolverLambdaToS3ResourceName}-policy-attachment`,
32
+ config: {
33
+ role: resolverLambdaRoleName,
34
+ policyArn: s3Policy.output.arn
35
+ }
36
+ });
37
+ const workerLambdaS3PolicyAttachment = app.addResource(aws.iam.RolePolicyAttachment, {
38
+ name: `${workerLambdaToS3ResourceName}-policy-attachment`,
39
+ config: {
40
+ role: workerLambdaRoleName,
41
+ policyArn: s3Policy.output.arn
42
+ }
43
+ });
44
+ return {
45
+ s3Policy,
46
+ workerLambdaS3PolicyAttachment,
47
+ resolverLambdaS3PolicyAttachment
48
+ };
49
+ };
50
+
51
+ //# sourceMappingURL=attachS3Permissions.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["aws","createSyncResourceName","attachS3Permissions","params","app","syncSystem","core","resolverLambdaRoleName","workerLambdaRoleName","resolverLambdaToS3ResourceName","workerLambdaToS3ResourceName","s3Policy","addResource","iam","Policy","name","config","description","policy","Version","Statement","Sid","Effect","Action","Resource","fileManagerBucketArn","apply","arn","resolverLambdaS3PolicyAttachment","RolePolicyAttachment","role","policyArn","output","workerLambdaS3PolicyAttachment"],"sources":["attachS3Permissions.ts"],"sourcesContent":["import * as aws from \"@pulumi/aws\";\nimport type { PulumiApp } from \"@webiny/pulumi\";\nimport type { IGetSyncSystemOutputResult } from \"~/pulumi/apps/syncSystem/types.js\";\nimport type { CoreOutput } from \"~/pulumi/apps/common/CoreOutput.js\";\nimport { createSyncResourceName } from \"~/pulumi/apps/syncSystem/createSyncResourceName.js\";\nimport type { WithServiceManifest } from \"~/pulumi/utils/withServiceManifest.js\";\n\nexport interface IAttachS3PermissionsParams {\n app: PulumiApp & WithServiceManifest;\n syncSystem: IGetSyncSystemOutputResult;\n core: CoreOutput;\n}\n\nexport const attachS3Permissions = (params: IAttachS3PermissionsParams) => {\n const { app, syncSystem, core } = params;\n\n const { resolverLambdaRoleName, workerLambdaRoleName } = syncSystem;\n\n const resolverLambdaToS3ResourceName = createSyncResourceName(`resolver-lambda-to-s3-fm`);\n const workerLambdaToS3ResourceName = createSyncResourceName(`worker-lambda-to-s3-fm`);\n\n const s3Policy = app.addResource(aws.iam.Policy, {\n name: `${resolverLambdaToS3ResourceName}-policy`,\n config: {\n description:\n \"This policy enables access from Sync System Resolver and Worker Lambda to Webiny S3.\",\n policy: {\n Version: \"2012-10-17\",\n Statement: [\n {\n Sid: \"PermissionForSyncLambdaToS3\",\n Effect: \"Allow\",\n Action: [\n \"s3:DeleteObject\",\n \"s3:PutObject\",\n \"s3:GetObject\",\n \"s3:ListBucket\"\n ],\n Resource: [\n core.fileManagerBucketArn.apply(arn => arn),\n core.fileManagerBucketArn.apply(arn => `${arn}/*`)\n ]\n }\n ]\n }\n }\n });\n\n const resolverLambdaS3PolicyAttachment = app.addResource(aws.iam.RolePolicyAttachment, {\n name: `${resolverLambdaToS3ResourceName}-policy-attachment`,\n config: {\n role: resolverLambdaRoleName,\n policyArn: s3Policy.output.arn\n }\n });\n\n const workerLambdaS3PolicyAttachment = app.addResource(aws.iam.RolePolicyAttachment, {\n name: `${workerLambdaToS3ResourceName}-policy-attachment`,\n config: {\n role: workerLambdaRoleName,\n policyArn: s3Policy.output.arn\n }\n });\n\n return {\n s3Policy,\n workerLambdaS3PolicyAttachment,\n resolverLambdaS3PolicyAttachment\n };\n};\n"],"mappings":"AAAA,OAAO,KAAKA,GAAG,MAAM,aAAa;AAIlC,SAASC,sBAAsB;AAS/B,OAAO,MAAMC,mBAAmB,GAAIC,MAAkC,IAAK;EACvE,MAAM;IAAEC,GAAG;IAAEC,UAAU;IAAEC;EAAK,CAAC,GAAGH,MAAM;EAExC,MAAM;IAAEI,sBAAsB;IAAEC;EAAqB,CAAC,GAAGH,UAAU;EAEnE,MAAMI,8BAA8B,GAAGR,sBAAsB,CAAC,0BAA0B,CAAC;EACzF,MAAMS,4BAA4B,GAAGT,sBAAsB,CAAC,wBAAwB,CAAC;EAErF,MAAMU,QAAQ,GAAGP,GAAG,CAACQ,WAAW,CAACZ,GAAG,CAACa,GAAG,CAACC,MAAM,EAAE;IAC7CC,IAAI,EAAE,GAAGN,8BAA8B,SAAS;IAChDO,MAAM,EAAE;MACJC,WAAW,EACP,sFAAsF;MAC1FC,MAAM,EAAE;QACJC,OAAO,EAAE,YAAY;QACrBC,SAAS,EAAE,CACP;UACIC,GAAG,EAAE,6BAA6B;UAClCC,MAAM,EAAE,OAAO;UACfC,MAAM,EAAE,CACJ,iBAAiB,EACjB,cAAc,EACd,cAAc,EACd,eAAe,CAClB;UACDC,QAAQ,EAAE,CACNlB,IAAI,CAACmB,oBAAoB,CAACC,KAAK,CAACC,GAAG,IAAIA,GAAG,CAAC,EAC3CrB,IAAI,CAACmB,oBAAoB,CAACC,KAAK,CAACC,GAAG,IAAI,GAAGA,GAAG,IAAI,CAAC;QAE1D,CAAC;MAET;IACJ;EACJ,CAAC,CAAC;EAEF,MAAMC,gCAAgC,GAAGxB,GAAG,CAACQ,WAAW,CAACZ,GAAG,CAACa,GAAG,CAACgB,oBAAoB,EAAE;IACnFd,IAAI,EAAE,GAAGN,8BAA8B,oBAAoB;IAC3DO,MAAM,EAAE;MACJc,IAAI,EAAEvB,sBAAsB;MAC5BwB,SAAS,EAAEpB,QAAQ,CAACqB,MAAM,CAACL;IAC/B;EACJ,CAAC,CAAC;EAEF,MAAMM,8BAA8B,GAAG7B,GAAG,CAACQ,WAAW,CAACZ,GAAG,CAACa,GAAG,CAACgB,oBAAoB,EAAE;IACjFd,IAAI,EAAE,GAAGL,4BAA4B,oBAAoB;IACzDM,MAAM,EAAE;MACJc,IAAI,EAAEtB,oBAAoB;MAC1BuB,SAAS,EAAEpB,QAAQ,CAACqB,MAAM,CAACL;IAC/B;EACJ,CAAC,CAAC;EAEF,OAAO;IACHhB,QAAQ;IACRsB,8BAA8B;IAC9BL;EACJ,CAAC;AACL,CAAC","ignoreList":[]}
@@ -0,0 +1,8 @@
1
+ import type { PulumiApp } from "@webiny/pulumi/types.js";
2
+ import type { CoreOutput } from "../../../../pulumi/apps/common/CoreOutput.js";
3
+ import type { WithServiceManifest } from "../../../../pulumi/utils/withServiceManifest.js";
4
+ export interface IAttachSyncSystemParams {
5
+ app: PulumiApp & WithServiceManifest;
6
+ core: CoreOutput;
7
+ }
8
+ export declare const attachSyncSystem: (params: IAttachSyncSystemParams) => Promise<void>;
@@ -0,0 +1,55 @@
1
+ import { getSyncSystemOutput } from "../getSyncSystemOutput.js";
2
+ import { attachEventBusPermissions } from "./attachEventBusPermissions.js";
3
+ import { attachDynamoDbPermissions } from "./attachDynamoDbPermissions.js";
4
+ import { attachS3Permissions } from "./attachS3Permissions.js";
5
+ import { addServiceManifest } from "./addServiceManifest.js";
6
+ import { attachCognitoPermissions } from "./attachCognitoPermissions.js";
7
+ export const attachSyncSystem = async params => {
8
+ const {
9
+ app,
10
+ core
11
+ } = params;
12
+ const syncSystem = await getSyncSystemOutput();
13
+ /**
14
+ * Possibly no sync system deployed - no need to do anything at that point.
15
+ * At this point, if sync system was deployed, and it is not anymore, all resources after this check will disappear.
16
+ */
17
+ if (!syncSystem) {
18
+ console.log(`No Sync System deployed. Skipping...`);
19
+ return;
20
+ }
21
+ /**
22
+ * Permissions for Webiny system to access Sync System resources.
23
+ */
24
+ attachEventBusPermissions({
25
+ app,
26
+ syncSystem
27
+ });
28
+ /**
29
+ * Permissions for Sync System to access Webiny system resources.
30
+ */
31
+ attachCognitoPermissions({
32
+ app,
33
+ syncSystem,
34
+ core
35
+ });
36
+ attachDynamoDbPermissions({
37
+ app,
38
+ syncSystem,
39
+ core
40
+ });
41
+ attachS3Permissions({
42
+ app,
43
+ syncSystem,
44
+ core
45
+ });
46
+ /**
47
+ * Add the Service Manifest item to the Webiny system.
48
+ */
49
+ addServiceManifest({
50
+ app,
51
+ syncSystem
52
+ });
53
+ };
54
+
55
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["getSyncSystemOutput","attachEventBusPermissions","attachDynamoDbPermissions","attachS3Permissions","addServiceManifest","attachCognitoPermissions","attachSyncSystem","params","app","core","syncSystem","console","log"],"sources":["index.ts"],"sourcesContent":["import { getSyncSystemOutput } from \"~/pulumi/apps/syncSystem/getSyncSystemOutput.js\";\nimport { attachEventBusPermissions } from \"./attachEventBusPermissions.js\";\nimport { attachDynamoDbPermissions } from \"~/pulumi/apps/syncSystem/api/attachDynamoDbPermissions.js\";\nimport { attachS3Permissions } from \"~/pulumi/apps/syncSystem/api/attachS3Permissions.js\";\nimport { addServiceManifest } from \"~/pulumi/apps/syncSystem/api/addServiceManifest.js\";\nimport type { PulumiApp } from \"@webiny/pulumi/types.js\";\nimport type { CoreOutput } from \"~/pulumi/apps/common/CoreOutput.js\";\nimport type { WithServiceManifest } from \"~/pulumi/utils/withServiceManifest.js\";\nimport { attachCognitoPermissions } from \"~/pulumi/apps/syncSystem/api/attachCognitoPermissions.js\";\n\nexport interface IAttachSyncSystemParams {\n app: PulumiApp & WithServiceManifest;\n core: CoreOutput;\n}\n\nexport const attachSyncSystem = async (params: IAttachSyncSystemParams) => {\n const { app, core } = params;\n\n const syncSystem = await getSyncSystemOutput();\n /**\n * Possibly no sync system deployed - no need to do anything at that point.\n * At this point, if sync system was deployed, and it is not anymore, all resources after this check will disappear.\n */\n if (!syncSystem) {\n console.log(`No Sync System deployed. Skipping...`);\n return;\n }\n /**\n * Permissions for Webiny system to access Sync System resources.\n */\n attachEventBusPermissions({\n app,\n syncSystem\n });\n /**\n * Permissions for Sync System to access Webiny system resources.\n */\n attachCognitoPermissions({\n app,\n syncSystem,\n core\n });\n attachDynamoDbPermissions({\n app,\n syncSystem,\n core\n });\n attachS3Permissions({\n app,\n syncSystem,\n core\n });\n /**\n * Add the Service Manifest item to the Webiny system.\n */\n addServiceManifest({\n app,\n syncSystem\n });\n};\n"],"mappings":"AAAA,SAASA,mBAAmB;AAC5B,SAASC,yBAAyB;AAClC,SAASC,yBAAyB;AAClC,SAASC,mBAAmB;AAC5B,SAASC,kBAAkB;AAI3B,SAASC,wBAAwB;AAOjC,OAAO,MAAMC,gBAAgB,GAAG,MAAOC,MAA+B,IAAK;EACvE,MAAM;IAAEC,GAAG;IAAEC;EAAK,CAAC,GAAGF,MAAM;EAE5B,MAAMG,UAAU,GAAG,MAAMV,mBAAmB,CAAC,CAAC;EAC9C;AACJ;AACA;AACA;EACI,IAAI,CAACU,UAAU,EAAE;IACbC,OAAO,CAACC,GAAG,CAAC,sCAAsC,CAAC;IACnD;EACJ;EACA;AACJ;AACA;EACIX,yBAAyB,CAAC;IACtBO,GAAG;IACHE;EACJ,CAAC,CAAC;EACF;AACJ;AACA;EACIL,wBAAwB,CAAC;IACrBG,GAAG;IACHE,UAAU;IACVD;EACJ,CAAC,CAAC;EACFP,yBAAyB,CAAC;IACtBM,GAAG;IACHE,UAAU;IACVD;EACJ,CAAC,CAAC;EACFN,mBAAmB,CAAC;IAChBK,GAAG;IACHE,UAAU;IACVD;EACJ,CAAC,CAAC;EACF;AACJ;AACA;EACIL,kBAAkB,CAAC;IACfI,GAAG;IACHE;EACJ,CAAC,CAAC;AACN,CAAC","ignoreList":[]}
@@ -0,0 +1 @@
1
+ export declare const APPS_SYNC_SYSTEM_PATH = "apps/sync";
@@ -0,0 +1,3 @@
1
+ export const APPS_SYNC_SYSTEM_PATH = "apps/sync";
2
+
3
+ //# sourceMappingURL=constants.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["APPS_SYNC_SYSTEM_PATH"],"sources":["constants.ts"],"sourcesContent":["export const APPS_SYNC_SYSTEM_PATH = \"apps/sync\";\n"],"mappings":"AAAA,OAAO,MAAMA,qBAAqB,GAAG,WAAW","ignoreList":[]}
@@ -0,0 +1,4 @@
1
+ /**
2
+ * Need to have standardized resource names.
3
+ */
4
+ export declare const createSyncResourceName: (name: string) => string;
@@ -0,0 +1,10 @@
1
+ import kebabCase from "lodash/kebabCase.js";
2
+
3
+ /**
4
+ * Need to have standardized resource names.
5
+ */
6
+ export const createSyncResourceName = name => {
7
+ return `sync-system-${kebabCase(name)}`;
8
+ };
9
+
10
+ //# sourceMappingURL=createSyncResourceName.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["kebabCase","createSyncResourceName","name"],"sources":["createSyncResourceName.ts"],"sourcesContent":["import kebabCase from \"lodash/kebabCase.js\";\n\n/**\n * Need to have standardized resource names.\n */\nexport const createSyncResourceName = (name: string) => {\n return `sync-system-${kebabCase(name)}`;\n};\n"],"mappings":"AAAA,OAAOA,SAAS,MAAM,qBAAqB;;AAE3C;AACA;AACA;AACA,OAAO,MAAMC,sBAAsB,GAAIC,IAAY,IAAK;EACpD,OAAO,eAAeF,SAAS,CAACE,IAAI,CAAC,EAAE;AAC3C,CAAC","ignoreList":[]}
@@ -0,0 +1,26 @@
1
+ import * as pulumi from "@pulumi/pulumi";
2
+ export declare function createSyncSystemPulumiApp(): import("@webiny/pulumi").PulumiApp<{
3
+ sqs: pulumi.Output<import("@pulumi/aws/sqs/queue.js").Queue>;
4
+ dynamoDb: pulumi.Output<import("@pulumi/aws/dynamodb/table.js").Table>;
5
+ eventBus: pulumi.Output<import("@pulumi/aws/cloudwatch/eventBus.js").EventBus>;
6
+ eventBusRule: pulumi.Output<import("@pulumi/aws/cloudwatch/eventRule.js").EventRule>;
7
+ eventBusTarget: pulumi.Output<import("@pulumi/aws/cloudwatch/eventTarget.js").EventTarget>;
8
+ eventBusPolicy: pulumi.Output<import("@pulumi/aws/sqs/queuePolicy.js").QueuePolicy>;
9
+ /**
10
+ * Worker Lambda - used to resolve actions triggered by the resolver Lambda.
11
+ */
12
+ workerLambda: pulumi.Output<import("@pulumi/aws/lambda/function.js").Function>;
13
+ workerLambdaRole: pulumi.Output<import("@pulumi/aws/iam/role.js").Role>;
14
+ /**
15
+ * Resolver Lambda - gets hit by SQS and resolves the data.
16
+ */
17
+ resolverLambda: pulumi.Output<import("@pulumi/aws/lambda/function.js").Function>;
18
+ resolverLambdaRole: pulumi.Output<import("@pulumi/aws/iam/role.js").Role>;
19
+ resolverLambdaPolicy: pulumi.Output<import("@pulumi/aws/iam/policy.js").Policy>;
20
+ resolverLambdaEventSourceMapping: pulumi.Output<import("@pulumi/aws/lambda/eventSourceMapping.js").EventSourceMapping>;
21
+ /**
22
+ * Systems we are connecting together.
23
+ */
24
+ primary: {};
25
+ secondary: {};
26
+ }>;
@@ -0,0 +1,181 @@
1
+ import * as pulumi from "@pulumi/pulumi";
2
+ import * as aws from "@pulumi/aws";
3
+ import { createPulumiApp, isResourceOfType } from "@webiny/pulumi";
4
+ import { SyncSystemSQS } from "./SyncSystemSQS.js";
5
+ import { SyncSystemResolverLambda } from "./SyncSystemResolverLambda.js";
6
+ import { APPS_SYNC_SYSTEM_PATH } from "./constants.js";
7
+ import { SyncSystemEventBus } from "./SyncSystemEventBus.js";
8
+ import { customApp } from "./customApp.js";
9
+ import { SyncSystemDynamoDb } from "./SyncSystemDynamoDb.js";
10
+ import { SyncSystemWorkerLambda } from "./SyncSystemWorkerLambda.js";
11
+ import { getProjectSdk } from "@webiny/project";
12
+ import { getVpcConfigFromExtension } from "../extensions/getVpcConfigFromExtension.js";
13
+ import { applyAwsResourceTags } from "../awsUtils.js";
14
+ export function createSyncSystemPulumiApp() {
15
+ return createPulumiApp({
16
+ name: "sync",
17
+ path: APPS_SYNC_SYSTEM_PATH,
18
+ program: async app => {
19
+ const sdk = await getProjectSdk();
20
+ const projectConfig = await sdk.getProjectConfig();
21
+ const pulumiResourceNamePrefix = await sdk.getPulumiResourceNamePrefix();
22
+ const vpcExtensionsConfig = getVpcConfigFromExtension(projectConfig);
23
+ if (pulumiResourceNamePrefix) {
24
+ app.onResource(resource => {
25
+ if (!resource.name.startsWith(pulumiResourceNamePrefix)) {
26
+ resource.name = `${pulumiResourceNamePrefix}${resource.name}`;
27
+ }
28
+ });
29
+ }
30
+
31
+ // <-------------------- Enterprise start -------------------->
32
+ app.addHandler(async () => {
33
+ const usingAdvancedVpcParams = vpcExtensionsConfig && typeof vpcExtensionsConfig !== "boolean";
34
+
35
+ // Not using advanced VPC params? Then immediately exit.
36
+ if (!usingAdvancedVpcParams) {
37
+ return;
38
+ }
39
+ const {
40
+ onResource,
41
+ addResource
42
+ } = app;
43
+ const {
44
+ useExistingVpc
45
+ } = vpcExtensionsConfig;
46
+
47
+ // 1. We first deal with "existing VPC" setup.
48
+ if (useExistingVpc) {
49
+ if (!useExistingVpc.lambdaFunctionsVpcConfig) {
50
+ throw new Error("Cannot specify `useExistingVpc` parameter because the `lambdaFunctionsVpcConfig` parameter wasn't provided.");
51
+ }
52
+ onResource(resource => {
53
+ if (isResourceOfType(resource, aws.lambda.Function)) {
54
+ const canUseVpc = resource.meta.canUseVpc !== false;
55
+ if (canUseVpc) {
56
+ resource.config.vpcConfig(useExistingVpc.lambdaFunctionsVpcConfig);
57
+ }
58
+ }
59
+ if (isResourceOfType(resource, aws.iam.Role)) {
60
+ if (resource.meta.isLambdaFunctionRole) {
61
+ addResource(aws.iam.RolePolicyAttachment, {
62
+ name: `${resource.name}-vpc-access-execution-role`,
63
+ config: {
64
+ role: resource.output.name,
65
+ policyArn: aws.iam.ManagedPolicy.AWSLambdaVPCAccessExecutionRole
66
+ }
67
+ });
68
+ }
69
+ }
70
+ });
71
+ }
72
+ return;
73
+ });
74
+ // <-------------------- Enterprise end -------------------->
75
+
76
+ const protect = app.env.isProduction;
77
+ const regionApp = customApp({
78
+ app,
79
+ protect
80
+ });
81
+ /**
82
+ * Sync System services.
83
+ */
84
+ const {
85
+ sqsQueue
86
+ } = regionApp.addModule(SyncSystemSQS);
87
+ const dynamoDb = regionApp.addModule(SyncSystemDynamoDb);
88
+ const workerLambda = regionApp.addModule(SyncSystemWorkerLambda);
89
+ const resolverLambda = regionApp.addModule(SyncSystemResolverLambda);
90
+ const {
91
+ eventBusRule,
92
+ eventBus,
93
+ eventBusTarget,
94
+ eventBusPolicy
95
+ } = regionApp.addModule(SyncSystemEventBus);
96
+ const output = {
97
+ /**
98
+ * Region provider.
99
+ */
100
+ region: pulumi.output(process.env.AWS_REGION),
101
+ /**
102
+ * SyncSystemSQS
103
+ */
104
+ sqsUrl: sqsQueue.output.url,
105
+ sqsArn: sqsQueue.output.arn,
106
+ sqsName: sqsQueue.output.name,
107
+ /**
108
+ * DynamoDB
109
+ */
110
+ dynamoDbArn: dynamoDb.output.arn,
111
+ dynamoDbName: dynamoDb.output.name,
112
+ dynamoDbHashKey: dynamoDb.output.hashKey,
113
+ dynamoDbRangeKey: dynamoDb.output.rangeKey,
114
+ /**
115
+ * SyncSystemResolverLambda
116
+ */
117
+ resolverLambdaArn: resolverLambda.lambda.output.arn,
118
+ resolverLambdaName: resolverLambda.lambda.output.name,
119
+ resolverLambdaRoleArn: resolverLambda.role.output.arn,
120
+ resolverLambdaRoleName: resolverLambda.role.output.name,
121
+ resolverLambdaRoleId: resolverLambda.role.output.id,
122
+ resolverLambdaPolicyArn: resolverLambda.policy.output.arn,
123
+ resolverLambdaPolicyName: resolverLambda.policy.output.name,
124
+ resolverLambdaPolicyId: resolverLambda.policy.output.id,
125
+ resolverLambdaEventSourceMappingArn: resolverLambda.eventSourceMapping.output.arn,
126
+ resolverLambdaEventSourceMappingId: resolverLambda.eventSourceMapping.output.id,
127
+ // # We can safely cast as we know that the property exists.
128
+ resolverLambdaEventSourceMappingEventSourceArn: resolverLambda.eventSourceMapping.output.eventSourceArn,
129
+ /**
130
+ * SyncSystemWorkerLambda
131
+ */
132
+ workerLambdaArn: workerLambda.lambda.output.arn,
133
+ workerLambdaName: workerLambda.lambda.output.name,
134
+ workerLambdaRoleArn: workerLambda.role.output.arn,
135
+ workerLambdaRoleName: workerLambda.role.output.name,
136
+ /**
137
+ * SyncSystemEventBus
138
+ */
139
+ eventBusArn: eventBus.output.arn,
140
+ eventBusName: eventBus.output.name,
141
+ eventBusRuleArn: eventBusRule.output.arn,
142
+ eventBusRuleName: eventBusRule.output.id,
143
+ eventBusTargetArn: eventBusTarget.output.arn,
144
+ eventBusPolicyId: eventBusPolicy.output.id,
145
+ eventBusPolicyUrn: eventBusPolicy.output.urn,
146
+ eventBusPolicyQueueUrl: eventBusPolicy.output.queueUrl
147
+ };
148
+ app.addOutputs(output);
149
+
150
+ // Applies internal and user-defined AWS tags.
151
+ await applyAwsResourceTags("sync");
152
+ return {
153
+ sqs: sqsQueue.output,
154
+ dynamoDb: dynamoDb.output,
155
+ eventBus: eventBus.output,
156
+ eventBusRule: eventBusRule.output,
157
+ eventBusTarget: eventBusTarget.output,
158
+ eventBusPolicy: eventBusPolicy.output,
159
+ /**
160
+ * Worker Lambda - used to resolve actions triggered by the resolver Lambda.
161
+ */
162
+ workerLambda: workerLambda.lambda.output,
163
+ workerLambdaRole: workerLambda.role.output,
164
+ /**
165
+ * Resolver Lambda - gets hit by SQS and resolves the data.
166
+ */
167
+ resolverLambda: resolverLambda.lambda.output,
168
+ resolverLambdaRole: resolverLambda.role.output,
169
+ resolverLambdaPolicy: resolverLambda.policy.output,
170
+ resolverLambdaEventSourceMapping: resolverLambda.eventSourceMapping.output,
171
+ /**
172
+ * Systems we are connecting together.
173
+ */
174
+ primary: {},
175
+ secondary: {}
176
+ };
177
+ }
178
+ });
179
+ }
180
+
181
+ //# sourceMappingURL=createSyncSystemPulumiApp.js.map