UNPKG

@aws-cdk/aws-apigateway

Version:

The CDK Construct Library for AWS::ApiGateway

124 lines 18.6 kB
"use strict"; var _a; Object.defineProperty(exports, "__esModule", { value: true }); exports.DomainName = exports.SecurityPolicy = void 0; const jsiiDeprecationWarnings = require("../.warnings.jsii.js"); const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti"); const core_1 = require("@aws-cdk/core"); const apigateway_generated_1 = require("./apigateway.generated"); const base_path_mapping_1 = require("./base-path-mapping"); const restapi_1 = require("./restapi"); /** * The minimum version of the SSL protocol that you want API Gateway to use for HTTPS connections. */ var SecurityPolicy; (function (SecurityPolicy) { /** Cipher suite TLS 1.0 */ SecurityPolicy["TLS_1_0"] = "TLS_1_0"; /** Cipher suite TLS 1.2 */ SecurityPolicy["TLS_1_2"] = "TLS_1_2"; })(SecurityPolicy = exports.SecurityPolicy || (exports.SecurityPolicy = {})); class DomainName extends core_1.Resource { constructor(scope, id, props) { super(scope, id); this.basePaths = new Set(); try { jsiiDeprecationWarnings._aws_cdk_aws_apigateway_DomainNameProps(props); } catch (error) { if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { Error.captureStackTrace(error, DomainName); } throw error; } const endpointType = props.endpointType || restapi_1.EndpointType.REGIONAL; const edge = endpointType === restapi_1.EndpointType.EDGE; if (!core_1.Token.isUnresolved(props.domainName) && /[A-Z]/.test(props.domainName)) { throw new Error(`Domain name does not support uppercase letters. Got: ${props.domainName}`); } const mtlsConfig = this.configureMTLS(props.mtls); const resource = new apigateway_generated_1.CfnDomainName(this, 'Resource', { domainName: props.domainName, certificateArn: edge ? props.certificate.certificateArn : undefined, regionalCertificateArn: edge ? undefined : props.certificate.certificateArn, endpointConfiguration: { types: [endpointType] }, mutualTlsAuthentication: mtlsConfig, securityPolicy: props.securityPolicy, }); this.domainName = resource.ref; this.domainNameAliasDomainName = edge ? resource.attrDistributionDomainName : resource.attrRegionalDomainName; this.domainNameAliasHostedZoneId = edge ? resource.attrDistributionHostedZoneId : resource.attrRegionalHostedZoneId; if (props.mapping) { this.addBasePathMapping(props.mapping, { basePath: props.basePath, }); } } /** * Imports an existing domain name. */ static fromDomainNameAttributes(scope, id, attrs) { try { jsiiDeprecationWarnings._aws_cdk_aws_apigateway_DomainNameAttributes(attrs); } catch (error) { if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { Error.captureStackTrace(error, this.fromDomainNameAttributes); } throw error; } class Import extends core_1.Resource { constructor() { super(...arguments); this.domainName = attrs.domainName; this.domainNameAliasDomainName = attrs.domainNameAliasTarget; this.domainNameAliasHostedZoneId = attrs.domainNameAliasHostedZoneId; } } return new Import(scope, id); } /** * Maps this domain to an API endpoint. * @param targetApi That target API endpoint, requests will be mapped to the deployment stage. * @param options Options for mapping to base path with or without a stage */ addBasePathMapping(targetApi, options = {}) { try { jsiiDeprecationWarnings._aws_cdk_aws_apigateway_IRestApi(targetApi); jsiiDeprecationWarnings._aws_cdk_aws_apigateway_BasePathMappingOptions(options); } catch (error) { if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { Error.captureStackTrace(error, this.addBasePathMapping); } throw error; } if (this.basePaths.has(undefined)) { throw new Error('This domain name already has an empty base path. No additional base paths are allowed.'); } this.basePaths.add(options.basePath); const basePath = options.basePath || '/'; const id = `Map:${basePath}=>${core_1.Names.nodeUniqueId(targetApi.node)}`; return new base_path_mapping_1.BasePathMapping(this, id, { domainName: this, restApi: targetApi, ...options, }); } configureMTLS(mtlsConfig) { if (!mtlsConfig) return undefined; return { truststoreUri: mtlsConfig.bucket.s3UrlForObject(mtlsConfig.key), truststoreVersion: mtlsConfig.version, }; } } exports.DomainName = DomainName; _a = JSII_RTTI_SYMBOL_1; DomainName[_a] = { fqn: "@aws-cdk/aws-apigateway.DomainName", version: "1.204.0" }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"domain-name.js","sourceRoot":"","sources":["domain-name.ts"],"names":[],"mappings":"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","sourcesContent":["import * as acm from '@aws-cdk/aws-certificatemanager';\nimport { IBucket } from '@aws-cdk/aws-s3';\nimport { IResource, Names, Resource, Token } from '@aws-cdk/core';\nimport { Construct } from 'constructs';\nimport { CfnDomainName } from './apigateway.generated';\nimport { BasePathMapping, BasePathMappingOptions } from './base-path-mapping';\nimport { EndpointType, IRestApi } from './restapi';\n\n/**\n * The minimum version of the SSL protocol that you want API Gateway to use for HTTPS connections.\n */\nexport enum SecurityPolicy {\n  /** Cipher suite TLS 1.0 */\n  TLS_1_0 = 'TLS_1_0',\n\n  /** Cipher suite TLS 1.2 */\n  TLS_1_2 = 'TLS_1_2',\n}\n\nexport interface DomainNameOptions {\n  /**\n   * The custom domain name for your API. Uppercase letters are not supported.\n   */\n  readonly domainName: string;\n\n  /**\n   * The reference to an AWS-managed certificate for use by the edge-optimized\n   * endpoint for the domain name. For \"EDGE\" domain names, the certificate\n   * needs to be in the US East (N. Virginia) region.\n   */\n  readonly certificate: acm.ICertificate;\n\n  /**\n   * The type of endpoint for this DomainName.\n   * @default REGIONAL\n   */\n  readonly endpointType?: EndpointType;\n\n  /**\n   * The Transport Layer Security (TLS) version + cipher suite for this domain name.\n   * @see https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-apigateway-domainname.html\n   * @default SecurityPolicy.TLS_1_0\n   */\n  readonly securityPolicy?: SecurityPolicy;\n\n  /**\n   * The mutual TLS authentication configuration for a custom domain name.\n   * @default - mTLS is not configured.\n   */\n  readonly mtls?: MTLSConfig;\n\n  /**\n   * The base path name that callers of the API must provide in the URL after\n   * the domain name (e.g. `example.com/base-path`). If you specify this\n   * property, it can't be an empty string.\n   *\n   * @default - map requests from the domain root (e.g. `example.com`). If this\n   * is undefined, no additional mappings will be allowed on this domain name.\n   */\n  readonly basePath?: string;\n}\n\nexport interface DomainNameProps extends DomainNameOptions {\n  /**\n   * If specified, all requests to this domain will be mapped to the production\n   * deployment of this API. If you wish to map this domain to multiple APIs\n   * with different base paths, don't specify this option and use\n   * `addBasePathMapping`.\n   *\n   * @default - you will have to call `addBasePathMapping` to map this domain to\n   * API endpoints.\n   */\n  readonly mapping?: IRestApi;\n}\n\nexport interface IDomainName extends IResource {\n  /**\n   * The domain name (e.g. `example.com`)\n   *\n   * @attribute DomainName\n   */\n  readonly domainName: string;\n\n  /**\n   * The Route53 alias target to use in order to connect a record set to this domain through an alias.\n   *\n   * @attribute DistributionDomainName,RegionalDomainName\n   */\n  readonly domainNameAliasDomainName: string;\n\n  /**\n   * The Route53 hosted zone ID to use in order to connect a record set to this domain through an alias.\n   *\n   * @attribute DistributionHostedZoneId,RegionalHostedZoneId\n   */\n  readonly domainNameAliasHostedZoneId: string;\n}\n\nexport class DomainName extends Resource implements IDomainName {\n\n  /**\n   * Imports an existing domain name.\n   */\n  public static fromDomainNameAttributes(scope: Construct, id: string, attrs: DomainNameAttributes): IDomainName {\n    class Import extends Resource implements IDomainName {\n      public readonly domainName = attrs.domainName;\n      public readonly domainNameAliasDomainName = attrs.domainNameAliasTarget;\n      public readonly domainNameAliasHostedZoneId = attrs.domainNameAliasHostedZoneId;\n    }\n\n    return new Import(scope, id);\n  }\n\n  public readonly domainName: string;\n  public readonly domainNameAliasDomainName: string;\n  public readonly domainNameAliasHostedZoneId: string;\n  private readonly basePaths = new Set<string | undefined>();\n\n  constructor(scope: Construct, id: string, props: DomainNameProps) {\n    super(scope, id);\n\n    const endpointType = props.endpointType || EndpointType.REGIONAL;\n    const edge = endpointType === EndpointType.EDGE;\n\n    if (!Token.isUnresolved(props.domainName) && /[A-Z]/.test(props.domainName)) {\n      throw new Error(`Domain name does not support uppercase letters. Got: ${props.domainName}`);\n    }\n\n    const mtlsConfig = this.configureMTLS(props.mtls);\n    const resource = new CfnDomainName(this, 'Resource', {\n      domainName: props.domainName,\n      certificateArn: edge ? props.certificate.certificateArn : undefined,\n      regionalCertificateArn: edge ? undefined : props.certificate.certificateArn,\n      endpointConfiguration: { types: [endpointType] },\n      mutualTlsAuthentication: mtlsConfig,\n      securityPolicy: props.securityPolicy,\n    });\n\n    this.domainName = resource.ref;\n\n    this.domainNameAliasDomainName = edge\n      ? resource.attrDistributionDomainName\n      : resource.attrRegionalDomainName;\n\n    this.domainNameAliasHostedZoneId = edge\n      ? resource.attrDistributionHostedZoneId\n      : resource.attrRegionalHostedZoneId;\n\n    if (props.mapping) {\n      this.addBasePathMapping(props.mapping, {\n        basePath: props.basePath,\n      });\n    }\n  }\n\n  /**\n   * Maps this domain to an API endpoint.\n   * @param targetApi That target API endpoint, requests will be mapped to the deployment stage.\n   * @param options Options for mapping to base path with or without a stage\n   */\n  public addBasePathMapping(targetApi: IRestApi, options: BasePathMappingOptions = { }) {\n    if (this.basePaths.has(undefined)) {\n      throw new Error('This domain name already has an empty base path. No additional base paths are allowed.');\n    }\n    this.basePaths.add(options.basePath);\n    const basePath = options.basePath || '/';\n    const id = `Map:${basePath}=>${Names.nodeUniqueId(targetApi.node)}`;\n    return new BasePathMapping(this, id, {\n      domainName: this,\n      restApi: targetApi,\n      ...options,\n    });\n  }\n\n  private configureMTLS(mtlsConfig?: MTLSConfig): CfnDomainName.MutualTlsAuthenticationProperty | undefined {\n    if (!mtlsConfig) return undefined;\n    return {\n      truststoreUri: mtlsConfig.bucket.s3UrlForObject(mtlsConfig.key),\n      truststoreVersion: mtlsConfig.version,\n    };\n  }\n}\n\nexport interface DomainNameAttributes {\n  /**\n   * The domain name (e.g. `example.com`)\n   */\n  readonly domainName: string;\n\n  /**\n   * The Route53 alias target to use in order to connect a record set to this domain through an alias.\n   */\n  readonly domainNameAliasTarget: string;\n\n  /**\n   * The Route53 hosted zone ID to use in order to connect a record set to this domain through an alias.\n   */\n  readonly domainNameAliasHostedZoneId: string;\n}\n\n/**\n * The mTLS authentication configuration for a custom domain name.\n */\nexport interface MTLSConfig {\n  /**\n   * The bucket that the trust store is hosted in.\n   */\n  readonly bucket: IBucket;\n\n  /**\n   * The key in S3 to look at for the trust store.\n   */\n  readonly key: string;\n\n  /**\n   *  The version of the S3 object that contains your truststore.\n   *  To specify a version, you must have versioning enabled for the S3 bucket.\n   *  @default - latest version\n   */\n  readonly version?: string;\n}\n"]}