@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,57 @@
1
+ import * as aws from "@pulumi/aws";
2
+ import * as pulumi from "@pulumi/pulumi";
3
+ import { getIdpConfig } from "./getIdpConfig.js";
4
+ import { getEnvVariableAwsRegion } from "../../../env/awsRegion.js";
5
+ const isString = value => {
6
+ return typeof value === "string";
7
+ };
8
+ export const configureAdminCognitoFederation = (app, config) => {
9
+ const region = getEnvVariableAwsRegion();
10
+ const userPool = app.resources.userPool;
11
+ const appClient = app.resources.userPoolClient;
12
+
13
+ /**
14
+ * We need to create a user pool domain, which is used to interact with the federated identity providers.
15
+ */
16
+ const userPoolDomain = app.addResource(aws.cognito.UserPoolDomain, {
17
+ name: "cognitoUserPoolDomain",
18
+ config: {
19
+ domain: isString(config.domain) ? config.domain : config.domain.name,
20
+ certificateArn: isString(config.domain) ? undefined : config.domain.certificateArn,
21
+ userPoolId: userPool.output.id
22
+ }
23
+ });
24
+ app.addOutput("cognitoUserPoolDomain", pulumi.interpolate`${userPoolDomain.output.domain}.auth.${region}.amazoncognito.com`);
25
+ const idpConfigs = [];
26
+ for (const idp of config.identityProviders) {
27
+ const config = getIdpConfig(idp.type, userPool.output.id, idp);
28
+
29
+ // The idea to lowercase the provider name emerged while working on backwards compatibility issue.
30
+ // Basically, in cases where a user used the OIDC provider and did not specify a name, instead of
31
+ // using `OIDC` as the name, we wanted to ensure `oidc` is used. But, what I soon realized is that
32
+ // by simply lowercasing the name, we can avoid the need to check for the provider type and name.
33
+ // And although this will now happen for all providers, it's not a problem since Pulumi requires
34
+ // names to be all lowercase anyway.
35
+ const name = config.providerName.toString().toLowerCase();
36
+ app.addResource(aws.cognito.IdentityProvider, {
37
+ name,
38
+ config
39
+ });
40
+ idpConfigs.push(config);
41
+ }
42
+ appClient.config.supportedIdentityProviders(["COGNITO", ...idpConfigs.map(config => {
43
+ // For built-in identity providers, we use the type as the name. Only for OIDC,
44
+ // we allow the user to provide a custom name, and we only use the type as a fallback.
45
+ if (config.providerType === "OIDC") {
46
+ return config.providerName;
47
+ }
48
+ return config.providerType;
49
+ })]);
50
+ appClient.config.allowedOauthScopes(["profile", "email", "openid"]);
51
+ appClient.config.allowedOauthFlows(["implicit", "code"]);
52
+ appClient.config.allowedOauthFlowsUserPoolClient(true);
53
+ appClient.config.callbackUrls(config.callbackUrls);
54
+ appClient.config.logoutUrls(config.logoutUrls ?? config.callbackUrls);
55
+ };
56
+
57
+ //# sourceMappingURL=configure.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["aws","pulumi","getIdpConfig","getEnvVariableAwsRegion","isString","value","configureAdminCognitoFederation","app","config","region","userPool","resources","appClient","userPoolClient","userPoolDomain","addResource","cognito","UserPoolDomain","name","domain","certificateArn","undefined","userPoolId","output","id","addOutput","interpolate","idpConfigs","idp","identityProviders","type","providerName","toString","toLowerCase","IdentityProvider","push","supportedIdentityProviders","map","providerType","allowedOauthScopes","allowedOauthFlows","allowedOauthFlowsUserPoolClient","callbackUrls","logoutUrls"],"sources":["configure.ts"],"sourcesContent":["import * as aws from \"@pulumi/aws\";\nimport { type UserPoolDomainArgs } from \"@pulumi/aws/cognito/userPoolDomain.js\";\nimport { type IdentityProviderArgs } from \"@pulumi/aws/cognito/index.js\";\nimport * as pulumi from \"@pulumi/pulumi\";\nimport {\n type PulumiApp,\n type PulumiAppResource,\n type PulumiAppResourceConstructor\n} from \"@webiny/pulumi\";\nimport { getIdpConfig } from \"./getIdpConfig.js\";\nimport { getEnvVariableAwsRegion } from \"~/pulumi/env/awsRegion.js\";\n\nexport type IdentityAttributeMapping = {\n \"custom:id\": string;\n username: string;\n email: string;\n family_name: string;\n given_name: string;\n [key: string]: string;\n};\n\nexport interface CognitoIdentityProvidersConfig {\n domain:\n | string\n | {\n name: UserPoolDomainArgs[\"domain\"];\n certificateArn?: UserPoolDomainArgs[\"certificateArn\"];\n };\n identityProviders: CognitoIdentityProviderConfig[];\n callbackUrls: string[];\n logoutUrls?: string[];\n}\n\nexport interface CognitoIdentityProviderConfig {\n name?: string;\n type: \"google\" | \"facebook\" | \"amazon\" | \"apple\" | \"oidc\";\n providerDetails: IdentityProviderArgs[\"providerDetails\"];\n idpIdentifiers?: IdentityProviderArgs[\"idpIdentifiers\"];\n attributeMapping?: IdentityAttributeMapping;\n}\n\nconst isString = (value?: any): value is string => {\n return typeof value === \"string\";\n};\n\nexport const configureAdminCognitoFederation = (\n app: PulumiApp,\n config: CognitoIdentityProvidersConfig\n) => {\n const region = getEnvVariableAwsRegion();\n\n const userPool = app.resources.userPool as PulumiAppResource<\n PulumiAppResourceConstructor<aws.cognito.UserPool>\n >;\n\n const appClient = app.resources.userPoolClient as PulumiAppResource<\n PulumiAppResourceConstructor<aws.cognito.UserPoolClient>\n >;\n\n /**\n * We need to create a user pool domain, which is used to interact with the federated identity providers.\n */\n const userPoolDomain = app.addResource(aws.cognito.UserPoolDomain, {\n name: \"cognitoUserPoolDomain\",\n config: {\n domain: isString(config.domain) ? config.domain : config.domain.name,\n certificateArn: isString(config.domain) ? undefined : config.domain.certificateArn,\n userPoolId: userPool.output.id\n }\n });\n\n app.addOutput(\n \"cognitoUserPoolDomain\",\n pulumi.interpolate`${userPoolDomain.output.domain}.auth.${region}.amazoncognito.com`\n );\n\n const idpConfigs: aws.cognito.IdentityProviderArgs[] = [];\n\n for (const idp of config.identityProviders) {\n const config = getIdpConfig(idp.type, userPool.output.id, idp);\n\n // The idea to lowercase the provider name emerged while working on backwards compatibility issue.\n // Basically, in cases where a user used the OIDC provider and did not specify a name, instead of\n // using `OIDC` as the name, we wanted to ensure `oidc` is used. But, what I soon realized is that\n // by simply lowercasing the name, we can avoid the need to check for the provider type and name.\n // And although this will now happen for all providers, it's not a problem since Pulumi requires\n // names to be all lowercase anyway.\n const name = config.providerName.toString().toLowerCase();\n\n app.addResource(aws.cognito.IdentityProvider, { name, config });\n\n idpConfigs.push(config);\n }\n\n appClient.config.supportedIdentityProviders([\n \"COGNITO\",\n ...idpConfigs.map(config => {\n // For built-in identity providers, we use the type as the name. Only for OIDC,\n // we allow the user to provide a custom name, and we only use the type as a fallback.\n if (config.providerType === \"OIDC\") {\n return config.providerName;\n }\n return config.providerType;\n })\n ]);\n\n appClient.config.allowedOauthScopes([\"profile\", \"email\", \"openid\"]);\n appClient.config.allowedOauthFlows([\"implicit\", \"code\"]);\n appClient.config.allowedOauthFlowsUserPoolClient(true);\n appClient.config.callbackUrls(config.callbackUrls);\n appClient.config.logoutUrls(config.logoutUrls ?? config.callbackUrls);\n};\n"],"mappings":"AAAA,OAAO,KAAKA,GAAG,MAAM,aAAa;AAGlC,OAAO,KAAKC,MAAM,MAAM,gBAAgB;AAMxC,SAASC,YAAY;AACrB,SAASC,uBAAuB;AA+BhC,MAAMC,QAAQ,GAAIC,KAAW,IAAsB;EAC/C,OAAO,OAAOA,KAAK,KAAK,QAAQ;AACpC,CAAC;AAED,OAAO,MAAMC,+BAA+B,GAAGA,CAC3CC,GAAc,EACdC,MAAsC,KACrC;EACD,MAAMC,MAAM,GAAGN,uBAAuB,CAAC,CAAC;EAExC,MAAMO,QAAQ,GAAGH,GAAG,CAACI,SAAS,CAACD,QAE9B;EAED,MAAME,SAAS,GAAGL,GAAG,CAACI,SAAS,CAACE,cAE/B;;EAED;AACJ;AACA;EACI,MAAMC,cAAc,GAAGP,GAAG,CAACQ,WAAW,CAACf,GAAG,CAACgB,OAAO,CAACC,cAAc,EAAE;IAC/DC,IAAI,EAAE,uBAAuB;IAC7BV,MAAM,EAAE;MACJW,MAAM,EAAEf,QAAQ,CAACI,MAAM,CAACW,MAAM,CAAC,GAAGX,MAAM,CAACW,MAAM,GAAGX,MAAM,CAACW,MAAM,CAACD,IAAI;MACpEE,cAAc,EAAEhB,QAAQ,CAACI,MAAM,CAACW,MAAM,CAAC,GAAGE,SAAS,GAAGb,MAAM,CAACW,MAAM,CAACC,cAAc;MAClFE,UAAU,EAAEZ,QAAQ,CAACa,MAAM,CAACC;IAChC;EACJ,CAAC,CAAC;EAEFjB,GAAG,CAACkB,SAAS,CACT,uBAAuB,EACvBxB,MAAM,CAACyB,WAAW,GAAGZ,cAAc,CAACS,MAAM,CAACJ,MAAM,SAASV,MAAM,oBACpE,CAAC;EAED,MAAMkB,UAA8C,GAAG,EAAE;EAEzD,KAAK,MAAMC,GAAG,IAAIpB,MAAM,CAACqB,iBAAiB,EAAE;IACxC,MAAMrB,MAAM,GAAGN,YAAY,CAAC0B,GAAG,CAACE,IAAI,EAAEpB,QAAQ,CAACa,MAAM,CAACC,EAAE,EAAEI,GAAG,CAAC;;IAE9D;IACA;IACA;IACA;IACA;IACA;IACA,MAAMV,IAAI,GAAGV,MAAM,CAACuB,YAAY,CAACC,QAAQ,CAAC,CAAC,CAACC,WAAW,CAAC,CAAC;IAEzD1B,GAAG,CAACQ,WAAW,CAACf,GAAG,CAACgB,OAAO,CAACkB,gBAAgB,EAAE;MAAEhB,IAAI;MAAEV;IAAO,CAAC,CAAC;IAE/DmB,UAAU,CAACQ,IAAI,CAAC3B,MAAM,CAAC;EAC3B;EAEAI,SAAS,CAACJ,MAAM,CAAC4B,0BAA0B,CAAC,CACxC,SAAS,EACT,GAAGT,UAAU,CAACU,GAAG,CAAC7B,MAAM,IAAI;IACxB;IACA;IACA,IAAIA,MAAM,CAAC8B,YAAY,KAAK,MAAM,EAAE;MAChC,OAAO9B,MAAM,CAACuB,YAAY;IAC9B;IACA,OAAOvB,MAAM,CAAC8B,YAAY;EAC9B,CAAC,CAAC,CACL,CAAC;EAEF1B,SAAS,CAACJ,MAAM,CAAC+B,kBAAkB,CAAC,CAAC,SAAS,EAAE,OAAO,EAAE,QAAQ,CAAC,CAAC;EACnE3B,SAAS,CAACJ,MAAM,CAACgC,iBAAiB,CAAC,CAAC,UAAU,EAAE,MAAM,CAAC,CAAC;EACxD5B,SAAS,CAACJ,MAAM,CAACiC,+BAA+B,CAAC,IAAI,CAAC;EACtD7B,SAAS,CAACJ,MAAM,CAACkC,YAAY,CAAClC,MAAM,CAACkC,YAAY,CAAC;EAClD9B,SAAS,CAACJ,MAAM,CAACmC,UAAU,CAACnC,MAAM,CAACmC,UAAU,IAAInC,MAAM,CAACkC,YAAY,CAAC;AACzE,CAAC","ignoreList":[]}
@@ -0,0 +1,4 @@
1
+ import type * as pulumi from "@pulumi/pulumi";
2
+ import { type CognitoIdentityProviderConfig } from "./configure.js";
3
+ import { type IdentityProviderArgs } from "@pulumi/aws/cognito/index.js";
4
+ export declare const getFacebookIdpConfig: (userPoolId: pulumi.Input<string>, config: CognitoIdentityProviderConfig) => IdentityProviderArgs;
@@ -0,0 +1,19 @@
1
+ export const getFacebookIdpConfig = (userPoolId, config) => {
2
+ return {
3
+ userPoolId,
4
+ providerName: "Facebook",
5
+ providerType: "Facebook",
6
+ providerDetails: config.providerDetails,
7
+ idpIdentifiers: config.idpIdentifiers,
8
+ attributeMapping: {
9
+ "custom:id": "id",
10
+ username: "id",
11
+ email: "email",
12
+ given_name: "first_name",
13
+ family_name: "last_name",
14
+ ...config.attributeMapping
15
+ }
16
+ };
17
+ };
18
+
19
+ //# sourceMappingURL=facebook.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["getFacebookIdpConfig","userPoolId","config","providerName","providerType","providerDetails","idpIdentifiers","attributeMapping","username","email","given_name","family_name"],"sources":["facebook.ts"],"sourcesContent":["import type * as pulumi from \"@pulumi/pulumi\";\nimport { type CognitoIdentityProviderConfig } from \"./configure.js\";\nimport { type IdentityProviderArgs } from \"@pulumi/aws/cognito/index.js\";\n\nexport const getFacebookIdpConfig = (\n userPoolId: pulumi.Input<string>,\n config: CognitoIdentityProviderConfig\n): IdentityProviderArgs => {\n return {\n userPoolId,\n providerName: \"Facebook\",\n providerType: \"Facebook\",\n providerDetails: config.providerDetails,\n idpIdentifiers: config.idpIdentifiers,\n attributeMapping: {\n \"custom:id\": \"id\",\n username: \"id\",\n email: \"email\",\n given_name: \"first_name\",\n family_name: \"last_name\",\n ...config.attributeMapping\n }\n };\n};\n"],"mappings":"AAIA,OAAO,MAAMA,oBAAoB,GAAGA,CAChCC,UAAgC,EAChCC,MAAqC,KACd;EACvB,OAAO;IACHD,UAAU;IACVE,YAAY,EAAE,UAAU;IACxBC,YAAY,EAAE,UAAU;IACxBC,eAAe,EAAEH,MAAM,CAACG,eAAe;IACvCC,cAAc,EAAEJ,MAAM,CAACI,cAAc;IACrCC,gBAAgB,EAAE;MACd,WAAW,EAAE,IAAI;MACjBC,QAAQ,EAAE,IAAI;MACdC,KAAK,EAAE,OAAO;MACdC,UAAU,EAAE,YAAY;MACxBC,WAAW,EAAE,WAAW;MACxB,GAAGT,MAAM,CAACK;IACd;EACJ,CAAC;AACL,CAAC","ignoreList":[]}
@@ -0,0 +1,3 @@
1
+ import type * as pulumi from "@pulumi/pulumi";
2
+ import { type CognitoIdentityProviderConfig } from "./configure.js";
3
+ export declare const getIdpConfig: (type: CognitoIdentityProviderConfig["type"], userPoolId: pulumi.Input<string>, config: CognitoIdentityProviderConfig) => import("@pulumi/aws/cognito/identityProvider.js").IdentityProviderArgs;
@@ -0,0 +1,17 @@
1
+ import { getGoogleIdpConfig } from "./google.js";
2
+ import { getFacebookIdpConfig } from "./facebook.js";
3
+ import { getAppleIdpConfig } from "./apple.js";
4
+ import { getAmazonIdpConfig } from "./amazon.js";
5
+ import { getOidcIdpConfig } from "./oidc.js";
6
+ const idpMap = {
7
+ google: getGoogleIdpConfig,
8
+ facebook: getFacebookIdpConfig,
9
+ amazon: getAmazonIdpConfig,
10
+ apple: getAppleIdpConfig,
11
+ oidc: getOidcIdpConfig
12
+ };
13
+ export const getIdpConfig = (type, userPoolId, config) => {
14
+ return idpMap[type](userPoolId, config);
15
+ };
16
+
17
+ //# sourceMappingURL=getIdpConfig.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["getGoogleIdpConfig","getFacebookIdpConfig","getAppleIdpConfig","getAmazonIdpConfig","getOidcIdpConfig","idpMap","google","facebook","amazon","apple","oidc","getIdpConfig","type","userPoolId","config"],"sources":["getIdpConfig.ts"],"sourcesContent":["import type * as pulumi from \"@pulumi/pulumi\";\nimport { type CognitoIdentityProviderConfig } from \"./configure.js\";\nimport { getGoogleIdpConfig } from \"./google.js\";\nimport { getFacebookIdpConfig } from \"./facebook.js\";\nimport { getAppleIdpConfig } from \"./apple.js\";\nimport { getAmazonIdpConfig } from \"./amazon.js\";\nimport { getOidcIdpConfig } from \"./oidc.js\";\n\nconst idpMap = {\n google: getGoogleIdpConfig,\n facebook: getFacebookIdpConfig,\n amazon: getAmazonIdpConfig,\n apple: getAppleIdpConfig,\n oidc: getOidcIdpConfig\n};\n\nexport const getIdpConfig = (\n type: CognitoIdentityProviderConfig[\"type\"],\n userPoolId: pulumi.Input<string>,\n config: CognitoIdentityProviderConfig\n) => {\n return idpMap[type](userPoolId, config);\n};\n"],"mappings":"AAEA,SAASA,kBAAkB;AAC3B,SAASC,oBAAoB;AAC7B,SAASC,iBAAiB;AAC1B,SAASC,kBAAkB;AAC3B,SAASC,gBAAgB;AAEzB,MAAMC,MAAM,GAAG;EACXC,MAAM,EAAEN,kBAAkB;EAC1BO,QAAQ,EAAEN,oBAAoB;EAC9BO,MAAM,EAAEL,kBAAkB;EAC1BM,KAAK,EAAEP,iBAAiB;EACxBQ,IAAI,EAAEN;AACV,CAAC;AAED,OAAO,MAAMO,YAAY,GAAGA,CACxBC,IAA2C,EAC3CC,UAAgC,EAChCC,MAAqC,KACpC;EACD,OAAOT,MAAM,CAACO,IAAI,CAAC,CAACC,UAAU,EAAEC,MAAM,CAAC;AAC3C,CAAC","ignoreList":[]}
@@ -0,0 +1,4 @@
1
+ import type * as pulumi from "@pulumi/pulumi";
2
+ import { type CognitoIdentityProviderConfig } from "./configure.js";
3
+ import { type IdentityProviderArgs } from "@pulumi/aws/cognito/index.js";
4
+ export declare const getGoogleIdpConfig: (userPoolId: pulumi.Input<string>, config: CognitoIdentityProviderConfig) => IdentityProviderArgs;
@@ -0,0 +1,19 @@
1
+ export const getGoogleIdpConfig = (userPoolId, config) => {
2
+ return {
3
+ userPoolId,
4
+ providerName: "Google",
5
+ providerType: "Google",
6
+ providerDetails: config.providerDetails,
7
+ idpIdentifiers: config.idpIdentifiers,
8
+ attributeMapping: {
9
+ "custom:id": "sub",
10
+ username: "sub",
11
+ email: "email",
12
+ given_name: "given_name",
13
+ family_name: "family_name",
14
+ ...config.attributeMapping
15
+ }
16
+ };
17
+ };
18
+
19
+ //# sourceMappingURL=google.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["getGoogleIdpConfig","userPoolId","config","providerName","providerType","providerDetails","idpIdentifiers","attributeMapping","username","email","given_name","family_name"],"sources":["google.ts"],"sourcesContent":["import type * as pulumi from \"@pulumi/pulumi\";\nimport { type CognitoIdentityProviderConfig } from \"./configure.js\";\nimport { type IdentityProviderArgs } from \"@pulumi/aws/cognito/index.js\";\n\nexport const getGoogleIdpConfig = (\n userPoolId: pulumi.Input<string>,\n config: CognitoIdentityProviderConfig\n): IdentityProviderArgs => {\n return {\n userPoolId,\n providerName: \"Google\",\n providerType: \"Google\",\n providerDetails: config.providerDetails,\n idpIdentifiers: config.idpIdentifiers,\n attributeMapping: {\n \"custom:id\": \"sub\",\n username: \"sub\",\n email: \"email\",\n given_name: \"given_name\",\n family_name: \"family_name\",\n ...config.attributeMapping\n }\n };\n};\n"],"mappings":"AAIA,OAAO,MAAMA,kBAAkB,GAAGA,CAC9BC,UAAgC,EAChCC,MAAqC,KACd;EACvB,OAAO;IACHD,UAAU;IACVE,YAAY,EAAE,QAAQ;IACtBC,YAAY,EAAE,QAAQ;IACtBC,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,YAAY;MACxBC,WAAW,EAAE,aAAa;MAC1B,GAAGT,MAAM,CAACK;IACd;EACJ,CAAC;AACL,CAAC","ignoreList":[]}
@@ -0,0 +1 @@
1
+ export * from "./configure.js";
@@ -0,0 +1,3 @@
1
+ export * from "./configure.js";
2
+
3
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":[],"sources":["index.ts"],"sourcesContent":["export * from \"./configure.js\";\n"],"mappings":"AAAA","ignoreList":[]}
@@ -0,0 +1,4 @@
1
+ import type * as pulumi from "@pulumi/pulumi";
2
+ import { type CognitoIdentityProviderConfig } from "./configure.js";
3
+ import { type IdentityProviderArgs } from "@pulumi/aws/cognito/index.js";
4
+ export declare const getOidcIdpConfig: (userPoolId: pulumi.Input<string>, config: CognitoIdentityProviderConfig) => IdentityProviderArgs;
@@ -0,0 +1,20 @@
1
+ export const getOidcIdpConfig = (userPoolId, config) => {
2
+ return {
3
+ userPoolId,
4
+ providerName: config.name || "OIDC",
5
+ providerType: "OIDC",
6
+ providerDetails: config.providerDetails,
7
+ idpIdentifiers: config.idpIdentifiers,
8
+ attributeMapping: {
9
+ "custom:id": "sub",
10
+ username: "sub",
11
+ email: "email",
12
+ given_name: "given_name",
13
+ family_name: "family_name",
14
+ preferred_username: "email",
15
+ ...config.attributeMapping
16
+ }
17
+ };
18
+ };
19
+
20
+ //# sourceMappingURL=oidc.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["getOidcIdpConfig","userPoolId","config","providerName","name","providerType","providerDetails","idpIdentifiers","attributeMapping","username","email","given_name","family_name","preferred_username"],"sources":["oidc.ts"],"sourcesContent":["import type * as pulumi from \"@pulumi/pulumi\";\nimport { type CognitoIdentityProviderConfig } from \"./configure.js\";\nimport { type IdentityProviderArgs } from \"@pulumi/aws/cognito/index.js\";\n\nexport const getOidcIdpConfig = (\n userPoolId: pulumi.Input<string>,\n config: CognitoIdentityProviderConfig\n): IdentityProviderArgs => {\n return {\n userPoolId,\n providerName: config.name || \"OIDC\",\n providerType: \"OIDC\",\n providerDetails: config.providerDetails,\n idpIdentifiers: config.idpIdentifiers,\n attributeMapping: {\n \"custom:id\": \"sub\",\n username: \"sub\",\n email: \"email\",\n given_name: \"given_name\",\n family_name: \"family_name\",\n preferred_username: \"email\",\n ...config.attributeMapping\n }\n };\n};\n"],"mappings":"AAIA,OAAO,MAAMA,gBAAgB,GAAGA,CAC5BC,UAAgC,EAChCC,MAAqC,KACd;EACvB,OAAO;IACHD,UAAU;IACVE,YAAY,EAAED,MAAM,CAACE,IAAI,IAAI,MAAM;IACnCC,YAAY,EAAE,MAAM;IACpBC,eAAe,EAAEJ,MAAM,CAACI,eAAe;IACvCC,cAAc,EAAEL,MAAM,CAACK,cAAc;IACrCC,gBAAgB,EAAE;MACd,WAAW,EAAE,KAAK;MAClBC,QAAQ,EAAE,KAAK;MACfC,KAAK,EAAE,OAAO;MACdC,UAAU,EAAE,YAAY;MACxBC,WAAW,EAAE,aAAa;MAC1BC,kBAAkB,EAAE,OAAO;MAC3B,GAAGX,MAAM,CAACM;IACd;EACJ,CAAC;AACL,CAAC","ignoreList":[]}
@@ -0,0 +1,2 @@
1
+ import type { CorePulumiApp } from "../../../pulumi/apps/core/index.js";
2
+ export declare const configureS3BucketMalwareProtection: (app: CorePulumiApp) => void;
@@ -0,0 +1,195 @@
1
+ import * as pulumi from "@pulumi/pulumi";
2
+ import * as aws from "@pulumi/aws";
3
+ import { getAwsAccountId, getAwsRegion } from "../awsUtils.js";
4
+ export const configureS3BucketMalwareProtection = app => {
5
+ const awsAccountId = getAwsAccountId(app);
6
+ const awsRegion = getAwsRegion(app);
7
+ const eventBus = app.resources.eventBus;
8
+ const bucket = app.resources.fileManagerBucket.output;
9
+ const currentAccount = {
10
+ StringEquals: {
11
+ "aws:ResourceAccount": awsAccountId
12
+ }
13
+ };
14
+ const managedByGuardDuty = {
15
+ StringEquals: {
16
+ "events:ManagedBy": "malware-protection-plan.guardduty.amazonaws.com"
17
+ }
18
+ };
19
+ const assumeRole = aws.iam.getPolicyDocument({
20
+ statements: [{
21
+ effect: "Allow",
22
+ principals: [{
23
+ type: "Service",
24
+ identifiers: ["malware-protection-plan.guardduty.amazonaws.com"]
25
+ }],
26
+ actions: ["sts:AssumeRole"]
27
+ }]
28
+ });
29
+ const role = app.addResource(aws.iam.Role, {
30
+ name: "fm-bucket-guardduty-role",
31
+ config: {
32
+ assumeRolePolicy: assumeRole.then(assumeRole => assumeRole.json)
33
+ }
34
+ });
35
+ const policy = app.addResource(aws.iam.Policy, {
36
+ name: `fm-bucket-guardduty-role-policy`,
37
+ config: {
38
+ description: "This policy enables GuardDuty to interact with the S3 bucket.",
39
+ policy: {
40
+ Version: "2012-10-17",
41
+ Statement: [{
42
+ Sid: "AllowManagedRuleToSendS3EventsToGuardDuty",
43
+ Effect: "Allow",
44
+ Action: ["events:PutRule"],
45
+ Resource: [pulumi.interpolate`arn:aws:events:${awsRegion}:${awsAccountId}:rule/DO-NOT-DELETE-AmazonGuardDutyMalwareProtectionS3*`],
46
+ Condition: {
47
+ ...managedByGuardDuty,
48
+ "ForAllValues:StringEquals": {
49
+ "events:source": "aws.s3",
50
+ "events:detail-type": ["Object Created", "AWS API Call via CloudTrail"]
51
+ },
52
+ Null: {
53
+ "events:source": "false",
54
+ "events:detail-type": "false"
55
+ }
56
+ }
57
+ }, {
58
+ Sid: "AllowUpdateTargetAndDeleteManagedRule",
59
+ Effect: "Allow",
60
+ Action: ["events:DeleteRule", "events:PutTargets", "events:RemoveTargets"],
61
+ Resource: [pulumi.interpolate`arn:aws:events:${awsRegion}:${awsAccountId}:rule/DO-NOT-DELETE-AmazonGuardDutyMalwareProtectionS3*`],
62
+ Condition: {
63
+ ...managedByGuardDuty
64
+ }
65
+ }, {
66
+ Sid: "AllowGuardDutyToMonitorEventBridgeManagedRule",
67
+ Effect: "Allow",
68
+ Action: ["events:DescribeRule", "events:ListTargetsByRule"],
69
+ Resource: [pulumi.interpolate`arn:aws:events:${awsRegion}:${awsAccountId}:rule/DO-NOT-DELETE-AmazonGuardDutyMalwareProtectionS3*`]
70
+ }, {
71
+ Sid: "AllowPostScanTag",
72
+ Effect: "Allow",
73
+ Action: ["s3:GetObjectTagging", "s3:GetObjectVersionTagging", "s3:PutObjectTagging", "s3:PutObjectVersionTagging"],
74
+ Resource: [pulumi.interpolate`arn:aws:s3:::${bucket.bucket}/*`],
75
+ Condition: {
76
+ ...currentAccount
77
+ }
78
+ }, {
79
+ Sid: "AllowEnableS3EventBridgeEvents",
80
+ Effect: "Allow",
81
+ Action: ["s3:PutBucketNotification", "s3:GetBucketNotification"],
82
+ Resource: [pulumi.interpolate`arn:aws:s3:::${bucket.bucket}`],
83
+ Condition: {
84
+ ...currentAccount
85
+ }
86
+ }, {
87
+ Sid: "AllowPutValidationObject",
88
+ Effect: "Allow",
89
+ Action: ["s3:PutObject"],
90
+ Resource: [pulumi.interpolate`arn:aws:s3:::${bucket.bucket}/malware-protection-resource-validation-object`],
91
+ Condition: {
92
+ ...currentAccount
93
+ }
94
+ }, {
95
+ Sid: "AllowCheckBucketOwnership",
96
+ Effect: "Allow",
97
+ Action: ["s3:ListBucket"],
98
+ Resource: [pulumi.interpolate`arn:aws:s3:::${bucket.bucket}`],
99
+ Condition: {
100
+ ...currentAccount
101
+ }
102
+ }, {
103
+ Sid: "AllowMalwareScan",
104
+ Effect: "Allow",
105
+ Action: ["s3:GetObject", "s3:GetObjectVersion"],
106
+ Resource: [pulumi.interpolate`arn:aws:s3:::${bucket.bucket}/*`],
107
+ Condition: {
108
+ ...currentAccount
109
+ }
110
+ }]
111
+ }
112
+ }
113
+ });
114
+ app.addResource(aws.iam.RolePolicyAttachment, {
115
+ name: `fm-bucket-malware-protection-role-policy-attachment`,
116
+ config: {
117
+ role: role.output.name,
118
+ policyArn: policy.output.arn
119
+ }
120
+ });
121
+ app.addResource(aws.guardduty.MalwareProtectionPlan, {
122
+ name: `fm-bucket-malware-protection-plan`,
123
+ config: {
124
+ role: role.output.arn,
125
+ protectedResource: {
126
+ s3Bucket: {
127
+ bucketName: bucket.bucket
128
+ }
129
+ }
130
+ }
131
+ });
132
+
133
+ // FORWARD EVENTS FROM "DEFAULT" TO CUSTOM EVENT BUS.
134
+
135
+ // Create an IAM Role for EventBridge to forward events
136
+ const eventBridgeRole = app.addResource(aws.iam.Role, {
137
+ name: "guard-duty-forward-events-role",
138
+ config: {
139
+ assumeRolePolicy: JSON.stringify({
140
+ Version: "2012-10-17",
141
+ Statement: [{
142
+ Effect: "Allow",
143
+ Principal: {
144
+ Service: "events.amazonaws.com"
145
+ },
146
+ Action: "sts:AssumeRole"
147
+ }]
148
+ })
149
+ }
150
+ });
151
+
152
+ // Attach Policy to Allow EventBridge to PutEvents on Custom Event Bus
153
+ app.addResource(aws.iam.RolePolicy, {
154
+ name: "guard-duty-forward-events-policy",
155
+ config: {
156
+ role: eventBridgeRole.output,
157
+ policy: pulumi.output(eventBus.output.arn).apply(arn => JSON.stringify({
158
+ Version: "2012-10-17",
159
+ Statement: [{
160
+ Effect: "Allow",
161
+ Action: "events:PutEvents",
162
+ Resource: arn
163
+ }]
164
+ }))
165
+ }
166
+ });
167
+ const forwardToCustomBusRule = app.addResource(aws.cloudwatch.EventRule, {
168
+ name: "forward-events-from-default-to-custom-bus-rule",
169
+ config: {
170
+ eventBusName: "default",
171
+ eventPattern: bucket.bucket.apply(name => JSON.stringify({
172
+ source: ["aws.guardduty"],
173
+ "detail-type": ["GuardDuty Malware Protection Object Scan Result"],
174
+ detail: {
175
+ s3ObjectDetails: {
176
+ bucketName: [name]
177
+ }
178
+ }
179
+ }))
180
+ }
181
+ });
182
+
183
+ // Target: Send events to the custom event bus
184
+ app.addResource(aws.cloudwatch.EventTarget, {
185
+ name: "forward-events-from-default-to-custom-bus-target",
186
+ config: {
187
+ rule: forwardToCustomBusRule.output.name,
188
+ roleArn: eventBridgeRole.output.arn,
189
+ eventBusName: "default",
190
+ arn: eventBus.output.arn
191
+ }
192
+ });
193
+ };
194
+
195
+ //# sourceMappingURL=configureS3BucketMalwareProtection.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["pulumi","aws","getAwsAccountId","getAwsRegion","configureS3BucketMalwareProtection","app","awsAccountId","awsRegion","eventBus","resources","bucket","fileManagerBucket","output","currentAccount","StringEquals","managedByGuardDuty","assumeRole","iam","getPolicyDocument","statements","effect","principals","type","identifiers","actions","role","addResource","Role","name","config","assumeRolePolicy","then","json","policy","Policy","description","Version","Statement","Sid","Effect","Action","Resource","interpolate","Condition","Null","RolePolicyAttachment","policyArn","arn","guardduty","MalwareProtectionPlan","protectedResource","s3Bucket","bucketName","eventBridgeRole","JSON","stringify","Principal","Service","RolePolicy","apply","forwardToCustomBusRule","cloudwatch","EventRule","eventBusName","eventPattern","source","detail","s3ObjectDetails","EventTarget","rule","roleArn"],"sources":["configureS3BucketMalwareProtection.ts"],"sourcesContent":["import * as pulumi from \"@pulumi/pulumi\";\nimport * as aws from \"@pulumi/aws\";\nimport type { CorePulumiApp } from \"~/pulumi/apps/core/index.js\";\nimport { getAwsAccountId, getAwsRegion } from \"~/pulumi/apps/awsUtils.js\";\n\nexport const configureS3BucketMalwareProtection = (app: CorePulumiApp) => {\n const awsAccountId = getAwsAccountId(app);\n const awsRegion = getAwsRegion(app);\n const eventBus = app.resources.eventBus;\n\n const bucket = app.resources.fileManagerBucket.output;\n\n const currentAccount = {\n StringEquals: {\n \"aws:ResourceAccount\": awsAccountId\n }\n };\n\n const managedByGuardDuty = {\n StringEquals: {\n \"events:ManagedBy\": \"malware-protection-plan.guardduty.amazonaws.com\"\n }\n };\n\n const assumeRole = aws.iam.getPolicyDocument({\n statements: [\n {\n effect: \"Allow\",\n principals: [\n {\n type: \"Service\",\n identifiers: [\"malware-protection-plan.guardduty.amazonaws.com\"]\n }\n ],\n actions: [\"sts:AssumeRole\"]\n }\n ]\n });\n\n const role = app.addResource(aws.iam.Role, {\n name: \"fm-bucket-guardduty-role\",\n config: {\n assumeRolePolicy: assumeRole.then(assumeRole => assumeRole.json)\n }\n });\n\n const policy = app.addResource(aws.iam.Policy, {\n name: `fm-bucket-guardduty-role-policy`,\n config: {\n description: \"This policy enables GuardDuty to interact with the S3 bucket.\",\n policy: {\n Version: \"2012-10-17\",\n Statement: [\n {\n Sid: \"AllowManagedRuleToSendS3EventsToGuardDuty\",\n Effect: \"Allow\",\n Action: [\"events:PutRule\"],\n Resource: [\n pulumi.interpolate`arn:aws:events:${awsRegion}:${awsAccountId}:rule/DO-NOT-DELETE-AmazonGuardDutyMalwareProtectionS3*`\n ],\n Condition: {\n ...managedByGuardDuty,\n \"ForAllValues:StringEquals\": {\n \"events:source\": \"aws.s3\",\n \"events:detail-type\": [\n \"Object Created\",\n \"AWS API Call via CloudTrail\"\n ]\n },\n Null: {\n \"events:source\": \"false\",\n \"events:detail-type\": \"false\"\n }\n }\n },\n {\n Sid: \"AllowUpdateTargetAndDeleteManagedRule\",\n Effect: \"Allow\",\n Action: [\"events:DeleteRule\", \"events:PutTargets\", \"events:RemoveTargets\"],\n Resource: [\n pulumi.interpolate`arn:aws:events:${awsRegion}:${awsAccountId}:rule/DO-NOT-DELETE-AmazonGuardDutyMalwareProtectionS3*`\n ],\n Condition: {\n ...managedByGuardDuty\n }\n },\n {\n Sid: \"AllowGuardDutyToMonitorEventBridgeManagedRule\",\n Effect: \"Allow\",\n Action: [\"events:DescribeRule\", \"events:ListTargetsByRule\"],\n Resource: [\n pulumi.interpolate`arn:aws:events:${awsRegion}:${awsAccountId}:rule/DO-NOT-DELETE-AmazonGuardDutyMalwareProtectionS3*`\n ]\n },\n {\n Sid: \"AllowPostScanTag\",\n Effect: \"Allow\",\n Action: [\n \"s3:GetObjectTagging\",\n \"s3:GetObjectVersionTagging\",\n \"s3:PutObjectTagging\",\n \"s3:PutObjectVersionTagging\"\n ],\n Resource: [pulumi.interpolate`arn:aws:s3:::${bucket.bucket}/*`],\n Condition: {\n ...currentAccount\n }\n },\n {\n Sid: \"AllowEnableS3EventBridgeEvents\",\n Effect: \"Allow\",\n Action: [\"s3:PutBucketNotification\", \"s3:GetBucketNotification\"],\n Resource: [pulumi.interpolate`arn:aws:s3:::${bucket.bucket}`],\n Condition: {\n ...currentAccount\n }\n },\n {\n Sid: \"AllowPutValidationObject\",\n Effect: \"Allow\",\n Action: [\"s3:PutObject\"],\n Resource: [\n pulumi.interpolate`arn:aws:s3:::${bucket.bucket}/malware-protection-resource-validation-object`\n ],\n Condition: {\n ...currentAccount\n }\n },\n {\n Sid: \"AllowCheckBucketOwnership\",\n Effect: \"Allow\",\n Action: [\"s3:ListBucket\"],\n Resource: [pulumi.interpolate`arn:aws:s3:::${bucket.bucket}`],\n Condition: {\n ...currentAccount\n }\n },\n {\n Sid: \"AllowMalwareScan\",\n Effect: \"Allow\",\n Action: [\"s3:GetObject\", \"s3:GetObjectVersion\"],\n Resource: [pulumi.interpolate`arn:aws:s3:::${bucket.bucket}/*`],\n Condition: {\n ...currentAccount\n }\n }\n ]\n }\n }\n });\n\n app.addResource(aws.iam.RolePolicyAttachment, {\n name: `fm-bucket-malware-protection-role-policy-attachment`,\n config: {\n role: role.output.name,\n policyArn: policy.output.arn\n }\n });\n\n app.addResource(aws.guardduty.MalwareProtectionPlan, {\n name: `fm-bucket-malware-protection-plan`,\n config: {\n role: role.output.arn,\n protectedResource: {\n s3Bucket: {\n bucketName: bucket.bucket\n }\n }\n }\n });\n\n // FORWARD EVENTS FROM \"DEFAULT\" TO CUSTOM EVENT BUS.\n\n // Create an IAM Role for EventBridge to forward events\n const eventBridgeRole = app.addResource(aws.iam.Role, {\n name: \"guard-duty-forward-events-role\",\n config: {\n assumeRolePolicy: JSON.stringify({\n Version: \"2012-10-17\",\n Statement: [\n {\n Effect: \"Allow\",\n Principal: { Service: \"events.amazonaws.com\" },\n Action: \"sts:AssumeRole\"\n }\n ]\n })\n }\n });\n\n // Attach Policy to Allow EventBridge to PutEvents on Custom Event Bus\n app.addResource(aws.iam.RolePolicy, {\n name: \"guard-duty-forward-events-policy\",\n config: {\n role: eventBridgeRole.output,\n policy: pulumi.output(eventBus.output.arn).apply(arn =>\n JSON.stringify({\n Version: \"2012-10-17\",\n Statement: [\n {\n Effect: \"Allow\",\n Action: \"events:PutEvents\",\n Resource: arn\n }\n ]\n })\n )\n }\n });\n\n const forwardToCustomBusRule = app.addResource(aws.cloudwatch.EventRule, {\n name: \"forward-events-from-default-to-custom-bus-rule\",\n config: {\n eventBusName: \"default\",\n eventPattern: bucket.bucket.apply(name =>\n JSON.stringify({\n source: [\"aws.guardduty\"],\n \"detail-type\": [\"GuardDuty Malware Protection Object Scan Result\"],\n detail: {\n s3ObjectDetails: {\n bucketName: [name]\n }\n }\n })\n )\n }\n });\n\n // Target: Send events to the custom event bus\n app.addResource(aws.cloudwatch.EventTarget, {\n name: \"forward-events-from-default-to-custom-bus-target\",\n config: {\n rule: forwardToCustomBusRule.output.name,\n roleArn: eventBridgeRole.output.arn,\n eventBusName: \"default\",\n arn: eventBus.output.arn\n }\n });\n};\n"],"mappings":"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","ignoreList":[]}
@@ -0,0 +1,32 @@
1
+ import * as aws from "@pulumi/aws";
2
+ export type CorePulumiApp = ReturnType<typeof createCorePulumiApp>;
3
+ export declare function createCorePulumiApp(): import("@webiny/pulumi").PulumiApp<{
4
+ fileManagerBucket: import("@webiny/pulumi").PulumiAppResource<typeof import("@pulumi/aws/s3/bucket.js").Bucket>;
5
+ eventBus: import("@webiny/pulumi").PulumiAppResource<typeof import("@pulumi/aws/cloudwatch/eventBus.js").EventBus>;
6
+ opensearch: {
7
+ domain: import("@webiny/pulumi").PulumiAppResource<import("@webiny/pulumi").PulumiAppResourceConstructor<import("@pulumi/aws/opensearch/domain.js").Domain, any>> | import("@webiny/pulumi").PulumiAppRemoteResource<aws.opensearch.GetDomainResult>;
8
+ domainPolicy: import("@webiny/pulumi").PulumiAppResource<typeof import("@pulumi/aws/opensearch/domainPolicy.js").DomainPolicy> | undefined;
9
+ table: import("@webiny/pulumi").PulumiAppResource<typeof import("@pulumi/aws/dynamodb/table.js").Table>;
10
+ dynamoToElastic: {
11
+ role: import("@webiny/pulumi").PulumiAppResource<typeof import("@pulumi/aws/iam/role.js").Role>;
12
+ policy: import("@webiny/pulumi").PulumiAppResource<typeof import("@pulumi/aws/iam/policy.js").Policy>;
13
+ lambda: import("@webiny/pulumi").PulumiAppResource<typeof import("@pulumi/aws/lambda/function.js").Function>;
14
+ eventSourceMapping: import("@webiny/pulumi").PulumiAppResource<typeof import("@pulumi/aws/lambda/eventSourceMapping.js").EventSourceMapping>;
15
+ };
16
+ } | undefined;
17
+ userPool: import("@webiny/pulumi").PulumiAppResource<typeof import("@pulumi/aws/cognito/userPool.js").UserPool>;
18
+ userPoolClient: import("@webiny/pulumi").PulumiAppResource<typeof import("@pulumi/aws/cognito/userPoolClient.js").UserPoolClient>;
19
+ dynamoDbTable: import("@webiny/pulumi").PulumiAppResource<typeof import("@pulumi/aws/dynamodb/table.js").Table>;
20
+ logDynamoDbTable: import("@webiny/pulumi").PulumiAppResource<typeof import("@pulumi/aws/dynamodb/table.js").Table>;
21
+ vpc: {
22
+ vpc: import("@webiny/pulumi").PulumiAppResource<typeof import("@pulumi/aws/ec2/vpc.js").Vpc>;
23
+ subnets: {
24
+ public: import("@webiny/pulumi").PulumiAppResource<typeof import("@pulumi/aws/ec2/subnet.js").Subnet>[];
25
+ private: import("@webiny/pulumi").PulumiAppResource<typeof import("@pulumi/aws/ec2/subnet.js").Subnet>[];
26
+ };
27
+ routeTables: {
28
+ privateSubnets: import("@webiny/pulumi").PulumiAppResource<typeof import("@pulumi/aws/ec2/routeTable.js").RouteTable>;
29
+ publicSubnets: import("@webiny/pulumi").PulumiAppResource<typeof import("@pulumi/aws/ec2/routeTable.js").RouteTable>;
30
+ };
31
+ } | null;
32
+ }> & import("~/pulumi/utils/withServiceManifest.js").WithServiceManifest;