UNPKG

@aws-cdk/aws-route53

Version:

The CDK Construct Library for AWS::Route53

329 lines 38.1 kB
"use strict"; var _a, _b, _c; Object.defineProperty(exports, "__esModule", { value: true }); exports.PrivateHostedZone = exports.PublicHostedZone = exports.HostedZone = void 0; const jsiiDeprecationWarnings = require("../.warnings.jsii.js"); const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti"); const iam = require("@aws-cdk/aws-iam"); const cxschema = require("@aws-cdk/cloud-assembly-schema"); const core_1 = require("@aws-cdk/core"); const record_set_1 = require("./record-set"); const route53_generated_1 = require("./route53.generated"); const util_1 = require("./util"); /** * Container for records, and records contain information about how to route traffic for a * specific domain, such as example.com and its subdomains (acme.example.com, zenith.example.com) */ class HostedZone extends core_1.Resource { constructor(scope, id, props) { super(scope, id); /** * VPCs to which this hosted zone will be added */ this.vpcs = new Array(); try { jsiiDeprecationWarnings._aws_cdk_aws_route53_HostedZoneProps(props); } catch (error) { if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { Error.captureStackTrace(error, HostedZone); } throw error; } util_1.validateZoneName(props.zoneName); const resource = new route53_generated_1.CfnHostedZone(this, 'Resource', { name: props.zoneName + '.', hostedZoneConfig: props.comment ? { comment: props.comment } : undefined, queryLoggingConfig: props.queryLogsLogGroupArn ? { cloudWatchLogsLogGroupArn: props.queryLogsLogGroupArn } : undefined, vpcs: core_1.Lazy.any({ produce: () => this.vpcs.length === 0 ? undefined : this.vpcs }), }); this.hostedZoneId = resource.ref; this.hostedZoneNameServers = resource.attrNameServers; this.zoneName = props.zoneName; for (const vpc of props.vpcs || []) { this.addVpc(vpc); } } get hostedZoneArn() { return util_1.makeHostedZoneArn(this, this.hostedZoneId); } /** * Import a Route 53 hosted zone defined either outside the CDK, or in a different CDK stack * * Use when hosted zone ID is known. Hosted zone name becomes unavailable through this query. * * @param scope the parent Construct for this Construct * @param id the logical name of this Construct * @param hostedZoneId the ID of the hosted zone to import */ static fromHostedZoneId(scope, id, hostedZoneId) { class Import extends core_1.Resource { constructor() { super(...arguments); this.hostedZoneId = hostedZoneId; } get zoneName() { throw new Error('HostedZone.fromHostedZoneId doesn\'t support "zoneName"'); } get hostedZoneArn() { return util_1.makeHostedZoneArn(this, this.hostedZoneId); } } return new Import(scope, id); } /** * Imports a hosted zone from another stack. * * Use when both hosted zone ID and hosted zone name are known. * * @param scope the parent Construct for this Construct * @param id the logical name of this Construct * @param attrs the HostedZoneAttributes (hosted zone ID and hosted zone name) */ static fromHostedZoneAttributes(scope, id, attrs) { try { jsiiDeprecationWarnings._aws_cdk_aws_route53_HostedZoneAttributes(attrs); } catch (error) { if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { Error.captureStackTrace(error, this.fromHostedZoneAttributes); } throw error; } class Import extends core_1.Resource { constructor() { super(...arguments); this.hostedZoneId = attrs.hostedZoneId; this.zoneName = attrs.zoneName; } get hostedZoneArn() { return util_1.makeHostedZoneArn(this, this.hostedZoneId); } } return new Import(scope, id); } /** * Lookup a hosted zone in the current account/region based on query parameters. * Requires environment, you must specify env for the stack. * * Use to easily query hosted zones. * * @see https://docs.aws.amazon.com/cdk/latest/guide/environments.html */ static fromLookup(scope, id, query) { try { jsiiDeprecationWarnings._aws_cdk_aws_route53_HostedZoneProviderProps(query); } catch (error) { if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { Error.captureStackTrace(error, this.fromLookup); } throw error; } const DEFAULT_HOSTED_ZONE = { Id: 'DUMMY', Name: query.domainName, }; const response = core_1.ContextProvider.getValue(scope, { provider: cxschema.ContextProvider.HOSTED_ZONE_PROVIDER, dummyValue: DEFAULT_HOSTED_ZONE, props: query, }).value; // CDK handles the '.' at the end, so remove it here if (response.Name.endsWith('.')) { response.Name = response.Name.substring(0, response.Name.length - 1); } response.Id = response.Id.replace('/hostedzone/', ''); return HostedZone.fromHostedZoneAttributes(scope, id, { hostedZoneId: response.Id, zoneName: response.Name, }); } /** * Add another VPC to this private hosted zone. * * @param vpc the other VPC to add. */ addVpc(vpc) { this.vpcs.push({ vpcId: vpc.vpcId, vpcRegion: core_1.Stack.of(vpc).region }); } } exports.HostedZone = HostedZone; _a = JSII_RTTI_SYMBOL_1; HostedZone[_a] = { fqn: "@aws-cdk/aws-route53.HostedZone", version: "1.197.0" }; /** * Create a Route53 public hosted zone. * * @resource AWS::Route53::HostedZone */ class PublicHostedZone extends HostedZone { constructor(scope, id, props) { super(scope, id, props); try { jsiiDeprecationWarnings._aws_cdk_aws_route53_PublicHostedZoneProps(props); } catch (error) { if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { Error.captureStackTrace(error, PublicHostedZone); } throw error; } if (props.caaAmazon) { new record_set_1.CaaAmazonRecord(this, 'CaaAmazon', { zone: this, }); } if (!props.crossAccountZoneDelegationPrincipal && props.crossAccountZoneDelegationRoleName) { throw Error('crossAccountZoneDelegationRoleName property is not supported without crossAccountZoneDelegationPrincipal'); } if (props.crossAccountZoneDelegationPrincipal) { this.crossAccountZoneDelegationRole = new iam.Role(this, 'CrossAccountZoneDelegationRole', { roleName: props.crossAccountZoneDelegationRoleName, assumedBy: props.crossAccountZoneDelegationPrincipal, inlinePolicies: { delegation: new iam.PolicyDocument({ statements: [ new iam.PolicyStatement({ actions: ['route53:ChangeResourceRecordSets'], resources: [this.hostedZoneArn], }), new iam.PolicyStatement({ actions: ['route53:ListHostedZonesByName'], resources: ['*'], }), ], }), }, }); } } /** * Import a Route 53 public hosted zone defined either outside the CDK, or in a different CDK stack * * @param scope the parent Construct for this Construct * @param id the logical name of this Construct * @param publicHostedZoneId the ID of the public hosted zone to import */ static fromPublicHostedZoneId(scope, id, publicHostedZoneId) { class Import extends core_1.Resource { constructor() { super(...arguments); this.hostedZoneId = publicHostedZoneId; } get zoneName() { throw new Error('cannot retrieve "zoneName" from an an imported hosted zone'); } get hostedZoneArn() { return util_1.makeHostedZoneArn(this, this.hostedZoneId); } } return new Import(scope, id); } /** * Imports a public hosted zone from another stack. * * Use when both hosted zone ID and hosted zone name are known. * * @param scope the parent Construct for this Construct * @param id the logical name of this Construct * @param attrs the PublicHostedZoneAttributes (hosted zone ID and hosted zone name) */ static fromPublicHostedZoneAttributes(scope, id, attrs) { try { jsiiDeprecationWarnings._aws_cdk_aws_route53_PublicHostedZoneAttributes(attrs); } catch (error) { if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { Error.captureStackTrace(error, this.fromPublicHostedZoneAttributes); } throw error; } class Import extends core_1.Resource { constructor() { super(...arguments); this.hostedZoneId = attrs.hostedZoneId; this.zoneName = attrs.zoneName; } get hostedZoneArn() { return util_1.makeHostedZoneArn(this, this.hostedZoneId); } } return new Import(scope, id); } addVpc(_vpc) { throw new Error('Cannot associate public hosted zones with a VPC'); } /** * Adds a delegation from this zone to a designated zone. * * @param delegate the zone being delegated to. * @param opts options for creating the DNS record, if any. */ addDelegation(delegate, opts = {}) { try { jsiiDeprecationWarnings._aws_cdk_aws_route53_IPublicHostedZone(delegate); jsiiDeprecationWarnings._aws_cdk_aws_route53_ZoneDelegationOptions(opts); } catch (error) { if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { Error.captureStackTrace(error, this.addDelegation); } throw error; } new record_set_1.ZoneDelegationRecord(this, `${this.zoneName} -> ${delegate.zoneName}`, { zone: this, recordName: delegate.zoneName, nameServers: delegate.hostedZoneNameServers, comment: opts.comment, ttl: opts.ttl, }); } } exports.PublicHostedZone = PublicHostedZone; _b = JSII_RTTI_SYMBOL_1; PublicHostedZone[_b] = { fqn: "@aws-cdk/aws-route53.PublicHostedZone", version: "1.197.0" }; /** * Create a Route53 private hosted zone for use in one or more VPCs. * * Note that `enableDnsHostnames` and `enableDnsSupport` must have been enabled * for the VPC you're configuring for private hosted zones. * * @resource AWS::Route53::HostedZone */ class PrivateHostedZone extends HostedZone { constructor(scope, id, props) { super(scope, id, props); try { jsiiDeprecationWarnings._aws_cdk_aws_route53_PrivateHostedZoneProps(props); } catch (error) { if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { Error.captureStackTrace(error, PrivateHostedZone); } throw error; } this.addVpc(props.vpc); } /** * Import a Route 53 private hosted zone defined either outside the CDK, or in a different CDK stack * * @param scope the parent Construct for this Construct * @param id the logical name of this Construct * @param privateHostedZoneId the ID of the private hosted zone to import */ static fromPrivateHostedZoneId(scope, id, privateHostedZoneId) { class Import extends core_1.Resource { constructor() { super(...arguments); this.hostedZoneId = privateHostedZoneId; } get zoneName() { throw new Error('cannot retrieve "zoneName" from an an imported hosted zone'); } get hostedZoneArn() { return util_1.makeHostedZoneArn(this, this.hostedZoneId); } } return new Import(scope, id); } } exports.PrivateHostedZone = PrivateHostedZone; _c = JSII_RTTI_SYMBOL_1; PrivateHostedZone[_c] = { fqn: "@aws-cdk/aws-route53.PrivateHostedZone", version: "1.197.0" }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"hosted-zone.js","sourceRoot":"","sources":["hosted-zone.ts"],"names":[],"mappings":"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","sourcesContent":["import * as ec2 from '@aws-cdk/aws-ec2';\nimport * as iam from '@aws-cdk/aws-iam';\nimport * as cxschema from '@aws-cdk/cloud-assembly-schema';\nimport { ContextProvider, Duration, Lazy, Resource, Stack } from '@aws-cdk/core';\nimport { Construct } from 'constructs';\nimport { HostedZoneProviderProps } from './hosted-zone-provider';\nimport { HostedZoneAttributes, IHostedZone, PublicHostedZoneAttributes } from './hosted-zone-ref';\nimport { CaaAmazonRecord, ZoneDelegationRecord } from './record-set';\nimport { CfnHostedZone } from './route53.generated';\nimport { makeHostedZoneArn, validateZoneName } from './util';\n\n/**\n * Common properties to create a Route 53 hosted zone\n */\nexport interface CommonHostedZoneProps {\n  /**\n   * The name of the domain. For resource record types that include a domain\n   * name, specify a fully qualified domain name.\n   */\n  readonly zoneName: string;\n\n  /**\n   * Any comments that you want to include about the hosted zone.\n   *\n   * @default none\n   */\n  readonly comment?: string;\n\n  /**\n   * The Amazon Resource Name (ARN) for the log group that you want Amazon Route 53 to send query logs to.\n   *\n   * @default disabled\n   */\n  readonly queryLogsLogGroupArn?: string;\n}\n\n/**\n * Properties of a new hosted zone\n */\nexport interface HostedZoneProps extends CommonHostedZoneProps {\n  /**\n   * A VPC that you want to associate with this hosted zone. When you specify\n   * this property, a private hosted zone will be created.\n   *\n   * You can associate additional VPCs to this private zone using `addVpc(vpc)`.\n   *\n   * @default public (no VPCs associated)\n   */\n  readonly vpcs?: ec2.IVpc[];\n}\n\n/**\n * Container for records, and records contain information about how to route traffic for a\n * specific domain, such as example.com and its subdomains (acme.example.com, zenith.example.com)\n */\nexport class HostedZone extends Resource implements IHostedZone {\n  public get hostedZoneArn(): string {\n    return makeHostedZoneArn(this, this.hostedZoneId);\n  }\n\n  /**\n   * Import a Route 53 hosted zone defined either outside the CDK, or in a different CDK stack\n   *\n   * Use when hosted zone ID is known. Hosted zone name becomes unavailable through this query.\n   *\n   * @param scope the parent Construct for this Construct\n   * @param id  the logical name of this Construct\n   * @param hostedZoneId the ID of the hosted zone to import\n   */\n  public static fromHostedZoneId(scope: Construct, id: string, hostedZoneId: string): IHostedZone {\n    class Import extends Resource implements IHostedZone {\n      public readonly hostedZoneId = hostedZoneId;\n      public get zoneName(): string {\n        throw new Error('HostedZone.fromHostedZoneId doesn\\'t support \"zoneName\"');\n      }\n      public get hostedZoneArn(): string {\n        return makeHostedZoneArn(this, this.hostedZoneId);\n      }\n    }\n\n    return new Import(scope, id);\n  }\n\n  /**\n   * Imports a hosted zone from another stack.\n   *\n   * Use when both hosted zone ID and hosted zone name are known.\n   *\n   * @param scope the parent Construct for this Construct\n   * @param id  the logical name of this Construct\n   * @param attrs the HostedZoneAttributes (hosted zone ID and hosted zone name)\n   */\n  public static fromHostedZoneAttributes(scope: Construct, id: string, attrs: HostedZoneAttributes): IHostedZone {\n    class Import extends Resource implements IHostedZone {\n      public readonly hostedZoneId = attrs.hostedZoneId;\n      public readonly zoneName = attrs.zoneName;\n      public get hostedZoneArn(): string {\n        return makeHostedZoneArn(this, this.hostedZoneId);\n      }\n    }\n\n    return new Import(scope, id);\n  }\n\n  /**\n   * Lookup a hosted zone in the current account/region based on query parameters.\n   * Requires environment, you must specify env for the stack.\n   *\n   * Use to easily query hosted zones.\n   *\n   * @see https://docs.aws.amazon.com/cdk/latest/guide/environments.html\n   */\n  public static fromLookup(scope: Construct, id: string, query: HostedZoneProviderProps): IHostedZone {\n    const DEFAULT_HOSTED_ZONE: HostedZoneContextResponse = {\n      Id: 'DUMMY',\n      Name: query.domainName,\n    };\n\n    interface HostedZoneContextResponse {\n      Id: string;\n      Name: string;\n    }\n\n    const response: HostedZoneContextResponse = ContextProvider.getValue(scope, {\n      provider: cxschema.ContextProvider.HOSTED_ZONE_PROVIDER,\n      dummyValue: DEFAULT_HOSTED_ZONE,\n      props: query,\n    }).value;\n\n    // CDK handles the '.' at the end, so remove it here\n    if (response.Name.endsWith('.')) {\n      response.Name = response.Name.substring(0, response.Name.length - 1);\n    }\n\n    response.Id = response.Id.replace('/hostedzone/', '');\n\n    return HostedZone.fromHostedZoneAttributes(scope, id, {\n      hostedZoneId: response.Id,\n      zoneName: response.Name,\n    });\n  }\n\n  public readonly hostedZoneId: string;\n  public readonly zoneName: string;\n  public readonly hostedZoneNameServers?: string[];\n\n  /**\n   * VPCs to which this hosted zone will be added\n   */\n  protected readonly vpcs = new Array<CfnHostedZone.VPCProperty>();\n\n  constructor(scope: Construct, id: string, props: HostedZoneProps) {\n    super(scope, id);\n\n    validateZoneName(props.zoneName);\n\n    const resource = new CfnHostedZone(this, 'Resource', {\n      name: props.zoneName + '.',\n      hostedZoneConfig: props.comment ? { comment: props.comment } : undefined,\n      queryLoggingConfig: props.queryLogsLogGroupArn ? { cloudWatchLogsLogGroupArn: props.queryLogsLogGroupArn } : undefined,\n      vpcs: Lazy.any({ produce: () => this.vpcs.length === 0 ? undefined : this.vpcs }),\n    });\n\n    this.hostedZoneId = resource.ref;\n    this.hostedZoneNameServers = resource.attrNameServers;\n    this.zoneName = props.zoneName;\n\n    for (const vpc of props.vpcs || []) {\n      this.addVpc(vpc);\n    }\n  }\n\n  /**\n   * Add another VPC to this private hosted zone.\n   *\n   * @param vpc the other VPC to add.\n   */\n  public addVpc(vpc: ec2.IVpc) {\n    this.vpcs.push({ vpcId: vpc.vpcId, vpcRegion: Stack.of(vpc).region });\n  }\n}\n\n/**\n * Construction properties for a PublicHostedZone.\n */\nexport interface PublicHostedZoneProps extends CommonHostedZoneProps {\n  /**\n   * Whether to create a CAA record to restrict certificate authorities allowed\n   * to issue certificates for this domain to Amazon only.\n   *\n   * @default false\n   */\n  readonly caaAmazon?: boolean;\n\n  /**\n   * A principal which is trusted to assume a role for zone delegation\n   *\n   * @default - No delegation configuration\n   */\n  readonly crossAccountZoneDelegationPrincipal?: iam.IPrincipal;\n\n  /**\n   * The name of the role created for cross account delegation\n   *\n   * @default - A role name is generated automatically\n   */\n  readonly crossAccountZoneDelegationRoleName?: string;\n}\n\n/**\n * Represents a Route 53 public hosted zone\n */\nexport interface IPublicHostedZone extends IHostedZone { }\n\n/**\n * Create a Route53 public hosted zone.\n *\n * @resource AWS::Route53::HostedZone\n */\nexport class PublicHostedZone extends HostedZone implements IPublicHostedZone {\n\n  /**\n   * Import a Route 53 public hosted zone defined either outside the CDK, or in a different CDK stack\n   *\n   * @param scope the parent Construct for this Construct\n   * @param id the logical name of this Construct\n   * @param publicHostedZoneId the ID of the public hosted zone to import\n   */\n  public static fromPublicHostedZoneId(scope: Construct, id: string, publicHostedZoneId: string): IPublicHostedZone {\n    class Import extends Resource implements IPublicHostedZone {\n      public readonly hostedZoneId = publicHostedZoneId;\n      public get zoneName(): string { throw new Error('cannot retrieve \"zoneName\" from an an imported hosted zone'); }\n      public get hostedZoneArn(): string {\n        return makeHostedZoneArn(this, this.hostedZoneId);\n      }\n    }\n    return new Import(scope, id);\n  }\n\n  /**\n   * Imports a public hosted zone from another stack.\n   *\n   * Use when both hosted zone ID and hosted zone name are known.\n   *\n   * @param scope the parent Construct for this Construct\n   * @param id  the logical name of this Construct\n   * @param attrs the PublicHostedZoneAttributes (hosted zone ID and hosted zone name)\n   */\n  public static fromPublicHostedZoneAttributes(scope: Construct, id: string, attrs: PublicHostedZoneAttributes): IHostedZone {\n    class Import extends Resource implements IHostedZone {\n      public readonly hostedZoneId = attrs.hostedZoneId;\n      public readonly zoneName = attrs.zoneName;\n      public get hostedZoneArn(): string {\n        return makeHostedZoneArn(this, this.hostedZoneId);\n      }\n    }\n    return new Import(scope, id);\n  }\n\n  /**\n   * Role for cross account zone delegation\n   */\n  public readonly crossAccountZoneDelegationRole?: iam.Role;\n\n  constructor(scope: Construct, id: string, props: PublicHostedZoneProps) {\n    super(scope, id, props);\n\n    if (props.caaAmazon) {\n      new CaaAmazonRecord(this, 'CaaAmazon', {\n        zone: this,\n      });\n    }\n\n    if (!props.crossAccountZoneDelegationPrincipal && props.crossAccountZoneDelegationRoleName) {\n      throw Error('crossAccountZoneDelegationRoleName property is not supported without crossAccountZoneDelegationPrincipal');\n    }\n\n    if (props.crossAccountZoneDelegationPrincipal) {\n      this.crossAccountZoneDelegationRole = new iam.Role(this, 'CrossAccountZoneDelegationRole', {\n        roleName: props.crossAccountZoneDelegationRoleName,\n        assumedBy: props.crossAccountZoneDelegationPrincipal,\n        inlinePolicies: {\n          delegation: new iam.PolicyDocument({\n            statements: [\n              new iam.PolicyStatement({\n                actions: ['route53:ChangeResourceRecordSets'],\n                resources: [this.hostedZoneArn],\n              }),\n              new iam.PolicyStatement({\n                actions: ['route53:ListHostedZonesByName'],\n                resources: ['*'],\n              }),\n            ],\n          }),\n        },\n      });\n    }\n  }\n\n  public addVpc(_vpc: ec2.IVpc) {\n    throw new Error('Cannot associate public hosted zones with a VPC');\n  }\n\n  /**\n   * Adds a delegation from this zone to a designated zone.\n   *\n   * @param delegate the zone being delegated to.\n   * @param opts     options for creating the DNS record, if any.\n   */\n  public addDelegation(delegate: IPublicHostedZone, opts: ZoneDelegationOptions = {}): void {\n    new ZoneDelegationRecord(this, `${this.zoneName} -> ${delegate.zoneName}`, {\n      zone: this,\n      recordName: delegate.zoneName,\n      nameServers: delegate.hostedZoneNameServers!, // PublicHostedZones always have name servers!\n      comment: opts.comment,\n      ttl: opts.ttl,\n    });\n  }\n}\n\n/**\n * Options available when creating a delegation relationship from one PublicHostedZone to another.\n */\nexport interface ZoneDelegationOptions {\n  /**\n   * A comment to add on the DNS record created to incorporate the delegation.\n   *\n   * @default none\n   */\n  readonly comment?: string;\n\n  /**\n   * The TTL (Time To Live) of the DNS delegation record in DNS caches.\n   *\n   * @default 172800\n   */\n  readonly ttl?: Duration;\n}\n\n/**\n * Properties to create a Route 53 private hosted zone\n */\nexport interface PrivateHostedZoneProps extends CommonHostedZoneProps {\n  /**\n   * A VPC that you want to associate with this hosted zone.\n   *\n   * Private hosted zones must be associated with at least one VPC. You can\n   * associated additional VPCs using `addVpc(vpc)`.\n   */\n  readonly vpc: ec2.IVpc;\n}\n\n/**\n * Represents a Route 53 private hosted zone\n */\nexport interface IPrivateHostedZone extends IHostedZone {}\n\n/**\n * Create a Route53 private hosted zone for use in one or more VPCs.\n *\n * Note that `enableDnsHostnames` and `enableDnsSupport` must have been enabled\n * for the VPC you're configuring for private hosted zones.\n *\n * @resource AWS::Route53::HostedZone\n */\nexport class PrivateHostedZone extends HostedZone implements IPrivateHostedZone {\n\n  /**\n   * Import a Route 53 private hosted zone defined either outside the CDK, or in a different CDK stack\n   *\n   * @param scope the parent Construct for this Construct\n   * @param id the logical name of this Construct\n   * @param privateHostedZoneId the ID of the private hosted zone to import\n   */\n  public static fromPrivateHostedZoneId(scope: Construct, id: string, privateHostedZoneId: string): IPrivateHostedZone {\n    class Import extends Resource implements IPrivateHostedZone {\n      public readonly hostedZoneId = privateHostedZoneId;\n      public get zoneName(): string { throw new Error('cannot retrieve \"zoneName\" from an an imported hosted zone'); }\n      public get hostedZoneArn(): string {\n        return makeHostedZoneArn(this, this.hostedZoneId);\n      }\n    }\n    return new Import(scope, id);\n  }\n\n  constructor(scope: Construct, id: string, props: PrivateHostedZoneProps) {\n    super(scope, id, props);\n\n    this.addVpc(props.vpc);\n  }\n}\n"]}