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
JavaScript
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"]}
;