awscdk-resources-mongodbatlas
Version:
MongoDB Atlas CDK Construct Library for AWS CloudFormation Resources
135 lines • 19.4 kB
JavaScript
"use strict";
var _a;
Object.defineProperty(exports, "__esModule", { value: true });
exports.AtlasEncryptionAtRestExpress = void 0;
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
// Copyright 2023 MongoDB Inc
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
const constructs_1 = require("constructs");
const atlas = require("../../index");
const NODE_COUNT = 3;
const NODE_COUNT_ANALYTICS = 1;
const BACKUP_ENABLED = true;
const INSTANCE_SIZE = "M30";
const MONGODB_VERSION = "5.0";
const ENCRYPTION_AT_REST_PROVIDER = atlas.CfnClusterPropsEncryptionAtRestProvider.AWS;
const REGION = "US_EAST_1";
const EBS_VOLUME_TYPE = "STANDARD";
const ENABLE_ENCRYPTION_AT_REST = true;
const CLUSTER_TYPE = "REPLICASET";
const DB_NAME = "admin";
const USERNAME = "cdkUser";
const ROLE = [
{
roleName: "atlasAdmin",
databaseName: "admin",
},
];
function randomNumber() {
const min = 10;
const max = 9999999;
return Math.floor(Math.random() * (max - min + 1) + min);
}
function getClusterProps(inputClusterProps) {
return {
name: inputClusterProps.name || "atlas-cluster-".concat(String(randomNumber())),
mongoDbMajorVersion: inputClusterProps.mongoDbMajorVersion || MONGODB_VERSION,
backupEnabled: inputClusterProps.backupEnabled ?? BACKUP_ENABLED,
diskSizeGb: inputClusterProps.diskSizeGb,
clusterType: inputClusterProps.clusterType || CLUSTER_TYPE,
biConnector: inputClusterProps.biConnector,
encryptionAtRestProvider: inputClusterProps.encryptionAtRestProvider || ENCRYPTION_AT_REST_PROVIDER,
labels: inputClusterProps.labels,
paused: inputClusterProps.paused,
pitEnabled: inputClusterProps.pitEnabled,
rootCertType: inputClusterProps.rootCertType,
terminationProtectionEnabled: inputClusterProps.terminationProtectionEnabled,
versionReleaseSystem: inputClusterProps.versionReleaseSystem,
advancedSettings: inputClusterProps.advancedSettings,
replicationSpecs: inputClusterProps.replicationSpecs || getDefaultClusterReplicationSpec(),
projectId: "",
};
}
function getDefaultClusterReplicationSpec() {
return [
{
numShards: 1,
advancedRegionConfigs: [
{
analyticsSpecs: {
ebsVolumeType: EBS_VOLUME_TYPE,
instanceSize: INSTANCE_SIZE,
nodeCount: NODE_COUNT_ANALYTICS,
},
electableSpecs: {
ebsVolumeType: EBS_VOLUME_TYPE,
instanceSize: INSTANCE_SIZE,
nodeCount: NODE_COUNT,
},
priority: 7,
regionName: REGION,
},
],
},
];
}
class AtlasEncryptionAtRestExpress extends constructs_1.Construct {
constructor(scope, id, props) {
super(scope, id);
this.encryptionAtRest = new atlas.CfnEncryptionAtRest(this, "encryption-at-rest-".concat(id), {
awsKmsConfig: {
customerMasterKeyId: props.encryptionAtRest.customerMasterKeyId,
roleId: props.encryptionAtRest.roleId,
enabled: props.encryptionAtRest.enabledEncryptionAtRest ||
ENABLE_ENCRYPTION_AT_REST,
region: props.encryptionAtRest.region || REGION,
},
projectId: props.projectId,
profile: props.profile,
});
if (props.cluster) {
// Create a new MongoDB Atlas Cluster and pass project ID
const clusterProps = getClusterProps(props.cluster);
this.cluster = new atlas.CfnCluster(this, "cluster-".concat(id), {
...clusterProps,
profile: props.profile,
projectId: props.projectId,
});
}
if (props.databaseUser) {
// Create a new MongoDB Atlas Database User
this.databaseUser = new atlas.CfnDatabaseUser(this, "db-user-".concat(id), {
...props.databaseUser,
profile: props.profile,
databaseName: props.databaseUser?.databaseName || DB_NAME,
projectId: props.projectId,
username: props.databaseUser?.username || USERNAME,
roles: props.databaseUser?.roles || ROLE,
password: props.databaseUser.password,
});
}
if (props.accessList) {
// Create a new MongoDB Atlas Project IP Access List
this.accessList = new atlas.CfnProjectIpAccessList(this, "access-list-".concat(id), {
...props.accessList,
profile: props.profile,
projectId: props.projectId,
});
}
}
}
exports.AtlasEncryptionAtRestExpress = AtlasEncryptionAtRestExpress;
_a = JSII_RTTI_SYMBOL_1;
AtlasEncryptionAtRestExpress[_a] = { fqn: "awscdk-resources-mongodbatlas.AtlasEncryptionAtRestExpress", version: "3.13.0" };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/l3-resources/encryption-at-rest-express/index.ts"],"names":[],"mappings":"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","sourcesContent":["// Copyright 2023 MongoDB Inc\n//\n// Licensed under the Apache License, Version 2.0 (the \"License\");\n// you may not use this file except in compliance with the License.\n// You may obtain a copy of the License at\n//\n//      http://www.apache.org/licenses/LICENSE-2.0\n//\n// Unless required by applicable law or agreed to in writing, software\n// distributed under the License is distributed on an \"AS IS\" BASIS,\n// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n// See the License for the specific language governing permissions and\n// limitations under the License.\n\nimport { Construct } from \"constructs\";\nimport * as atlas from \"../../index\";\nimport {\n  ClusterProps,\n  DatabaseUserProps,\n  IpAccessListProps,\n} from \"../common/props\";\n\nconst NODE_COUNT = 3;\nconst NODE_COUNT_ANALYTICS = 1;\nconst BACKUP_ENABLED = true;\nconst INSTANCE_SIZE = \"M30\";\nconst MONGODB_VERSION = \"5.0\";\nconst ENCRYPTION_AT_REST_PROVIDER =\n  atlas.CfnClusterPropsEncryptionAtRestProvider.AWS;\nconst REGION = \"US_EAST_1\";\nconst EBS_VOLUME_TYPE = \"STANDARD\";\nconst ENABLE_ENCRYPTION_AT_REST = true;\nconst CLUSTER_TYPE = \"REPLICASET\";\nconst DB_NAME = \"admin\";\nconst USERNAME = \"cdkUser\";\nconst ROLE = [\n  {\n    roleName: \"atlasAdmin\",\n    databaseName: \"admin\",\n  },\n];\n\nfunction randomNumber() {\n  const min = 10;\n  const max = 9999999;\n  return Math.floor(Math.random() * (max - min + 1) + min);\n}\n\nfunction getClusterProps(\n  inputClusterProps: ClusterProps\n): atlas.CfnClusterProps {\n  return {\n    name:\n      inputClusterProps.name || \"atlas-cluster-\".concat(String(randomNumber())),\n    mongoDbMajorVersion:\n      inputClusterProps.mongoDbMajorVersion || MONGODB_VERSION,\n    backupEnabled: inputClusterProps.backupEnabled ?? BACKUP_ENABLED,\n    diskSizeGb: inputClusterProps.diskSizeGb,\n    clusterType: inputClusterProps.clusterType || CLUSTER_TYPE,\n    biConnector: inputClusterProps.biConnector,\n    encryptionAtRestProvider:\n      inputClusterProps.encryptionAtRestProvider || ENCRYPTION_AT_REST_PROVIDER,\n    labels: inputClusterProps.labels,\n    paused: inputClusterProps.paused,\n    pitEnabled: inputClusterProps.pitEnabled,\n    rootCertType: inputClusterProps.rootCertType,\n    terminationProtectionEnabled:\n      inputClusterProps.terminationProtectionEnabled,\n    versionReleaseSystem: inputClusterProps.versionReleaseSystem,\n    advancedSettings: inputClusterProps.advancedSettings,\n    replicationSpecs:\n      inputClusterProps.replicationSpecs || getDefaultClusterReplicationSpec(),\n    projectId: \"\",\n  };\n}\n\nfunction getDefaultClusterReplicationSpec(): atlas.AdvancedReplicationSpec[] {\n  return [\n    {\n      numShards: 1,\n      advancedRegionConfigs: [\n        {\n          analyticsSpecs: {\n            ebsVolumeType: EBS_VOLUME_TYPE,\n            instanceSize: INSTANCE_SIZE,\n            nodeCount: NODE_COUNT_ANALYTICS,\n          },\n          electableSpecs: {\n            ebsVolumeType: EBS_VOLUME_TYPE,\n            instanceSize: INSTANCE_SIZE,\n            nodeCount: NODE_COUNT,\n          },\n          priority: 7,\n          regionName: REGION,\n        },\n      ],\n    },\n  ];\n}\n\nexport interface EncryptionAtRestProps {\n  /**\n   * ID of an AWS IAM role authorized to manage an AWS customer master key.\n   *\n   * @schema AwsKms#RoleID\n   */\n  readonly roleId: string;\n  /**\n   * The AWS customer master key used to encrypt and decrypt the MongoDB master keys.\n   *\n   * @schema AwsKms#CustomerMasterKeyID\n   */\n  readonly customerMasterKeyId: string;\n  /**\n   * Specifies whether Encryption at Rest is enabled for an Atlas project. To disable Encryption at Rest, pass only this parameter with a value of false. When you disable Encryption at Rest, Atlas also removes the configuration details.\n   * Default Value: true\n   * @schema AwsKms#Enabled\n   */\n  readonly enabledEncryptionAtRest?: boolean;\n\n  /**\n   * The AWS region in which the AWS customer master key exists.\n   *\n   * @schema AwsKms#Region\n   */\n  readonly region?: string;\n}\n\nexport interface AtlasEncryptionAtRestExpressProps {\n  readonly cluster?: ClusterProps;\n  readonly accessList?: IpAccessListProps;\n  readonly encryptionAtRest: EncryptionAtRestProps;\n  readonly databaseUser?: DatabaseUserProps;\n  readonly profile?: string;\n  readonly projectId: string;\n}\n\nexport class AtlasEncryptionAtRestExpress extends Construct {\n  readonly encryptionAtRest: atlas.CfnEncryptionAtRest;\n  readonly cluster?: atlas.CfnCluster;\n  readonly accessList?: atlas.CfnProjectIpAccessList;\n  readonly databaseUser?: atlas.CfnDatabaseUser;\n\n  constructor(\n    scope: Construct,\n    id: string,\n    props: AtlasEncryptionAtRestExpressProps\n  ) {\n    super(scope, id);\n\n    this.encryptionAtRest = new atlas.CfnEncryptionAtRest(\n      this,\n      \"encryption-at-rest-\".concat(id),\n      {\n        awsKmsConfig: {\n          customerMasterKeyId: props.encryptionAtRest.customerMasterKeyId,\n          roleId: props.encryptionAtRest.roleId,\n          enabled:\n            props.encryptionAtRest.enabledEncryptionAtRest ||\n            ENABLE_ENCRYPTION_AT_REST,\n          region: props.encryptionAtRest.region || REGION,\n        },\n        projectId: props.projectId,\n        profile: props.profile,\n      }\n    );\n\n    if (props.cluster) {\n      // Create a new MongoDB Atlas Cluster and pass project ID\n      const clusterProps = getClusterProps(props.cluster);\n      this.cluster = new atlas.CfnCluster(this, \"cluster-\".concat(id), {\n        ...clusterProps,\n        profile: props.profile,\n        projectId: props.projectId,\n      });\n    }\n\n    if (props.databaseUser) {\n      // Create a new MongoDB Atlas Database User\n      this.databaseUser = new atlas.CfnDatabaseUser(\n        this,\n        \"db-user-\".concat(id),\n        {\n          ...props.databaseUser,\n          profile: props.profile,\n          databaseName: props.databaseUser?.databaseName || DB_NAME,\n          projectId: props.projectId,\n          username: props.databaseUser?.username || USERNAME,\n          roles: props.databaseUser?.roles || ROLE,\n          password: props.databaseUser.password,\n        }\n      );\n    }\n\n    if (props.accessList) {\n      // Create a new MongoDB Atlas Project IP Access List\n      this.accessList = new atlas.CfnProjectIpAccessList(\n        this,\n        \"access-list-\".concat(id),\n        {\n          ...props.accessList,\n          profile: props.profile,\n          projectId: props.projectId,\n        }\n      );\n    }\n  }\n}\n"]}