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.
196 lines • 24.2 kB
JavaScript
var _a, _b, _c, _d;
Object.defineProperty(exports, "__esModule", { value: true });
exports.EventStage = exports.StateMachineStage = exports.DataStage = exports.Stage = void 0;
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
const cloudwatch = require("aws-cdk-lib/aws-cloudwatch");
const events = require("aws-cdk-lib/aws-events");
const events_targets = require("aws-cdk-lib/aws-events-targets");
const sfn = require("aws-cdk-lib/aws-stepfunctions");
const constructs_1 = require("constructs");
/**
* Abstract class representing a stage.
*/
class Stage extends constructs_1.Construct {
/**
* Constructs the stage.
* @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);
this.name = props.name;
this.description = props.description;
}
}
exports.Stage = Stage;
_a = JSII_RTTI_SYMBOL_1;
Stage[_a] = { fqn: "aws-ddk-core.Stage", version: "1.4.1" };
/**
* Class that represents a data stage within a data pipeline.
*
* To create a DataStage, inherit from this class, add infrastructure required by the stage,
* and implement `eventPatterns` and `targets` properties.
*
* @example
* class MyStage extends DataStage:
* readonly queue: sqs.Queue;
*
* constructor(scope: Construct, id: string, props: MyStageProps) {
* super(scope, id, props);
*
* this.queue = sqs.Queue(this, "Queue");
*
* this.eventPatterns = {
* detail_type: ["my-detail-type"],
* };
* this.targets = [new events_targets.SqsQueue(this.queue)];
* }
*/
class DataStage extends Stage {
/**
* Constructs the stage.
* @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.alarmsEnabled = props.alarmsEnabled ?? true;
this.cloudwatchAlarms = [];
}
/**
* Add a CloudWatch alarm for the DataStage.
* @param id Identifier of the CloudWatch Alarm.
* @param props Properties for the alarm.
* @returns this DataStage.
*/
addAlarm(id, props) {
if (this.alarmsEnabled) {
this.cloudwatchAlarms.push(new cloudwatch.Alarm(this, id, {
metric: props.metric,
comparisonOperator: props.comparisonOperator ?? cloudwatch.ComparisonOperator.GREATER_THAN_THRESHOLD,
threshold: props.threshold ?? 1,
evaluationPeriods: props.evaluationPeriods ?? 1,
}));
}
return this;
}
}
exports.DataStage = DataStage;
_b = JSII_RTTI_SYMBOL_1;
DataStage[_b] = { fqn: "aws-ddk-core.DataStage", version: "1.4.1" };
function getDefinitionBody(definition, definitionFile) {
if (definition && definitionFile) {
throw new Error("Only one of 'definition' or 'definitionFile' should be provided.");
}
if (!definition && !definitionFile) {
throw new Error("One of 'definition' or 'definitionFile' must be provided.");
}
if (definitionFile) {
return sfn.DefinitionBody.fromFile(definitionFile, {});
}
else {
if (typeof definition == "string") {
return sfn.DefinitionBody.fromString(definition);
}
if (definition) {
return sfn.DefinitionBody.fromChainable(definition);
}
}
throw new Error("Not able to create a definition body.");
}
/**
* DataStage with helper methods to simplify StateMachine stages creation.
*/
class StateMachineStage extends DataStage {
/**
* Constructs state machine stage.
* @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);
}
/**
* Constructs a state machine from the definition.
* @param props State machine stage properties.
* @returns Dictionary with event pattern, targets and state machine construct.
*/
createStateMachine(props) {
const stateMachine = new sfn.StateMachine(this, "State Machine", {
definitionBody: getDefinitionBody(props.definition, props.definitionFile),
stateMachineName: props.stateMachineName,
});
if (props.additionalRolePolicyStatements) {
props.additionalRolePolicyStatements.forEach((s) => {
stateMachine.addToRolePolicy(s);
});
}
this.addAlarm("State Machine Failure Alarm", {
metric: stateMachine.metricFailed(),
threshold: props.stateMachineFailedExecutionsAlarmThreshold,
evaluationPeriods: props.stateMachineFailedExecutionsAlarmEvaluationPeriods,
});
const stateMachineInput = props.stateMachineInput;
const eventPattern = {
source: ["aws.states"],
detailType: ["Step Functions Execution Status Change"],
detail: {
status: ["SUCCEEDED"],
stateMachineArn: [stateMachine.stateMachineArn],
},
};
const targets = [
new events_targets.SfnStateMachine(stateMachine, {
input: events.RuleTargetInput.fromObject(stateMachineInput),
}),
];
return {
eventPattern,
targets,
stateMachine,
};
}
}
exports.StateMachineStage = StateMachineStage;
_c = JSII_RTTI_SYMBOL_1;
StateMachineStage[_c] = { fqn: "aws-ddk-core.StateMachineStage", version: "1.4.1" };
/**
* Class that represents an event stage within a data pipeline.
*
* To create an EventStage, inherit from this class, add infrastructure required by the stage,
* and implement the `eventPattern` property.
*
* The `targets` property will be set to null.
*
* @example
* class MyStage extends EventStage:
* constructor(scope: Construct, id: string, props: MyStageProps) {
* super(scope, id, props);
*
* this.eventPatterns = {
* source: ["aws.s3"],
* detail: props.detail,
* detail_type: props.detail_type,
* };
* }
*/
class EventStage extends Stage {
/**
* Constructs event stage.
* @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.targets = undefined;
}
}
exports.EventStage = EventStage;
_d = JSII_RTTI_SYMBOL_1;
EventStage[_d] = { fqn: "aws-ddk-core.EventStage", version: "1.4.1" };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"stage.js","sourceRoot":"","sources":["../../src/pipelines/stage.ts"],"names":[],"mappings":"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","sourcesContent":["import * as cloudwatch from \"aws-cdk-lib/aws-cloudwatch\";\nimport * as events from \"aws-cdk-lib/aws-events\";\nimport * as events_targets from \"aws-cdk-lib/aws-events-targets\";\nimport * as iam from \"aws-cdk-lib/aws-iam\";\nimport * as sfn from \"aws-cdk-lib/aws-stepfunctions\";\nimport { Construct } from \"constructs\";\n\n/**\n * Properties for the base abstract stage.\n */\nexport interface StageProps {\n  /**\n   * Name of the stage.\n   */\n  readonly name?: string;\n  /**\n   * Description of the stage.\n   */\n  readonly description?: string;\n}\n\n/**\n * Abstract class representing a stage.\n */\nexport abstract class Stage extends Construct {\n  /**\n   * Name of the stage.\n   */\n  public readonly name?: string;\n  /**\n   * Description of the stage.\n   */\n  public readonly description?: string;\n\n  /**\n   * Input targets for the stage.\n   *\n   * Targets are used by Event Rules to describe what should be invoked when a rule matches an event.\n   */\n  abstract readonly targets?: events.IRuleTarget[];\n  /**\n   * Output event pattern of the stage.\n   *\n   * Event pattern describes the structure of output event(s) produced by this stage.\n   * Event Rules use event patterns to select events and route them to targets.\n   */\n  abstract readonly eventPattern?: events.EventPattern;\n\n  /**\n   * Constructs the stage.\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: StageProps) {\n    super(scope, id);\n\n    this.name = props.name;\n    this.description = props.description;\n  }\n}\n\n/**\n * Properties for the `DataStage`.\n */\nexport interface DataStageProps extends StageProps {\n  /**\n   * Enable/Disable all alarms in a DataStage.\n   *\n   * @default true\n   */\n  readonly alarmsEnabled?: boolean;\n}\n\n/**\n * Properties for the alarm being added to the DataStage.\n */\nexport interface AlarmProps {\n  /**\n   * Metric to use for creating the stage's CloudWatch Alarm.\n   */\n  readonly metric: cloudwatch.IMetric;\n  /**\n   * Comparison operator to use for alarm.\n   *\n   * @default GREATER_THAN_THRESHOLD\n   */\n  readonly comparisonOperator?: cloudwatch.ComparisonOperator;\n  /**\n   * The value against which the specified alarm statistic is compared.\n   * @default 5\n   */\n  readonly evaluationPeriods?: number;\n  /**\n   * The number of periods over which data is compared to the specified threshold.\n   * @default 1\n   */\n  readonly threshold?: number;\n}\n\n/**\n * Class that represents a data stage within a data pipeline.\n *\n * To create a DataStage, inherit from this class, add infrastructure required by the stage,\n * and implement `eventPatterns` and `targets` properties.\n *\n * @example\n * class MyStage extends DataStage:\n *   readonly queue: sqs.Queue;\n *\n *   constructor(scope: Construct, id: string, props: MyStageProps) {\n *      super(scope, id, props);\n *\n *      this.queue = sqs.Queue(this, \"Queue\");\n *\n *      this.eventPatterns = {\n *        detail_type: [\"my-detail-type\"],\n *      };\n *      this.targets = [new events_targets.SqsQueue(this.queue)];\n *   }\n */\nexport abstract class DataStage extends Stage {\n  /**\n   * List of CloudWatch Alarms linked to the stage.\n   */\n  readonly cloudwatchAlarms: cloudwatch.Alarm[];\n  /**\n   * Flag indicating whether the alarms are enabled for this stage.\n   */\n  readonly alarmsEnabled: boolean;\n\n  /**\n   * Constructs the stage.\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: DataStageProps) {\n    super(scope, id, props);\n\n    this.alarmsEnabled = props.alarmsEnabled ?? true;\n    this.cloudwatchAlarms = [];\n  }\n\n  /**\n   * Add a CloudWatch alarm for the DataStage.\n   * @param id Identifier of the CloudWatch Alarm.\n   * @param props Properties for the alarm.\n   * @returns this DataStage.\n   */\n  addAlarm(id: string, props: AlarmProps): DataStage {\n    if (this.alarmsEnabled) {\n      this.cloudwatchAlarms.push(\n        new cloudwatch.Alarm(this, id, {\n          metric: props.metric,\n          comparisonOperator: props.comparisonOperator ?? cloudwatch.ComparisonOperator.GREATER_THAN_THRESHOLD,\n          threshold: props.threshold ?? 1,\n          evaluationPeriods: props.evaluationPeriods ?? 1,\n        }),\n      );\n    }\n    return this;\n  }\n}\n\nfunction getDefinitionBody(definition?: sfn.IChainable | string, definitionFile?: string): sfn.DefinitionBody {\n  if (definition && definitionFile) {\n    throw new Error(\"Only one of 'definition' or 'definitionFile' should be provided.\");\n  }\n  if (!definition && !definitionFile) {\n    throw new Error(\"One of 'definition' or 'definitionFile' must be provided.\");\n  }\n\n  if (definitionFile) {\n    return sfn.DefinitionBody.fromFile(definitionFile, {});\n  } else {\n    if (typeof definition == \"string\") {\n      return sfn.DefinitionBody.fromString(definition);\n    }\n    if (definition) {\n      return sfn.DefinitionBody.fromChainable(definition);\n    }\n  }\n  throw new Error(\"Not able to create a definition body.\");\n}\n\n/**\n * Properties of a state machine stage.\n */\nexport interface StateMachineStageProps extends StageProps {\n  /**\n   * Steps for the state machine.\n   * Can either be provided as 'sfn.IChainable' or a JSON string.\n   */\n  readonly definition?: sfn.IChainable | string;\n  /**\n   * File containing a JSON definition for the state machine.\n   */\n  readonly definitionFile?: string;\n  /**\n   * Input of the state machine.\n   */\n  readonly stateMachineInput?: { [key: string]: any };\n  /**\n   * Name of the state machine.\n   */\n  readonly stateMachineName?: string;\n  /**\n   * Additional IAM policy statements to add to the state machine role.\n   */\n  readonly additionalRolePolicyStatements?: iam.PolicyStatement[];\n  /**\n   * The number of failed state machine executions before triggering CW alarm.\n   * @default 1\n   */\n  readonly stateMachineFailedExecutionsAlarmThreshold?: number;\n  /**\n   * The number of periods over which data is compared to the specified threshold.\n   * @default 1\n   */\n  readonly stateMachineFailedExecutionsAlarmEvaluationPeriods?: number;\n  /**\n   * Enable/Disable all alarms in the stage.\n   * @default true\n   */\n  readonly alarmsEnabled?: boolean;\n}\n\nexport interface CreateStateMachineResult {\n  readonly eventPattern: events.EventPattern;\n  readonly targets: events.IRuleTarget[];\n  readonly stateMachine: sfn.StateMachine;\n}\n\n/**\n * DataStage with helper methods to simplify StateMachine stages creation.\n */\nexport abstract class StateMachineStage extends DataStage {\n  /**\n   * State machine.\n   */\n  abstract readonly stateMachine: sfn.StateMachine;\n\n  /**\n   * Constructs state machine stage.\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: StateMachineStageProps) {\n    super(scope, id, props);\n  }\n\n  /**\n   * Constructs a state machine from the definition.\n   * @param props State machine stage properties.\n   * @returns Dictionary with event pattern, targets and state machine construct.\n   */\n  protected createStateMachine(props: StateMachineStageProps): CreateStateMachineResult {\n    const stateMachine = new sfn.StateMachine(this, \"State Machine\", {\n      definitionBody: getDefinitionBody(props.definition, props.definitionFile),\n      stateMachineName: props.stateMachineName,\n    });\n\n    if (props.additionalRolePolicyStatements) {\n      props.additionalRolePolicyStatements.forEach((s) => {\n        stateMachine.addToRolePolicy(s);\n      });\n    }\n\n    this.addAlarm(\"State Machine Failure Alarm\", {\n      metric: stateMachine.metricFailed(),\n      threshold: props.stateMachineFailedExecutionsAlarmThreshold,\n      evaluationPeriods: props.stateMachineFailedExecutionsAlarmEvaluationPeriods,\n    });\n\n    const stateMachineInput = props.stateMachineInput;\n    const eventPattern = {\n      source: [\"aws.states\"],\n      detailType: [\"Step Functions Execution Status Change\"],\n      detail: {\n        status: [\"SUCCEEDED\"],\n        stateMachineArn: [stateMachine.stateMachineArn],\n      },\n    };\n    const targets = [\n      new events_targets.SfnStateMachine(stateMachine, {\n        input: events.RuleTargetInput.fromObject(stateMachineInput),\n      }),\n    ];\n\n    return {\n      eventPattern,\n      targets,\n      stateMachine,\n    };\n  }\n}\n\n/**\n * Properties for the event stage.\n */\nexport interface EventStageProps extends StageProps {}\n\n/**\n * Class that represents an event stage within a data pipeline.\n *\n * To create an EventStage, inherit from this class, add infrastructure required by the stage,\n * and implement the `eventPattern` property.\n *\n * The `targets` property will be set to null.\n *\n * @example\n * class MyStage extends EventStage:\n *   constructor(scope: Construct, id: string, props: MyStageProps) {\n *      super(scope, id, props);\n *\n *      this.eventPatterns = {\n *        source: [\"aws.s3\"],\n *        detail: props.detail,\n *        detail_type: props.detail_type,\n *      };\n *   }\n */\nexport abstract class EventStage extends Stage {\n  readonly targets?: events.IRuleTarget[];\n\n  /**\n   * Constructs event stage.\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: EventStageProps) {\n    super(scope, id, props);\n\n    this.targets = undefined;\n  }\n}\n"]}
;