@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 @@
1
+ {"version":3,"names":["path","pulumi","aws","random","createAppModule","getAwsAccountId","CoreVpc","LAMBDA_RUNTIME","LogDynamo","getDevClusterConfig","instanceType","getProdClusterConfig","instanceCount","zoneAwarenessEnabled","zoneAwarenessConfig","availabilityZoneCount","OS_ENGINE_VERSION","OpenSearch","name","config","app","params","isProduction","env","vpc","getModule","optional","logDynamoDbTable","domain","domainPolicy","process","AWS_OS_DOMAIN_NAME","domainName","String","addRemoteResource","opensearch","getDomain","async","randomId","RandomId","byteLength","namePrefix","getParam","create","pulumiResourceNamePrefix","domainLogicalName","domainPhysicalName","hex","apply","slice","addResource","Domain","engineVersion","clusterConfig","vpcOptions","subnetIds","subnets","private","map","s","output","id","securityGroupIds","defaultSecurityGroupId","undefined","ebsOptions","ebsEnabled","volumeSize","volumeType","advancedOptions","snapshotOptions","automatedSnapshotStartHour","opts","protect","accountId","DomainPolicy","accessPolicies","all","arn","domainArn","JSON","stringify","Version","Statement","Effect","Principal","AWS","Action","Resource","table","dynamodb","Table","attributes","type","streamEnabled","streamViewType","billingMode","hashKey","rangeKey","globalSecondaryIndexes","projectionType","ttl","attributeName","enabled","roleName","role","iam","Role","assumeRolePolicy","Service","meta","isLambdaFunctionRole","policy","getDynamoDbToElasticLambdaPolicy","RolePolicyAttachment","policyArn","ManagedPolicy","AWSLambdaVPCAccessExecutionRole","AWSLambdaBasicExecutionRole","AWSLambdaDynamoDBExecutionRole","lambda","Function","runtime","handler","timeout","memorySize","environment","variables","DEBUG","OPENSEARCH_ENDPOINT","endpoint","DB_TABLE_LOG","description","code","asset","AssetArchive","FileArchive","join","paths","workspace","vpcConfig","loggingConfig","logFormat","eventSourceMapping","EventSourceMapping","eventSourceArn","streamArn","functionName","startingPosition","maximumRetryAttempts","batchSize","maximumBatchingWindowInSeconds","addOutputs","opensearchDomainArn","opensearchDomainEndpoint","opensearchDynamodbTableArn","opensearchDynamodbTableName","dynamoToElastic","Policy","Sid","interpolate"],"sources":["CoreOpenSearch.ts"],"sourcesContent":["/**\n * Important documents to read:\n *\n * https://docs.aws.amazon.com/opensearch-service/latest/developerguide/limits.html#network-limits\n */\nimport path from \"path\";\nimport * as pulumi from \"@pulumi/pulumi\";\nimport * as aws from \"@pulumi/aws\";\nimport * as random from \"@pulumi/random\";\nimport {\n createAppModule,\n type PulumiApp,\n type PulumiAppRemoteResource,\n type PulumiAppResource,\n type PulumiAppResourceConstructor\n} from \"@webiny/pulumi\";\n\nimport { getAwsAccountId } from \"../awsUtils.js\";\nimport { CoreVpc } from \"./CoreVpc.js\";\nimport { LAMBDA_RUNTIME } from \"~/pulumi/constants.js\";\nimport { LogDynamo } from \"~/pulumi/apps/core/LogDynamo.js\";\n\nexport interface OpenSearchParams {\n protect: boolean;\n}\n\nfunction getDevClusterConfig(): aws.types.input.opensearch.DomainClusterConfig {\n return {\n instanceType: \"t3.small.search\"\n };\n}\n\nfunction getProdClusterConfig(): aws.types.input.opensearch.DomainClusterConfig {\n return {\n // For production deployments, we create 3 instances and configure multi-AZ across 3 zones.\n instanceType: \"t3.medium.search\",\n instanceCount: 3,\n zoneAwarenessEnabled: true,\n zoneAwarenessConfig: {\n availabilityZoneCount: 3\n }\n };\n}\n\nconst OS_ENGINE_VERSION = \"OpenSearch_3.3\";\n\nexport const OpenSearch = createAppModule({\n name: \"OpenSearch\",\n config(app, params: OpenSearchParams) {\n const isProduction = app.env.isProduction;\n\n const vpc = app.getModule(CoreVpc, { optional: true });\n\n const logDynamoDbTable = app.getModule(LogDynamo);\n\n // This needs to be implemented in order to be able to use a shared OpenSearch cluster.\n let domain:\n | PulumiAppResource<PulumiAppResourceConstructor<aws.opensearch.Domain>>\n | PulumiAppRemoteResource<aws.opensearch.GetDomainResult>;\n\n let domainPolicy;\n\n if (process.env.AWS_OS_DOMAIN_NAME) {\n const domainName = String(process.env.AWS_OS_DOMAIN_NAME);\n // This can be useful for testing purposes in ephemeral environments. More information here:\n // https://www.webiny.com/docs/key-topics/ci-cd/testing/slow-ephemeral-environments\n domain = app.addRemoteResource(domainName, () => {\n return aws.opensearch.getDomain({ domainName }, { async: true });\n });\n } else {\n const randomId = new random.RandomId(\"osDomainRandomId\", { byteLength: 8 });\n const namePrefix = app.getParam(app.params.create.pulumiResourceNamePrefix) || \"\";\n\n const domainLogicalName = \"webiny-js\";\n const domainPhysicalName = randomId.hex.apply((hex: string) => {\n return `${namePrefix}${domainLogicalName}-${hex.slice(-7)}`;\n });\n\n domain = app.addResource(aws.opensearch.Domain, {\n name: domainLogicalName,\n config: {\n domainName: domainPhysicalName,\n engineVersion: OS_ENGINE_VERSION,\n clusterConfig: isProduction ? getProdClusterConfig() : getDevClusterConfig(),\n vpcOptions: vpc\n ? {\n subnetIds: vpc.subnets.private.map(s => s.output.id),\n securityGroupIds: [vpc.vpc.output.defaultSecurityGroupId]\n }\n : undefined,\n ebsOptions: {\n ebsEnabled: true,\n volumeSize: 10,\n volumeType: \"gp2\"\n },\n advancedOptions: {\n \"rest.action.multi.allow_explicit_index\": \"true\"\n },\n snapshotOptions: {\n automatedSnapshotStartHour: 23\n }\n },\n opts: { protect: params.protect }\n });\n\n /**\n * Domain policy defines who can access your OpenSearch Domain.\n * For details on OpenSearch security, read the official documentation:\n * https://docs.aws.amazon.com/openSearch-service/latest/developerguide/security.html\n */\n const accountId = getAwsAccountId(app);\n\n domainPolicy = app.addResource(aws.opensearch.DomainPolicy, {\n name: `${domainLogicalName}-policy`,\n config: {\n domainName: domain.output.domainName,\n accessPolicies: pulumi\n .all([accountId, domain.output.arn])\n .apply(([accountId, domainArn]) => {\n return JSON.stringify({\n Version: \"2012-10-17\",\n Statement: [\n /**\n * Allow requests signed with current account\n */\n {\n Effect: \"Allow\",\n Principal: {\n AWS: accountId\n },\n Action: \"es:*\",\n Resource: `${domainArn}/*`\n }\n ]\n });\n })\n },\n opts: { protect: params.protect }\n });\n }\n\n /**\n * Create a table for OpenSearch records. All ES records are stored in this table to dramatically improve\n * performance and stability on write operations (especially massive data imports). This table also serves as a backup and\n * a single source of truth for your OpenSearch domain. Streaming is enabled on this table, and it will\n * allow asynchronous synchronization of data with OpenSearch domain.\n */\n const table = app.addResource(aws.dynamodb.Table, {\n name: \"webiny-es\",\n config: {\n attributes: [\n { name: \"PK\", type: \"S\" },\n { name: \"SK\", type: \"S\" },\n { name: \"GSI_TENANT\", type: \"S\" }\n ],\n streamEnabled: true,\n streamViewType: \"NEW_AND_OLD_IMAGES\",\n billingMode: \"PAY_PER_REQUEST\",\n hashKey: \"PK\",\n rangeKey: \"SK\",\n globalSecondaryIndexes: [\n {\n name: \"GSI_TENANT\",\n hashKey: \"GSI_TENANT\",\n projectionType: \"KEYS_ONLY\"\n }\n ],\n ttl: {\n attributeName: \"expiresAt\",\n enabled: true\n }\n },\n opts: { protect: params.protect }\n });\n\n const roleName = \"dynamo-to-elastic-lambda-role\";\n\n const role = app.addResource(aws.iam.Role, {\n name: roleName,\n config: {\n assumeRolePolicy: {\n Version: \"2012-10-17\",\n Statement: [\n {\n Action: \"sts:AssumeRole\",\n Principal: {\n Service: \"lambda.amazonaws.com\"\n },\n Effect: \"Allow\"\n }\n ]\n }\n },\n meta: { isLambdaFunctionRole: true }\n });\n\n const policy = getDynamoDbToElasticLambdaPolicy(app, domain.output);\n\n app.addResource(aws.iam.RolePolicyAttachment, {\n name: `${roleName}-DynamoDbToElasticLambdaPolicy`,\n config: {\n role: role.output,\n policyArn: policy.output.arn\n }\n });\n\n // Only use `AWSLambdaVPCAccessExecutionRole` policy if VPC feature is enabled.\n if (vpc) {\n app.addResource(aws.iam.RolePolicyAttachment, {\n name: `${roleName}-AWSLambdaVPCAccessExecutionRole`,\n config: {\n role: role.output,\n policyArn: aws.iam.ManagedPolicy.AWSLambdaVPCAccessExecutionRole\n }\n });\n } else {\n app.addResource(aws.iam.RolePolicyAttachment, {\n name: `${roleName}-AWSLambdaBasicExecutionRole`,\n config: {\n role: role.output,\n policyArn: aws.iam.ManagedPolicy.AWSLambdaBasicExecutionRole\n }\n });\n }\n\n app.addResource(aws.iam.RolePolicyAttachment, {\n name: `${roleName}-AWSLambdaDynamoDBExecutionRole`,\n config: {\n role: role.output,\n policyArn: aws.iam.ManagedPolicy.AWSLambdaDynamoDBExecutionRole\n }\n });\n\n /**\n * This Lambda will process the stream events from DynamoDB table that contains OpenSearch items.\n * OpenSearch can't take large amount of individual writes in a short period of time, so this way\n * we store data for OpenSearch in a DynamoDB table, and asynchronously insert it into OpenSearch\n * using batching.\n */\n const lambda = app.addResource(aws.lambda.Function, {\n name: \"dynamo-to-elastic\",\n config: {\n role: role.output.arn,\n runtime: LAMBDA_RUNTIME,\n handler: \"handler.handler\",\n timeout: 900,\n memorySize: 1024,\n environment: {\n variables: {\n DEBUG: String(process.env.DEBUG),\n OPENSEARCH_ENDPOINT: domain.output.endpoint,\n DB_TABLE_LOG: logDynamoDbTable.output.name\n }\n },\n description: \"Process DynamoDB Stream.\",\n code: new pulumi.asset.AssetArchive({\n \".\": new pulumi.asset.FileArchive(\n path.join(app.paths.workspace, \"dynamoToElastic/build\")\n )\n }),\n vpcConfig: vpc\n ? {\n subnetIds: vpc.subnets.private.map(s => s.output.id),\n securityGroupIds: [vpc.vpc.output.defaultSecurityGroupId]\n }\n : undefined,\n loggingConfig: {\n logFormat: \"JSON\"\n }\n }\n });\n\n const eventSourceMapping = app.addResource(aws.lambda.EventSourceMapping, {\n name: \"dynamo-to-elastic\",\n config: {\n eventSourceArn: table.output.streamArn,\n functionName: lambda.output.arn,\n startingPosition: \"LATEST\",\n maximumRetryAttempts: 3,\n batchSize: 50,\n maximumBatchingWindowInSeconds: 1\n }\n });\n\n app.addOutputs({\n opensearchDomainArn: domain.output.arn,\n opensearchDomainEndpoint: domain.output.endpoint,\n opensearchDynamodbTableArn: table.output.arn,\n opensearchDynamodbTableName: table.output.name\n });\n\n return {\n domain,\n domainPolicy,\n table,\n dynamoToElastic: {\n role,\n policy,\n lambda,\n eventSourceMapping\n }\n };\n }\n});\n\nfunction getDynamoDbToElasticLambdaPolicy(\n app: PulumiApp,\n domain: pulumi.Output<aws.opensearch.Domain | aws.opensearch.GetDomainResult>\n) {\n return app.addResource(aws.iam.Policy, {\n name: \"DynamoDbToElasticLambdaPolicy-updated\",\n config: {\n description: \"This policy enables access to ES and Dynamodb streams\",\n policy: {\n Version: \"2012-10-17\",\n Statement: [\n {\n Sid: \"PermissionForES\",\n Effect: \"Allow\",\n Action: [\n \"es:ESHttpGet\",\n \"es:ESHttpDelete\",\n \"es:ESHttpPatch\",\n \"es:ESHttpPost\",\n \"es:ESHttpPut\",\n \"dynamodb:BatchGetItem\",\n \"dynamodb:BatchWriteItem\",\n \"dynamodb:PutItem\",\n \"dynamodb:GetItem\",\n \"dynamodb:DeleteItem\",\n \"dynamodb:Query\",\n \"dynamodb:UpdateItem\"\n ],\n Resource: [\n pulumi.interpolate`${domain.arn}`,\n pulumi.interpolate`${domain.arn}/*`\n ]\n }\n ]\n }\n }\n });\n}\n"],"mappings":"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","ignoreList":[]}
@@ -0,0 +1,13 @@
1
+ import { type PulumiAppModule } from "@webiny/pulumi";
2
+ export type CoreVpc = PulumiAppModule<typeof CoreVpc>;
3
+ export declare const CoreVpc: import("@webiny/pulumi").PulumiAppModuleDefinition<{
4
+ vpc: import("@webiny/pulumi").PulumiAppResource<typeof import("@pulumi/aws/ec2/vpc").Vpc>;
5
+ subnets: {
6
+ public: import("@webiny/pulumi").PulumiAppResource<typeof import("@pulumi/aws/ec2/subnet").Subnet>[];
7
+ private: import("@webiny/pulumi").PulumiAppResource<typeof import("@pulumi/aws/ec2/subnet").Subnet>[];
8
+ };
9
+ routeTables: {
10
+ privateSubnets: import("@webiny/pulumi").PulumiAppResource<typeof import("@pulumi/aws/ec2/routeTable").RouteTable>;
11
+ publicSubnets: import("@webiny/pulumi").PulumiAppResource<typeof import("@pulumi/aws/ec2/routeTable").RouteTable>;
12
+ };
13
+ }, void>;
@@ -0,0 +1,160 @@
1
+ import * as aws from "@pulumi/aws";
2
+ import { createAppModule } from "@webiny/pulumi";
3
+ export const CoreVpc = createAppModule({
4
+ name: "CoreVpc",
5
+ config(app) {
6
+ // Create VPC.
7
+ const vpc = app.addResource(aws.ec2.Vpc, {
8
+ name: "webiny",
9
+ config: {
10
+ cidrBlock: "10.0.0.0/16"
11
+ }
12
+ });
13
+
14
+ // Create one public and three private subnets.
15
+ // The third subnet will use the third AZ if available, otherwise reuses the first AZ.
16
+ const publicSubnet = app.addResource(aws.ec2.Subnet, {
17
+ name: "public",
18
+ config: {
19
+ vpcId: vpc.output.id,
20
+ cidrBlock: "10.0.0.0/24",
21
+ tags: {
22
+ Name: "public-subnet"
23
+ }
24
+ }
25
+ });
26
+ const availabilityZones = app.addHandler(() => {
27
+ return aws.getAvailabilityZones({
28
+ state: "available"
29
+ });
30
+ });
31
+ const privateSubnet1 = app.addResource(aws.ec2.Subnet, {
32
+ name: "private-subnet-1",
33
+ config: {
34
+ vpcId: vpc.output.id,
35
+ cidrBlock: "10.0.1.0/24",
36
+ availabilityZone: availabilityZones.apply(zone => zone.names[0]),
37
+ tags: {
38
+ Name: "private-subnet-1"
39
+ }
40
+ }
41
+ });
42
+ const privateSubnet2 = app.addResource(aws.ec2.Subnet, {
43
+ name: "private-subnet-2",
44
+ config: {
45
+ vpcId: vpc.output.id,
46
+ cidrBlock: "10.0.2.0/24",
47
+ availabilityZone: availabilityZones.apply(zone => zone.names[1] || zone.names[0]),
48
+ tags: {
49
+ Name: "private-subnet-2"
50
+ }
51
+ }
52
+ });
53
+ const privateSubnet3 = app.addResource(aws.ec2.Subnet, {
54
+ name: "private-subnet-3",
55
+ config: {
56
+ vpcId: vpc.output.id,
57
+ cidrBlock: "10.0.3.0/24",
58
+ availabilityZone: availabilityZones.apply(zone => zone.names[2] || zone.names[0]),
59
+ tags: {
60
+ Name: "private-subnet-3"
61
+ }
62
+ }
63
+ });
64
+
65
+ // Create Internet gateway.
66
+ const internetGateway = app.addResource(aws.ec2.InternetGateway, {
67
+ name: "internet-gateway",
68
+ config: {
69
+ vpcId: vpc.output.id
70
+ }
71
+ });
72
+
73
+ // Create NAT gateway.z
74
+ const elasticIpAllocation = app.addResource(aws.ec2.Eip, {
75
+ name: "nat-gateway-elastic-ip",
76
+ config: {
77
+ domain: "vpc"
78
+ }
79
+ });
80
+ const natGateway = app.addResource(aws.ec2.NatGateway, {
81
+ name: "nat-gateway",
82
+ config: {
83
+ allocationId: elasticIpAllocation.output.id,
84
+ subnetId: publicSubnet.output.id
85
+ }
86
+ });
87
+
88
+ // Create a route table for both subnets.
89
+ const publicSubnetRouteTable = app.addResource(aws.ec2.RouteTable, {
90
+ name: "public",
91
+ config: {
92
+ vpcId: vpc.output.id,
93
+ routes: [{
94
+ cidrBlock: "0.0.0.0/0",
95
+ gatewayId: internetGateway.output.id
96
+ }]
97
+ }
98
+ });
99
+ const privateSubnetRouteTable = app.addResource(aws.ec2.RouteTable, {
100
+ name: "private",
101
+ config: {
102
+ vpcId: vpc.output.id,
103
+ routes: [{
104
+ cidrBlock: "0.0.0.0/0",
105
+ natGatewayId: natGateway.output.id
106
+ }]
107
+ }
108
+ });
109
+
110
+ // Create route table associations - links between subnets and route tables.
111
+ app.addResource(aws.ec2.RouteTableAssociation, {
112
+ name: "public-subnet-route-table-association",
113
+ config: {
114
+ subnetId: publicSubnet.output.id,
115
+ routeTableId: publicSubnetRouteTable.output.id
116
+ }
117
+ });
118
+ app.addResource(aws.ec2.RouteTableAssociation, {
119
+ name: "private-subnet-1-route-table-association",
120
+ config: {
121
+ subnetId: privateSubnet1.output.id,
122
+ routeTableId: privateSubnetRouteTable.output.id
123
+ }
124
+ });
125
+ app.addResource(aws.ec2.RouteTableAssociation, {
126
+ name: "private-subnet-2-route-table-association",
127
+ config: {
128
+ subnetId: privateSubnet2.output.id,
129
+ routeTableId: privateSubnetRouteTable.output.id
130
+ }
131
+ });
132
+ app.addResource(aws.ec2.RouteTableAssociation, {
133
+ name: "private-subnet-3-route-table-association",
134
+ config: {
135
+ subnetId: privateSubnet3.output.id,
136
+ routeTableId: privateSubnetRouteTable.output.id
137
+ }
138
+ });
139
+ const subnets = {
140
+ public: [publicSubnet],
141
+ private: [privateSubnet1, privateSubnet2, privateSubnet3]
142
+ };
143
+ const routeTables = {
144
+ privateSubnets: privateSubnetRouteTable,
145
+ publicSubnets: publicSubnetRouteTable
146
+ };
147
+ app.addOutputs({
148
+ vpcPublicSubnetIds: subnets.public.map(subNet => subNet.output.id),
149
+ vpcPrivateSubnetIds: subnets.private.map(subNet => subNet.output.id),
150
+ vpcSecurityGroupIds: [vpc.output.defaultSecurityGroupId]
151
+ });
152
+ return {
153
+ vpc,
154
+ subnets,
155
+ routeTables
156
+ };
157
+ }
158
+ });
159
+
160
+ //# sourceMappingURL=CoreVpc.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["aws","createAppModule","CoreVpc","name","config","app","vpc","addResource","ec2","Vpc","cidrBlock","publicSubnet","Subnet","vpcId","output","id","tags","Name","availabilityZones","addHandler","getAvailabilityZones","state","privateSubnet1","availabilityZone","apply","zone","names","privateSubnet2","privateSubnet3","internetGateway","InternetGateway","elasticIpAllocation","Eip","domain","natGateway","NatGateway","allocationId","subnetId","publicSubnetRouteTable","RouteTable","routes","gatewayId","privateSubnetRouteTable","natGatewayId","RouteTableAssociation","routeTableId","subnets","public","private","routeTables","privateSubnets","publicSubnets","addOutputs","vpcPublicSubnetIds","map","subNet","vpcPrivateSubnetIds","vpcSecurityGroupIds","defaultSecurityGroupId"],"sources":["CoreVpc.ts"],"sourcesContent":["import * as aws from \"@pulumi/aws\";\nimport { createAppModule, type PulumiAppModule } from \"@webiny/pulumi\";\n\nexport type CoreVpc = PulumiAppModule<typeof CoreVpc>;\n\nexport const CoreVpc = createAppModule({\n name: \"CoreVpc\",\n config(app) {\n // Create VPC.\n const vpc = app.addResource(aws.ec2.Vpc, {\n name: \"webiny\",\n config: {\n cidrBlock: \"10.0.0.0/16\"\n }\n });\n\n // Create one public and three private subnets.\n // The third subnet will use the third AZ if available, otherwise reuses the first AZ.\n const publicSubnet = app.addResource(aws.ec2.Subnet, {\n name: \"public\",\n config: {\n vpcId: vpc.output.id,\n cidrBlock: \"10.0.0.0/24\",\n tags: { Name: \"public-subnet\" }\n }\n });\n\n const availabilityZones = app.addHandler(() => {\n return aws.getAvailabilityZones({\n state: \"available\"\n });\n });\n\n const privateSubnet1 = app.addResource(aws.ec2.Subnet, {\n name: \"private-subnet-1\",\n config: {\n vpcId: vpc.output.id,\n cidrBlock: \"10.0.1.0/24\",\n availabilityZone: availabilityZones.apply(zone => zone.names[0]),\n tags: { Name: \"private-subnet-1\" }\n }\n });\n\n const privateSubnet2 = app.addResource(aws.ec2.Subnet, {\n name: \"private-subnet-2\",\n config: {\n vpcId: vpc.output.id,\n cidrBlock: \"10.0.2.0/24\",\n availabilityZone: availabilityZones.apply(zone => zone.names[1] || zone.names[0]),\n tags: { Name: \"private-subnet-2\" }\n }\n });\n\n const privateSubnet3 = app.addResource(aws.ec2.Subnet, {\n name: \"private-subnet-3\",\n config: {\n vpcId: vpc.output.id,\n cidrBlock: \"10.0.3.0/24\",\n availabilityZone: availabilityZones.apply(zone => zone.names[2] || zone.names[0]),\n tags: { Name: \"private-subnet-3\" }\n }\n });\n\n // Create Internet gateway.\n const internetGateway = app.addResource(aws.ec2.InternetGateway, {\n name: \"internet-gateway\",\n config: {\n vpcId: vpc.output.id\n }\n });\n\n // Create NAT gateway.z\n const elasticIpAllocation = app.addResource(aws.ec2.Eip, {\n name: \"nat-gateway-elastic-ip\",\n config: {\n domain: \"vpc\"\n }\n });\n\n const natGateway = app.addResource(aws.ec2.NatGateway, {\n name: \"nat-gateway\",\n config: {\n allocationId: elasticIpAllocation.output.id,\n subnetId: publicSubnet.output.id\n }\n });\n\n // Create a route table for both subnets.\n const publicSubnetRouteTable = app.addResource(aws.ec2.RouteTable, {\n name: \"public\",\n config: {\n vpcId: vpc.output.id,\n routes: [\n {\n cidrBlock: \"0.0.0.0/0\",\n gatewayId: internetGateway.output.id\n }\n ]\n }\n });\n\n const privateSubnetRouteTable = app.addResource(aws.ec2.RouteTable, {\n name: \"private\",\n config: {\n vpcId: vpc.output.id,\n routes: [\n {\n cidrBlock: \"0.0.0.0/0\",\n natGatewayId: natGateway.output.id\n }\n ]\n }\n });\n\n // Create route table associations - links between subnets and route tables.\n app.addResource(aws.ec2.RouteTableAssociation, {\n name: \"public-subnet-route-table-association\",\n config: {\n subnetId: publicSubnet.output.id,\n routeTableId: publicSubnetRouteTable.output.id\n }\n });\n\n app.addResource(aws.ec2.RouteTableAssociation, {\n name: \"private-subnet-1-route-table-association\",\n config: {\n subnetId: privateSubnet1.output.id,\n routeTableId: privateSubnetRouteTable.output.id\n }\n });\n\n app.addResource(aws.ec2.RouteTableAssociation, {\n name: \"private-subnet-2-route-table-association\",\n config: {\n subnetId: privateSubnet2.output.id,\n routeTableId: privateSubnetRouteTable.output.id\n }\n });\n\n app.addResource(aws.ec2.RouteTableAssociation, {\n name: \"private-subnet-3-route-table-association\",\n config: {\n subnetId: privateSubnet3.output.id,\n routeTableId: privateSubnetRouteTable.output.id\n }\n });\n\n const subnets = {\n public: [publicSubnet],\n private: [privateSubnet1, privateSubnet2, privateSubnet3]\n };\n\n const routeTables = {\n privateSubnets: privateSubnetRouteTable,\n publicSubnets: publicSubnetRouteTable\n };\n\n app.addOutputs({\n vpcPublicSubnetIds: subnets.public.map(subNet => subNet.output.id),\n vpcPrivateSubnetIds: subnets.private.map(subNet => subNet.output.id),\n vpcSecurityGroupIds: [vpc.output.defaultSecurityGroupId]\n });\n\n return {\n vpc,\n subnets,\n routeTables\n };\n }\n});\n"],"mappings":"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","ignoreList":[]}
@@ -0,0 +1,5 @@
1
+ import { type PulumiAppModule } from "@webiny/pulumi";
2
+ export type LogDynamo = PulumiAppModule<typeof LogDynamo>;
3
+ export declare const LogDynamo: import("@webiny/pulumi").PulumiAppModuleDefinition<import("@webiny/pulumi").PulumiAppResource<typeof import("@pulumi/aws/dynamodb/table").Table>, {
4
+ protect: boolean;
5
+ }>;
@@ -0,0 +1,94 @@
1
+ import * as aws from "@pulumi/aws";
2
+ import { createAppModule } from "@webiny/pulumi";
3
+ export const LogDynamo = createAppModule({
4
+ name: "DynamoDbLog",
5
+ config(app, params) {
6
+ return app.addResource(aws.dynamodb.Table, {
7
+ name: "webiny-log",
8
+ config: {
9
+ attributes: [{
10
+ name: "PK",
11
+ type: "S"
12
+ }, {
13
+ name: "SK",
14
+ type: "S"
15
+ }, {
16
+ name: "GSI_TENANT",
17
+ type: "S"
18
+ }, {
19
+ name: "GSI1_PK",
20
+ type: "S"
21
+ }, {
22
+ name: "GSI1_SK",
23
+ type: "S"
24
+ }, {
25
+ name: "GSI2_PK",
26
+ type: "S"
27
+ }, {
28
+ name: "GSI2_SK",
29
+ type: "S"
30
+ }, {
31
+ name: "GSI3_PK",
32
+ type: "S"
33
+ }, {
34
+ name: "GSI3_SK",
35
+ type: "S"
36
+ }, {
37
+ name: "GSI4_PK",
38
+ type: "S"
39
+ }, {
40
+ name: "GSI4_SK",
41
+ type: "S"
42
+ }, {
43
+ name: "GSI5_PK",
44
+ type: "S"
45
+ }, {
46
+ name: "GSI5_SK",
47
+ type: "S"
48
+ }],
49
+ billingMode: "PAY_PER_REQUEST",
50
+ hashKey: "PK",
51
+ rangeKey: "SK",
52
+ globalSecondaryIndexes: [{
53
+ name: "GSI_TENANT",
54
+ hashKey: "GSI_TENANT",
55
+ projectionType: "KEYS_ONLY"
56
+ }, {
57
+ name: "GSI1",
58
+ hashKey: "GSI1_PK",
59
+ rangeKey: "GSI1_SK",
60
+ projectionType: "ALL"
61
+ }, {
62
+ name: "GSI2",
63
+ hashKey: "GSI2_PK",
64
+ rangeKey: "GSI2_SK",
65
+ projectionType: "ALL"
66
+ }, {
67
+ name: "GSI3",
68
+ hashKey: "GSI3_PK",
69
+ rangeKey: "GSI3_SK",
70
+ projectionType: "ALL"
71
+ }, {
72
+ name: "GSI4",
73
+ hashKey: "GSI4_PK",
74
+ rangeKey: "GSI4_SK",
75
+ projectionType: "ALL"
76
+ }, {
77
+ name: "GSI5",
78
+ hashKey: "GSI5_PK",
79
+ rangeKey: "GSI5_SK",
80
+ projectionType: "ALL"
81
+ }],
82
+ ttl: {
83
+ attributeName: "expiresAt",
84
+ enabled: true
85
+ }
86
+ },
87
+ opts: {
88
+ protect: params.protect
89
+ }
90
+ });
91
+ }
92
+ });
93
+
94
+ //# sourceMappingURL=LogDynamo.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["aws","createAppModule","LogDynamo","name","config","app","params","addResource","dynamodb","Table","attributes","type","billingMode","hashKey","rangeKey","globalSecondaryIndexes","projectionType","ttl","attributeName","enabled","opts","protect"],"sources":["LogDynamo.ts"],"sourcesContent":["import * as aws from \"@pulumi/aws\";\nimport { createAppModule, type PulumiApp, type PulumiAppModule } from \"@webiny/pulumi\";\n\nexport type LogDynamo = PulumiAppModule<typeof LogDynamo>;\n\nexport const LogDynamo = createAppModule({\n name: \"DynamoDbLog\",\n config(app: PulumiApp, params: { protect: boolean }) {\n return app.addResource(aws.dynamodb.Table, {\n name: \"webiny-log\",\n config: {\n attributes: [\n { name: \"PK\", type: \"S\" },\n { name: \"SK\", type: \"S\" },\n { name: \"GSI_TENANT\", type: \"S\" },\n { name: \"GSI1_PK\", type: \"S\" },\n { name: \"GSI1_SK\", type: \"S\" },\n { name: \"GSI2_PK\", type: \"S\" },\n { name: \"GSI2_SK\", type: \"S\" },\n { name: \"GSI3_PK\", type: \"S\" },\n { name: \"GSI3_SK\", type: \"S\" },\n { name: \"GSI4_PK\", type: \"S\" },\n { name: \"GSI4_SK\", type: \"S\" },\n { name: \"GSI5_PK\", type: \"S\" },\n { name: \"GSI5_SK\", type: \"S\" }\n ],\n billingMode: \"PAY_PER_REQUEST\",\n hashKey: \"PK\",\n rangeKey: \"SK\",\n globalSecondaryIndexes: [\n {\n name: \"GSI_TENANT\",\n hashKey: \"GSI_TENANT\",\n projectionType: \"KEYS_ONLY\"\n },\n {\n name: \"GSI1\",\n hashKey: \"GSI1_PK\",\n rangeKey: \"GSI1_SK\",\n projectionType: \"ALL\"\n },\n {\n name: \"GSI2\",\n hashKey: \"GSI2_PK\",\n rangeKey: \"GSI2_SK\",\n projectionType: \"ALL\"\n },\n {\n name: \"GSI3\",\n hashKey: \"GSI3_PK\",\n rangeKey: \"GSI3_SK\",\n projectionType: \"ALL\"\n },\n {\n name: \"GSI4\",\n hashKey: \"GSI4_PK\",\n rangeKey: \"GSI4_SK\",\n projectionType: \"ALL\"\n },\n {\n name: \"GSI5\",\n hashKey: \"GSI5_PK\",\n rangeKey: \"GSI5_SK\",\n projectionType: \"ALL\"\n }\n ],\n ttl: {\n attributeName: \"expiresAt\",\n enabled: true\n }\n },\n opts: {\n protect: params.protect\n }\n });\n }\n});\n"],"mappings":"AAAA,OAAO,KAAKA,GAAG,MAAM,aAAa;AAClC,SAASC,eAAe,QAA8C,gBAAgB;AAItF,OAAO,MAAMC,SAAS,GAAGD,eAAe,CAAC;EACrCE,IAAI,EAAE,aAAa;EACnBC,MAAMA,CAACC,GAAc,EAAEC,MAA4B,EAAE;IACjD,OAAOD,GAAG,CAACE,WAAW,CAACP,GAAG,CAACQ,QAAQ,CAACC,KAAK,EAAE;MACvCN,IAAI,EAAE,YAAY;MAClBC,MAAM,EAAE;QACJM,UAAU,EAAE,CACR;UAAEP,IAAI,EAAE,IAAI;UAAEQ,IAAI,EAAE;QAAI,CAAC,EACzB;UAAER,IAAI,EAAE,IAAI;UAAEQ,IAAI,EAAE;QAAI,CAAC,EACzB;UAAER,IAAI,EAAE,YAAY;UAAEQ,IAAI,EAAE;QAAI,CAAC,EACjC;UAAER,IAAI,EAAE,SAAS;UAAEQ,IAAI,EAAE;QAAI,CAAC,EAC9B;UAAER,IAAI,EAAE,SAAS;UAAEQ,IAAI,EAAE;QAAI,CAAC,EAC9B;UAAER,IAAI,EAAE,SAAS;UAAEQ,IAAI,EAAE;QAAI,CAAC,EAC9B;UAAER,IAAI,EAAE,SAAS;UAAEQ,IAAI,EAAE;QAAI,CAAC,EAC9B;UAAER,IAAI,EAAE,SAAS;UAAEQ,IAAI,EAAE;QAAI,CAAC,EAC9B;UAAER,IAAI,EAAE,SAAS;UAAEQ,IAAI,EAAE;QAAI,CAAC,EAC9B;UAAER,IAAI,EAAE,SAAS;UAAEQ,IAAI,EAAE;QAAI,CAAC,EAC9B;UAAER,IAAI,EAAE,SAAS;UAAEQ,IAAI,EAAE;QAAI,CAAC,EAC9B;UAAER,IAAI,EAAE,SAAS;UAAEQ,IAAI,EAAE;QAAI,CAAC,EAC9B;UAAER,IAAI,EAAE,SAAS;UAAEQ,IAAI,EAAE;QAAI,CAAC,CACjC;QACDC,WAAW,EAAE,iBAAiB;QAC9BC,OAAO,EAAE,IAAI;QACbC,QAAQ,EAAE,IAAI;QACdC,sBAAsB,EAAE,CACpB;UACIZ,IAAI,EAAE,YAAY;UAClBU,OAAO,EAAE,YAAY;UACrBG,cAAc,EAAE;QACpB,CAAC,EACD;UACIb,IAAI,EAAE,MAAM;UACZU,OAAO,EAAE,SAAS;UAClBC,QAAQ,EAAE,SAAS;UACnBE,cAAc,EAAE;QACpB,CAAC,EACD;UACIb,IAAI,EAAE,MAAM;UACZU,OAAO,EAAE,SAAS;UAClBC,QAAQ,EAAE,SAAS;UACnBE,cAAc,EAAE;QACpB,CAAC,EACD;UACIb,IAAI,EAAE,MAAM;UACZU,OAAO,EAAE,SAAS;UAClBC,QAAQ,EAAE,SAAS;UACnBE,cAAc,EAAE;QACpB,CAAC,EACD;UACIb,IAAI,EAAE,MAAM;UACZU,OAAO,EAAE,SAAS;UAClBC,QAAQ,EAAE,SAAS;UACnBE,cAAc,EAAE;QACpB,CAAC,EACD;UACIb,IAAI,EAAE,MAAM;UACZU,OAAO,EAAE,SAAS;UAClBC,QAAQ,EAAE,SAAS;UACnBE,cAAc,EAAE;QACpB,CAAC,CACJ;QACDC,GAAG,EAAE;UACDC,aAAa,EAAE,WAAW;UAC1BC,OAAO,EAAE;QACb;MACJ,CAAC;MACDC,IAAI,EAAE;QACFC,OAAO,EAAEf,MAAM,CAACe;MACpB;IACJ,CAAC,CAAC;EACN;AACJ,CAAC,CAAC","ignoreList":[]}
@@ -0,0 +1,7 @@
1
+ import * as pulumi from "@pulumi/pulumi";
2
+ export interface WatchCommandParams {
3
+ deploymentId: pulumi.Output<string>;
4
+ }
5
+ export declare const WatchCommand: import("@webiny/pulumi").PulumiAppModuleDefinition<{
6
+ iotAuthorizerFunction: import("@webiny/pulumi").PulumiAppResource<typeof import("@pulumi/aws/lambda/function").Function>;
7
+ }, WatchCommandParams>;
@@ -0,0 +1,105 @@
1
+ import * as aws from "@pulumi/aws";
2
+ import { createAppModule } from "@webiny/pulumi";
3
+ import { LAMBDA_RUNTIME } from "../../constants.js";
4
+ import * as pulumi from "@pulumi/pulumi";
5
+ import path from "path";
6
+ import { CoreVpc } from "../index.js";
7
+ export const WatchCommand = createAppModule({
8
+ name: "WatchCommand",
9
+ config(app, params) {
10
+ const roleName = "iot-authorizer-lambda-role";
11
+ const role = app.addResource(aws.iam.Role, {
12
+ name: roleName,
13
+ config: {
14
+ assumeRolePolicy: {
15
+ Version: "2012-10-17",
16
+ Statement: [{
17
+ Action: "sts:AssumeRole",
18
+ Principal: {
19
+ Service: "lambda.amazonaws.com"
20
+ },
21
+ Effect: "Allow"
22
+ }]
23
+ }
24
+ },
25
+ meta: {
26
+ isLambdaFunctionRole: true
27
+ }
28
+ });
29
+ const vpc = app.getModule(CoreVpc, {
30
+ optional: true
31
+ });
32
+
33
+ // Only use `AWSLambdaVPCAccessExecutionRole` policy if VPC feature is enabled.
34
+ if (vpc) {
35
+ app.addResource(aws.iam.RolePolicyAttachment, {
36
+ name: `${roleName}-AWSLambdaVPCAccessExecutionRole`,
37
+ config: {
38
+ role: role.output,
39
+ policyArn: aws.iam.ManagedPolicy.AWSLambdaVPCAccessExecutionRole
40
+ }
41
+ });
42
+ } else {
43
+ app.addResource(aws.iam.RolePolicyAttachment, {
44
+ name: `${roleName}-AWSLambdaBasicExecutionRole`,
45
+ config: {
46
+ role: role.output,
47
+ policyArn: aws.iam.ManagedPolicy.AWSLambdaBasicExecutionRole
48
+ }
49
+ });
50
+ }
51
+ const iotAuthorizerFunction = app.addResource(aws.lambda.Function, {
52
+ name: "watch-command-iot-authorizer",
53
+ config: {
54
+ role: role.output.arn,
55
+ runtime: LAMBDA_RUNTIME,
56
+ handler: "handler.handler",
57
+ timeout: 10,
58
+ memorySize: 128,
59
+ description: "Authorizes 'webiny watch' command communication.",
60
+ code: new pulumi.asset.AssetArchive({
61
+ ".": new pulumi.asset.FileArchive(path.join(import.meta.dirname, "webinyWatchCommand"))
62
+ }),
63
+ environment: {
64
+ variables: {
65
+ WEBINY_WATCH_COMMAND_TOPIC: params.deploymentId.apply(deploymentId => {
66
+ return `webiny-watch-${deploymentId}`;
67
+ })
68
+ }
69
+ },
70
+ vpcConfig: vpc ? {
71
+ subnetIds: vpc.subnets.private.map(s => s.output.id),
72
+ securityGroupIds: [vpc.vpc.output.defaultSecurityGroupId]
73
+ } : undefined,
74
+ loggingConfig: {
75
+ logFormat: "JSON"
76
+ }
77
+ }
78
+ });
79
+ const iotAuthorizer = app.addResource(aws.iot.Authorizer, {
80
+ name: "watch-command-iot-authorizer",
81
+ config: {
82
+ signingDisabled: true,
83
+ authorizerFunctionArn: iotAuthorizerFunction.output.arn,
84
+ status: "ACTIVE"
85
+ }
86
+ });
87
+ app.addResource(aws.lambda.Permission, {
88
+ name: "webiny-watch-iot-authorizer",
89
+ config: {
90
+ principal: "iot.amazonaws.com",
91
+ function: iotAuthorizerFunction.output.arn,
92
+ sourceArn: iotAuthorizer.output.arn,
93
+ action: "lambda:InvokeFunction"
94
+ }
95
+ });
96
+ app.addOutputs({
97
+ iotAuthorizerName: iotAuthorizer.output.name
98
+ });
99
+ return {
100
+ iotAuthorizerFunction
101
+ };
102
+ }
103
+ });
104
+
105
+ //# sourceMappingURL=WatchCommand.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["aws","createAppModule","LAMBDA_RUNTIME","pulumi","path","CoreVpc","WatchCommand","name","config","app","params","roleName","role","addResource","iam","Role","assumeRolePolicy","Version","Statement","Action","Principal","Service","Effect","meta","isLambdaFunctionRole","vpc","getModule","optional","RolePolicyAttachment","output","policyArn","ManagedPolicy","AWSLambdaVPCAccessExecutionRole","AWSLambdaBasicExecutionRole","iotAuthorizerFunction","lambda","Function","arn","runtime","handler","timeout","memorySize","description","code","asset","AssetArchive","FileArchive","join","import","dirname","environment","variables","WEBINY_WATCH_COMMAND_TOPIC","deploymentId","apply","vpcConfig","subnetIds","subnets","private","map","s","id","securityGroupIds","defaultSecurityGroupId","undefined","loggingConfig","logFormat","iotAuthorizer","iot","Authorizer","signingDisabled","authorizerFunctionArn","status","Permission","principal","function","sourceArn","action","addOutputs","iotAuthorizerName"],"sources":["WatchCommand.ts"],"sourcesContent":["import * as aws from \"@pulumi/aws\";\nimport { createAppModule, type PulumiApp } from \"@webiny/pulumi\";\nimport { LAMBDA_RUNTIME } from \"~/pulumi/constants.js\";\nimport * as pulumi from \"@pulumi/pulumi\";\nimport path from \"path\";\nimport { CoreVpc } from \"~/pulumi/apps/index.js\";\n\nexport interface WatchCommandParams {\n deploymentId: pulumi.Output<string>;\n}\n\nexport const WatchCommand = createAppModule({\n name: \"WatchCommand\",\n config(app: PulumiApp, params: WatchCommandParams) {\n const roleName = \"iot-authorizer-lambda-role\";\n\n const role = app.addResource(aws.iam.Role, {\n name: roleName,\n config: {\n assumeRolePolicy: {\n Version: \"2012-10-17\",\n Statement: [\n {\n Action: \"sts:AssumeRole\",\n Principal: {\n Service: \"lambda.amazonaws.com\"\n },\n Effect: \"Allow\"\n }\n ]\n }\n },\n meta: { isLambdaFunctionRole: true }\n });\n\n const vpc = app.getModule(CoreVpc, { optional: true });\n\n // Only use `AWSLambdaVPCAccessExecutionRole` policy if VPC feature is enabled.\n if (vpc) {\n app.addResource(aws.iam.RolePolicyAttachment, {\n name: `${roleName}-AWSLambdaVPCAccessExecutionRole`,\n config: {\n role: role.output,\n policyArn: aws.iam.ManagedPolicy.AWSLambdaVPCAccessExecutionRole\n }\n });\n } else {\n app.addResource(aws.iam.RolePolicyAttachment, {\n name: `${roleName}-AWSLambdaBasicExecutionRole`,\n config: {\n role: role.output,\n policyArn: aws.iam.ManagedPolicy.AWSLambdaBasicExecutionRole\n }\n });\n }\n\n const iotAuthorizerFunction = app.addResource(aws.lambda.Function, {\n name: \"watch-command-iot-authorizer\",\n config: {\n role: role.output.arn,\n runtime: LAMBDA_RUNTIME,\n handler: \"handler.handler\",\n timeout: 10,\n memorySize: 128,\n description: \"Authorizes 'webiny watch' command communication.\",\n code: new pulumi.asset.AssetArchive({\n \".\": new pulumi.asset.FileArchive(\n path.join(import.meta.dirname, \"webinyWatchCommand\")\n )\n }),\n environment: {\n variables: {\n WEBINY_WATCH_COMMAND_TOPIC: params.deploymentId.apply(deploymentId => {\n return `webiny-watch-${deploymentId}`;\n })\n }\n },\n vpcConfig: vpc\n ? {\n subnetIds: vpc.subnets.private.map(s => s.output.id),\n securityGroupIds: [vpc.vpc.output.defaultSecurityGroupId]\n }\n : undefined,\n loggingConfig: {\n logFormat: \"JSON\"\n }\n }\n });\n\n const iotAuthorizer = app.addResource(aws.iot.Authorizer, {\n name: \"watch-command-iot-authorizer\",\n config: {\n signingDisabled: true,\n authorizerFunctionArn: iotAuthorizerFunction.output.arn,\n status: \"ACTIVE\"\n }\n });\n\n app.addResource(aws.lambda.Permission, {\n name: \"webiny-watch-iot-authorizer\",\n config: {\n principal: \"iot.amazonaws.com\",\n function: iotAuthorizerFunction.output.arn,\n sourceArn: iotAuthorizer.output.arn,\n action: \"lambda:InvokeFunction\"\n }\n });\n\n app.addOutputs({\n iotAuthorizerName: iotAuthorizer.output.name\n });\n\n return { iotAuthorizerFunction };\n }\n});\n"],"mappings":"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","ignoreList":[]}
@@ -0,0 +1,9 @@
1
+ import type * as pulumi from "@pulumi/pulumi";
2
+ import { type IdentityProviderArgs } from "@pulumi/aws/cognito/index.js";
3
+ import { type CognitoIdentityProviderConfig } from "./configure.js";
4
+ /**
5
+ * Amazon doesn't provide first/last name as separate attributes. Instead, it gives you a `name`.
6
+ * To handle this, developers will need to set up a pre-authentication Lambda trigger on the user pool,
7
+ * to generate proper first/last name using custom code.
8
+ */
9
+ export declare const getAmazonIdpConfig: (userPoolId: pulumi.Input<string>, config: CognitoIdentityProviderConfig) => IdentityProviderArgs;
@@ -0,0 +1,24 @@
1
+ /**
2
+ * Amazon doesn't provide first/last name as separate attributes. Instead, it gives you a `name`.
3
+ * To handle this, developers will need to set up a pre-authentication Lambda trigger on the user pool,
4
+ * to generate proper first/last name using custom code.
5
+ */
6
+ export const getAmazonIdpConfig = (userPoolId, config) => {
7
+ return {
8
+ userPoolId,
9
+ providerName: "Amazon",
10
+ providerType: "LoginWithAmazon",
11
+ providerDetails: config.providerDetails,
12
+ idpIdentifiers: config.idpIdentifiers,
13
+ attributeMapping: {
14
+ "custom:id": "user_id",
15
+ username: "user_id",
16
+ email: "email",
17
+ given_name: "name",
18
+ family_name: "name",
19
+ ...config.attributeMapping
20
+ }
21
+ };
22
+ };
23
+
24
+ //# sourceMappingURL=amazon.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["getAmazonIdpConfig","userPoolId","config","providerName","providerType","providerDetails","idpIdentifiers","attributeMapping","username","email","given_name","family_name"],"sources":["amazon.ts"],"sourcesContent":["import type * as pulumi from \"@pulumi/pulumi\";\nimport { type IdentityProviderArgs } from \"@pulumi/aws/cognito/index.js\";\nimport { type CognitoIdentityProviderConfig } from \"./configure.js\";\n\n/**\n * Amazon doesn't provide first/last name as separate attributes. Instead, it gives you a `name`.\n * To handle this, developers will need to set up a pre-authentication Lambda trigger on the user pool,\n * to generate proper first/last name using custom code.\n */\nexport const getAmazonIdpConfig = (\n userPoolId: pulumi.Input<string>,\n config: CognitoIdentityProviderConfig\n): IdentityProviderArgs => {\n return {\n userPoolId,\n providerName: \"Amazon\",\n providerType: \"LoginWithAmazon\",\n providerDetails: config.providerDetails,\n idpIdentifiers: config.idpIdentifiers,\n attributeMapping: {\n \"custom:id\": \"user_id\",\n username: \"user_id\",\n email: \"email\",\n given_name: \"name\",\n family_name: \"name\",\n ...config.attributeMapping\n }\n };\n};\n"],"mappings":"AAIA;AACA;AACA;AACA;AACA;AACA,OAAO,MAAMA,kBAAkB,GAAGA,CAC9BC,UAAgC,EAChCC,MAAqC,KACd;EACvB,OAAO;IACHD,UAAU;IACVE,YAAY,EAAE,QAAQ;IACtBC,YAAY,EAAE,iBAAiB;IAC/BC,eAAe,EAAEH,MAAM,CAACG,eAAe;IACvCC,cAAc,EAAEJ,MAAM,CAACI,cAAc;IACrCC,gBAAgB,EAAE;MACd,WAAW,EAAE,SAAS;MACtBC,QAAQ,EAAE,SAAS;MACnBC,KAAK,EAAE,OAAO;MACdC,UAAU,EAAE,MAAM;MAClBC,WAAW,EAAE,MAAM;MACnB,GAAGT,MAAM,CAACK;IACd;EACJ,CAAC;AACL,CAAC","ignoreList":[]}
@@ -0,0 +1,4 @@
1
+ import type * as pulumi from "@pulumi/pulumi";
2
+ import { type IdentityProviderArgs } from "@pulumi/aws/cognito/index.js";
3
+ import { type CognitoIdentityProviderConfig } from "./configure.js";
4
+ export declare const getAppleIdpConfig: (userPoolId: pulumi.Input<string>, config: CognitoIdentityProviderConfig) => IdentityProviderArgs;
@@ -0,0 +1,19 @@
1
+ export const getAppleIdpConfig = (userPoolId, config) => {
2
+ return {
3
+ userPoolId,
4
+ providerName: "Apple",
5
+ providerType: "SignInWithApple",
6
+ providerDetails: config.providerDetails,
7
+ idpIdentifiers: config.idpIdentifiers,
8
+ attributeMapping: {
9
+ "custom:id": "sub",
10
+ username: "sub",
11
+ email: "email",
12
+ given_name: "firstName",
13
+ family_name: "lastName",
14
+ ...config.attributeMapping
15
+ }
16
+ };
17
+ };
18
+
19
+ //# sourceMappingURL=apple.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["getAppleIdpConfig","userPoolId","config","providerName","providerType","providerDetails","idpIdentifiers","attributeMapping","username","email","given_name","family_name"],"sources":["apple.ts"],"sourcesContent":["import type * as pulumi from \"@pulumi/pulumi\";\nimport { type IdentityProviderArgs } from \"@pulumi/aws/cognito/index.js\";\nimport { type CognitoIdentityProviderConfig } from \"./configure.js\";\n\nexport const getAppleIdpConfig = (\n userPoolId: pulumi.Input<string>,\n config: CognitoIdentityProviderConfig\n): IdentityProviderArgs => {\n return {\n userPoolId,\n providerName: \"Apple\",\n providerType: \"SignInWithApple\",\n providerDetails: config.providerDetails,\n idpIdentifiers: config.idpIdentifiers,\n attributeMapping: {\n \"custom:id\": \"sub\",\n username: \"sub\",\n email: \"email\",\n given_name: \"firstName\",\n family_name: \"lastName\",\n ...config.attributeMapping\n }\n };\n};\n"],"mappings":"AAIA,OAAO,MAAMA,iBAAiB,GAAGA,CAC7BC,UAAgC,EAChCC,MAAqC,KACd;EACvB,OAAO;IACHD,UAAU;IACVE,YAAY,EAAE,OAAO;IACrBC,YAAY,EAAE,iBAAiB;IAC/BC,eAAe,EAAEH,MAAM,CAACG,eAAe;IACvCC,cAAc,EAAEJ,MAAM,CAACI,cAAc;IACrCC,gBAAgB,EAAE;MACd,WAAW,EAAE,KAAK;MAClBC,QAAQ,EAAE,KAAK;MACfC,KAAK,EAAE,OAAO;MACdC,UAAU,EAAE,WAAW;MACvBC,WAAW,EAAE,UAAU;MACvB,GAAGT,MAAM,CAACK;IACd;EACJ,CAAC;AACL,CAAC","ignoreList":[]}
@@ -0,0 +1,28 @@
1
+ import { type UserPoolDomainArgs } from "@pulumi/aws/cognito/userPoolDomain.js";
2
+ import { type IdentityProviderArgs } from "@pulumi/aws/cognito/index.js";
3
+ import { type PulumiApp } from "@webiny/pulumi";
4
+ export type IdentityAttributeMapping = {
5
+ "custom:id": string;
6
+ username: string;
7
+ email: string;
8
+ family_name: string;
9
+ given_name: string;
10
+ [key: string]: string;
11
+ };
12
+ export interface CognitoIdentityProvidersConfig {
13
+ domain: string | {
14
+ name: UserPoolDomainArgs["domain"];
15
+ certificateArn?: UserPoolDomainArgs["certificateArn"];
16
+ };
17
+ identityProviders: CognitoIdentityProviderConfig[];
18
+ callbackUrls: string[];
19
+ logoutUrls?: string[];
20
+ }
21
+ export interface CognitoIdentityProviderConfig {
22
+ name?: string;
23
+ type: "google" | "facebook" | "amazon" | "apple" | "oidc";
24
+ providerDetails: IdentityProviderArgs["providerDetails"];
25
+ idpIdentifiers?: IdentityProviderArgs["idpIdentifiers"];
26
+ attributeMapping?: IdentityAttributeMapping;
27
+ }
28
+ export declare const configureAdminCognitoFederation: (app: PulumiApp, config: CognitoIdentityProvidersConfig) => void;