UNPKG

@aws-cdk/aws-ec2

Version:

The CDK Construct Library for AWS::EC2

205 lines 23.3 kB
"use strict"; var _a, _b, _c; Object.defineProperty(exports, "__esModule", { value: true }); exports.SubnetNetworkAclAssociation = exports.NetworkAclEntry = exports.TrafficDirection = exports.Action = exports.NetworkAcl = 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 ec2_generated_1 = require("./ec2.generated"); /** * A NetworkAclBase that is not created in this template * * */ class NetworkAclBase extends core_1.Resource { /** * Add a new entry to the ACL */ addEntry(id, options) { return new NetworkAclEntry(this, id, { networkAcl: this, ...options, }); } } /** * Define a new custom network ACL * * By default, will deny all inbound and outbound traffic unless entries are * added explicitly allowing it. * * */ class NetworkAcl extends NetworkAclBase { constructor(scope, id, props) { super(scope, id, { physicalName: props.networkAclName, }); try { jsiiDeprecationWarnings._aws_cdk_aws_ec2_NetworkAclProps(props); } catch (error) { if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { Error.captureStackTrace(error, NetworkAcl); } throw error; } this.vpc = props.vpc; this.networkAcl = new ec2_generated_1.CfnNetworkAcl(this, 'Resource', { vpcId: props.vpc.vpcId, }); this.networkAclId = this.networkAcl.ref; this.networkAclVpcId = this.networkAcl.vpcId; if (props.subnetSelection !== undefined) { this.associateWithSubnet('DefaultAssociation', props.subnetSelection); } } /** * Import an existing NetworkAcl into this app. */ static fromNetworkAclId(scope, id, networkAclId) { class Import extends NetworkAclBase { constructor() { super(...arguments); this.networkAclId = networkAclId; } } return new Import(scope, id); } /** * Associate the ACL with a given set of subnets */ associateWithSubnet(id, selection) { try { jsiiDeprecationWarnings._aws_cdk_aws_ec2_SubnetSelection(selection); } catch (error) { if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { Error.captureStackTrace(error, this.associateWithSubnet); } throw error; } const subnets = this.vpc.selectSubnets(selection); for (const subnet of subnets.subnets) { subnet.associateNetworkAcl(id, this); } } } exports.NetworkAcl = NetworkAcl; _a = JSII_RTTI_SYMBOL_1; NetworkAcl[_a] = { fqn: "@aws-cdk/aws-ec2.NetworkAcl", version: "1.204.0" }; /** * What action to apply to traffic matching the ACL * * */ var Action; (function (Action) { /** * Allow the traffic */ Action["ALLOW"] = "allow"; /** * Deny the traffic */ Action["DENY"] = "deny"; })(Action = exports.Action || (exports.Action = {})); /** * Base class for NetworkAclEntries * * */ class NetworkAclEntryBase extends core_1.Resource { } /** * Direction of traffic the AclEntry applies to * * */ var TrafficDirection; (function (TrafficDirection) { /** * Traffic leaving the subnet */ TrafficDirection[TrafficDirection["EGRESS"] = 0] = "EGRESS"; /** * Traffic entering the subnet */ TrafficDirection[TrafficDirection["INGRESS"] = 1] = "INGRESS"; })(TrafficDirection = exports.TrafficDirection || (exports.TrafficDirection = {})); /** * Define an entry in a Network ACL table * * */ class NetworkAclEntry extends NetworkAclEntryBase { constructor(scope, id, props) { super(scope, id, { physicalName: props.networkAclEntryName, }); try { jsiiDeprecationWarnings._aws_cdk_aws_ec2_NetworkAclEntryProps(props); } catch (error) { if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { Error.captureStackTrace(error, NetworkAclEntry); } throw error; } this.networkAcl = props.networkAcl; new ec2_generated_1.CfnNetworkAclEntry(this, 'Resource', { networkAclId: this.networkAcl.networkAclId, ruleNumber: props.ruleNumber, ruleAction: props.ruleAction ?? Action.ALLOW, egress: props.direction !== undefined ? props.direction === TrafficDirection.EGRESS : undefined, ...props.traffic.toTrafficConfig(), ...props.cidr.toCidrConfig(), }); } } exports.NetworkAclEntry = NetworkAclEntry; _b = JSII_RTTI_SYMBOL_1; NetworkAclEntry[_b] = { fqn: "@aws-cdk/aws-ec2.NetworkAclEntry", version: "1.204.0" }; /** * Associate a network ACL with a subnet * * */ class SubnetNetworkAclAssociationBase extends core_1.Resource { } class SubnetNetworkAclAssociation extends SubnetNetworkAclAssociationBase { constructor(scope, id, props) { super(scope, id, { physicalName: props.subnetNetworkAclAssociationName, }); try { jsiiDeprecationWarnings._aws_cdk_aws_ec2_SubnetNetworkAclAssociationProps(props); } catch (error) { if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { Error.captureStackTrace(error, SubnetNetworkAclAssociation); } throw error; } this.association = new ec2_generated_1.CfnSubnetNetworkAclAssociation(this, 'Resource', { networkAclId: props.networkAcl.networkAclId, subnetId: props.subnet.subnetId, }); this.networkAcl = props.networkAcl; this.subnet = props.subnet; this.subnetNetworkAclAssociationAssociationId = this.association.attrAssociationId; } static fromSubnetNetworkAclAssociationAssociationId(scope, id, subnetNetworkAclAssociationAssociationId) { class Import extends SubnetNetworkAclAssociationBase { constructor() { super(...arguments); this.subnetNetworkAclAssociationAssociationId = subnetNetworkAclAssociationAssociationId; } } return new Import(scope, id); } } exports.SubnetNetworkAclAssociation = SubnetNetworkAclAssociation; _c = JSII_RTTI_SYMBOL_1; SubnetNetworkAclAssociation[_c] = { fqn: "@aws-cdk/aws-ec2.SubnetNetworkAclAssociation", version: "1.204.0" }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"network-acl.js","sourceRoot":"","sources":["network-acl.ts"],"names":[],"mappings":"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","sourcesContent":["import { IResource, Resource } from '@aws-cdk/core';\nimport { Construct } from 'constructs';\nimport { CfnNetworkAcl, CfnNetworkAclEntry, CfnSubnetNetworkAclAssociation } from './ec2.generated';\nimport { AclCidr, AclTraffic } from './network-acl-types';\nimport { ISubnet, IVpc, SubnetSelection } from './vpc';\n\n/**\n * A NetworkAcl\n *\n *\n */\nexport interface INetworkAcl extends IResource {\n  /**\n   * ID for the current Network ACL\n   * @attribute\n   */\n  readonly networkAclId: string;\n\n  /**\n   * Add a new entry to the ACL\n   */\n  addEntry(id: string, options: CommonNetworkAclEntryOptions): NetworkAclEntry;\n}\n\n/**\n * A NetworkAclBase that is not created in this template\n *\n *\n */\nabstract class NetworkAclBase extends Resource implements INetworkAcl {\n  public abstract readonly networkAclId: string;\n\n  /**\n   * Add a new entry to the ACL\n   */\n  public addEntry(id: string, options: CommonNetworkAclEntryOptions): NetworkAclEntry {\n    return new NetworkAclEntry(this, id, {\n      networkAcl: this,\n      ...options,\n    });\n  }\n\n}\n\n/**\n * Properties to create NetworkAcl\n *\n *\n */\nexport interface NetworkAclProps {\n  /**\n   * The name of the NetworkAcl.\n   *\n   * It is not recommended to use an explicit name.\n   *\n   * @default If you don't specify a networkAclName, AWS CloudFormation generates a\n   * unique physical ID and uses that ID for the group name.\n   */\n  readonly networkAclName?: string;\n\n  /**\n   * The VPC in which to create the NetworkACL.\n   */\n  readonly vpc: IVpc;\n\n  /**\n   * Subnets in the given VPC to associate the ACL with\n   *\n   * More subnets can always be added later by calling\n   * `associateWithSubnets()`.\n   *\n   * @default - No subnets associated\n   */\n  readonly subnetSelection?: SubnetSelection;\n}\n\n/**\n * Define a new custom network ACL\n *\n * By default, will deny all inbound and outbound traffic unless entries are\n * added explicitly allowing it.\n *\n *\n */\nexport class NetworkAcl extends NetworkAclBase {\n  /**\n   * Import an existing NetworkAcl into this app.\n   */\n  public static fromNetworkAclId(scope: Construct, id: string, networkAclId: string): INetworkAcl {\n    class Import extends NetworkAclBase {\n      public readonly networkAclId = networkAclId;\n    }\n\n    return new Import(scope, id);\n  }\n\n  /**\n   * The ID of the NetworkACL\n   *\n   * @attribute\n   */\n  public readonly networkAclId: string;\n\n  /**\n   * The VPC ID for this NetworkACL\n   *\n   * @attribute\n   */\n  public readonly networkAclVpcId: string;\n\n  private readonly networkAcl: CfnNetworkAcl;\n  private readonly vpc: IVpc;\n\n  constructor(scope: Construct, id: string, props: NetworkAclProps) {\n    super(scope, id, {\n      physicalName: props.networkAclName,\n    });\n\n    this.vpc = props.vpc;\n\n    this.networkAcl = new CfnNetworkAcl(this, 'Resource', {\n      vpcId: props.vpc.vpcId,\n    });\n\n    this.networkAclId = this.networkAcl.ref;\n    this.networkAclVpcId = this.networkAcl.vpcId;\n\n    if (props.subnetSelection !== undefined) {\n      this.associateWithSubnet('DefaultAssociation', props.subnetSelection);\n    }\n  }\n\n  /**\n   * Associate the ACL with a given set of subnets\n   */\n  public associateWithSubnet(id: string, selection: SubnetSelection) {\n    const subnets = this.vpc.selectSubnets(selection);\n    for (const subnet of subnets.subnets) {\n      subnet.associateNetworkAcl(id, this);\n    }\n  }\n}\n\n/**\n * What action to apply to traffic matching the ACL\n *\n *\n */\nexport enum Action {\n  /**\n   * Allow the traffic\n   */\n  ALLOW = 'allow',\n\n  /**\n   * Deny the traffic\n   */\n  DENY = 'deny',\n}\n\n/**\n * A NetworkAclEntry\n *\n *\n */\nexport interface INetworkAclEntry extends IResource {\n  /**\n   * The network ACL.\n   */\n  readonly networkAcl: INetworkAcl\n\n}\n\n/**\n * Base class for NetworkAclEntries\n *\n *\n */\nabstract class NetworkAclEntryBase extends Resource implements INetworkAclEntry {\n  public abstract readonly networkAcl: INetworkAcl;\n}\n\n/**\n * Direction of traffic the AclEntry applies to\n *\n *\n */\nexport enum TrafficDirection {\n  /**\n   * Traffic leaving the subnet\n   */\n  EGRESS,\n\n  /**\n   * Traffic entering the subnet\n   */\n  INGRESS,\n}\n\n/**\n * Basic NetworkACL entry props\n *\n *\n */\nexport interface CommonNetworkAclEntryOptions {\n  /**\n   * The name of the NetworkAclEntry.\n   *\n   * It is not recommended to use an explicit group name.\n   *\n   * @default If you don't specify a NetworkAclName, AWS CloudFormation generates a\n   * unique physical ID and uses that ID for the group name.\n   */\n  readonly networkAclEntryName?: string;\n\n  /**\n   * The CIDR range to allow or deny.\n   */\n  readonly cidr: AclCidr;\n\n  /**\n   * What kind of traffic this ACL rule applies to\n   */\n  readonly traffic: AclTraffic;\n\n  /**\n   * Traffic direction, with respect to the subnet, this rule applies to\n   *\n   * @default TrafficDirection.INGRESS\n   */\n  readonly direction?: TrafficDirection;\n\n  /**\n   * Whether to allow or deny traffic that matches the rule; valid values are \"allow\" or \"deny\".\n   *\n   * Any traffic that is not explicitly allowed is automatically denied in a custom\n   * ACL, all traffic is automatically allowed in a default ACL.\n   *\n   * @default ALLOW\n   */\n  readonly ruleAction?: Action;\n\n  /**\n   * Rule number to assign to the entry, such as 100. ACL entries are processed in ascending order by rule number.\n   * Entries can't use the same rule number unless one is an egress rule and the other is an ingress rule.\n   */\n  readonly ruleNumber: number;\n}\n\n/**\n * Properties to create NetworkAclEntry\n *\n *\n */\nexport interface NetworkAclEntryProps extends CommonNetworkAclEntryOptions {\n  /**\n   * The network ACL this entry applies to.\n   */\n  readonly networkAcl: INetworkAcl;\n}\n\n/**\n * Define an entry in a Network ACL table\n *\n *\n */\nexport class NetworkAclEntry extends NetworkAclEntryBase {\n  public readonly networkAcl: INetworkAcl;\n\n  constructor(scope: Construct, id: string, props: NetworkAclEntryProps) {\n    super(scope, id, {\n      physicalName: props.networkAclEntryName,\n    });\n\n    this.networkAcl = props.networkAcl;\n\n    new CfnNetworkAclEntry(this, 'Resource', {\n      networkAclId: this.networkAcl.networkAclId,\n      ruleNumber: props.ruleNumber,\n      ruleAction: props.ruleAction ?? Action.ALLOW,\n      egress: props.direction !== undefined ? props.direction === TrafficDirection.EGRESS : undefined,\n      ...props.traffic.toTrafficConfig(),\n      ...props.cidr.toCidrConfig(),\n    });\n  }\n}\n\n/**\n * A SubnetNetworkAclAssociation\n *\n *\n */\nexport interface ISubnetNetworkAclAssociation extends IResource {\n  /**\n   * ID for the current SubnetNetworkAclAssociation\n   * @attribute\n   */\n  readonly subnetNetworkAclAssociationAssociationId: string;\n}\n\n/**\n * Properties to create a SubnetNetworkAclAssociation\n *\n *\n */\nexport interface SubnetNetworkAclAssociationProps {\n  /**\n   * The name of the SubnetNetworkAclAssociation.\n   *\n   * It is not recommended to use an explicit name.\n   *\n   * @default If you don't specify a SubnetNetworkAclAssociationName, AWS CloudFormation generates a\n   * unique physical ID and uses that ID for the group name.\n   */\n  readonly subnetNetworkAclAssociationName?: string;\n\n  /**\n   * The Network ACL this association is defined for\n   *\n   * @attribute\n   */\n  readonly networkAcl: INetworkAcl;\n\n  /**\n   * ID of the Subnet\n   * @attribute\n   */\n  readonly subnet: ISubnet;\n}\n\n/**\n * Associate a network ACL with a subnet\n *\n *\n */\nabstract class SubnetNetworkAclAssociationBase extends Resource implements ISubnetNetworkAclAssociation {\n  public abstract readonly subnetNetworkAclAssociationAssociationId: string;\n}\nexport class SubnetNetworkAclAssociation extends SubnetNetworkAclAssociationBase {\n  public static fromSubnetNetworkAclAssociationAssociationId(\n    scope: Construct, id: string,\n    subnetNetworkAclAssociationAssociationId: string): ISubnetNetworkAclAssociation {\n    class Import extends SubnetNetworkAclAssociationBase {\n      public readonly subnetNetworkAclAssociationAssociationId = subnetNetworkAclAssociationAssociationId;\n    }\n\n    return new Import(scope, id);\n  }\n  /**\n   * ID for the current SubnetNetworkAclAssociation\n   * @attribute\n   */\n  public readonly subnetNetworkAclAssociationAssociationId: string;\n\n  /**\n   * ID for the current Network ACL\n   * @attribute\n   */\n  public readonly networkAcl: INetworkAcl;\n\n  /**\n   * ID of the Subnet\n   * @attribute\n   */\n  public readonly subnet: ISubnet;\n\n  private association: CfnSubnetNetworkAclAssociation;\n\n  constructor(scope: Construct, id: string, props: SubnetNetworkAclAssociationProps) {\n    super(scope, id, {\n      physicalName: props.subnetNetworkAclAssociationName,\n    });\n\n    this.association = new CfnSubnetNetworkAclAssociation(this, 'Resource', {\n      networkAclId: props.networkAcl.networkAclId,\n      subnetId: props.subnet.subnetId,\n    });\n\n    this.networkAcl = props.networkAcl;\n    this.subnet = props.subnet;\n    this.subnetNetworkAclAssociationAssociationId = this.association.attrAssociationId;\n  }\n}\n"]}