UNPKG

40.9 kBJavaScriptView Raw
1"use strict";
2var _a, _b;
3Object.defineProperty(exports, "__esModule", { value: true });
4exports.PipelineNotificationEvents = exports.Action = exports.GlobalVariables = exports.ActionCategory = void 0;
5const jsiiDeprecationWarnings = require("../.warnings.jsii.js");
6const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
7const events = require("@aws-cdk/aws-events");
8const core_1 = require("@aws-cdk/core");
9var ActionCategory;
10(function (ActionCategory) {
11 ActionCategory["SOURCE"] = "Source";
12 ActionCategory["BUILD"] = "Build";
13 ActionCategory["TEST"] = "Test";
14 ActionCategory["APPROVAL"] = "Approval";
15 ActionCategory["DEPLOY"] = "Deploy";
16 ActionCategory["INVOKE"] = "Invoke";
17})(ActionCategory = exports.ActionCategory || (exports.ActionCategory = {}));
18/**
19 * The CodePipeline variables that are global,
20 * not bound to a specific action.
21 * This class defines a bunch of static fields that represent the different variables.
22 * These can be used can be used in any action configuration.
23 */
24class GlobalVariables {
25}
26exports.GlobalVariables = GlobalVariables;
27_a = JSII_RTTI_SYMBOL_1;
28GlobalVariables[_a] = { fqn: "@aws-cdk/aws-codepipeline.GlobalVariables", version: "1.156.1" };
29/** The identifier of the current pipeline execution. */
30GlobalVariables.executionId = '#{codepipeline.PipelineExecutionId}';
31/**
32 * Low-level class for generic CodePipeline Actions implementing the {@link IAction} interface.
33 * Contains some common logic that can be re-used by all {@link IAction} implementations.
34 * If you're writing your own Action class,
35 * feel free to extend this class.
36 */
37class Action {
38 constructor() {
39 this._variableReferenced = false;
40 this._namespaceToken = core_1.Lazy.string({
41 produce: () => {
42 // make sure the action was bound (= added to a pipeline)
43 if (this._actualNamespace === undefined) {
44 throw new Error(`Cannot reference variables of action '${this.actionProperties.actionName}', ` +
45 'as that action was never added to a pipeline');
46 }
47 else {
48 return this._customerProvidedNamespace !== undefined
49 // if a customer passed a namespace explicitly, always use that
50 ? this._customerProvidedNamespace
51 // otherwise, only return a namespace if any variable was referenced
52 : (this._variableReferenced ? this._actualNamespace : undefined);
53 }
54 },
55 });
56 }
57 get actionProperties() {
58 if (this.__actionProperties === undefined) {
59 const actionProperties = this.providedActionProperties;
60 this._customerProvidedNamespace = actionProperties.variablesNamespace;
61 this.__actionProperties = {
62 ...actionProperties,
63 variablesNamespace: this._customerProvidedNamespace === undefined
64 ? this._namespaceToken
65 : this._customerProvidedNamespace,
66 };
67 }
68 return this.__actionProperties;
69 }
70 bind(scope, stage, options) {
71 try {
72 jsiiDeprecationWarnings._aws_cdk_aws_codepipeline_IStage(stage);
73 jsiiDeprecationWarnings._aws_cdk_aws_codepipeline_ActionBindOptions(options);
74 }
75 catch (error) {
76 if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
77 Error.captureStackTrace(error, this.bind);
78 }
79 throw error;
80 }
81 this.__pipeline = stage.pipeline;
82 this.__stage = stage;
83 this.__scope = scope;
84 this._actualNamespace = this._customerProvidedNamespace === undefined
85 // default a namespace name, based on the stage and action names
86 ? `${stage.stageName}_${this.actionProperties.actionName}_NS`
87 : this._customerProvidedNamespace;
88 return this.bound(scope, stage, options);
89 }
90 onStateChange(name, target, options) {
91 const rule = new events.Rule(this._scope, name, options);
92 rule.addTarget(target);
93 rule.addEventPattern({
94 detailType: ['CodePipeline Action Execution State Change'],
95 source: ['aws.codepipeline'],
96 resources: [this._pipeline.pipelineArn],
97 detail: {
98 stage: [this._stage.stageName],
99 action: [this.actionProperties.actionName],
100 },
101 });
102 return rule;
103 }
104 variableExpression(variableName) {
105 this._variableReferenced = true;
106 return `#{${this._namespaceToken}.${variableName}}`;
107 }
108 get _pipeline() {
109 if (this.__pipeline) {
110 return this.__pipeline;
111 }
112 else {
113 throw new Error('Action must be added to a stage that is part of a pipeline before using onStateChange');
114 }
115 }
116 get _stage() {
117 if (this.__stage) {
118 return this.__stage;
119 }
120 else {
121 throw new Error('Action must be added to a stage that is part of a pipeline before using onStateChange');
122 }
123 }
124 /**
125 * Retrieves the Construct scope of this Action.
126 * Only available after the Action has been added to a Stage,
127 * and that Stage to a Pipeline.
128 */
129 get _scope() {
130 if (this.__scope) {
131 return this.__scope;
132 }
133 else {
134 throw new Error('Action must be added to a stage that is part of a pipeline first');
135 }
136 }
137}
138exports.Action = Action;
139_b = JSII_RTTI_SYMBOL_1;
140Action[_b] = { fqn: "@aws-cdk/aws-codepipeline.Action", version: "1.156.1" };
141/**
142 * The list of event types for AWS Codepipeline Pipeline
143 * @see https://docs.aws.amazon.com/dtconsole/latest/userguide/concepts.html#events-ref-pipeline
144 */
145var PipelineNotificationEvents;
146(function (PipelineNotificationEvents) {
147 /**
148 * Trigger notification when pipeline execution failed
149 */
150 PipelineNotificationEvents["PIPELINE_EXECUTION_FAILED"] = "codepipeline-pipeline-pipeline-execution-failed";
151 /**
152 * Trigger notification when pipeline execution canceled
153 */
154 PipelineNotificationEvents["PIPELINE_EXECUTION_CANCELED"] = "codepipeline-pipeline-pipeline-execution-canceled";
155 /**
156 * Trigger notification when pipeline execution started
157 */
158 PipelineNotificationEvents["PIPELINE_EXECUTION_STARTED"] = "codepipeline-pipeline-pipeline-execution-started";
159 /**
160 * Trigger notification when pipeline execution resumed
161 */
162 PipelineNotificationEvents["PIPELINE_EXECUTION_RESUMED"] = "codepipeline-pipeline-pipeline-execution-resumed";
163 /**
164 * Trigger notification when pipeline execution succeeded
165 */
166 PipelineNotificationEvents["PIPELINE_EXECUTION_SUCCEEDED"] = "codepipeline-pipeline-pipeline-execution-succeeded";
167 /**
168 * Trigger notification when pipeline execution superseded
169 */
170 PipelineNotificationEvents["PIPELINE_EXECUTION_SUPERSEDED"] = "codepipeline-pipeline-pipeline-execution-superseded";
171 /**
172 * Trigger notification when pipeline stage execution started
173 */
174 PipelineNotificationEvents["STAGE_EXECUTION_STARTED"] = "codepipeline-pipeline-stage-execution-started";
175 /**
176 * Trigger notification when pipeline stage execution succeeded
177 */
178 PipelineNotificationEvents["STAGE_EXECUTION_SUCCEEDED"] = "codepipeline-pipeline-stage-execution-succeeded";
179 /**
180 * Trigger notification when pipeline stage execution resumed
181 */
182 PipelineNotificationEvents["STAGE_EXECUTION_RESUMED"] = "codepipeline-pipeline-stage-execution-resumed";
183 /**
184 * Trigger notification when pipeline stage execution canceled
185 */
186 PipelineNotificationEvents["STAGE_EXECUTION_CANCELED"] = "codepipeline-pipeline-stage-execution-canceled";
187 /**
188 * Trigger notification when pipeline stage execution failed
189 */
190 PipelineNotificationEvents["STAGE_EXECUTION_FAILED"] = "codepipeline-pipeline-stage-execution-failed";
191 /**
192 * Trigger notification when pipeline action execution succeeded
193 */
194 PipelineNotificationEvents["ACTION_EXECUTION_SUCCEEDED"] = "codepipeline-pipeline-action-execution-succeeded";
195 /**
196 * Trigger notification when pipeline action execution failed
197 */
198 PipelineNotificationEvents["ACTION_EXECUTION_FAILED"] = "codepipeline-pipeline-action-execution-failed";
199 /**
200 * Trigger notification when pipeline action execution canceled
201 */
202 PipelineNotificationEvents["ACTION_EXECUTION_CANCELED"] = "codepipeline-pipeline-action-execution-canceled";
203 /**
204 * Trigger notification when pipeline action execution started
205 */
206 PipelineNotificationEvents["ACTION_EXECUTION_STARTED"] = "codepipeline-pipeline-action-execution-started";
207 /**
208 * Trigger notification when pipeline manual approval failed
209 */
210 PipelineNotificationEvents["MANUAL_APPROVAL_FAILED"] = "codepipeline-pipeline-manual-approval-failed";
211 /**
212 * Trigger notification when pipeline manual approval needed
213 */
214 PipelineNotificationEvents["MANUAL_APPROVAL_NEEDED"] = "codepipeline-pipeline-manual-approval-needed";
215 /**
216 * Trigger notification when pipeline manual approval succeeded
217 */
218 PipelineNotificationEvents["MANUAL_APPROVAL_SUCCEEDED"] = "codepipeline-pipeline-manual-approval-succeeded";
219})(PipelineNotificationEvents = exports.PipelineNotificationEvents || (exports.PipelineNotificationEvents = {}));
220//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"action.js","sourceRoot":"","sources":["action.ts"],"names":[],"mappings":";;;;;;AACA,8CAA8C;AAG9C,wCAAgD;AAOhD,IAAY,cAOX;AAPD,WAAY,cAAc;IACxB,mCAAiB,CAAA;IACjB,iCAAe,CAAA;IACf,+BAAa,CAAA;IACb,uCAAqB,CAAA;IACrB,mCAAiB,CAAA;IACjB,mCAAiB,CAAA;AACnB,CAAC,EAPW,cAAc,GAAd,sBAAc,KAAd,sBAAc,QAOzB;AAgBD;;;;;GAKG;AACH,MAAa,eAAe;;AAA5B,0CAGC;;;AAFC,wDAAwD;AACjC,2BAAW,GAAG,qCAAqC,CAAC;AAkT7E;;;;;GAKG;AACH,MAAsB,MAAM;IAgB1B;QAFQ,wBAAmB,GAAG,KAAK,CAAC;QAGlC,IAAI,CAAC,eAAe,GAAG,WAAI,CAAC,MAAM,CAAC;YACjC,OAAO,EAAE,GAAG,EAAE;gBACZ,yDAAyD;gBACzD,IAAI,IAAI,CAAC,gBAAgB,KAAK,SAAS,EAAE;oBACvC,MAAM,IAAI,KAAK,CAAC,yCAAyC,IAAI,CAAC,gBAAgB,CAAC,UAAU,KAAK;wBAC5F,8CAA8C,CAAC,CAAC;iBACnD;qBAAM;oBACL,OAAO,IAAI,CAAC,0BAA0B,KAAK,SAAS;wBAClD,+DAA+D;wBAC/D,CAAC,CAAC,IAAI,CAAC,0BAA0B;wBACjC,oEAAoE;wBACpE,CAAC,CAAC,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC;iBACpE;YACH,CAAC;SACF,CAAC,CAAC;KACJ;IAED,IAAW,gBAAgB;QACzB,IAAI,IAAI,CAAC,kBAAkB,KAAK,SAAS,EAAE;YACzC,MAAM,gBAAgB,GAAG,IAAI,CAAC,wBAAwB,CAAC;YACvD,IAAI,CAAC,0BAA0B,GAAG,gBAAgB,CAAC,kBAAkB,CAAC;YACtE,IAAI,CAAC,kBAAkB,GAAG;gBACxB,GAAG,gBAAgB;gBACnB,kBAAkB,EAAE,IAAI,CAAC,0BAA0B,KAAK,SAAS;oBAC/D,CAAC,CAAC,IAAI,CAAC,eAAe;oBACtB,CAAC,CAAC,IAAI,CAAC,0BAA0B;aACpC,CAAC;SACH;QACD,OAAO,IAAI,CAAC,kBAAkB,CAAC;KAChC;IAEM,IAAI,CAAC,KAAgB,EAAE,KAAa,EAAE,OAA0B;;;;;;;;;;;QACrE,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC,QAAQ,CAAC;QACjC,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;QACrB,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;QAErB,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,0BAA0B,KAAK,SAAS;YACnE,gEAAgE;YAChE,CAAC,CAAC,GAAG,KAAK,CAAC,SAAS,IAAI,IAAI,CAAC,gBAAgB,CAAC,UAAU,KAAK;YAC7D,CAAC,CAAC,IAAI,CAAC,0BAA0B,CAAC;QAEpC,OAAO,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,KAAK,EAAE,OAAO,CAAC,CAAC;KAC1C;IAEM,aAAa,CAAC,IAAY,EAAE,MAA2B,EAAE,OAA0B;QACxF,MAAM,IAAI,GAAG,IAAI,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,EAAE,OAAO,CAAC,CAAC;QACzD,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;QACvB,IAAI,CAAC,eAAe,CAAC;YACnB,UAAU,EAAE,CAAC,4CAA4C,CAAC;YAC1D,MAAM,EAAE,CAAC,kBAAkB,CAAC;YAC5B,SAAS,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC;YACvC,MAAM,EAAE;gBACN,KAAK,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC;gBAC9B,MAAM,EAAE,CAAC,IAAI,CAAC,gBAAgB,CAAC,UAAU,CAAC;aAC3C;SACF,CAAC,CAAC;QACH,OAAO,IAAI,CAAC;KACb;IAES,kBAAkB,CAAC,YAAoB;QAC/C,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC;QAChC,OAAO,KAAK,IAAI,CAAC,eAAe,IAAI,YAAY,GAAG,CAAC;KACrD;IAOD,IAAY,SAAS;QACnB,IAAI,IAAI,CAAC,UAAU,EAAE;YACnB,OAAO,IAAI,CAAC,UAAU,CAAC;SACxB;aAAM;YACL,MAAM,IAAI,KAAK,CAAC,uFAAuF,CAAC,CAAC;SAC1G;KACF;IAED,IAAY,MAAM;QAChB,IAAI,IAAI,CAAC,OAAO,EAAE;YAChB,OAAO,IAAI,CAAC,OAAO,CAAC;SACrB;aAAM;YACL,MAAM,IAAI,KAAK,CAAC,uFAAuF,CAAC,CAAC;SAC1G;KACF;IAED;;;;OAIG;IACH,IAAY,MAAM;QAChB,IAAI,IAAI,CAAC,OAAO,EAAE;YAChB,OAAO,IAAI,CAAC,OAAO,CAAC;SACrB;aAAM;YACL,MAAM,IAAI,KAAK,CAAC,kEAAkE,CAAC,CAAC;SACrF;KACF;;AAjHH,wBAkHC;;;AAED;;;GAGG;AACH,IAAY,0BA0FX;AA1FD,WAAY,0BAA0B;IACpC;;OAEG;IACH,2GAA6E,CAAA;IAE7E;;OAEG;IACH,+GAAiF,CAAA;IAEjF;;OAEG;IACH,6GAA+E,CAAA;IAE/E;;OAEG;IACH,6GAA+E,CAAA;IAE/E;;OAEG;IACH,iHAAmF,CAAA;IAEnF;;OAEG;IACH,mHAAqF,CAAA;IAErF;;OAEG;IACH,uGAAyE,CAAA;IAEzE;;MAEE;IACF,2GAA6E,CAAA;IAE7E;;MAEE;IACF,uGAAyE,CAAA;IAEzE;;MAEE;IACF,yGAA2E,CAAA;IAE3E;;MAEE;IACF,qGAAuE,CAAA;IAEvE;;OAEG;IACH,6GAA+E,CAAA;IAE/E;;OAEG;IACH,uGAAyE,CAAA;IAEzE;;OAEG;IACH,2GAA6E,CAAA;IAE7E;;OAEG;IACH,yGAA2E,CAAA;IAE3E;;OAEG;IACH,qGAAuE,CAAA;IAEvE;;OAEG;IACH,qGAAuE,CAAA;IAEvE;;OAEG;IACH,2GAA6E,CAAA;AAC/E,CAAC,EA1FW,0BAA0B,GAA1B,kCAA0B,KAA1B,kCAA0B,QA0FrC","sourcesContent":["import * as notifications from '@aws-cdk/aws-codestarnotifications';\nimport * as events from '@aws-cdk/aws-events';\nimport * as iam from '@aws-cdk/aws-iam';\nimport * as s3 from '@aws-cdk/aws-s3';\nimport { IResource, Lazy } from '@aws-cdk/core';\nimport { Artifact } from './artifact';\n\n// keep this import separate from other imports to reduce chance for merge conflicts with v2-main\n// eslint-disable-next-line no-duplicate-imports, import/order\nimport { Construct } from '@aws-cdk/core';\n\nexport enum ActionCategory {\n  SOURCE = 'Source',\n  BUILD = 'Build',\n  TEST = 'Test',\n  APPROVAL = 'Approval',\n  DEPLOY = 'Deploy',\n  INVOKE = 'Invoke'\n}\n\n/**\n * Specifies the constraints on the number of input and output\n * artifacts an action can have.\n *\n * The constraints for each action type are documented on the\n * {@link https://docs.aws.amazon.com/codepipeline/latest/userguide/reference-pipeline-structure.html Pipeline Structure Reference} page.\n */\nexport interface ActionArtifactBounds {\n  readonly minInputs: number;\n  readonly maxInputs: number;\n  readonly minOutputs: number;\n  readonly maxOutputs: number;\n}\n\n/**\n * The CodePipeline variables that are global,\n * not bound to a specific action.\n * This class defines a bunch of static fields that represent the different variables.\n * These can be used can be used in any action configuration.\n */\nexport class GlobalVariables {\n  /** The identifier of the current pipeline execution. */\n  public static readonly executionId = '#{codepipeline.PipelineExecutionId}';\n}\n\nexport interface ActionProperties {\n  readonly actionName: string;\n  readonly role?: iam.IRole;\n\n  /**\n   * The AWS region the given Action resides in.\n   * Note that a cross-region Pipeline requires replication buckets to function correctly.\n   * You can provide their names with the {@link PipelineProps#crossRegionReplicationBuckets} property.\n   * If you don't, the CodePipeline Construct will create new Stacks in your CDK app containing those buckets,\n   * that you will need to `cdk deploy` before deploying the main, Pipeline-containing Stack.\n   *\n   * @default the Action resides in the same region as the Pipeline\n   */\n  readonly region?: string;\n\n  /**\n   * The account the Action is supposed to live in.\n   * For Actions backed by resources,\n   * this is inferred from the Stack {@link resource} is part of.\n   * However, some Actions, like the CloudFormation ones,\n   * are not backed by any resource, and they still might want to be cross-account.\n   * In general, a concrete Action class should specify either {@link resource},\n   * or {@link account} - but not both.\n   */\n  readonly account?: string;\n\n  /**\n   * The optional resource that is backing this Action.\n   * This is used for automatically handling Actions backed by\n   * resources from a different account and/or region.\n   */\n  readonly resource?: IResource;\n\n  /**\n   * The category of the action.\n   * The category defines which action type the owner\n   * (the entity that performs the action) performs.\n   */\n  readonly category: ActionCategory;\n\n  /**\n   * The service provider that the action calls.\n   */\n  readonly provider: string;\n  readonly owner?: string;\n  readonly version?: string;\n\n  /**\n   * The order in which AWS CodePipeline runs this action.\n   * For more information, see the AWS CodePipeline User Guide.\n   *\n   * https://docs.aws.amazon.com/codepipeline/latest/userguide/reference-pipeline-structure.html#action-requirements\n   */\n  readonly runOrder?: number;\n  readonly artifactBounds: ActionArtifactBounds;\n  readonly inputs?: Artifact[];\n  readonly outputs?: Artifact[];\n\n  /**\n   * The name of the namespace to use for variables emitted by this action.\n   *\n   * @default - a name will be generated, based on the stage and action names\n   */\n  readonly variablesNamespace?: string;\n}\n\nexport interface ActionBindOptions {\n  readonly role: iam.IRole;\n\n  readonly bucket: s3.IBucket;\n}\n\nexport interface ActionConfig {\n  readonly configuration?: any;\n}\n\n/**\n * Additional options to pass to the notification rule.\n */\nexport interface PipelineNotifyOnOptions extends notifications.NotificationRuleOptions {\n  /**\n   * A list of event types associated with this notification rule for CodePipeline Pipeline.\n   * For a complete list of event types and IDs, see Notification concepts in the Developer Tools Console User Guide.\n   * @see https://docs.aws.amazon.com/dtconsole/latest/userguide/concepts.html#concepts-api\n   */\n  readonly events: PipelineNotificationEvents[];\n}\n\n/**\n * A Pipeline Action.\n * If you want to implement this interface,\n * consider extending the {@link Action} class,\n * which contains some common logic.\n */\nexport interface IAction {\n  /**\n   * The simple properties of the Action,\n   * like its Owner, name, etc.\n   * Note that this accessor will be called before the {@link bind} callback.\n   */\n  readonly actionProperties: ActionProperties;\n\n  /**\n   * The callback invoked when this Action is added to a Pipeline.\n   *\n   * @param scope the Construct tree scope the Action can use if it needs to create any resources\n   * @param stage the {@link IStage} this Action is being added to\n   * @param options additional options the Action can use,\n   *   like the artifact Bucket of the pipeline it's being added to\n   */\n  bind(scope: Construct, stage: IStage, options: ActionBindOptions): ActionConfig;\n\n  /**\n   * Creates an Event that will be triggered whenever the state of this Action changes.\n   *\n   * @param name the name to use for the new Event\n   * @param target the optional target for the Event\n   * @param options additional options that can be used to customize the created Event\n   */\n  onStateChange(name: string, target?: events.IRuleTarget, options?: events.RuleProps): events.Rule;\n}\n\n/**\n * The abstract view of an AWS CodePipeline as required and used by Actions.\n * It extends {@link events.IRuleTarget},\n * so this interface can be used as a Target for CloudWatch Events.\n */\nexport interface IPipeline extends IResource, notifications.INotificationRuleSource {\n  /**\n   * The name of the Pipeline.\n   *\n   * @attribute\n   */\n  readonly pipelineName: string;\n\n  /**\n   * The ARN of the Pipeline.\n   *\n   * @attribute\n   */\n  readonly pipelineArn: string;\n\n  /**\n   * Define an event rule triggered by this CodePipeline.\n   *\n   * @param id Identifier for this event handler.\n   * @param options Additional options to pass to the event rule.\n   */\n  onEvent(id: string, options?: events.OnEventOptions): events.Rule;\n\n  /**\n   * Define an event rule triggered by the \"CodePipeline Pipeline Execution\n   * State Change\" event emitted from this pipeline.\n   *\n   * @param id Identifier for this event handler.\n   * @param options Additional options to pass to the event rule.\n   */\n  onStateChange(id: string, options?: events.OnEventOptions): events.Rule;\n\n  /**\n   * Defines a CodeStar notification rule triggered when the pipeline\n   * events emitted by you specified, it very similar to `onEvent` API.\n   *\n   * You can also use the methods `notifyOnExecutionStateChange`, `notifyOnAnyStageStateChange`,\n   * `notifyOnAnyActionStateChange` and `notifyOnAnyManualApprovalStateChange`\n   * to define rules for these specific event emitted.\n   *\n   * @param id The id of the CodeStar notification rule\n   * @param target The target to register for the CodeStar Notifications destination.\n   * @param options Customization options for CodeStar notification rule\n   * @returns CodeStar notification rule associated with this build project.\n   */\n  notifyOn(\n    id: string,\n    target: notifications.INotificationRuleTarget,\n    options: PipelineNotifyOnOptions,\n  ): notifications.INotificationRule;\n\n  /**\n   * Define an notification rule triggered by the set of the \"Pipeline execution\" events emitted from this pipeline.\n   * @see https://docs.aws.amazon.com/dtconsole/latest/userguide/concepts.html#events-ref-pipeline\n   *\n   * @param id Identifier for this notification handler.\n   * @param target The target to register for the CodeStar Notifications destination.\n   * @param options Additional options to pass to the notification rule.\n   */\n  notifyOnExecutionStateChange(\n    id: string,\n    target: notifications.INotificationRuleTarget,\n    options?: notifications.NotificationRuleOptions,\n  ): notifications.INotificationRule;\n\n  /**\n   * Define an notification rule triggered by the set of the \"Stage execution\" events emitted from this pipeline.\n   * @see https://docs.aws.amazon.com/dtconsole/latest/userguide/concepts.html#events-ref-pipeline\n   *\n   * @param id Identifier for this notification handler.\n   * @param target The target to register for the CodeStar Notifications destination.\n   * @param options Additional options to pass to the notification rule.\n   */\n  notifyOnAnyStageStateChange(\n    id: string,\n    target: notifications.INotificationRuleTarget,\n    options?: notifications.NotificationRuleOptions,\n  ): notifications.INotificationRule;\n\n  /**\n   * Define an notification rule triggered by the set of the \"Action execution\" events emitted from this pipeline.\n   * @see https://docs.aws.amazon.com/dtconsole/latest/userguide/concepts.html#events-ref-pipeline\n   *\n   * @param id Identifier for this notification handler.\n   * @param target The target to register for the CodeStar Notifications destination.\n   * @param options Additional options to pass to the notification rule.\n   */\n  notifyOnAnyActionStateChange(\n    id: string,\n    target: notifications.INotificationRuleTarget,\n    options?: notifications.NotificationRuleOptions,\n  ): notifications.INotificationRule;\n\n  /**\n   * Define an notification rule triggered by the set of the \"Manual approval\" events emitted from this pipeline.\n   * @see https://docs.aws.amazon.com/dtconsole/latest/userguide/concepts.html#events-ref-pipeline\n   *\n   * @param id Identifier for this notification handler.\n   * @param target The target to register for the CodeStar Notifications destination.\n   * @param options Additional options to pass to the notification rule.\n   */\n  notifyOnAnyManualApprovalStateChange(\n    id: string,\n    target: notifications.INotificationRuleTarget,\n    options?: notifications.NotificationRuleOptions,\n  ): notifications.INotificationRule;\n}\n\n/**\n * The abstract interface of a Pipeline Stage that is used by Actions.\n */\nexport interface IStage {\n  /**\n   * The physical, human-readable name of this Pipeline Stage.\n   */\n  readonly stageName: string;\n\n  readonly pipeline: IPipeline;\n\n  /**\n   * The actions belonging to this stage.\n   */\n  readonly actions: IAction[];\n\n  addAction(action: IAction): void;\n\n  onStateChange(name: string, target?: events.IRuleTarget, options?: events.RuleProps): events.Rule;\n}\n\n/**\n * Common properties shared by all Actions.\n */\nexport interface CommonActionProps {\n  /**\n   * The physical, human-readable name of the Action.\n   * Note that Action names must be unique within a single Stage.\n   */\n  readonly actionName: string;\n\n  /**\n   * The runOrder property for this Action.\n   * RunOrder determines the relative order in which multiple Actions in the same Stage execute.\n   *\n   * @default 1\n   * @see https://docs.aws.amazon.com/codepipeline/latest/userguide/reference-pipeline-structure.html\n   */\n  readonly runOrder?: number;\n\n  /**\n   * The name of the namespace to use for variables emitted by this action.\n   *\n   * @default - a name will be generated, based on the stage and action names,\n   *   if any of the action's variables were referenced - otherwise,\n   *   no namespace will be set\n   */\n  readonly variablesNamespace?: string;\n}\n\n/**\n * Common properties shared by all Actions whose {@link ActionProperties.owner} field is 'AWS'\n * (or unset, as 'AWS' is the default).\n */\nexport interface CommonAwsActionProps extends CommonActionProps {\n  /**\n   * The Role in which context's this Action will be executing in.\n   * The Pipeline's Role will assume this Role\n   * (the required permissions for that will be granted automatically)\n   * right before executing this Action.\n   * This Action will be passed into your {@link IAction.bind}\n   * method in the {@link ActionBindOptions.role} property.\n   *\n   * @default a new Role will be generated\n   */\n  readonly role?: iam.IRole;\n}\n\n/**\n * Low-level class for generic CodePipeline Actions implementing the {@link IAction} interface.\n * Contains some common logic that can be re-used by all {@link IAction} implementations.\n * If you're writing your own Action class,\n * feel free to extend this class.\n */\nexport abstract class Action implements IAction {\n  /**\n   * This is a renamed version of the {@link IAction.actionProperties} property.\n   */\n  protected abstract readonly providedActionProperties: ActionProperties;\n\n  private __actionProperties?: ActionProperties;\n  private __pipeline?: IPipeline;\n  private __stage?: IStage;\n  private __scope?: Construct;\n  private readonly _namespaceToken: string;\n  private _customerProvidedNamespace?: string;\n  private _actualNamespace?: string;\n\n  private _variableReferenced = false;\n\n  protected constructor() {\n    this._namespaceToken = Lazy.string({\n      produce: () => {\n        // make sure the action was bound (= added to a pipeline)\n        if (this._actualNamespace === undefined) {\n          throw new Error(`Cannot reference variables of action '${this.actionProperties.actionName}', ` +\n            'as that action was never added to a pipeline');\n        } else {\n          return this._customerProvidedNamespace !== undefined\n            // if a customer passed a namespace explicitly, always use that\n            ? this._customerProvidedNamespace\n            // otherwise, only return a namespace if any variable was referenced\n            : (this._variableReferenced ? this._actualNamespace : undefined);\n        }\n      },\n    });\n  }\n\n  public get actionProperties(): ActionProperties {\n    if (this.__actionProperties === undefined) {\n      const actionProperties = this.providedActionProperties;\n      this._customerProvidedNamespace = actionProperties.variablesNamespace;\n      this.__actionProperties = {\n        ...actionProperties,\n        variablesNamespace: this._customerProvidedNamespace === undefined\n          ? this._namespaceToken\n          : this._customerProvidedNamespace,\n      };\n    }\n    return this.__actionProperties;\n  }\n\n  public bind(scope: Construct, stage: IStage, options: ActionBindOptions): ActionConfig {\n    this.__pipeline = stage.pipeline;\n    this.__stage = stage;\n    this.__scope = scope;\n\n    this._actualNamespace = this._customerProvidedNamespace === undefined\n      // default a namespace name, based on the stage and action names\n      ? `${stage.stageName}_${this.actionProperties.actionName}_NS`\n      : this._customerProvidedNamespace;\n\n    return this.bound(scope, stage, options);\n  }\n\n  public onStateChange(name: string, target?: events.IRuleTarget, options?: events.RuleProps) {\n    const rule = new events.Rule(this._scope, name, options);\n    rule.addTarget(target);\n    rule.addEventPattern({\n      detailType: ['CodePipeline Action Execution State Change'],\n      source: ['aws.codepipeline'],\n      resources: [this._pipeline.pipelineArn],\n      detail: {\n        stage: [this._stage.stageName],\n        action: [this.actionProperties.actionName],\n      },\n    });\n    return rule;\n  }\n\n  protected variableExpression(variableName: string): string {\n    this._variableReferenced = true;\n    return `#{${this._namespaceToken}.${variableName}}`;\n  }\n\n  /**\n   * This is a renamed version of the {@link IAction.bind} method.\n   */\n  protected abstract bound(scope: Construct, stage: IStage, options: ActionBindOptions): ActionConfig;\n\n  private get _pipeline(): IPipeline {\n    if (this.__pipeline) {\n      return this.__pipeline;\n    } else {\n      throw new Error('Action must be added to a stage that is part of a pipeline before using onStateChange');\n    }\n  }\n\n  private get _stage(): IStage {\n    if (this.__stage) {\n      return this.__stage;\n    } else {\n      throw new Error('Action must be added to a stage that is part of a pipeline before using onStateChange');\n    }\n  }\n\n  /**\n   * Retrieves the Construct scope of this Action.\n   * Only available after the Action has been added to a Stage,\n   * and that Stage to a Pipeline.\n   */\n  private get _scope(): Construct {\n    if (this.__scope) {\n      return this.__scope;\n    } else {\n      throw new Error('Action must be added to a stage that is part of a pipeline first');\n    }\n  }\n}\n\n/**\n * The list of event types for AWS Codepipeline Pipeline\n * @see https://docs.aws.amazon.com/dtconsole/latest/userguide/concepts.html#events-ref-pipeline\n */\nexport enum PipelineNotificationEvents {\n  /**\n   * Trigger notification when pipeline execution failed\n   */\n  PIPELINE_EXECUTION_FAILED = 'codepipeline-pipeline-pipeline-execution-failed',\n\n  /**\n   * Trigger notification when pipeline execution canceled\n   */\n  PIPELINE_EXECUTION_CANCELED = 'codepipeline-pipeline-pipeline-execution-canceled',\n\n  /**\n   * Trigger notification when pipeline execution started\n   */\n  PIPELINE_EXECUTION_STARTED = 'codepipeline-pipeline-pipeline-execution-started',\n\n  /**\n   * Trigger notification when pipeline execution resumed\n   */\n  PIPELINE_EXECUTION_RESUMED = 'codepipeline-pipeline-pipeline-execution-resumed',\n\n  /**\n   * Trigger notification when pipeline execution succeeded\n   */\n  PIPELINE_EXECUTION_SUCCEEDED = 'codepipeline-pipeline-pipeline-execution-succeeded',\n\n  /**\n   * Trigger notification when pipeline execution superseded\n   */\n  PIPELINE_EXECUTION_SUPERSEDED = 'codepipeline-pipeline-pipeline-execution-superseded',\n\n  /**\n   * Trigger notification when pipeline stage execution started\n   */\n  STAGE_EXECUTION_STARTED = 'codepipeline-pipeline-stage-execution-started',\n\n  /**\n  * Trigger notification when pipeline stage execution succeeded\n  */\n  STAGE_EXECUTION_SUCCEEDED = 'codepipeline-pipeline-stage-execution-succeeded',\n\n  /**\n  * Trigger notification when pipeline stage execution resumed\n  */\n  STAGE_EXECUTION_RESUMED = 'codepipeline-pipeline-stage-execution-resumed',\n\n  /**\n  * Trigger notification when pipeline stage execution canceled\n  */\n  STAGE_EXECUTION_CANCELED = 'codepipeline-pipeline-stage-execution-canceled',\n\n  /**\n  * Trigger notification when pipeline stage execution failed\n  */\n  STAGE_EXECUTION_FAILED = 'codepipeline-pipeline-stage-execution-failed',\n\n  /**\n   * Trigger notification when pipeline action execution succeeded\n   */\n  ACTION_EXECUTION_SUCCEEDED = 'codepipeline-pipeline-action-execution-succeeded',\n\n  /**\n   * Trigger notification when pipeline action execution failed\n   */\n  ACTION_EXECUTION_FAILED = 'codepipeline-pipeline-action-execution-failed',\n\n  /**\n   * Trigger notification when pipeline action execution canceled\n   */\n  ACTION_EXECUTION_CANCELED = 'codepipeline-pipeline-action-execution-canceled',\n\n  /**\n   * Trigger notification when pipeline action execution started\n   */\n  ACTION_EXECUTION_STARTED = 'codepipeline-pipeline-action-execution-started',\n\n  /**\n   * Trigger notification when pipeline manual approval failed\n   */\n  MANUAL_APPROVAL_FAILED = 'codepipeline-pipeline-manual-approval-failed',\n\n  /**\n   * Trigger notification when pipeline manual approval needed\n   */\n  MANUAL_APPROVAL_NEEDED = 'codepipeline-pipeline-manual-approval-needed',\n\n  /**\n   * Trigger notification when pipeline manual approval succeeded\n   */\n  MANUAL_APPROVAL_SUCCEEDED = 'codepipeline-pipeline-manual-approval-succeeded',\n}\n"]}
\No newline at end of file