UNPKG

@aws-cdk/aws-codepipeline

Version:

Better interface to AWS Code Pipeline

106 lines 13.5 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.RichAction = void 0; const core_1 = require("@aws-cdk/core"); /** * Helper routines to work with Actions * * Can't put these on Action themselves since we only have an interface * and every library would need to reimplement everything (there is no * `ActionBase`). * * So here go the members that should have gone onto the Action class * but can't. * * It was probably my own idea but I don't want it anymore: * https://github.com/aws/aws-cdk/issues/10393 */ class RichAction { constructor(action, pipeline) { this.action = action; this.pipeline = pipeline; this.actionProperties = action.actionProperties; } bind(scope, stage, options) { return this.action.bind(scope, stage, options); } onStateChange(name, target, options) { return this.action.onStateChange(name, target, options); } get isCrossRegion() { return !actionDimensionSameAsPipelineDimension(this.effectiveRegion, this.pipeline.env.region); } get isCrossAccount() { return !actionDimensionSameAsPipelineDimension(this.effectiveAccount, this.pipeline.env.account); } /** * Returns the Stack of the resource backing this action * if they belong to the same environment. * Returns `undefined` if either this action is not backed by a resource, * or if the resource does not belong to the same env as its Stack * (which can happen for imported resources). */ get resourceStack() { const actionResource = this.actionProperties.resource; if (!actionResource) { return undefined; } const actionResourceStack = core_1.Stack.of(actionResource); const actionResourceStackEnv = { region: actionResourceStack.region, account: actionResourceStack.account, }; return sameEnv(actionResource.env, actionResourceStackEnv) ? actionResourceStack : undefined; } /** * The region this action wants to execute in. * `undefined` means it wants to execute in the same region as the pipeline. */ get effectiveRegion() { return this.action.actionProperties.resource?.env.region ?? this.action.actionProperties.region; } /** * The account this action wants to execute in. * `undefined` means it wants to execute in the same account as the pipeline. */ get effectiveAccount() { return this.action.actionProperties.role?.env.account ?? this.action.actionProperties?.resource?.env.account ?? this.action.actionProperties.account; } } exports.RichAction = RichAction; function actionDimensionSameAsPipelineDimension(actionDim, pipelineDim) { // if the action's dimension is `undefined`, // it means it is in the same region/account as the pipeline if (!actionDim) { return true; } // if the action's region/account is AWS::Region/AWS::AccountId, // we assume it's also in the same region/account as the pipeline if (core_1.Token.isUnresolved(actionDim)) { return true; } // here, we know the action's dimension is explicitly set; // in this case, it must be equal to the pipeline's dimension // for the action to be considered in the same region/account return core_1.Token.compareStrings(actionDim, pipelineDim) === core_1.TokenComparison.SAME; } /** * Whether the two envs represent the same environment */ function sameEnv(env1, env2) { return sameEnvDimension(env1.region, env2.region) && sameEnvDimension(env1.account, env2.account); } /** * Whether two string probably contain the same environment dimension (region or account) * * Used to compare either accounts or regions, and also returns true if both * are unresolved (in which case both are expted to be "current region" or "current account"). */ function sameEnvDimension(dim1, dim2) { return [core_1.TokenComparison.SAME, core_1.TokenComparison.BOTH_UNRESOLVED].includes(core_1.Token.compareStrings(dim1, dim2)); } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"rich-action.js","sourceRoot":"","sources":["rich-action.ts"],"names":[],"mappings":"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","sourcesContent":["import * as events from '@aws-cdk/aws-events';\nimport { ResourceEnvironment, Stack, Token, TokenComparison } from '@aws-cdk/core';\nimport { ActionBindOptions, ActionConfig, ActionProperties, IAction, IPipeline, IStage } from '../action';\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\n/**\n * Helper routines to work with Actions\n *\n * Can't put these on Action themselves since we only have an interface\n * and every library would need to reimplement everything (there is no\n * `ActionBase`).\n *\n * So here go the members that should have gone onto the Action class\n * but can't.\n *\n * It was probably my own idea but I don't want it anymore:\n * https://github.com/aws/aws-cdk/issues/10393\n */\nexport class RichAction implements IAction {\n  public readonly actionProperties: ActionProperties;\n\n  constructor(private readonly action: IAction, private readonly pipeline: IPipeline) {\n    this.actionProperties = action.actionProperties;\n  }\n\n  public bind(scope: Construct, stage: IStage, options: ActionBindOptions): ActionConfig {\n    return this.action.bind(scope, stage, options);\n  }\n\n  public onStateChange(name: string, target?: events.IRuleTarget, options?: events.RuleProps): events.Rule {\n    return this.action.onStateChange(name, target, options);\n  }\n\n  public get isCrossRegion(): boolean {\n    return !actionDimensionSameAsPipelineDimension(this.effectiveRegion, this.pipeline.env.region);\n  }\n\n  public get isCrossAccount(): boolean {\n    return !actionDimensionSameAsPipelineDimension(this.effectiveAccount, this.pipeline.env.account);\n  }\n\n  /**\n   * Returns the Stack of the resource backing this action\n   * if they belong to the same environment.\n   * Returns `undefined` if either this action is not backed by a resource,\n   * or if the resource does not belong to the same env as its Stack\n   * (which can happen for imported resources).\n   */\n  public get resourceStack(): Stack | undefined {\n    const actionResource = this.actionProperties.resource;\n    if (!actionResource) {\n      return undefined;\n    }\n\n    const actionResourceStack = Stack.of(actionResource);\n    const actionResourceStackEnv: ResourceEnvironment = {\n      region: actionResourceStack.region,\n      account: actionResourceStack.account,\n    };\n\n    return sameEnv(actionResource.env, actionResourceStackEnv) ? actionResourceStack : undefined;\n  }\n\n  /**\n   * The region this action wants to execute in.\n   * `undefined` means it wants to execute in the same region as the pipeline.\n   */\n  public get effectiveRegion(): string | undefined {\n    return this.action.actionProperties.resource?.env.region\n      ?? this.action.actionProperties.region;\n  }\n\n  /**\n   * The account this action wants to execute in.\n   * `undefined` means it wants to execute in the same account as the pipeline.\n   */\n  public get effectiveAccount(): string | undefined {\n    return this.action.actionProperties.role?.env.account\n      ?? this.action.actionProperties?.resource?.env.account\n      ?? this.action.actionProperties.account;\n  }\n}\n\nfunction actionDimensionSameAsPipelineDimension(actionDim: string | undefined, pipelineDim: string) {\n  // if the action's dimension is `undefined`,\n  // it means it is in the same region/account as the pipeline\n  if (!actionDim) {\n    return true;\n  }\n  // if the action's region/account is AWS::Region/AWS::AccountId,\n  // we assume it's also in the same region/account as the pipeline\n  if (Token.isUnresolved(actionDim)) {\n    return true;\n  }\n  // here, we know the action's dimension is explicitly set;\n  // in this case, it must be equal to the pipeline's dimension\n  // for the action to be considered in the same region/account\n  return Token.compareStrings(actionDim, pipelineDim) === TokenComparison.SAME;\n}\n\n/**\n * Whether the two envs represent the same environment\n */\nfunction sameEnv(env1: ResourceEnvironment, env2: ResourceEnvironment) {\n  return sameEnvDimension(env1.region, env2.region)\n    && sameEnvDimension(env1.account, env2.account);\n}\n\n/**\n * Whether two string probably contain the same environment dimension (region or account)\n *\n * Used to compare either accounts or regions, and also returns true if both\n * are unresolved (in which case both are expted to be \"current region\" or \"current account\").\n */\nfunction sameEnvDimension(dim1: string, dim2: string) {\n  return [TokenComparison.SAME, TokenComparison.BOTH_UNRESOLVED].includes(Token.compareStrings(dim1, dim2));\n}\n"]}