advanced-cdk-constructs
Version:
[](https://codecov.io/gh/spensireli/advanced-cdk-constructs)
190 lines • 24.4 kB
JavaScript
"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}"]}