UNPKG

advanced-cdk-constructs

Version:

[![codecov](https://codecov.io/gh/spensireli/advanced-cdk-constructs/graph/badge.svg?token=50IITI207T)](https://codecov.io/gh/spensireli/advanced-cdk-constructs)

190 lines 24.4 kB
"use strict"; var _a; Object.defineProperty(exports, "__esModule", { value: true }); exports.DeclarativePolicy = exports.SnapshotBlockPublicAccessState = exports.InstanceMetadataTags = exports.HttpEndpoint = exports.HttpTokens = exports.ImageProvider = exports.AllowedImagesState = exports.VpcBlockPublicAccessMode = void 0; const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti"); const aws_cdk_lib_1 = require("aws-cdk-lib"); const constructs_1 = require("constructs"); /** * Modes for blocking public access to VPCs. */ var VpcBlockPublicAccessMode; (function (VpcBlockPublicAccessMode) { /** No blocking of public access. */ VpcBlockPublicAccessMode["OFF"] = "off"; /** Block only ingress (incoming) public access. */ VpcBlockPublicAccessMode["BLOCK_INGRESS"] = "block_ingress"; /** Block both ingress and egress (bidirectional) public access. */ VpcBlockPublicAccessMode["BLOCK_BIDIRECTIONAL"] = "block_bidirectional"; })(VpcBlockPublicAccessMode || (exports.VpcBlockPublicAccessMode = VpcBlockPublicAccessMode = {})); /** * State for allowed images policy. */ var AllowedImagesState; (function (AllowedImagesState) { /** Only allow images from specified providers. */ AllowedImagesState["ENABLED"] = "enabled"; /** Audit mode for allowed images. */ AllowedImagesState["AUDIT_MODE"] = "audit_mode"; })(AllowedImagesState || (exports.AllowedImagesState = AllowedImagesState = {})); /** * Predefined image providers for allowed images policy. */ var ImageProvider; (function (ImageProvider) { /** Amazon-provided images. */ ImageProvider["AMAZON"] = "amazon"; /** AWS Marketplace images. */ ImageProvider["AWS_MARKETPLACE"] = "aws_marketplace"; /** AWS Backup Vault images. */ ImageProvider["AWS_BACKUP_VAULT"] = "aws_backup_vault"; })(ImageProvider || (exports.ImageProvider = ImageProvider = {})); /** * Options for IMDSv2 HttpTokens requirement. */ var HttpTokens; (function (HttpTokens) { /** No preference for HttpTokens. */ HttpTokens["NO_PREFERENCE"] = "no_preference"; /** Require HttpTokens. */ HttpTokens["REQUIRED"] = "required"; /** HttpTokens are optional. */ HttpTokens["OPTIONAL"] = "optional"; })(HttpTokens || (exports.HttpTokens = HttpTokens = {})); /** * Options for IMDSv2 HttpEndpoint. */ var HttpEndpoint; (function (HttpEndpoint) { /** No preference for HttpEndpoint. */ HttpEndpoint["NO_PREFERENCE"] = "no_preference"; /** Enable HttpEndpoint. */ HttpEndpoint["ENABLED"] = "enabled"; /** Disable HttpEndpoint. */ HttpEndpoint["DISABLED"] = "disabled"; })(HttpEndpoint || (exports.HttpEndpoint = HttpEndpoint = {})); /** * Options for IMDSv2 Instance Metadata Tags. */ var InstanceMetadataTags; (function (InstanceMetadataTags) { /** No preference for instance metadata tags. */ InstanceMetadataTags["NO_PREFERENCE"] = "no_preference"; /** Enable instance metadata tags. */ InstanceMetadataTags["ENABLED"] = "enabled"; /** Disable instance metadata tags. */ InstanceMetadataTags["DISABLED"] = "disabled"; })(InstanceMetadataTags || (exports.InstanceMetadataTags = InstanceMetadataTags = {})); /** * State for blocking public access to EBS snapshots. */ var SnapshotBlockPublicAccessState; (function (SnapshotBlockPublicAccessState) { /** Block new sharing of snapshots. */ SnapshotBlockPublicAccessState["BLOCK_NEW_SHARING"] = "block_new_sharing"; /** Block all sharing of snapshots. */ SnapshotBlockPublicAccessState["BLOCK_ALL_SHARING"] = "block_all_sharing"; })(SnapshotBlockPublicAccessState || (exports.SnapshotBlockPublicAccessState = SnapshotBlockPublicAccessState = {})); /** * A CDK construct that creates an AWS Organizations EC2 Declarative Policy. * * This construct allows you to declaratively define and apply EC2-related policies * such as blocking public access to VPCs, restricting AMI providers, enforcing * instance metadata service settings, and more. * * Example: * ```ts * new DeclarativePolicy(this, 'MyPolicy', { * targetIds: ['ou-xxxx-xxxxxxxx'], * vpcBlockPublicAccess: true, * vpcBlockPublicAccessMode: VpcBlockPublicAccessMode.BLOCK_BIDIRECTIONAL, * }); * ``` */ class DeclarativePolicy extends constructs_1.Construct { /** * Create a new DeclarativePolicy. * @param scope The parent construct. * @param id The construct ID. * @param props The policy properties. */ constructor(scope, id, props) { super(scope, id); // Set defaults for boolean properties const vpcBlockPublicAccess = props.vpcBlockPublicAccess ?? true; const disableSerialConsoleAccess = props.disableSerialConsoleAccess ?? true; const imageBlockPublicAccess = props.imageBlockPublicAccess ?? true; const restrictImageProviders = props.restrictImageProviders ?? true; const instanceMetadataDefaults = props.instanceMetadataDefaults ?? true; const blockPublicSnapshots = props.blockPublicSnapshots ?? true; const declarativePolicy = { ec2_attributes: { vpc_block_public_access: vpcBlockPublicAccess ? { internet_gateway_block: { mode: { '@@assign': props.vpcBlockPublicAccessMode ?? VpcBlockPublicAccessMode.BLOCK_INGRESS, }, exclusions_allowed: { '@@assign': 'enabled', }, }, } : undefined, serial_console_access: disableSerialConsoleAccess ? { status: { '@@assign': 'disabled', }, } : undefined, image_block_public_access: imageBlockPublicAccess ? { state: { '@@assign': 'block_new_sharing', }, } : undefined, allowed_images_settings: restrictImageProviders ? { state: { '@@assign': props.allowedImagesState ?? AllowedImagesState.ENABLED, }, ...(props.allowedImageProviders && props.allowedImageProviders.length > 0 ? { image_criteria: { criteria_1: { allowed_image_providers: { '@@append': props.allowedImageProviders, }, }, }, } : {}), } : undefined, instance_metadata_defaults: instanceMetadataDefaults ? { http_tokens: { '@@assign': props.httpTokens ?? HttpTokens.REQUIRED, }, http_put_response_hop_limit: { '@@assign': props.httpPutResponseHopLimit?.toString() ?? '4', }, http_endpoint: { '@@assign': props.httpEndpoint ?? HttpEndpoint.ENABLED, }, instance_metadata_tags: { '@@assign': props.instanceMetadataTags ?? InstanceMetadataTags.ENABLED, }, } : undefined, snapshot_block_public_access: blockPublicSnapshots ? { state: { '@@assign': props.snapshotBlockPublicAccessState ?? SnapshotBlockPublicAccessState.BLOCK_NEW_SHARING, }, } : undefined, }, }; const applyDeclarativePolicy = new aws_cdk_lib_1.aws_organizations.CfnPolicy(this, `DeclarativePolicy-${this.node.id}`, { content: declarativePolicy, name: props.name ?? `DeclarativePolicy-${this.node.id}`, type: 'DECLARATIVE_POLICY_EC2', description: props.description ?? 'Declarative Policy from Advanced CDK Constructs', targetIds: props.targetIds, }); this.declarativePolicyArn = applyDeclarativePolicy.attrArn; } } exports.DeclarativePolicy = DeclarativePolicy; _a = JSII_RTTI_SYMBOL_1; DeclarativePolicy[_a] = { fqn: "advanced-cdk-constructs.DeclarativePolicy", version: "0.0.14" }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"declarative-policies.js","sourceRoot":"","sources":["../../src/declarative-policies/declarative-policies.ts"],"names":[],"mappings":"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","sourcesContent":["import { aws_organizations as organizations } from 'aws-cdk-lib';\nimport { Construct } from 'constructs';\n\n/**\n * Modes for blocking public access to VPCs.\n */\nexport enum VpcBlockPublicAccessMode {\n  /** No blocking of public access. */\n  OFF = 'off',\n  /** Block only ingress (incoming) public access. */\n  BLOCK_INGRESS = 'block_ingress',\n  /** Block both ingress and egress (bidirectional) public access. */\n  BLOCK_BIDIRECTIONAL = 'block_bidirectional',\n}\n\n/**\n * State for allowed images policy.\n */\nexport enum AllowedImagesState {\n  /** Only allow images from specified providers. */\n  ENABLED = 'enabled',\n  /** Audit mode for allowed images. */\n  AUDIT_MODE = 'audit_mode',\n}\n\n/**\n * Predefined image providers for allowed images policy.\n */\nexport enum ImageProvider {\n  /** Amazon-provided images. */\n  AMAZON = 'amazon',\n  /** AWS Marketplace images. */\n  AWS_MARKETPLACE = 'aws_marketplace',\n  /** AWS Backup Vault images. */\n  AWS_BACKUP_VAULT = 'aws_backup_vault',\n}\n\n/**\n * Options for IMDSv2 HttpTokens requirement.\n */\nexport enum HttpTokens {\n  /** No preference for HttpTokens. */\n  NO_PREFERENCE = 'no_preference',\n  /** Require HttpTokens. */\n  REQUIRED = 'required',\n  /** HttpTokens are optional. */\n  OPTIONAL = 'optional',\n}\n\n/**\n * Options for IMDSv2 HttpEndpoint.\n */\nexport enum HttpEndpoint {\n  /** No preference for HttpEndpoint. */\n  NO_PREFERENCE = 'no_preference',\n  /** Enable HttpEndpoint. */\n  ENABLED = 'enabled',\n  /** Disable HttpEndpoint. */\n  DISABLED = 'disabled',\n}\n\n/**\n * Options for IMDSv2 Instance Metadata Tags.\n */\nexport enum InstanceMetadataTags {\n  /** No preference for instance metadata tags. */\n  NO_PREFERENCE = 'no_preference',\n  /** Enable instance metadata tags. */\n  ENABLED = 'enabled',\n  /** Disable instance metadata tags. */\n  DISABLED = 'disabled',\n}\n\n/**\n * State for blocking public access to EBS snapshots.\n */\nexport enum SnapshotBlockPublicAccessState {\n  /** Block new sharing of snapshots. */\n  BLOCK_NEW_SHARING = 'block_new_sharing',\n  /** Block all sharing of snapshots. */\n  BLOCK_ALL_SHARING = 'block_all_sharing',\n}\n\n/**\n * An image provider (predefined or AWS account ID).\n */\nexport type ImageProviderOrAccountId = ImageProvider | string;\n\n/**\n * Properties for configuring a DeclarativePolicy.\n */\nexport interface DeclarativePolicyProps {\n  /** The target AWS account or organizational unit IDs to which the policy will be attached. */\n  readonly targetIds: string[];\n  /** The name of the policy. */\n  readonly name?: string;\n  /** The description of the policy. */\n  readonly description?: string;\n  /** Whether to block public access to VPCs. Defaults to true. */\n  readonly vpcBlockPublicAccess?: boolean;\n  /** Whether to disable serial console access. Defaults to true. */\n  readonly disableSerialConsoleAccess?: boolean;\n  /** Whether to block public access to AMIs. Defaults to true. */\n  readonly imageBlockPublicAccess?: boolean;\n  /** Whether to restrict allowed image providers. Defaults to true. */\n  readonly restrictImageProviders?: boolean;\n  /** Whether to enforce instance metadata service defaults. Defaults to true. */\n  readonly instanceMetadataDefaults?: boolean;\n  /** Whether to block public sharing of EBS snapshots. Defaults to true. */\n  readonly blockPublicSnapshots?: boolean;\n  /** The mode for blocking public access to VPCs. */\n  readonly vpcBlockPublicAccessMode?: VpcBlockPublicAccessMode;\n  /** The state for allowed images policy. */\n  readonly allowedImagesState?: AllowedImagesState;\n  /** The list of allowed image providers or AWS account IDs. */\n  readonly allowedImageProviders?: ImageProviderOrAccountId[];\n  /** The HttpTokens setting for instance metadata service. */\n  readonly httpTokens?: HttpTokens;\n  /** The hop limit for HTTP PUT responses from the instance metadata service. */\n  readonly httpPutResponseHopLimit?: number;\n  /** The HttpEndpoint setting for instance metadata service. */\n  readonly httpEndpoint?: HttpEndpoint;\n  /** The instance metadata tags setting. */\n  readonly instanceMetadataTags?: InstanceMetadataTags;\n  /** The state for blocking public access to EBS snapshots. */\n  readonly snapshotBlockPublicAccessState?: SnapshotBlockPublicAccessState;\n}\n\n/**\n * A CDK construct that creates an AWS Organizations EC2 Declarative Policy.\n *\n * This construct allows you to declaratively define and apply EC2-related policies\n * such as blocking public access to VPCs, restricting AMI providers, enforcing\n * instance metadata service settings, and more.\n *\n * Example:\n * ```ts\n * new DeclarativePolicy(this, 'MyPolicy', {\n *   targetIds: ['ou-xxxx-xxxxxxxx'],\n *   vpcBlockPublicAccess: true,\n *   vpcBlockPublicAccessMode: VpcBlockPublicAccessMode.BLOCK_BIDIRECTIONAL,\n * });\n * ```\n */\nexport class DeclarativePolicy extends Construct {\n  /**\n   * The ARN of the created declarative policy.\n   */\n  public readonly declarativePolicyArn!: string;\n\n  /**\n   * Create a new DeclarativePolicy.\n   * @param scope The parent construct.\n   * @param id The construct ID.\n   * @param props The policy properties.\n   */\n  constructor(scope: Construct, id: string, props: DeclarativePolicyProps) {\n    super(scope, id);\n\n    // Set defaults for boolean properties\n    const vpcBlockPublicAccess = props.vpcBlockPublicAccess ?? true;\n    const disableSerialConsoleAccess = props.disableSerialConsoleAccess ?? true;\n    const imageBlockPublicAccess = props.imageBlockPublicAccess ?? true;\n    const restrictImageProviders = props.restrictImageProviders ?? true;\n    const instanceMetadataDefaults = props.instanceMetadataDefaults ?? true;\n    const blockPublicSnapshots = props.blockPublicSnapshots ?? true;\n\n    const declarativePolicy = {\n      ec2_attributes: {\n        vpc_block_public_access: vpcBlockPublicAccess ? {\n          internet_gateway_block: {\n            mode: {\n              '@@assign': props.vpcBlockPublicAccessMode ?? VpcBlockPublicAccessMode.BLOCK_INGRESS,\n            },\n            exclusions_allowed: {\n              '@@assign': 'enabled',\n            },\n          },\n        } : undefined,\n        serial_console_access: disableSerialConsoleAccess ? {\n          status: {\n            '@@assign': 'disabled',\n          },\n        } : undefined,\n        image_block_public_access: imageBlockPublicAccess ? {\n          state: {\n            '@@assign': 'block_new_sharing',\n          },\n        } : undefined,\n        allowed_images_settings: restrictImageProviders ? {\n          state: {\n            '@@assign': props.allowedImagesState ?? AllowedImagesState.ENABLED,\n          },\n          ...(props.allowedImageProviders && props.allowedImageProviders.length > 0 ? {\n            image_criteria: {\n              criteria_1: {\n                allowed_image_providers: {\n                  '@@append': props.allowedImageProviders,\n                },\n              },\n            },\n          } : {}),\n        } : undefined,\n        instance_metadata_defaults: instanceMetadataDefaults ? {\n          http_tokens: {\n            '@@assign': props.httpTokens ?? HttpTokens.REQUIRED,\n          },\n          http_put_response_hop_limit: {\n            '@@assign': props.httpPutResponseHopLimit?.toString() ?? '4',\n          },\n          http_endpoint: {\n            '@@assign': props.httpEndpoint ?? HttpEndpoint.ENABLED,\n          },\n          instance_metadata_tags: {\n            '@@assign': props.instanceMetadataTags ?? InstanceMetadataTags.ENABLED,\n          },\n        } : undefined,\n        snapshot_block_public_access: blockPublicSnapshots ? {\n          state: {\n            '@@assign': props.snapshotBlockPublicAccessState ?? SnapshotBlockPublicAccessState.BLOCK_NEW_SHARING,\n          },\n        } : undefined,\n      },\n    };\n\n    const applyDeclarativePolicy = new organizations.CfnPolicy(this, `DeclarativePolicy-${this.node.id}`, {\n      content: declarativePolicy,\n      name: props.name ?? `DeclarativePolicy-${this.node.id}`,\n      type: 'DECLARATIVE_POLICY_EC2',\n      description: props.description ?? 'Declarative Policy from Advanced CDK Constructs',\n      targetIds: props.targetIds,\n    });\n    this.declarativePolicyArn = applyDeclarativePolicy.attrArn;\n\n  }\n}"]}