@cloudcamp/aws-runtime
Version:
CloudCamp - Launch faster by building scalable infrastructure in few lines of code.
126 lines • 15.2 kB
JavaScript
;
var _a;
Object.defineProperty(exports, "__esModule", { value: true });
exports.Database = void 0;
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
const cdk = require("aws-cdk-lib/core");
const rds = require("aws-cdk-lib/aws-rds");
const ec2 = require("aws-cdk-lib/aws-ec2");
const core_1 = require("aws-cdk-lib/core");
const secretsmanager = require("aws-cdk-lib/aws-secretsmanager");
const app_1 = require("./app");
const aws_rds_1 = require("aws-cdk-lib/aws-rds");
const constructs_1 = require("constructs");
/**
* @experimental
* @order 5
*/
class Database extends constructs_1.Construct {
/**
* @param scope the scope.
* @param id the id.
* @param props the props.
* @experimental
*/
constructor(scope, id, props) {
super(scope, id);
let engine;
let type;
let port;
props = props || {};
switch (props.engine) {
case undefined:
case "postgres":
engine = rds.DatabaseClusterEngine.auroraPostgres({
version: aws_rds_1.AuroraPostgresEngineVersion.VER_10_14,
});
type = "postgres";
port = 5432;
break;
case "mysql":
engine = rds.DatabaseClusterEngine.auroraMysql({
version: aws_rds_1.AuroraMysqlEngineVersion.VER_5_7_12,
});
type = "mysql";
port = 3306;
break;
}
const username = props.username || "administrator";
const secret = new secretsmanager.Secret(this, "cluster-secret", {
generateSecretString: {
excludePunctuation: true,
},
});
const password = secret.secretValue;
const databaseName = props.databaseName || "maindb";
let vpc = ec2.Vpc.fromLookup(this, "vpc", {
vpcId: app_1.App.instance.configuration.vpcId,
});
const securityGroup = new ec2.SecurityGroup(this, "security-group", {
vpc,
allowAllOutbound: true,
});
securityGroup.addIngressRule(ec2.Peer.anyIpv4(), ec2.Port.tcp(port));
this.cluster = new rds.ServerlessCluster(this, "cluster", {
engine: engine,
vpc,
scaling: {
autoPause: core_1.Duration.minutes(props.autoPause || 0),
minCapacity: this.getCapacity(props.minCapacity),
maxCapacity: this.getCapacity(props.maxCapacity),
},
deletionProtection: true,
removalPolicy: cdk.RemovalPolicy.RETAIN,
defaultDatabaseName: databaseName,
securityGroups: [securityGroup],
credentials: {
username: username,
password: password,
},
});
let host = this.cluster.clusterEndpoint.hostname;
this.vars = {
databaseUrl: `${type}://${username}:${password}@${host}:${port}/${databaseName}`,
databaseName: databaseName,
databaseUsername: username,
databasePassword: password.toString(),
databaseHost: host,
databasePort: `${port}`,
databaseType: type,
};
}
getCapacity(capacity) {
switch (capacity) {
case undefined:
return rds.AuroraCapacityUnit.ACU_2;
case 1:
return rds.AuroraCapacityUnit.ACU_1;
case 2:
return rds.AuroraCapacityUnit.ACU_2;
case 4:
return rds.AuroraCapacityUnit.ACU_4;
case 8:
return rds.AuroraCapacityUnit.ACU_1;
case 16:
return rds.AuroraCapacityUnit.ACU_16;
case 32:
return rds.AuroraCapacityUnit.ACU_32;
case 64:
return rds.AuroraCapacityUnit.ACU_64;
case 128:
return rds.AuroraCapacityUnit.ACU_128;
case 192:
return rds.AuroraCapacityUnit.ACU_192;
case 256:
return rds.AuroraCapacityUnit.ACU_256;
case 384:
return rds.AuroraCapacityUnit.ACU_384;
default:
throw new Error(`Unsupported database capacity: ${capacity}`);
}
}
}
exports.Database = Database;
_a = JSII_RTTI_SYMBOL_1;
Database[_a] = { fqn: "@cloudcamp/aws-runtime.Database", version: "0.0.1" };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"database.js","sourceRoot":"","sources":["../src/database.ts"],"names":[],"mappings":"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","sourcesContent":["import * as cdk from \"aws-cdk-lib/core\";\nimport * as rds from \"aws-cdk-lib/aws-rds\";\nimport * as ec2 from \"aws-cdk-lib/aws-ec2\";\nimport { Duration } from \"aws-cdk-lib/core\";\nimport * as secretsmanager from \"aws-cdk-lib/aws-secretsmanager\";\nimport { App } from \"./app\";\nimport {\n  AuroraMysqlEngineVersion,\n  AuroraPostgresEngineVersion,\n} from \"aws-cdk-lib/aws-rds\";\nimport { Construct } from \"constructs\";\n\n// TODO logs\n// TODO alerts\n// TODO how to change password?\n// TODO how to run scripts to create databases\n\n// Needs a private subnet\n// https://github.com/aws/aws-cdk/issues/7062\n\ntype DatabaseCapacity = 1 | 2 | 4 | 8 | 16 | 32 | 64 | 128 | 192 | 256 | 384;\n\nexport interface DatabaseProps {\n                                    \n  readonly engine?: \"mysql\" | \"postgres\";\n  readonly databaseName?: string;\n  readonly username?: string;\n  readonly autoPause?: number;\n  readonly minCapacity?: DatabaseCapacity;\n  readonly maxCapacity?: DatabaseCapacity;\n}\n\nexport interface DatabaseVariables {\n  readonly databaseUrl: string;\n  readonly databaseName: string;\n  readonly databaseUsername: string;\n  readonly databasePassword: string;\n  readonly databaseHost: string;\n  readonly databasePort: string;\n  readonly databaseType: string;\n}\n\n                   \nexport class Database extends Construct {\n  cluster: rds.IServerlessCluster;\n\n  vars: DatabaseVariables;\n\n                                                                                               \n  constructor(scope: Construct, id: string, props?: DatabaseProps) {\n    super(scope, id);\n\n    let engine: rds.IClusterEngine;\n    let type: string;\n    let port: number;\n\n    props = props || {};\n\n    switch (props.engine) {\n      case undefined:\n      case \"postgres\":\n        engine = rds.DatabaseClusterEngine.auroraPostgres({\n          version: AuroraPostgresEngineVersion.VER_10_14,\n        });\n        type = \"postgres\";\n        port = 5432;\n        break;\n      case \"mysql\":\n        engine = rds.DatabaseClusterEngine.auroraMysql({\n          version: AuroraMysqlEngineVersion.VER_5_7_12,\n        });\n        type = \"mysql\";\n        port = 3306;\n        break;\n    }\n\n    const username = props.username || \"administrator\";\n\n    const secret = new secretsmanager.Secret(this, \"cluster-secret\", {\n      generateSecretString: {\n        excludePunctuation: true,\n      },\n    });\n\n    const password = secret.secretValue;\n    const databaseName = props.databaseName || \"maindb\";\n\n    let vpc = ec2.Vpc.fromLookup(this, \"vpc\", {\n      vpcId: App.instance.configuration.vpcId,\n    });\n\n    const securityGroup = new ec2.SecurityGroup(this, \"security-group\", {\n      vpc,\n      allowAllOutbound: true,\n    });\n    securityGroup.addIngressRule(ec2.Peer.anyIpv4(), ec2.Port.tcp(port));\n\n    this.cluster = new rds.ServerlessCluster(this, \"cluster\", {\n      engine: engine,\n      vpc,\n      scaling: {\n        autoPause: Duration.minutes(props.autoPause || 0),\n        minCapacity: this.getCapacity(props.minCapacity),\n        maxCapacity: this.getCapacity(props.maxCapacity),\n      },\n      deletionProtection: true,\n      removalPolicy: cdk.RemovalPolicy.RETAIN,\n      defaultDatabaseName: databaseName,\n      securityGroups: [securityGroup],\n      credentials: {\n        username: username,\n        password: password,\n      },\n    });\n\n    let host = this.cluster.clusterEndpoint.hostname;\n\n    this.vars = {\n      databaseUrl: `${type}://${username}:${password}@${host}:${port}/${databaseName}`,\n      databaseName: databaseName,\n      databaseUsername: username,\n      databasePassword: password.toString(),\n      databaseHost: host,\n      databasePort: `${port}`,\n      databaseType: type,\n    };\n  }\n\n  private getCapacity(capacity?: DatabaseCapacity) {\n    switch (capacity) {\n      case undefined:\n        return rds.AuroraCapacityUnit.ACU_2;\n      case 1:\n        return rds.AuroraCapacityUnit.ACU_1;\n      case 2:\n        return rds.AuroraCapacityUnit.ACU_2;\n      case 4:\n        return rds.AuroraCapacityUnit.ACU_4;\n      case 8:\n        return rds.AuroraCapacityUnit.ACU_1;\n      case 16:\n        return rds.AuroraCapacityUnit.ACU_16;\n      case 32:\n        return rds.AuroraCapacityUnit.ACU_32;\n      case 64:\n        return rds.AuroraCapacityUnit.ACU_64;\n      case 128:\n        return rds.AuroraCapacityUnit.ACU_128;\n      case 192:\n        return rds.AuroraCapacityUnit.ACU_192;\n      case 256:\n        return rds.AuroraCapacityUnit.ACU_256;\n      case 384:\n        return rds.AuroraCapacityUnit.ACU_384;\n      default:\n        throw new Error(`Unsupported database capacity: ${capacity}`);\n    }\n  }\n}\n"]}