@webiny/project-aws 6.3.0 → 6.4.0-beta.0
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/_templates/appTemplates/admin/src/index.tsx +0 -3
- package/abstractions/ApiGqlClient.js +2 -1
- package/abstractions/ApiGqlClient.js.map +1 -1
- package/abstractions/InvokeLambdaFunction.js +2 -1
- package/abstractions/InvokeLambdaFunction.js.map +1 -1
- package/abstractions/features/pulumi/AdminPulumi.js +2 -1
- package/abstractions/features/pulumi/AdminPulumi.js.map +1 -1
- package/abstractions/features/pulumi/ApiPulumi.js +2 -1
- package/abstractions/features/pulumi/ApiPulumi.js.map +1 -1
- package/abstractions/features/pulumi/CorePulumi.js +2 -1
- package/abstractions/features/pulumi/CorePulumi.js.map +1 -1
- package/abstractions/features/pulumi/index.js +0 -2
- package/abstractions/index.js +0 -2
- package/abstractions/services/AdminStackOutputService.js +2 -1
- package/abstractions/services/AdminStackOutputService.js.map +1 -1
- package/abstractions/services/ApiStackOutputService.js +2 -1
- package/abstractions/services/ApiStackOutputService.js.map +1 -1
- package/abstractions/services/CoreStackOutputService.js +2 -1
- package/abstractions/services/CoreStackOutputService.js.map +1 -1
- package/admin.js +5 -4
- package/admin.js.map +1 -1
- package/api.js +13 -12
- package/api.js.map +1 -1
- package/apps/createAdminApp.js +11 -12
- package/apps/createAdminApp.js.map +1 -1
- package/apps/createAdminAppConfig.js +12 -18
- package/apps/createAdminAppConfig.js.map +1 -1
- package/apps/createApiApp.js +17 -22
- package/apps/createApiApp.js.map +1 -1
- package/apps/createBlueGreenApp.js +13 -16
- package/apps/createBlueGreenApp.js.map +1 -1
- package/apps/createCoreApp.js +12 -13
- package/apps/createCoreApp.js.map +1 -1
- package/apps/createReactAppConfig.d.ts +0 -7
- package/apps/createReactAppConfig.js +56 -69
- package/apps/createReactAppConfig.js.map +1 -1
- package/apps/createSyncSystemApp.js +8 -7
- package/apps/createSyncSystemApp.js.map +1 -1
- package/apps/index.js +0 -2
- package/cli.js +3 -2
- package/cli.js.map +1 -1
- package/exports/extensions.js +0 -2
- package/exports/infra/admin.js +0 -2
- package/exports/infra/api.js +0 -2
- package/exports/infra/core.js +0 -2
- package/exports/infra.js +1 -3
- package/extensions/ApiLambdaFunction.js +45 -56
- package/extensions/ApiLambdaFunction.js.map +1 -1
- package/extensions/ApiRoute.js +90 -104
- package/extensions/ApiRoute.js.map +1 -1
- package/extensions/AwsDefaultRegion.js +17 -16
- package/extensions/AwsDefaultRegion.js.map +1 -1
- package/extensions/Cms/ModelFieldCompression.js +16 -15
- package/extensions/Cms/ModelFieldCompression.js.map +1 -1
- package/extensions/Encryption.js +30 -29
- package/extensions/Encryption.js.map +1 -1
- package/extensions/Mailer/Smtp.js +15 -14
- package/extensions/Mailer/Smtp.js.map +1 -1
- package/extensions/Mailer/Smtp.test.js +117 -131
- package/extensions/Mailer/Smtp.test.js.map +1 -1
- package/extensions/Mailer/SmtpParamsSchema.js +11 -14
- package/extensions/Mailer/SmtpParamsSchema.js.map +1 -1
- package/extensions/OpenSearch/EnsureOsServiceRoleBeforeCoreDeploy.js +25 -30
- package/extensions/OpenSearch/EnsureOsServiceRoleBeforeCoreDeploy.js.map +1 -1
- package/extensions/OpenSearch/EnsureOsWasDeployed.js +14 -24
- package/extensions/OpenSearch/EnsureOsWasDeployed.js.map +1 -1
- package/extensions/OpenSearch/InjectDdbEsLambdaFnHandler.js +25 -21
- package/extensions/OpenSearch/InjectDdbEsLambdaFnHandler.js.map +1 -1
- package/extensions/OpenSearch/ReplaceApiLambdaFnHandlers.js +26 -22
- package/extensions/OpenSearch/ReplaceApiLambdaFnHandlers.js.map +1 -1
- package/extensions/OpenSearch.js +30 -31
- package/extensions/OpenSearch.js.map +1 -1
- package/extensions/ProjectAws/AdminStackOutputService.js +0 -2
- package/extensions/ProjectAws/ApiStackOutputService.js +0 -2
- package/extensions/ProjectAws/AutoInstall/AutoInstallAfterApiDeploy.js +65 -74
- package/extensions/ProjectAws/AutoInstall/AutoInstallAfterApiDeploy.js.map +1 -1
- package/extensions/ProjectAws/AutoInstall.js +15 -14
- package/extensions/ProjectAws/AutoInstall.js.map +1 -1
- package/extensions/ProjectAws/BlueGreenDeployments/EnsureVariantBeforeDeploy.js +15 -19
- package/extensions/ProjectAws/BlueGreenDeployments/EnsureVariantBeforeDeploy.js.map +1 -1
- package/extensions/ProjectAws/BlueGreenDeployments/PrintDeploymentInfoAfterDeploy.js +56 -45
- package/extensions/ProjectAws/BlueGreenDeployments/PrintDeploymentInfoAfterDeploy.js.map +1 -1
- package/extensions/ProjectAws/BlueGreenDeployments/SetPrimaryVariantCliCommand.js +57 -55
- package/extensions/ProjectAws/BlueGreenDeployments/SetPrimaryVariantCliCommand.js.map +1 -1
- package/extensions/ProjectAws/BuildAppWorkspace.js +49 -54
- package/extensions/ProjectAws/BuildAppWorkspace.js.map +1 -1
- package/extensions/ProjectAws/CoreStackOutputService.js +0 -2
- package/extensions/ProjectAws/EnsureAwsCredentialsBeforeDeploy.js +26 -30
- package/extensions/ProjectAws/EnsureAwsCredentialsBeforeDeploy.js.map +1 -1
- package/extensions/ProjectAws/SetAdminEnvVars/SetAdminEnvVars.js +25 -38
- package/extensions/ProjectAws/SetAdminEnvVars/SetAdminEnvVars.js.map +1 -1
- package/extensions/ProjectAws/SetAdminEnvVars/SetAdminEnvVarsBeforeBuild.js +22 -17
- package/extensions/ProjectAws/SetAdminEnvVars/SetAdminEnvVarsBeforeBuild.js.map +1 -1
- package/extensions/ProjectAws/SetAdminEnvVars/SetAdminEnvVarsBeforeWatch.js +22 -17
- package/extensions/ProjectAws/SetAdminEnvVars/SetAdminEnvVarsBeforeWatch.js.map +1 -1
- package/extensions/ProjectAws/SetDatabaseSetupOutput.js +20 -21
- package/extensions/ProjectAws/SetDatabaseSetupOutput.js.map +1 -1
- package/extensions/ProjectAws/UploadAdminAppToS3.js +53 -58
- package/extensions/ProjectAws/UploadAdminAppToS3.js.map +1 -1
- package/extensions/ProjectAws/definitions.js +13 -6
- package/extensions/ProjectAws/definitions.js.map +1 -1
- package/extensions/ProjectAws.js +44 -45
- package/extensions/ProjectAws.js.map +1 -1
- package/extensions/RegisterRoutesPulumi.js +24 -29
- package/extensions/RegisterRoutesPulumi.js.map +1 -1
- package/extensions/definitions.js +10 -3
- package/extensions/definitions.js.map +1 -1
- package/extensions/index.js +0 -2
- package/features/ApiGqlClient.js +46 -51
- package/features/ApiGqlClient.js.map +1 -1
- package/features/InvokeLambdaFunction.js +30 -32
- package/features/InvokeLambdaFunction.js.map +1 -1
- package/features/index.js +0 -2
- package/index.js +0 -2
- package/infra.js +57 -59
- package/infra.js.map +1 -1
- package/package.json +14 -14
- package/project.js +7 -6
- package/project.js.map +1 -1
- package/pulumi/apps/admin/createAdminPulumiApp.js +36 -44
- package/pulumi/apps/admin/createAdminPulumiApp.js.map +1 -1
- package/pulumi/apps/admin/index.js +0 -2
- package/pulumi/apps/api/ApiBackgroundTask.js +153 -137
- package/pulumi/apps/api/ApiBackgroundTask.js.map +1 -1
- package/pulumi/apps/api/ApiCloudfront.js +188 -130
- package/pulumi/apps/api/ApiCloudfront.js.map +1 -1
- package/pulumi/apps/api/ApiFileManager.js +34 -33
- package/pulumi/apps/api/ApiFileManager.js.map +1 -1
- package/pulumi/apps/api/ApiGateway.js +67 -74
- package/pulumi/apps/api/ApiGateway.js.map +1 -1
- package/pulumi/apps/api/ApiGraphql.js +223 -152
- package/pulumi/apps/api/ApiGraphql.js.map +1 -1
- package/pulumi/apps/api/ApiOutput.js +29 -30
- package/pulumi/apps/api/ApiOutput.js.map +1 -1
- package/pulumi/apps/api/ApiScheduler.js +94 -92
- package/pulumi/apps/api/ApiScheduler.js.map +1 -1
- package/pulumi/apps/api/ApiWebsocket.js +141 -133
- package/pulumi/apps/api/ApiWebsocket.js.map +1 -1
- package/pulumi/apps/api/backgroundTask/definition.js +122 -144
- package/pulumi/apps/api/backgroundTask/definition.js.map +1 -1
- package/pulumi/apps/api/backgroundTask/policy.js +37 -23
- package/pulumi/apps/api/backgroundTask/policy.js.map +1 -1
- package/pulumi/apps/api/backgroundTask/role.js +29 -29
- package/pulumi/apps/api/backgroundTask/role.js.map +1 -1
- package/pulumi/apps/api/backgroundTask/types.js +9 -11
- package/pulumi/apps/api/backgroundTask/types.js.map +1 -1
- package/pulumi/apps/api/createApiPulumiApp.js +206 -274
- package/pulumi/apps/api/createApiPulumiApp.js.map +1 -1
- package/pulumi/apps/api/handleGuardDutyEvents.js +54 -51
- package/pulumi/apps/api/handleGuardDutyEvents.js.map +1 -1
- package/pulumi/apps/api/index.js +0 -2
- package/pulumi/apps/awsUtils.js +21 -24
- package/pulumi/apps/awsUtils.js.map +1 -1
- package/pulumi/apps/blueGreen/BlueGreenRouterApiGateway.js +37 -40
- package/pulumi/apps/blueGreen/BlueGreenRouterApiGateway.js.map +1 -1
- package/pulumi/apps/blueGreen/BlueGreenRouterCloudFront.js +83 -91
- package/pulumi/apps/blueGreen/BlueGreenRouterCloudFront.js.map +1 -1
- package/pulumi/apps/blueGreen/BlueGreenRouterCloudFrontStore.js +17 -16
- package/pulumi/apps/blueGreen/BlueGreenRouterCloudFrontStore.js.map +1 -1
- package/pulumi/apps/blueGreen/cloudfront/createCloudFrontDefaultCacheBehaviorPolicies.js +13 -12
- package/pulumi/apps/blueGreen/cloudfront/createCloudFrontDefaultCacheBehaviorPolicies.js.map +1 -1
- package/pulumi/apps/blueGreen/cloudfront/createCloudFrontFunctionDomainMap.js +9 -14
- package/pulumi/apps/blueGreen/cloudfront/createCloudFrontFunctionDomainMap.js.map +1 -1
- package/pulumi/apps/blueGreen/cloudfront/createOriginId.js +5 -7
- package/pulumi/apps/blueGreen/cloudfront/createOriginId.js.map +1 -1
- package/pulumi/apps/blueGreen/constants.js +15 -3
- package/pulumi/apps/blueGreen/constants.js.map +1 -1
- package/pulumi/apps/blueGreen/createBlueGreenPulumiApp.js +77 -103
- package/pulumi/apps/blueGreen/createBlueGreenPulumiApp.js.map +1 -1
- package/pulumi/apps/blueGreen/domains/attachDomainsToOutput.js +20 -26
- package/pulumi/apps/blueGreen/domains/attachDomainsToOutput.js.map +1 -1
- package/pulumi/apps/blueGreen/domains/convertApplicationDomains.js +17 -20
- package/pulumi/apps/blueGreen/domains/convertApplicationDomains.js.map +1 -1
- package/pulumi/apps/blueGreen/domains/getApplicationDomains.js +51 -61
- package/pulumi/apps/blueGreen/domains/getApplicationDomains.js.map +1 -1
- package/pulumi/apps/blueGreen/domains/resolveDomains.js +24 -38
- package/pulumi/apps/blueGreen/domains/resolveDomains.js.map +1 -1
- package/pulumi/apps/blueGreen/functions/buildHandlerFunction.js +7 -14
- package/pulumi/apps/blueGreen/functions/buildHandlerFunction.js.map +1 -1
- package/pulumi/apps/blueGreen/functions/handler.js +1 -57
- package/pulumi/apps/blueGreen/functions/handler.js.map +1 -1
- package/pulumi/apps/blueGreen/types.js +0 -3
- package/pulumi/apps/blueGreen/validation/validateDeployments.js +19 -24
- package/pulumi/apps/blueGreen/validation/validateDeployments.js.map +1 -1
- package/pulumi/apps/common/CoreOutput.js +34 -37
- package/pulumi/apps/common/CoreOutput.js.map +1 -1
- package/pulumi/apps/common/VpcConfig.js +20 -20
- package/pulumi/apps/common/VpcConfig.js.map +1 -1
- package/pulumi/apps/common/index.js +0 -2
- package/pulumi/apps/core/CoreAuditLogsDynamo.js +245 -182
- package/pulumi/apps/core/CoreAuditLogsDynamo.js.map +1 -1
- package/pulumi/apps/core/CoreCognito.js +117 -106
- package/pulumi/apps/core/CoreCognito.js.map +1 -1
- package/pulumi/apps/core/CoreDynamo.js +91 -70
- package/pulumi/apps/core/CoreDynamo.js.map +1 -1
- package/pulumi/apps/core/CoreEventBus.js +10 -9
- package/pulumi/apps/core/CoreEventBus.js.map +1 -1
- package/pulumi/apps/core/CoreFileManager.js +76 -68
- package/pulumi/apps/core/CoreFileManager.js.map +1 -1
- package/pulumi/apps/core/CoreOpenSearch.js +281 -305
- package/pulumi/apps/core/CoreOpenSearch.js.map +1 -1
- package/pulumi/apps/core/CoreVpc.js +155 -156
- package/pulumi/apps/core/CoreVpc.js.map +1 -1
- package/pulumi/apps/core/WatchCommand.js +94 -96
- package/pulumi/apps/core/WatchCommand.js.map +1 -1
- package/pulumi/apps/core/cognitoIdentityProviders/amazon.js +16 -22
- package/pulumi/apps/core/cognitoIdentityProviders/amazon.js.map +1 -1
- package/pulumi/apps/core/cognitoIdentityProviders/apple.js +16 -17
- package/pulumi/apps/core/cognitoIdentityProviders/apple.js.map +1 -1
- package/pulumi/apps/core/cognitoIdentityProviders/configure.js +44 -50
- package/pulumi/apps/core/cognitoIdentityProviders/configure.js.map +1 -1
- package/pulumi/apps/core/cognitoIdentityProviders/facebook.js +16 -17
- package/pulumi/apps/core/cognitoIdentityProviders/facebook.js.map +1 -1
- package/pulumi/apps/core/cognitoIdentityProviders/getIdpConfig.js +7 -8
- package/pulumi/apps/core/cognitoIdentityProviders/getIdpConfig.js.map +1 -1
- package/pulumi/apps/core/cognitoIdentityProviders/google.js +16 -17
- package/pulumi/apps/core/cognitoIdentityProviders/google.js.map +1 -1
- package/pulumi/apps/core/cognitoIdentityProviders/index.js +0 -2
- package/pulumi/apps/core/cognitoIdentityProviders/oidc.js +17 -18
- package/pulumi/apps/core/cognitoIdentityProviders/oidc.js.map +1 -1
- package/pulumi/apps/core/configureS3BucketMalwareProtection.js +251 -188
- package/pulumi/apps/core/configureS3BucketMalwareProtection.js.map +1 -1
- package/pulumi/apps/core/createCorePulumiApp.js +212 -280
- package/pulumi/apps/core/createCorePulumiApp.js.map +1 -1
- package/pulumi/apps/core/index.js +0 -2
- package/pulumi/apps/core/webinyWatchCommand/handler.js +45 -32
- package/pulumi/apps/core/webinyWatchCommand/handler.js.map +1 -1
- package/pulumi/apps/createAppBucket.js +157 -146
- package/pulumi/apps/createAppBucket.js.map +1 -1
- package/pulumi/apps/customDomain.js +7 -6
- package/pulumi/apps/customDomain.js.map +1 -1
- package/pulumi/apps/extensions/getAwsTagsFromExtension.js +8 -7
- package/pulumi/apps/extensions/getAwsTagsFromExtension.js.map +1 -1
- package/pulumi/apps/extensions/getBgDeploymentsConfigFromExtension.js +6 -7
- package/pulumi/apps/extensions/getBgDeploymentsConfigFromExtension.js.map +1 -1
- package/pulumi/apps/extensions/getOsConfigFromExtension.js +17 -41
- package/pulumi/apps/extensions/getOsConfigFromExtension.js.map +1 -1
- package/pulumi/apps/extensions/getVpcConfigFromExtension.js +13 -25
- package/pulumi/apps/extensions/getVpcConfigFromExtension.js.map +1 -1
- package/pulumi/apps/index.js +0 -3
- package/pulumi/apps/lambdaUtils.js +57 -61
- package/pulumi/apps/lambdaUtils.js.map +1 -1
- package/pulumi/apps/react/createReactPulumiApp.js +108 -129
- package/pulumi/apps/react/createReactPulumiApp.js.map +1 -1
- package/pulumi/apps/react/index.js +0 -2
- package/pulumi/apps/syncSystem/SyncSystemDynamo.js +77 -62
- package/pulumi/apps/syncSystem/SyncSystemDynamo.js.map +1 -1
- package/pulumi/apps/syncSystem/SyncSystemDynamoDb.js +74 -57
- package/pulumi/apps/syncSystem/SyncSystemDynamoDb.js.map +1 -1
- package/pulumi/apps/syncSystem/SyncSystemEventBus.js +77 -71
- package/pulumi/apps/syncSystem/SyncSystemEventBus.js.map +1 -1
- package/pulumi/apps/syncSystem/SyncSystemLambda.js +154 -86
- package/pulumi/apps/syncSystem/SyncSystemLambda.js.map +1 -1
- package/pulumi/apps/syncSystem/SyncSystemOutput.js +14 -13
- package/pulumi/apps/syncSystem/SyncSystemOutput.js.map +1 -1
- package/pulumi/apps/syncSystem/SyncSystemResolverLambda.js +56 -60
- package/pulumi/apps/syncSystem/SyncSystemResolverLambda.js.map +1 -1
- package/pulumi/apps/syncSystem/SyncSystemSQS.js +25 -49
- package/pulumi/apps/syncSystem/SyncSystemSQS.js.map +1 -1
- package/pulumi/apps/syncSystem/SyncSystemWorkerLambda.js +44 -43
- package/pulumi/apps/syncSystem/SyncSystemWorkerLambda.js.map +1 -1
- package/pulumi/apps/syncSystem/addTableItems.js +35 -45
- package/pulumi/apps/syncSystem/addTableItems.js.map +1 -1
- package/pulumi/apps/syncSystem/api/addServiceManifest.js +12 -14
- package/pulumi/apps/syncSystem/api/addServiceManifest.js.map +1 -1
- package/pulumi/apps/syncSystem/api/attachCognitoPermissions.js +49 -55
- package/pulumi/apps/syncSystem/api/attachCognitoPermissions.js.map +1 -1
- package/pulumi/apps/syncSystem/api/attachDynamoDbPermissions.js +88 -40
- package/pulumi/apps/syncSystem/api/attachDynamoDbPermissions.js.map +1 -1
- package/pulumi/apps/syncSystem/api/attachEventBusPermissions.js +37 -43
- package/pulumi/apps/syncSystem/api/attachEventBusPermissions.js.map +1 -1
- package/pulumi/apps/syncSystem/api/attachS3Permissions.js +51 -47
- package/pulumi/apps/syncSystem/api/attachS3Permissions.js.map +1 -1
- package/pulumi/apps/syncSystem/api/index.js +28 -46
- package/pulumi/apps/syncSystem/api/index.js.map +1 -1
- package/pulumi/apps/syncSystem/constants.js +2 -1
- package/pulumi/apps/syncSystem/constants.js.map +1 -1
- package/pulumi/apps/syncSystem/createSyncResourceName.js +2 -7
- package/pulumi/apps/syncSystem/createSyncResourceName.js.map +1 -1
- package/pulumi/apps/syncSystem/createSyncSystemPulumiApp.js +101 -166
- package/pulumi/apps/syncSystem/createSyncSystemPulumiApp.js.map +1 -1
- package/pulumi/apps/syncSystem/customApp.js +12 -16
- package/pulumi/apps/syncSystem/customApp.js.map +1 -1
- package/pulumi/apps/syncSystem/getSyncSystemOutput.js +5 -6
- package/pulumi/apps/syncSystem/getSyncSystemOutput.js.map +1 -1
- package/pulumi/apps/syncSystem/lambda/createSyncSystemResolverLambdaPolicy.js +108 -42
- package/pulumi/apps/syncSystem/lambda/createSyncSystemResolverLambdaPolicy.js.map +1 -1
- package/pulumi/apps/syncSystem/types.js +0 -3
- package/pulumi/constants.js +2 -1
- package/pulumi/constants.js.map +1 -1
- package/pulumi/env/awsRegion.js +3 -2
- package/pulumi/env/awsRegion.js.map +1 -1
- package/pulumi/env/base.js +11 -27
- package/pulumi/env/base.js.map +1 -1
- package/pulumi/env/env.js +3 -2
- package/pulumi/env/env.js.map +1 -1
- package/pulumi/env/projectName.js +3 -2
- package/pulumi/env/projectName.js.map +1 -1
- package/pulumi/env/variant.js +4 -3
- package/pulumi/env/variant.js.map +1 -1
- package/pulumi/extensions/AdminCustomDomains.js +15 -11
- package/pulumi/extensions/AdminCustomDomains.js.map +1 -1
- package/pulumi/extensions/AdminPulumi.js +16 -19
- package/pulumi/extensions/AdminPulumi.js.map +1 -1
- package/pulumi/extensions/ApiCustomDomains.js +15 -11
- package/pulumi/extensions/ApiCustomDomains.js.map +1 -1
- package/pulumi/extensions/ApiPulumi.js +16 -19
- package/pulumi/extensions/ApiPulumi.js.map +1 -1
- package/pulumi/extensions/AwsTags.js +11 -10
- package/pulumi/extensions/AwsTags.js.map +1 -1
- package/pulumi/extensions/BlueGreenDeployments.js +29 -26
- package/pulumi/extensions/BlueGreenDeployments.js.map +1 -1
- package/pulumi/extensions/CorePulumi.js +16 -19
- package/pulumi/extensions/CorePulumi.js.map +1 -1
- package/pulumi/extensions/OpenSearch.js +16 -15
- package/pulumi/extensions/OpenSearch.js.map +1 -1
- package/pulumi/extensions/Vpc.js +21 -20
- package/pulumi/extensions/Vpc.js.map +1 -1
- package/pulumi/extensions/index.js +12 -10
- package/pulumi/extensions/index.js.map +1 -1
- package/pulumi/features/AdminPulumi/AdminPulumi.js +18 -14
- package/pulumi/features/AdminPulumi/AdminPulumi.js.map +1 -1
- package/pulumi/features/AdminPulumi/index.js +0 -2
- package/pulumi/features/ApiPulumi/ApiPulumi.js +18 -14
- package/pulumi/features/ApiPulumi/ApiPulumi.js.map +1 -1
- package/pulumi/features/ApiPulumi/index.js +0 -2
- package/pulumi/features/CorePulumi/CorePulumi.js +18 -14
- package/pulumi/features/CorePulumi/CorePulumi.js.map +1 -1
- package/pulumi/features/CorePulumi/index.js +0 -2
- package/pulumi/features/index.js +0 -2
- package/pulumi/index.js +0 -2
- package/pulumi/types.js +0 -3
- package/pulumi/utils/addDomainsUrlsOutputs.js +20 -37
- package/pulumi/utils/addDomainsUrlsOutputs.js.map +1 -1
- package/pulumi/utils/addServiceManifestTableItem.js +12 -15
- package/pulumi/utils/addServiceManifestTableItem.js.map +1 -1
- package/pulumi/utils/crawlDirectory.js +10 -15
- package/pulumi/utils/crawlDirectory.js.map +1 -1
- package/pulumi/utils/createAssetArchive.js +5 -6
- package/pulumi/utils/createAssetArchive.js.map +1 -1
- package/pulumi/utils/dynamodb.js +26 -27
- package/pulumi/utils/dynamodb.js.map +1 -1
- package/pulumi/utils/getPresignedPost.js +27 -30
- package/pulumi/utils/getPresignedPost.js.map +1 -1
- package/pulumi/utils/index.js +1 -3
- package/pulumi/utils/lambdaEnvVariables.js +42 -54
- package/pulumi/utils/lambdaEnvVariables.js.map +1 -1
- package/pulumi/utils/tagResources.js +248 -28
- package/pulumi/utils/tagResources.js.map +1 -1
- package/pulumi/utils/uploadFolderToS3.js +101 -131
- package/pulumi/utils/uploadFolderToS3.js.map +1 -1
- package/pulumi/utils/withServiceManifest.js +28 -37
- package/pulumi/utils/withServiceManifest.js.map +1 -1
- package/services/AdminStackOutputService.js +14 -11
- package/services/AdminStackOutputService.js.map +1 -1
- package/services/ApiStackOutputService.js +14 -11
- package/services/ApiStackOutputService.js.map +1 -1
- package/services/CoreStackOutputService.js +14 -11
- package/services/CoreStackOutputService.js.map +1 -1
- package/utils/getTemplatesFolderPath.js +8 -10
- package/utils/getTemplatesFolderPath.js.map +1 -1
- package/utils/index.js +0 -2
- package/abstractions/features/pulumi/index.js.map +0 -1
- package/abstractions/index.js.map +0 -1
- package/apps/index.js.map +0 -1
- package/exports/extensions.js.map +0 -1
- package/exports/infra/admin.js.map +0 -1
- package/exports/infra/api.js.map +0 -1
- package/exports/infra/core.js.map +0 -1
- package/exports/infra.js.map +0 -1
- package/extensions/ProjectAws/AdminStackOutputService.js.map +0 -1
- package/extensions/ProjectAws/ApiStackOutputService.js.map +0 -1
- package/extensions/ProjectAws/CoreStackOutputService.js.map +0 -1
- package/extensions/index.js.map +0 -1
- package/features/index.js.map +0 -1
- package/index.js.map +0 -1
- package/pulumi/apps/admin/index.js.map +0 -1
- package/pulumi/apps/api/index.js.map +0 -1
- package/pulumi/apps/blueGreen/types.js.map +0 -1
- package/pulumi/apps/common/index.js.map +0 -1
- package/pulumi/apps/core/cognitoIdentityProviders/index.js.map +0 -1
- package/pulumi/apps/core/index.js.map +0 -1
- package/pulumi/apps/index.js.map +0 -1
- package/pulumi/apps/react/index.js.map +0 -1
- package/pulumi/apps/syncSystem/types.js.map +0 -1
- package/pulumi/features/AdminPulumi/index.js.map +0 -1
- package/pulumi/features/ApiPulumi/index.js.map +0 -1
- package/pulumi/features/CorePulumi/index.js.map +0 -1
- package/pulumi/features/index.js.map +0 -1
- package/pulumi/index.js.map +0 -1
- package/pulumi/types.js.map +0 -1
- package/pulumi/utils/index.js.map +0 -1
- package/utils/index.js.map +0 -1
|
@@ -1,9 +1,7 @@
|
|
|
1
|
-
import * as aws from "@pulumi/aws";
|
|
2
1
|
import { createPulumiApp, isResourceOfType } from "@webiny/pulumi";
|
|
3
2
|
import { ApiBackgroundTask, ApiCloudfront, ApiFileManager, ApiGateway, ApiGraphql, ApiWebsocket, CoreOutput, VpcConfig } from "../index.js";
|
|
4
3
|
import { addDomainsUrlsOutputs, withCommonLambdaEnvVariables, withServiceManifest } from "../../utils/index.js";
|
|
5
4
|
import { getEnvVariableAwsRegion } from "../../env/awsRegion.js";
|
|
6
|
-
// import { attachSyncSystem } from "../syncSystem/api/index.js";
|
|
7
5
|
import { applyAwsResourceTags, getAwsAccountId } from "../awsUtils.js";
|
|
8
6
|
import { ApiScheduler } from "./ApiScheduler.js";
|
|
9
7
|
import { getProjectSdk } from "@webiny/project";
|
|
@@ -12,287 +10,221 @@ import { getOsConfigFromExtension } from "../extensions/getOsConfigFromExtension
|
|
|
12
10
|
import { handleGuardDutyEvents } from "./handleGuardDutyEvents.js";
|
|
13
11
|
import { ApiPulumi } from "../../../abstractions/features/pulumi/index.js";
|
|
14
12
|
import { apiPulumi } from "../../features/ApiPulumi/index.js";
|
|
15
|
-
import { ApiCustomDomains
|
|
13
|
+
import { ApiCustomDomains } from "../../extensions/ApiCustomDomains.js";
|
|
16
14
|
import { applyCustomDomain } from "../customDomain.js";
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
}
|
|
40
|
-
if (params.indexPrefix) {
|
|
41
|
-
process.env.OPENSEARCH_INDEX_PREFIX = params.indexPrefix;
|
|
42
|
-
}
|
|
43
|
-
if (params.sharedIndexes) {
|
|
44
|
-
process.env.OPENSEARCH_SHARED_INDEXES = "true";
|
|
45
|
-
}
|
|
46
|
-
if (params.username) {
|
|
47
|
-
process.env.OPENSEARCH_USERNAME = params.username;
|
|
48
|
-
}
|
|
49
|
-
if (params.password) {
|
|
50
|
-
process.env.OPENSEARCH_PASSWORD = params.password;
|
|
51
|
-
}
|
|
52
|
-
}
|
|
53
|
-
}
|
|
54
|
-
if (pulumiResourceNamePrefix) {
|
|
55
|
-
app.onResource(resource => {
|
|
56
|
-
if (!resource.name.startsWith(pulumiResourceNamePrefix)) {
|
|
57
|
-
resource.name = `${pulumiResourceNamePrefix}${resource.name}`;
|
|
58
|
-
}
|
|
59
|
-
});
|
|
60
|
-
}
|
|
61
|
-
|
|
62
|
-
// <-------------------- Enterprise start -------------------->
|
|
63
|
-
app.addHandler(async () => {
|
|
64
|
-
const featureFlags = await sdk.getFeatureFlags();
|
|
65
|
-
const usingAdvancedVpcParams = vpcExtensionsConfig && typeof vpcExtensionsConfig !== "boolean";
|
|
66
|
-
if (featureFlags.isFileManagerThreatDetectionEnabled()) {
|
|
67
|
-
handleGuardDutyEvents(app);
|
|
68
|
-
}
|
|
69
|
-
|
|
70
|
-
// Not using advanced VPC params? Then immediately exit.
|
|
71
|
-
if (usingAdvancedVpcParams) {
|
|
72
|
-
const {
|
|
73
|
-
onResource,
|
|
74
|
-
addResource
|
|
75
|
-
} = app;
|
|
76
|
-
const {
|
|
77
|
-
useExistingVpc
|
|
78
|
-
} = vpcExtensionsConfig;
|
|
79
|
-
|
|
80
|
-
// 1. We first deal with "existing VPC" setup.
|
|
81
|
-
if (useExistingVpc) {
|
|
82
|
-
if (!useExistingVpc.lambdaFunctionsVpcConfig) {
|
|
83
|
-
throw new Error("Cannot specify `useExistingVpc` parameter because the `lambdaFunctionsVpcConfig` parameter wasn't provided.");
|
|
84
|
-
}
|
|
85
|
-
onResource(resource => {
|
|
86
|
-
if (isResourceOfType(resource, aws.lambda.Function)) {
|
|
87
|
-
const canUseVpc = resource.meta.canUseVpc !== false;
|
|
88
|
-
if (canUseVpc) {
|
|
89
|
-
resource.config.vpcConfig(useExistingVpc.lambdaFunctionsVpcConfig);
|
|
15
|
+
import * as __rspack_external__pulumi_aws_e7af83c1 from "@pulumi/aws";
|
|
16
|
+
const createApiPulumiApp = ()=>{
|
|
17
|
+
const baseApp = createPulumiApp({
|
|
18
|
+
name: "api",
|
|
19
|
+
path: "apps/api",
|
|
20
|
+
program: async (app)=>{
|
|
21
|
+
const sdk = await getProjectSdk();
|
|
22
|
+
const projectConfig = await sdk.getProjectConfig();
|
|
23
|
+
const pulumiResourceNamePrefix = await sdk.getPulumiResourceNamePrefix();
|
|
24
|
+
const vpcExtensionsConfig = getVpcConfigFromExtension(projectConfig);
|
|
25
|
+
const openSearchExtensionConfig = getOsConfigFromExtension(projectConfig);
|
|
26
|
+
let searchEngineParams = null;
|
|
27
|
+
if (openSearchExtensionConfig) searchEngineParams = openSearchExtensionConfig;
|
|
28
|
+
if (searchEngineParams) {
|
|
29
|
+
const params = searchEngineParams;
|
|
30
|
+
if ("object" == typeof params) {
|
|
31
|
+
if (params.endpoint) process.env.OPENSEARCH_ENDPOINT = params.endpoint;
|
|
32
|
+
if (params.domainName) process.env.AWS_OS_DOMAIN_NAME = params.domainName;
|
|
33
|
+
if (params.indexPrefix) process.env.OPENSEARCH_INDEX_PREFIX = params.indexPrefix;
|
|
34
|
+
if (params.sharedIndexes) process.env.OPENSEARCH_SHARED_INDEXES = "true";
|
|
35
|
+
if (params.username) process.env.OPENSEARCH_USERNAME = params.username;
|
|
36
|
+
if (params.password) process.env.OPENSEARCH_PASSWORD = params.password;
|
|
90
37
|
}
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
if (resource.
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
38
|
+
}
|
|
39
|
+
if (pulumiResourceNamePrefix) app.onResource((resource)=>{
|
|
40
|
+
if (!resource.name.startsWith(pulumiResourceNamePrefix)) resource.name = `${pulumiResourceNamePrefix}${resource.name}`;
|
|
41
|
+
});
|
|
42
|
+
app.addHandler(async ()=>{
|
|
43
|
+
const featureFlags = await sdk.getFeatureFlags();
|
|
44
|
+
const usingAdvancedVpcParams = vpcExtensionsConfig && "boolean" != typeof vpcExtensionsConfig;
|
|
45
|
+
if (featureFlags.isFileManagerThreatDetectionEnabled()) handleGuardDutyEvents(app);
|
|
46
|
+
if (usingAdvancedVpcParams) {
|
|
47
|
+
const { onResource, addResource } = app;
|
|
48
|
+
const { useExistingVpc } = vpcExtensionsConfig;
|
|
49
|
+
if (useExistingVpc) {
|
|
50
|
+
if (!useExistingVpc.lambdaFunctionsVpcConfig) throw new Error("Cannot specify `useExistingVpc` parameter because the `lambdaFunctionsVpcConfig` parameter wasn't provided.");
|
|
51
|
+
onResource((resource)=>{
|
|
52
|
+
if (isResourceOfType(resource, __rspack_external__pulumi_aws_e7af83c1.lambda.Function)) {
|
|
53
|
+
const canUseVpc = false !== resource.meta.canUseVpc;
|
|
54
|
+
if (canUseVpc) resource.config.vpcConfig(useExistingVpc.lambdaFunctionsVpcConfig);
|
|
55
|
+
}
|
|
56
|
+
if (isResourceOfType(resource, __rspack_external__pulumi_aws_e7af83c1.iam.Role)) {
|
|
57
|
+
if (resource.meta.isLambdaFunctionRole) addResource(__rspack_external__pulumi_aws_e7af83c1.iam.RolePolicyAttachment, {
|
|
58
|
+
name: `${resource.name}-vpc-access-execution-role`,
|
|
59
|
+
config: {
|
|
60
|
+
role: resource.output.name,
|
|
61
|
+
policyArn: __rspack_external__pulumi_aws_e7af83c1.iam.ManagedPolicy.AWSLambdaVPCAccessExecutionRole
|
|
62
|
+
}
|
|
63
|
+
});
|
|
64
|
+
}
|
|
65
|
+
});
|
|
99
66
|
}
|
|
100
|
-
});
|
|
101
67
|
}
|
|
102
|
-
}
|
|
103
68
|
});
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
69
|
+
sdk.getContainer().registerComposite(apiPulumi);
|
|
70
|
+
const pulumiHandlers = sdk.getContainer().resolve(ApiPulumi);
|
|
71
|
+
app.addHandler(()=>pulumiHandlers.execute(app));
|
|
72
|
+
const isProduction = app.env.isProduction;
|
|
73
|
+
const core = app.addModule(CoreOutput);
|
|
74
|
+
const vpcEnabled = true === vpcExtensionsConfig || "object" == typeof vpcExtensionsConfig || isProduction;
|
|
75
|
+
app.addModule(VpcConfig, {
|
|
76
|
+
enabled: vpcEnabled
|
|
77
|
+
});
|
|
78
|
+
const graphql = app.addModule(ApiGraphql, {
|
|
79
|
+
env: {
|
|
80
|
+
COGNITO_REGION: getEnvVariableAwsRegion(),
|
|
81
|
+
COGNITO_USER_POOL_ID: core.cognitoUserPoolId,
|
|
82
|
+
DB_TABLE: core.primaryDynamodbTableName,
|
|
83
|
+
DB_TABLE_AUDIT_LOGS: core.auditLogsDynamodbTableName,
|
|
84
|
+
DB_TABLE_OPENSEARCH: core.opensearchDynamodbTableName,
|
|
85
|
+
OPENSEARCH_ENDPOINT: core.opensearchDomainEndpoint,
|
|
86
|
+
OPENSEARCH_INDEX_PREFIX: process.env.OPENSEARCH_INDEX_PREFIX,
|
|
87
|
+
OPENSEARCH_SHARED_INDEXES: process.env.OPENSEARCH_SHARED_INDEXES,
|
|
88
|
+
OPENSEARCH_USERNAME: process.env.OPENSEARCH_USERNAME,
|
|
89
|
+
OPENSEARCH_PASSWORD: process.env.OPENSEARCH_PASSWORD,
|
|
90
|
+
S3_BUCKET: core.fileManagerBucketId,
|
|
91
|
+
EVENT_BUS: core.eventBusArn,
|
|
92
|
+
OKTA_ISSUER: process.env["OKTA_ISSUER"]
|
|
93
|
+
}
|
|
94
|
+
});
|
|
95
|
+
const websocket = app.addModule(ApiWebsocket);
|
|
96
|
+
const fileManager = app.addModule(ApiFileManager, {
|
|
97
|
+
env: {
|
|
98
|
+
DB_TABLE: core.primaryDynamodbTableName,
|
|
99
|
+
DB_TABLE_AUDIT_LOGS: core.auditLogsDynamodbTableName
|
|
100
|
+
}
|
|
101
|
+
});
|
|
102
|
+
const apiGateway = app.addModule(ApiGateway, {
|
|
103
|
+
"graphql-post": {
|
|
104
|
+
path: "/graphql",
|
|
105
|
+
method: "POST",
|
|
106
|
+
function: graphql.functions.graphql.output.arn
|
|
107
|
+
},
|
|
108
|
+
"graphql-options": {
|
|
109
|
+
path: "/graphql",
|
|
110
|
+
method: "OPTIONS",
|
|
111
|
+
function: graphql.functions.graphql.output.arn
|
|
112
|
+
},
|
|
113
|
+
"files-any": {
|
|
114
|
+
path: "/files/{path+}",
|
|
115
|
+
method: "ANY",
|
|
116
|
+
function: fileManager.functions.download.output.arn
|
|
117
|
+
},
|
|
118
|
+
"private-any": {
|
|
119
|
+
path: "/private/{path+}",
|
|
120
|
+
method: "ANY",
|
|
121
|
+
function: fileManager.functions.download.output.arn
|
|
122
|
+
},
|
|
123
|
+
"cms-post": {
|
|
124
|
+
path: "/cms/{key+}",
|
|
125
|
+
method: "POST",
|
|
126
|
+
function: graphql.functions.graphql.output.arn
|
|
127
|
+
},
|
|
128
|
+
"cms-options": {
|
|
129
|
+
path: "/cms/{key+}",
|
|
130
|
+
method: "OPTIONS",
|
|
131
|
+
function: graphql.functions.graphql.output.arn
|
|
132
|
+
},
|
|
133
|
+
"redirects-get": {
|
|
134
|
+
path: "/wb/redirects",
|
|
135
|
+
method: "GET",
|
|
136
|
+
function: graphql.functions.graphql.output.arn
|
|
137
|
+
},
|
|
138
|
+
"redirects-options": {
|
|
139
|
+
path: "/wb/redirects",
|
|
140
|
+
method: "OPTIONS",
|
|
141
|
+
function: graphql.functions.graphql.output.arn
|
|
142
|
+
},
|
|
143
|
+
"files-catch-all": {
|
|
144
|
+
path: "/{path+}",
|
|
145
|
+
method: "ANY",
|
|
146
|
+
function: fileManager.functions.download.output.arn
|
|
147
|
+
}
|
|
148
|
+
});
|
|
149
|
+
const cloudfront = app.addModule(ApiCloudfront);
|
|
150
|
+
const backgroundTask = app.addModule(ApiBackgroundTask);
|
|
151
|
+
const scheduler = app.addModule(ApiScheduler);
|
|
152
|
+
const [apiCustomDomains] = projectConfig.extensionsByType(ApiCustomDomains);
|
|
153
|
+
if (apiCustomDomains) {
|
|
154
|
+
const { domains, sslMethod, certificateArn } = apiCustomDomains.params;
|
|
155
|
+
applyCustomDomain(cloudfront, {
|
|
156
|
+
domains,
|
|
157
|
+
sslSupportMethod: sslMethod,
|
|
158
|
+
acmCertificateArn: certificateArn
|
|
159
|
+
});
|
|
160
|
+
}
|
|
161
|
+
app.addOutputs({
|
|
162
|
+
awsAccountId: getAwsAccountId(app),
|
|
163
|
+
region: __rspack_external__pulumi_aws_e7af83c1.config.region,
|
|
164
|
+
cognitoUserPoolId: core.cognitoUserPoolId,
|
|
165
|
+
cognitoAppClientId: core.cognitoAppClientId,
|
|
166
|
+
cognitoUserPoolPasswordPolicy: core.cognitoUserPoolPasswordPolicy,
|
|
167
|
+
dynamoDbTable: core.primaryDynamodbTableName,
|
|
168
|
+
auditLogsDynamoDbTable: core.auditLogsDynamodbTableName,
|
|
169
|
+
graphqlLambdaName: graphql.functions.graphql.output.name,
|
|
170
|
+
graphqlLambdaRole: graphql.role.output.arn,
|
|
171
|
+
graphqlLambdaRoleName: graphql.role.output.name,
|
|
172
|
+
backgroundTaskLambdaArn: backgroundTask.backgroundTask.output.arn,
|
|
173
|
+
backgroundTaskStepFunctionArn: backgroundTask.stepFunction.output.arn,
|
|
174
|
+
fileManagerDownloadLambdaArn: fileManager.functions.download.output.arn,
|
|
175
|
+
websocketApiId: websocket.websocketApi.output.id,
|
|
176
|
+
websocketApiUrl: websocket.websocketApiUrl,
|
|
177
|
+
schedulerLambdaInvokeRole: scheduler.invokeRole.output.arn
|
|
178
|
+
});
|
|
179
|
+
if (searchEngineParams) app.addOutputs({
|
|
180
|
+
dynamoDbOpensearchTable: core.opensearchDynamodbTableName
|
|
181
|
+
});
|
|
182
|
+
app.addHandler(()=>{
|
|
183
|
+
addDomainsUrlsOutputs({
|
|
184
|
+
app,
|
|
185
|
+
cloudfrontDistribution: cloudfront,
|
|
186
|
+
map: {
|
|
187
|
+
distributionDomain: "cloudfrontApiDomain",
|
|
188
|
+
distributionUrl: "cloudfrontApiUrl",
|
|
189
|
+
usedDomain: "apiDomain",
|
|
190
|
+
usedUrl: "apiUrl"
|
|
191
|
+
}
|
|
192
|
+
});
|
|
193
|
+
});
|
|
194
|
+
await applyAwsResourceTags("api");
|
|
195
|
+
return {
|
|
196
|
+
fileManager,
|
|
197
|
+
graphql,
|
|
198
|
+
apiGateway,
|
|
199
|
+
websocket,
|
|
200
|
+
cloudfront,
|
|
201
|
+
backgroundTask,
|
|
202
|
+
scheduler
|
|
203
|
+
};
|
|
198
204
|
}
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
domains,
|
|
212
|
-
sslSupportMethod: sslMethod,
|
|
213
|
-
acmCertificateArn: certificateArn
|
|
214
|
-
});
|
|
215
|
-
}
|
|
216
|
-
app.addOutputs({
|
|
217
|
-
awsAccountId: getAwsAccountId(app),
|
|
218
|
-
region: aws.config.region,
|
|
219
|
-
cognitoUserPoolId: core.cognitoUserPoolId,
|
|
220
|
-
cognitoAppClientId: core.cognitoAppClientId,
|
|
221
|
-
cognitoUserPoolPasswordPolicy: core.cognitoUserPoolPasswordPolicy,
|
|
222
|
-
dynamoDbTable: core.primaryDynamodbTableName,
|
|
223
|
-
auditLogsDynamoDbTable: core.auditLogsDynamodbTableName,
|
|
224
|
-
graphqlLambdaName: graphql.functions.graphql.output.name,
|
|
225
|
-
graphqlLambdaRole: graphql.role.output.arn,
|
|
226
|
-
graphqlLambdaRoleName: graphql.role.output.name,
|
|
227
|
-
backgroundTaskLambdaArn: backgroundTask.backgroundTask.output.arn,
|
|
228
|
-
backgroundTaskStepFunctionArn: backgroundTask.stepFunction.output.arn,
|
|
229
|
-
fileManagerDownloadLambdaArn: fileManager.functions.download.output.arn,
|
|
230
|
-
websocketApiId: websocket.websocketApi.output.id,
|
|
231
|
-
websocketApiUrl: websocket.websocketApiUrl,
|
|
232
|
-
schedulerLambdaInvokeRole: scheduler.invokeRole.output.arn
|
|
233
|
-
});
|
|
234
|
-
|
|
235
|
-
// Only add `dynamoDbOpensearchTable` output if using search engine (ES/OS).
|
|
236
|
-
if (searchEngineParams) {
|
|
237
|
-
app.addOutputs({
|
|
238
|
-
dynamoDbOpensearchTable: core.opensearchDynamodbTableName
|
|
205
|
+
});
|
|
206
|
+
const app = withServiceManifest(withCommonLambdaEnvVariables(baseApp));
|
|
207
|
+
app.addHandler(()=>{
|
|
208
|
+
app.addServiceManifest({
|
|
209
|
+
name: "api",
|
|
210
|
+
manifest: {
|
|
211
|
+
bgTaskSfn: baseApp.resources.backgroundTask.stepFunction.output.arn,
|
|
212
|
+
cloudfront: {
|
|
213
|
+
distributionId: baseApp.resources.cloudfront.output.id,
|
|
214
|
+
domain: baseApp.resources.cloudfront.output.domainName.apply((v)=>`https://${v}`)
|
|
215
|
+
}
|
|
216
|
+
}
|
|
239
217
|
});
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
distributionDomain: "cloudfrontApiDomain",
|
|
247
|
-
distributionUrl: "cloudfrontApiUrl",
|
|
248
|
-
usedDomain: "apiDomain",
|
|
249
|
-
usedUrl: "apiUrl"
|
|
250
|
-
}
|
|
218
|
+
app.addServiceManifest({
|
|
219
|
+
name: "scheduler",
|
|
220
|
+
manifest: {
|
|
221
|
+
lambdaArn: baseApp.resources.graphql.functions.graphql.output.arn,
|
|
222
|
+
roleArn: baseApp.resources.scheduler.invokeRole.output.arn
|
|
223
|
+
}
|
|
251
224
|
});
|
|
252
|
-
});
|
|
253
|
-
// /**
|
|
254
|
-
// * We need to attach the Sync System if it exists.
|
|
255
|
-
// */
|
|
256
|
-
// await attachSyncSystem({
|
|
257
|
-
// app,
|
|
258
|
-
// core,
|
|
259
|
-
// env: app.params.run.env
|
|
260
|
-
// });
|
|
261
|
-
|
|
262
|
-
// Applies internal and user-defined AWS tags.
|
|
263
|
-
await applyAwsResourceTags("api");
|
|
264
|
-
return {
|
|
265
|
-
fileManager,
|
|
266
|
-
graphql,
|
|
267
|
-
apiGateway,
|
|
268
|
-
websocket,
|
|
269
|
-
cloudfront,
|
|
270
|
-
backgroundTask,
|
|
271
|
-
scheduler
|
|
272
|
-
};
|
|
273
|
-
}
|
|
274
|
-
});
|
|
275
|
-
const app = withServiceManifest(withCommonLambdaEnvVariables(baseApp));
|
|
276
|
-
app.addHandler(() => {
|
|
277
|
-
app.addServiceManifest({
|
|
278
|
-
name: "api",
|
|
279
|
-
manifest: {
|
|
280
|
-
bgTaskSfn: baseApp.resources.backgroundTask.stepFunction.output.arn,
|
|
281
|
-
cloudfront: {
|
|
282
|
-
distributionId: baseApp.resources.cloudfront.output.id,
|
|
283
|
-
domain: baseApp.resources.cloudfront.output.domainName.apply(v => `https://${v}`)
|
|
284
|
-
}
|
|
285
|
-
}
|
|
286
|
-
});
|
|
287
|
-
app.addServiceManifest({
|
|
288
|
-
name: "scheduler",
|
|
289
|
-
manifest: {
|
|
290
|
-
lambdaArn: baseApp.resources.graphql.functions.graphql.output.arn,
|
|
291
|
-
roleArn: baseApp.resources.scheduler.invokeRole.output.arn
|
|
292
|
-
}
|
|
293
225
|
});
|
|
294
|
-
|
|
295
|
-
return app;
|
|
226
|
+
return app;
|
|
296
227
|
};
|
|
228
|
+
export { createApiPulumiApp };
|
|
297
229
|
|
|
298
230
|
//# sourceMappingURL=createApiPulumiApp.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["aws","createPulumiApp","isResourceOfType","ApiBackgroundTask","ApiCloudfront","ApiFileManager","ApiGateway","ApiGraphql","ApiWebsocket","CoreOutput","VpcConfig","addDomainsUrlsOutputs","withCommonLambdaEnvVariables","withServiceManifest","getEnvVariableAwsRegion","applyAwsResourceTags","getAwsAccountId","ApiScheduler","getProjectSdk","getVpcConfigFromExtension","getOsConfigFromExtension","handleGuardDutyEvents","ApiPulumi","apiPulumi","ApiCustomDomains","apiCustomDomainsExt","applyCustomDomain","createApiPulumiApp","baseApp","name","path","program","app","sdk","projectConfig","getProjectConfig","pulumiResourceNamePrefix","getPulumiResourceNamePrefix","vpcExtensionsConfig","openSearchExtensionConfig","searchEngineParams","params","endpoint","process","env","OPENSEARCH_ENDPOINT","domainName","AWS_OS_DOMAIN_NAME","indexPrefix","OPENSEARCH_INDEX_PREFIX","sharedIndexes","OPENSEARCH_SHARED_INDEXES","username","OPENSEARCH_USERNAME","password","OPENSEARCH_PASSWORD","onResource","resource","startsWith","addHandler","featureFlags","getFeatureFlags","usingAdvancedVpcParams","isFileManagerThreatDetectionEnabled","addResource","useExistingVpc","lambdaFunctionsVpcConfig","Error","lambda","Function","canUseVpc","meta","config","vpcConfig","iam","Role","isLambdaFunctionRole","RolePolicyAttachment","role","output","policyArn","ManagedPolicy","AWSLambdaVPCAccessExecutionRole","getContainer","registerComposite","pulumiHandlers","resolve","execute","isProduction","core","addModule","vpcEnabled","enabled","graphql","COGNITO_REGION","COGNITO_USER_POOL_ID","cognitoUserPoolId","DB_TABLE","primaryDynamodbTableName","DB_TABLE_AUDIT_LOGS","auditLogsDynamodbTableName","DB_TABLE_OPENSEARCH","opensearchDynamodbTableName","opensearchDomainEndpoint","S3_BUCKET","fileManagerBucketId","EVENT_BUS","eventBusArn","OKTA_ISSUER","websocket","fileManager","apiGateway","method","function","functions","arn","download","cloudfront","backgroundTask","scheduler","apiCustomDomains","extensionsByType","domains","sslMethod","certificateArn","sslSupportMethod","acmCertificateArn","addOutputs","awsAccountId","region","cognitoAppClientId","cognitoUserPoolPasswordPolicy","dynamoDbTable","auditLogsDynamoDbTable","graphqlLambdaName","graphqlLambdaRole","graphqlLambdaRoleName","backgroundTaskLambdaArn","backgroundTaskStepFunctionArn","stepFunction","fileManagerDownloadLambdaArn","websocketApiId","websocketApi","id","websocketApiUrl","schedulerLambdaInvokeRole","invokeRole","dynamoDbOpensearchTable","cloudfrontDistribution","map","distributionDomain","distributionUrl","usedDomain","usedUrl","addServiceManifest","manifest","bgTaskSfn","resources","distributionId","domain","apply","v","lambdaArn","roleArn"],"sources":["createApiPulumiApp.ts"],"sourcesContent":["import * as aws from \"@pulumi/aws\";\nimport { createPulumiApp, isResourceOfType, type PulumiApp } from \"@webiny/pulumi\";\nimport {\n ApiBackgroundTask,\n ApiCloudfront,\n ApiFileManager,\n ApiGateway,\n ApiGraphql,\n ApiWebsocket,\n CoreOutput,\n VpcConfig\n} from \"~/pulumi/apps/index.js\";\nimport {\n addDomainsUrlsOutputs,\n withCommonLambdaEnvVariables,\n withServiceManifest\n} from \"~/pulumi/utils/index.js\";\nimport { getEnvVariableAwsRegion } from \"~/pulumi/env/awsRegion.js\";\n// import { attachSyncSystem } from \"../syncSystem/api/index.js\";\nimport { applyAwsResourceTags, getAwsAccountId } from \"~/pulumi/apps/awsUtils.js\";\nimport type { WithServiceManifest } from \"~/pulumi/utils/withServiceManifest.js\";\nimport { ApiScheduler } from \"~/pulumi/apps/api/ApiScheduler.js\";\nimport { getProjectSdk } from \"@webiny/project\";\nimport { getVpcConfigFromExtension } from \"~/pulumi/apps/extensions/getVpcConfigFromExtension.js\";\nimport { getOsConfigFromExtension } from \"~/pulumi/apps/extensions/getOsConfigFromExtension.js\";\nimport { handleGuardDutyEvents } from \"./handleGuardDutyEvents.js\";\nimport { ApiPulumi } from \"~/abstractions/features/pulumi/index.js\";\nimport { apiPulumi } from \"~/pulumi/features/ApiPulumi/index.js\";\nimport { ApiCustomDomains as apiCustomDomainsExt } from \"~/pulumi/extensions/ApiCustomDomains.js\";\nimport { applyCustomDomain } from \"~/pulumi/apps/customDomain.js\";\n\nexport type ApiPulumiApp = ReturnType<typeof createApiPulumiApp>;\n\nexport const createApiPulumiApp = () => {\n const baseApp = createPulumiApp({\n name: \"api\",\n path: \"apps/api\",\n program: async (app: PulumiApp & WithServiceManifest) => {\n const sdk = await getProjectSdk();\n const projectConfig = await sdk.getProjectConfig();\n\n const pulumiResourceNamePrefix = await sdk.getPulumiResourceNamePrefix();\n const vpcExtensionsConfig = getVpcConfigFromExtension(projectConfig);\n const openSearchExtensionConfig = getOsConfigFromExtension(projectConfig);\n\n let searchEngineParams: typeof openSearchExtensionConfig | null = null;\n\n if (openSearchExtensionConfig) {\n searchEngineParams = openSearchExtensionConfig;\n }\n\n if (searchEngineParams) {\n const params = searchEngineParams;\n if (typeof params === \"object\") {\n if (params.endpoint) {\n process.env.OPENSEARCH_ENDPOINT = params.endpoint;\n }\n\n if (params.domainName) {\n process.env.AWS_OS_DOMAIN_NAME = params.domainName;\n }\n\n if (params.indexPrefix) {\n process.env.OPENSEARCH_INDEX_PREFIX = params.indexPrefix;\n }\n\n if (params.sharedIndexes) {\n process.env.OPENSEARCH_SHARED_INDEXES = \"true\";\n }\n\n if (params.username) {\n process.env.OPENSEARCH_USERNAME = params.username;\n }\n\n if (params.password) {\n process.env.OPENSEARCH_PASSWORD = params.password;\n }\n }\n }\n\n if (pulumiResourceNamePrefix) {\n app.onResource(resource => {\n if (!resource.name.startsWith(pulumiResourceNamePrefix)) {\n resource.name = `${pulumiResourceNamePrefix}${resource.name}`;\n }\n });\n }\n\n // <-------------------- Enterprise start -------------------->\n app.addHandler(async () => {\n const featureFlags = await sdk.getFeatureFlags();\n\n const usingAdvancedVpcParams =\n vpcExtensionsConfig && typeof vpcExtensionsConfig !== \"boolean\";\n\n if (featureFlags.isFileManagerThreatDetectionEnabled()) {\n handleGuardDutyEvents(app as ApiPulumiApp);\n }\n\n // Not using advanced VPC params? Then immediately exit.\n if (usingAdvancedVpcParams) {\n const { onResource, addResource } = app;\n const { useExistingVpc } = vpcExtensionsConfig;\n\n // 1. We first deal with \"existing VPC\" setup.\n if (useExistingVpc) {\n if (!useExistingVpc.lambdaFunctionsVpcConfig) {\n throw new Error(\n \"Cannot specify `useExistingVpc` parameter because the `lambdaFunctionsVpcConfig` parameter wasn't provided.\"\n );\n }\n\n onResource(resource => {\n if (isResourceOfType(resource, aws.lambda.Function)) {\n const canUseVpc = resource.meta.canUseVpc !== false;\n if (canUseVpc) {\n resource.config.vpcConfig(\n useExistingVpc!.lambdaFunctionsVpcConfig\n );\n }\n }\n\n if (isResourceOfType(resource, aws.iam.Role)) {\n if (resource.meta.isLambdaFunctionRole) {\n addResource(aws.iam.RolePolicyAttachment, {\n name: `${resource.name}-vpc-access-execution-role`,\n config: {\n role: resource.output.name,\n policyArn:\n aws.iam.ManagedPolicy\n .AWSLambdaVPCAccessExecutionRole\n }\n });\n }\n }\n });\n }\n }\n });\n // <-------------------- Enterprise end -------------------->\n\n // Overrides must be applied via a handler, registered at the very start of the program.\n // By doing this, we're ensuring user's adjustments are not applied to late.\n sdk.getContainer().registerComposite(apiPulumi);\n const pulumiHandlers = sdk.getContainer().resolve(ApiPulumi);\n\n app.addHandler(() => {\n return pulumiHandlers.execute(app as ApiPulumiApp);\n });\n\n const isProduction = app.env.isProduction;\n\n // Register core output as a module available to all the other modules\n const core = app.addModule(CoreOutput);\n\n // Register VPC config module to be available to other modules.\n const vpcEnabled =\n vpcExtensionsConfig === true ||\n typeof vpcExtensionsConfig === \"object\" ||\n isProduction;\n\n app.addModule(VpcConfig, { enabled: vpcEnabled });\n\n const graphql = app.addModule(ApiGraphql, {\n env: {\n COGNITO_REGION: getEnvVariableAwsRegion(),\n COGNITO_USER_POOL_ID: core.cognitoUserPoolId,\n DB_TABLE: core.primaryDynamodbTableName,\n DB_TABLE_AUDIT_LOGS: core.auditLogsDynamodbTableName,\n DB_TABLE_OPENSEARCH: core.opensearchDynamodbTableName,\n OPENSEARCH_ENDPOINT: core.opensearchDomainEndpoint,\n\n // Not required. Useful for testing purposes / ephemeral environments.\n // https://www.webiny.com/docs/key-topics/ci-cd/testing/slow-ephemeral-environments\n OPENSEARCH_INDEX_PREFIX: process.env.OPENSEARCH_INDEX_PREFIX,\n OPENSEARCH_SHARED_INDEXES: process.env.OPENSEARCH_SHARED_INDEXES,\n OPENSEARCH_USERNAME: process.env.OPENSEARCH_USERNAME,\n OPENSEARCH_PASSWORD: process.env.OPENSEARCH_PASSWORD,\n\n S3_BUCKET: core.fileManagerBucketId,\n EVENT_BUS: core.eventBusArn,\n // TODO: move to okta plugin\n OKTA_ISSUER: process.env[\"OKTA_ISSUER\"]\n }\n });\n\n const websocket = app.addModule(ApiWebsocket);\n\n const fileManager = app.addModule(ApiFileManager, {\n env: {\n DB_TABLE: core.primaryDynamodbTableName,\n DB_TABLE_AUDIT_LOGS: core.auditLogsDynamodbTableName\n }\n });\n\n const apiGateway = app.addModule(ApiGateway, {\n \"graphql-post\": {\n path: \"/graphql\",\n method: \"POST\",\n function: graphql.functions.graphql.output.arn\n },\n \"graphql-options\": {\n path: \"/graphql\",\n method: \"OPTIONS\",\n function: graphql.functions.graphql.output.arn\n },\n \"files-any\": {\n path: \"/files/{path+}\",\n method: \"ANY\",\n function: fileManager.functions.download.output.arn\n },\n \"private-any\": {\n path: \"/private/{path+}\",\n method: \"ANY\",\n function: fileManager.functions.download.output.arn\n },\n \"cms-post\": {\n path: \"/cms/{key+}\",\n method: \"POST\",\n function: graphql.functions.graphql.output.arn\n },\n \"cms-options\": {\n path: \"/cms/{key+}\",\n method: \"OPTIONS\",\n function: graphql.functions.graphql.output.arn\n },\n \"redirects-get\": {\n path: \"/wb/redirects\",\n method: \"GET\",\n function: graphql.functions.graphql.output.arn\n },\n \"redirects-options\": {\n path: \"/wb/redirects\",\n method: \"OPTIONS\",\n function: graphql.functions.graphql.output.arn\n },\n \"files-catch-all\": {\n path: \"/{path+}\",\n method: \"ANY\",\n function: fileManager.functions.download.output.arn\n }\n });\n\n const cloudfront = app.addModule(ApiCloudfront);\n const backgroundTask = app.addModule(ApiBackgroundTask);\n const scheduler = app.addModule(ApiScheduler);\n\n const [apiCustomDomains] = projectConfig.extensionsByType(apiCustomDomainsExt);\n if (apiCustomDomains) {\n const { domains, sslMethod, certificateArn } = apiCustomDomains.params;\n applyCustomDomain(cloudfront, {\n domains,\n sslSupportMethod: sslMethod,\n acmCertificateArn: certificateArn\n });\n }\n\n app.addOutputs({\n awsAccountId: getAwsAccountId(app),\n region: aws.config.region,\n cognitoUserPoolId: core.cognitoUserPoolId,\n cognitoAppClientId: core.cognitoAppClientId,\n cognitoUserPoolPasswordPolicy: core.cognitoUserPoolPasswordPolicy,\n dynamoDbTable: core.primaryDynamodbTableName,\n auditLogsDynamoDbTable: core.auditLogsDynamodbTableName,\n graphqlLambdaName: graphql.functions.graphql.output.name,\n graphqlLambdaRole: graphql.role.output.arn,\n graphqlLambdaRoleName: graphql.role.output.name,\n backgroundTaskLambdaArn: backgroundTask.backgroundTask.output.arn,\n backgroundTaskStepFunctionArn: backgroundTask.stepFunction.output.arn,\n fileManagerDownloadLambdaArn: fileManager.functions.download.output.arn,\n websocketApiId: websocket.websocketApi.output.id,\n websocketApiUrl: websocket.websocketApiUrl,\n schedulerLambdaInvokeRole: scheduler.invokeRole.output.arn\n });\n\n // Only add `dynamoDbOpensearchTable` output if using search engine (ES/OS).\n if (searchEngineParams) {\n app.addOutputs({\n dynamoDbOpensearchTable: core.opensearchDynamodbTableName\n });\n }\n\n app.addHandler(() => {\n addDomainsUrlsOutputs({\n app,\n cloudfrontDistribution: cloudfront,\n map: {\n distributionDomain: \"cloudfrontApiDomain\",\n distributionUrl: \"cloudfrontApiUrl\",\n usedDomain: \"apiDomain\",\n usedUrl: \"apiUrl\"\n }\n });\n });\n // /**\n // * We need to attach the Sync System if it exists.\n // */\n // await attachSyncSystem({\n // app,\n // core,\n // env: app.params.run.env\n // });\n\n // Applies internal and user-defined AWS tags.\n await applyAwsResourceTags(\"api\");\n\n return {\n fileManager,\n graphql,\n apiGateway,\n websocket,\n cloudfront,\n backgroundTask,\n scheduler\n };\n }\n });\n\n const app = withServiceManifest(withCommonLambdaEnvVariables(baseApp));\n\n app.addHandler(() => {\n app.addServiceManifest({\n name: \"api\",\n manifest: {\n bgTaskSfn: baseApp.resources.backgroundTask.stepFunction.output.arn,\n cloudfront: {\n distributionId: baseApp.resources.cloudfront.output.id,\n domain: baseApp.resources.cloudfront.output.domainName.apply(\n v => `https://${v}`\n )\n }\n }\n });\n\n app.addServiceManifest({\n name: \"scheduler\",\n manifest: {\n lambdaArn: baseApp.resources.graphql.functions.graphql.output.arn,\n roleArn: baseApp.resources.scheduler.invokeRole.output.arn\n }\n });\n });\n\n return app;\n};\n"],"mappings":"AAAA,OAAO,KAAKA,GAAG,MAAM,aAAa;AAClC,SAASC,eAAe,EAAEC,gBAAgB,QAAwB,gBAAgB;AAClF,SACIC,iBAAiB,EACjBC,aAAa,EACbC,cAAc,EACdC,UAAU,EACVC,UAAU,EACVC,YAAY,EACZC,UAAU,EACVC,SAAS;AAEb,SACIC,qBAAqB,EACrBC,4BAA4B,EAC5BC,mBAAmB;AAEvB,SAASC,uBAAuB;AAChC;AACA,SAASC,oBAAoB,EAAEC,eAAe;AAE9C,SAASC,YAAY;AACrB,SAASC,aAAa,QAAQ,iBAAiB;AAC/C,SAASC,yBAAyB;AAClC,SAASC,wBAAwB;AACjC,SAASC,qBAAqB;AAC9B,SAASC,SAAS;AAClB,SAASC,SAAS;AAClB,SAASC,gBAAgB,IAAIC,mBAAmB;AAChD,SAASC,iBAAiB;AAI1B,OAAO,MAAMC,kBAAkB,GAAGA,CAAA,KAAM;EACpC,MAAMC,OAAO,GAAG3B,eAAe,CAAC;IAC5B4B,IAAI,EAAE,KAAK;IACXC,IAAI,EAAE,UAAU;IAChBC,OAAO,EAAE,MAAOC,GAAoC,IAAK;MACrD,MAAMC,GAAG,GAAG,MAAMf,aAAa,CAAC,CAAC;MACjC,MAAMgB,aAAa,GAAG,MAAMD,GAAG,CAACE,gBAAgB,CAAC,CAAC;MAElD,MAAMC,wBAAwB,GAAG,MAAMH,GAAG,CAACI,2BAA2B,CAAC,CAAC;MACxE,MAAMC,mBAAmB,GAAGnB,yBAAyB,CAACe,aAAa,CAAC;MACpE,MAAMK,yBAAyB,GAAGnB,wBAAwB,CAACc,aAAa,CAAC;MAEzE,IAAIM,kBAA2D,GAAG,IAAI;MAEtE,IAAID,yBAAyB,EAAE;QAC3BC,kBAAkB,GAAGD,yBAAyB;MAClD;MAEA,IAAIC,kBAAkB,EAAE;QACpB,MAAMC,MAAM,GAAGD,kBAAkB;QACjC,IAAI,OAAOC,MAAM,KAAK,QAAQ,EAAE;UAC5B,IAAIA,MAAM,CAACC,QAAQ,EAAE;YACjBC,OAAO,CAACC,GAAG,CAACC,mBAAmB,GAAGJ,MAAM,CAACC,QAAQ;UACrD;UAEA,IAAID,MAAM,CAACK,UAAU,EAAE;YACnBH,OAAO,CAACC,GAAG,CAACG,kBAAkB,GAAGN,MAAM,CAACK,UAAU;UACtD;UAEA,IAAIL,MAAM,CAACO,WAAW,EAAE;YACpBL,OAAO,CAACC,GAAG,CAACK,uBAAuB,GAAGR,MAAM,CAACO,WAAW;UAC5D;UAEA,IAAIP,MAAM,CAACS,aAAa,EAAE;YACtBP,OAAO,CAACC,GAAG,CAACO,yBAAyB,GAAG,MAAM;UAClD;UAEA,IAAIV,MAAM,CAACW,QAAQ,EAAE;YACjBT,OAAO,CAACC,GAAG,CAACS,mBAAmB,GAAGZ,MAAM,CAACW,QAAQ;UACrD;UAEA,IAAIX,MAAM,CAACa,QAAQ,EAAE;YACjBX,OAAO,CAACC,GAAG,CAACW,mBAAmB,GAAGd,MAAM,CAACa,QAAQ;UACrD;QACJ;MACJ;MAEA,IAAIlB,wBAAwB,EAAE;QAC1BJ,GAAG,CAACwB,UAAU,CAACC,QAAQ,IAAI;UACvB,IAAI,CAACA,QAAQ,CAAC5B,IAAI,CAAC6B,UAAU,CAACtB,wBAAwB,CAAC,EAAE;YACrDqB,QAAQ,CAAC5B,IAAI,GAAG,GAAGO,wBAAwB,GAAGqB,QAAQ,CAAC5B,IAAI,EAAE;UACjE;QACJ,CAAC,CAAC;MACN;;MAEA;MACAG,GAAG,CAAC2B,UAAU,CAAC,YAAY;QACvB,MAAMC,YAAY,GAAG,MAAM3B,GAAG,CAAC4B,eAAe,CAAC,CAAC;QAEhD,MAAMC,sBAAsB,GACxBxB,mBAAmB,IAAI,OAAOA,mBAAmB,KAAK,SAAS;QAEnE,IAAIsB,YAAY,CAACG,mCAAmC,CAAC,CAAC,EAAE;UACpD1C,qBAAqB,CAACW,GAAmB,CAAC;QAC9C;;QAEA;QACA,IAAI8B,sBAAsB,EAAE;UACxB,MAAM;YAAEN,UAAU;YAAEQ;UAAY,CAAC,GAAGhC,GAAG;UACvC,MAAM;YAAEiC;UAAe,CAAC,GAAG3B,mBAAmB;;UAE9C;UACA,IAAI2B,cAAc,EAAE;YAChB,IAAI,CAACA,cAAc,CAACC,wBAAwB,EAAE;cAC1C,MAAM,IAAIC,KAAK,CACX,6GACJ,CAAC;YACL;YAEAX,UAAU,CAACC,QAAQ,IAAI;cACnB,IAAIvD,gBAAgB,CAACuD,QAAQ,EAAEzD,GAAG,CAACoE,MAAM,CAACC,QAAQ,CAAC,EAAE;gBACjD,MAAMC,SAAS,GAAGb,QAAQ,CAACc,IAAI,CAACD,SAAS,KAAK,KAAK;gBACnD,IAAIA,SAAS,EAAE;kBACXb,QAAQ,CAACe,MAAM,CAACC,SAAS,CACrBR,cAAc,CAAEC,wBACpB,CAAC;gBACL;cACJ;cAEA,IAAIhE,gBAAgB,CAACuD,QAAQ,EAAEzD,GAAG,CAAC0E,GAAG,CAACC,IAAI,CAAC,EAAE;gBAC1C,IAAIlB,QAAQ,CAACc,IAAI,CAACK,oBAAoB,EAAE;kBACpCZ,WAAW,CAAChE,GAAG,CAAC0E,GAAG,CAACG,oBAAoB,EAAE;oBACtChD,IAAI,EAAE,GAAG4B,QAAQ,CAAC5B,IAAI,4BAA4B;oBAClD2C,MAAM,EAAE;sBACJM,IAAI,EAAErB,QAAQ,CAACsB,MAAM,CAAClD,IAAI;sBAC1BmD,SAAS,EACLhF,GAAG,CAAC0E,GAAG,CAACO,aAAa,CAChBC;oBACb;kBACJ,CAAC,CAAC;gBACN;cACJ;YACJ,CAAC,CAAC;UACN;QACJ;MACJ,CAAC,CAAC;MACF;;MAEA;MACA;MACAjD,GAAG,CAACkD,YAAY,CAAC,CAAC,CAACC,iBAAiB,CAAC7D,SAAS,CAAC;MAC/C,MAAM8D,cAAc,GAAGpD,GAAG,CAACkD,YAAY,CAAC,CAAC,CAACG,OAAO,CAAChE,SAAS,CAAC;MAE5DU,GAAG,CAAC2B,UAAU,CAAC,MAAM;QACjB,OAAO0B,cAAc,CAACE,OAAO,CAACvD,GAAmB,CAAC;MACtD,CAAC,CAAC;MAEF,MAAMwD,YAAY,GAAGxD,GAAG,CAACY,GAAG,CAAC4C,YAAY;;MAEzC;MACA,MAAMC,IAAI,GAAGzD,GAAG,CAAC0D,SAAS,CAACjF,UAAU,CAAC;;MAEtC;MACA,MAAMkF,UAAU,GACZrD,mBAAmB,KAAK,IAAI,IAC5B,OAAOA,mBAAmB,KAAK,QAAQ,IACvCkD,YAAY;MAEhBxD,GAAG,CAAC0D,SAAS,CAAChF,SAAS,EAAE;QAAEkF,OAAO,EAAED;MAAW,CAAC,CAAC;MAEjD,MAAME,OAAO,GAAG7D,GAAG,CAAC0D,SAAS,CAACnF,UAAU,EAAE;QACtCqC,GAAG,EAAE;UACDkD,cAAc,EAAEhF,uBAAuB,CAAC,CAAC;UACzCiF,oBAAoB,EAAEN,IAAI,CAACO,iBAAiB;UAC5CC,QAAQ,EAAER,IAAI,CAACS,wBAAwB;UACvCC,mBAAmB,EAAEV,IAAI,CAACW,0BAA0B;UACpDC,mBAAmB,EAAEZ,IAAI,CAACa,2BAA2B;UACrDzD,mBAAmB,EAAE4C,IAAI,CAACc,wBAAwB;UAElD;UACA;UACAtD,uBAAuB,EAAEN,OAAO,CAACC,GAAG,CAACK,uBAAuB;UAC5DE,yBAAyB,EAAER,OAAO,CAACC,GAAG,CAACO,yBAAyB;UAChEE,mBAAmB,EAAEV,OAAO,CAACC,GAAG,CAACS,mBAAmB;UACpDE,mBAAmB,EAAEZ,OAAO,CAACC,GAAG,CAACW,mBAAmB;UAEpDiD,SAAS,EAAEf,IAAI,CAACgB,mBAAmB;UACnCC,SAAS,EAAEjB,IAAI,CAACkB,WAAW;UAC3B;UACAC,WAAW,EAAEjE,OAAO,CAACC,GAAG,CAAC,aAAa;QAC1C;MACJ,CAAC,CAAC;MAEF,MAAMiE,SAAS,GAAG7E,GAAG,CAAC0D,SAAS,CAAClF,YAAY,CAAC;MAE7C,MAAMsG,WAAW,GAAG9E,GAAG,CAAC0D,SAAS,CAACrF,cAAc,EAAE;QAC9CuC,GAAG,EAAE;UACDqD,QAAQ,EAAER,IAAI,CAACS,wBAAwB;UACvCC,mBAAmB,EAAEV,IAAI,CAACW;QAC9B;MACJ,CAAC,CAAC;MAEF,MAAMW,UAAU,GAAG/E,GAAG,CAAC0D,SAAS,CAACpF,UAAU,EAAE;QACzC,cAAc,EAAE;UACZwB,IAAI,EAAE,UAAU;UAChBkF,MAAM,EAAE,MAAM;UACdC,QAAQ,EAAEpB,OAAO,CAACqB,SAAS,CAACrB,OAAO,CAACd,MAAM,CAACoC;QAC/C,CAAC;QACD,iBAAiB,EAAE;UACfrF,IAAI,EAAE,UAAU;UAChBkF,MAAM,EAAE,SAAS;UACjBC,QAAQ,EAAEpB,OAAO,CAACqB,SAAS,CAACrB,OAAO,CAACd,MAAM,CAACoC;QAC/C,CAAC;QACD,WAAW,EAAE;UACTrF,IAAI,EAAE,gBAAgB;UACtBkF,MAAM,EAAE,KAAK;UACbC,QAAQ,EAAEH,WAAW,CAACI,SAAS,CAACE,QAAQ,CAACrC,MAAM,CAACoC;QACpD,CAAC;QACD,aAAa,EAAE;UACXrF,IAAI,EAAE,kBAAkB;UACxBkF,MAAM,EAAE,KAAK;UACbC,QAAQ,EAAEH,WAAW,CAACI,SAAS,CAACE,QAAQ,CAACrC,MAAM,CAACoC;QACpD,CAAC;QACD,UAAU,EAAE;UACRrF,IAAI,EAAE,aAAa;UACnBkF,MAAM,EAAE,MAAM;UACdC,QAAQ,EAAEpB,OAAO,CAACqB,SAAS,CAACrB,OAAO,CAACd,MAAM,CAACoC;QAC/C,CAAC;QACD,aAAa,EAAE;UACXrF,IAAI,EAAE,aAAa;UACnBkF,MAAM,EAAE,SAAS;UACjBC,QAAQ,EAAEpB,OAAO,CAACqB,SAAS,CAACrB,OAAO,CAACd,MAAM,CAACoC;QAC/C,CAAC;QACD,eAAe,EAAE;UACbrF,IAAI,EAAE,eAAe;UACrBkF,MAAM,EAAE,KAAK;UACbC,QAAQ,EAAEpB,OAAO,CAACqB,SAAS,CAACrB,OAAO,CAACd,MAAM,CAACoC;QAC/C,CAAC;QACD,mBAAmB,EAAE;UACjBrF,IAAI,EAAE,eAAe;UACrBkF,MAAM,EAAE,SAAS;UACjBC,QAAQ,EAAEpB,OAAO,CAACqB,SAAS,CAACrB,OAAO,CAACd,MAAM,CAACoC;QAC/C,CAAC;QACD,iBAAiB,EAAE;UACfrF,IAAI,EAAE,UAAU;UAChBkF,MAAM,EAAE,KAAK;UACbC,QAAQ,EAAEH,WAAW,CAACI,SAAS,CAACE,QAAQ,CAACrC,MAAM,CAACoC;QACpD;MACJ,CAAC,CAAC;MAEF,MAAME,UAAU,GAAGrF,GAAG,CAAC0D,SAAS,CAACtF,aAAa,CAAC;MAC/C,MAAMkH,cAAc,GAAGtF,GAAG,CAAC0D,SAAS,CAACvF,iBAAiB,CAAC;MACvD,MAAMoH,SAAS,GAAGvF,GAAG,CAAC0D,SAAS,CAACzE,YAAY,CAAC;MAE7C,MAAM,CAACuG,gBAAgB,CAAC,GAAGtF,aAAa,CAACuF,gBAAgB,CAAChG,mBAAmB,CAAC;MAC9E,IAAI+F,gBAAgB,EAAE;QAClB,MAAM;UAAEE,OAAO;UAAEC,SAAS;UAAEC;QAAe,CAAC,GAAGJ,gBAAgB,CAAC/E,MAAM;QACtEf,iBAAiB,CAAC2F,UAAU,EAAE;UAC1BK,OAAO;UACPG,gBAAgB,EAAEF,SAAS;UAC3BG,iBAAiB,EAAEF;QACvB,CAAC,CAAC;MACN;MAEA5F,GAAG,CAAC+F,UAAU,CAAC;QACXC,YAAY,EAAEhH,eAAe,CAACgB,GAAG,CAAC;QAClCiG,MAAM,EAAEjI,GAAG,CAACwE,MAAM,CAACyD,MAAM;QACzBjC,iBAAiB,EAAEP,IAAI,CAACO,iBAAiB;QACzCkC,kBAAkB,EAAEzC,IAAI,CAACyC,kBAAkB;QAC3CC,6BAA6B,EAAE1C,IAAI,CAAC0C,6BAA6B;QACjEC,aAAa,EAAE3C,IAAI,CAACS,wBAAwB;QAC5CmC,sBAAsB,EAAE5C,IAAI,CAACW,0BAA0B;QACvDkC,iBAAiB,EAAEzC,OAAO,CAACqB,SAAS,CAACrB,OAAO,CAACd,MAAM,CAAClD,IAAI;QACxD0G,iBAAiB,EAAE1C,OAAO,CAACf,IAAI,CAACC,MAAM,CAACoC,GAAG;QAC1CqB,qBAAqB,EAAE3C,OAAO,CAACf,IAAI,CAACC,MAAM,CAAClD,IAAI;QAC/C4G,uBAAuB,EAAEnB,cAAc,CAACA,cAAc,CAACvC,MAAM,CAACoC,GAAG;QACjEuB,6BAA6B,EAAEpB,cAAc,CAACqB,YAAY,CAAC5D,MAAM,CAACoC,GAAG;QACrEyB,4BAA4B,EAAE9B,WAAW,CAACI,SAAS,CAACE,QAAQ,CAACrC,MAAM,CAACoC,GAAG;QACvE0B,cAAc,EAAEhC,SAAS,CAACiC,YAAY,CAAC/D,MAAM,CAACgE,EAAE;QAChDC,eAAe,EAAEnC,SAAS,CAACmC,eAAe;QAC1CC,yBAAyB,EAAE1B,SAAS,CAAC2B,UAAU,CAACnE,MAAM,CAACoC;MAC3D,CAAC,CAAC;;MAEF;MACA,IAAI3E,kBAAkB,EAAE;QACpBR,GAAG,CAAC+F,UAAU,CAAC;UACXoB,uBAAuB,EAAE1D,IAAI,CAACa;QAClC,CAAC,CAAC;MACN;MAEAtE,GAAG,CAAC2B,UAAU,CAAC,MAAM;QACjBhD,qBAAqB,CAAC;UAClBqB,GAAG;UACHoH,sBAAsB,EAAE/B,UAAU;UAClCgC,GAAG,EAAE;YACDC,kBAAkB,EAAE,qBAAqB;YACzCC,eAAe,EAAE,kBAAkB;YACnCC,UAAU,EAAE,WAAW;YACvBC,OAAO,EAAE;UACb;QACJ,CAAC,CAAC;MACN,CAAC,CAAC;MACF;MACA;MACA;MACA;MACA;MACA;MACA;MACA;;MAEA;MACA,MAAM1I,oBAAoB,CAAC,KAAK,CAAC;MAEjC,OAAO;QACH+F,WAAW;QACXjB,OAAO;QACPkB,UAAU;QACVF,SAAS;QACTQ,UAAU;QACVC,cAAc;QACdC;MACJ,CAAC;IACL;EACJ,CAAC,CAAC;EAEF,MAAMvF,GAAG,GAAGnB,mBAAmB,CAACD,4BAA4B,CAACgB,OAAO,CAAC,CAAC;EAEtEI,GAAG,CAAC2B,UAAU,CAAC,MAAM;IACjB3B,GAAG,CAAC0H,kBAAkB,CAAC;MACnB7H,IAAI,EAAE,KAAK;MACX8H,QAAQ,EAAE;QACNC,SAAS,EAAEhI,OAAO,CAACiI,SAAS,CAACvC,cAAc,CAACqB,YAAY,CAAC5D,MAAM,CAACoC,GAAG;QACnEE,UAAU,EAAE;UACRyC,cAAc,EAAElI,OAAO,CAACiI,SAAS,CAACxC,UAAU,CAACtC,MAAM,CAACgE,EAAE;UACtDgB,MAAM,EAAEnI,OAAO,CAACiI,SAAS,CAACxC,UAAU,CAACtC,MAAM,CAACjC,UAAU,CAACkH,KAAK,CACxDC,CAAC,IAAI,WAAWA,CAAC,EACrB;QACJ;MACJ;IACJ,CAAC,CAAC;IAEFjI,GAAG,CAAC0H,kBAAkB,CAAC;MACnB7H,IAAI,EAAE,WAAW;MACjB8H,QAAQ,EAAE;QACNO,SAAS,EAAEtI,OAAO,CAACiI,SAAS,CAAChE,OAAO,CAACqB,SAAS,CAACrB,OAAO,CAACd,MAAM,CAACoC,GAAG;QACjEgD,OAAO,EAAEvI,OAAO,CAACiI,SAAS,CAACtC,SAAS,CAAC2B,UAAU,CAACnE,MAAM,CAACoC;MAC3D;IACJ,CAAC,CAAC;EACN,CAAC,CAAC;EAEF,OAAOnF,GAAG;AACd,CAAC","ignoreList":[]}
|
|
1
|
+
{"version":3,"file":"pulumi/apps/api/createApiPulumiApp.js","sources":["../../../../src/pulumi/apps/api/createApiPulumiApp.ts"],"sourcesContent":["import * as aws from \"@pulumi/aws\";\nimport { createPulumiApp, isResourceOfType, type PulumiApp } from \"@webiny/pulumi\";\nimport {\n ApiBackgroundTask,\n ApiCloudfront,\n ApiFileManager,\n ApiGateway,\n ApiGraphql,\n ApiWebsocket,\n CoreOutput,\n VpcConfig\n} from \"~/pulumi/apps/index.js\";\nimport {\n addDomainsUrlsOutputs,\n withCommonLambdaEnvVariables,\n withServiceManifest\n} from \"~/pulumi/utils/index.js\";\nimport { getEnvVariableAwsRegion } from \"~/pulumi/env/awsRegion.js\";\n// import { attachSyncSystem } from \"../syncSystem/api/index.js\";\nimport { applyAwsResourceTags, getAwsAccountId } from \"~/pulumi/apps/awsUtils.js\";\nimport type { WithServiceManifest } from \"~/pulumi/utils/withServiceManifest.js\";\nimport { ApiScheduler } from \"~/pulumi/apps/api/ApiScheduler.js\";\nimport { getProjectSdk } from \"@webiny/project\";\nimport { getVpcConfigFromExtension } from \"~/pulumi/apps/extensions/getVpcConfigFromExtension.js\";\nimport { getOsConfigFromExtension } from \"~/pulumi/apps/extensions/getOsConfigFromExtension.js\";\nimport { handleGuardDutyEvents } from \"./handleGuardDutyEvents.js\";\nimport { ApiPulumi } from \"~/abstractions/features/pulumi/index.js\";\nimport { apiPulumi } from \"~/pulumi/features/ApiPulumi/index.js\";\nimport { ApiCustomDomains as apiCustomDomainsExt } from \"~/pulumi/extensions/ApiCustomDomains.js\";\nimport { applyCustomDomain } from \"~/pulumi/apps/customDomain.js\";\n\nexport type ApiPulumiApp = ReturnType<typeof createApiPulumiApp>;\n\nexport const createApiPulumiApp = () => {\n const baseApp = createPulumiApp({\n name: \"api\",\n path: \"apps/api\",\n program: async (app: PulumiApp & WithServiceManifest) => {\n const sdk = await getProjectSdk();\n const projectConfig = await sdk.getProjectConfig();\n\n const pulumiResourceNamePrefix = await sdk.getPulumiResourceNamePrefix();\n const vpcExtensionsConfig = getVpcConfigFromExtension(projectConfig);\n const openSearchExtensionConfig = getOsConfigFromExtension(projectConfig);\n\n let searchEngineParams: typeof openSearchExtensionConfig | null = null;\n\n if (openSearchExtensionConfig) {\n searchEngineParams = openSearchExtensionConfig;\n }\n\n if (searchEngineParams) {\n const params = searchEngineParams;\n if (typeof params === \"object\") {\n if (params.endpoint) {\n process.env.OPENSEARCH_ENDPOINT = params.endpoint;\n }\n\n if (params.domainName) {\n process.env.AWS_OS_DOMAIN_NAME = params.domainName;\n }\n\n if (params.indexPrefix) {\n process.env.OPENSEARCH_INDEX_PREFIX = params.indexPrefix;\n }\n\n if (params.sharedIndexes) {\n process.env.OPENSEARCH_SHARED_INDEXES = \"true\";\n }\n\n if (params.username) {\n process.env.OPENSEARCH_USERNAME = params.username;\n }\n\n if (params.password) {\n process.env.OPENSEARCH_PASSWORD = params.password;\n }\n }\n }\n\n if (pulumiResourceNamePrefix) {\n app.onResource(resource => {\n if (!resource.name.startsWith(pulumiResourceNamePrefix)) {\n resource.name = `${pulumiResourceNamePrefix}${resource.name}`;\n }\n });\n }\n\n // <-------------------- Enterprise start -------------------->\n app.addHandler(async () => {\n const featureFlags = await sdk.getFeatureFlags();\n\n const usingAdvancedVpcParams =\n vpcExtensionsConfig && typeof vpcExtensionsConfig !== \"boolean\";\n\n if (featureFlags.isFileManagerThreatDetectionEnabled()) {\n handleGuardDutyEvents(app as ApiPulumiApp);\n }\n\n // Not using advanced VPC params? Then immediately exit.\n if (usingAdvancedVpcParams) {\n const { onResource, addResource } = app;\n const { useExistingVpc } = vpcExtensionsConfig;\n\n // 1. We first deal with \"existing VPC\" setup.\n if (useExistingVpc) {\n if (!useExistingVpc.lambdaFunctionsVpcConfig) {\n throw new Error(\n \"Cannot specify `useExistingVpc` parameter because the `lambdaFunctionsVpcConfig` parameter wasn't provided.\"\n );\n }\n\n onResource(resource => {\n if (isResourceOfType(resource, aws.lambda.Function)) {\n const canUseVpc = resource.meta.canUseVpc !== false;\n if (canUseVpc) {\n resource.config.vpcConfig(\n useExistingVpc!.lambdaFunctionsVpcConfig\n );\n }\n }\n\n if (isResourceOfType(resource, aws.iam.Role)) {\n if (resource.meta.isLambdaFunctionRole) {\n addResource(aws.iam.RolePolicyAttachment, {\n name: `${resource.name}-vpc-access-execution-role`,\n config: {\n role: resource.output.name,\n policyArn:\n aws.iam.ManagedPolicy\n .AWSLambdaVPCAccessExecutionRole\n }\n });\n }\n }\n });\n }\n }\n });\n // <-------------------- Enterprise end -------------------->\n\n // Overrides must be applied via a handler, registered at the very start of the program.\n // By doing this, we're ensuring user's adjustments are not applied to late.\n sdk.getContainer().registerComposite(apiPulumi);\n const pulumiHandlers = sdk.getContainer().resolve(ApiPulumi);\n\n app.addHandler(() => {\n return pulumiHandlers.execute(app as ApiPulumiApp);\n });\n\n const isProduction = app.env.isProduction;\n\n // Register core output as a module available to all the other modules\n const core = app.addModule(CoreOutput);\n\n // Register VPC config module to be available to other modules.\n const vpcEnabled =\n vpcExtensionsConfig === true ||\n typeof vpcExtensionsConfig === \"object\" ||\n isProduction;\n\n app.addModule(VpcConfig, { enabled: vpcEnabled });\n\n const graphql = app.addModule(ApiGraphql, {\n env: {\n COGNITO_REGION: getEnvVariableAwsRegion(),\n COGNITO_USER_POOL_ID: core.cognitoUserPoolId,\n DB_TABLE: core.primaryDynamodbTableName,\n DB_TABLE_AUDIT_LOGS: core.auditLogsDynamodbTableName,\n DB_TABLE_OPENSEARCH: core.opensearchDynamodbTableName,\n OPENSEARCH_ENDPOINT: core.opensearchDomainEndpoint,\n\n // Not required. Useful for testing purposes / ephemeral environments.\n // https://www.webiny.com/docs/key-topics/ci-cd/testing/slow-ephemeral-environments\n OPENSEARCH_INDEX_PREFIX: process.env.OPENSEARCH_INDEX_PREFIX,\n OPENSEARCH_SHARED_INDEXES: process.env.OPENSEARCH_SHARED_INDEXES,\n OPENSEARCH_USERNAME: process.env.OPENSEARCH_USERNAME,\n OPENSEARCH_PASSWORD: process.env.OPENSEARCH_PASSWORD,\n\n S3_BUCKET: core.fileManagerBucketId,\n EVENT_BUS: core.eventBusArn,\n // TODO: move to okta plugin\n OKTA_ISSUER: process.env[\"OKTA_ISSUER\"]\n }\n });\n\n const websocket = app.addModule(ApiWebsocket);\n\n const fileManager = app.addModule(ApiFileManager, {\n env: {\n DB_TABLE: core.primaryDynamodbTableName,\n DB_TABLE_AUDIT_LOGS: core.auditLogsDynamodbTableName\n }\n });\n\n const apiGateway = app.addModule(ApiGateway, {\n \"graphql-post\": {\n path: \"/graphql\",\n method: \"POST\",\n function: graphql.functions.graphql.output.arn\n },\n \"graphql-options\": {\n path: \"/graphql\",\n method: \"OPTIONS\",\n function: graphql.functions.graphql.output.arn\n },\n \"files-any\": {\n path: \"/files/{path+}\",\n method: \"ANY\",\n function: fileManager.functions.download.output.arn\n },\n \"private-any\": {\n path: \"/private/{path+}\",\n method: \"ANY\",\n function: fileManager.functions.download.output.arn\n },\n \"cms-post\": {\n path: \"/cms/{key+}\",\n method: \"POST\",\n function: graphql.functions.graphql.output.arn\n },\n \"cms-options\": {\n path: \"/cms/{key+}\",\n method: \"OPTIONS\",\n function: graphql.functions.graphql.output.arn\n },\n \"redirects-get\": {\n path: \"/wb/redirects\",\n method: \"GET\",\n function: graphql.functions.graphql.output.arn\n },\n \"redirects-options\": {\n path: \"/wb/redirects\",\n method: \"OPTIONS\",\n function: graphql.functions.graphql.output.arn\n },\n \"files-catch-all\": {\n path: \"/{path+}\",\n method: \"ANY\",\n function: fileManager.functions.download.output.arn\n }\n });\n\n const cloudfront = app.addModule(ApiCloudfront);\n const backgroundTask = app.addModule(ApiBackgroundTask);\n const scheduler = app.addModule(ApiScheduler);\n\n const [apiCustomDomains] = projectConfig.extensionsByType(apiCustomDomainsExt);\n if (apiCustomDomains) {\n const { domains, sslMethod, certificateArn } = apiCustomDomains.params;\n applyCustomDomain(cloudfront, {\n domains,\n sslSupportMethod: sslMethod,\n acmCertificateArn: certificateArn\n });\n }\n\n app.addOutputs({\n awsAccountId: getAwsAccountId(app),\n region: aws.config.region,\n cognitoUserPoolId: core.cognitoUserPoolId,\n cognitoAppClientId: core.cognitoAppClientId,\n cognitoUserPoolPasswordPolicy: core.cognitoUserPoolPasswordPolicy,\n dynamoDbTable: core.primaryDynamodbTableName,\n auditLogsDynamoDbTable: core.auditLogsDynamodbTableName,\n graphqlLambdaName: graphql.functions.graphql.output.name,\n graphqlLambdaRole: graphql.role.output.arn,\n graphqlLambdaRoleName: graphql.role.output.name,\n backgroundTaskLambdaArn: backgroundTask.backgroundTask.output.arn,\n backgroundTaskStepFunctionArn: backgroundTask.stepFunction.output.arn,\n fileManagerDownloadLambdaArn: fileManager.functions.download.output.arn,\n websocketApiId: websocket.websocketApi.output.id,\n websocketApiUrl: websocket.websocketApiUrl,\n schedulerLambdaInvokeRole: scheduler.invokeRole.output.arn\n });\n\n // Only add `dynamoDbOpensearchTable` output if using search engine (ES/OS).\n if (searchEngineParams) {\n app.addOutputs({\n dynamoDbOpensearchTable: core.opensearchDynamodbTableName\n });\n }\n\n app.addHandler(() => {\n addDomainsUrlsOutputs({\n app,\n cloudfrontDistribution: cloudfront,\n map: {\n distributionDomain: \"cloudfrontApiDomain\",\n distributionUrl: \"cloudfrontApiUrl\",\n usedDomain: \"apiDomain\",\n usedUrl: \"apiUrl\"\n }\n });\n });\n // /**\n // * We need to attach the Sync System if it exists.\n // */\n // await attachSyncSystem({\n // app,\n // core,\n // env: app.params.run.env\n // });\n\n // Applies internal and user-defined AWS tags.\n await applyAwsResourceTags(\"api\");\n\n return {\n fileManager,\n graphql,\n apiGateway,\n websocket,\n cloudfront,\n backgroundTask,\n scheduler\n };\n }\n });\n\n const app = withServiceManifest(withCommonLambdaEnvVariables(baseApp));\n\n app.addHandler(() => {\n app.addServiceManifest({\n name: \"api\",\n manifest: {\n bgTaskSfn: baseApp.resources.backgroundTask.stepFunction.output.arn,\n cloudfront: {\n distributionId: baseApp.resources.cloudfront.output.id,\n domain: baseApp.resources.cloudfront.output.domainName.apply(\n v => `https://${v}`\n )\n }\n }\n });\n\n app.addServiceManifest({\n name: \"scheduler\",\n manifest: {\n lambdaArn: baseApp.resources.graphql.functions.graphql.output.arn,\n roleArn: baseApp.resources.scheduler.invokeRole.output.arn\n }\n });\n });\n\n return app;\n};\n"],"names":["createApiPulumiApp","baseApp","createPulumiApp","app","sdk","getProjectSdk","projectConfig","pulumiResourceNamePrefix","vpcExtensionsConfig","getVpcConfigFromExtension","openSearchExtensionConfig","getOsConfigFromExtension","searchEngineParams","params","process","resource","featureFlags","usingAdvancedVpcParams","handleGuardDutyEvents","onResource","addResource","useExistingVpc","Error","isResourceOfType","aws","canUseVpc","apiPulumi","pulumiHandlers","ApiPulumi","isProduction","core","CoreOutput","vpcEnabled","VpcConfig","graphql","ApiGraphql","getEnvVariableAwsRegion","websocket","ApiWebsocket","fileManager","ApiFileManager","apiGateway","ApiGateway","cloudfront","ApiCloudfront","backgroundTask","ApiBackgroundTask","scheduler","ApiScheduler","apiCustomDomains","apiCustomDomainsExt","domains","sslMethod","certificateArn","applyCustomDomain","getAwsAccountId","addDomainsUrlsOutputs","applyAwsResourceTags","withServiceManifest","withCommonLambdaEnvVariables","v"],"mappings":"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"}
|