aws-delivlib 14.2.1 → 14.3.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -143,6 +143,14 @@ export interface ShellableProps extends ShellableOptions {
143
143
  * Filename of the initial script to start, relative to scriptDirectory.
144
144
  */
145
145
  entrypoint: string;
146
+ /**
147
+ * Additional arguments to pass to the entrypoint script.
148
+ *
149
+ * (NOTE: not named 'arguments' because that's a reserved identifier in JavaScript)
150
+ *
151
+ * @default No arguments
152
+ */
153
+ readonly args?: string[];
146
154
  }
147
155
  export interface AssumeRole {
148
156
  /**
@@ -274,7 +282,7 @@ export declare abstract class ShellPlatform {
274
282
  /**
275
283
  * Return commands to start the entrypoint script
276
284
  */
277
- abstract buildCommands(entrypoint: string): string[];
285
+ abstract buildCommands(entrypoint: string, args?: string[]): string[];
278
286
  /**
279
287
  * Type of platform
280
288
  */
@@ -287,7 +295,7 @@ export declare class LinuxPlatform extends ShellPlatform {
287
295
  readonly platformType = PlatformType.Linux;
288
296
  installCommands(): string[] | undefined;
289
297
  prebuildCommands(assumeRole?: AssumeRole, useRegionalStsEndpoints?: boolean): string[];
290
- buildCommands(entrypoint: string): string[];
298
+ buildCommands(entrypoint: string, args?: string[]): string[];
291
299
  }
292
300
  /**
293
301
  * A Windows Platform
@@ -296,5 +304,5 @@ export declare class WindowsPlatform extends ShellPlatform {
296
304
  readonly platformType = PlatformType.Windows;
297
305
  installCommands(): string[] | undefined;
298
306
  prebuildCommands(assumeRole?: AssumeRole, _useRegionalStsEndpoints?: boolean): string[];
299
- buildCommands(entrypoint: string): string[];
307
+ buildCommands(entrypoint: string, args?: string[]): string[];
300
308
  }
package/lib/shellable.js CHANGED
@@ -235,11 +235,11 @@ class LinuxPlatform extends ShellPlatform {
235
235
  }
236
236
  return lines;
237
237
  }
238
- buildCommands(entrypoint) {
238
+ buildCommands(entrypoint, args) {
239
239
  return [
240
240
  'export SCRIPT_DIR=/tmp/scriptdir',
241
241
  `echo "Running ${entrypoint}"`,
242
- `/bin/bash /tmp/scriptdir/${entrypoint}`,
242
+ `/bin/bash /tmp/scriptdir/${entrypoint} ${(args !== null && args !== void 0 ? args : []).join(' ')}`.trimRight(),
243
243
  ];
244
244
  }
245
245
  }
@@ -270,16 +270,16 @@ class WindowsPlatform extends ShellPlatform {
270
270
  // Punting for someone who knows PowerShell well enough.
271
271
  ];
272
272
  }
273
- buildCommands(entrypoint) {
273
+ buildCommands(entrypoint, args) {
274
274
  return [
275
275
  'Set-Variable -Name TEMPDIR -Value (New-TemporaryFile).DirectoryName',
276
276
  `aws s3 cp s3://$env:${S3_BUCKET_ENV}/$env:${S3_KEY_ENV} $TEMPDIR\\scripts.zip`,
277
277
  'New-Item -ItemType Directory -Path $TEMPDIR\\scriptdir',
278
278
  'Expand-Archive -Path $TEMPDIR/scripts.zip -DestinationPath $TEMPDIR\\scriptdir',
279
279
  '$env:SCRIPT_DIR = "$TEMPDIR\\scriptdir"',
280
- `& $TEMPDIR\\scriptdir\\${entrypoint}`,
280
+ `& $TEMPDIR\\scriptdir\\${entrypoint} ${(args !== null && args !== void 0 ? args : []).join(' ')}`.trimRight(),
281
281
  ];
282
282
  }
283
283
  }
284
284
  exports.WindowsPlatform = WindowsPlatform;
285
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"shellable.js","sourceRoot":"","sources":["shellable.ts"],"names":[],"mappings":"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","sourcesContent":["import * as fs from 'fs';\nimport * as path from 'path';\nimport {\n  Duration,\n  aws_cloudwatch as cloudwatch, aws_codebuild as cbuild,\n  aws_codepipeline as cpipeline, aws_codepipeline_actions as cpipeline_actions,\n  aws_iam as iam, aws_s3_assets as assets, aws_secretsmanager, aws_ssm,\n} from 'aws-cdk-lib';\nimport { Construct } from 'constructs';\nimport { BuildSpec } from './build-spec';\nimport { renderEnvironmentVariables } from './util';\n\nconst S3_BUCKET_ENV = 'SCRIPT_S3_BUCKET';\nconst S3_KEY_ENV = 'SCRIPT_S3_KEY';\n\nexport interface ShellableOptions {\n  /**\n   * Description for the CodeBuild Project\n   */\n  readonly description?: string;\n\n  /**\n   * Source for the CodeBuild project\n   *\n   * @default no source\n   */\n  source?: cbuild.ISource;\n\n  /**\n   * What platform to us to run the scripts on\n   *\n   * @default ShellPlatform.LinuxUbuntu\n   */\n  platform?: ShellPlatform;\n\n  /**\n   * Additional environment variables to set.\n   *\n   * @default No additional environment variables\n   */\n  environment?: { [key: string]: string | undefined };\n\n  /**\n   * Environment variables with secrets manager values. The values must be complete Secret Manager ARNs.\n   *\n   * @default no additional environment variables\n   */\n  environmentSecrets?: { [key: string]: string };\n\n  /**\n   * Environment variables with SSM parameter values.\n   *\n   * @default no additional environment variables\n   */\n  environmentParameters?: { [key: string]: string };\n\n  /**\n   * The compute type to use for the build container.\n   *\n   * Note that not all combinations are available. For example,\n   * Windows images cannot be run on ComputeType.Small.\n   *\n   * @default ComputeType.Medium\n   */\n  computeType?: cbuild.ComputeType;\n\n  /**\n   * Indicates how the project builds Docker images. Specify true to enable\n   * running the Docker daemon inside a Docker container. This value must be\n   * set to true only if this build project will be used to build Docker\n   * images, and the specified build environment image is not one provided by\n   * AWS CodeBuild with Docker support. Otherwise, all associated builds that\n   * attempt to interact with the Docker daemon will fail.\n   *\n   * @default false\n   */\n  privileged?: boolean;\n\n  /**\n   * The name for the build project.\n   *\n   * @default a name is generated by CloudFormation.\n   */\n  buildProjectName?: string;\n\n  /**\n   * Indicates if Regional AWS STS endpoints should be used instead\n   * of the global endpoint. Specify true to use Regional AWS STS endpoints.\n   *\n   * @default false\n   */\n  useRegionalStsEndpoints?: boolean;\n\n  /**\n   * Can be used to run this build using a specific IAM role. This can be used,\n   * for example, to execute in the context of another account (e.g. to run\n   * tests in isolation).\n   */\n  assumeRole?: AssumeRole;\n\n  /**\n   * Additional buildspec (for artifacts etc.)\n   *\n   * @default No additional buildspec\n   */\n  buildSpec?: BuildSpec;\n\n  /**\n   * The timeout of the build.\n   *\n   * @default the CodeBuild default (1 hour)\n   */\n  timeout?: Duration;\n\n  /**\n   * Alarm period.\n   *\n   * @default 300 seconds (5 minutes)\n   */\n  alarmPeriod?: Duration;\n\n  /**\n   * Alarm threshold.\n   * @default 1\n   */\n  alarmThreshold?: number;\n\n  /**\n   * Alarm evaluation periods.\n   * @default 1\n   */\n  alarmEvaluationPeriods?: number;\n\n  secondaryArtifactNames?: string[];\n\n  /**\n   * Clarify whether this Shellable produces any artifacts\n   *\n   * @default true\n   */\n  readonly producesArtifacts?: boolean;\n\n  /**\n   * Namespace to use when adding as an action to the pipeline\n   *\n   * @default No namespace\n   */\n  readonly actionNamespace?: string;\n\n  /**\n   * Additional environment variables to set from the pipeline action\n   *\n   * @default No environment variables\n   */\n  readonly pipelineEnvironmentVars?: Record<string, string>;\n}\n\n/**\n * Properties used to create a Shellable\n */\nexport interface ShellableProps extends ShellableOptions {\n  /**\n   * Directory with the scripts.\n   *\n   * The whole directory will be uploaded.\n   */\n  scriptDirectory: string;\n\n  /**\n   * Filename of the initial script to start, relative to scriptDirectory.\n   */\n  entrypoint: string;\n}\n\nexport interface AssumeRole {\n  /**\n   * The Amazon Resource Name (ARN) of the role to assume.\n   */\n  roleArn: string;\n\n  /**\n   * An identifier for the assumed role session.\n   *\n   * Use  the  role  session name to uniquely identify a session when the same\n   * role is assumed by different principals or for different reasons. In\n   * cross-account scenarios, the role session name is visible to, and can be\n   * logged by the account that owns the role.  The role session name is also\n   * used in the ARN of the assumed role principal. This means that subsequent\n   * cross-account API requests using the tem- porary security credentials will\n   * expose the role session name to the external account in their CloudTrail\n   * logs.\n   *\n   * The regex used to validate this parameter is a string of characters\n   * consisting  of upper- and lower-case alphanumeric characters with no\n   * spaces. You can also include underscores or any of the following\n   * characters: =,.@-\n   */\n  sessionName: string;\n\n  /**\n   * A  unique  identifier  that  is  used by third parties when assuming roles\n   * in their customers' accounts. For each  role  that  the  third party can\n   * assume, they should instruct their customers to ensure the role's trust\n   * policy checks for the external ID that the third  party generated.  Each\n   * time the third party assumes the role, they should pass the customer's\n   * external ID. The external ID is useful in  order to  help  third  parties\n   * bind a role to the customer who created it. For more information about the\n   * external ID, see How to Use an Exter- nal  ID  When Granting Access to Your\n   * AWS Resources to a Third Party in the IAM User Guide .\n   *\n   * This parameter must be a string of characters consisting  of upper- and\n   * lower-case alphanumeric characters with no spaces. You can also include\n   * underscores or  any  of  the  following characters: =,.@:/-\n   */\n  externalId?: string;\n\n  /**\n   * When a profie name is configured, an assumed role configuration will be created\n   * in the shared aws configuration file (~/.aws/config). This is in contrary of simply invoking\n   * an `sts assume-role` command that creates a session with a fixed expiry date.\n   *\n   * Using a profile will delegate credential refreshing to the SDK/CLI.\n   * This is needed to support long running sessions that needs sessions that are longer than\n   * the session duration that can be configured with a `sts assume-role`.\n   *\n   * The application code will access to this profile in the `AWS_PROFILE` env variable.\n   *\n   * Only relevant if `refresh` is specified.\n   *\n   * @see https://docs.aws.amazon.com/cli/latest/userguide/cli-configure-files.html\n   *\n   * @default 'long-running-profile'\n   */\n  profileName?: string;\n\n  /**\n   * Specify this if you have a long running execution that needs long running sessions.\n   * This will create a profile and use it to delegate credential refreshing to the SDK/CLI\n   *\n   * @default false\n   */\n  refresh?: boolean;\n\n}\n\n/**\n * A CodeBuild project that runs arbitrary scripts.\n *\n * The scripts to be run are specified by supplying a directory.\n * All files in the directory are uploaded, then the script designated\n * as the entry point is started.\n *\n * The script is executed in the directory where the build project's\n * input is stored. The directory where the script files are stored\n * is in the $SCRIPT_DIR environment variable.\n *\n * Supports both Windows and Linux computes.\n */\nexport class Shellable extends Construct {\n  public readonly project: cbuild.Project;\n  public readonly role: iam.IRole;\n\n  /**\n   * CloudWatch alarm that will be triggered if this action fails.\n   */\n  public readonly alarm: cloudwatch.Alarm;\n\n  private readonly platform: ShellPlatform;\n  private readonly buildSpec: BuildSpec;\n\n  private readonly outputArtifactName?: string;\n\n  constructor(parent: Construct, id: string, private readonly props: ShellableProps) {\n    super(parent, id);\n\n    this.platform = props.platform || ShellPlatform.LinuxUbuntu;\n\n    const entrypoint = path.join(props.scriptDirectory, props.entrypoint);\n    if (!fs.existsSync(entrypoint)) {\n      throw new Error(`Cannot find test entrypoint: ${entrypoint}`);\n    }\n\n    const asset = new assets.Asset(this, 'ScriptDirectory', {\n      path: props.scriptDirectory,\n    });\n\n    this.outputArtifactName = (props.producesArtifacts ?? true) ? `Artifact_${this.node.addr}` : undefined;\n    if (this.outputArtifactName && this.outputArtifactName.length > 100) {\n      throw new Error(`Whoops, too long: ${this.outputArtifactName}`);\n    }\n\n    this.buildSpec = BuildSpec.simple({\n      install: this.platform.installCommands(),\n      preBuild: this.platform.prebuildCommands(props.assumeRole, props.useRegionalStsEndpoints),\n      build: this.platform.buildCommands(props.entrypoint),\n    }).merge(props.buildSpec || BuildSpec.empty());\n\n    const environmentSecretsAsSecretNames = this.convertEnvironmentSecretArnsToSecretNames(props.environmentSecrets);\n\n    this.project = new cbuild.Project(this, 'Resource', {\n      projectName: props.buildProjectName,\n      description: props.description,\n      source: props.source,\n      environment: {\n        buildImage: this.platform.buildImage,\n        computeType: props.computeType || cbuild.ComputeType.MEDIUM,\n        privileged: props.privileged,\n      },\n      environmentVariables: {\n        [S3_BUCKET_ENV]: { value: asset.s3BucketName },\n        [S3_KEY_ENV]: { value: asset.s3ObjectKey },\n        ...renderEnvironmentVariables(props.environment),\n        ...renderEnvironmentVariables(environmentSecretsAsSecretNames, cbuild.BuildEnvironmentVariableType.SECRETS_MANAGER),\n        ...renderEnvironmentVariables(props.environmentParameters, cbuild.BuildEnvironmentVariableType.PARAMETER_STORE),\n      },\n      timeout: props.timeout,\n      buildSpec: cbuild.BuildSpec.fromObject(this.buildSpec.render({ primaryArtifactName: this.outputArtifactName })),\n      ssmSessionPermissions: true,\n    });\n\n    this.role = this.project.role!; // not undefined, as it's a new Project\n    asset.grantRead(this.role);\n\n    // Grant read access to secrets\n    Object.entries(props.environmentSecrets ?? {}).forEach(([name, secretArn]) => {\n      const secret = aws_secretsmanager.Secret.fromSecretCompleteArn(this, `${name}Secret`, secretArn);\n      secret.grantRead(this.role);\n    });\n\n    // Grant read access to parameters\n    Object.entries(props.environmentParameters ?? {}).forEach(([name, parameterName]) => {\n      const parameter = aws_ssm.StringParameter.fromStringParameterName(this, `${name}Parameter`, parameterName);\n      parameter.grantRead(this.role);\n    });\n\n    if (props.assumeRole) {\n      this.role.addToPrincipalPolicy(new iam.PolicyStatement({\n        actions: ['sts:AssumeRole'],\n        resources: [props.assumeRole.roleArn],\n      }));\n    }\n\n    this.alarm = new cloudwatch.Alarm(this, 'Alarm', {\n      metric: this.project.metricFailedBuilds({ period: props.alarmPeriod || Duration.seconds(300) }),\n      threshold: props.alarmThreshold || 1,\n      comparisonOperator: cloudwatch.ComparisonOperator.GREATER_THAN_OR_EQUAL_TO_THRESHOLD,\n      evaluationPeriods: props.alarmEvaluationPeriods || 1,\n      treatMissingData: cloudwatch.TreatMissingData.IGNORE,\n    });\n  }\n\n  public addToPipeline(stage: cpipeline.IStage, name: string, inputArtifact: cpipeline.Artifact, runOrder?: number):\n  cpipeline_actions.CodeBuildAction {\n    const codeBuildAction = new cpipeline_actions.CodeBuildAction({\n      actionName: name,\n      project: this.project,\n      runOrder,\n      input: inputArtifact,\n      variablesNamespace: this.props.actionNamespace,\n      environmentVariables: this.props.pipelineEnvironmentVars\n        ? Object.fromEntries(Object.entries(this.props.pipelineEnvironmentVars)\n          .map(([k, v]) => ([k, { type: cbuild.BuildEnvironmentVariableType.PLAINTEXT, value: v }] as const)))\n        : undefined,\n      outputs: this.outputArtifactName\n        ? [this.outputArtifactName, ...this.buildSpec.additionalArtifactNames ?? []].map(n => new cpipeline.Artifact(n))\n        : undefined,\n    });\n    stage.addAction(codeBuildAction);\n    return codeBuildAction;\n  }\n\n  /**\n   * The contract of `environmentSecrets` is that the values are complete Secret ARNs;\n   * however, the CodeBuild construct expects secret names as the inputs for environment variables.\n   * This method converts the environment secrets from ARNs to names.\n   */\n  private convertEnvironmentSecretArnsToSecretNames(environmentSecrets?: { [key: string]: string }) {\n    if (!environmentSecrets) {\n      return undefined;\n    }\n\n    const out: { [key: string]: string } = { };\n    Object.entries(environmentSecrets ?? {}).forEach(([name, secretArn]) => {\n      const secret = aws_secretsmanager.Secret.fromSecretCompleteArn(this, `${name}SecretFromArn`, secretArn);\n      out[name] = secret.secretName;\n    });\n    return out;\n  }\n}\n\n/**\n * Platform archetype\n */\nexport enum PlatformType {\n  Linux = 'Linux',\n  Windows = 'Windows'\n}\n\n/**\n * The platform type to run the scripts on\n */\nexport abstract class ShellPlatform {\n  /**\n   * Return a default Ubuntu Linux platform\n   */\n  public static get LinuxUbuntu(): ShellPlatform {\n    // Cannot be static member because of initialization order\n    return new LinuxPlatform(cbuild.LinuxBuildImage.STANDARD_6_0);\n  }\n\n  /**\n   * Return a default Windows platform\n   */\n  public static get Windows(): ShellPlatform {\n    // Cannot be static member because of initialization order\n    return new WindowsPlatform(cbuild.WindowsBuildImage.WIN_SERVER_CORE_2019_BASE);\n  }\n\n  constructor(public readonly buildImage: cbuild.IBuildImage) {\n  }\n\n  /**\n   * Retrn commands to prepare the host for the shellable.\n   */\n  public abstract installCommands(): string[] | undefined;\n\n  /**\n   * Return commands to download the script bundle\n   */\n  public abstract prebuildCommands(assumeRole?: AssumeRole, useRegionalStsEndpoints?: boolean): string[];\n\n  /**\n   * Return commands to start the entrypoint script\n   */\n  public abstract buildCommands(entrypoint: string): string[];\n\n  /**\n   * Type of platform\n   */\n  public abstract get platformType(): PlatformType;\n}\n\n/**\n * A Linux Platform\n */\nexport class LinuxPlatform extends ShellPlatform {\n  public readonly platformType = PlatformType.Linux;\n\n  public installCommands(): string[] | undefined {\n    return undefined;\n  }\n\n  public prebuildCommands(assumeRole?: AssumeRole, useRegionalStsEndpoints?: boolean): string[] {\n    const lines = new Array<string>();\n    // Better echo the location here; if this fails, the error message only contains\n    // the unexpanded variables by default. It might fail if you're running an old\n    // definition of the CodeBuild project--the permissions will have been changed\n    // to only allow downloading the very latest version.\n    lines.push(`echo \"Downloading scripts from s3://\\${${S3_BUCKET_ENV}}/\\${${S3_KEY_ENV}}\"`);\n    lines.push(`aws s3 cp s3://\\${${S3_BUCKET_ENV}}/\\${${S3_KEY_ENV}} /tmp`);\n    lines.push('mkdir -p /tmp/scriptdir');\n    lines.push(`unzip /tmp/$(basename \\$${S3_KEY_ENV}) -d /tmp/scriptdir`);\n\n    if (assumeRole) {\n\n      if (assumeRole.refresh) {\n\n        const awsHome = '~/.aws';\n\n        const profileName = assumeRole.profileName ?? 'long-running-profile';\n\n        lines.push(`mkdir -p ${awsHome}`);\n        lines.push(`touch ${awsHome}/credentials`);\n        lines.push(`config=${awsHome}/config`);\n        lines.push(`echo [profile ${profileName}]>> $\\{config\\}`);\n        lines.push('echo credential_source = EcsContainer >> $\\{config\\}');\n        lines.push(`echo role_session_name = ${assumeRole.sessionName} >> $\\{config\\}`);\n        lines.push(`echo role_arn = ${assumeRole.roleArn} >> $config`);\n\n        if (assumeRole.externalId) {\n          lines.push(`echo external_id = ${assumeRole.externalId} >> $config`);\n        }\n\n        // let the application code know which role is being used.\n        lines.push(`export AWS_PROFILE=${profileName}`);\n\n        // force the AWS SDK for JavaScript to actually load the config file (do automatically so users don't forget)\n        lines.push('export AWS_SDK_LOAD_CONFIG=1');\n\n      } else {\n\n        const externalId = assumeRole.externalId ? `--external-id \"${assumeRole.externalId}\"` : '';\n        const StsEndpoints = useRegionalStsEndpoints ? 'regional' : 'legacy';\n\n        lines.push('creds=$(mktemp -d)/creds.json');\n        lines.push(`AWS_STS_REGIONAL_ENDPOINTS=${StsEndpoints} aws sts assume-role --role-arn \"${assumeRole.roleArn}\" --role-session-name \"${assumeRole.sessionName}\" ${externalId} > $creds`);\n        lines.push('export AWS_ACCESS_KEY_ID=\"$(cat ${creds} | grep \"AccessKeyId\" | cut -d\\'\"\\' -f 4)\"');\n        lines.push('export AWS_SECRET_ACCESS_KEY=\"$(cat ${creds} | grep \"SecretAccessKey\" | cut -d\\'\"\\' -f 4)\"');\n        lines.push('export AWS_SESSION_TOKEN=\"$(cat ${creds} | grep \"SessionToken\" | cut -d\\'\"\\' -f 4)\"');\n      }\n    }\n\n    return lines;\n  }\n\n  public buildCommands(entrypoint: string): string[] {\n    return [\n      'export SCRIPT_DIR=/tmp/scriptdir',\n      `echo \"Running ${entrypoint}\"`,\n      `/bin/bash /tmp/scriptdir/${entrypoint}`,\n    ];\n  }\n}\n\n/**\n * A Windows Platform\n */\nexport class WindowsPlatform extends ShellPlatform {\n  public readonly platformType = PlatformType.Windows;\n\n  public installCommands(): string[] | undefined {\n    return [\n      // Update the image's nodejs to the latest LTS release.\n      'Import-Module \"C:\\\\ProgramData\\\\chocolatey\\\\helpers\\\\chocolateyProfile.psm1\"',\n      'C:\\\\ProgramData\\\\chocolatey\\\\bin\\\\choco.exe upgrade nodejs-lts -y',\n    ];\n  }\n\n  public prebuildCommands(assumeRole?: AssumeRole, _useRegionalStsEndpoints?: boolean): string[] {\n    if (assumeRole) {\n      throw new Error('assumeRole is not supported on Windows: https://github.com/cdklabs/aws-delivlib/issues/57');\n    }\n\n    return [\n      // Would love to do downloading here and executing in the next step,\n      // but I don't know how to propagate the value of $TEMPDIR.\n      //\n      // Punting for someone who knows PowerShell well enough.\n    ];\n  }\n\n  public buildCommands(entrypoint: string): string[] {\n    return [\n      'Set-Variable -Name TEMPDIR -Value (New-TemporaryFile).DirectoryName',\n      `aws s3 cp s3://$env:${S3_BUCKET_ENV}/$env:${S3_KEY_ENV} $TEMPDIR\\\\scripts.zip`,\n      'New-Item -ItemType Directory -Path $TEMPDIR\\\\scriptdir',\n      'Expand-Archive -Path $TEMPDIR/scripts.zip -DestinationPath $TEMPDIR\\\\scriptdir',\n      '$env:SCRIPT_DIR = \"$TEMPDIR\\\\scriptdir\"',\n      `& $TEMPDIR\\\\scriptdir\\\\${entrypoint}`,\n    ];\n  }\n}\n"]}
285
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"shellable.js","sourceRoot":"","sources":["shellable.ts"],"names":[],"mappings":"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","sourcesContent":["import * as fs from 'fs';\nimport * as path from 'path';\nimport {\n  Duration,\n  aws_cloudwatch as cloudwatch, aws_codebuild as cbuild,\n  aws_codepipeline as cpipeline, aws_codepipeline_actions as cpipeline_actions,\n  aws_iam as iam, aws_s3_assets as assets, aws_secretsmanager, aws_ssm,\n} from 'aws-cdk-lib';\nimport { Construct } from 'constructs';\nimport { BuildSpec } from './build-spec';\nimport { renderEnvironmentVariables } from './util';\n\nconst S3_BUCKET_ENV = 'SCRIPT_S3_BUCKET';\nconst S3_KEY_ENV = 'SCRIPT_S3_KEY';\n\nexport interface ShellableOptions {\n  /**\n   * Description for the CodeBuild Project\n   */\n  readonly description?: string;\n\n  /**\n   * Source for the CodeBuild project\n   *\n   * @default no source\n   */\n  source?: cbuild.ISource;\n\n  /**\n   * What platform to us to run the scripts on\n   *\n   * @default ShellPlatform.LinuxUbuntu\n   */\n  platform?: ShellPlatform;\n\n  /**\n   * Additional environment variables to set.\n   *\n   * @default No additional environment variables\n   */\n  environment?: { [key: string]: string | undefined };\n\n  /**\n   * Environment variables with secrets manager values. The values must be complete Secret Manager ARNs.\n   *\n   * @default no additional environment variables\n   */\n  environmentSecrets?: { [key: string]: string };\n\n  /**\n   * Environment variables with SSM parameter values.\n   *\n   * @default no additional environment variables\n   */\n  environmentParameters?: { [key: string]: string };\n\n  /**\n   * The compute type to use for the build container.\n   *\n   * Note that not all combinations are available. For example,\n   * Windows images cannot be run on ComputeType.Small.\n   *\n   * @default ComputeType.Medium\n   */\n  computeType?: cbuild.ComputeType;\n\n  /**\n   * Indicates how the project builds Docker images. Specify true to enable\n   * running the Docker daemon inside a Docker container. This value must be\n   * set to true only if this build project will be used to build Docker\n   * images, and the specified build environment image is not one provided by\n   * AWS CodeBuild with Docker support. Otherwise, all associated builds that\n   * attempt to interact with the Docker daemon will fail.\n   *\n   * @default false\n   */\n  privileged?: boolean;\n\n  /**\n   * The name for the build project.\n   *\n   * @default a name is generated by CloudFormation.\n   */\n  buildProjectName?: string;\n\n  /**\n   * Indicates if Regional AWS STS endpoints should be used instead\n   * of the global endpoint. Specify true to use Regional AWS STS endpoints.\n   *\n   * @default false\n   */\n  useRegionalStsEndpoints?: boolean;\n\n  /**\n   * Can be used to run this build using a specific IAM role. This can be used,\n   * for example, to execute in the context of another account (e.g. to run\n   * tests in isolation).\n   */\n  assumeRole?: AssumeRole;\n\n  /**\n   * Additional buildspec (for artifacts etc.)\n   *\n   * @default No additional buildspec\n   */\n  buildSpec?: BuildSpec;\n\n  /**\n   * The timeout of the build.\n   *\n   * @default the CodeBuild default (1 hour)\n   */\n  timeout?: Duration;\n\n  /**\n   * Alarm period.\n   *\n   * @default 300 seconds (5 minutes)\n   */\n  alarmPeriod?: Duration;\n\n  /**\n   * Alarm threshold.\n   * @default 1\n   */\n  alarmThreshold?: number;\n\n  /**\n   * Alarm evaluation periods.\n   * @default 1\n   */\n  alarmEvaluationPeriods?: number;\n\n  secondaryArtifactNames?: string[];\n\n  /**\n   * Clarify whether this Shellable produces any artifacts\n   *\n   * @default true\n   */\n  readonly producesArtifacts?: boolean;\n\n  /**\n   * Namespace to use when adding as an action to the pipeline\n   *\n   * @default No namespace\n   */\n  readonly actionNamespace?: string;\n\n  /**\n   * Additional environment variables to set from the pipeline action\n   *\n   * @default No environment variables\n   */\n  readonly pipelineEnvironmentVars?: Record<string, string>;\n}\n\n/**\n * Properties used to create a Shellable\n */\nexport interface ShellableProps extends ShellableOptions {\n  /**\n   * Directory with the scripts.\n   *\n   * The whole directory will be uploaded.\n   */\n  scriptDirectory: string;\n\n  /**\n   * Filename of the initial script to start, relative to scriptDirectory.\n   */\n  entrypoint: string;\n\n  /**\n   * Additional arguments to pass to the entrypoint script.\n   *\n   * (NOTE: not named 'arguments' because that's a reserved identifier in JavaScript)\n   *\n   * @default No arguments\n   */\n  readonly args?: string[];\n}\n\nexport interface AssumeRole {\n  /**\n   * The Amazon Resource Name (ARN) of the role to assume.\n   */\n  roleArn: string;\n\n  /**\n   * An identifier for the assumed role session.\n   *\n   * Use  the  role  session name to uniquely identify a session when the same\n   * role is assumed by different principals or for different reasons. In\n   * cross-account scenarios, the role session name is visible to, and can be\n   * logged by the account that owns the role.  The role session name is also\n   * used in the ARN of the assumed role principal. This means that subsequent\n   * cross-account API requests using the tem- porary security credentials will\n   * expose the role session name to the external account in their CloudTrail\n   * logs.\n   *\n   * The regex used to validate this parameter is a string of characters\n   * consisting  of upper- and lower-case alphanumeric characters with no\n   * spaces. You can also include underscores or any of the following\n   * characters: =,.@-\n   */\n  sessionName: string;\n\n  /**\n   * A  unique  identifier  that  is  used by third parties when assuming roles\n   * in their customers' accounts. For each  role  that  the  third party can\n   * assume, they should instruct their customers to ensure the role's trust\n   * policy checks for the external ID that the third  party generated.  Each\n   * time the third party assumes the role, they should pass the customer's\n   * external ID. The external ID is useful in  order to  help  third  parties\n   * bind a role to the customer who created it. For more information about the\n   * external ID, see How to Use an Exter- nal  ID  When Granting Access to Your\n   * AWS Resources to a Third Party in the IAM User Guide .\n   *\n   * This parameter must be a string of characters consisting  of upper- and\n   * lower-case alphanumeric characters with no spaces. You can also include\n   * underscores or  any  of  the  following characters: =,.@:/-\n   */\n  externalId?: string;\n\n  /**\n   * When a profie name is configured, an assumed role configuration will be created\n   * in the shared aws configuration file (~/.aws/config). This is in contrary of simply invoking\n   * an `sts assume-role` command that creates a session with a fixed expiry date.\n   *\n   * Using a profile will delegate credential refreshing to the SDK/CLI.\n   * This is needed to support long running sessions that needs sessions that are longer than\n   * the session duration that can be configured with a `sts assume-role`.\n   *\n   * The application code will access to this profile in the `AWS_PROFILE` env variable.\n   *\n   * Only relevant if `refresh` is specified.\n   *\n   * @see https://docs.aws.amazon.com/cli/latest/userguide/cli-configure-files.html\n   *\n   * @default 'long-running-profile'\n   */\n  profileName?: string;\n\n  /**\n   * Specify this if you have a long running execution that needs long running sessions.\n   * This will create a profile and use it to delegate credential refreshing to the SDK/CLI\n   *\n   * @default false\n   */\n  refresh?: boolean;\n\n}\n\n/**\n * A CodeBuild project that runs arbitrary scripts.\n *\n * The scripts to be run are specified by supplying a directory.\n * All files in the directory are uploaded, then the script designated\n * as the entry point is started.\n *\n * The script is executed in the directory where the build project's\n * input is stored. The directory where the script files are stored\n * is in the $SCRIPT_DIR environment variable.\n *\n * Supports both Windows and Linux computes.\n */\nexport class Shellable extends Construct {\n  public readonly project: cbuild.Project;\n  public readonly role: iam.IRole;\n\n  /**\n   * CloudWatch alarm that will be triggered if this action fails.\n   */\n  public readonly alarm: cloudwatch.Alarm;\n\n  private readonly platform: ShellPlatform;\n  private readonly buildSpec: BuildSpec;\n\n  private readonly outputArtifactName?: string;\n\n  constructor(parent: Construct, id: string, private readonly props: ShellableProps) {\n    super(parent, id);\n\n    this.platform = props.platform || ShellPlatform.LinuxUbuntu;\n\n    const entrypoint = path.join(props.scriptDirectory, props.entrypoint);\n    if (!fs.existsSync(entrypoint)) {\n      throw new Error(`Cannot find test entrypoint: ${entrypoint}`);\n    }\n\n    const asset = new assets.Asset(this, 'ScriptDirectory', {\n      path: props.scriptDirectory,\n    });\n\n    this.outputArtifactName = (props.producesArtifacts ?? true) ? `Artifact_${this.node.addr}` : undefined;\n    if (this.outputArtifactName && this.outputArtifactName.length > 100) {\n      throw new Error(`Whoops, too long: ${this.outputArtifactName}`);\n    }\n\n    this.buildSpec = BuildSpec.simple({\n      install: this.platform.installCommands(),\n      preBuild: this.platform.prebuildCommands(props.assumeRole, props.useRegionalStsEndpoints),\n      build: this.platform.buildCommands(props.entrypoint),\n    }).merge(props.buildSpec || BuildSpec.empty());\n\n    const environmentSecretsAsSecretNames = this.convertEnvironmentSecretArnsToSecretNames(props.environmentSecrets);\n\n    this.project = new cbuild.Project(this, 'Resource', {\n      projectName: props.buildProjectName,\n      description: props.description,\n      source: props.source,\n      environment: {\n        buildImage: this.platform.buildImage,\n        computeType: props.computeType || cbuild.ComputeType.MEDIUM,\n        privileged: props.privileged,\n      },\n      environmentVariables: {\n        [S3_BUCKET_ENV]: { value: asset.s3BucketName },\n        [S3_KEY_ENV]: { value: asset.s3ObjectKey },\n        ...renderEnvironmentVariables(props.environment),\n        ...renderEnvironmentVariables(environmentSecretsAsSecretNames, cbuild.BuildEnvironmentVariableType.SECRETS_MANAGER),\n        ...renderEnvironmentVariables(props.environmentParameters, cbuild.BuildEnvironmentVariableType.PARAMETER_STORE),\n      },\n      timeout: props.timeout,\n      buildSpec: cbuild.BuildSpec.fromObject(this.buildSpec.render({ primaryArtifactName: this.outputArtifactName })),\n      ssmSessionPermissions: true,\n    });\n\n    this.role = this.project.role!; // not undefined, as it's a new Project\n    asset.grantRead(this.role);\n\n    // Grant read access to secrets\n    Object.entries(props.environmentSecrets ?? {}).forEach(([name, secretArn]) => {\n      const secret = aws_secretsmanager.Secret.fromSecretCompleteArn(this, `${name}Secret`, secretArn);\n      secret.grantRead(this.role);\n    });\n\n    // Grant read access to parameters\n    Object.entries(props.environmentParameters ?? {}).forEach(([name, parameterName]) => {\n      const parameter = aws_ssm.StringParameter.fromStringParameterName(this, `${name}Parameter`, parameterName);\n      parameter.grantRead(this.role);\n    });\n\n    if (props.assumeRole) {\n      this.role.addToPrincipalPolicy(new iam.PolicyStatement({\n        actions: ['sts:AssumeRole'],\n        resources: [props.assumeRole.roleArn],\n      }));\n    }\n\n    this.alarm = new cloudwatch.Alarm(this, 'Alarm', {\n      metric: this.project.metricFailedBuilds({ period: props.alarmPeriod || Duration.seconds(300) }),\n      threshold: props.alarmThreshold || 1,\n      comparisonOperator: cloudwatch.ComparisonOperator.GREATER_THAN_OR_EQUAL_TO_THRESHOLD,\n      evaluationPeriods: props.alarmEvaluationPeriods || 1,\n      treatMissingData: cloudwatch.TreatMissingData.IGNORE,\n    });\n  }\n\n  public addToPipeline(stage: cpipeline.IStage, name: string, inputArtifact: cpipeline.Artifact, runOrder?: number):\n  cpipeline_actions.CodeBuildAction {\n    const codeBuildAction = new cpipeline_actions.CodeBuildAction({\n      actionName: name,\n      project: this.project,\n      runOrder,\n      input: inputArtifact,\n      variablesNamespace: this.props.actionNamespace,\n      environmentVariables: this.props.pipelineEnvironmentVars\n        ? Object.fromEntries(Object.entries(this.props.pipelineEnvironmentVars)\n          .map(([k, v]) => ([k, { type: cbuild.BuildEnvironmentVariableType.PLAINTEXT, value: v }] as const)))\n        : undefined,\n      outputs: this.outputArtifactName\n        ? [this.outputArtifactName, ...this.buildSpec.additionalArtifactNames ?? []].map(n => new cpipeline.Artifact(n))\n        : undefined,\n    });\n    stage.addAction(codeBuildAction);\n    return codeBuildAction;\n  }\n\n  /**\n   * The contract of `environmentSecrets` is that the values are complete Secret ARNs;\n   * however, the CodeBuild construct expects secret names as the inputs for environment variables.\n   * This method converts the environment secrets from ARNs to names.\n   */\n  private convertEnvironmentSecretArnsToSecretNames(environmentSecrets?: { [key: string]: string }) {\n    if (!environmentSecrets) {\n      return undefined;\n    }\n\n    const out: { [key: string]: string } = { };\n    Object.entries(environmentSecrets ?? {}).forEach(([name, secretArn]) => {\n      const secret = aws_secretsmanager.Secret.fromSecretCompleteArn(this, `${name}SecretFromArn`, secretArn);\n      out[name] = secret.secretName;\n    });\n    return out;\n  }\n}\n\n/**\n * Platform archetype\n */\nexport enum PlatformType {\n  Linux = 'Linux',\n  Windows = 'Windows'\n}\n\n/**\n * The platform type to run the scripts on\n */\nexport abstract class ShellPlatform {\n  /**\n   * Return a default Ubuntu Linux platform\n   */\n  public static get LinuxUbuntu(): ShellPlatform {\n    // Cannot be static member because of initialization order\n    return new LinuxPlatform(cbuild.LinuxBuildImage.STANDARD_6_0);\n  }\n\n  /**\n   * Return a default Windows platform\n   */\n  public static get Windows(): ShellPlatform {\n    // Cannot be static member because of initialization order\n    return new WindowsPlatform(cbuild.WindowsBuildImage.WIN_SERVER_CORE_2019_BASE);\n  }\n\n  constructor(public readonly buildImage: cbuild.IBuildImage) {\n  }\n\n  /**\n   * Retrn commands to prepare the host for the shellable.\n   */\n  public abstract installCommands(): string[] | undefined;\n\n  /**\n   * Return commands to download the script bundle\n   */\n  public abstract prebuildCommands(assumeRole?: AssumeRole, useRegionalStsEndpoints?: boolean): string[];\n\n  /**\n   * Return commands to start the entrypoint script\n   */\n  public abstract buildCommands(entrypoint: string, args?: string[]): string[];\n\n  /**\n   * Type of platform\n   */\n  public abstract get platformType(): PlatformType;\n}\n\n/**\n * A Linux Platform\n */\nexport class LinuxPlatform extends ShellPlatform {\n  public readonly platformType = PlatformType.Linux;\n\n  public installCommands(): string[] | undefined {\n    return undefined;\n  }\n\n  public prebuildCommands(assumeRole?: AssumeRole, useRegionalStsEndpoints?: boolean): string[] {\n    const lines = new Array<string>();\n    // Better echo the location here; if this fails, the error message only contains\n    // the unexpanded variables by default. It might fail if you're running an old\n    // definition of the CodeBuild project--the permissions will have been changed\n    // to only allow downloading the very latest version.\n    lines.push(`echo \"Downloading scripts from s3://\\${${S3_BUCKET_ENV}}/\\${${S3_KEY_ENV}}\"`);\n    lines.push(`aws s3 cp s3://\\${${S3_BUCKET_ENV}}/\\${${S3_KEY_ENV}} /tmp`);\n    lines.push('mkdir -p /tmp/scriptdir');\n    lines.push(`unzip /tmp/$(basename \\$${S3_KEY_ENV}) -d /tmp/scriptdir`);\n\n    if (assumeRole) {\n\n      if (assumeRole.refresh) {\n\n        const awsHome = '~/.aws';\n\n        const profileName = assumeRole.profileName ?? 'long-running-profile';\n\n        lines.push(`mkdir -p ${awsHome}`);\n        lines.push(`touch ${awsHome}/credentials`);\n        lines.push(`config=${awsHome}/config`);\n        lines.push(`echo [profile ${profileName}]>> $\\{config\\}`);\n        lines.push('echo credential_source = EcsContainer >> $\\{config\\}');\n        lines.push(`echo role_session_name = ${assumeRole.sessionName} >> $\\{config\\}`);\n        lines.push(`echo role_arn = ${assumeRole.roleArn} >> $config`);\n\n        if (assumeRole.externalId) {\n          lines.push(`echo external_id = ${assumeRole.externalId} >> $config`);\n        }\n\n        // let the application code know which role is being used.\n        lines.push(`export AWS_PROFILE=${profileName}`);\n\n        // force the AWS SDK for JavaScript to actually load the config file (do automatically so users don't forget)\n        lines.push('export AWS_SDK_LOAD_CONFIG=1');\n\n      } else {\n\n        const externalId = assumeRole.externalId ? `--external-id \"${assumeRole.externalId}\"` : '';\n        const StsEndpoints = useRegionalStsEndpoints ? 'regional' : 'legacy';\n\n        lines.push('creds=$(mktemp -d)/creds.json');\n        lines.push(`AWS_STS_REGIONAL_ENDPOINTS=${StsEndpoints} aws sts assume-role --role-arn \"${assumeRole.roleArn}\" --role-session-name \"${assumeRole.sessionName}\" ${externalId} > $creds`);\n        lines.push('export AWS_ACCESS_KEY_ID=\"$(cat ${creds} | grep \"AccessKeyId\" | cut -d\\'\"\\' -f 4)\"');\n        lines.push('export AWS_SECRET_ACCESS_KEY=\"$(cat ${creds} | grep \"SecretAccessKey\" | cut -d\\'\"\\' -f 4)\"');\n        lines.push('export AWS_SESSION_TOKEN=\"$(cat ${creds} | grep \"SessionToken\" | cut -d\\'\"\\' -f 4)\"');\n      }\n    }\n\n    return lines;\n  }\n\n  public buildCommands(entrypoint: string, args?: string[]): string[] {\n    return [\n      'export SCRIPT_DIR=/tmp/scriptdir',\n      `echo \"Running ${entrypoint}\"`,\n      `/bin/bash /tmp/scriptdir/${entrypoint} ${(args ?? []).join(' ')}`.trimRight(),\n    ];\n  }\n}\n\n/**\n * A Windows Platform\n */\nexport class WindowsPlatform extends ShellPlatform {\n  public readonly platformType = PlatformType.Windows;\n\n  public installCommands(): string[] | undefined {\n    return [\n      // Update the image's nodejs to the latest LTS release.\n      'Import-Module \"C:\\\\ProgramData\\\\chocolatey\\\\helpers\\\\chocolateyProfile.psm1\"',\n      'C:\\\\ProgramData\\\\chocolatey\\\\bin\\\\choco.exe upgrade nodejs-lts -y',\n    ];\n  }\n\n  public prebuildCommands(assumeRole?: AssumeRole, _useRegionalStsEndpoints?: boolean): string[] {\n    if (assumeRole) {\n      throw new Error('assumeRole is not supported on Windows: https://github.com/cdklabs/aws-delivlib/issues/57');\n    }\n\n    return [\n      // Would love to do downloading here and executing in the next step,\n      // but I don't know how to propagate the value of $TEMPDIR.\n      //\n      // Punting for someone who knows PowerShell well enough.\n    ];\n  }\n\n  public buildCommands(entrypoint: string, args?: string[]): string[] {\n    return [\n      'Set-Variable -Name TEMPDIR -Value (New-TemporaryFile).DirectoryName',\n      `aws s3 cp s3://$env:${S3_BUCKET_ENV}/$env:${S3_KEY_ENV} $TEMPDIR\\\\scripts.zip`,\n      'New-Item -ItemType Directory -Path $TEMPDIR\\\\scriptdir',\n      'Expand-Archive -Path $TEMPDIR/scripts.zip -DestinationPath $TEMPDIR\\\\scriptdir',\n      '$env:SCRIPT_DIR = \"$TEMPDIR\\\\scriptdir\"',\n      `& $TEMPDIR\\\\scriptdir\\\\${entrypoint} ${(args ?? []).join(' ')}`.trimRight(),\n    ];\n  }\n}\n"]}
package/package.json CHANGED
@@ -91,7 +91,7 @@
91
91
  },
92
92
  "main": "lib/index.js",
93
93
  "license": "Apache-2.0",
94
- "version": "14.2.1",
94
+ "version": "14.3.0",
95
95
  "jest": {
96
96
  "testMatch": [
97
97
  "**/lib/__tests__/**/?(*.)+(spec|test).js?(x)"