@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,136 +1,194 @@
|
|
|
1
|
-
import * as aws from "@pulumi/aws";
|
|
2
1
|
import { createAppModule } from "@webiny/pulumi";
|
|
3
2
|
import { ApiGateway } from "./ApiGateway.js";
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
3
|
+
import * as __rspack_external__pulumi_aws_e7af83c1 from "@pulumi/aws";
|
|
4
|
+
const ApiCloudfront = createAppModule({
|
|
5
|
+
name: "ApiCloudfront",
|
|
6
|
+
config (app) {
|
|
7
|
+
const gateway = app.getModule(ApiGateway);
|
|
8
|
+
const cookies = {
|
|
9
|
+
forward: "whitelist",
|
|
10
|
+
whitelistedNames: [
|
|
11
|
+
"wby-id-token"
|
|
12
|
+
]
|
|
13
|
+
};
|
|
14
|
+
const forwardHeaders = [
|
|
15
|
+
"Origin",
|
|
16
|
+
"Authorization",
|
|
17
|
+
"Accept",
|
|
18
|
+
"Accept-Language",
|
|
19
|
+
"X-Tenant",
|
|
20
|
+
"X-Webiny-Sdk"
|
|
21
|
+
];
|
|
22
|
+
return app.addResource(__rspack_external__pulumi_aws_e7af83c1.cloudfront.Distribution, {
|
|
23
|
+
name: "api-cloudfront",
|
|
24
|
+
config: {
|
|
25
|
+
httpVersion: "http2and3",
|
|
26
|
+
waitForDeployment: false,
|
|
27
|
+
isIpv6Enabled: true,
|
|
28
|
+
enabled: true,
|
|
29
|
+
defaultCacheBehavior: {
|
|
30
|
+
compress: true,
|
|
31
|
+
allowedMethods: [
|
|
32
|
+
"GET",
|
|
33
|
+
"HEAD",
|
|
34
|
+
"OPTIONS",
|
|
35
|
+
"PUT",
|
|
36
|
+
"POST",
|
|
37
|
+
"PATCH",
|
|
38
|
+
"DELETE"
|
|
39
|
+
],
|
|
40
|
+
cachedMethods: [
|
|
41
|
+
"GET",
|
|
42
|
+
"HEAD",
|
|
43
|
+
"OPTIONS"
|
|
44
|
+
],
|
|
45
|
+
forwardedValues: {
|
|
46
|
+
cookies,
|
|
47
|
+
headers: forwardHeaders,
|
|
48
|
+
queryString: true
|
|
49
|
+
},
|
|
50
|
+
minTtl: 0,
|
|
51
|
+
defaultTtl: 0,
|
|
52
|
+
maxTtl: 86400,
|
|
53
|
+
targetOriginId: gateway.api.output.name,
|
|
54
|
+
viewerProtocolPolicy: "allow-all"
|
|
55
|
+
},
|
|
56
|
+
orderedCacheBehaviors: [
|
|
57
|
+
{
|
|
58
|
+
compress: true,
|
|
59
|
+
allowedMethods: [
|
|
60
|
+
"GET",
|
|
61
|
+
"HEAD",
|
|
62
|
+
"OPTIONS",
|
|
63
|
+
"PUT",
|
|
64
|
+
"POST",
|
|
65
|
+
"PATCH",
|
|
66
|
+
"DELETE"
|
|
67
|
+
],
|
|
68
|
+
cachedMethods: [
|
|
69
|
+
"GET",
|
|
70
|
+
"HEAD",
|
|
71
|
+
"OPTIONS"
|
|
72
|
+
],
|
|
73
|
+
forwardedValues: {
|
|
74
|
+
cookies: {
|
|
75
|
+
forward: "none"
|
|
76
|
+
},
|
|
77
|
+
headers: forwardHeaders,
|
|
78
|
+
queryString: true
|
|
79
|
+
},
|
|
80
|
+
pathPattern: "/cms*",
|
|
81
|
+
viewerProtocolPolicy: "allow-all",
|
|
82
|
+
targetOriginId: gateway.api.output.name
|
|
83
|
+
},
|
|
84
|
+
{
|
|
85
|
+
compress: true,
|
|
86
|
+
allowedMethods: [
|
|
87
|
+
"GET",
|
|
88
|
+
"HEAD",
|
|
89
|
+
"OPTIONS",
|
|
90
|
+
"PUT",
|
|
91
|
+
"POST",
|
|
92
|
+
"PATCH",
|
|
93
|
+
"DELETE"
|
|
94
|
+
],
|
|
95
|
+
cachedMethods: [
|
|
96
|
+
"GET",
|
|
97
|
+
"HEAD",
|
|
98
|
+
"OPTIONS"
|
|
99
|
+
],
|
|
100
|
+
forwardedValues: {
|
|
101
|
+
cookies: {
|
|
102
|
+
forward: "none"
|
|
103
|
+
},
|
|
104
|
+
headers: forwardHeaders,
|
|
105
|
+
queryString: true
|
|
106
|
+
},
|
|
107
|
+
pathPattern: "/wb/*",
|
|
108
|
+
viewerProtocolPolicy: "allow-all",
|
|
109
|
+
targetOriginId: gateway.api.output.name
|
|
110
|
+
},
|
|
111
|
+
{
|
|
112
|
+
allowedMethods: [
|
|
113
|
+
"HEAD",
|
|
114
|
+
"GET",
|
|
115
|
+
"OPTIONS"
|
|
116
|
+
],
|
|
117
|
+
cachedMethods: [
|
|
118
|
+
"HEAD",
|
|
119
|
+
"GET",
|
|
120
|
+
"OPTIONS"
|
|
121
|
+
],
|
|
122
|
+
forwardedValues: {
|
|
123
|
+
cookies: {
|
|
124
|
+
forward: "none"
|
|
125
|
+
},
|
|
126
|
+
headers: forwardHeaders,
|
|
127
|
+
queryString: true
|
|
128
|
+
},
|
|
129
|
+
minTtl: 0,
|
|
130
|
+
defaultTtl: 0,
|
|
131
|
+
maxTtl: 2592000,
|
|
132
|
+
pathPattern: "/files/*",
|
|
133
|
+
viewerProtocolPolicy: "allow-all",
|
|
134
|
+
targetOriginId: gateway.api.output.name
|
|
135
|
+
},
|
|
136
|
+
{
|
|
137
|
+
allowedMethods: [
|
|
138
|
+
"HEAD",
|
|
139
|
+
"GET",
|
|
140
|
+
"OPTIONS"
|
|
141
|
+
],
|
|
142
|
+
cachedMethods: [
|
|
143
|
+
"HEAD",
|
|
144
|
+
"GET",
|
|
145
|
+
"OPTIONS"
|
|
146
|
+
],
|
|
147
|
+
forwardedValues: {
|
|
148
|
+
cookies: cookies,
|
|
149
|
+
headers: forwardHeaders,
|
|
150
|
+
queryString: true
|
|
151
|
+
},
|
|
152
|
+
minTtl: 0,
|
|
153
|
+
defaultTtl: 0,
|
|
154
|
+
maxTtl: 2592000,
|
|
155
|
+
pathPattern: "/private/*",
|
|
156
|
+
viewerProtocolPolicy: "allow-all",
|
|
157
|
+
targetOriginId: gateway.api.output.name
|
|
158
|
+
}
|
|
159
|
+
],
|
|
160
|
+
origins: [
|
|
161
|
+
{
|
|
162
|
+
domainName: gateway.stage.output.invokeUrl.apply((url)=>new URL(url).hostname),
|
|
163
|
+
originPath: gateway.stage.output.invokeUrl.apply((url)=>new URL(url).pathname),
|
|
164
|
+
originId: gateway.api.output.name,
|
|
165
|
+
customOriginConfig: {
|
|
166
|
+
httpPort: 80,
|
|
167
|
+
httpsPort: 443,
|
|
168
|
+
originProtocolPolicy: "https-only",
|
|
169
|
+
originSslProtocols: [
|
|
170
|
+
"TLSv1.2"
|
|
171
|
+
]
|
|
172
|
+
}
|
|
173
|
+
}
|
|
174
|
+
],
|
|
175
|
+
restrictions: {
|
|
176
|
+
geoRestriction: {
|
|
177
|
+
restrictionType: "none"
|
|
178
|
+
}
|
|
179
|
+
},
|
|
180
|
+
viewerCertificate: {
|
|
181
|
+
cloudfrontDefaultCertificate: true
|
|
182
|
+
}
|
|
43
183
|
},
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
compress: true,
|
|
52
|
-
allowedMethods: ["GET", "HEAD", "OPTIONS", "PUT", "POST", "PATCH", "DELETE"],
|
|
53
|
-
cachedMethods: ["GET", "HEAD", "OPTIONS"],
|
|
54
|
-
forwardedValues: {
|
|
55
|
-
cookies: {
|
|
56
|
-
forward: "none"
|
|
57
|
-
},
|
|
58
|
-
headers: forwardHeaders,
|
|
59
|
-
queryString: true
|
|
60
|
-
},
|
|
61
|
-
pathPattern: "/wb/*",
|
|
62
|
-
viewerProtocolPolicy: "allow-all",
|
|
63
|
-
targetOriginId: gateway.api.output.name
|
|
64
|
-
}, {
|
|
65
|
-
allowedMethods: ["HEAD", "GET", "OPTIONS"],
|
|
66
|
-
cachedMethods: ["HEAD", "GET", "OPTIONS"],
|
|
67
|
-
forwardedValues: {
|
|
68
|
-
cookies: {
|
|
69
|
-
forward: "none"
|
|
70
|
-
},
|
|
71
|
-
headers: forwardHeaders,
|
|
72
|
-
queryString: true
|
|
73
|
-
},
|
|
74
|
-
// MinTTL <= DefaultTTL <= MaxTTL
|
|
75
|
-
minTtl: 0,
|
|
76
|
-
defaultTtl: 0,
|
|
77
|
-
maxTtl: 2592000,
|
|
78
|
-
pathPattern: "/files/*",
|
|
79
|
-
viewerProtocolPolicy: "allow-all",
|
|
80
|
-
targetOriginId: gateway.api.output.name
|
|
81
|
-
}, {
|
|
82
|
-
allowedMethods: ["HEAD", "GET", "OPTIONS"],
|
|
83
|
-
cachedMethods: ["HEAD", "GET", "OPTIONS"],
|
|
84
|
-
forwardedValues: {
|
|
85
|
-
cookies: cookies,
|
|
86
|
-
headers: forwardHeaders,
|
|
87
|
-
queryString: true
|
|
88
|
-
},
|
|
89
|
-
// MinTTL <= DefaultTTL <= MaxTTL
|
|
90
|
-
minTtl: 0,
|
|
91
|
-
defaultTtl: 0,
|
|
92
|
-
maxTtl: 2592000,
|
|
93
|
-
pathPattern: "/private/*",
|
|
94
|
-
viewerProtocolPolicy: "allow-all",
|
|
95
|
-
targetOriginId: gateway.api.output.name
|
|
96
|
-
}],
|
|
97
|
-
origins: [{
|
|
98
|
-
domainName: gateway.stage.output.invokeUrl.apply(url => new URL(url).hostname),
|
|
99
|
-
originPath: gateway.stage.output.invokeUrl.apply(url => new URL(url).pathname),
|
|
100
|
-
originId: gateway.api.output.name,
|
|
101
|
-
customOriginConfig: {
|
|
102
|
-
httpPort: 80,
|
|
103
|
-
httpsPort: 443,
|
|
104
|
-
originProtocolPolicy: "https-only",
|
|
105
|
-
originSslProtocols: ["TLSv1.2"]
|
|
106
|
-
}
|
|
107
|
-
}],
|
|
108
|
-
restrictions: {
|
|
109
|
-
geoRestriction: {
|
|
110
|
-
restrictionType: "none"
|
|
111
|
-
}
|
|
112
|
-
},
|
|
113
|
-
viewerCertificate: {
|
|
114
|
-
cloudfrontDefaultCertificate: true
|
|
115
|
-
}
|
|
116
|
-
},
|
|
117
|
-
opts: {
|
|
118
|
-
// We are ignoring changes to the "staging" property. This is because of the following.
|
|
119
|
-
// With the 5.41.0 release of Webiny, we also upgraded Pulumi to v6. This introduced a change
|
|
120
|
-
// with how Cloudfront distributions are deployed, where Pulumi now also controls the new
|
|
121
|
-
// `staging` property.
|
|
122
|
-
// If not set, Pulumi will default it to `false`. Which is fine, but, the problem is
|
|
123
|
-
// that, because this property did not exist before, it will always be considered as a change
|
|
124
|
-
// upon deployment.
|
|
125
|
-
// We might think this is fine, but, the problem is that a change in this property causes
|
|
126
|
-
// a full replacement of the Cloudfront distribution, which is not acceptable. Especially
|
|
127
|
-
// if a custom domain has already been associated with the distribution. This then would
|
|
128
|
-
// require the user to disassociate the domain, wait for the distribution to be replaced,
|
|
129
|
-
// and then re-associate the domain. This is not a good experience.
|
|
130
|
-
ignoreChanges: ["staging"]
|
|
131
|
-
}
|
|
132
|
-
});
|
|
133
|
-
}
|
|
184
|
+
opts: {
|
|
185
|
+
ignoreChanges: [
|
|
186
|
+
"staging"
|
|
187
|
+
]
|
|
188
|
+
}
|
|
189
|
+
});
|
|
190
|
+
}
|
|
134
191
|
});
|
|
192
|
+
export { ApiCloudfront };
|
|
135
193
|
|
|
136
194
|
//# sourceMappingURL=ApiCloudfront.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["aws","createAppModule","ApiGateway","ApiCloudfront","name","config","app","gateway","getModule","cookies","forward","whitelistedNames","forwardHeaders","addResource","cloudfront","Distribution","httpVersion","waitForDeployment","isIpv6Enabled","enabled","defaultCacheBehavior","compress","allowedMethods","cachedMethods","forwardedValues","headers","queryString","minTtl","defaultTtl","maxTtl","targetOriginId","api","output","viewerProtocolPolicy","orderedCacheBehaviors","pathPattern","origins","domainName","stage","invokeUrl","apply","url","URL","hostname","originPath","pathname","originId","customOriginConfig","httpPort","httpsPort","originProtocolPolicy","originSslProtocols","restrictions","geoRestriction","restrictionType","viewerCertificate","cloudfrontDefaultCertificate","opts","ignoreChanges"],"sources":["ApiCloudfront.ts"],"sourcesContent":["import * as aws from \"@pulumi/aws\";\nimport type { PulumiApp, PulumiAppModule } from \"@webiny/pulumi\";\nimport { createAppModule } from \"@webiny/pulumi\";\n\nimport { ApiGateway } from \"./ApiGateway.js\";\n\nexport type ApiCloudfront = PulumiAppModule<typeof ApiCloudfront>;\n\nexport const ApiCloudfront = createAppModule({\n name: \"ApiCloudfront\",\n config(app: PulumiApp) {\n const gateway = app.getModule(ApiGateway);\n\n const cookies = {\n forward: \"whitelist\",\n whitelistedNames: [\"wby-id-token\"]\n };\n\n const forwardHeaders = [\n \"Origin\",\n \"Authorization\",\n \"Accept\",\n \"Accept-Language\",\n \"X-Tenant\",\n \"X-Webiny-Sdk\"\n ];\n\n return app.addResource(aws.cloudfront.Distribution, {\n name: \"api-cloudfront\",\n config: {\n httpVersion: \"http2and3\",\n waitForDeployment: false,\n isIpv6Enabled: true,\n enabled: true,\n defaultCacheBehavior: {\n compress: true,\n allowedMethods: [\"GET\", \"HEAD\", \"OPTIONS\", \"PUT\", \"POST\", \"PATCH\", \"DELETE\"],\n cachedMethods: [\"GET\", \"HEAD\", \"OPTIONS\"],\n forwardedValues: {\n cookies,\n headers: forwardHeaders,\n queryString: true\n },\n // MinTTL <= DefaultTTL <= MaxTTL\n minTtl: 0,\n defaultTtl: 0,\n maxTtl: 86400,\n targetOriginId: gateway.api.output.name,\n viewerProtocolPolicy: \"allow-all\"\n },\n orderedCacheBehaviors: [\n {\n compress: true,\n allowedMethods: [\n \"GET\",\n \"HEAD\",\n \"OPTIONS\",\n \"PUT\",\n \"POST\",\n \"PATCH\",\n \"DELETE\"\n ],\n cachedMethods: [\"GET\", \"HEAD\", \"OPTIONS\"],\n forwardedValues: {\n cookies: {\n forward: \"none\"\n },\n headers: forwardHeaders,\n queryString: true\n },\n pathPattern: \"/cms*\",\n viewerProtocolPolicy: \"allow-all\",\n targetOriginId: gateway.api.output.name\n },\n {\n compress: true,\n allowedMethods: [\n \"GET\",\n \"HEAD\",\n \"OPTIONS\",\n \"PUT\",\n \"POST\",\n \"PATCH\",\n \"DELETE\"\n ],\n cachedMethods: [\"GET\", \"HEAD\", \"OPTIONS\"],\n forwardedValues: {\n cookies: {\n forward: \"none\"\n },\n headers: forwardHeaders,\n queryString: true\n },\n pathPattern: \"/wb/*\",\n viewerProtocolPolicy: \"allow-all\",\n targetOriginId: gateway.api.output.name\n },\n {\n allowedMethods: [\"HEAD\", \"GET\", \"OPTIONS\"],\n cachedMethods: [\"HEAD\", \"GET\", \"OPTIONS\"],\n forwardedValues: {\n cookies: {\n forward: \"none\"\n },\n headers: forwardHeaders,\n queryString: true\n },\n // MinTTL <= DefaultTTL <= MaxTTL\n minTtl: 0,\n defaultTtl: 0,\n maxTtl: 2592000,\n pathPattern: \"/files/*\",\n viewerProtocolPolicy: \"allow-all\",\n targetOriginId: gateway.api.output.name\n },\n {\n allowedMethods: [\"HEAD\", \"GET\", \"OPTIONS\"],\n cachedMethods: [\"HEAD\", \"GET\", \"OPTIONS\"],\n forwardedValues: {\n cookies: cookies,\n headers: forwardHeaders,\n queryString: true\n },\n // MinTTL <= DefaultTTL <= MaxTTL\n minTtl: 0,\n defaultTtl: 0,\n maxTtl: 2592000,\n pathPattern: \"/private/*\",\n viewerProtocolPolicy: \"allow-all\",\n targetOriginId: gateway.api.output.name\n }\n ],\n origins: [\n {\n domainName: gateway.stage.output.invokeUrl.apply(\n (url: string) => new URL(url).hostname\n ),\n originPath: gateway.stage.output.invokeUrl.apply(\n (url: string) => new URL(url).pathname\n ),\n originId: gateway.api.output.name,\n customOriginConfig: {\n httpPort: 80,\n httpsPort: 443,\n originProtocolPolicy: \"https-only\",\n originSslProtocols: [\"TLSv1.2\"]\n }\n }\n ],\n restrictions: {\n geoRestriction: {\n restrictionType: \"none\"\n }\n },\n viewerCertificate: {\n cloudfrontDefaultCertificate: true\n }\n },\n opts: {\n // We are ignoring changes to the \"staging\" property. This is because of the following.\n // With the 5.41.0 release of Webiny, we also upgraded Pulumi to v6. This introduced a change\n // with how Cloudfront distributions are deployed, where Pulumi now also controls the new\n // `staging` property.\n // If not set, Pulumi will default it to `false`. Which is fine, but, the problem is\n // that, because this property did not exist before, it will always be considered as a change\n // upon deployment.\n // We might think this is fine, but, the problem is that a change in this property causes\n // a full replacement of the Cloudfront distribution, which is not acceptable. Especially\n // if a custom domain has already been associated with the distribution. This then would\n // require the user to disassociate the domain, wait for the distribution to be replaced,\n // and then re-associate the domain. This is not a good experience.\n ignoreChanges: [\"staging\"]\n }\n });\n }\n});\n"],"mappings":"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","ignoreList":[]}
|
|
1
|
+
{"version":3,"file":"pulumi/apps/api/ApiCloudfront.js","sources":["../../../../src/pulumi/apps/api/ApiCloudfront.ts"],"sourcesContent":["import * as aws from \"@pulumi/aws\";\nimport type { PulumiApp, PulumiAppModule } from \"@webiny/pulumi\";\nimport { createAppModule } from \"@webiny/pulumi\";\n\nimport { ApiGateway } from \"./ApiGateway.js\";\n\nexport type ApiCloudfront = PulumiAppModule<typeof ApiCloudfront>;\n\nexport const ApiCloudfront = createAppModule({\n name: \"ApiCloudfront\",\n config(app: PulumiApp) {\n const gateway = app.getModule(ApiGateway);\n\n const cookies = {\n forward: \"whitelist\",\n whitelistedNames: [\"wby-id-token\"]\n };\n\n const forwardHeaders = [\n \"Origin\",\n \"Authorization\",\n \"Accept\",\n \"Accept-Language\",\n \"X-Tenant\",\n \"X-Webiny-Sdk\"\n ];\n\n return app.addResource(aws.cloudfront.Distribution, {\n name: \"api-cloudfront\",\n config: {\n httpVersion: \"http2and3\",\n waitForDeployment: false,\n isIpv6Enabled: true,\n enabled: true,\n defaultCacheBehavior: {\n compress: true,\n allowedMethods: [\"GET\", \"HEAD\", \"OPTIONS\", \"PUT\", \"POST\", \"PATCH\", \"DELETE\"],\n cachedMethods: [\"GET\", \"HEAD\", \"OPTIONS\"],\n forwardedValues: {\n cookies,\n headers: forwardHeaders,\n queryString: true\n },\n // MinTTL <= DefaultTTL <= MaxTTL\n minTtl: 0,\n defaultTtl: 0,\n maxTtl: 86400,\n targetOriginId: gateway.api.output.name,\n viewerProtocolPolicy: \"allow-all\"\n },\n orderedCacheBehaviors: [\n {\n compress: true,\n allowedMethods: [\n \"GET\",\n \"HEAD\",\n \"OPTIONS\",\n \"PUT\",\n \"POST\",\n \"PATCH\",\n \"DELETE\"\n ],\n cachedMethods: [\"GET\", \"HEAD\", \"OPTIONS\"],\n forwardedValues: {\n cookies: {\n forward: \"none\"\n },\n headers: forwardHeaders,\n queryString: true\n },\n pathPattern: \"/cms*\",\n viewerProtocolPolicy: \"allow-all\",\n targetOriginId: gateway.api.output.name\n },\n {\n compress: true,\n allowedMethods: [\n \"GET\",\n \"HEAD\",\n \"OPTIONS\",\n \"PUT\",\n \"POST\",\n \"PATCH\",\n \"DELETE\"\n ],\n cachedMethods: [\"GET\", \"HEAD\", \"OPTIONS\"],\n forwardedValues: {\n cookies: {\n forward: \"none\"\n },\n headers: forwardHeaders,\n queryString: true\n },\n pathPattern: \"/wb/*\",\n viewerProtocolPolicy: \"allow-all\",\n targetOriginId: gateway.api.output.name\n },\n {\n allowedMethods: [\"HEAD\", \"GET\", \"OPTIONS\"],\n cachedMethods: [\"HEAD\", \"GET\", \"OPTIONS\"],\n forwardedValues: {\n cookies: {\n forward: \"none\"\n },\n headers: forwardHeaders,\n queryString: true\n },\n // MinTTL <= DefaultTTL <= MaxTTL\n minTtl: 0,\n defaultTtl: 0,\n maxTtl: 2592000,\n pathPattern: \"/files/*\",\n viewerProtocolPolicy: \"allow-all\",\n targetOriginId: gateway.api.output.name\n },\n {\n allowedMethods: [\"HEAD\", \"GET\", \"OPTIONS\"],\n cachedMethods: [\"HEAD\", \"GET\", \"OPTIONS\"],\n forwardedValues: {\n cookies: cookies,\n headers: forwardHeaders,\n queryString: true\n },\n // MinTTL <= DefaultTTL <= MaxTTL\n minTtl: 0,\n defaultTtl: 0,\n maxTtl: 2592000,\n pathPattern: \"/private/*\",\n viewerProtocolPolicy: \"allow-all\",\n targetOriginId: gateway.api.output.name\n }\n ],\n origins: [\n {\n domainName: gateway.stage.output.invokeUrl.apply(\n (url: string) => new URL(url).hostname\n ),\n originPath: gateway.stage.output.invokeUrl.apply(\n (url: string) => new URL(url).pathname\n ),\n originId: gateway.api.output.name,\n customOriginConfig: {\n httpPort: 80,\n httpsPort: 443,\n originProtocolPolicy: \"https-only\",\n originSslProtocols: [\"TLSv1.2\"]\n }\n }\n ],\n restrictions: {\n geoRestriction: {\n restrictionType: \"none\"\n }\n },\n viewerCertificate: {\n cloudfrontDefaultCertificate: true\n }\n },\n opts: {\n // We are ignoring changes to the \"staging\" property. This is because of the following.\n // With the 5.41.0 release of Webiny, we also upgraded Pulumi to v6. This introduced a change\n // with how Cloudfront distributions are deployed, where Pulumi now also controls the new\n // `staging` property.\n // If not set, Pulumi will default it to `false`. Which is fine, but, the problem is\n // that, because this property did not exist before, it will always be considered as a change\n // upon deployment.\n // We might think this is fine, but, the problem is that a change in this property causes\n // a full replacement of the Cloudfront distribution, which is not acceptable. Especially\n // if a custom domain has already been associated with the distribution. This then would\n // require the user to disassociate the domain, wait for the distribution to be replaced,\n // and then re-associate the domain. This is not a good experience.\n ignoreChanges: [\"staging\"]\n }\n });\n }\n});\n"],"names":["ApiCloudfront","createAppModule","app","gateway","ApiGateway","cookies","forwardHeaders","aws","url","URL"],"mappings":"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"}
|
|
@@ -1,39 +1,40 @@
|
|
|
1
|
-
import * as aws from "@pulumi/aws";
|
|
2
1
|
import { getLayerArn } from "@webiny/aws-layers";
|
|
3
2
|
import { createAppModule } from "@webiny/pulumi";
|
|
4
3
|
import { ApiGraphql } from "../index.js";
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
4
|
+
import * as __rspack_external__pulumi_aws_e7af83c1 from "@pulumi/aws";
|
|
5
|
+
const ApiFileManager = createAppModule({
|
|
6
|
+
name: "ApiFileManager",
|
|
7
|
+
config (app, config) {
|
|
8
|
+
const graphql = app.getModule(ApiGraphql);
|
|
9
|
+
const baseConfig = graphql.functions.graphql.config.clone();
|
|
10
|
+
const download = app.addResource(__rspack_external__pulumi_aws_e7af83c1.lambda.Function, {
|
|
11
|
+
name: "fm-download",
|
|
12
|
+
config: {
|
|
13
|
+
...baseConfig,
|
|
14
|
+
memorySize: 1600,
|
|
15
|
+
description: "Serves previously uploaded files.",
|
|
16
|
+
layers: [
|
|
17
|
+
getLayerArn("sharp")
|
|
18
|
+
],
|
|
19
|
+
environment: {
|
|
20
|
+
variables: graphql.functions.graphql.output.environment.apply((env)=>({
|
|
21
|
+
WEBINY_FUNCTION_TYPE: "asset-delivery",
|
|
22
|
+
...env?.variables,
|
|
23
|
+
...config.env
|
|
24
|
+
}))
|
|
25
|
+
},
|
|
26
|
+
loggingConfig: {
|
|
27
|
+
logFormat: "JSON"
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
});
|
|
31
|
+
return {
|
|
32
|
+
functions: {
|
|
33
|
+
download
|
|
34
|
+
}
|
|
35
|
+
};
|
|
36
|
+
}
|
|
37
37
|
});
|
|
38
|
+
export { ApiFileManager };
|
|
38
39
|
|
|
39
40
|
//# sourceMappingURL=ApiFileManager.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"
|
|
1
|
+
{"version":3,"file":"pulumi/apps/api/ApiFileManager.js","sources":["../../../../src/pulumi/apps/api/ApiFileManager.ts"],"sourcesContent":["import * as aws from \"@pulumi/aws\";\nimport { getLayerArn } from \"@webiny/aws-layers\";\nimport type { PulumiApp, PulumiAppModule } from \"@webiny/pulumi\";\nimport { createAppModule } from \"@webiny/pulumi\";\n\nimport { ApiGraphql } from \"~/pulumi/apps/index.js\";\n\nexport type ApiFileManager = PulumiAppModule<typeof ApiFileManager>;\n\ninterface ApiFileManagerConfig {\n env: Record<string, any>;\n}\n\nexport const ApiFileManager = createAppModule({\n name: \"ApiFileManager\",\n config(app: PulumiApp, config: ApiFileManagerConfig) {\n const graphql = app.getModule(ApiGraphql);\n\n const baseConfig = graphql.functions.graphql.config.clone();\n\n const download = app.addResource(aws.lambda.Function, {\n name: \"fm-download\",\n config: {\n ...baseConfig,\n memorySize: 1600,\n description: \"Serves previously uploaded files.\",\n layers: [getLayerArn(\"sharp\")],\n environment: {\n variables: graphql.functions.graphql.output.environment.apply(env => {\n return {\n WEBINY_FUNCTION_TYPE: \"asset-delivery\",\n ...env?.variables,\n ...config.env\n };\n })\n },\n loggingConfig: {\n logFormat: \"JSON\"\n }\n }\n });\n\n return {\n functions: {\n download\n }\n };\n }\n});\n"],"names":["ApiFileManager","createAppModule","app","config","graphql","ApiGraphql","baseConfig","download","aws","getLayerArn","env"],"mappings":";;;;AAaO,MAAMA,iBAAiBC,gBAAgB;IAC1C,MAAM;IACN,QAAOC,GAAc,EAAEC,MAA4B;QAC/C,MAAMC,UAAUF,IAAI,SAAS,CAACG;QAE9B,MAAMC,aAAaF,QAAQ,SAAS,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK;QAEzD,MAAMG,WAAWL,IAAI,WAAW,CAACM,uCAAAA,MAAAA,CAAAA,QAAmB,EAAE;YAClD,MAAM;YACN,QAAQ;gBACJ,GAAGF,UAAU;gBACb,YAAY;gBACZ,aAAa;gBACb,QAAQ;oBAACG,YAAY;iBAAS;gBAC9B,aAAa;oBACT,WAAWL,QAAQ,SAAS,CAAC,OAAO,CAAC,MAAM,CAAC,WAAW,CAAC,KAAK,CAACM,CAAAA,MACnD;4BACH,sBAAsB;4BACtB,GAAGA,KAAK,SAAS;4BACjB,GAAGP,OAAO,GAAG;wBACjB;gBAER;gBACA,eAAe;oBACX,WAAW;gBACf;YACJ;QACJ;QAEA,OAAO;YACH,WAAW;gBACPI;YACJ;QACJ;IACJ;AACJ"}
|
|
@@ -1,83 +1,76 @@
|
|
|
1
|
-
import * as aws from "@pulumi/aws";
|
|
2
1
|
import { createAppModule } from "@webiny/pulumi";
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
2
|
+
import * as __rspack_external__pulumi_aws_e7af83c1 from "@pulumi/aws";
|
|
3
|
+
const ApiGateway = createAppModule({
|
|
4
|
+
name: "ApiGateway",
|
|
5
|
+
config (app, routesConfig) {
|
|
6
|
+
const api = app.addResource(__rspack_external__pulumi_aws_e7af83c1.apigatewayv2.Api, {
|
|
7
|
+
name: "api-gateway",
|
|
8
|
+
config: {
|
|
9
|
+
protocolType: "HTTP",
|
|
10
|
+
description: "Main API gateway"
|
|
11
|
+
}
|
|
12
|
+
});
|
|
13
|
+
const stage = app.addResource(__rspack_external__pulumi_aws_e7af83c1.apigatewayv2.Stage, {
|
|
14
|
+
name: "default",
|
|
15
|
+
config: {
|
|
16
|
+
apiId: api.output.id,
|
|
17
|
+
autoDeploy: true,
|
|
18
|
+
defaultRouteSettings: {
|
|
19
|
+
throttlingBurstLimit: 5000,
|
|
20
|
+
throttlingRateLimit: 10000
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
});
|
|
24
|
+
const routes = {};
|
|
25
|
+
for (const name of Object.keys(routesConfig))addRoute(name, routesConfig[name]);
|
|
26
|
+
return {
|
|
27
|
+
api,
|
|
28
|
+
stage,
|
|
29
|
+
routes,
|
|
30
|
+
addRoute
|
|
31
|
+
};
|
|
32
|
+
function addRoute(name, params) {
|
|
33
|
+
if (routes[name]) return;
|
|
34
|
+
const route = createRoute(app, api.output, name, params);
|
|
35
|
+
routes[name] = route;
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
});
|
|
39
|
+
function createRoute(app, api, name, params) {
|
|
40
|
+
const integration = app.addResource(__rspack_external__pulumi_aws_e7af83c1.apigatewayv2.Integration, {
|
|
41
|
+
name: name,
|
|
42
|
+
config: {
|
|
43
|
+
description: "GraphQL API Integration",
|
|
44
|
+
apiId: api.id,
|
|
45
|
+
integrationType: "AWS_PROXY",
|
|
46
|
+
integrationMethod: params.method,
|
|
47
|
+
integrationUri: params.function,
|
|
48
|
+
passthroughBehavior: "WHEN_NO_MATCH"
|
|
49
|
+
}
|
|
12
50
|
});
|
|
13
|
-
const
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
51
|
+
const route = app.addResource(__rspack_external__pulumi_aws_e7af83c1.apigatewayv2.Route, {
|
|
52
|
+
name: name,
|
|
53
|
+
config: {
|
|
54
|
+
apiId: api.id,
|
|
55
|
+
routeKey: `${params.method} ${params.path}`,
|
|
56
|
+
target: integration.output.id.apply((value)=>`integrations/${value}`)
|
|
57
|
+
}
|
|
58
|
+
});
|
|
59
|
+
const permission = app.addResource(__rspack_external__pulumi_aws_e7af83c1.lambda.Permission, {
|
|
60
|
+
name: `allow-${name}`,
|
|
61
|
+
config: {
|
|
62
|
+
action: "lambda:InvokeFunction",
|
|
63
|
+
function: params.function,
|
|
64
|
+
principal: "apigateway.amazonaws.com",
|
|
65
|
+
sourceArn: api.executionArn.apply((arn)=>`${arn}/*/*${params.path}`)
|
|
25
66
|
}
|
|
26
|
-
}
|
|
27
67
|
});
|
|
28
|
-
const routes = {};
|
|
29
|
-
for (const name of Object.keys(routesConfig)) {
|
|
30
|
-
addRoute(name, routesConfig[name]);
|
|
31
|
-
}
|
|
32
68
|
return {
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
addRoute
|
|
69
|
+
integration,
|
|
70
|
+
route,
|
|
71
|
+
permission
|
|
37
72
|
};
|
|
38
|
-
function addRoute(name, params) {
|
|
39
|
-
if (routes[name]) {
|
|
40
|
-
return;
|
|
41
|
-
}
|
|
42
|
-
const route = createRoute(app, api.output, name, params);
|
|
43
|
-
routes[name] = route;
|
|
44
|
-
}
|
|
45
|
-
}
|
|
46
|
-
});
|
|
47
|
-
function createRoute(app, api, name, params) {
|
|
48
|
-
const integration = app.addResource(aws.apigatewayv2.Integration, {
|
|
49
|
-
name: name,
|
|
50
|
-
config: {
|
|
51
|
-
description: "GraphQL API Integration",
|
|
52
|
-
apiId: api.id,
|
|
53
|
-
integrationType: "AWS_PROXY",
|
|
54
|
-
integrationMethod: params.method,
|
|
55
|
-
integrationUri: params.function,
|
|
56
|
-
passthroughBehavior: "WHEN_NO_MATCH"
|
|
57
|
-
}
|
|
58
|
-
});
|
|
59
|
-
const route = app.addResource(aws.apigatewayv2.Route, {
|
|
60
|
-
name: name,
|
|
61
|
-
config: {
|
|
62
|
-
apiId: api.id,
|
|
63
|
-
routeKey: `${params.method} ${params.path}`,
|
|
64
|
-
target: integration.output.id.apply(value => `integrations/${value}`)
|
|
65
|
-
}
|
|
66
|
-
});
|
|
67
|
-
const permission = app.addResource(aws.lambda.Permission, {
|
|
68
|
-
name: `allow-${name}`,
|
|
69
|
-
config: {
|
|
70
|
-
action: "lambda:InvokeFunction",
|
|
71
|
-
function: params.function,
|
|
72
|
-
principal: "apigateway.amazonaws.com",
|
|
73
|
-
sourceArn: api.executionArn.apply(arn => `${arn}/*/*${params.path}`)
|
|
74
|
-
}
|
|
75
|
-
});
|
|
76
|
-
return {
|
|
77
|
-
integration,
|
|
78
|
-
route,
|
|
79
|
-
permission
|
|
80
|
-
};
|
|
81
73
|
}
|
|
74
|
+
export { ApiGateway };
|
|
82
75
|
|
|
83
76
|
//# sourceMappingURL=ApiGateway.js.map
|