@aws-cdk/aws-redshift-alpha
Version:
The CDK Construct Library for AWS::Redshift
108 lines • 14.9 kB
JavaScript
"use strict";
var _a;
Object.defineProperty(exports, "__esModule", { value: true });
exports.User = void 0;
const jsiiDeprecationWarnings = require("../.warnings.jsii.js");
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
const cdk = require("aws-cdk-lib/core");
const constructs_1 = require("constructs");
const database_secret_1 = require("./database-secret");
const database_query_1 = require("./private/database-query");
const handler_name_1 = require("./private/database-query-provider/handler-name");
const privileges_1 = require("./private/privileges");
class UserBase extends constructs_1.Construct {
addTablePrivileges(table, ...actions) {
if (!this.privileges) {
this.privileges = new privileges_1.UserTablePrivileges(this, 'TablePrivileges', {
...this.databaseProps,
user: this,
});
// The privilege should be granted or revoked when the table exists.
this.privileges.node.addDependency(table);
}
this.privileges.addPrivileges(table, ...actions);
}
}
/**
* A user in a Redshift cluster.
*/
class User extends UserBase {
/**
* Specify a Redshift user using credentials that already exist.
*/
static fromUserAttributes(scope, id, attrs) {
try {
jsiiDeprecationWarnings._aws_cdk_aws_redshift_alpha_UserAttributes(attrs);
}
catch (error) {
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
Error.captureStackTrace(error, this.fromUserAttributes);
}
throw error;
}
return new class extends UserBase {
constructor() {
super(...arguments);
this.username = attrs.username;
this.password = attrs.password;
this.cluster = attrs.cluster;
this.databaseName = attrs.databaseName;
this.databaseProps = attrs;
}
}(scope, id);
}
constructor(scope, id, props) {
super(scope, id);
try {
jsiiDeprecationWarnings._aws_cdk_aws_redshift_alpha_UserProps(props);
}
catch (error) {
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
Error.captureStackTrace(error, User);
}
throw error;
}
this.databaseProps = props;
this.cluster = props.cluster;
this.databaseName = props.databaseName;
const username = props.username ?? cdk.Names.uniqueId(this).toLowerCase();
const secret = new database_secret_1.DatabaseSecret(this, 'Secret', {
username,
encryptionKey: props.encryptionKey,
excludeCharacters: props.excludeCharacters,
});
const attachedSecret = secret.attach(props.cluster);
this.password = attachedSecret.secretValueFromJson('password');
this.resource = new database_query_1.DatabaseQuery(this, 'Resource', {
...this.databaseProps,
handler: handler_name_1.HandlerName.User,
properties: {
username,
passwordSecretArn: attachedSecret.secretArn,
},
});
attachedSecret.grantRead(this.resource);
this.username = this.resource.getAttString('username');
this.secret = secret;
}
/**
* Apply the given removal policy to this resource
*
* The Removal Policy controls what happens to this resource when it stops
* being managed by CloudFormation, either because you've removed it from the
* CDK application or because you've made a change that requires the resource
* to be replaced.
*
* The resource can be destroyed (`RemovalPolicy.DESTROY`), or left in your AWS
* account for data recovery and cleanup later (`RemovalPolicy.RETAIN`).
*
* This resource is destroyed by default.
*/
applyRemovalPolicy(policy) {
this.resource.applyRemovalPolicy(policy);
}
}
exports.User = User;
_a = JSII_RTTI_SYMBOL_1;
User[_a] = { fqn: "@aws-cdk/aws-redshift-alpha.User", version: "2.211.0-alpha.0" };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"user.js","sourceRoot":"","sources":["user.ts"],"names":[],"mappings":";;;;;;AAEA,wCAAwC;AACxC,2CAAmD;AAGnD,uDAAmD;AACnD,6DAAyD;AACzD,iFAA6E;AAE7E,qDAA2D;AAqF3D,MAAe,QAAS,SAAQ,sBAAS;IAavC,kBAAkB,CAAC,KAAa,EAAE,GAAG,OAAsB;QACzD,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC;YACrB,IAAI,CAAC,UAAU,GAAG,IAAI,gCAAmB,CAAC,IAAI,EAAE,iBAAiB,EAAE;gBACjE,GAAG,IAAI,CAAC,aAAa;gBACrB,IAAI,EAAE,IAAI;aACX,CAAC,CAAC;YAEH,oEAAoE;YACpE,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QAC5C,CAAC;QAED,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,KAAK,EAAE,GAAG,OAAO,CAAC,CAAC;KAClD;CACF;AAED;;GAEG;AACH,MAAa,IAAK,SAAQ,QAAQ;IAChC;;OAEG;IACH,MAAM,CAAC,kBAAkB,CAAC,KAAgB,EAAE,EAAU,EAAE,KAAqB;;;;;;;;;;QAC3E,OAAO,IAAI,KAAM,SAAQ,QAAQ;YAAtB;;gBACA,aAAQ,GAAG,KAAK,CAAC,QAAQ,CAAC;gBAC1B,aAAQ,GAAG,KAAK,CAAC,QAAQ,CAAC;gBAC1B,YAAO,GAAG,KAAK,CAAC,OAAO,CAAC;gBACxB,iBAAY,GAAG,KAAK,CAAC,YAAY,CAAC;gBACxB,kBAAa,GAAG,KAAK,CAAC;YAC3C,CAAC;SAAA,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;KACd;IAgBD,YAAY,KAAgB,EAAE,EAAU,EAAE,KAAgB;QACxD,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;;;;;;+CA7BR,IAAI;;;;QA+Bb,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;QAC3B,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC,OAAO,CAAC;QAC7B,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC,YAAY,CAAC;QAEvC,MAAM,QAAQ,GAAG,KAAK,CAAC,QAAQ,IAAI,GAAG,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,WAAW,EAAE,CAAC;QAC1E,MAAM,MAAM,GAAG,IAAI,gCAAc,CAAC,IAAI,EAAE,QAAQ,EAAE;YAChD,QAAQ;YACR,aAAa,EAAE,KAAK,CAAC,aAAa;YAClC,iBAAiB,EAAE,KAAK,CAAC,iBAAiB;SAC3C,CAAC,CAAC;QACH,MAAM,cAAc,GAAG,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;QACpD,IAAI,CAAC,QAAQ,GAAG,cAAc,CAAC,mBAAmB,CAAC,UAAU,CAAC,CAAC;QAE/D,IAAI,CAAC,QAAQ,GAAG,IAAI,8BAAa,CAAmB,IAAI,EAAE,UAAU,EAAE;YACpE,GAAG,IAAI,CAAC,aAAa;YACrB,OAAO,EAAE,0BAAW,CAAC,IAAI;YACzB,UAAU,EAAE;gBACV,QAAQ;gBACR,iBAAiB,EAAE,cAAc,CAAC,SAAS;aAC5C;SACF,CAAC,CAAC;QACH,cAAc,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAExC,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,UAAU,CAAC,CAAC;QACvD,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;KACtB;IAED;;;;;;;;;;;;OAYG;IACI,kBAAkB,CAAC,MAAyB;QACjD,IAAI,CAAC,QAAQ,CAAC,kBAAkB,CAAC,MAAM,CAAC,CAAC;KAC1C;;AAzEH,oBA0EC","sourcesContent":["import * as kms from 'aws-cdk-lib/aws-kms';\nimport * as secretsmanager from 'aws-cdk-lib/aws-secretsmanager';\nimport * as cdk from 'aws-cdk-lib/core';\nimport { Construct, IConstruct } from 'constructs';\nimport { ICluster } from './cluster';\nimport { DatabaseOptions } from './database-options';\nimport { DatabaseSecret } from './database-secret';\nimport { DatabaseQuery } from './private/database-query';\nimport { HandlerName } from './private/database-query-provider/handler-name';\nimport { UserHandlerProps } from './private/handler-props';\nimport { UserTablePrivileges } from './private/privileges';\nimport { ITable, TableAction } from './table';\n\n/**\n * Properties for configuring a Redshift user.\n */\nexport interface UserProps extends DatabaseOptions {\n  /**\n   * The name of the user.\n   *\n   * For valid values, see: https://docs.aws.amazon.com/redshift/latest/dg/r_names.html\n   *\n   * @default - a name is generated\n   */\n  readonly username?: string;\n\n  /**\n   * KMS key to encrypt the generated secret.\n   *\n   * @default - the default AWS managed key is used\n   */\n  readonly encryptionKey?: kms.IKey;\n\n  /**\n   * Characters to not include in the generated password.\n   *\n   * @default '\"@/\\\\\\ \\''\n   */\n  readonly excludeCharacters?: string;\n\n  /**\n   * The policy to apply when this resource is removed from the application.\n   *\n   * @default cdk.RemovalPolicy.Destroy\n   */\n  readonly removalPolicy?: cdk.RemovalPolicy;\n}\n\n/**\n * Represents a user in a Redshift database.\n */\nexport interface IUser extends IConstruct {\n  /**\n   * The name of the user.\n   */\n  readonly username: string;\n\n  /**\n   * The password of the user.\n   */\n  readonly password: cdk.SecretValue;\n\n  /**\n   * The cluster where the table is located.\n   */\n  readonly cluster: ICluster;\n\n  /**\n   * The name of the database where the table is located.\n   */\n  readonly databaseName: string;\n\n  /**\n   * Grant this user privilege to access a table.\n   */\n  addTablePrivileges(table: ITable, ...actions: TableAction[]): void;\n}\n\n/**\n * A full specification of a Redshift user that can be used to import it fluently into the CDK application.\n */\nexport interface UserAttributes extends DatabaseOptions {\n  /**\n   * The name of the user.\n   */\n  readonly username: string;\n\n  /**\n   * The password of the user.\n   *\n   * Do not put passwords in CDK code directly.\n   */\n  readonly password: cdk.SecretValue;\n}\n\nabstract class UserBase extends Construct implements IUser {\n  abstract readonly username: string;\n  abstract readonly password: cdk.SecretValue;\n  abstract readonly cluster: ICluster;\n  abstract readonly databaseName: string;\n\n  /**\n   * The tables that user will have access to\n   */\n  private privileges?: UserTablePrivileges;\n\n  protected abstract readonly databaseProps: DatabaseOptions;\n\n  addTablePrivileges(table: ITable, ...actions: TableAction[]): void {\n    if (!this.privileges) {\n      this.privileges = new UserTablePrivileges(this, 'TablePrivileges', {\n        ...this.databaseProps,\n        user: this,\n      });\n\n      // The privilege should be granted or revoked when the table exists.\n      this.privileges.node.addDependency(table);\n    }\n\n    this.privileges.addPrivileges(table, ...actions);\n  }\n}\n\n/**\n * A user in a Redshift cluster.\n */\nexport class User extends UserBase {\n  /**\n   * Specify a Redshift user using credentials that already exist.\n   */\n  static fromUserAttributes(scope: Construct, id: string, attrs: UserAttributes): IUser {\n    return new class extends UserBase {\n      readonly username = attrs.username;\n      readonly password = attrs.password;\n      readonly cluster = attrs.cluster;\n      readonly databaseName = attrs.databaseName;\n      protected readonly databaseProps = attrs;\n    }(scope, id);\n  }\n\n  readonly username: string;\n  readonly password: cdk.SecretValue;\n  readonly cluster: ICluster;\n  readonly databaseName: string;\n  protected databaseProps: DatabaseOptions;\n\n  /**\n   * The Secrets Manager secret of the user.\n   * @attribute\n   */\n  public readonly secret: secretsmanager.ISecret;\n\n  private resource: DatabaseQuery<UserHandlerProps>;\n\n  constructor(scope: Construct, id: string, props: UserProps) {\n    super(scope, id);\n\n    this.databaseProps = props;\n    this.cluster = props.cluster;\n    this.databaseName = props.databaseName;\n\n    const username = props.username ?? cdk.Names.uniqueId(this).toLowerCase();\n    const secret = new DatabaseSecret(this, 'Secret', {\n      username,\n      encryptionKey: props.encryptionKey,\n      excludeCharacters: props.excludeCharacters,\n    });\n    const attachedSecret = secret.attach(props.cluster);\n    this.password = attachedSecret.secretValueFromJson('password');\n\n    this.resource = new DatabaseQuery<UserHandlerProps>(this, 'Resource', {\n      ...this.databaseProps,\n      handler: HandlerName.User,\n      properties: {\n        username,\n        passwordSecretArn: attachedSecret.secretArn,\n      },\n    });\n    attachedSecret.grantRead(this.resource);\n\n    this.username = this.resource.getAttString('username');\n    this.secret = secret;\n  }\n\n  /**\n   * Apply the given removal policy to this resource\n   *\n   * The Removal Policy controls what happens to this resource when it stops\n   * being managed by CloudFormation, either because you've removed it from the\n   * CDK application or because you've made a change that requires the resource\n   * to be replaced.\n   *\n   * The resource can be destroyed (`RemovalPolicy.DESTROY`), or left in your AWS\n   * account for data recovery and cleanup later (`RemovalPolicy.RETAIN`).\n   *\n   * This resource is destroyed by default.\n   */\n  public applyRemovalPolicy(policy: cdk.RemovalPolicy): void {\n    this.resource.applyRemovalPolicy(policy);\n  }\n}\n"]}