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.

91 lines 14 kB
"use strict"; var _a; Object.defineProperty(exports, "__esModule", { value: true }); exports.AthenaSQLStage = void 0; const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti"); const events = require("aws-cdk-lib/aws-events"); const eventsTargets = require("aws-cdk-lib/aws-events-targets"); 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 execute Athena SQL query. */ class AthenaSQLStage extends stage_1.StateMachineStage { /** * Constructs `AthenaSQLStage`. * @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; if (props.queryString && props.queryStringPath) { throw TypeError("For this stage provide one of queryString or queryStringPath parameter, not both"); } const queryStringInput = props.queryStringPath ? sfn.JsonPath.stringAt(props.queryStringPath) : props.queryString; if (!queryStringInput) { throw TypeError("For this stage one of queryString or queryStringPath parameter is required"); } var cnt = 0; if (props.queryString) { if (props.parallel) { var athenaQueryExec = new sfn.Parallel(this, "All Jobs"); for (var query of queryStringInput) { const addStep = this.getAthenaStartQueryExecutionStep(query, props, cnt); var athenaQueryExec = athenaQueryExec.branch(addStep); cnt = cnt + 1; } } else { var athenaQueryExec = undefined; for (var query of queryStringInput) { const addStep = this.getAthenaStartQueryExecutionStep(query, props, cnt); var athenaQueryExec = athenaQueryExec ? athenaQueryExec.next(addStep) : addStep; cnt = cnt + 1; } } } else { var athenaQueryExec = this.getAthenaStartQueryExecutionStep(queryStringInput, props, cnt); } const definition = athenaQueryExec.next(new sfn.Succeed(this, "Success")); ({ eventPattern: this.eventPattern, stateMachine: this.stateMachine } = this.createStateMachine({ definition: definition, ...props, })); this.targets = [ new eventsTargets.SfnStateMachine(this.stateMachine, { input: props.queryString ? events.RuleTargetInput.fromObject(this.stateMachineInput) : events.RuleTargetInput.fromEventPath("$.detail"), }), ]; } getAthenaStartQueryExecutionStep(queryStringInput, props, cnt) { const encryptionOption = props.encryptionOption ?? tasks.EncryptionOption.S3_MANAGED; const encryptionKey = props.encryptionKey; const startQueryExec = new tasks.AthenaStartQueryExecution(this, `Query Exec ${cnt}`, { queryString: queryStringInput, integrationPattern: sfn.IntegrationPattern.RUN_JOB, queryExecutionContext: { catalogName: props.catalogName, databaseName: props.databaseName, }, resultConfiguration: { encryptionConfiguration: { encryptionOption: encryptionOption, encryptionKey: encryptionKey, }, outputLocation: props.outputLocation, }, workGroup: props.workGroup, }); return startQueryExec; } } exports.AthenaSQLStage = AthenaSQLStage; _a = JSII_RTTI_SYMBOL_1; AthenaSQLStage[_a] = { fqn: "aws-ddk-core.AthenaSQLStage", version: "1.4.1" }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"athena-sql.js","sourceRoot":"","sources":["../../src/stages/athena-sql.ts"],"names":[],"mappings":"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","sourcesContent":["import * as events from \"aws-cdk-lib/aws-events\";\nimport * as eventsTargets from \"aws-cdk-lib/aws-events-targets\";\nimport * as kms from \"aws-cdk-lib/aws-kms\";\nimport * as s3 from \"aws-cdk-lib/aws-s3\";\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 `AthenaSQLStage`.\n */\nexport interface AthenaToSQLStageProps extends StateMachineStageProps {\n  /**\n   * SQL queries that will be started.\n   */\n  readonly queryString?: Array<string>;\n  /**\n   * dynamic path in statemachine for SQL query to be started.\n   */\n  readonly queryStringPath?: string;\n  /**\n   * flag to determine parallel or sequential execution\n   * @default false\n   */\n  readonly parallel?: boolean;\n  /**\n   * Athena workgroup name.\n   */\n  readonly workGroup?: string;\n  /**\n   * Catalog name.\n   */\n  readonly catalogName?: string;\n  /**\n   * Database name.\n   */\n  readonly databaseName?: string;\n  /**\n   * Output S3 location\n   */\n  readonly outputLocation?: s3.Location;\n  /**\n   * Encryption KMS key.\n   */\n  readonly encryptionKey?: kms.Key;\n  /**\n   * Encryption configuration.\n   */\n  readonly encryptionOption?: tasks.EncryptionOption;\n}\n\n/**\n * Stage that contains a step function that execute Athena SQL query.\n */\nexport class AthenaSQLStage 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 `AthenaSQLStage`.\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: AthenaToSQLStageProps) {\n    super(scope, id, props);\n\n    this.stateMachineInput = props.stateMachineInput;\n\n    if (props.queryString && props.queryStringPath) {\n      throw TypeError(\"For this stage provide one of queryString or queryStringPath parameter, not both\");\n    }\n    const queryStringInput = props.queryStringPath ? sfn.JsonPath.stringAt(props.queryStringPath) : props.queryString;\n    if (!queryStringInput) {\n      throw TypeError(\"For this stage one of queryString or queryStringPath parameter is required\");\n    }\n\n    var cnt = 0;\n    if (props.queryString) {\n      if (props.parallel) {\n        var athenaQueryExec: any = new sfn.Parallel(this, \"All Jobs\");\n        for (var query of queryStringInput) {\n          const addStep = this.getAthenaStartQueryExecutionStep(query, props, cnt);\n          var athenaQueryExec = athenaQueryExec.branch(addStep);\n          cnt = cnt + 1;\n        }\n      } else {\n        var athenaQueryExec: any = undefined;\n        for (var query of queryStringInput) {\n          const addStep = this.getAthenaStartQueryExecutionStep(query, props, cnt);\n          var athenaQueryExec = athenaQueryExec ? athenaQueryExec.next(addStep) : addStep;\n          cnt = cnt + 1;\n        }\n      }\n    } else {\n      var athenaQueryExec: any = this.getAthenaStartQueryExecutionStep(queryStringInput, props, cnt);\n    }\n\n    const definition = athenaQueryExec.next(new sfn.Succeed(this, \"Success\"));\n\n    ({ eventPattern: this.eventPattern, stateMachine: this.stateMachine } = this.createStateMachine({\n      definition: definition,\n      ...props,\n    }));\n    this.targets = [\n      new eventsTargets.SfnStateMachine(this.stateMachine, {\n        input: props.queryString\n          ? events.RuleTargetInput.fromObject(this.stateMachineInput)\n          : events.RuleTargetInput.fromEventPath(\"$.detail\"),\n      }),\n    ];\n  }\n\n  private getAthenaStartQueryExecutionStep(\n    queryStringInput: any,\n    props: AthenaToSQLStageProps,\n    cnt: number,\n  ): tasks.AthenaStartQueryExecution {\n    const encryptionOption = props.encryptionOption ?? tasks.EncryptionOption.S3_MANAGED;\n    const encryptionKey = props.encryptionKey;\n    const startQueryExec = new tasks.AthenaStartQueryExecution(this, `Query Exec ${cnt}`, {\n      queryString: queryStringInput,\n      integrationPattern: sfn.IntegrationPattern.RUN_JOB,\n      queryExecutionContext: {\n        catalogName: props.catalogName,\n        databaseName: props.databaseName,\n      },\n      resultConfiguration: {\n        encryptionConfiguration: {\n          encryptionOption: encryptionOption,\n          encryptionKey: encryptionKey,\n        },\n        outputLocation: props.outputLocation,\n      },\n      workGroup: props.workGroup,\n    });\n\n    return startQueryExec;\n  }\n}\n"]}