UNPKG

awscdk-resources-mongodbatlas

Version:

MongoDB Atlas CDK Construct Library for AWS CloudFormation Resources

135 lines 19.4 kB
"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"]}