UNPKG

@aws-cdk/aws-redshift-alpha

Version:

The CDK Construct Library for AWS::Redshift

118 lines 15.2 kB
"use strict"; 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 { /** * The tables that user will have access to */ privileges; 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 { static [JSII_RTTI_SYMBOL_1] = { fqn: "@aws-cdk/aws-redshift-alpha.User", version: "2.237.1-alpha.0" }; /** * 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 { username = attrs.username; password = attrs.password; cluster = attrs.cluster; databaseName = attrs.databaseName; databaseProps = attrs; }(scope, id); } username; password; cluster; databaseName; databaseProps; /** * The Secrets Manager secret of the user. * @attribute */ secret; resource; 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; //# 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;IAMvC;;OAEG;IACK,UAAU,CAAuB;IAIzC,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;YACtB,QAAQ,GAAG,KAAK,CAAC,QAAQ,CAAC;YAC1B,QAAQ,GAAG,KAAK,CAAC,QAAQ,CAAC;YAC1B,OAAO,GAAG,KAAK,CAAC,OAAO,CAAC;YACxB,YAAY,GAAG,KAAK,CAAC,YAAY,CAAC;YACxB,aAAa,GAAG,KAAK,CAAC;SAC1C,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;KACd;IAEQ,QAAQ,CAAS;IACjB,QAAQ,CAAkB;IAC1B,OAAO,CAAW;IAClB,YAAY,CAAS;IACpB,aAAa,CAAkB;IAEzC;;;OAGG;IACa,MAAM,CAAyB;IAEvC,QAAQ,CAAkC;IAElD,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"]}