@webiny/project-aws 0.0.0-unstable.3c5210ad37
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.
- package/LICENSE +21 -0
- package/README.md +11 -0
- package/_templates/appTemplates/admin/src/App.scss +2 -0
- package/_templates/appTemplates/admin/src/App.tsx +13 -0
- package/_templates/appTemplates/admin/src/Extensions.tsx +7 -0
- package/_templates/appTemplates/admin/src/index.tsx +11 -0
- package/_templates/appTemplates/admin/tsconfig.json +7 -0
- package/_templates/appTemplates/admin/webiny.application.ts +3 -0
- package/_templates/appTemplates/admin/webiny.config.ts +3 -0
- package/_templates/appTemplates/api/graphql/package.json +43 -0
- package/_templates/appTemplates/api/graphql/src/extensions.ts +9 -0
- package/_templates/appTemplates/api/graphql/src/index.ts +80 -0
- package/_templates/appTemplates/api/graphql/src/security.ts +43 -0
- package/_templates/appTemplates/api/graphql/tsconfig.json +7 -0
- package/_templates/appTemplates/api/graphql/webiny.config.ts +8 -0
- package/_templates/appTemplates/api/migration/src/index.ts +23 -0
- package/_templates/appTemplates/api/migration/tsconfig.json +7 -0
- package/_templates/appTemplates/api/migration/webiny.config.ts +8 -0
- package/_templates/appTemplates/api/webiny.application.ts +3 -0
- package/_templates/appTemplates/blueGreen/webiny.application.ts +3 -0
- package/_templates/appTemplates/core/webiny.application.ts +3 -0
- package/_templates/appTemplates/syncSystem/webiny.application.ts +3 -0
- package/_templates/extensions/ApiLambdaFunction/package.json +9 -0
- package/_templates/extensions/ApiLambdaFunction/tsconfig.json +7 -0
- package/_templates/extensions/ApiLambdaFunction/webiny.config.ts +8 -0
- package/_templates/extensions/OpenSearch/api/graphql/src/index.ts +90 -0
- package/_templates/extensions/OpenSearch/api/migration/src/index.ts +33 -0
- package/_templates/extensions/OpenSearch/coreDdbToEsHandler/dynamoToElastic/src/index.ts +15 -0
- package/_templates/extensions/OpenSearch/coreDdbToEsHandler/dynamoToElastic/tsconfig.json +7 -0
- package/_templates/extensions/OpenSearch/coreDdbToEsHandler/dynamoToElastic/webiny.config.ts +8 -0
- package/abstractions/ApiGqlClient.d.ts +23 -0
- package/abstractions/ApiGqlClient.js +4 -0
- package/abstractions/ApiGqlClient.js.map +1 -0
- package/abstractions/InvokeLambdaFunction.d.ts +18 -0
- package/abstractions/InvokeLambdaFunction.js +4 -0
- package/abstractions/InvokeLambdaFunction.js.map +1 -0
- package/abstractions/index.d.ts +5 -0
- package/abstractions/index.js +7 -0
- package/abstractions/index.js.map +1 -0
- package/abstractions/services/AdminStackOutputService.d.ts +13 -0
- package/abstractions/services/AdminStackOutputService.js +4 -0
- package/abstractions/services/AdminStackOutputService.js.map +1 -0
- package/abstractions/services/ApiStackOutputService.d.ts +30 -0
- package/abstractions/services/ApiStackOutputService.js +4 -0
- package/abstractions/services/ApiStackOutputService.js.map +1 -0
- package/abstractions/services/CoreStackOutputService.d.ts +16 -0
- package/abstractions/services/CoreStackOutputService.js +4 -0
- package/abstractions/services/CoreStackOutputService.js.map +1 -0
- package/admin.d.ts +22 -0
- package/admin.js +7 -0
- package/admin.js.map +1 -0
- package/api.d.ts +22 -0
- package/api.js +7 -0
- package/api.js.map +1 -0
- package/apps/createAdminApp.d.ts +15 -0
- package/apps/createAdminApp.js +15 -0
- package/apps/createAdminApp.js.map +1 -0
- package/apps/createAdminAppConfig.d.ts +2 -0
- package/apps/createAdminAppConfig.js +21 -0
- package/apps/createAdminAppConfig.js.map +1 -0
- package/apps/createApiApp.d.ts +65 -0
- package/apps/createApiApp.js +25 -0
- package/apps/createApiApp.js.map +1 -0
- package/apps/createBlueGreenApp.d.ts +24 -0
- package/apps/createBlueGreenApp.js +20 -0
- package/apps/createBlueGreenApp.js.map +1 -0
- package/apps/createCoreApp.d.ts +36 -0
- package/apps/createCoreApp.js +16 -0
- package/apps/createCoreApp.js.map +1 -0
- package/apps/createReactAppConfig.d.ts +53 -0
- package/apps/createReactAppConfig.js +79 -0
- package/apps/createReactAppConfig.js.map +1 -0
- package/apps/createSyncSystemApp.d.ts +21 -0
- package/apps/createSyncSystemApp.js +11 -0
- package/apps/createSyncSystemApp.js.map +1 -0
- package/apps/index.d.ts +7 -0
- package/apps/index.js +9 -0
- package/apps/index.js.map +1 -0
- package/cli.d.ts +9 -0
- package/cli.js +6 -0
- package/cli.js.map +1 -0
- package/exports/extensions.d.ts +5 -0
- package/exports/extensions.js +7 -0
- package/exports/extensions.js.map +1 -0
- package/exports/infra/admin.d.ts +1 -0
- package/exports/infra/admin.js +3 -0
- package/exports/infra/admin.js.map +1 -0
- package/exports/infra/api.d.ts +1 -0
- package/exports/infra/api.js +3 -0
- package/exports/infra/api.js.map +1 -0
- package/exports/infra/core.d.ts +1 -0
- package/exports/infra/core.js +3 -0
- package/exports/infra/core.js.map +1 -0
- package/exports/infra/index.d.ts +1 -0
- package/exports/infra/index.js +3 -0
- package/exports/infra/index.js.map +1 -0
- package/extensions/ApiLambdaFunction.d.ts +11 -0
- package/extensions/ApiLambdaFunction.js +68 -0
- package/extensions/ApiLambdaFunction.js.map +1 -0
- package/extensions/AwsDefaultRegion.d.ts +8 -0
- package/extensions/AwsDefaultRegion.js +22 -0
- package/extensions/AwsDefaultRegion.js.map +1 -0
- package/extensions/OpenSearch/EnsureOsServiceRoleBeforeCoreDeploy.d.ts +10 -0
- package/extensions/OpenSearch/EnsureOsServiceRoleBeforeCoreDeploy.js +40 -0
- package/extensions/OpenSearch/EnsureOsServiceRoleBeforeCoreDeploy.js.map +1 -0
- package/extensions/OpenSearch/EnsureOsWasDeployed.d.ts +11 -0
- package/extensions/OpenSearch/EnsureOsWasDeployed.js +34 -0
- package/extensions/OpenSearch/EnsureOsWasDeployed.js.map +1 -0
- package/extensions/OpenSearch/InjectDdbEsLambdaFnHandler.d.ts +12 -0
- package/extensions/OpenSearch/InjectDdbEsLambdaFnHandler.js +31 -0
- package/extensions/OpenSearch/InjectDdbEsLambdaFnHandler.js.map +1 -0
- package/extensions/OpenSearch/ReplaceApiLambdaFnHandlers.d.ts +12 -0
- package/extensions/OpenSearch/ReplaceApiLambdaFnHandlers.js +32 -0
- package/extensions/OpenSearch/ReplaceApiLambdaFnHandlers.js.map +1 -0
- package/extensions/OpenSearch.d.ts +17 -0
- package/extensions/OpenSearch.js +35 -0
- package/extensions/OpenSearch.js.map +1 -0
- package/extensions/ProjectAws/AdminStackOutputService.d.ts +1 -0
- package/extensions/ProjectAws/AdminStackOutputService.js +3 -0
- package/extensions/ProjectAws/AdminStackOutputService.js.map +1 -0
- package/extensions/ProjectAws/ApiStackOutputService.d.ts +1 -0
- package/extensions/ProjectAws/ApiStackOutputService.js +3 -0
- package/extensions/ProjectAws/ApiStackOutputService.js.map +1 -0
- package/extensions/ProjectAws/AutoInstall/AutoInstallAfterApiDeploy.d.ts +17 -0
- package/extensions/ProjectAws/AutoInstall/AutoInstallAfterApiDeploy.js +108 -0
- package/extensions/ProjectAws/AutoInstall/AutoInstallAfterApiDeploy.js.map +1 -0
- package/extensions/ProjectAws/AutoInstall.d.ts +33 -0
- package/extensions/ProjectAws/AutoInstall.js +19 -0
- package/extensions/ProjectAws/AutoInstall.js.map +1 -0
- package/extensions/ProjectAws/BlueGreenDeployments/EnsureVariantBeforeDeploy.d.ts +10 -0
- package/extensions/ProjectAws/BlueGreenDeployments/EnsureVariantBeforeDeploy.js +27 -0
- package/extensions/ProjectAws/BlueGreenDeployments/EnsureVariantBeforeDeploy.js.map +1 -0
- package/extensions/ProjectAws/BlueGreenDeployments/PrintDeploymentInfoAfterDeploy.d.ts +20 -0
- package/extensions/ProjectAws/BlueGreenDeployments/PrintDeploymentInfoAfterDeploy.js +54 -0
- package/extensions/ProjectAws/BlueGreenDeployments/PrintDeploymentInfoAfterDeploy.js.map +1 -0
- package/extensions/ProjectAws/BlueGreenDeployments/SetPrimaryVariantCliCommand.d.ts +18 -0
- package/extensions/ProjectAws/BlueGreenDeployments/SetPrimaryVariantCliCommand.js +60 -0
- package/extensions/ProjectAws/BlueGreenDeployments/SetPrimaryVariantCliCommand.js.map +1 -0
- package/extensions/ProjectAws/BuildAppWorkspace.d.ts +12 -0
- package/extensions/ProjectAws/BuildAppWorkspace.js +66 -0
- package/extensions/ProjectAws/BuildAppWorkspace.js.map +1 -0
- package/extensions/ProjectAws/CoreStackOutputService.d.ts +1 -0
- package/extensions/ProjectAws/CoreStackOutputService.js +3 -0
- package/extensions/ProjectAws/CoreStackOutputService.js.map +1 -0
- package/extensions/ProjectAws/ExecuteDataMigrations.d.ts +16 -0
- package/extensions/ProjectAws/ExecuteDataMigrations.js +69 -0
- package/extensions/ProjectAws/ExecuteDataMigrations.js.map +1 -0
- package/extensions/ProjectAws/SetAdminEnvVars/SetAdminEnvVars.d.ts +13 -0
- package/extensions/ProjectAws/SetAdminEnvVars/SetAdminEnvVars.js +43 -0
- package/extensions/ProjectAws/SetAdminEnvVars/SetAdminEnvVars.js.map +1 -0
- package/extensions/ProjectAws/SetAdminEnvVars/SetAdminEnvVarsBeforeBuild.d.ts +13 -0
- package/extensions/ProjectAws/SetAdminEnvVars/SetAdminEnvVarsBeforeBuild.js +24 -0
- package/extensions/ProjectAws/SetAdminEnvVars/SetAdminEnvVarsBeforeBuild.js.map +1 -0
- package/extensions/ProjectAws/SetAdminEnvVars/SetAdminEnvVarsBeforeWatch.d.ts +13 -0
- package/extensions/ProjectAws/SetAdminEnvVars/SetAdminEnvVarsBeforeWatch.js +24 -0
- package/extensions/ProjectAws/SetAdminEnvVars/SetAdminEnvVarsBeforeWatch.js.map +1 -0
- package/extensions/ProjectAws/SetDatabaseSetupOutput.d.ts +10 -0
- package/extensions/ProjectAws/SetDatabaseSetupOutput.js +29 -0
- package/extensions/ProjectAws/SetDatabaseSetupOutput.js.map +1 -0
- package/extensions/ProjectAws/UploadAdminAppToS3.d.ts +13 -0
- package/extensions/ProjectAws/UploadAdminAppToS3.js +69 -0
- package/extensions/ProjectAws/UploadAdminAppToS3.js.map +1 -0
- package/extensions/ProjectAws/definitions.d.ts +3 -0
- package/extensions/ProjectAws/definitions.js +9 -0
- package/extensions/ProjectAws/definitions.js.map +1 -0
- package/extensions/ProjectAws.d.ts +2 -0
- package/extensions/ProjectAws.js +52 -0
- package/extensions/ProjectAws.js.map +1 -0
- package/extensions/definitions.d.ts +3 -0
- package/extensions/definitions.js +6 -0
- package/extensions/definitions.js.map +1 -0
- package/extensions/index.d.ts +5 -0
- package/extensions/index.js +7 -0
- package/extensions/index.js.map +1 -0
- package/features/ApiGqlClient.d.ts +21 -0
- package/features/ApiGqlClient.js +59 -0
- package/features/ApiGqlClient.js.map +1 -0
- package/features/InvokeLambdaFunction.d.ts +10 -0
- package/features/InvokeLambdaFunction.js +38 -0
- package/features/InvokeLambdaFunction.js.map +1 -0
- package/features/index.d.ts +2 -0
- package/features/index.js +4 -0
- package/features/index.js.map +1 -0
- package/index.d.ts +6 -0
- package/index.js +8 -0
- package/index.js.map +1 -0
- package/infra.d.ts +425 -0
- package/infra.js +54 -0
- package/infra.js.map +1 -0
- package/package.json +60 -0
- package/project.d.ts +139 -0
- package/project.js +10 -0
- package/project.js.map +1 -0
- package/pulumi/apps/admin/createAdminPulumiApp.d.ts +12 -0
- package/pulumi/apps/admin/createAdminPulumiApp.js +52 -0
- package/pulumi/apps/admin/createAdminPulumiApp.js.map +1 -0
- package/pulumi/apps/admin/index.d.ts +1 -0
- package/pulumi/apps/admin/index.js +3 -0
- package/pulumi/apps/admin/index.js.map +1 -0
- package/pulumi/apps/api/ApiBackgroundTask.d.ts +12 -0
- package/pulumi/apps/api/ApiBackgroundTask.js +148 -0
- package/pulumi/apps/api/ApiBackgroundTask.js.map +1 -0
- package/pulumi/apps/api/ApiCloudfront.d.ts +3 -0
- package/pulumi/apps/api/ApiCloudfront.js +136 -0
- package/pulumi/apps/api/ApiCloudfront.js.map +1 -0
- package/pulumi/apps/api/ApiFileManager.d.ts +11 -0
- package/pulumi/apps/api/ApiFileManager.js +39 -0
- package/pulumi/apps/api/ApiFileManager.js.map +1 -0
- package/pulumi/apps/api/ApiGateway.d.ts +18 -0
- package/pulumi/apps/api/ApiGateway.js +80 -0
- package/pulumi/apps/api/ApiGateway.js.map +1 -0
- package/pulumi/apps/api/ApiGraphql.d.ts +22 -0
- package/pulumi/apps/api/ApiGraphql.js +164 -0
- package/pulumi/apps/api/ApiGraphql.js.map +1 -0
- package/pulumi/apps/api/ApiMigration.d.ts +5 -0
- package/pulumi/apps/api/ApiMigration.js +83 -0
- package/pulumi/apps/api/ApiMigration.js.map +1 -0
- package/pulumi/apps/api/ApiOutput.d.ts +23 -0
- package/pulumi/apps/api/ApiOutput.js +36 -0
- package/pulumi/apps/api/ApiOutput.js.map +1 -0
- package/pulumi/apps/api/ApiScheduler.d.ts +8 -0
- package/pulumi/apps/api/ApiScheduler.js +100 -0
- package/pulumi/apps/api/ApiScheduler.js.map +1 -0
- package/pulumi/apps/api/ApiWebsocket.d.ts +14 -0
- package/pulumi/apps/api/ApiWebsocket.js +138 -0
- package/pulumi/apps/api/ApiWebsocket.js.map +1 -0
- package/pulumi/apps/api/backgroundTask/definition.d.ts +7 -0
- package/pulumi/apps/api/backgroundTask/definition.js +149 -0
- package/pulumi/apps/api/backgroundTask/definition.js.map +1 -0
- package/pulumi/apps/api/backgroundTask/policy.d.ts +8 -0
- package/pulumi/apps/api/backgroundTask/policy.js +26 -0
- package/pulumi/apps/api/backgroundTask/policy.js.map +1 -0
- package/pulumi/apps/api/backgroundTask/role.d.ts +9 -0
- package/pulumi/apps/api/backgroundTask/role.js +32 -0
- package/pulumi/apps/api/backgroundTask/role.js.map +1 -0
- package/pulumi/apps/api/backgroundTask/types.d.ts +91 -0
- package/pulumi/apps/api/backgroundTask/types.js +14 -0
- package/pulumi/apps/api/backgroundTask/types.js.map +1 -0
- package/pulumi/apps/api/createApiPulumiApp.d.ts +57 -0
- package/pulumi/apps/api/createApiPulumiApp.js +281 -0
- package/pulumi/apps/api/createApiPulumiApp.js.map +1 -0
- package/pulumi/apps/api/handleGuardDutyEvents.d.ts +2 -0
- package/pulumi/apps/api/handleGuardDutyEvents.js +55 -0
- package/pulumi/apps/api/handleGuardDutyEvents.js.map +1 -0
- package/pulumi/apps/api/index.d.ts +9 -0
- package/pulumi/apps/api/index.js +11 -0
- package/pulumi/apps/api/index.js.map +1 -0
- package/pulumi/apps/awsUtils.d.ts +5 -0
- package/pulumi/apps/awsUtils.js +34 -0
- package/pulumi/apps/awsUtils.js.map +1 -0
- package/pulumi/apps/blueGreen/BlueGreenRouterApiGateway.d.ts +11 -0
- package/pulumi/apps/blueGreen/BlueGreenRouterApiGateway.js +44 -0
- package/pulumi/apps/blueGreen/BlueGreenRouterApiGateway.js.map +1 -0
- package/pulumi/apps/blueGreen/BlueGreenRouterCloudFront.d.ts +17 -0
- package/pulumi/apps/blueGreen/BlueGreenRouterCloudFront.js +100 -0
- package/pulumi/apps/blueGreen/BlueGreenRouterCloudFront.js.map +1 -0
- package/pulumi/apps/blueGreen/BlueGreenRouterCloudFrontStore.d.ts +10 -0
- package/pulumi/apps/blueGreen/BlueGreenRouterCloudFrontStore.js +20 -0
- package/pulumi/apps/blueGreen/BlueGreenRouterCloudFrontStore.js.map +1 -0
- package/pulumi/apps/blueGreen/cloudfront/createCloudFrontDefaultCacheBehaviorPolicies.d.ts +7 -0
- package/pulumi/apps/blueGreen/cloudfront/createCloudFrontDefaultCacheBehaviorPolicies.js +15 -0
- package/pulumi/apps/blueGreen/cloudfront/createCloudFrontDefaultCacheBehaviorPolicies.js.map +1 -0
- package/pulumi/apps/blueGreen/cloudfront/createCloudFrontFunctionDomainMap.d.ts +14 -0
- package/pulumi/apps/blueGreen/cloudfront/createCloudFrontFunctionDomainMap.js +23 -0
- package/pulumi/apps/blueGreen/cloudfront/createCloudFrontFunctionDomainMap.js.map +1 -0
- package/pulumi/apps/blueGreen/cloudfront/createOriginId.d.ts +11 -0
- package/pulumi/apps/blueGreen/cloudfront/createOriginId.js +10 -0
- package/pulumi/apps/blueGreen/cloudfront/createOriginId.js.map +1 -0
- package/pulumi/apps/blueGreen/constants.d.ts +3 -0
- package/pulumi/apps/blueGreen/constants.js +5 -0
- package/pulumi/apps/blueGreen/constants.js.map +1 -0
- package/pulumi/apps/blueGreen/createBlueGreenPulumiApp.d.ts +15 -0
- package/pulumi/apps/blueGreen/createBlueGreenPulumiApp.js +122 -0
- package/pulumi/apps/blueGreen/createBlueGreenPulumiApp.js.map +1 -0
- package/pulumi/apps/blueGreen/domains/attachDomainsToOutput.d.ts +9 -0
- package/pulumi/apps/blueGreen/domains/attachDomainsToOutput.js +30 -0
- package/pulumi/apps/blueGreen/domains/attachDomainsToOutput.js.map +1 -0
- package/pulumi/apps/blueGreen/domains/convertApplicationDomains.d.ts +6 -0
- package/pulumi/apps/blueGreen/domains/convertApplicationDomains.js +23 -0
- package/pulumi/apps/blueGreen/domains/convertApplicationDomains.js.map +1 -0
- package/pulumi/apps/blueGreen/domains/getApplicationDomains.d.ts +18 -0
- package/pulumi/apps/blueGreen/domains/getApplicationDomains.js +73 -0
- package/pulumi/apps/blueGreen/domains/getApplicationDomains.js.map +1 -0
- package/pulumi/apps/blueGreen/domains/resolveDomains.d.ts +6 -0
- package/pulumi/apps/blueGreen/domains/resolveDomains.js +41 -0
- package/pulumi/apps/blueGreen/domains/resolveDomains.js.map +1 -0
- package/pulumi/apps/blueGreen/functions/buildHandlerFunction.d.ts +15 -0
- package/pulumi/apps/blueGreen/functions/buildHandlerFunction.js +18 -0
- package/pulumi/apps/blueGreen/functions/buildHandlerFunction.js.map +1 -0
- package/pulumi/apps/blueGreen/functions/handler.d.ts +1 -0
- package/pulumi/apps/blueGreen/functions/handler.js +60 -0
- package/pulumi/apps/blueGreen/functions/handler.js.map +1 -0
- package/pulumi/apps/blueGreen/types.d.ts +77 -0
- package/pulumi/apps/blueGreen/types.js +3 -0
- package/pulumi/apps/blueGreen/types.js.map +1 -0
- package/pulumi/apps/blueGreen/validation/validateDeployments.d.ts +2 -0
- package/pulumi/apps/blueGreen/validation/validateDeployments.js +33 -0
- package/pulumi/apps/blueGreen/validation/validateDeployments.js.map +1 -0
- package/pulumi/apps/common/CoreOutput.d.ts +38 -0
- package/pulumi/apps/common/CoreOutput.js +46 -0
- package/pulumi/apps/common/CoreOutput.js.map +1 -0
- package/pulumi/apps/common/VpcConfig.d.ts +8 -0
- package/pulumi/apps/common/VpcConfig.js +25 -0
- package/pulumi/apps/common/VpcConfig.js.map +1 -0
- package/pulumi/apps/common/index.d.ts +2 -0
- package/pulumi/apps/common/index.js +4 -0
- package/pulumi/apps/common/index.js.map +1 -0
- package/pulumi/apps/core/CoreAuditLogsDynamo.d.ts +5 -0
- package/pulumi/apps/core/CoreAuditLogsDynamo.js +186 -0
- package/pulumi/apps/core/CoreAuditLogsDynamo.js.map +1 -0
- package/pulumi/apps/core/CoreCognito.d.ts +10 -0
- package/pulumi/apps/core/CoreCognito.js +110 -0
- package/pulumi/apps/core/CoreCognito.js.map +1 -0
- package/pulumi/apps/core/CoreDynamo.d.ts +5 -0
- package/pulumi/apps/core/CoreDynamo.js +74 -0
- package/pulumi/apps/core/CoreDynamo.js.map +1 -0
- package/pulumi/apps/core/CoreEventBus.d.ts +1 -0
- package/pulumi/apps/core/CoreEventBus.js +13 -0
- package/pulumi/apps/core/CoreEventBus.js.map +1 -0
- package/pulumi/apps/core/CoreFileManager.d.ts +11 -0
- package/pulumi/apps/core/CoreFileManager.js +72 -0
- package/pulumi/apps/core/CoreFileManager.js.map +1 -0
- package/pulumi/apps/core/CoreOpenSearch.d.ts +16 -0
- package/pulumi/apps/core/CoreOpenSearch.js +299 -0
- package/pulumi/apps/core/CoreOpenSearch.js.map +1 -0
- package/pulumi/apps/core/CoreVpc.d.ts +13 -0
- package/pulumi/apps/core/CoreVpc.js +160 -0
- package/pulumi/apps/core/CoreVpc.js.map +1 -0
- package/pulumi/apps/core/LogDynamo.d.ts +5 -0
- package/pulumi/apps/core/LogDynamo.js +122 -0
- package/pulumi/apps/core/LogDynamo.js.map +1 -0
- package/pulumi/apps/core/WatchCommand.d.ts +7 -0
- package/pulumi/apps/core/WatchCommand.js +105 -0
- package/pulumi/apps/core/WatchCommand.js.map +1 -0
- package/pulumi/apps/core/cognitoIdentityProviders/amazon.d.ts +9 -0
- package/pulumi/apps/core/cognitoIdentityProviders/amazon.js +24 -0
- package/pulumi/apps/core/cognitoIdentityProviders/amazon.js.map +1 -0
- package/pulumi/apps/core/cognitoIdentityProviders/apple.d.ts +4 -0
- package/pulumi/apps/core/cognitoIdentityProviders/apple.js +19 -0
- package/pulumi/apps/core/cognitoIdentityProviders/apple.js.map +1 -0
- package/pulumi/apps/core/cognitoIdentityProviders/configure.d.ts +28 -0
- package/pulumi/apps/core/cognitoIdentityProviders/configure.js +57 -0
- package/pulumi/apps/core/cognitoIdentityProviders/configure.js.map +1 -0
- package/pulumi/apps/core/cognitoIdentityProviders/facebook.d.ts +4 -0
- package/pulumi/apps/core/cognitoIdentityProviders/facebook.js +19 -0
- package/pulumi/apps/core/cognitoIdentityProviders/facebook.js.map +1 -0
- package/pulumi/apps/core/cognitoIdentityProviders/getIdpConfig.d.ts +3 -0
- package/pulumi/apps/core/cognitoIdentityProviders/getIdpConfig.js +17 -0
- package/pulumi/apps/core/cognitoIdentityProviders/getIdpConfig.js.map +1 -0
- package/pulumi/apps/core/cognitoIdentityProviders/google.d.ts +4 -0
- package/pulumi/apps/core/cognitoIdentityProviders/google.js +19 -0
- package/pulumi/apps/core/cognitoIdentityProviders/google.js.map +1 -0
- package/pulumi/apps/core/cognitoIdentityProviders/index.d.ts +1 -0
- package/pulumi/apps/core/cognitoIdentityProviders/index.js +3 -0
- package/pulumi/apps/core/cognitoIdentityProviders/index.js.map +1 -0
- package/pulumi/apps/core/cognitoIdentityProviders/oidc.d.ts +4 -0
- package/pulumi/apps/core/cognitoIdentityProviders/oidc.js +20 -0
- package/pulumi/apps/core/cognitoIdentityProviders/oidc.js.map +1 -0
- package/pulumi/apps/core/configureS3BucketMalwareProtection.d.ts +2 -0
- package/pulumi/apps/core/configureS3BucketMalwareProtection.js +195 -0
- package/pulumi/apps/core/configureS3BucketMalwareProtection.js.map +1 -0
- package/pulumi/apps/core/createCorePulumiApp.d.ts +32 -0
- package/pulumi/apps/core/createCorePulumiApp.js +295 -0
- package/pulumi/apps/core/createCorePulumiApp.js.map +1 -0
- package/pulumi/apps/core/index.d.ts +8 -0
- package/pulumi/apps/core/index.js +10 -0
- package/pulumi/apps/core/index.js.map +1 -0
- package/pulumi/apps/core/webinyWatchCommand/handler.d.ts +28 -0
- package/pulumi/apps/core/webinyWatchCommand/handler.js +37 -0
- package/pulumi/apps/core/webinyWatchCommand/handler.js.map +1 -0
- package/pulumi/apps/createAppBucket.d.ts +17 -0
- package/pulumi/apps/createAppBucket.js +152 -0
- package/pulumi/apps/createAppBucket.js.map +1 -0
- package/pulumi/apps/customDomain.d.ts +9 -0
- package/pulumi/apps/customDomain.js +9 -0
- package/pulumi/apps/customDomain.js.map +1 -0
- package/pulumi/apps/extensions/getAwsTagsFromExtension.d.ts +2 -0
- package/pulumi/apps/extensions/getAwsTagsFromExtension.js +10 -0
- package/pulumi/apps/extensions/getAwsTagsFromExtension.js.map +1 -0
- package/pulumi/apps/extensions/getBgDeploymentsConfigFromExtension.d.ts +23 -0
- package/pulumi/apps/extensions/getBgDeploymentsConfigFromExtension.js +10 -0
- package/pulumi/apps/extensions/getBgDeploymentsConfigFromExtension.js.map +1 -0
- package/pulumi/apps/extensions/getOsConfigFromExtension.d.ts +7 -0
- package/pulumi/apps/extensions/getOsConfigFromExtension.js +33 -0
- package/pulumi/apps/extensions/getOsConfigFromExtension.js.map +1 -0
- package/pulumi/apps/extensions/getVpcConfigFromExtension.d.ts +15 -0
- package/pulumi/apps/extensions/getVpcConfigFromExtension.js +29 -0
- package/pulumi/apps/extensions/getVpcConfigFromExtension.js.map +1 -0
- package/pulumi/apps/index.d.ts +6 -0
- package/pulumi/apps/index.js +8 -0
- package/pulumi/apps/index.js.map +1 -0
- package/pulumi/apps/lambdaUtils.d.ts +11 -0
- package/pulumi/apps/lambdaUtils.js +70 -0
- package/pulumi/apps/lambdaUtils.js.map +1 -0
- package/pulumi/apps/react/createReactPulumiApp.d.ts +32 -0
- package/pulumi/apps/react/createReactPulumiApp.js +150 -0
- package/pulumi/apps/react/createReactPulumiApp.js.map +1 -0
- package/pulumi/apps/react/index.d.ts +1 -0
- package/pulumi/apps/react/index.js +3 -0
- package/pulumi/apps/react/index.js.map +1 -0
- package/pulumi/apps/syncSystem/SyncSystemDynamo.d.ts +5 -0
- package/pulumi/apps/syncSystem/SyncSystemDynamo.js +56 -0
- package/pulumi/apps/syncSystem/SyncSystemDynamo.js.map +1 -0
- package/pulumi/apps/syncSystem/SyncSystemDynamoDb.d.ts +3 -0
- package/pulumi/apps/syncSystem/SyncSystemDynamoDb.js +52 -0
- package/pulumi/apps/syncSystem/SyncSystemDynamoDb.js.map +1 -0
- package/pulumi/apps/syncSystem/SyncSystemEventBus.d.ts +6 -0
- package/pulumi/apps/syncSystem/SyncSystemEventBus.js +77 -0
- package/pulumi/apps/syncSystem/SyncSystemEventBus.js.map +1 -0
- package/pulumi/apps/syncSystem/SyncSystemLambda.d.ts +11 -0
- package/pulumi/apps/syncSystem/SyncSystemLambda.js +99 -0
- package/pulumi/apps/syncSystem/SyncSystemLambda.js.map +1 -0
- package/pulumi/apps/syncSystem/SyncSystemOutput.d.ts +3 -0
- package/pulumi/apps/syncSystem/SyncSystemOutput.js +18 -0
- package/pulumi/apps/syncSystem/SyncSystemOutput.js.map +1 -0
- package/pulumi/apps/syncSystem/SyncSystemResolverLambda.d.ts +8 -0
- package/pulumi/apps/syncSystem/SyncSystemResolverLambda.js +73 -0
- package/pulumi/apps/syncSystem/SyncSystemResolverLambda.js.map +1 -0
- package/pulumi/apps/syncSystem/SyncSystemSQS.d.ts +3 -0
- package/pulumi/apps/syncSystem/SyncSystemSQS.js +54 -0
- package/pulumi/apps/syncSystem/SyncSystemSQS.js.map +1 -0
- package/pulumi/apps/syncSystem/SyncSystemWorkerLambda.d.ts +7 -0
- package/pulumi/apps/syncSystem/SyncSystemWorkerLambda.js +52 -0
- package/pulumi/apps/syncSystem/SyncSystemWorkerLambda.js.map +1 -0
- package/pulumi/apps/syncSystem/addTableItems.d.ts +8 -0
- package/pulumi/apps/syncSystem/addTableItems.js +51 -0
- package/pulumi/apps/syncSystem/addTableItems.js.map +1 -0
- package/pulumi/apps/syncSystem/api/addServiceManifest.d.ts +8 -0
- package/pulumi/apps/syncSystem/api/addServiceManifest.js +18 -0
- package/pulumi/apps/syncSystem/api/addServiceManifest.js.map +1 -0
- package/pulumi/apps/syncSystem/api/attachCognitoPermissions.d.ts +14 -0
- package/pulumi/apps/syncSystem/api/attachCognitoPermissions.js +59 -0
- package/pulumi/apps/syncSystem/api/attachCognitoPermissions.js.map +1 -0
- package/pulumi/apps/syncSystem/api/attachDynamoDbPermissions.d.ts +13 -0
- package/pulumi/apps/syncSystem/api/attachDynamoDbPermissions.js +44 -0
- package/pulumi/apps/syncSystem/api/attachDynamoDbPermissions.js.map +1 -0
- package/pulumi/apps/syncSystem/api/attachEventBusPermissions.d.ts +17 -0
- package/pulumi/apps/syncSystem/api/attachEventBusPermissions.js +48 -0
- package/pulumi/apps/syncSystem/api/attachEventBusPermissions.js.map +1 -0
- package/pulumi/apps/syncSystem/api/attachS3Permissions.d.ts +14 -0
- package/pulumi/apps/syncSystem/api/attachS3Permissions.js +51 -0
- package/pulumi/apps/syncSystem/api/attachS3Permissions.js.map +1 -0
- package/pulumi/apps/syncSystem/api/index.d.ts +8 -0
- package/pulumi/apps/syncSystem/api/index.js +55 -0
- package/pulumi/apps/syncSystem/api/index.js.map +1 -0
- package/pulumi/apps/syncSystem/constants.d.ts +1 -0
- package/pulumi/apps/syncSystem/constants.js +3 -0
- package/pulumi/apps/syncSystem/constants.js.map +1 -0
- package/pulumi/apps/syncSystem/createSyncResourceName.d.ts +4 -0
- package/pulumi/apps/syncSystem/createSyncResourceName.js +10 -0
- package/pulumi/apps/syncSystem/createSyncResourceName.js.map +1 -0
- package/pulumi/apps/syncSystem/createSyncSystemPulumiApp.d.ts +26 -0
- package/pulumi/apps/syncSystem/createSyncSystemPulumiApp.js +181 -0
- package/pulumi/apps/syncSystem/createSyncSystemPulumiApp.js.map +1 -0
- package/pulumi/apps/syncSystem/customApp.d.ts +6 -0
- package/pulumi/apps/syncSystem/customApp.js +19 -0
- package/pulumi/apps/syncSystem/customApp.js.map +1 -0
- package/pulumi/apps/syncSystem/getSyncSystemOutput.d.ts +3 -0
- package/pulumi/apps/syncSystem/getSyncSystemOutput.js +10 -0
- package/pulumi/apps/syncSystem/getSyncSystemOutput.js.map +1 -0
- package/pulumi/apps/syncSystem/lambda/createSyncSystemResolverLambdaPolicy.d.ts +7 -0
- package/pulumi/apps/syncSystem/lambda/createSyncSystemResolverLambdaPolicy.js +48 -0
- package/pulumi/apps/syncSystem/lambda/createSyncSystemResolverLambdaPolicy.js.map +1 -0
- package/pulumi/apps/syncSystem/types.d.ts +56 -0
- package/pulumi/apps/syncSystem/types.js +3 -0
- package/pulumi/apps/syncSystem/types.js.map +1 -0
- package/pulumi/constants.d.ts +1 -0
- package/pulumi/constants.js +4 -0
- package/pulumi/constants.js.map +1 -0
- package/pulumi/env/awsRegion.d.ts +1 -0
- package/pulumi/env/awsRegion.js +6 -0
- package/pulumi/env/awsRegion.js.map +1 -0
- package/pulumi/env/base.d.ts +15 -0
- package/pulumi/env/base.js +29 -0
- package/pulumi/env/base.js.map +1 -0
- package/pulumi/env/env.d.ts +1 -0
- package/pulumi/env/env.js +6 -0
- package/pulumi/env/env.js.map +1 -0
- package/pulumi/env/projectName.d.ts +1 -0
- package/pulumi/env/projectName.js +6 -0
- package/pulumi/env/projectName.js.map +1 -0
- package/pulumi/env/variant.d.ts +1 -0
- package/pulumi/env/variant.js +7 -0
- package/pulumi/env/variant.js.map +1 -0
- package/pulumi/extensions/AdminCustomDomains.d.ts +14 -0
- package/pulumi/extensions/AdminCustomDomains.js +16 -0
- package/pulumi/extensions/AdminCustomDomains.js.map +1 -0
- package/pulumi/extensions/AwsTags.d.ts +8 -0
- package/pulumi/extensions/AwsTags.js +15 -0
- package/pulumi/extensions/AwsTags.js.map +1 -0
- package/pulumi/extensions/BlueGreenDeployments.d.ts +134 -0
- package/pulumi/extensions/BlueGreenDeployments.js +34 -0
- package/pulumi/extensions/BlueGreenDeployments.js.map +1 -0
- package/pulumi/extensions/OpenSearch.d.ts +17 -0
- package/pulumi/extensions/OpenSearch.js +17 -0
- package/pulumi/extensions/OpenSearch.js.map +1 -0
- package/pulumi/extensions/Vpc.d.ts +71 -0
- package/pulumi/extensions/Vpc.js +25 -0
- package/pulumi/extensions/Vpc.js.map +1 -0
- package/pulumi/extensions/index.d.ts +220 -0
- package/pulumi/extensions/index.js +13 -0
- package/pulumi/extensions/index.js.map +1 -0
- package/pulumi/index.d.ts +3 -0
- package/pulumi/index.js +5 -0
- package/pulumi/index.js.map +1 -0
- package/pulumi/types.d.ts +44 -0
- package/pulumi/types.js +3 -0
- package/pulumi/types.js.map +1 -0
- package/pulumi/utils/addDomainsUrlsOutputs.d.ts +18 -0
- package/pulumi/utils/addDomainsUrlsOutputs.js +40 -0
- package/pulumi/utils/addDomainsUrlsOutputs.js.map +1 -0
- package/pulumi/utils/addServiceManifestTableItem.d.ts +12 -0
- package/pulumi/utils/addServiceManifestTableItem.js +28 -0
- package/pulumi/utils/addServiceManifestTableItem.js.map +1 -0
- package/pulumi/utils/crawlDirectory.d.ts +1 -0
- package/pulumi/utils/crawlDirectory.js +19 -0
- package/pulumi/utils/crawlDirectory.js.map +1 -0
- package/pulumi/utils/createAssetArchive.d.ts +2 -0
- package/pulumi/utils/createAssetArchive.js +8 -0
- package/pulumi/utils/createAssetArchive.js.map +1 -0
- package/pulumi/utils/dynamodb.d.ts +14 -0
- package/pulumi/utils/dynamodb.js +29 -0
- package/pulumi/utils/dynamodb.js.map +1 -0
- package/pulumi/utils/getPresignedPost.d.ts +11 -0
- package/pulumi/utils/getPresignedPost.js +34 -0
- package/pulumi/utils/getPresignedPost.js.map +1 -0
- package/pulumi/utils/index.d.ts +5 -0
- package/pulumi/utils/index.js +7 -0
- package/pulumi/utils/index.js.map +1 -0
- package/pulumi/utils/lambdaEnvVariables.d.ts +20 -0
- package/pulumi/utils/lambdaEnvVariables.js +62 -0
- package/pulumi/utils/lambdaEnvVariables.js.map +1 -0
- package/pulumi/utils/tagResources.d.ts +5 -0
- package/pulumi/utils/tagResources.js +33 -0
- package/pulumi/utils/tagResources.js.map +1 -0
- package/pulumi/utils/uploadFolderToS3.d.ts +26 -0
- package/pulumi/utils/uploadFolderToS3.js +147 -0
- package/pulumi/utils/uploadFolderToS3.js.map +1 -0
- package/pulumi/utils/withServiceManifest.d.ts +14 -0
- package/pulumi/utils/withServiceManifest.js +45 -0
- package/pulumi/utils/withServiceManifest.js.map +1 -0
- package/services/AdminStackOutputService.d.ts +10 -0
- package/services/AdminStackOutputService.js +16 -0
- package/services/AdminStackOutputService.js.map +1 -0
- package/services/ApiStackOutputService.d.ts +10 -0
- package/services/ApiStackOutputService.js +16 -0
- package/services/ApiStackOutputService.js.map +1 -0
- package/services/CoreStackOutputService.d.ts +10 -0
- package/services/CoreStackOutputService.js +16 -0
- package/services/CoreStackOutputService.js.map +1 -0
- package/utils/getTemplatesFolderPath.d.ts +1 -0
- package/utils/getTemplatesFolderPath.js +16 -0
- package/utils/getTemplatesFolderPath.js.map +1 -0
- package/utils/index.d.ts +1 -0
- package/utils/index.js +3 -0
- package/utils/index.js.map +1 -0
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
import path from "path";
|
|
2
|
+
import * as aws from "@pulumi/aws";
|
|
3
|
+
import { createAppModule } from "@webiny/pulumi";
|
|
4
|
+
import { createLambdaRoleWithoutVpc } from "../lambdaUtils.js";
|
|
5
|
+
import { LAMBDA_RUNTIME } from "../../constants.js";
|
|
6
|
+
import { createSyncSystemResolverLambdaPolicy } from "./lambda/createSyncSystemResolverLambdaPolicy.js";
|
|
7
|
+
import { createSyncResourceName } from "./createSyncResourceName.js";
|
|
8
|
+
import { createAssetArchive } from "../../utils/createAssetArchive.js";
|
|
9
|
+
import { SyncSystemSQS } from "./SyncSystemSQS.js";
|
|
10
|
+
import { SyncSystemDynamoDb } from "./SyncSystemDynamoDb.js";
|
|
11
|
+
import { SyncSystemWorkerLambda } from "./SyncSystemWorkerLambda.js";
|
|
12
|
+
export const SyncSystemResolverLambda = createAppModule({
|
|
13
|
+
name: "SyncSystemResolverLambda",
|
|
14
|
+
config(app) {
|
|
15
|
+
const {
|
|
16
|
+
sqsQueue
|
|
17
|
+
} = app.getModule(SyncSystemSQS);
|
|
18
|
+
const dynamoDb = app.getModule(SyncSystemDynamoDb);
|
|
19
|
+
const {
|
|
20
|
+
lambda: workerLambda
|
|
21
|
+
} = app.getModule(SyncSystemWorkerLambda);
|
|
22
|
+
const roleName = createSyncResourceName("resolver-lambda-role");
|
|
23
|
+
const policy = createSyncSystemResolverLambdaPolicy({
|
|
24
|
+
name: `${roleName}-policy`,
|
|
25
|
+
app
|
|
26
|
+
});
|
|
27
|
+
const role = createLambdaRoleWithoutVpc(app, {
|
|
28
|
+
name: roleName,
|
|
29
|
+
policy: policy.output
|
|
30
|
+
});
|
|
31
|
+
const lambda = app.addResource(aws.lambda.Function, {
|
|
32
|
+
name: createSyncResourceName("resolver-lambda"),
|
|
33
|
+
config: {
|
|
34
|
+
runtime: LAMBDA_RUNTIME,
|
|
35
|
+
handler: "handler.handler",
|
|
36
|
+
role: role.output.arn,
|
|
37
|
+
timeout: 900,
|
|
38
|
+
memorySize: 512,
|
|
39
|
+
code: createAssetArchive(path.join(app.paths.workspace, "resolver/build")),
|
|
40
|
+
environment: {
|
|
41
|
+
variables: {
|
|
42
|
+
DB_TABLE: dynamoDb.output.name,
|
|
43
|
+
AWS_SYNC_WORKER_LAMBDA_ARN: workerLambda.output.arn,
|
|
44
|
+
DEBUG: String(process.env.DEBUG),
|
|
45
|
+
PULUMI_APPS: "true",
|
|
46
|
+
AWS_NODEJS_CONNECTION_REUSE_ENABLED: "1"
|
|
47
|
+
}
|
|
48
|
+
},
|
|
49
|
+
loggingConfig: {
|
|
50
|
+
logFormat: "JSON"
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
});
|
|
54
|
+
const eventSourceMapping = app.addResource(aws.lambda.EventSourceMapping, {
|
|
55
|
+
name: createSyncResourceName("sqs-to-resolver-lambda"),
|
|
56
|
+
config: {
|
|
57
|
+
enabled: true,
|
|
58
|
+
eventSourceArn: sqsQueue.output.arn,
|
|
59
|
+
functionName: lambda.output.arn,
|
|
60
|
+
batchSize: 1
|
|
61
|
+
// maximumBatchingWindowInSeconds: 2
|
|
62
|
+
}
|
|
63
|
+
});
|
|
64
|
+
return {
|
|
65
|
+
role,
|
|
66
|
+
policy,
|
|
67
|
+
lambda,
|
|
68
|
+
eventSourceMapping
|
|
69
|
+
};
|
|
70
|
+
}
|
|
71
|
+
});
|
|
72
|
+
|
|
73
|
+
//# sourceMappingURL=SyncSystemResolverLambda.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["path","aws","createAppModule","createLambdaRoleWithoutVpc","LAMBDA_RUNTIME","createSyncSystemResolverLambdaPolicy","createSyncResourceName","createAssetArchive","SyncSystemSQS","SyncSystemDynamoDb","SyncSystemWorkerLambda","SyncSystemResolverLambda","name","config","app","sqsQueue","getModule","dynamoDb","lambda","workerLambda","roleName","policy","role","output","addResource","Function","runtime","handler","arn","timeout","memorySize","code","join","paths","workspace","environment","variables","DB_TABLE","AWS_SYNC_WORKER_LAMBDA_ARN","DEBUG","String","process","env","PULUMI_APPS","AWS_NODEJS_CONNECTION_REUSE_ENABLED","loggingConfig","logFormat","eventSourceMapping","EventSourceMapping","enabled","eventSourceArn","functionName","batchSize"],"sources":["SyncSystemResolverLambda.ts"],"sourcesContent":["import path from \"path\";\nimport * as aws from \"@pulumi/aws\";\nimport type { PulumiApp, PulumiAppModule } from \"@webiny/pulumi\";\nimport { createAppModule } from \"@webiny/pulumi\";\nimport { createLambdaRoleWithoutVpc } from \"../lambdaUtils.js\";\nimport { LAMBDA_RUNTIME } from \"~/pulumi/constants.js\";\nimport { createSyncSystemResolverLambdaPolicy } from \"./lambda/createSyncSystemResolverLambdaPolicy.js\";\nimport { createSyncResourceName } from \"./createSyncResourceName.js\";\nimport { createAssetArchive } from \"~/pulumi/utils/createAssetArchive.js\";\nimport { SyncSystemSQS } from \"./SyncSystemSQS.js\";\nimport { SyncSystemDynamoDb } from \"~/pulumi/apps/syncSystem/SyncSystemDynamoDb.js\";\nimport { SyncSystemWorkerLambda } from \"~/pulumi/apps/syncSystem/SyncSystemWorkerLambda.js\";\n\nexport type SyncSystemResolverLambda = PulumiAppModule<typeof SyncSystemResolverLambda>;\n\nexport const SyncSystemResolverLambda = createAppModule({\n name: \"SyncSystemResolverLambda\",\n config(app: PulumiApp) {\n const { sqsQueue } = app.getModule(SyncSystemSQS);\n const dynamoDb = app.getModule(SyncSystemDynamoDb);\n\n const { lambda: workerLambda } = app.getModule(SyncSystemWorkerLambda);\n\n const roleName = createSyncResourceName(\"resolver-lambda-role\");\n const policy = createSyncSystemResolverLambdaPolicy({\n name: `${roleName}-policy`,\n app\n });\n const role = createLambdaRoleWithoutVpc(app, {\n name: roleName,\n policy: policy.output\n });\n\n const lambda = app.addResource(aws.lambda.Function, {\n name: createSyncResourceName(\"resolver-lambda\"),\n config: {\n runtime: LAMBDA_RUNTIME,\n handler: \"handler.handler\",\n role: role.output.arn,\n timeout: 900,\n memorySize: 512,\n code: createAssetArchive(path.join(app.paths.workspace, \"resolver/build\")),\n environment: {\n variables: {\n DB_TABLE: dynamoDb.output.name,\n AWS_SYNC_WORKER_LAMBDA_ARN: workerLambda.output.arn,\n DEBUG: String(process.env.DEBUG),\n PULUMI_APPS: \"true\",\n AWS_NODEJS_CONNECTION_REUSE_ENABLED: \"1\"\n }\n },\n loggingConfig: {\n logFormat: \"JSON\"\n }\n }\n });\n\n const eventSourceMapping = app.addResource(aws.lambda.EventSourceMapping, {\n name: createSyncResourceName(\"sqs-to-resolver-lambda\"),\n config: {\n enabled: true,\n eventSourceArn: sqsQueue.output.arn,\n functionName: lambda.output.arn,\n batchSize: 1\n // maximumBatchingWindowInSeconds: 2\n }\n });\n\n return {\n role,\n policy,\n lambda,\n eventSourceMapping\n };\n }\n});\n"],"mappings":"AAAA,OAAOA,IAAI,MAAM,MAAM;AACvB,OAAO,KAAKC,GAAG,MAAM,aAAa;AAElC,SAASC,eAAe,QAAQ,gBAAgB;AAChD,SAASC,0BAA0B;AACnC,SAASC,cAAc;AACvB,SAASC,oCAAoC;AAC7C,SAASC,sBAAsB;AAC/B,SAASC,kBAAkB;AAC3B,SAASC,aAAa;AACtB,SAASC,kBAAkB;AAC3B,SAASC,sBAAsB;AAI/B,OAAO,MAAMC,wBAAwB,GAAGT,eAAe,CAAC;EACpDU,IAAI,EAAE,0BAA0B;EAChCC,MAAMA,CAACC,GAAc,EAAE;IACnB,MAAM;MAAEC;IAAS,CAAC,GAAGD,GAAG,CAACE,SAAS,CAACR,aAAa,CAAC;IACjD,MAAMS,QAAQ,GAAGH,GAAG,CAACE,SAAS,CAACP,kBAAkB,CAAC;IAElD,MAAM;MAAES,MAAM,EAAEC;IAAa,CAAC,GAAGL,GAAG,CAACE,SAAS,CAACN,sBAAsB,CAAC;IAEtE,MAAMU,QAAQ,GAAGd,sBAAsB,CAAC,sBAAsB,CAAC;IAC/D,MAAMe,MAAM,GAAGhB,oCAAoC,CAAC;MAChDO,IAAI,EAAE,GAAGQ,QAAQ,SAAS;MAC1BN;IACJ,CAAC,CAAC;IACF,MAAMQ,IAAI,GAAGnB,0BAA0B,CAACW,GAAG,EAAE;MACzCF,IAAI,EAAEQ,QAAQ;MACdC,MAAM,EAAEA,MAAM,CAACE;IACnB,CAAC,CAAC;IAEF,MAAML,MAAM,GAAGJ,GAAG,CAACU,WAAW,CAACvB,GAAG,CAACiB,MAAM,CAACO,QAAQ,EAAE;MAChDb,IAAI,EAAEN,sBAAsB,CAAC,iBAAiB,CAAC;MAC/CO,MAAM,EAAE;QACJa,OAAO,EAAEtB,cAAc;QACvBuB,OAAO,EAAE,iBAAiB;QAC1BL,IAAI,EAAEA,IAAI,CAACC,MAAM,CAACK,GAAG;QACrBC,OAAO,EAAE,GAAG;QACZC,UAAU,EAAE,GAAG;QACfC,IAAI,EAAExB,kBAAkB,CAACP,IAAI,CAACgC,IAAI,CAAClB,GAAG,CAACmB,KAAK,CAACC,SAAS,EAAE,gBAAgB,CAAC,CAAC;QAC1EC,WAAW,EAAE;UACTC,SAAS,EAAE;YACPC,QAAQ,EAAEpB,QAAQ,CAACM,MAAM,CAACX,IAAI;YAC9B0B,0BAA0B,EAAEnB,YAAY,CAACI,MAAM,CAACK,GAAG;YACnDW,KAAK,EAAEC,MAAM,CAACC,OAAO,CAACC,GAAG,CAACH,KAAK,CAAC;YAChCI,WAAW,EAAE,MAAM;YACnBC,mCAAmC,EAAE;UACzC;QACJ,CAAC;QACDC,aAAa,EAAE;UACXC,SAAS,EAAE;QACf;MACJ;IACJ,CAAC,CAAC;IAEF,MAAMC,kBAAkB,GAAGjC,GAAG,CAACU,WAAW,CAACvB,GAAG,CAACiB,MAAM,CAAC8B,kBAAkB,EAAE;MACtEpC,IAAI,EAAEN,sBAAsB,CAAC,wBAAwB,CAAC;MACtDO,MAAM,EAAE;QACJoC,OAAO,EAAE,IAAI;QACbC,cAAc,EAAEnC,QAAQ,CAACQ,MAAM,CAACK,GAAG;QACnCuB,YAAY,EAAEjC,MAAM,CAACK,MAAM,CAACK,GAAG;QAC/BwB,SAAS,EAAE;QACX;MACJ;IACJ,CAAC,CAAC;IAEF,OAAO;MACH9B,IAAI;MACJD,MAAM;MACNH,MAAM;MACN6B;IACJ,CAAC;EACL;AACJ,CAAC,CAAC","ignoreList":[]}
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
import * as aws from "@pulumi/aws";
|
|
2
|
+
import { createAppModule } from "@webiny/pulumi";
|
|
3
|
+
import { createSyncResourceName } from "./createSyncResourceName.js";
|
|
4
|
+
export const SyncSystemSQS = createAppModule({
|
|
5
|
+
name: "SyncSystemSQS",
|
|
6
|
+
config: app => {
|
|
7
|
+
const config = {
|
|
8
|
+
/**
|
|
9
|
+
* We must name the SQS queue with a ".fifo" suffix to enable FIFO functionality.
|
|
10
|
+
* If we add .fifo to a resource name, it will fail because pulumi adds some random generated id + .fifo to the end of the name.
|
|
11
|
+
* ... and there cannot be two .fifo in the name.
|
|
12
|
+
*/
|
|
13
|
+
name: `${createSyncResourceName("sqs")}.fifo`,
|
|
14
|
+
delaySeconds: 0,
|
|
15
|
+
/**
|
|
16
|
+
* 5 minutes should be enough for the message to be processed.
|
|
17
|
+
*/
|
|
18
|
+
visibilityTimeoutSeconds: 900,
|
|
19
|
+
fifoQueue: true,
|
|
20
|
+
receiveWaitTimeSeconds: 0,
|
|
21
|
+
deduplicationScope: "queue",
|
|
22
|
+
/**
|
|
23
|
+
* The maximum message size is 256 KB.
|
|
24
|
+
* Chunks are billed in 64KB increments, so let's keep the message size below that.
|
|
25
|
+
*/
|
|
26
|
+
maxMessageSize: 60 * 1024,
|
|
27
|
+
// KB
|
|
28
|
+
/**
|
|
29
|
+
* How log do we keep the message in the queue?
|
|
30
|
+
*/
|
|
31
|
+
messageRetentionSeconds: 4 /* days */ * 24 * 60 * 60,
|
|
32
|
+
/**
|
|
33
|
+
* No need to encrypt the message as nothing outside the system can actually read it.
|
|
34
|
+
*/
|
|
35
|
+
sqsManagedSseEnabled: false,
|
|
36
|
+
/**
|
|
37
|
+
* We want to make sure that no message is sent more than once.
|
|
38
|
+
*
|
|
39
|
+
* TODO: determine if the criteria by which will we create a hash for the ID.
|
|
40
|
+
* TODO: must set "MessageDeduplicationId" property when creating the message.
|
|
41
|
+
*/
|
|
42
|
+
contentBasedDeduplication: true
|
|
43
|
+
};
|
|
44
|
+
const sqsQueue = app.addResource(aws.sqs.Queue, {
|
|
45
|
+
name: `${createSyncResourceName("sqs")}`,
|
|
46
|
+
config
|
|
47
|
+
});
|
|
48
|
+
return {
|
|
49
|
+
sqsQueue
|
|
50
|
+
};
|
|
51
|
+
}
|
|
52
|
+
});
|
|
53
|
+
|
|
54
|
+
//# sourceMappingURL=SyncSystemSQS.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["aws","createAppModule","createSyncResourceName","SyncSystemSQS","name","config","app","delaySeconds","visibilityTimeoutSeconds","fifoQueue","receiveWaitTimeSeconds","deduplicationScope","maxMessageSize","messageRetentionSeconds","sqsManagedSseEnabled","contentBasedDeduplication","sqsQueue","addResource","sqs","Queue"],"sources":["SyncSystemSQS.ts"],"sourcesContent":["import * as aws from \"@pulumi/aws\";\nimport type { QueueArgs } from \"@pulumi/aws/sqs/index.js\";\nimport type { PulumiApp } from \"@webiny/pulumi\";\nimport { createAppModule } from \"@webiny/pulumi\";\nimport { createSyncResourceName } from \"./createSyncResourceName.js\";\n\nexport const SyncSystemSQS = createAppModule({\n name: \"SyncSystemSQS\",\n config: (app: PulumiApp) => {\n const config: QueueArgs = {\n /**\n * We must name the SQS queue with a \".fifo\" suffix to enable FIFO functionality.\n * If we add .fifo to a resource name, it will fail because pulumi adds some random generated id + .fifo to the end of the name.\n * ... and there cannot be two .fifo in the name.\n */\n name: `${createSyncResourceName(\"sqs\")}.fifo`,\n delaySeconds: 0,\n /**\n * 5 minutes should be enough for the message to be processed.\n */\n visibilityTimeoutSeconds: 900,\n fifoQueue: true,\n receiveWaitTimeSeconds: 0,\n deduplicationScope: \"queue\",\n /**\n * The maximum message size is 256 KB.\n * Chunks are billed in 64KB increments, so let's keep the message size below that.\n */\n maxMessageSize: 60 * 1024, // KB\n /**\n * How log do we keep the message in the queue?\n */\n messageRetentionSeconds: 4 /* days */ * 24 * 60 * 60,\n /**\n * No need to encrypt the message as nothing outside the system can actually read it.\n */\n sqsManagedSseEnabled: false,\n /**\n * We want to make sure that no message is sent more than once.\n *\n * TODO: determine if the criteria by which will we create a hash for the ID.\n * TODO: must set \"MessageDeduplicationId\" property when creating the message.\n */\n contentBasedDeduplication: true\n };\n\n const sqsQueue = app.addResource(aws.sqs.Queue, {\n name: `${createSyncResourceName(\"sqs\")}`,\n config\n });\n\n return {\n sqsQueue\n };\n }\n});\n"],"mappings":"AAAA,OAAO,KAAKA,GAAG,MAAM,aAAa;AAGlC,SAASC,eAAe,QAAQ,gBAAgB;AAChD,SAASC,sBAAsB;AAE/B,OAAO,MAAMC,aAAa,GAAGF,eAAe,CAAC;EACzCG,IAAI,EAAE,eAAe;EACrBC,MAAM,EAAGC,GAAc,IAAK;IACxB,MAAMD,MAAiB,GAAG;MACtB;AACZ;AACA;AACA;AACA;MACYD,IAAI,EAAE,GAAGF,sBAAsB,CAAC,KAAK,CAAC,OAAO;MAC7CK,YAAY,EAAE,CAAC;MACf;AACZ;AACA;MACYC,wBAAwB,EAAE,GAAG;MAC7BC,SAAS,EAAE,IAAI;MACfC,sBAAsB,EAAE,CAAC;MACzBC,kBAAkB,EAAE,OAAO;MAC3B;AACZ;AACA;AACA;MACYC,cAAc,EAAE,EAAE,GAAG,IAAI;MAAE;MAC3B;AACZ;AACA;MACYC,uBAAuB,EAAE,CAAC,CAAC,aAAa,EAAE,GAAG,EAAE,GAAG,EAAE;MACpD;AACZ;AACA;MACYC,oBAAoB,EAAE,KAAK;MAC3B;AACZ;AACA;AACA;AACA;AACA;MACYC,yBAAyB,EAAE;IAC/B,CAAC;IAED,MAAMC,QAAQ,GAAGV,GAAG,CAACW,WAAW,CAACjB,GAAG,CAACkB,GAAG,CAACC,KAAK,EAAE;MAC5Cf,IAAI,EAAE,GAAGF,sBAAsB,CAAC,KAAK,CAAC,EAAE;MACxCG;IACJ,CAAC,CAAC;IAEF,OAAO;MACHW;IACJ,CAAC;EACL;AACJ,CAAC,CAAC","ignoreList":[]}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import type { PulumiAppModule } from "@webiny/pulumi";
|
|
2
|
+
export type SyncSystemWorkerLambda = PulumiAppModule<typeof SyncSystemWorkerLambda>;
|
|
3
|
+
export declare const SyncSystemWorkerLambda: import("@webiny/pulumi").PulumiAppModuleDefinition<{
|
|
4
|
+
role: import("@webiny/pulumi").PulumiAppResource<typeof import("@pulumi/aws/iam/role.js").Role>;
|
|
5
|
+
policy: import("@webiny/pulumi").PulumiAppResource<typeof import("@pulumi/aws/iam/rolePolicyAttachment.js").RolePolicyAttachment>;
|
|
6
|
+
lambda: import("@webiny/pulumi").PulumiAppResource<typeof import("@pulumi/aws/lambda/function.js").Function>;
|
|
7
|
+
}, void>;
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
import path from "path";
|
|
2
|
+
import * as aws from "@pulumi/aws";
|
|
3
|
+
import { createAppModule } from "@webiny/pulumi";
|
|
4
|
+
import { LAMBDA_RUNTIME } from "../../constants.js";
|
|
5
|
+
import { createSyncResourceName } from "./createSyncResourceName.js";
|
|
6
|
+
import { createAssetArchive } from "../../utils/createAssetArchive.js";
|
|
7
|
+
import { createLambdaRoleWithoutVpc } from "../lambdaUtils.js";
|
|
8
|
+
export const SyncSystemWorkerLambda = createAppModule({
|
|
9
|
+
name: "SyncSystemWorkerLambda",
|
|
10
|
+
config(app) {
|
|
11
|
+
const lambdaName = createSyncResourceName("worker-lambda");
|
|
12
|
+
const roleName = `${lambdaName}-role`;
|
|
13
|
+
const role = createLambdaRoleWithoutVpc(app, {
|
|
14
|
+
name: roleName
|
|
15
|
+
});
|
|
16
|
+
const policy = app.addResource(aws.iam.RolePolicyAttachment, {
|
|
17
|
+
name: `${roleName}-policy-attachment`,
|
|
18
|
+
config: {
|
|
19
|
+
role: role.output.name,
|
|
20
|
+
policyArn: aws.iam.ManagedPolicy.AWSLambdaBasicExecutionRole
|
|
21
|
+
}
|
|
22
|
+
});
|
|
23
|
+
const lambda = app.addResource(aws.lambda.Function, {
|
|
24
|
+
name: lambdaName,
|
|
25
|
+
config: {
|
|
26
|
+
runtime: LAMBDA_RUNTIME,
|
|
27
|
+
handler: "handler.handler",
|
|
28
|
+
role: role.output.arn,
|
|
29
|
+
timeout: 900,
|
|
30
|
+
memorySize: 512,
|
|
31
|
+
code: createAssetArchive(path.join(app.paths.workspace, "worker/build")),
|
|
32
|
+
environment: {
|
|
33
|
+
variables: {
|
|
34
|
+
DEBUG: String(process.env.DEBUG),
|
|
35
|
+
PULUMI_APPS: "true",
|
|
36
|
+
AWS_NODEJS_CONNECTION_REUSE_ENABLED: "1"
|
|
37
|
+
}
|
|
38
|
+
},
|
|
39
|
+
loggingConfig: {
|
|
40
|
+
logFormat: "JSON"
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
});
|
|
44
|
+
return {
|
|
45
|
+
role,
|
|
46
|
+
policy,
|
|
47
|
+
lambda
|
|
48
|
+
};
|
|
49
|
+
}
|
|
50
|
+
});
|
|
51
|
+
|
|
52
|
+
//# sourceMappingURL=SyncSystemWorkerLambda.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["path","aws","createAppModule","LAMBDA_RUNTIME","createSyncResourceName","createAssetArchive","createLambdaRoleWithoutVpc","SyncSystemWorkerLambda","name","config","app","lambdaName","roleName","role","policy","addResource","iam","RolePolicyAttachment","output","policyArn","ManagedPolicy","AWSLambdaBasicExecutionRole","lambda","Function","runtime","handler","arn","timeout","memorySize","code","join","paths","workspace","environment","variables","DEBUG","String","process","env","PULUMI_APPS","AWS_NODEJS_CONNECTION_REUSE_ENABLED","loggingConfig","logFormat"],"sources":["SyncSystemWorkerLambda.ts"],"sourcesContent":["import path from \"path\";\nimport * as aws from \"@pulumi/aws\";\nimport type { PulumiApp, PulumiAppModule } from \"@webiny/pulumi\";\nimport { createAppModule } from \"@webiny/pulumi\";\nimport { LAMBDA_RUNTIME } from \"~/pulumi/constants.js\";\nimport { createSyncResourceName } from \"./createSyncResourceName.js\";\nimport { createAssetArchive } from \"~/pulumi/utils/createAssetArchive.js\";\nimport { createLambdaRoleWithoutVpc } from \"~/pulumi/apps/lambdaUtils.js\";\n\nexport type SyncSystemWorkerLambda = PulumiAppModule<typeof SyncSystemWorkerLambda>;\n\nexport const SyncSystemWorkerLambda = createAppModule({\n name: \"SyncSystemWorkerLambda\",\n config(app: PulumiApp) {\n const lambdaName = createSyncResourceName(\"worker-lambda\");\n const roleName = `${lambdaName}-role`;\n\n const role = createLambdaRoleWithoutVpc(app, {\n name: roleName\n });\n\n const policy = app.addResource(aws.iam.RolePolicyAttachment, {\n name: `${roleName}-policy-attachment`,\n config: {\n role: role.output.name,\n policyArn: aws.iam.ManagedPolicy.AWSLambdaBasicExecutionRole\n }\n });\n\n const lambda = app.addResource(aws.lambda.Function, {\n name: lambdaName,\n config: {\n runtime: LAMBDA_RUNTIME,\n handler: \"handler.handler\",\n role: role.output.arn,\n timeout: 900,\n memorySize: 512,\n code: createAssetArchive(path.join(app.paths.workspace, \"worker/build\")),\n environment: {\n variables: {\n DEBUG: String(process.env.DEBUG),\n PULUMI_APPS: \"true\",\n AWS_NODEJS_CONNECTION_REUSE_ENABLED: \"1\"\n }\n },\n loggingConfig: {\n logFormat: \"JSON\"\n }\n }\n });\n\n return {\n role,\n policy,\n lambda\n };\n }\n});\n"],"mappings":"AAAA,OAAOA,IAAI,MAAM,MAAM;AACvB,OAAO,KAAKC,GAAG,MAAM,aAAa;AAElC,SAASC,eAAe,QAAQ,gBAAgB;AAChD,SAASC,cAAc;AACvB,SAASC,sBAAsB;AAC/B,SAASC,kBAAkB;AAC3B,SAASC,0BAA0B;AAInC,OAAO,MAAMC,sBAAsB,GAAGL,eAAe,CAAC;EAClDM,IAAI,EAAE,wBAAwB;EAC9BC,MAAMA,CAACC,GAAc,EAAE;IACnB,MAAMC,UAAU,GAAGP,sBAAsB,CAAC,eAAe,CAAC;IAC1D,MAAMQ,QAAQ,GAAG,GAAGD,UAAU,OAAO;IAErC,MAAME,IAAI,GAAGP,0BAA0B,CAACI,GAAG,EAAE;MACzCF,IAAI,EAAEI;IACV,CAAC,CAAC;IAEF,MAAME,MAAM,GAAGJ,GAAG,CAACK,WAAW,CAACd,GAAG,CAACe,GAAG,CAACC,oBAAoB,EAAE;MACzDT,IAAI,EAAE,GAAGI,QAAQ,oBAAoB;MACrCH,MAAM,EAAE;QACJI,IAAI,EAAEA,IAAI,CAACK,MAAM,CAACV,IAAI;QACtBW,SAAS,EAAElB,GAAG,CAACe,GAAG,CAACI,aAAa,CAACC;MACrC;IACJ,CAAC,CAAC;IAEF,MAAMC,MAAM,GAAGZ,GAAG,CAACK,WAAW,CAACd,GAAG,CAACqB,MAAM,CAACC,QAAQ,EAAE;MAChDf,IAAI,EAAEG,UAAU;MAChBF,MAAM,EAAE;QACJe,OAAO,EAAErB,cAAc;QACvBsB,OAAO,EAAE,iBAAiB;QAC1BZ,IAAI,EAAEA,IAAI,CAACK,MAAM,CAACQ,GAAG;QACrBC,OAAO,EAAE,GAAG;QACZC,UAAU,EAAE,GAAG;QACfC,IAAI,EAAExB,kBAAkB,CAACL,IAAI,CAAC8B,IAAI,CAACpB,GAAG,CAACqB,KAAK,CAACC,SAAS,EAAE,cAAc,CAAC,CAAC;QACxEC,WAAW,EAAE;UACTC,SAAS,EAAE;YACPC,KAAK,EAAEC,MAAM,CAACC,OAAO,CAACC,GAAG,CAACH,KAAK,CAAC;YAChCI,WAAW,EAAE,MAAM;YACnBC,mCAAmC,EAAE;UACzC;QACJ,CAAC;QACDC,aAAa,EAAE;UACXC,SAAS,EAAE;QACf;MACJ;IACJ,CAAC,CAAC;IAEF,OAAO;MACH7B,IAAI;MACJC,MAAM;MACNQ;IACJ,CAAC;EACL;AACJ,CAAC,CAAC","ignoreList":[]}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import type { PulumiApp } from "@webiny/pulumi";
|
|
2
|
+
import type { SyncSystemDynamo } from "./SyncSystemDynamo.js";
|
|
3
|
+
export interface IAddTableItemsParams {
|
|
4
|
+
app: PulumiApp;
|
|
5
|
+
table: SyncSystemDynamo;
|
|
6
|
+
items: Record<string, string | number | Record<string, string>>;
|
|
7
|
+
}
|
|
8
|
+
export declare const addTableItems: (params: IAddTableItemsParams) => void;
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import * as aws from "@pulumi/aws";
|
|
2
|
+
import * as pulumi from "@pulumi/pulumi";
|
|
3
|
+
export const addTableItems = params => {
|
|
4
|
+
const {
|
|
5
|
+
app,
|
|
6
|
+
table,
|
|
7
|
+
items
|
|
8
|
+
} = params;
|
|
9
|
+
/**
|
|
10
|
+
* Store some settings in the table.
|
|
11
|
+
*/
|
|
12
|
+
app.addResource(aws.dynamodb.TableItem, {
|
|
13
|
+
name: "syncSystemSettings",
|
|
14
|
+
config: {
|
|
15
|
+
tableName: table.output.arn,
|
|
16
|
+
hashKey: table.output.hashKey,
|
|
17
|
+
rangeKey: pulumi.output(table.output.rangeKey).apply(key => key || "SK"),
|
|
18
|
+
item: pulumi.interpolate`{
|
|
19
|
+
${buildTableItems({
|
|
20
|
+
PK: "syncSystem#SETTINGS",
|
|
21
|
+
SK: "default",
|
|
22
|
+
...items
|
|
23
|
+
})}
|
|
24
|
+
}`
|
|
25
|
+
}
|
|
26
|
+
});
|
|
27
|
+
};
|
|
28
|
+
const getTableItemType = value => {
|
|
29
|
+
if (value === null || value === undefined) {
|
|
30
|
+
return "S";
|
|
31
|
+
}
|
|
32
|
+
switch (typeof value) {
|
|
33
|
+
case "string":
|
|
34
|
+
return "S";
|
|
35
|
+
case "number":
|
|
36
|
+
return "N";
|
|
37
|
+
case "object":
|
|
38
|
+
return "M";
|
|
39
|
+
default:
|
|
40
|
+
throw new Error(`Unsupported type: ${typeof value}`);
|
|
41
|
+
}
|
|
42
|
+
};
|
|
43
|
+
const buildTableItems = items => {
|
|
44
|
+
return Object.keys(items).reduce((output, key) => {
|
|
45
|
+
const value = items[key];
|
|
46
|
+
output.push(`"${key}": {"${getTableItemType(value)}": "${value}"}`);
|
|
47
|
+
return output;
|
|
48
|
+
}, []).join(",");
|
|
49
|
+
};
|
|
50
|
+
|
|
51
|
+
//# sourceMappingURL=addTableItems.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["aws","pulumi","addTableItems","params","app","table","items","addResource","dynamodb","TableItem","name","config","tableName","output","arn","hashKey","rangeKey","apply","key","item","interpolate","buildTableItems","PK","SK","getTableItemType","value","undefined","Error","Object","keys","reduce","push","join"],"sources":["addTableItems.ts"],"sourcesContent":["import * as aws from \"@pulumi/aws\";\nimport * as pulumi from \"@pulumi/pulumi\";\nimport type { PulumiApp } from \"@webiny/pulumi\";\nimport type { SyncSystemDynamo } from \"./SyncSystemDynamo.js\";\n\nexport interface IAddTableItemsParams {\n app: PulumiApp;\n table: SyncSystemDynamo;\n items: Record<string, string | number | Record<string, string>>;\n}\n\nexport const addTableItems = (params: IAddTableItemsParams): void => {\n const { app, table, items } = params;\n /**\n * Store some settings in the table.\n */\n app.addResource(aws.dynamodb.TableItem, {\n name: \"syncSystemSettings\",\n config: {\n tableName: table.output.arn,\n hashKey: table.output.hashKey,\n rangeKey: pulumi.output(table.output.rangeKey).apply(key => key || \"SK\"),\n item: pulumi.interpolate`{\n ${buildTableItems({\n PK: \"syncSystem#SETTINGS\",\n SK: \"default\",\n ...items\n })}\n }`\n }\n });\n};\n\nconst getTableItemType = (value: unknown) => {\n if (value === null || value === undefined) {\n return \"S\";\n }\n switch (typeof value) {\n case \"string\":\n return \"S\";\n case \"number\":\n return \"N\";\n case \"object\":\n return \"M\";\n default:\n throw new Error(`Unsupported type: ${typeof value}`);\n }\n};\n\nconst buildTableItems = (\n items: Record<string, string | number | Record<string, string>>\n): string => {\n return Object.keys(items)\n .reduce<string[]>((output, key) => {\n const value = items[key];\n output.push(`\"${key}\": {\"${getTableItemType(value)}\": \"${value}\"}`);\n return output;\n }, [])\n .join(\",\");\n};\n"],"mappings":"AAAA,OAAO,KAAKA,GAAG,MAAM,aAAa;AAClC,OAAO,KAAKC,MAAM,MAAM,gBAAgB;AAUxC,OAAO,MAAMC,aAAa,GAAIC,MAA4B,IAAW;EACjE,MAAM;IAAEC,GAAG;IAAEC,KAAK;IAAEC;EAAM,CAAC,GAAGH,MAAM;EACpC;AACJ;AACA;EACIC,GAAG,CAACG,WAAW,CAACP,GAAG,CAACQ,QAAQ,CAACC,SAAS,EAAE;IACpCC,IAAI,EAAE,oBAAoB;IAC1BC,MAAM,EAAE;MACJC,SAAS,EAAEP,KAAK,CAACQ,MAAM,CAACC,GAAG;MAC3BC,OAAO,EAAEV,KAAK,CAACQ,MAAM,CAACE,OAAO;MAC7BC,QAAQ,EAAEf,MAAM,CAACY,MAAM,CAACR,KAAK,CAACQ,MAAM,CAACG,QAAQ,CAAC,CAACC,KAAK,CAACC,GAAG,IAAIA,GAAG,IAAI,IAAI,CAAC;MACxEC,IAAI,EAAElB,MAAM,CAACmB,WAAW;AACpC,gBAAgBC,eAAe,CAAC;QACdC,EAAE,EAAE,qBAAqB;QACzBC,EAAE,EAAE,SAAS;QACb,GAAGjB;MACP,CAAC,CAAC;AAChB;IACQ;EACJ,CAAC,CAAC;AACN,CAAC;AAED,MAAMkB,gBAAgB,GAAIC,KAAc,IAAK;EACzC,IAAIA,KAAK,KAAK,IAAI,IAAIA,KAAK,KAAKC,SAAS,EAAE;IACvC,OAAO,GAAG;EACd;EACA,QAAQ,OAAOD,KAAK;IAChB,KAAK,QAAQ;MACT,OAAO,GAAG;IACd,KAAK,QAAQ;MACT,OAAO,GAAG;IACd,KAAK,QAAQ;MACT,OAAO,GAAG;IACd;MACI,MAAM,IAAIE,KAAK,CAAC,qBAAqB,OAAOF,KAAK,EAAE,CAAC;EAC5D;AACJ,CAAC;AAED,MAAMJ,eAAe,GACjBf,KAA+D,IACtD;EACT,OAAOsB,MAAM,CAACC,IAAI,CAACvB,KAAK,CAAC,CACpBwB,MAAM,CAAW,CAACjB,MAAM,EAAEK,GAAG,KAAK;IAC/B,MAAMO,KAAK,GAAGnB,KAAK,CAACY,GAAG,CAAC;IACxBL,MAAM,CAACkB,IAAI,CAAC,IAAIb,GAAG,QAAQM,gBAAgB,CAACC,KAAK,CAAC,OAAOA,KAAK,IAAI,CAAC;IACnE,OAAOZ,MAAM;EACjB,CAAC,EAAE,EAAE,CAAC,CACLmB,IAAI,CAAC,GAAG,CAAC;AAClB,CAAC","ignoreList":[]}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import type { PulumiApp } from "@webiny/pulumi";
|
|
2
|
+
import type { IGetSyncSystemOutputResult } from "../../../../pulumi/apps/syncSystem/types.js";
|
|
3
|
+
import type { WithServiceManifest } from "../../../../pulumi/utils/withServiceManifest.js";
|
|
4
|
+
export interface IAddServiceManifestParams {
|
|
5
|
+
app: PulumiApp & WithServiceManifest;
|
|
6
|
+
syncSystem: IGetSyncSystemOutputResult;
|
|
7
|
+
}
|
|
8
|
+
export declare const addServiceManifest: (params: IAddServiceManifestParams) => void;
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
export const addServiceManifest = params => {
|
|
2
|
+
const {
|
|
3
|
+
app,
|
|
4
|
+
syncSystem
|
|
5
|
+
} = params;
|
|
6
|
+
app.addHandler(() => {
|
|
7
|
+
app.addServiceManifest({
|
|
8
|
+
name: "sync",
|
|
9
|
+
manifest: {
|
|
10
|
+
eventBusArn: syncSystem.eventBusArn,
|
|
11
|
+
eventBusName: syncSystem.eventBusName,
|
|
12
|
+
region: syncSystem.region
|
|
13
|
+
}
|
|
14
|
+
});
|
|
15
|
+
});
|
|
16
|
+
};
|
|
17
|
+
|
|
18
|
+
//# sourceMappingURL=addServiceManifest.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["addServiceManifest","params","app","syncSystem","addHandler","name","manifest","eventBusArn","eventBusName","region"],"sources":["addServiceManifest.ts"],"sourcesContent":["import type { PulumiApp } from \"@webiny/pulumi\";\nimport type { IGetSyncSystemOutputResult } from \"~/pulumi/apps/syncSystem/types.js\";\nimport type { WithServiceManifest } from \"~/pulumi/utils/withServiceManifest.js\";\n\nexport interface IAddServiceManifestParams {\n app: PulumiApp & WithServiceManifest;\n syncSystem: IGetSyncSystemOutputResult;\n}\n\nexport const addServiceManifest = (params: IAddServiceManifestParams) => {\n const { app, syncSystem } = params;\n\n app.addHandler(() => {\n app.addServiceManifest({\n name: \"sync\",\n manifest: {\n eventBusArn: syncSystem.eventBusArn,\n eventBusName: syncSystem.eventBusName,\n region: syncSystem.region\n }\n });\n });\n};\n"],"mappings":"AASA,OAAO,MAAMA,kBAAkB,GAAIC,MAAiC,IAAK;EACrE,MAAM;IAAEC,GAAG;IAAEC;EAAW,CAAC,GAAGF,MAAM;EAElCC,GAAG,CAACE,UAAU,CAAC,MAAM;IACjBF,GAAG,CAACF,kBAAkB,CAAC;MACnBK,IAAI,EAAE,MAAM;MACZC,QAAQ,EAAE;QACNC,WAAW,EAAEJ,UAAU,CAACI,WAAW;QACnCC,YAAY,EAAEL,UAAU,CAACK,YAAY;QACrCC,MAAM,EAAEN,UAAU,CAACM;MACvB;IACJ,CAAC,CAAC;EACN,CAAC,CAAC;AACN,CAAC","ignoreList":[]}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import type { PulumiApp } from "@webiny/pulumi";
|
|
2
|
+
import type { WithServiceManifest } from "../../../../pulumi/utils/withServiceManifest.js";
|
|
3
|
+
import type { IGetSyncSystemOutputResult } from "../../../../pulumi/apps/syncSystem/types.js";
|
|
4
|
+
import type { CoreOutput } from "../../../../apps/index.js";
|
|
5
|
+
export interface IAttachCognitoPermissionsParams {
|
|
6
|
+
app: PulumiApp & WithServiceManifest;
|
|
7
|
+
syncSystem: IGetSyncSystemOutputResult;
|
|
8
|
+
core: CoreOutput;
|
|
9
|
+
}
|
|
10
|
+
export declare const attachCognitoPermissions: (params: IAttachCognitoPermissionsParams) => {
|
|
11
|
+
cognitoPolicy: import("@webiny/pulumi").PulumiAppResource<typeof import("@pulumi/aws/iam/policy").Policy>;
|
|
12
|
+
workerLambdaS3PolicyAttachment: import("@webiny/pulumi").PulumiAppResource<typeof import("@pulumi/aws/iam/rolePolicyAttachment").RolePolicyAttachment>;
|
|
13
|
+
resolverLambdaS3PolicyAttachment: import("@webiny/pulumi").PulumiAppResource<typeof import("@pulumi/aws/iam/rolePolicyAttachment").RolePolicyAttachment>;
|
|
14
|
+
} | null;
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
import * as aws from "@pulumi/aws";
|
|
2
|
+
import { createSyncResourceName } from "../createSyncResourceName.js";
|
|
3
|
+
export const attachCognitoPermissions = params => {
|
|
4
|
+
const {
|
|
5
|
+
app,
|
|
6
|
+
syncSystem,
|
|
7
|
+
core
|
|
8
|
+
} = params;
|
|
9
|
+
/**
|
|
10
|
+
* TODO there must be a way to skip this if Cognito is not used in the Webiny deployment.
|
|
11
|
+
*/
|
|
12
|
+
if (!core.cognitoUserPoolArn) {
|
|
13
|
+
return null;
|
|
14
|
+
}
|
|
15
|
+
const {
|
|
16
|
+
resolverLambdaRoleName,
|
|
17
|
+
workerLambdaRoleName
|
|
18
|
+
} = syncSystem;
|
|
19
|
+
const resolverLambdaToS3ResourceName = createSyncResourceName(`resolver-lambda-to-cognito`);
|
|
20
|
+
const workerLambdaToS3ResourceName = createSyncResourceName(`worker-lambda-to-cognito`);
|
|
21
|
+
const cognitoPolicy = app.addResource(aws.iam.Policy, {
|
|
22
|
+
name: `${resolverLambdaToS3ResourceName}-policy`,
|
|
23
|
+
config: {
|
|
24
|
+
description: "This policy enables access from Sync System Resolver and Worker Lambda to Webiny Cognito.",
|
|
25
|
+
policy: {
|
|
26
|
+
Version: "2012-10-17",
|
|
27
|
+
Statement: [{
|
|
28
|
+
Sid: "PermissionForSyncLambdaToCognito",
|
|
29
|
+
Effect: "Allow",
|
|
30
|
+
Action: ["cognito-idp:*"],
|
|
31
|
+
Resource: core.cognitoUserPoolArn.apply(arn => {
|
|
32
|
+
return [arn, `${arn}/*`];
|
|
33
|
+
})
|
|
34
|
+
}]
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
});
|
|
38
|
+
const resolverLambdaS3PolicyAttachment = app.addResource(aws.iam.RolePolicyAttachment, {
|
|
39
|
+
name: `${resolverLambdaToS3ResourceName}-policy-attachment`,
|
|
40
|
+
config: {
|
|
41
|
+
role: resolverLambdaRoleName,
|
|
42
|
+
policyArn: cognitoPolicy.output.arn
|
|
43
|
+
}
|
|
44
|
+
});
|
|
45
|
+
const workerLambdaS3PolicyAttachment = app.addResource(aws.iam.RolePolicyAttachment, {
|
|
46
|
+
name: `${workerLambdaToS3ResourceName}-policy-attachment`,
|
|
47
|
+
config: {
|
|
48
|
+
role: workerLambdaRoleName,
|
|
49
|
+
policyArn: cognitoPolicy.output.arn
|
|
50
|
+
}
|
|
51
|
+
});
|
|
52
|
+
return {
|
|
53
|
+
cognitoPolicy,
|
|
54
|
+
workerLambdaS3PolicyAttachment,
|
|
55
|
+
resolverLambdaS3PolicyAttachment
|
|
56
|
+
};
|
|
57
|
+
};
|
|
58
|
+
|
|
59
|
+
//# sourceMappingURL=attachCognitoPermissions.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["aws","createSyncResourceName","attachCognitoPermissions","params","app","syncSystem","core","cognitoUserPoolArn","resolverLambdaRoleName","workerLambdaRoleName","resolverLambdaToS3ResourceName","workerLambdaToS3ResourceName","cognitoPolicy","addResource","iam","Policy","name","config","description","policy","Version","Statement","Sid","Effect","Action","Resource","apply","arn","resolverLambdaS3PolicyAttachment","RolePolicyAttachment","role","policyArn","output","workerLambdaS3PolicyAttachment"],"sources":["attachCognitoPermissions.ts"],"sourcesContent":["import * as aws from \"@pulumi/aws\";\nimport type { PulumiApp } from \"@webiny/pulumi\";\nimport type { WithServiceManifest } from \"~/pulumi/utils/withServiceManifest.js\";\nimport type { IGetSyncSystemOutputResult } from \"~/pulumi/apps/syncSystem/types.js\";\nimport type { CoreOutput } from \"~/apps/index.js\";\nimport { createSyncResourceName } from \"~/pulumi/apps/syncSystem/createSyncResourceName.js\";\n\nexport interface IAttachCognitoPermissionsParams {\n app: PulumiApp & WithServiceManifest;\n syncSystem: IGetSyncSystemOutputResult;\n core: CoreOutput;\n}\n\nexport const attachCognitoPermissions = (params: IAttachCognitoPermissionsParams) => {\n const { app, syncSystem, core } = params;\n /**\n * TODO there must be a way to skip this if Cognito is not used in the Webiny deployment.\n */\n if (!core.cognitoUserPoolArn) {\n return null;\n }\n\n const { resolverLambdaRoleName, workerLambdaRoleName } = syncSystem;\n\n const resolverLambdaToS3ResourceName = createSyncResourceName(`resolver-lambda-to-cognito`);\n const workerLambdaToS3ResourceName = createSyncResourceName(`worker-lambda-to-cognito`);\n\n const cognitoPolicy = app.addResource(aws.iam.Policy, {\n name: `${resolverLambdaToS3ResourceName}-policy`,\n config: {\n description:\n \"This policy enables access from Sync System Resolver and Worker Lambda to Webiny Cognito.\",\n policy: {\n Version: \"2012-10-17\",\n Statement: [\n {\n Sid: \"PermissionForSyncLambdaToCognito\",\n Effect: \"Allow\",\n Action: [\"cognito-idp:*\"],\n Resource: core.cognitoUserPoolArn.apply(arn => {\n return [arn, `${arn}/*`];\n })\n }\n ]\n }\n }\n });\n\n const resolverLambdaS3PolicyAttachment = app.addResource(aws.iam.RolePolicyAttachment, {\n name: `${resolverLambdaToS3ResourceName}-policy-attachment`,\n config: {\n role: resolverLambdaRoleName,\n policyArn: cognitoPolicy.output.arn\n }\n });\n\n const workerLambdaS3PolicyAttachment = app.addResource(aws.iam.RolePolicyAttachment, {\n name: `${workerLambdaToS3ResourceName}-policy-attachment`,\n config: {\n role: workerLambdaRoleName,\n policyArn: cognitoPolicy.output.arn\n }\n });\n\n return {\n cognitoPolicy,\n workerLambdaS3PolicyAttachment,\n resolverLambdaS3PolicyAttachment\n };\n};\n"],"mappings":"AAAA,OAAO,KAAKA,GAAG,MAAM,aAAa;AAKlC,SAASC,sBAAsB;AAQ/B,OAAO,MAAMC,wBAAwB,GAAIC,MAAuC,IAAK;EACjF,MAAM;IAAEC,GAAG;IAAEC,UAAU;IAAEC;EAAK,CAAC,GAAGH,MAAM;EACxC;AACJ;AACA;EACI,IAAI,CAACG,IAAI,CAACC,kBAAkB,EAAE;IAC1B,OAAO,IAAI;EACf;EAEA,MAAM;IAAEC,sBAAsB;IAAEC;EAAqB,CAAC,GAAGJ,UAAU;EAEnE,MAAMK,8BAA8B,GAAGT,sBAAsB,CAAC,4BAA4B,CAAC;EAC3F,MAAMU,4BAA4B,GAAGV,sBAAsB,CAAC,0BAA0B,CAAC;EAEvF,MAAMW,aAAa,GAAGR,GAAG,CAACS,WAAW,CAACb,GAAG,CAACc,GAAG,CAACC,MAAM,EAAE;IAClDC,IAAI,EAAE,GAAGN,8BAA8B,SAAS;IAChDO,MAAM,EAAE;MACJC,WAAW,EACP,2FAA2F;MAC/FC,MAAM,EAAE;QACJC,OAAO,EAAE,YAAY;QACrBC,SAAS,EAAE,CACP;UACIC,GAAG,EAAE,kCAAkC;UACvCC,MAAM,EAAE,OAAO;UACfC,MAAM,EAAE,CAAC,eAAe,CAAC;UACzBC,QAAQ,EAAEnB,IAAI,CAACC,kBAAkB,CAACmB,KAAK,CAACC,GAAG,IAAI;YAC3C,OAAO,CAACA,GAAG,EAAE,GAAGA,GAAG,IAAI,CAAC;UAC5B,CAAC;QACL,CAAC;MAET;IACJ;EACJ,CAAC,CAAC;EAEF,MAAMC,gCAAgC,GAAGxB,GAAG,CAACS,WAAW,CAACb,GAAG,CAACc,GAAG,CAACe,oBAAoB,EAAE;IACnFb,IAAI,EAAE,GAAGN,8BAA8B,oBAAoB;IAC3DO,MAAM,EAAE;MACJa,IAAI,EAAEtB,sBAAsB;MAC5BuB,SAAS,EAAEnB,aAAa,CAACoB,MAAM,CAACL;IACpC;EACJ,CAAC,CAAC;EAEF,MAAMM,8BAA8B,GAAG7B,GAAG,CAACS,WAAW,CAACb,GAAG,CAACc,GAAG,CAACe,oBAAoB,EAAE;IACjFb,IAAI,EAAE,GAAGL,4BAA4B,oBAAoB;IACzDM,MAAM,EAAE;MACJa,IAAI,EAAErB,oBAAoB;MAC1BsB,SAAS,EAAEnB,aAAa,CAACoB,MAAM,CAACL;IACpC;EACJ,CAAC,CAAC;EAEF,OAAO;IACHf,aAAa;IACbqB,8BAA8B;IAC9BL;EACJ,CAAC;AACL,CAAC","ignoreList":[]}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import type { PulumiApp } from "@webiny/pulumi";
|
|
2
|
+
import type { IGetSyncSystemOutputResult } from "../../../../pulumi/apps/syncSystem/types.js";
|
|
3
|
+
import type { CoreOutput } from "../../../../pulumi/apps/common/CoreOutput.js";
|
|
4
|
+
import type { WithServiceManifest } from "../../../../pulumi/utils/withServiceManifest.js";
|
|
5
|
+
export interface IAttachDynamoDbPermissionsParams {
|
|
6
|
+
app: PulumiApp & WithServiceManifest;
|
|
7
|
+
syncSystem: IGetSyncSystemOutputResult;
|
|
8
|
+
core: CoreOutput;
|
|
9
|
+
}
|
|
10
|
+
export declare const attachDynamoDbPermissions: (params: IAttachDynamoDbPermissionsParams) => {
|
|
11
|
+
dynamoDbPolicy: import("@webiny/pulumi").PulumiAppResource<typeof import("@pulumi/aws/iam/policy").Policy>;
|
|
12
|
+
lambdaRolePolicyAttachment: import("@webiny/pulumi").PulumiAppResource<typeof import("@pulumi/aws/iam/rolePolicyAttachment").RolePolicyAttachment>;
|
|
13
|
+
};
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* We need to attach Sync System Lambda policy to access DynamoDB in the Webiny system.
|
|
3
|
+
*/
|
|
4
|
+
import * as aws from "@pulumi/aws";
|
|
5
|
+
import { createSyncResourceName } from "../createSyncResourceName.js";
|
|
6
|
+
export const attachDynamoDbPermissions = params => {
|
|
7
|
+
const {
|
|
8
|
+
app,
|
|
9
|
+
syncSystem,
|
|
10
|
+
core
|
|
11
|
+
} = params;
|
|
12
|
+
const {
|
|
13
|
+
resolverLambdaRoleName
|
|
14
|
+
} = syncSystem;
|
|
15
|
+
const lambdaToDynamoDbResourceName = createSyncResourceName(`resolver-lambda-to-dynamodb`);
|
|
16
|
+
const dynamoDbPolicy = app.addResource(aws.iam.Policy, {
|
|
17
|
+
name: `${lambdaToDynamoDbResourceName}-policy`,
|
|
18
|
+
config: {
|
|
19
|
+
description: "This policy enables access from Sync System Lambda to Webiny DynamoDB.",
|
|
20
|
+
policy: {
|
|
21
|
+
Version: "2012-10-17",
|
|
22
|
+
Statement: [{
|
|
23
|
+
Sid: "PermissionForSyncLambdaToDynamoDb",
|
|
24
|
+
Effect: "Allow",
|
|
25
|
+
Action: ["dynamodb:BatchGetItem", "dynamodb:BatchWriteItem", "dynamodb:ConditionCheckItem", "dynamodb:CreateBackup", "dynamodb:CreateTable", "dynamodb:CreateTableReplica", "dynamodb:DeleteBackup", "dynamodb:DeleteItem", "dynamodb:DeleteTable", "dynamodb:DeleteTableReplica", "dynamodb:DescribeBackup", "dynamodb:DescribeContinuousBackups", "dynamodb:DescribeContributorInsights", "dynamodb:DescribeExport", "dynamodb:DescribeKinesisStreamingDestination", "dynamodb:DescribeLimits", "dynamodb:DescribeReservedCapacity", "dynamodb:DescribeReservedCapacityOfferings", "dynamodb:DescribeStream", "dynamodb:DescribeTable", "dynamodb:DescribeTableReplicaAutoScaling", "dynamodb:DescribeTimeToLive", "dynamodb:DisableKinesisStreamingDestination", "dynamodb:EnableKinesisStreamingDestination", "dynamodb:ExportTableToPointInTime", "dynamodb:GetItem", "dynamodb:GetRecords", "dynamodb:GetShardIterator", "dynamodb:ListBackups", "dynamodb:ListContributorInsights", "dynamodb:ListExports", "dynamodb:ListStreams", "dynamodb:ListTables", "dynamodb:ListTagsOfResource", "dynamodb:PartiQLDelete", "dynamodb:PartiQLInsert", "dynamodb:PartiQLSelect", "dynamodb:PartiQLUpdate", "dynamodb:PurchaseReservedCapacityOfferings", "dynamodb:PutItem", "dynamodb:Query", "dynamodb:RestoreTableFromBackup", "dynamodb:RestoreTableToPointInTime", "dynamodb:Scan", "dynamodb:UpdateContinuousBackups", "dynamodb:UpdateContributorInsights", "dynamodb:UpdateItem", "dynamodb:UpdateTable", "dynamodb:UpdateTableReplicaAutoScaling", "dynamodb:UpdateTimeToLive"],
|
|
26
|
+
Resource: [core.primaryDynamodbTableArn.apply(arn => arn), core.primaryDynamodbTableArn.apply(arn => `${arn}/*`)]
|
|
27
|
+
}]
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
});
|
|
31
|
+
const lambdaRolePolicyAttachment = app.addResource(aws.iam.RolePolicyAttachment, {
|
|
32
|
+
name: `${lambdaToDynamoDbResourceName}-role-policy-attachment`,
|
|
33
|
+
config: {
|
|
34
|
+
role: resolverLambdaRoleName,
|
|
35
|
+
policyArn: dynamoDbPolicy.output.arn
|
|
36
|
+
}
|
|
37
|
+
});
|
|
38
|
+
return {
|
|
39
|
+
dynamoDbPolicy,
|
|
40
|
+
lambdaRolePolicyAttachment
|
|
41
|
+
};
|
|
42
|
+
};
|
|
43
|
+
|
|
44
|
+
//# sourceMappingURL=attachDynamoDbPermissions.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["aws","createSyncResourceName","attachDynamoDbPermissions","params","app","syncSystem","core","resolverLambdaRoleName","lambdaToDynamoDbResourceName","dynamoDbPolicy","addResource","iam","Policy","name","config","description","policy","Version","Statement","Sid","Effect","Action","Resource","primaryDynamodbTableArn","apply","arn","lambdaRolePolicyAttachment","RolePolicyAttachment","role","policyArn","output"],"sources":["attachDynamoDbPermissions.ts"],"sourcesContent":["/**\n * We need to attach Sync System Lambda policy to access DynamoDB in the Webiny system.\n */\nimport * as aws from \"@pulumi/aws\";\nimport type { PulumiApp } from \"@webiny/pulumi\";\nimport type { IGetSyncSystemOutputResult } from \"~/pulumi/apps/syncSystem/types.js\";\nimport { createSyncResourceName } from \"~/pulumi/apps/syncSystem/createSyncResourceName.js\";\nimport type { CoreOutput } from \"~/pulumi/apps/common/CoreOutput.js\";\nimport type { WithServiceManifest } from \"~/pulumi/utils/withServiceManifest.js\";\n\nexport interface IAttachDynamoDbPermissionsParams {\n app: PulumiApp & WithServiceManifest;\n syncSystem: IGetSyncSystemOutputResult;\n core: CoreOutput;\n}\n\nexport const attachDynamoDbPermissions = (params: IAttachDynamoDbPermissionsParams) => {\n const { app, syncSystem, core } = params;\n\n const { resolverLambdaRoleName } = syncSystem;\n\n const lambdaToDynamoDbResourceName = createSyncResourceName(`resolver-lambda-to-dynamodb`);\n\n const dynamoDbPolicy = app.addResource(aws.iam.Policy, {\n name: `${lambdaToDynamoDbResourceName}-policy`,\n config: {\n description: \"This policy enables access from Sync System Lambda to Webiny DynamoDB.\",\n policy: {\n Version: \"2012-10-17\",\n Statement: [\n {\n Sid: \"PermissionForSyncLambdaToDynamoDb\",\n Effect: \"Allow\",\n Action: [\n \"dynamodb:BatchGetItem\",\n \"dynamodb:BatchWriteItem\",\n \"dynamodb:ConditionCheckItem\",\n \"dynamodb:CreateBackup\",\n \"dynamodb:CreateTable\",\n \"dynamodb:CreateTableReplica\",\n \"dynamodb:DeleteBackup\",\n \"dynamodb:DeleteItem\",\n \"dynamodb:DeleteTable\",\n \"dynamodb:DeleteTableReplica\",\n \"dynamodb:DescribeBackup\",\n \"dynamodb:DescribeContinuousBackups\",\n \"dynamodb:DescribeContributorInsights\",\n \"dynamodb:DescribeExport\",\n \"dynamodb:DescribeKinesisStreamingDestination\",\n \"dynamodb:DescribeLimits\",\n \"dynamodb:DescribeReservedCapacity\",\n \"dynamodb:DescribeReservedCapacityOfferings\",\n \"dynamodb:DescribeStream\",\n \"dynamodb:DescribeTable\",\n \"dynamodb:DescribeTableReplicaAutoScaling\",\n \"dynamodb:DescribeTimeToLive\",\n \"dynamodb:DisableKinesisStreamingDestination\",\n \"dynamodb:EnableKinesisStreamingDestination\",\n \"dynamodb:ExportTableToPointInTime\",\n \"dynamodb:GetItem\",\n \"dynamodb:GetRecords\",\n \"dynamodb:GetShardIterator\",\n \"dynamodb:ListBackups\",\n \"dynamodb:ListContributorInsights\",\n \"dynamodb:ListExports\",\n \"dynamodb:ListStreams\",\n \"dynamodb:ListTables\",\n \"dynamodb:ListTagsOfResource\",\n \"dynamodb:PartiQLDelete\",\n \"dynamodb:PartiQLInsert\",\n \"dynamodb:PartiQLSelect\",\n \"dynamodb:PartiQLUpdate\",\n \"dynamodb:PurchaseReservedCapacityOfferings\",\n \"dynamodb:PutItem\",\n \"dynamodb:Query\",\n \"dynamodb:RestoreTableFromBackup\",\n \"dynamodb:RestoreTableToPointInTime\",\n \"dynamodb:Scan\",\n \"dynamodb:UpdateContinuousBackups\",\n \"dynamodb:UpdateContributorInsights\",\n \"dynamodb:UpdateItem\",\n \"dynamodb:UpdateTable\",\n \"dynamodb:UpdateTableReplicaAutoScaling\",\n \"dynamodb:UpdateTimeToLive\"\n ],\n Resource: [\n core.primaryDynamodbTableArn.apply(arn => arn),\n core.primaryDynamodbTableArn.apply(arn => `${arn}/*`)\n ]\n }\n ]\n }\n }\n });\n\n const lambdaRolePolicyAttachment = app.addResource(aws.iam.RolePolicyAttachment, {\n name: `${lambdaToDynamoDbResourceName}-role-policy-attachment`,\n config: {\n role: resolverLambdaRoleName,\n policyArn: dynamoDbPolicy.output.arn\n }\n });\n\n return {\n dynamoDbPolicy,\n lambdaRolePolicyAttachment\n };\n};\n"],"mappings":"AAAA;AACA;AACA;AACA,OAAO,KAAKA,GAAG,MAAM,aAAa;AAGlC,SAASC,sBAAsB;AAU/B,OAAO,MAAMC,yBAAyB,GAAIC,MAAwC,IAAK;EACnF,MAAM;IAAEC,GAAG;IAAEC,UAAU;IAAEC;EAAK,CAAC,GAAGH,MAAM;EAExC,MAAM;IAAEI;EAAuB,CAAC,GAAGF,UAAU;EAE7C,MAAMG,4BAA4B,GAAGP,sBAAsB,CAAC,6BAA6B,CAAC;EAE1F,MAAMQ,cAAc,GAAGL,GAAG,CAACM,WAAW,CAACV,GAAG,CAACW,GAAG,CAACC,MAAM,EAAE;IACnDC,IAAI,EAAE,GAAGL,4BAA4B,SAAS;IAC9CM,MAAM,EAAE;MACJC,WAAW,EAAE,wEAAwE;MACrFC,MAAM,EAAE;QACJC,OAAO,EAAE,YAAY;QACrBC,SAAS,EAAE,CACP;UACIC,GAAG,EAAE,mCAAmC;UACxCC,MAAM,EAAE,OAAO;UACfC,MAAM,EAAE,CACJ,uBAAuB,EACvB,yBAAyB,EACzB,6BAA6B,EAC7B,uBAAuB,EACvB,sBAAsB,EACtB,6BAA6B,EAC7B,uBAAuB,EACvB,qBAAqB,EACrB,sBAAsB,EACtB,6BAA6B,EAC7B,yBAAyB,EACzB,oCAAoC,EACpC,sCAAsC,EACtC,yBAAyB,EACzB,8CAA8C,EAC9C,yBAAyB,EACzB,mCAAmC,EACnC,4CAA4C,EAC5C,yBAAyB,EACzB,wBAAwB,EACxB,0CAA0C,EAC1C,6BAA6B,EAC7B,6CAA6C,EAC7C,4CAA4C,EAC5C,mCAAmC,EACnC,kBAAkB,EAClB,qBAAqB,EACrB,2BAA2B,EAC3B,sBAAsB,EACtB,kCAAkC,EAClC,sBAAsB,EACtB,sBAAsB,EACtB,qBAAqB,EACrB,6BAA6B,EAC7B,wBAAwB,EACxB,wBAAwB,EACxB,wBAAwB,EACxB,wBAAwB,EACxB,4CAA4C,EAC5C,kBAAkB,EAClB,gBAAgB,EAChB,iCAAiC,EACjC,oCAAoC,EACpC,eAAe,EACf,kCAAkC,EAClC,oCAAoC,EACpC,qBAAqB,EACrB,sBAAsB,EACtB,wCAAwC,EACxC,2BAA2B,CAC9B;UACDC,QAAQ,EAAE,CACNhB,IAAI,CAACiB,uBAAuB,CAACC,KAAK,CAACC,GAAG,IAAIA,GAAG,CAAC,EAC9CnB,IAAI,CAACiB,uBAAuB,CAACC,KAAK,CAACC,GAAG,IAAI,GAAGA,GAAG,IAAI,CAAC;QAE7D,CAAC;MAET;IACJ;EACJ,CAAC,CAAC;EAEF,MAAMC,0BAA0B,GAAGtB,GAAG,CAACM,WAAW,CAACV,GAAG,CAACW,GAAG,CAACgB,oBAAoB,EAAE;IAC7Ed,IAAI,EAAE,GAAGL,4BAA4B,yBAAyB;IAC9DM,MAAM,EAAE;MACJc,IAAI,EAAErB,sBAAsB;MAC5BsB,SAAS,EAAEpB,cAAc,CAACqB,MAAM,CAACL;IACrC;EACJ,CAAC,CAAC;EAEF,OAAO;IACHhB,cAAc;IACdiB;EACJ,CAAC;AACL,CAAC","ignoreList":[]}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import type { PulumiApp } from "@webiny/pulumi/types.js";
|
|
2
|
+
import type { IGetSyncSystemOutputResult } from "../types.js";
|
|
3
|
+
import type { WithServiceManifest } from "../../../../pulumi/utils/withServiceManifest.js";
|
|
4
|
+
export interface IAttachEventBusPermissionsParam {
|
|
5
|
+
app: PulumiApp & WithServiceManifest;
|
|
6
|
+
syncSystem: IGetSyncSystemOutputResult;
|
|
7
|
+
}
|
|
8
|
+
/**
|
|
9
|
+
* We need to attach the policy to:
|
|
10
|
+
* * GraphQL Lambda Role
|
|
11
|
+
* * File Manager Manage Lambda Role
|
|
12
|
+
* TODO determine if any other are required
|
|
13
|
+
*/
|
|
14
|
+
export declare const attachEventBusPermissions: (params: IAttachEventBusPermissionsParam) => {
|
|
15
|
+
eventBridgePolicy: import("@webiny/pulumi/PulumiAppResource.js").PulumiAppResource<typeof import("@pulumi/aws/iam/policy.js").Policy>;
|
|
16
|
+
graphQlPolicyAttachment: import("@webiny/pulumi/PulumiAppResource.js").PulumiAppResource<typeof import("@pulumi/aws/iam/rolePolicyAttachment.js").RolePolicyAttachment>;
|
|
17
|
+
};
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import * as aws from "@pulumi/aws";
|
|
2
|
+
import { createSyncResourceName } from "../createSyncResourceName.js";
|
|
3
|
+
import { ApiGraphql } from "../../api/ApiGraphql.js";
|
|
4
|
+
/**
|
|
5
|
+
* We need to attach the policy to:
|
|
6
|
+
* * GraphQL Lambda Role
|
|
7
|
+
* * File Manager Manage Lambda Role
|
|
8
|
+
* TODO determine if any other are required
|
|
9
|
+
*/
|
|
10
|
+
export const attachEventBusPermissions = params => {
|
|
11
|
+
const {
|
|
12
|
+
app,
|
|
13
|
+
syncSystem
|
|
14
|
+
} = params;
|
|
15
|
+
const {
|
|
16
|
+
eventBusArn
|
|
17
|
+
} = syncSystem;
|
|
18
|
+
const graphql = app.getModule(ApiGraphql);
|
|
19
|
+
const lambdaToEventBridgeResourceName = createSyncResourceName(`lambda-to-event-bridge`);
|
|
20
|
+
const eventBridgePolicy = app.addResource(aws.iam.Policy, {
|
|
21
|
+
name: `${lambdaToEventBridgeResourceName}-policy`,
|
|
22
|
+
config: {
|
|
23
|
+
description: "This policy enables access from Webiny Lambdas to Sync System EventBridge.",
|
|
24
|
+
policy: {
|
|
25
|
+
Version: "2012-10-17",
|
|
26
|
+
Statement: [{
|
|
27
|
+
Sid: "PermissionForSyncLambdaToEventBridge",
|
|
28
|
+
Effect: "Allow",
|
|
29
|
+
Action: "events:PutEvents",
|
|
30
|
+
Resource: [eventBusArn]
|
|
31
|
+
}]
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
});
|
|
35
|
+
const graphQlPolicyAttachment = app.addResource(aws.iam.RolePolicyAttachment, {
|
|
36
|
+
name: `${lambdaToEventBridgeResourceName}-graphql-role-policy-attachment`,
|
|
37
|
+
config: {
|
|
38
|
+
role: graphql.role.output.name,
|
|
39
|
+
policyArn: eventBridgePolicy.output.arn
|
|
40
|
+
}
|
|
41
|
+
});
|
|
42
|
+
return {
|
|
43
|
+
eventBridgePolicy,
|
|
44
|
+
graphQlPolicyAttachment
|
|
45
|
+
};
|
|
46
|
+
};
|
|
47
|
+
|
|
48
|
+
//# sourceMappingURL=attachEventBusPermissions.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["aws","createSyncResourceName","ApiGraphql","attachEventBusPermissions","params","app","syncSystem","eventBusArn","graphql","getModule","lambdaToEventBridgeResourceName","eventBridgePolicy","addResource","iam","Policy","name","config","description","policy","Version","Statement","Sid","Effect","Action","Resource","graphQlPolicyAttachment","RolePolicyAttachment","role","output","policyArn","arn"],"sources":["attachEventBusPermissions.ts"],"sourcesContent":["import * as aws from \"@pulumi/aws\";\nimport type { PulumiApp } from \"@webiny/pulumi/types.js\";\nimport type { IGetSyncSystemOutputResult } from \"../types.js\";\nimport { createSyncResourceName } from \"../createSyncResourceName.js\";\nimport { ApiGraphql } from \"~/pulumi/apps/api/ApiGraphql.js\";\nimport type { WithServiceManifest } from \"~/pulumi/utils/withServiceManifest.js\";\n\nexport interface IAttachEventBusPermissionsParam {\n app: PulumiApp & WithServiceManifest;\n syncSystem: IGetSyncSystemOutputResult;\n}\n\n/**\n * We need to attach the policy to:\n * * GraphQL Lambda Role\n * * File Manager Manage Lambda Role\n * TODO determine if any other are required\n */\nexport const attachEventBusPermissions = (params: IAttachEventBusPermissionsParam) => {\n const { app, syncSystem } = params;\n\n const { eventBusArn } = syncSystem;\n\n const graphql = app.getModule(ApiGraphql);\n\n const lambdaToEventBridgeResourceName = createSyncResourceName(`lambda-to-event-bridge`);\n const eventBridgePolicy = app.addResource(aws.iam.Policy, {\n name: `${lambdaToEventBridgeResourceName}-policy`,\n config: {\n description:\n \"This policy enables access from Webiny Lambdas to Sync System EventBridge.\",\n policy: {\n Version: \"2012-10-17\",\n Statement: [\n {\n Sid: \"PermissionForSyncLambdaToEventBridge\",\n Effect: \"Allow\",\n Action: \"events:PutEvents\",\n Resource: [eventBusArn]\n }\n ]\n }\n }\n });\n\n const graphQlPolicyAttachment = app.addResource(aws.iam.RolePolicyAttachment, {\n name: `${lambdaToEventBridgeResourceName}-graphql-role-policy-attachment`,\n config: {\n role: graphql.role.output.name,\n policyArn: eventBridgePolicy.output.arn\n }\n });\n\n return {\n eventBridgePolicy,\n graphQlPolicyAttachment\n };\n};\n"],"mappings":"AAAA,OAAO,KAAKA,GAAG,MAAM,aAAa;AAGlC,SAASC,sBAAsB;AAC/B,SAASC,UAAU;AAQnB;AACA;AACA;AACA;AACA;AACA;AACA,OAAO,MAAMC,yBAAyB,GAAIC,MAAuC,IAAK;EAClF,MAAM;IAAEC,GAAG;IAAEC;EAAW,CAAC,GAAGF,MAAM;EAElC,MAAM;IAAEG;EAAY,CAAC,GAAGD,UAAU;EAElC,MAAME,OAAO,GAAGH,GAAG,CAACI,SAAS,CAACP,UAAU,CAAC;EAEzC,MAAMQ,+BAA+B,GAAGT,sBAAsB,CAAC,wBAAwB,CAAC;EACxF,MAAMU,iBAAiB,GAAGN,GAAG,CAACO,WAAW,CAACZ,GAAG,CAACa,GAAG,CAACC,MAAM,EAAE;IACtDC,IAAI,EAAE,GAAGL,+BAA+B,SAAS;IACjDM,MAAM,EAAE;MACJC,WAAW,EACP,4EAA4E;MAChFC,MAAM,EAAE;QACJC,OAAO,EAAE,YAAY;QACrBC,SAAS,EAAE,CACP;UACIC,GAAG,EAAE,sCAAsC;UAC3CC,MAAM,EAAE,OAAO;UACfC,MAAM,EAAE,kBAAkB;UAC1BC,QAAQ,EAAE,CAACjB,WAAW;QAC1B,CAAC;MAET;IACJ;EACJ,CAAC,CAAC;EAEF,MAAMkB,uBAAuB,GAAGpB,GAAG,CAACO,WAAW,CAACZ,GAAG,CAACa,GAAG,CAACa,oBAAoB,EAAE;IAC1EX,IAAI,EAAE,GAAGL,+BAA+B,iCAAiC;IACzEM,MAAM,EAAE;MACJW,IAAI,EAAEnB,OAAO,CAACmB,IAAI,CAACC,MAAM,CAACb,IAAI;MAC9Bc,SAAS,EAAElB,iBAAiB,CAACiB,MAAM,CAACE;IACxC;EACJ,CAAC,CAAC;EAEF,OAAO;IACHnB,iBAAiB;IACjBc;EACJ,CAAC;AACL,CAAC","ignoreList":[]}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import type { PulumiApp } from "@webiny/pulumi";
|
|
2
|
+
import type { IGetSyncSystemOutputResult } from "../../../../pulumi/apps/syncSystem/types.js";
|
|
3
|
+
import type { CoreOutput } from "../../../../pulumi/apps/common/CoreOutput.js";
|
|
4
|
+
import type { WithServiceManifest } from "../../../../pulumi/utils/withServiceManifest.js";
|
|
5
|
+
export interface IAttachS3PermissionsParams {
|
|
6
|
+
app: PulumiApp & WithServiceManifest;
|
|
7
|
+
syncSystem: IGetSyncSystemOutputResult;
|
|
8
|
+
core: CoreOutput;
|
|
9
|
+
}
|
|
10
|
+
export declare const attachS3Permissions: (params: IAttachS3PermissionsParams) => {
|
|
11
|
+
s3Policy: import("@webiny/pulumi").PulumiAppResource<typeof import("@pulumi/aws/iam/policy").Policy>;
|
|
12
|
+
workerLambdaS3PolicyAttachment: import("@webiny/pulumi").PulumiAppResource<typeof import("@pulumi/aws/iam/rolePolicyAttachment").RolePolicyAttachment>;
|
|
13
|
+
resolverLambdaS3PolicyAttachment: import("@webiny/pulumi").PulumiAppResource<typeof import("@pulumi/aws/iam/rolePolicyAttachment").RolePolicyAttachment>;
|
|
14
|
+
};
|