@pepperize/cdk-organizations
Version:
Manage AWS organizations, organizational units (OU), accounts and service control policies (SCP).
98 lines • 15.7 kB
JavaScript
"use strict";
var _a;
Object.defineProperty(exports, "__esModule", { value: true });
exports.Policy = exports.PolicyType = void 0;
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
const aws_cdk_lib_1 = require("aws-cdk-lib");
const custom_resources_1 = require("aws-cdk-lib/custom-resources");
const constructs_1 = require("constructs");
const tag_resource_1 = require("./tag-resource");
const validators_1 = require("./validators");
/**
* Organizations offers policy types in the following two broad categories:
* <ol>
* <li>Authorization policies help you to centrally manage the security of the AWS accounts in your organization.</li>
* <li>Management policies enable you to centrally configure and manage AWS services and their features.</li>
* </ol>
*
* @see https://docs.aws.amazon.com/organizations/latest/userguide/orgs_manage_policies.html#orgs-policy-types
*/
var PolicyType;
(function (PolicyType) {
/**
* Service control policies (SCPs) offer central control over the maximum available permissions for all of the accounts in your organization.
*/
PolicyType["SERVICE_CONTROL_POLICY"] = "SERVICE_CONTROL_POLICY";
/**
* Tag policies help you standardize the tags attached to the AWS resources in your organization's accounts.
*/
PolicyType["TAG_POLICY"] = "TAG_POLICY";
/**
* Backup policies help you centrally manage and apply backup plans to the AWS resources across your organization's accounts.
*/
PolicyType["BACKUP_POLICY"] = "BACKUP_POLICY";
/**
* Artificial Intelligence (AI) services opt-out policies enable you to control data collection for AWS AI services for all of your organization's accounts.
*/
PolicyType["AISERVICES_OPT_OUT_POLICY"] = "AISERVICES_OPT_OUT_POLICY";
})(PolicyType || (exports.PolicyType = PolicyType = {}));
class Policy extends constructs_1.Construct {
constructor(scope, id, props) {
super(scope, id);
this.tags = new aws_cdk_lib_1.TagManager(aws_cdk_lib_1.TagType.KEY_VALUE, "Custom::Organizations_Policy");
const { content, description, policyName, policyType } = props;
const organizationsRegion = process.env.CDK_AWS_PARTITION === "aws-cn" ? "cn-northwest-1" : "us-east-1";
if (!validators_1.Validators.of().policyContent(content)) {
aws_cdk_lib_1.Annotations.of(this).addError("The text content of the policy must be valid and between 1 and 1,000,000 characters long.");
}
const policy = new custom_resources_1.AwsCustomResource(this, "PolicyCustomResource", {
resourceType: "Custom::Organizations_Policy",
onCreate: {
service: "Organizations",
action: "createPolicy", // https://docs.aws.amazon.com/AWSJavaScriptSDK/latest/AWS/Organizations.html#createPolicy-property
region: organizationsRegion,
parameters: {
Content: content,
Description: description,
Name: policyName,
Type: policyType,
},
outputPaths: ["Policy.PolicySummary.Id"],
physicalResourceId: custom_resources_1.PhysicalResourceId.fromResponse("Policy.PolicySummary.Id"),
},
onUpdate: {
service: "Organizations",
action: "updatePolicy", // https://docs.aws.amazon.com/AWSJavaScriptSDK/latest/AWS/Organizations.html#updatePolicy-property
region: organizationsRegion,
parameters: {
Content: content,
Description: description,
Name: policyName,
PolicyId: new custom_resources_1.PhysicalResourceIdReference(),
},
outputPaths: ["Policy.PolicySummary.Id"],
physicalResourceId: custom_resources_1.PhysicalResourceId.fromResponse("Policy.PolicySummary.Id"),
},
onDelete: {
service: "Organizations",
action: "deletePolicy", // https://docs.aws.amazon.com/AWSJavaScriptSDK/latest/AWS/Organizations.html#deletePolicy-property
region: organizationsRegion,
parameters: {
PolicyId: new custom_resources_1.PhysicalResourceIdReference(),
},
},
installLatestAwsSdk: false,
policy: custom_resources_1.AwsCustomResourcePolicy.fromSdkCalls({ resources: custom_resources_1.AwsCustomResourcePolicy.ANY_RESOURCE }),
});
this.policyId = policy.getResponseField("Policy.PolicySummary.Id");
const tagResource = new tag_resource_1.TagResource(this, "Tags", { resourceId: this.policyId, tags: this.tags.renderedTags });
tagResource.node.addDependency(policy);
}
identifier() {
return this.policyId;
}
}
exports.Policy = Policy;
_a = JSII_RTTI_SYMBOL_1;
Policy[_a] = { fqn: "@pepperize/cdk-organizations.Policy", version: "0.7.988" };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"policy.js","sourceRoot":"","sources":["../src/policy.ts"],"names":[],"mappings":"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","sourcesContent":["import { Annotations, TagManager, TagType } from \"aws-cdk-lib\";\nimport {\n  AwsCustomResource,\n  AwsCustomResourcePolicy,\n  PhysicalResourceId,\n  PhysicalResourceIdReference,\n} from \"aws-cdk-lib/custom-resources\";\nimport { Construct, IConstruct } from \"constructs\";\nimport { ITaggableResource, TagResource } from \"./tag-resource\";\nimport { Validators } from \"./validators\";\n\n/**\n * Organizations offers policy types in the following two broad categories:\n * <ol>\n *     <li>Authorization policies help you to centrally manage the security of the AWS accounts in your organization.</li>\n *     <li>Management policies enable you to centrally configure and manage AWS services and their features.</li>\n * </ol>\n *\n * @see https://docs.aws.amazon.com/organizations/latest/userguide/orgs_manage_policies.html#orgs-policy-types\n */\nexport enum PolicyType {\n  /**\n   * Service control policies (SCPs) offer central control over the maximum available permissions for all of the accounts in your organization.\n   */\n  SERVICE_CONTROL_POLICY = \"SERVICE_CONTROL_POLICY\",\n  /**\n   * Tag policies help you standardize the tags attached to the AWS resources in your organization's accounts.\n   */\n  TAG_POLICY = \"TAG_POLICY\",\n  /**\n   * Backup policies help you centrally manage and apply backup plans to the AWS resources across your organization's accounts.\n   */\n  BACKUP_POLICY = \"BACKUP_POLICY\",\n  /**\n   * Artificial Intelligence (AI) services opt-out policies enable you to control data collection for AWS AI services for all of your organization's accounts.\n   */\n  AISERVICES_OPT_OUT_POLICY = \"AISERVICES_OPT_OUT_POLICY\",\n}\n\nexport interface PolicyProps {\n  /**\n   * The policy text content to add to the new policy. The text that you supply must adhere to the rules of the policy type you specify in the Type parameter.\n   */\n  readonly content: string;\n  /**\n   * An optional description to assign to the policy.\n   */\n  readonly description?: string;\n  /**\n   * The friendly name to assign to the policy.\n   */\n  readonly policyName: string;\n  /**\n   * The type of policy to create. You can specify one of the following values:\n   */\n  readonly policyType: PolicyType;\n}\n\n/**\n * Policies in AWS Organizations enable you to apply additional types of management to the AWS accounts in your organization. <strong>You can use policies when all features are enabled in your organization.</strong>\n *\n * <strong>Before you can create and attach a policy to your organization, you must enable that policy type for use.</strong>\n *\n * @see https://docs.aws.amazon.com/organizations/latest/userguide/orgs_manage_policies.html\n * @see FeatureSet\n */\nexport interface IPolicy extends IConstruct {\n  /**\n   * The unique identifier (ID) of the policy. The regex pattern for a policy ID string requires \"p-\" followed by from 8 to 128 lowercase or uppercase letters, digits, or the underscore character (_).\n   */\n  readonly policyId: string;\n}\n\nexport class Policy extends Construct implements IPolicy, ITaggableResource {\n  public readonly policyId: string;\n\n  readonly tags = new TagManager(TagType.KEY_VALUE, \"Custom::Organizations_Policy\");\n\n  public constructor(scope: Construct, id: string, props: PolicyProps) {\n    super(scope, id);\n\n    const { content, description, policyName, policyType } = props;\n    const organizationsRegion = process.env.CDK_AWS_PARTITION === \"aws-cn\" ? \"cn-northwest-1\" : \"us-east-1\";\n\n    if (!Validators.of().policyContent(content)) {\n      Annotations.of(this).addError(\n        \"The text content of the policy must be valid and between 1 and 1,000,000 characters long.\"\n      );\n    }\n\n    const policy = new AwsCustomResource(this, \"PolicyCustomResource\", {\n      resourceType: \"Custom::Organizations_Policy\",\n      onCreate: {\n        service: \"Organizations\",\n        action: \"createPolicy\", // https://docs.aws.amazon.com/AWSJavaScriptSDK/latest/AWS/Organizations.html#createPolicy-property\n        region: organizationsRegion,\n        parameters: {\n          Content: content,\n          Description: description,\n          Name: policyName,\n          Type: policyType,\n        },\n        outputPaths: [\"Policy.PolicySummary.Id\"],\n        physicalResourceId: PhysicalResourceId.fromResponse(\"Policy.PolicySummary.Id\"),\n      },\n      onUpdate: {\n        service: \"Organizations\",\n        action: \"updatePolicy\", // https://docs.aws.amazon.com/AWSJavaScriptSDK/latest/AWS/Organizations.html#updatePolicy-property\n        region: organizationsRegion,\n        parameters: {\n          Content: content,\n          Description: description,\n          Name: policyName,\n          PolicyId: new PhysicalResourceIdReference(),\n        },\n        outputPaths: [\"Policy.PolicySummary.Id\"],\n        physicalResourceId: PhysicalResourceId.fromResponse(\"Policy.PolicySummary.Id\"),\n      },\n      onDelete: {\n        service: \"Organizations\",\n        action: \"deletePolicy\", // https://docs.aws.amazon.com/AWSJavaScriptSDK/latest/AWS/Organizations.html#deletePolicy-property\n        region: organizationsRegion,\n        parameters: {\n          PolicyId: new PhysicalResourceIdReference(),\n        },\n      },\n      installLatestAwsSdk: false,\n      policy: AwsCustomResourcePolicy.fromSdkCalls({ resources: AwsCustomResourcePolicy.ANY_RESOURCE }),\n    });\n    this.policyId = policy.getResponseField(\"Policy.PolicySummary.Id\");\n\n    const tagResource = new TagResource(this, \"Tags\", { resourceId: this.policyId, tags: this.tags.renderedTags });\n    tagResource.node.addDependency(policy);\n  }\n\n  identifier(): string {\n    return this.policyId;\n  }\n}\n"]}