UNPKG

@aws-cdk/aws-ec2

Version:

The CDK Construct Library for AWS::EC2

58 lines 12.5 kB
"use strict"; var _a; Object.defineProperty(exports, "__esModule", { value: true }); exports.VpcEndpointService = 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 region_info_1 = require("@aws-cdk/region-info"); const ec2_generated_1 = require("./ec2.generated"); /** * A VPC endpoint service * @resource AWS::EC2::VPCEndpointService * */ class VpcEndpointService extends core_1.Resource { constructor(scope, id, props) { super(scope, id); try { jsiiDeprecationWarnings._aws_cdk_aws_ec2_VpcEndpointServiceProps(props); } catch (error) { if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { Error.captureStackTrace(error, VpcEndpointService); } throw error; } if (props.vpcEndpointServiceLoadBalancers === undefined || props.vpcEndpointServiceLoadBalancers.length === 0) { throw new Error('VPC Endpoint Service must have at least one load balancer specified.'); } this.vpcEndpointServiceLoadBalancers = props.vpcEndpointServiceLoadBalancers; this.acceptanceRequired = props.acceptanceRequired ?? true; if (props.allowedPrincipals && props.whitelistedPrincipals) { throw new Error('`whitelistedPrincipals` is deprecated; please use `allowedPrincipals` instead'); } this.allowedPrincipals = props.allowedPrincipals ?? props.whitelistedPrincipals ?? []; this.whitelistedPrincipals = this.allowedPrincipals; this.endpointService = new ec2_generated_1.CfnVPCEndpointService(this, id, { networkLoadBalancerArns: this.vpcEndpointServiceLoadBalancers.map(lb => lb.loadBalancerArn), acceptanceRequired: this.acceptanceRequired, }); this.vpcEndpointServiceId = this.endpointService.ref; const { region } = core_1.Stack.of(this); const serviceNamePrefix = !core_1.Token.isUnresolved(region) ? (region_info_1.RegionInfo.get(region).vpcEndpointServiceNamePrefix ?? region_info_1.Default.VPC_ENDPOINT_SERVICE_NAME_PREFIX) : region_info_1.Default.VPC_ENDPOINT_SERVICE_NAME_PREFIX; this.vpcEndpointServiceName = core_1.Fn.join('.', [serviceNamePrefix, core_1.Aws.REGION, this.vpcEndpointServiceId]); if (this.allowedPrincipals.length > 0) { new ec2_generated_1.CfnVPCEndpointServicePermissions(this, 'Permissions', { serviceId: this.endpointService.ref, allowedPrincipals: this.allowedPrincipals.map(x => x.arn), }); } } } exports.VpcEndpointService = VpcEndpointService; _a = JSII_RTTI_SYMBOL_1; VpcEndpointService[_a] = { fqn: "@aws-cdk/aws-ec2.VpcEndpointService", version: "1.204.0" }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"vpc-endpoint-service.js","sourceRoot":"","sources":["vpc-endpoint-service.ts"],"names":[],"mappings":";;;;;;AACA,wCAA2E;AAC3E,sDAA2D;AAE3D,mDAA0F;AAqC1F;;;;GAIG;AACH,MAAa,kBAAmB,SAAQ,eAAQ;IA0C9C,YAAY,KAAgB,EAAE,EAAU,EAAE,KAA8B;QACtE,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;;;;;;+CA3CR,kBAAkB;;;;QA6C3B,IAAI,KAAK,CAAC,+BAA+B,KAAK,SAAS,IAAI,KAAK,CAAC,+BAA+B,CAAC,MAAM,KAAK,CAAC,EAAE;YAC7G,MAAM,IAAI,KAAK,CAAC,sEAAsE,CAAC,CAAC;SACzF;QAED,IAAI,CAAC,+BAA+B,GAAG,KAAK,CAAC,+BAA+B,CAAC;QAC7E,IAAI,CAAC,kBAAkB,GAAG,KAAK,CAAC,kBAAkB,IAAI,IAAI,CAAC;QAE3D,IAAI,KAAK,CAAC,iBAAiB,IAAI,KAAK,CAAC,qBAAqB,EAAE;YAC1D,MAAM,IAAI,KAAK,CAAC,+EAA+E,CAAC,CAAC;SAClG;QACD,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC,iBAAiB,IAAI,KAAK,CAAC,qBAAqB,IAAI,EAAE,CAAC;QACtF,IAAI,CAAC,qBAAqB,GAAG,IAAI,CAAC,iBAAiB,CAAC;QAEpD,IAAI,CAAC,eAAe,GAAG,IAAI,qCAAqB,CAAC,IAAI,EAAE,EAAE,EAAE;YACzD,uBAAuB,EAAE,IAAI,CAAC,+BAA+B,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,eAAe,CAAC;YAC3F,kBAAkB,EAAE,IAAI,CAAC,kBAAkB;SAC5C,CAAC,CAAC;QAEH,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC;QAErD,MAAM,EAAE,MAAM,EAAE,GAAG,YAAK,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC;QAClC,MAAM,iBAAiB,GAAG,CAAC,YAAK,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC,CAAC;YACrD,CAAC,wBAAU,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,4BAA4B,IAAI,qBAAO,CAAC,gCAAgC,CAAC,CAAC,CAAC;YACnG,qBAAO,CAAC,gCAAgC,CAAC;QAE3C,IAAI,CAAC,sBAAsB,GAAG,SAAE,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,iBAAiB,EAAE,UAAG,CAAC,MAAM,EAAE,IAAI,CAAC,oBAAoB,CAAC,CAAC,CAAC;QACvG,IAAI,IAAI,CAAC,iBAAiB,CAAC,MAAM,GAAG,CAAC,EAAE;YACrC,IAAI,gDAAgC,CAAC,IAAI,EAAE,aAAa,EAAE;gBACxD,SAAS,EAAE,IAAI,CAAC,eAAe,CAAC,GAAG;gBACnC,iBAAiB,EAAE,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC;aAC1D,CAAC,CAAC;SACJ;KACF;;AA7EH,gDA8EC","sourcesContent":["import { ArnPrincipal } from '@aws-cdk/aws-iam';\nimport { Aws, Fn, IResource, Resource, Stack, Token } from '@aws-cdk/core';\nimport { Default, RegionInfo } from '@aws-cdk/region-info';\nimport { Construct } from 'constructs';\nimport { CfnVPCEndpointService, CfnVPCEndpointServicePermissions } from './ec2.generated';\n\n/**\n * A load balancer that can host a VPC Endpoint Service\n *\n */\nexport interface IVpcEndpointServiceLoadBalancer {\n  /**\n   * The ARN of the load balancer that hosts the VPC Endpoint Service\n   *\n   * @attribute\n   */\n  readonly loadBalancerArn: string;\n}\n\n/**\n * A VPC endpoint service.\n *\n */\nexport interface IVpcEndpointService extends IResource {\n  /**\n   * The service name of the VPC Endpoint Service that clients use to connect to,\n   * like com.amazonaws.vpce.<region>.vpce-svc-xxxxxxxxxxxxxxxx\n   *\n   * @attribute\n   */\n  readonly vpcEndpointServiceName: string;\n\n  /**\n   * The id of the VPC Endpoint Service that clients use to connect to,\n   * like vpce-svc-xxxxxxxxxxxxxxxx\n   *\n   * @attribute\n   */\n  readonly vpcEndpointServiceId: string;\n}\n\n/**\n * A VPC endpoint service\n * @resource AWS::EC2::VPCEndpointService\n *\n */\nexport class VpcEndpointService extends Resource implements IVpcEndpointService {\n\n  /**\n   * One or more network load balancers to host the service.\n   * @attribute\n   */\n  public readonly vpcEndpointServiceLoadBalancers: IVpcEndpointServiceLoadBalancer[];\n\n  /**\n   * Whether to require manual acceptance of new connections to the service.\n   *\n   */\n  public readonly acceptanceRequired: boolean;\n\n  /**\n   * One or more Principal ARNs to allow inbound connections to.\n   * @deprecated use `allowedPrincipals`\n   */\n  public readonly whitelistedPrincipals: ArnPrincipal[];\n\n  /**\n   * One or more Principal ARNs to allow inbound connections to.\n   *\n   */\n  public readonly allowedPrincipals: ArnPrincipal[];\n\n  /**\n   * The id of the VPC Endpoint Service, like vpce-svc-xxxxxxxxxxxxxxxx.\n   * @attribute\n   */\n  public readonly vpcEndpointServiceId: string;\n\n  /**\n   * The service name of the VPC Endpoint Service that clients use to connect to,\n   * like com.amazonaws.vpce.<region>.vpce-svc-xxxxxxxxxxxxxxxx\n   *\n   * @attribute\n   */\n  public readonly vpcEndpointServiceName: string;\n\n  private readonly endpointService: CfnVPCEndpointService;\n\n  constructor(scope: Construct, id: string, props: VpcEndpointServiceProps) {\n    super(scope, id);\n\n    if (props.vpcEndpointServiceLoadBalancers === undefined || props.vpcEndpointServiceLoadBalancers.length === 0) {\n      throw new Error('VPC Endpoint Service must have at least one load balancer specified.');\n    }\n\n    this.vpcEndpointServiceLoadBalancers = props.vpcEndpointServiceLoadBalancers;\n    this.acceptanceRequired = props.acceptanceRequired ?? true;\n\n    if (props.allowedPrincipals && props.whitelistedPrincipals) {\n      throw new Error('`whitelistedPrincipals` is deprecated; please use `allowedPrincipals` instead');\n    }\n    this.allowedPrincipals = props.allowedPrincipals ?? props.whitelistedPrincipals ?? [];\n    this.whitelistedPrincipals = this.allowedPrincipals;\n\n    this.endpointService = new CfnVPCEndpointService(this, id, {\n      networkLoadBalancerArns: this.vpcEndpointServiceLoadBalancers.map(lb => lb.loadBalancerArn),\n      acceptanceRequired: this.acceptanceRequired,\n    });\n\n    this.vpcEndpointServiceId = this.endpointService.ref;\n\n    const { region } = Stack.of(this);\n    const serviceNamePrefix = !Token.isUnresolved(region) ?\n      (RegionInfo.get(region).vpcEndpointServiceNamePrefix ?? Default.VPC_ENDPOINT_SERVICE_NAME_PREFIX) :\n      Default.VPC_ENDPOINT_SERVICE_NAME_PREFIX;\n\n    this.vpcEndpointServiceName = Fn.join('.', [serviceNamePrefix, Aws.REGION, this.vpcEndpointServiceId]);\n    if (this.allowedPrincipals.length > 0) {\n      new CfnVPCEndpointServicePermissions(this, 'Permissions', {\n        serviceId: this.endpointService.ref,\n        allowedPrincipals: this.allowedPrincipals.map(x => x.arn),\n      });\n    }\n  }\n}\n\n/**\n * Construction properties for a VpcEndpointService.\n *\n */\nexport interface VpcEndpointServiceProps {\n\n  /**\n   * Name of the Vpc Endpoint Service\n   * @deprecated This property is not used\n   * @default - CDK generated name\n   */\n  readonly vpcEndpointServiceName?: string;\n\n  /**\n   * One or more load balancers to host the VPC Endpoint Service.\n   *\n   */\n  readonly vpcEndpointServiceLoadBalancers: IVpcEndpointServiceLoadBalancer[];\n\n  /**\n   * Whether requests from service consumers to connect to the service through\n   * an endpoint must be accepted.\n   * @default true\n   *\n   */\n  readonly acceptanceRequired?: boolean;\n\n  /**\n   * IAM users, IAM roles, or AWS accounts to allow inbound connections from.\n   * These principals can connect to your service using VPC endpoints. Takes a\n   * list of one or more ArnPrincipal.\n   * @default - no principals\n   * @deprecated use `allowedPrincipals`\n   */\n  readonly whitelistedPrincipals?: ArnPrincipal[];\n\n  /**\n   * IAM users, IAM roles, or AWS accounts to allow inbound connections from.\n   * These principals can connect to your service using VPC endpoints. Takes a\n   * list of one or more ArnPrincipal.\n   * @default - no principals\n   *\n   */\n  readonly allowedPrincipals?: ArnPrincipal[];\n}\n"]}