UNPKG

aws-ddk-core

Version:

The AWS DataOps Development Kit is an open source development framework for customers that build data workflows and modern data architecture on AWS.

87 lines 14.1 kB
"use strict"; var _a; Object.defineProperty(exports, "__esModule", { value: true }); exports.RedshiftDataApiStage = void 0; const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti"); const cdk = require("aws-cdk-lib"); const iam = require("aws-cdk-lib/aws-iam"); const sfn = require("aws-cdk-lib/aws-stepfunctions"); const tasks = require("aws-cdk-lib/aws-stepfunctions-tasks"); const stage_1 = require("../pipelines/stage"); /** * Stage that contains a step function that executes Redshift Data API statements. */ class RedshiftDataApiStage extends stage_1.StateMachineStage { /** * Constructs `RedshiftDataApiStage`. * @param scope Scope within which this construct is defined. * @param id Identifier of the stage. * @param props Properties for the stage. */ constructor(scope, id, props) { super(scope, id, props); this.stateMachineInput = props.stateMachineInput; const stack = cdk.Stack.of(this); const databaseName = props.databaseName ?? "dev"; const databaseUser = props.databaseUser ?? "awsuser"; const redshiftClusterArn = `arn:aws:redshift:${stack.region}:${stack.account}:cluster:${props.redshiftClusterIdentifier}`; const redshiftDatabaseArn = `arn:aws:redshift:${stack.region}:${stack.account}:dbname:${props.redshiftClusterIdentifier}/${databaseName}`; const redshiftUserArn = `arn:aws:redshift:${stack.region}:${stack.account}:dbuser:${props.redshiftClusterIdentifier}/${databaseUser}`; const pollingTime = props.pollingTime ?? cdk.Duration.seconds(15); const batchExecuteStatement = new tasks.CallAwsService(this, `${id} Execute Statement on Redshift`, { service: "redshiftdata", action: "batchExecuteStatement", iamResources: [redshiftClusterArn], parameters: { ClusterIdentifier: props.redshiftClusterIdentifier, Database: databaseName, Sqls: props.sqlStatements, DbUser: databaseUser, }, resultPath: "$.sql_output", }); const wait = new sfn.Wait(this, "wait", { time: sfn.WaitTime.duration(pollingTime), }); const describeStatement = new tasks.CallAwsService(this, `${id} Describe Statement on Redshift`, { service: "redshiftdata", action: "describeStatement", iamResources: [redshiftClusterArn], parameters: { "Id.$": "$.sql_output.Id", }, resultPath: "$.sql_output", }); const definition = batchExecuteStatement .next(wait) .next(describeStatement) .next(new sfn.Choice(this, "check status") .when(sfn.Condition.stringEquals("$.sql_output.Status", "FAILED"), new sfn.Fail(this, "failure")) .when(sfn.Condition.stringEquals("$.sql_output.Status", "FINISHED"), new sfn.Succeed(this, "success")) .otherwise(wait)); ({ eventPattern: this.eventPattern, stateMachine: this.stateMachine } = this.createStateMachine({ definition: definition, ...props, })); this.stateMachine.addToRolePolicy(new iam.PolicyStatement({ effect: iam.Effect.ALLOW, actions: [ "redshift-data:BatchExecuteStatement", "redshift-data:ListStatements", "redshift-data:GetStatementResult", "redshift-data:DescribeStatement", "redshift-data:ExecuteStatement", ], resources: ["*"], })); this.stateMachine.addToRolePolicy(new iam.PolicyStatement({ effect: iam.Effect.ALLOW, actions: ["redshift:GetClusterCredentials"], resources: [redshiftClusterArn, redshiftDatabaseArn, redshiftUserArn], })); } } exports.RedshiftDataApiStage = RedshiftDataApiStage; _a = JSII_RTTI_SYMBOL_1; RedshiftDataApiStage[_a] = { fqn: "aws-ddk-core.RedshiftDataApiStage", version: "1.4.1" }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"redshift-data-api.js","sourceRoot":"","sources":["../../src/stages/redshift-data-api.ts"],"names":[],"mappings":"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","sourcesContent":["import * as cdk from \"aws-cdk-lib\";\nimport * as events from \"aws-cdk-lib/aws-events\";\nimport * as iam from \"aws-cdk-lib/aws-iam\";\nimport * as sfn from \"aws-cdk-lib/aws-stepfunctions\";\nimport * as tasks from \"aws-cdk-lib/aws-stepfunctions-tasks\";\nimport { Construct } from \"constructs\";\nimport { StateMachineStage, StateMachineStageProps } from \"../pipelines/stage\";\n\n/**\n * Properties for `RedshiftDataApiStage`.\n */\nexport interface RedshiftDataApiStageProps extends StateMachineStageProps {\n  /**\n   * Identifier of the Redshift cluster.\n   */\n  readonly redshiftClusterIdentifier: string;\n  /**\n   * List of SQL statements to execute.\n   */\n  readonly sqlStatements: string[];\n  /**\n   * Name of the database in Redshift.\n   *\n   * @default \"dev\"\n   */\n  readonly databaseName?: string;\n  /**\n   * Database user.\n   *\n   * @default \"awsuser\"\n   */\n  readonly databaseUser?: string;\n  /**\n   * Waiting time between checking whether the statements have finished executing.\n   *\n   * @default cdk.Duration.seconds(15)\n   */\n  readonly pollingTime?: cdk.Duration;\n}\n\n/**\n * Stage that contains a step function that executes Redshift Data API statements.\n */\nexport class RedshiftDataApiStage extends StateMachineStage {\n  readonly targets?: events.IRuleTarget[];\n  readonly eventPattern?: events.EventPattern;\n  readonly stateMachine: sfn.StateMachine;\n  readonly stateMachineInput?: { [key: string]: any };\n  readonly eventBridgeEventPath?: string;\n\n  /**\n   * Constructs `RedshiftDataApiStage`.\n   * @param scope Scope within which this construct is defined.\n   * @param id Identifier of the stage.\n   * @param props Properties for the stage.\n   */\n  constructor(scope: Construct, id: string, props: RedshiftDataApiStageProps) {\n    super(scope, id, props);\n\n    this.stateMachineInput = props.stateMachineInput;\n    const stack = cdk.Stack.of(this);\n    const databaseName = props.databaseName ?? \"dev\";\n    const databaseUser = props.databaseUser ?? \"awsuser\";\n    const redshiftClusterArn = `arn:aws:redshift:${stack.region}:${stack.account}:cluster:${props.redshiftClusterIdentifier}`;\n    const redshiftDatabaseArn = `arn:aws:redshift:${stack.region}:${stack.account}:dbname:${props.redshiftClusterIdentifier}/${databaseName}`;\n    const redshiftUserArn = `arn:aws:redshift:${stack.region}:${stack.account}:dbuser:${props.redshiftClusterIdentifier}/${databaseUser}`;\n    const pollingTime = props.pollingTime ?? cdk.Duration.seconds(15);\n\n    const batchExecuteStatement = new tasks.CallAwsService(this, `${id} Execute Statement on Redshift`, {\n      service: \"redshiftdata\",\n      action: \"batchExecuteStatement\",\n      iamResources: [redshiftClusterArn],\n      parameters: {\n        ClusterIdentifier: props.redshiftClusterIdentifier,\n        Database: databaseName,\n        Sqls: props.sqlStatements,\n        DbUser: databaseUser,\n      },\n      resultPath: \"$.sql_output\",\n    });\n    const wait = new sfn.Wait(this, \"wait\", {\n      time: sfn.WaitTime.duration(pollingTime),\n    });\n\n    const describeStatement = new tasks.CallAwsService(this, `${id} Describe Statement on Redshift`, {\n      service: \"redshiftdata\",\n      action: \"describeStatement\",\n      iamResources: [redshiftClusterArn],\n      parameters: {\n        \"Id.$\": \"$.sql_output.Id\",\n      },\n      resultPath: \"$.sql_output\",\n    });\n\n    const definition = batchExecuteStatement\n      .next(wait)\n      .next(describeStatement)\n      .next(\n        new sfn.Choice(this, \"check status\")\n          .when(sfn.Condition.stringEquals(\"$.sql_output.Status\", \"FAILED\"), new sfn.Fail(this, \"failure\"))\n          .when(sfn.Condition.stringEquals(\"$.sql_output.Status\", \"FINISHED\"), new sfn.Succeed(this, \"success\"))\n          .otherwise(wait),\n      );\n\n    ({ eventPattern: this.eventPattern, stateMachine: this.stateMachine } = this.createStateMachine({\n      definition: definition,\n      ...props,\n    }));\n    this.stateMachine.addToRolePolicy(\n      new iam.PolicyStatement({\n        effect: iam.Effect.ALLOW,\n        actions: [\n          \"redshift-data:BatchExecuteStatement\",\n          \"redshift-data:ListStatements\",\n          \"redshift-data:GetStatementResult\",\n          \"redshift-data:DescribeStatement\",\n          \"redshift-data:ExecuteStatement\",\n        ],\n        resources: [\"*\"],\n      }),\n    );\n    this.stateMachine.addToRolePolicy(\n      new iam.PolicyStatement({\n        effect: iam.Effect.ALLOW,\n        actions: [\"redshift:GetClusterCredentials\"],\n        resources: [redshiftClusterArn, redshiftDatabaseArn, redshiftUserArn],\n      }),\n    );\n  }\n}\n"]}