UNPKG

@aws-cdk/aws-amplify-alpha

Version:

The CDK Construct Library for AWS::Amplify

146 lines 23.6 kB
"use strict"; var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) { var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; return c > 3 && r && Object.defineProperty(target, key, r), r; }; var _a; Object.defineProperty(exports, "__esModule", { value: true }); exports.Branch = void 0; const jsiiDeprecationWarnings = require("../.warnings.jsii.js"); const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti"); const iam = require("aws-cdk-lib/aws-iam"); const core_1 = require("aws-cdk-lib/core"); const custom_resources_1 = require("aws-cdk-lib/custom-resources"); const aws_amplify_1 = require("aws-cdk-lib/aws-amplify"); const app_1 = require("./app"); const utils_1 = require("./utils"); const asset_deployment_provider_generated_1 = require("../custom-resource-handlers/dist/aws-amplify-alpha/asset-deployment-provider.generated"); const metadata_resource_1 = require("aws-cdk-lib/core/lib/metadata-resource"); const prop_injectable_1 = require("aws-cdk-lib/core/lib/prop-injectable"); /** * An Amplify Console branch */ let Branch = class Branch extends core_1.Resource { /** * Import an existing branch */ static fromBranchName(scope, id, branchName) { class Import extends core_1.Resource { constructor() { super(...arguments); this.branchName = branchName; } } return new Import(scope, id); } constructor(scope, id, props) { super(scope, id); try { jsiiDeprecationWarnings._aws_cdk_aws_amplify_alpha_BranchProps(props); } catch (error) { if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { Error.captureStackTrace(error, Branch); } throw error; } // Enhanced CDK Analytics Telemetry (0, metadata_resource_1.addConstructMetadata)(this, props); if (props.app instanceof app_1.App) { const platform = props.app.platform; const isSSR = (0, utils_1.isServerSideRendered)(platform); if (props.computeRole && !isSSR) { throw new core_1.ValidationError('`computeRole` can only be specified for branches of apps with `Platform.WEB_COMPUTE` or `Platform.WEB_DYNAMIC`.', this); } } this.environmentVariables = props.environmentVariables || {}; const branchName = props.branchName || id; const branch = new aws_amplify_1.CfnBranch(this, 'Resource', { appId: props.app.appId, basicAuthConfig: props.basicAuth && props.basicAuth.bind(this, `${branchName}BasicAuth`), branchName, buildSpec: props.buildSpec && props.buildSpec.toBuildSpec(), description: props.description, enableAutoBuild: props.autoBuild ?? true, enablePullRequestPreview: props.pullRequestPreview ?? true, environmentVariables: core_1.Lazy.any({ produce: () => (0, utils_1.renderEnvironmentVariables)(this.environmentVariables) }, { omitEmptyArray: true }), pullRequestEnvironmentName: props.pullRequestEnvironmentName, stage: props.stage, enablePerformanceMode: props.performanceMode, enableSkewProtection: props.skewProtection, computeRoleArn: props.computeRole?.roleArn, }); this.arn = branch.attrArn; this.branchName = branch.attrBranchName; if (props.asset) { new core_1.CustomResource(this, 'DeploymentResource', { serviceToken: AmplifyAssetDeploymentProvider.getOrCreate(this), resourceType: 'Custom::AmplifyAssetDeployment', properties: { AppId: props.app.appId, BranchName: branchName, S3ObjectKey: props.asset.s3ObjectKey, S3BucketName: props.asset.s3BucketName, }, }); } } /** * Adds an environment variable to this branch. * * All environment variables that you add are encrypted to prevent rogue * access so you can use them to store secret information. */ addEnvironment(name, value) { this.environmentVariables[name] = value; return this; } }; exports.Branch = Branch; _a = JSII_RTTI_SYMBOL_1; Branch[_a] = { fqn: "@aws-cdk/aws-amplify-alpha.Branch", version: "2.215.0-alpha.0" }; /** Uniquely identifies this class. */ Branch.PROPERTY_INJECTION_ID = '@aws-cdk.aws-amplify-alpha.Branch'; __decorate([ (0, metadata_resource_1.MethodMetadata)() ], Branch.prototype, "addEnvironment", null); exports.Branch = Branch = __decorate([ prop_injectable_1.propertyInjectable ], Branch); class AmplifyAssetDeploymentProvider extends core_1.NestedStack { /** * Returns the singleton provider. */ static getOrCreate(scope) { const providerId = 'com.amazonaws.cdk.custom-resources.amplify-asset-deployment-provider'; const stack = core_1.Stack.of(scope); const group = stack.node.tryFindChild(providerId) ?? new AmplifyAssetDeploymentProvider(stack, providerId); return group.provider.serviceToken; } constructor(scope, id) { super(scope, id); const onEvent = new asset_deployment_provider_generated_1.AssetDeploymentOnEventFunction(this, 'amplify-asset-deployment-on-event'); onEvent.addToRolePolicy(new iam.PolicyStatement({ resources: ['*'], actions: [ 's3:GetObject', 's3:GetSignedUrl', 'amplify:ListJobs', 'amplify:StartDeployment', ], })); const isComplete = new asset_deployment_provider_generated_1.AssetDeploymentIsCompleteFunction(this, 'amplify-asset-deployment-is-complete'); isComplete.addToRolePolicy(new iam.PolicyStatement({ resources: ['*'], actions: ['amplify:GetJob*'], })); this.provider = new custom_resources_1.Provider(this, 'amplify-asset-deployment-handler-provider', { onEventHandler: onEvent, isCompleteHandler: isComplete, totalTimeout: core_1.Duration.minutes(5), }); } } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"branch.js","sourceRoot":"","sources":["branch.ts"],"names":[],"mappings":"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","sourcesContent":["import * as codebuild from 'aws-cdk-lib/aws-codebuild';\nimport * as iam from 'aws-cdk-lib/aws-iam';\nimport { Asset } from 'aws-cdk-lib/aws-s3-assets';\nimport {\n  CustomResource,\n  IResource,\n  Lazy,\n  Resource,\n  Duration,\n  NestedStack,\n  Stack,\n  ValidationError,\n} from 'aws-cdk-lib/core';\nimport { Provider } from 'aws-cdk-lib/custom-resources';\nimport { Construct } from 'constructs';\nimport { CfnBranch } from 'aws-cdk-lib/aws-amplify';\nimport { App, IApp } from './app';\nimport { BasicAuth } from './basic-auth';\nimport { renderEnvironmentVariables, isServerSideRendered } from './utils';\nimport { AssetDeploymentIsCompleteFunction, AssetDeploymentOnEventFunction } from '../custom-resource-handlers/dist/aws-amplify-alpha/asset-deployment-provider.generated';\nimport { addConstructMetadata, MethodMetadata } from 'aws-cdk-lib/core/lib/metadata-resource';\nimport { propertyInjectable } from 'aws-cdk-lib/core/lib/prop-injectable';\n\n/**\n * A branch\n */\nexport interface IBranch extends IResource {\n  /**\n   * The name of the branch\n   *\n   * @attribute\n   */\n  readonly branchName: string;\n}\n\n/**\n * Options to add a branch to an application\n */\nexport interface BranchOptions {\n  /**\n   * The Basic Auth configuration. Use this to set password protection for\n   * the branch\n   *\n   * @default - no password protection\n   */\n  readonly basicAuth?: BasicAuth;\n\n  /**\n   * The name of the branch\n   *\n   * @default - the construct's id\n   */\n  readonly branchName?: string;\n\n  /**\n   * BuildSpec for the branch\n   *\n   * @see https://docs.aws.amazon.com/amplify/latest/userguide/build-settings.html\n   *\n   * @default - no build spec\n   */\n  readonly buildSpec?: codebuild.BuildSpec;\n\n  /**\n   * A description for the branch\n   *\n   * @default - no description\n   */\n  readonly description?: string;\n\n  /**\n   * Whether to enable auto building for the branch\n   *\n   * @default true\n   */\n  readonly autoBuild?: boolean;\n\n  /**\n   * Whether to enable pull request preview for the branch.\n   *\n   * @default true\n   */\n  readonly pullRequestPreview?: boolean;\n\n  /**\n   * Environment variables for the branch.\n   *\n   * All environment variables that you add are encrypted to prevent rogue\n   * access so you can use them to store secret information.\n   *\n   * @default - application environment variables\n   */\n  readonly environmentVariables?: { [name: string]: string };\n\n  /**\n   * The dedicated backend environment for the pull request previews\n   *\n   * @default - automatically provision a temporary backend\n   */\n  readonly pullRequestEnvironmentName?: string;\n\n  /**\n   * Stage for the branch\n   *\n   * @default - no stage\n   */\n  readonly stage?: string;\n\n  /**\n   * Asset for deployment.\n   *\n   * The Amplify app must not have a sourceCodeProvider configured as this resource uses Amplify's\n   * startDeployment API to initiate and deploy a S3 asset onto the App.\n   *\n   * @default - no asset\n   */\n  readonly asset?: Asset;\n\n  /**\n   * Enables performance mode for the branch.\n   *\n   * Performance mode optimizes for faster hosting performance by keeping content cached at the edge\n   * for a longer interval. When performance mode is enabled, hosting configuration or code changes\n   * can take up to 10 minutes to roll out.\n   *\n   * @default false\n   */\n  readonly performanceMode?: boolean;\n\n  /**\n   * Specifies whether the skew protection feature is enabled for the branch.\n   *\n   * Deployment skew protection is available to Amplify applications to eliminate version skew issues\n   * between client and servers in web applications.\n   * When you apply skew protection to a branch, you can ensure that your clients always interact\n   * with the correct version of server-side assets, regardless of when a deployment occurs.\n   *\n   * @default None - Default setting is no skew protection.\n   */\n  readonly skewProtection?: boolean;\n\n  /**\n   * The IAM role to assign to a branch of an SSR app.\n   * The SSR Compute role allows the Amplify Hosting compute service to securely access specific AWS resources based on the role's permissions.\n   *\n   * This role overrides the app-level compute role.\n   *\n   * @default undefined - No specific role for the branch. If the app has a compute role, it will be inherited.\n   */\n  readonly computeRole?: iam.IRole;\n}\n\n/**\n * Properties for a Branch\n */\nexport interface BranchProps extends BranchOptions {\n  /**\n   * The application within which the branch must be created\n   */\n  readonly app: IApp;\n}\n\n/**\n * An Amplify Console branch\n */\n@propertyInjectable\nexport class Branch extends Resource implements IBranch {\n  /** Uniquely identifies this class. */\n  public static readonly PROPERTY_INJECTION_ID: string = '@aws-cdk.aws-amplify-alpha.Branch';\n\n  /**\n   * Import an existing branch\n   */\n  public static fromBranchName(scope: Construct, id: string, branchName: string): IBranch {\n    class Import extends Resource implements IBranch {\n      public readonly branchName = branchName;\n    }\n    return new Import(scope, id);\n  }\n\n  /**\n   * The ARN of the branch\n   *\n   * @attribute\n   */\n  public readonly arn: string;\n\n  public readonly branchName: string;\n\n  private readonly environmentVariables: { [name: string]: string };\n\n  constructor(scope: Construct, id: string, props: BranchProps) {\n    super(scope, id);\n    // Enhanced CDK Analytics Telemetry\n    addConstructMetadata(this, props);\n\n    if (props.app instanceof App) {\n      const platform = props.app.platform;\n      const isSSR = isServerSideRendered(platform);\n\n      if (props.computeRole && !isSSR) {\n        throw new ValidationError('`computeRole` can only be specified for branches of apps with `Platform.WEB_COMPUTE` or `Platform.WEB_DYNAMIC`.', this);\n      }\n    }\n\n    this.environmentVariables = props.environmentVariables || {};\n\n    const branchName = props.branchName || id;\n    const branch = new CfnBranch(this, 'Resource', {\n      appId: props.app.appId,\n      basicAuthConfig: props.basicAuth && props.basicAuth.bind(this, `${branchName}BasicAuth`),\n      branchName,\n      buildSpec: props.buildSpec && props.buildSpec.toBuildSpec(),\n      description: props.description,\n      enableAutoBuild: props.autoBuild ?? true,\n      enablePullRequestPreview: props.pullRequestPreview ?? true,\n      environmentVariables: Lazy.any({ produce: () => renderEnvironmentVariables(this.environmentVariables) }, { omitEmptyArray: true }),\n      pullRequestEnvironmentName: props.pullRequestEnvironmentName,\n      stage: props.stage,\n      enablePerformanceMode: props.performanceMode,\n      enableSkewProtection: props.skewProtection,\n      computeRoleArn: props.computeRole?.roleArn,\n    });\n\n    this.arn = branch.attrArn;\n    this.branchName = branch.attrBranchName;\n\n    if (props.asset) {\n      new CustomResource(this, 'DeploymentResource', {\n        serviceToken: AmplifyAssetDeploymentProvider.getOrCreate(this),\n        resourceType: 'Custom::AmplifyAssetDeployment',\n        properties: {\n          AppId: props.app.appId,\n          BranchName: branchName,\n          S3ObjectKey: props.asset.s3ObjectKey,\n          S3BucketName: props.asset.s3BucketName,\n        },\n      });\n    }\n  }\n\n  /**\n   * Adds an environment variable to this branch.\n   *\n   * All environment variables that you add are encrypted to prevent rogue\n   * access so you can use them to store secret information.\n   */\n  @MethodMetadata()\n  public addEnvironment(name: string, value: string) {\n    this.environmentVariables[name] = value;\n    return this;\n  }\n}\n\nclass AmplifyAssetDeploymentProvider extends NestedStack {\n  /**\n   * Returns the singleton provider.\n   */\n  public static getOrCreate(scope: Construct) {\n    const providerId =\n      'com.amazonaws.cdk.custom-resources.amplify-asset-deployment-provider';\n    const stack = Stack.of(scope);\n    const group =\n      (stack.node.tryFindChild(providerId) as AmplifyAssetDeploymentProvider) ?? new AmplifyAssetDeploymentProvider(stack, providerId);\n    return group.provider.serviceToken;\n  }\n\n  private readonly provider: Provider;\n\n  constructor(scope: Construct, id: string) {\n    super(scope, id);\n\n    const onEvent = new AssetDeploymentOnEventFunction(this, 'amplify-asset-deployment-on-event');\n    onEvent.addToRolePolicy(new iam.PolicyStatement({\n      resources: ['*'],\n      actions: [\n        's3:GetObject',\n        's3:GetSignedUrl',\n        'amplify:ListJobs',\n        'amplify:StartDeployment',\n      ],\n    }));\n\n    const isComplete = new AssetDeploymentIsCompleteFunction(this, 'amplify-asset-deployment-is-complete');\n    isComplete.addToRolePolicy(new iam.PolicyStatement({\n      resources: ['*'],\n      actions: ['amplify:GetJob*'],\n    }));\n\n    this.provider = new Provider(\n      this,\n      'amplify-asset-deployment-handler-provider',\n      {\n        onEventHandler: onEvent,\n        isCompleteHandler: isComplete,\n        totalTimeout: Duration.minutes(5),\n      },\n    );\n  }\n}\n"]}