projen-pipelines 0.0.55 → 0.0.57

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.
@@ -5,6 +5,7 @@ exports.GitlabCDKPipeline = void 0;
5
5
  const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
6
6
  const projen_1 = require("projen");
7
7
  const base_1 = require("./base");
8
+ const engine_1 = require("../engine");
8
9
  /**
9
10
  * The GitlabCDKPipeline class extends CDKPipeline to provide a way to configure and execute
10
11
  * AWS CDK deployment pipelines within GitLab CI/CD environments. It integrates IAM role management,
@@ -103,11 +104,27 @@ awslogin() {
103
104
  if (this.options.iamRoleArns?.synth) {
104
105
  script.push(`awslogin '${this.options.iamRoleArns.synth}'`);
105
106
  }
107
+ const extensions = ['.aws_base', '.artifacts_cdk'];
108
+ const needs = [];
109
+ const preInstallSteps = (this.options.preInstallSteps ?? []).map(s => s.toGitlab());
110
+ script.push(...preInstallSteps.flatMap(s => s.commands));
111
+ extensions.push(...preInstallSteps.flatMap(s => s.extensions));
112
+ needs.push(...preInstallSteps.flatMap(s => s.needs));
113
+ script.push(...this.renderInstallCommands());
114
+ const preSynthSteps = (this.options.preSynthSteps ?? []).map(s => s.toGitlab());
115
+ script.push(...preSynthSteps.flatMap(s => s.commands));
116
+ extensions.push(...preSynthSteps.flatMap(s => s.extensions));
117
+ needs.push(...preSynthSteps.flatMap(s => s.needs));
106
118
  script.push(...this.renderSynthCommands());
119
+ const postSynthSteps = (this.options.postSynthSteps ?? []).map(s => s.toGitlab());
120
+ script.push(...postSynthSteps.flatMap(s => s.commands));
121
+ extensions.push(...postSynthSteps.flatMap(s => s.extensions));
122
+ needs.push(...postSynthSteps.flatMap(s => s.needs));
107
123
  this.config.addStages('synth');
108
124
  this.config.addJobs({
109
125
  synth: {
110
- extends: ['.aws_base', '.artifacts_cdk'],
126
+ extends: extensions,
127
+ needs: needs,
111
128
  stage: 'synth',
112
129
  tags: this.options.runnerTags?.synth ?? this.options.runnerTags?.default,
113
130
  script,
@@ -125,14 +142,17 @@ awslogin() {
125
142
  if (this.options.iamRoleArns?.assetPublishing) {
126
143
  script.push(`awslogin '${this.options.iamRoleArns.assetPublishing}'`);
127
144
  }
145
+ const preInstallSteps = (this.options.preInstallSteps ?? []).map(s => s.toGitlab());
146
+ script.push(...preInstallSteps.flatMap(s => s.commands));
147
+ script.push(...this.renderInstallCommands());
128
148
  script.push(...this.getAssetUploadCommands(this.needsVersionedArtifacts));
129
149
  this.config.addStages('publish_assets');
130
150
  this.config.addJobs({
131
151
  publish_assets: {
132
- extends: ['.aws_base'],
152
+ extends: ['.aws_base', ...preInstallSteps.flatMap(s => s.extensions)],
133
153
  stage: 'publish_assets',
134
154
  tags: this.options.runnerTags?.assetPublishing ?? this.options.runnerTags?.default,
135
- needs: [{ job: 'synth', artifacts: true }],
155
+ needs: [{ job: 'synth', artifacts: true }, ...preInstallSteps.flatMap(s => s.needs)],
136
156
  script,
137
157
  },
138
158
  });
@@ -146,13 +166,11 @@ awslogin() {
146
166
  * @param {DeploymentStage} stage - The deployment stage configuration to set up.
147
167
  */
148
168
  createDeployment(stage) {
149
- const script = [];
150
- script.push(`awslogin '${this.options.iamRoleArns?.deployment?.[stage.name] ?? this.options.iamRoleArns?.default}'`);
151
- script.push(...this.renderInstallCommands());
169
+ const preInstallSteps = (this.options.preInstallSteps ?? []).map(s => s.toGitlab());
152
170
  this.config.addStages(stage.name);
153
171
  this.config.addJobs({
154
172
  [`diff-${stage.name}`]: {
155
- extends: ['.aws_base'],
173
+ extends: ['.aws_base', ...preInstallSteps.flatMap(s => s.extensions)],
156
174
  stage: stage.name,
157
175
  tags: this.options.runnerTags?.diff?.[stage.name] ?? this.options.runnerTags?.deployment?.[stage.name] ?? this.options.runnerTags?.default,
158
176
  only: {
@@ -161,15 +179,17 @@ awslogin() {
161
179
  needs: [
162
180
  { job: 'synth', artifacts: true },
163
181
  { job: 'publish_assets' },
182
+ ...preInstallSteps.flatMap(s => s.needs),
164
183
  ],
165
184
  script: [
166
185
  `awslogin '${this.options.iamRoleArns?.diff?.[stage.name] ?? this.options.iamRoleArns?.deployment?.[stage.name] ?? this.options.iamRoleArns?.default}'`,
186
+ ...preInstallSteps.flatMap(s => s.commands),
167
187
  ...this.renderInstallCommands(),
168
188
  ...this.renderDiffCommands(stage.name),
169
189
  ],
170
190
  },
171
191
  [`deploy-${stage.name}`]: {
172
- extends: ['.aws_base', '.artifacts_cdkdeploy'],
192
+ extends: ['.aws_base', '.artifacts_cdkdeploy', ...preInstallSteps.flatMap(s => s.extensions)],
173
193
  stage: stage.name,
174
194
  tags: this.options.runnerTags?.deployment?.[stage.name] ?? this.options.runnerTags?.default,
175
195
  ...stage.manualApproval && {
@@ -182,9 +202,11 @@ awslogin() {
182
202
  { job: 'synth', artifacts: true },
183
203
  { job: 'publish_assets' },
184
204
  { job: `diff-${stage.name}` },
205
+ ...preInstallSteps.flatMap(s => s.needs),
185
206
  ],
186
207
  script: [
187
208
  `awslogin '${this.options.iamRoleArns?.deployment?.[stage.name] ?? this.options.iamRoleArns?.default}'`,
209
+ ...preInstallSteps.flatMap(s => s.commands),
188
210
  ...this.renderInstallCommands(),
189
211
  ...this.renderDeployCommands(stage.name),
190
212
  ],
@@ -192,8 +214,11 @@ awslogin() {
192
214
  });
193
215
  this.deploymentStages.push(stage.name);
194
216
  }
217
+ engineType() {
218
+ return engine_1.PipelineEngine.GITLAB;
219
+ }
195
220
  }
196
221
  exports.GitlabCDKPipeline = GitlabCDKPipeline;
197
222
  _a = JSII_RTTI_SYMBOL_1;
198
- GitlabCDKPipeline[_a] = { fqn: "projen-pipelines.GitlabCDKPipeline", version: "0.0.55" };
199
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gitlab.js","sourceRoot":"","sources":["../../src/awscdk/gitlab.ts"],"names":[],"mappings":";;;;;AAAA,mCAAwC;AACxC,iCAA0E;AAmD1E;;;;GAIG;AACH,MAAa,iBAAkB,SAAQ,kBAAW;IAchD;;;;;;OAMG;IACH,YAAY,GAA+B,EAAU,OAAiC;QACpF,KAAK,CAAC,GAAG,EAAE,OAAO,CAAC,CAAC;QAD+B,YAAO,GAAP,OAAO,CAA0B;QAVtF,4CAA4C;QACpC,qBAAgB,GAAa,EAAE,CAAC;QAYtC,uCAAuC;QACvC,IAAI,CAAC,MAAM,GAAG,IAAI,eAAM,CAAC,mBAAmB,CAAC,GAAG,EAAE;YAChD,MAAM,EAAE,EAAE;YACV,IAAI,EAAE,EAAE;SACT,CAAC,CAAC;QAEH,IAAI,CAAC,uBAAuB,GAAG,KAAK,CAAC,CAAC,6CAA6C;QACnF,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAC,KAAK,IAAI,6CAA6C,CAAC;QAE/E,IAAI,CAAC,aAAa,EAAE,CAAC;QAErB,IAAI,CAAC,WAAW,EAAE,CAAC;QAEnB,IAAI,CAAC,iBAAiB,EAAE,CAAC;QAEzB,KAAK,MAAM,KAAK,IAAI,OAAO,CAAC,MAAM,EAAE;YAClC,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC;SAC9B;IACH,CAAC;IAED;;;;OAIG;IACO,aAAa;QACrB,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC;YAClB,gBAAgB,EAAE;gBAChB,SAAS,EAAE;oBACT,IAAI,EAAE,eAAM,CAAC,SAAS,CAAC,UAAU;oBACjC,QAAQ,EAAE,SAAS;oBACnB,IAAI,EAAE,iDAAiD;oBACvD,SAAS,EAAE,KAAK;oBAChB,KAAK,EAAE,CAAC,SAAS,CAAC;iBACnB;aACF;YACD,sBAAsB,EAAE;gBACtB,SAAS,EAAE;oBACT,IAAI,EAAE,eAAM,CAAC,SAAS,CAAC,UAAU;oBACjC,QAAQ,EAAE,SAAS;oBACnB,IAAI,EAAE,gDAAgD;oBACtD,SAAS,EAAE,KAAK;oBAChB,KAAK,EAAE,CAAC,oBAAoB,CAAC;iBAC9B;aACF;YACD,WAAW,EAAE;gBACX,KAAK,EAAE,EAAE,IAAI,EAAE,IAAI,CAAC,QAAQ,EAAE;gBAC9B,QAAQ,EAAE;oBACR,SAAS,EAAE;wBACT,GAAG,EAAE,2BAA2B;qBACjC;iBACF;gBACD,SAAS,EAAE;oBACT,EAAE,EAAE,MAAM;iBAEX;gBACD,YAAY,EAAE;oBACZ;;;;;;;;;;;;;;CAcT;iBACQ;aACF;SACF,CAAC,CAAC;IACL,CAAC;IAED;;;;;OAKG;IACO,WAAW;QACnB,MAAM,MAAM,GAAG,CAAC,0BAA0B,CAAC,CAAC;QAC5C,IAAI,IAAI,CAAC,OAAO,CAAC,WAAW,EAAE,KAAK,EAAE;YACnC,MAAM,CAAC,IAAI,CAAC,aAAa,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,KAAK,GAAG,CAAC,CAAC;SAC7D;QACD,MAAM,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,mBAAmB,EAAE,CAAC,CAAC;QAE3C,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;QAC/B,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC;YAClB,KAAK,EAAE;gBACL,OAAO,EAAE,CAAC,WAAW,EAAE,gBAAgB,CAAC;gBACxC,KAAK,EAAE,OAAO;gBACd,IAAI,EAAE,IAAI,CAAC,OAAO,CAAC,UAAU,EAAE,KAAK,IAAI,IAAI,CAAC,OAAO,CAAC,UAAU,EAAE,OAAO;gBACxE,MAAM;aACP;SACF,CAAC,CAAC;IACL,CAAC;IAED;;;;;OAKG;IACO,iBAAiB;QACzB,MAAM,MAAM,GAAG,CAAC,8BAA8B,CAAC,CAAC;QAChD,IAAI,IAAI,CAAC,OAAO,CAAC,WAAW,EAAE,eAAe,EAAE;YAC7C,MAAM,CAAC,IAAI,CAAC,aAAa,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,eAAe,GAAG,CAAC,CAAC;SACvE;QACD,MAAM,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,sBAAsB,CAAC,IAAI,CAAC,uBAAuB,CAAC,CAAC,CAAC;QAE1E,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,gBAAgB,CAAC,CAAC;QACxC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC;YAClB,cAAc,EAAE;gBACd,OAAO,EAAE,CAAC,WAAW,CAAC;gBACtB,KAAK,EAAE,gBAAgB;gBACvB,IAAI,EAAE,IAAI,CAAC,OAAO,CAAC,UAAU,EAAE,eAAe,IAAI,IAAI,CAAC,OAAO,CAAC,UAAU,EAAE,OAAO;gBAClF,KAAK,EAAE,CAAC,EAAE,GAAG,EAAE,OAAO,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC;gBAC1C,MAAM;aACP;SACF,CAAC,CAAC;IACL,CAAC;IAED;;;;;;;OAOG;IACO,gBAAgB,CAAC,KAAsB;QAC/C,MAAM,MAAM,GAAG,EAAE,CAAC;QAClB,MAAM,CAAC,IAAI,CAAC,aAAa,IAAI,CAAC,OAAO,CAAC,WAAW,EAAE,UAAU,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,OAAO,CAAC,WAAW,EAAE,OAAO,GAAG,CAAC,CAAC;QACrH,MAAM,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,qBAAqB,EAAE,CAAC,CAAC;QAE7C,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;QAClC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC;YAClB,CAAC,QAAQ,KAAK,CAAC,IAAI,EAAE,CAAC,EAAE;gBACtB,OAAO,EAAE,CAAC,WAAW,CAAC;gBACtB,KAAK,EAAE,KAAK,CAAC,IAAI;gBACjB,IAAI,EAAE,IAAI,CAAC,OAAO,CAAC,UAAU,EAAE,IAAI,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,OAAO,CAAC,UAAU,EAAE,UAAU,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,OAAO,CAAC,UAAU,EAAE,OAAO;gBAC1I,IAAI,EAAE;oBACJ,IAAI,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC;iBACxB;gBACD,KAAK,EAAE;oBACL,EAAE,GAAG,EAAE,OAAO,EAAE,SAAS,EAAE,IAAI,EAAE;oBACjC,EAAE,GAAG,EAAE,gBAAgB,EAAE;iBAC1B;gBACD,MAAM,EAAE;oBACN,aAAa,IAAI,CAAC,OAAO,CAAC,WAAW,EAAE,IAAI,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,OAAO,CAAC,WAAW,EAAE,UAAU,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,OAAO,CAAC,WAAW,EAAE,OAAO,GAAG;oBACvJ,GAAG,IAAI,CAAC,qBAAqB,EAAE;oBAC/B,GAAG,IAAI,CAAC,kBAAkB,CAAC,KAAK,CAAC,IAAI,CAAC;iBACvC;aACF;YACD,CAAC,UAAU,KAAK,CAAC,IAAI,EAAE,CAAC,EAAE;gBACxB,OAAO,EAAE,CAAC,WAAW,EAAE,sBAAsB,CAAC;gBAC9C,KAAK,EAAE,KAAK,CAAC,IAAI;gBACjB,IAAI,EAAE,IAAI,CAAC,OAAO,CAAC,UAAU,EAAE,UAAU,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,OAAO,CAAC,UAAU,EAAE,OAAO;gBAC3F,GAAG,KAAK,CAAC,cAAc,IAAI;oBACzB,IAAI,EAAE,eAAM,CAAC,OAAO,CAAC,MAAM;iBAC5B;gBACD,IAAI,EAAE;oBACJ,IAAI,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC;iBACxB;gBACD,KAAK,EAAE;oBACL,EAAE,GAAG,EAAE,OAAO,EAAE,SAAS,EAAE,IAAI,EAAE;oBACjC,EAAE,GAAG,EAAE,gBAAgB,EAAE;oBACzB,EAAE,GAAG,EAAE,QAAQ,KAAK,CAAC,IAAI,EAAE,EAAE;iBAC9B;gBACD,MAAM,EAAE;oBACN,aAAa,IAAI,CAAC,OAAO,CAAC,WAAW,EAAE,UAAU,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,OAAO,CAAC,WAAW,EAAE,OAAO,GAAG;oBACvG,GAAG,IAAI,CAAC,qBAAqB,EAAE;oBAC/B,GAAG,IAAI,CAAC,oBAAoB,CAAC,KAAK,CAAC,IAAI,CAAC;iBACzC;aACF;SACF,CAAC,CAAC;QACH,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;IACzC,CAAC;;AA7MH,8CA+MC","sourcesContent":["import { awscdk, gitlab } from 'projen';\nimport { CDKPipeline, CDKPipelineOptions, DeploymentStage } from './base';\n\n/**\n * Configuration for IAM roles used within the GitLab CI/CD pipeline for various stages.\n * Allows specifying different IAM roles for synthesis, asset publishing, and deployment stages,\n * providing granular control over permissions.\n */\nexport interface GitlabIamRoleConfig {\n  /** Default IAM role ARN used if specific stage role is not provided. */\n  readonly default?: string;\n  /** IAM role ARN for the synthesis stage. */\n  readonly synth?: string;\n  /** IAM role ARN for the asset publishing stage. */\n  readonly assetPublishing?: string;\n  /** A map of stage names to IAM role ARNs for the diff operation. */\n  readonly diff?: { [stage: string]: string };\n  /** A map of stage names to IAM role ARNs for the deployment operation. */\n  readonly deployment?: { [stage: string]: string };\n}\n\n/**\n * Configuration for GitLab runner tags used within the CI/CD pipeline for various stages.\n * This allows for specifying different runners based on the tags for different stages of the pipeline.\n */\nexport interface GitlabRunnerTags {\n  /** Default runner tags used if specific stage tags are not provided. */\n  readonly default?: string[];\n  /** Runner tags for the synthesis stage. */\n  readonly synth?: string[];\n  /** Runner tags for the asset publishing stage. */\n  readonly assetPublishing?: string[];\n  /** A map of stage names to runner tags for the diff operation. */\n  readonly diff?: { [stage: string]: string[] };\n  /** A map of stage names to runner tags for the deployment operation. */\n  readonly deployment?: { [stage: string]: string[] };\n}\n\n/**\n * Options for configuring the GitLab CDK pipeline, extending the base CDK pipeline options.\n */\nexport interface GitlabCDKPipelineOptions extends CDKPipelineOptions {\n  /** IAM role ARNs configuration for the pipeline. */\n  readonly iamRoleArns: GitlabIamRoleConfig;\n  /** Runner tags configuration for the pipeline. */\n  readonly runnerTags?: GitlabRunnerTags;\n  /** The Docker image to use for running the pipeline jobs. */\n  readonly image?: string;\n\n  // readonly publishedCloudAssemblies?: boolean;\n}\n\n/**\n * The GitlabCDKPipeline class extends CDKPipeline to provide a way to configure and execute\n * AWS CDK deployment pipelines within GitLab CI/CD environments. It integrates IAM role management,\n * runner configuration, and defines stages and jobs for the deployment workflow.\n */\nexport class GitlabCDKPipeline extends CDKPipeline {\n\n  /** Indicates if versioned artifacts are required. Currently set to false  */\n  public readonly needsVersionedArtifacts: boolean;\n\n  /** The Docker image used for pipeline jobs. Defaults to a specified image or a default value. */\n  public readonly jobImage: string;\n\n  /** GitLab CI/CD configuration object. */\n  public readonly config: gitlab.GitlabConfiguration;\n\n  /** List of deployment stages as strings. */\n  private deploymentStages: string[] = [];\n\n  /**\n   * Constructs an instance of GitlabCDKPipeline, initializing the GitLab CI/CD configuration\n   * and setting up the necessary stages and jobs for AWS CDK deployment.\n   *\n   * @param {awscdk.AwsCdkTypeScriptApp} app - The AWS CDK app associated with the pipeline.\n   * @param {GitlabCDKPipelineOptions} options - Configuration options for the pipeline.\n   */\n  constructor(app: awscdk.AwsCdkTypeScriptApp, private options: GitlabCDKPipelineOptions) {\n    super(app, options);\n\n    // TODO use existing config if possible\n    this.config = new gitlab.GitlabConfiguration(app, {\n      stages: [],\n      jobs: {},\n    });\n\n    this.needsVersionedArtifacts = false; // options.publishedCloudAssemblies ?? false;\n    this.jobImage = options.image ?? 'image: jsii/superchain:1-buster-slim-node18';\n\n    this.setupSnippets();\n\n    this.createSynth();\n\n    this.createAssetUpload();\n\n    for (const stage of options.stages) {\n      this.createDeployment(stage);\n    }\n  }\n\n  /**\n   * Sets up base job snippets for artifact handling and AWS configuration.\n   * This method defines reusable job configurations to be extended by specific pipeline jobs,\n   * facilitating artifact caching and AWS authentication setup.\n   */\n  protected setupSnippets() {\n    this.config.addJobs({\n      '.artifacts_cdk': {\n        artifacts: {\n          when: gitlab.CacheWhen.ON_SUCCESS,\n          expireIn: '30 days',\n          name: 'CDK Assembly - $CI_JOB_NAME-$CI_COMMIT_REF_SLUG',\n          untracked: false,\n          paths: ['cdk.out'],\n        },\n      },\n      '.artifacts_cdkdeploy': {\n        artifacts: {\n          when: gitlab.CacheWhen.ON_SUCCESS,\n          expireIn: '30 days',\n          name: 'CDK Outputs - $CI_JOB_NAME-$CI_COMMIT_REF_SLUG',\n          untracked: false,\n          paths: ['cdk-outputs-*.json'],\n        },\n      },\n      '.aws_base': {\n        image: { name: this.jobImage },\n        idTokens: {\n          AWS_TOKEN: {\n            aud: 'https://sts.amazonaws.com',\n          },\n        },\n        variables: {\n          CI: 'true',\n          // NPM_REGISTRY: 'xxx'\n        },\n        beforeScript: [\n          `check_variables_defined() {\n  for var in \"$@\"; do\n    if [ -z \"$(eval \"echo \\\\$$var\")\" ]; then\n      log_fatal \"\\${var} not defined\";\n    fi\n  done\n}\n\nawslogin() {\n  roleArn=\\${1: -\\${AWS_ROLE_ARN}}\n  check_variables_defined roleArn AWS_TOKEN\n  export $(printf \"AWS_ACCESS_KEY_ID=%s AWS_SECRET_ACCESS_KEY=%s AWS_SESSION_TOKEN=%s\" $(aws sts assume-role-with-web-identity --role-arn \\${roleArn} --role-session-name \"GitLabRunner-\\${CI_PROJECT_ID}-\\${CI_PIPELINE_ID}\" --web-identity-token \\${AWS_TOKEN} --duration-seconds 3600 --query 'Credentials.[AccessKeyId,SecretAccessKey,SessionToken]' --output text))\n  # TODO CODE ARTIFACT\n}\n`,\n        ],\n      },\n    });\n  }\n\n  /**\n   * Creates the 'synth' stage of the pipeline to synthesize AWS CDK applications.\n   * This method configures the job to execute CDK synthesis, applying the appropriate IAM role\n   * for AWS commands and specifying runner tags for job execution. The synthesized outputs are\n   * configured to be cached as artifacts.\n   */\n  protected createSynth(): void {\n    const script = ['echo \"Running CDK synth\"'];\n    if (this.options.iamRoleArns?.synth) {\n      script.push(`awslogin '${this.options.iamRoleArns.synth}'`);\n    }\n    script.push(...this.renderSynthCommands());\n\n    this.config.addStages('synth');\n    this.config.addJobs({\n      synth: {\n        extends: ['.aws_base', '.artifacts_cdk'],\n        stage: 'synth',\n        tags: this.options.runnerTags?.synth ?? this.options.runnerTags?.default,\n        script,\n      },\n    });\n  }\n\n  /**\n   * Sets up the asset publishing stage of the pipeline.\n   * This method configures a job to upload synthesized assets to AWS, handling IAM role\n   * authentication and specifying runner tags. It depends on the successful completion\n   * of the 'synth' stage, ensuring assets are only published after successful synthesis.\n   */\n  protected createAssetUpload(): void {\n    const script = ['echo \"Publish assets to AWS\"'];\n    if (this.options.iamRoleArns?.assetPublishing) {\n      script.push(`awslogin '${this.options.iamRoleArns.assetPublishing}'`);\n    }\n    script.push(...this.getAssetUploadCommands(this.needsVersionedArtifacts));\n\n    this.config.addStages('publish_assets');\n    this.config.addJobs({\n      publish_assets: {\n        extends: ['.aws_base'],\n        stage: 'publish_assets',\n        tags: this.options.runnerTags?.assetPublishing ?? this.options.runnerTags?.default,\n        needs: [{ job: 'synth', artifacts: true }],\n        script,\n      },\n    });\n  }\n\n  /**\n   * Dynamically creates deployment stages based on the deployment configuration.\n   * For each provided deployment stage, this method sets up jobs for 'diff' and 'deploy' actions,\n   * applying the correct IAM roles and runner tags. It supports conditional manual approval for\n   * deployment stages, providing flexibility in the deployment workflow.\n   *\n   * @param {DeploymentStage} stage - The deployment stage configuration to set up.\n   */\n  protected createDeployment(stage: DeploymentStage): void {\n    const script = [];\n    script.push(`awslogin '${this.options.iamRoleArns?.deployment?.[stage.name] ?? this.options.iamRoleArns?.default}'`);\n    script.push(...this.renderInstallCommands());\n\n    this.config.addStages(stage.name);\n    this.config.addJobs({\n      [`diff-${stage.name}`]: {\n        extends: ['.aws_base'],\n        stage: stage.name,\n        tags: this.options.runnerTags?.diff?.[stage.name] ?? this.options.runnerTags?.deployment?.[stage.name] ?? this.options.runnerTags?.default,\n        only: {\n          refs: [this.branchName],\n        },\n        needs: [\n          { job: 'synth', artifacts: true },\n          { job: 'publish_assets' },\n        ],\n        script: [\n          `awslogin '${this.options.iamRoleArns?.diff?.[stage.name] ?? this.options.iamRoleArns?.deployment?.[stage.name] ?? this.options.iamRoleArns?.default}'`,\n          ...this.renderInstallCommands(),\n          ...this.renderDiffCommands(stage.name),\n        ],\n      },\n      [`deploy-${stage.name}`]: {\n        extends: ['.aws_base', '.artifacts_cdkdeploy'],\n        stage: stage.name,\n        tags: this.options.runnerTags?.deployment?.[stage.name] ?? this.options.runnerTags?.default,\n        ...stage.manualApproval && {\n          when: gitlab.JobWhen.MANUAL,\n        },\n        only: {\n          refs: [this.branchName],\n        },\n        needs: [\n          { job: 'synth', artifacts: true },\n          { job: 'publish_assets' },\n          { job: `diff-${stage.name}` },\n        ],\n        script: [\n          `awslogin '${this.options.iamRoleArns?.deployment?.[stage.name] ?? this.options.iamRoleArns?.default}'`,\n          ...this.renderInstallCommands(),\n          ...this.renderDeployCommands(stage.name),\n        ],\n      },\n    });\n    this.deploymentStages.push(stage.name);\n  }\n\n}\n\n"]}
223
+ GitlabCDKPipeline[_a] = { fqn: "projen-pipelines.GitlabCDKPipeline", version: "0.0.57" };
224
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gitlab.js","sourceRoot":"","sources":["../../src/awscdk/gitlab.ts"],"names":[],"mappings":"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","sourcesContent":["import { awscdk, gitlab } from 'projen';\nimport { CDKPipeline, CDKPipelineOptions, DeploymentStage } from './base';\nimport { PipelineEngine } from '../engine';\n\n/**\n * Configuration for IAM roles used within the GitLab CI/CD pipeline for various stages.\n * Allows specifying different IAM roles for synthesis, asset publishing, and deployment stages,\n * providing granular control over permissions.\n */\nexport interface GitlabIamRoleConfig {\n  /** Default IAM role ARN used if specific stage role is not provided. */\n  readonly default?: string;\n  /** IAM role ARN for the synthesis stage. */\n  readonly synth?: string;\n  /** IAM role ARN for the asset publishing stage. */\n  readonly assetPublishing?: string;\n  /** A map of stage names to IAM role ARNs for the diff operation. */\n  readonly diff?: { [stage: string]: string };\n  /** A map of stage names to IAM role ARNs for the deployment operation. */\n  readonly deployment?: { [stage: string]: string };\n}\n\n/**\n * Configuration for GitLab runner tags used within the CI/CD pipeline for various stages.\n * This allows for specifying different runners based on the tags for different stages of the pipeline.\n */\nexport interface GitlabRunnerTags {\n  /** Default runner tags used if specific stage tags are not provided. */\n  readonly default?: string[];\n  /** Runner tags for the synthesis stage. */\n  readonly synth?: string[];\n  /** Runner tags for the asset publishing stage. */\n  readonly assetPublishing?: string[];\n  /** A map of stage names to runner tags for the diff operation. */\n  readonly diff?: { [stage: string]: string[] };\n  /** A map of stage names to runner tags for the deployment operation. */\n  readonly deployment?: { [stage: string]: string[] };\n}\n\n/**\n * Options for configuring the GitLab CDK pipeline, extending the base CDK pipeline options.\n */\nexport interface GitlabCDKPipelineOptions extends CDKPipelineOptions {\n  /** IAM role ARNs configuration for the pipeline. */\n  readonly iamRoleArns: GitlabIamRoleConfig;\n  /** Runner tags configuration for the pipeline. */\n  readonly runnerTags?: GitlabRunnerTags;\n  /** The Docker image to use for running the pipeline jobs. */\n  readonly image?: string;\n\n  // readonly publishedCloudAssemblies?: boolean;\n}\n\n/**\n * The GitlabCDKPipeline class extends CDKPipeline to provide a way to configure and execute\n * AWS CDK deployment pipelines within GitLab CI/CD environments. It integrates IAM role management,\n * runner configuration, and defines stages and jobs for the deployment workflow.\n */\nexport class GitlabCDKPipeline extends CDKPipeline {\n\n  /** Indicates if versioned artifacts are required. Currently set to false  */\n  public readonly needsVersionedArtifacts: boolean;\n\n  /** The Docker image used for pipeline jobs. Defaults to a specified image or a default value. */\n  public readonly jobImage: string;\n\n  /** GitLab CI/CD configuration object. */\n  public readonly config: gitlab.GitlabConfiguration;\n\n  /** List of deployment stages as strings. */\n  private deploymentStages: string[] = [];\n\n  /**\n   * Constructs an instance of GitlabCDKPipeline, initializing the GitLab CI/CD configuration\n   * and setting up the necessary stages and jobs for AWS CDK deployment.\n   *\n   * @param {awscdk.AwsCdkTypeScriptApp} app - The AWS CDK app associated with the pipeline.\n   * @param {GitlabCDKPipelineOptions} options - Configuration options for the pipeline.\n   */\n  constructor(app: awscdk.AwsCdkTypeScriptApp, private options: GitlabCDKPipelineOptions) {\n    super(app, options);\n\n    // TODO use existing config if possible\n    this.config = new gitlab.GitlabConfiguration(app, {\n      stages: [],\n      jobs: {},\n    });\n\n    this.needsVersionedArtifacts = false; // options.publishedCloudAssemblies ?? false;\n    this.jobImage = options.image ?? 'image: jsii/superchain:1-buster-slim-node18';\n\n    this.setupSnippets();\n\n    this.createSynth();\n\n    this.createAssetUpload();\n\n    for (const stage of options.stages) {\n      this.createDeployment(stage);\n    }\n  }\n\n  /**\n   * Sets up base job snippets for artifact handling and AWS configuration.\n   * This method defines reusable job configurations to be extended by specific pipeline jobs,\n   * facilitating artifact caching and AWS authentication setup.\n   */\n  protected setupSnippets() {\n    this.config.addJobs({\n      '.artifacts_cdk': {\n        artifacts: {\n          when: gitlab.CacheWhen.ON_SUCCESS,\n          expireIn: '30 days',\n          name: 'CDK Assembly - $CI_JOB_NAME-$CI_COMMIT_REF_SLUG',\n          untracked: false,\n          paths: ['cdk.out'],\n        },\n      },\n      '.artifacts_cdkdeploy': {\n        artifacts: {\n          when: gitlab.CacheWhen.ON_SUCCESS,\n          expireIn: '30 days',\n          name: 'CDK Outputs - $CI_JOB_NAME-$CI_COMMIT_REF_SLUG',\n          untracked: false,\n          paths: ['cdk-outputs-*.json'],\n        },\n      },\n      '.aws_base': {\n        image: { name: this.jobImage },\n        idTokens: {\n          AWS_TOKEN: {\n            aud: 'https://sts.amazonaws.com',\n          },\n        },\n        variables: {\n          CI: 'true',\n          // NPM_REGISTRY: 'xxx'\n        },\n        beforeScript: [\n          `check_variables_defined() {\n  for var in \"$@\"; do\n    if [ -z \"$(eval \"echo \\\\$$var\")\" ]; then\n      log_fatal \"\\${var} not defined\";\n    fi\n  done\n}\n\nawslogin() {\n  roleArn=\\${1: -\\${AWS_ROLE_ARN}}\n  check_variables_defined roleArn AWS_TOKEN\n  export $(printf \"AWS_ACCESS_KEY_ID=%s AWS_SECRET_ACCESS_KEY=%s AWS_SESSION_TOKEN=%s\" $(aws sts assume-role-with-web-identity --role-arn \\${roleArn} --role-session-name \"GitLabRunner-\\${CI_PROJECT_ID}-\\${CI_PIPELINE_ID}\" --web-identity-token \\${AWS_TOKEN} --duration-seconds 3600 --query 'Credentials.[AccessKeyId,SecretAccessKey,SessionToken]' --output text))\n  # TODO CODE ARTIFACT\n}\n`,\n        ],\n      },\n    });\n  }\n\n  /**\n   * Creates the 'synth' stage of the pipeline to synthesize AWS CDK applications.\n   * This method configures the job to execute CDK synthesis, applying the appropriate IAM role\n   * for AWS commands and specifying runner tags for job execution. The synthesized outputs are\n   * configured to be cached as artifacts.\n   */\n  protected createSynth(): void {\n    const script = ['echo \"Running CDK synth\"'];\n    if (this.options.iamRoleArns?.synth) {\n      script.push(`awslogin '${this.options.iamRoleArns.synth}'`);\n    }\n    const extensions = ['.aws_base', '.artifacts_cdk'];\n    const needs = [];\n\n    const preInstallSteps = (this.options.preInstallSteps ?? []).map(s => s.toGitlab());\n    script.push(...preInstallSteps.flatMap(s => s.commands));\n    extensions.push(...preInstallSteps.flatMap(s => s.extensions));\n    needs.push(...preInstallSteps.flatMap(s => s.needs));\n\n    script.push(...this.renderInstallCommands());\n\n    const preSynthSteps = (this.options.preSynthSteps ?? []).map(s => s.toGitlab());\n    script.push(...preSynthSteps.flatMap(s => s.commands));\n    extensions.push(...preSynthSteps.flatMap(s => s.extensions));\n    needs.push(...preSynthSteps.flatMap(s => s.needs));\n\n    script.push(...this.renderSynthCommands());\n\n    const postSynthSteps = (this.options.postSynthSteps ?? []).map(s => s.toGitlab());\n    script.push(...postSynthSteps.flatMap(s => s.commands));\n    extensions.push(...postSynthSteps.flatMap(s => s.extensions));\n    needs.push(...postSynthSteps.flatMap(s => s.needs));\n\n    this.config.addStages('synth');\n    this.config.addJobs({\n      synth: {\n        extends: extensions,\n        needs: needs,\n        stage: 'synth',\n        tags: this.options.runnerTags?.synth ?? this.options.runnerTags?.default,\n        script,\n      },\n    });\n  }\n\n  /**\n   * Sets up the asset publishing stage of the pipeline.\n   * This method configures a job to upload synthesized assets to AWS, handling IAM role\n   * authentication and specifying runner tags. It depends on the successful completion\n   * of the 'synth' stage, ensuring assets are only published after successful synthesis.\n   */\n  protected createAssetUpload(): void {\n    const script = ['echo \"Publish assets to AWS\"'];\n    if (this.options.iamRoleArns?.assetPublishing) {\n      script.push(`awslogin '${this.options.iamRoleArns.assetPublishing}'`);\n    }\n    const preInstallSteps = (this.options.preInstallSteps ?? []).map(s => s.toGitlab());\n    script.push(...preInstallSteps.flatMap(s => s.commands));\n\n    script.push(...this.renderInstallCommands());\n    script.push(...this.getAssetUploadCommands(this.needsVersionedArtifacts));\n\n    this.config.addStages('publish_assets');\n    this.config.addJobs({\n      publish_assets: {\n        extends: ['.aws_base', ...preInstallSteps.flatMap(s => s.extensions)],\n        stage: 'publish_assets',\n        tags: this.options.runnerTags?.assetPublishing ?? this.options.runnerTags?.default,\n        needs: [{ job: 'synth', artifacts: true }, ...preInstallSteps.flatMap(s => s.needs)],\n        script,\n      },\n    });\n  }\n\n  /**\n   * Dynamically creates deployment stages based on the deployment configuration.\n   * For each provided deployment stage, this method sets up jobs for 'diff' and 'deploy' actions,\n   * applying the correct IAM roles and runner tags. It supports conditional manual approval for\n   * deployment stages, providing flexibility in the deployment workflow.\n   *\n   * @param {DeploymentStage} stage - The deployment stage configuration to set up.\n   */\n  protected createDeployment(stage: DeploymentStage): void {\n    const preInstallSteps = (this.options.preInstallSteps ?? []).map(s => s.toGitlab());\n\n    this.config.addStages(stage.name);\n    this.config.addJobs({\n      [`diff-${stage.name}`]: {\n        extends: ['.aws_base', ...preInstallSteps.flatMap(s => s.extensions)],\n        stage: stage.name,\n        tags: this.options.runnerTags?.diff?.[stage.name] ?? this.options.runnerTags?.deployment?.[stage.name] ?? this.options.runnerTags?.default,\n        only: {\n          refs: [this.branchName],\n        },\n        needs: [\n          { job: 'synth', artifacts: true },\n          { job: 'publish_assets' },\n          ...preInstallSteps.flatMap(s => s.needs),\n        ],\n        script: [\n          `awslogin '${this.options.iamRoleArns?.diff?.[stage.name] ?? this.options.iamRoleArns?.deployment?.[stage.name] ?? this.options.iamRoleArns?.default}'`,\n          ...preInstallSteps.flatMap(s => s.commands),\n          ...this.renderInstallCommands(),\n          ...this.renderDiffCommands(stage.name),\n        ],\n\n      },\n      [`deploy-${stage.name}`]: {\n        extends: ['.aws_base', '.artifacts_cdkdeploy', ...preInstallSteps.flatMap(s => s.extensions)],\n        stage: stage.name,\n        tags: this.options.runnerTags?.deployment?.[stage.name] ?? this.options.runnerTags?.default,\n        ...stage.manualApproval && {\n          when: gitlab.JobWhen.MANUAL,\n        },\n        only: {\n          refs: [this.branchName],\n        },\n        needs: [\n          { job: 'synth', artifacts: true },\n          { job: 'publish_assets' },\n          { job: `diff-${stage.name}` },\n          ...preInstallSteps.flatMap(s => s.needs),\n        ],\n        script: [\n          `awslogin '${this.options.iamRoleArns?.deployment?.[stage.name] ?? this.options.iamRoleArns?.default}'`,\n          ...preInstallSteps.flatMap(s => s.commands),\n          ...this.renderInstallCommands(),\n          ...this.renderDeployCommands(stage.name),\n        ],\n      },\n    });\n    this.deploymentStages.push(stage.name);\n  }\n\n  public engineType(): PipelineEngine {\n    return PipelineEngine.GITLAB;\n  }\n\n}\n\n"]}
@@ -0,0 +1,12 @@
1
+ /**
2
+ * The CI/CD tooling used to run your pipeline.
3
+ * The component will render workflows for the given system
4
+ */
5
+ export declare enum PipelineEngine {
6
+ /** Create GitHub actions */
7
+ GITHUB = 0,
8
+ /** Create a .gitlab-ci.yaml file */
9
+ GITLAB = 1,
10
+ /** Create bash scripts */
11
+ BASH = 2
12
+ }
package/lib/engine.js ADDED
@@ -0,0 +1,19 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.PipelineEngine = void 0;
4
+ /**
5
+ * The CI/CD tooling used to run your pipeline.
6
+ * The component will render workflows for the given system
7
+ */
8
+ var PipelineEngine;
9
+ (function (PipelineEngine) {
10
+ /** Create GitHub actions */
11
+ PipelineEngine[PipelineEngine["GITHUB"] = 0] = "GITHUB";
12
+ /** Create a .gitlab-ci.yaml file */
13
+ PipelineEngine[PipelineEngine["GITLAB"] = 1] = "GITLAB";
14
+ // /** Create AWS CodeCatalyst workflows */
15
+ // CODE_CATALYST,
16
+ /** Create bash scripts */
17
+ PipelineEngine[PipelineEngine["BASH"] = 2] = "BASH";
18
+ })(PipelineEngine = exports.PipelineEngine || (exports.PipelineEngine = {}));
19
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW5naW5lLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL2VuZ2luZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFDQTs7O0dBR0c7QUFDSCxJQUFZLGNBU1g7QUFURCxXQUFZLGNBQWM7SUFDeEIsNEJBQTRCO0lBQzVCLHVEQUFNLENBQUE7SUFDTixvQ0FBb0M7SUFDcEMsdURBQU0sQ0FBQTtJQUNOLDJDQUEyQztJQUMzQyxpQkFBaUI7SUFDakIsMEJBQTBCO0lBQzFCLG1EQUFJLENBQUE7QUFDTixDQUFDLEVBVFcsY0FBYyxHQUFkLHNCQUFjLEtBQWQsc0JBQWMsUUFTekIiLCJzb3VyY2VzQ29udGVudCI6WyJcbi8qKlxuICogVGhlIENJL0NEIHRvb2xpbmcgdXNlZCB0byBydW4geW91ciBwaXBlbGluZS5cbiAqIFRoZSBjb21wb25lbnQgd2lsbCByZW5kZXIgd29ya2Zsb3dzIGZvciB0aGUgZ2l2ZW4gc3lzdGVtXG4gKi9cbmV4cG9ydCBlbnVtIFBpcGVsaW5lRW5naW5lIHtcbiAgLyoqIENyZWF0ZSBHaXRIdWIgYWN0aW9ucyAqL1xuICBHSVRIVUIsXG4gIC8qKiBDcmVhdGUgYSAuZ2l0bGFiLWNpLnlhbWwgZmlsZSAqL1xuICBHSVRMQUIsXG4gIC8vIC8qKiBDcmVhdGUgQVdTIENvZGVDYXRhbHlzdCB3b3JrZmxvd3MgKi9cbiAgLy8gQ09ERV9DQVRBTFlTVCxcbiAgLyoqIENyZWF0ZSBiYXNoIHNjcmlwdHMgKi9cbiAgQkFTSCxcbn0iXX0=
package/lib/index.d.ts CHANGED
@@ -1 +1,3 @@
1
+ export * from './engine';
2
+ export * from './steps';
1
3
  export * from './awscdk';
package/lib/index.js CHANGED
@@ -10,5 +10,7 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
10
10
  for (var p in m) if (p !== "default" && !exports.hasOwnProperty(p)) __createBinding(exports, m, p);
11
11
  };
12
12
  Object.defineProperty(exports, "__esModule", { value: true });
13
+ __exportStar(require("./engine"), exports);
14
+ __exportStar(require("./steps"), exports);
13
15
  __exportStar(require("./awscdk"), exports);
14
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7O0FBQUEsMkNBQXlCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9hd3NjZGsnOyJdfQ==
16
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7O0FBQUEsMkNBQXlCO0FBQ3pCLDBDQUF3QjtBQUN4QiwyQ0FBeUIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2VuZ2luZSc7XG5leHBvcnQgKiBmcm9tICcuL3N0ZXBzJztcbmV4cG9ydCAqIGZyb20gJy4vYXdzY2RrJzsiXX0=
@@ -0,0 +1 @@
1
+ export * from './step';
@@ -0,0 +1,14 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
5
+ }) : (function(o, m, k, k2) {
6
+ if (k2 === undefined) k2 = k;
7
+ o[k2] = m[k];
8
+ }));
9
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
10
+ for (var p in m) if (p !== "default" && !exports.hasOwnProperty(p)) __createBinding(exports, m, p);
11
+ };
12
+ Object.defineProperty(exports, "__esModule", { value: true });
13
+ __exportStar(require("./step"), exports);
14
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvc3RlcHMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7O0FBQUEseUNBQXVCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9zdGVwJzsiXX0=
@@ -0,0 +1,77 @@
1
+ import { Project } from 'projen';
2
+ import { JobStep } from 'projen/lib/github/workflows-model';
3
+ import { Need } from 'projen/lib/gitlab';
4
+ /**
5
+ * Configuration interface for a GitLab CI step.
6
+ */
7
+ export interface GitlabStepConfig {
8
+ /** List of job extensions related to the step. */
9
+ readonly extensions: string[];
10
+ /** Dependencies which need to be completed before this step. */
11
+ readonly needs: Need[];
12
+ /** Shell commands to execute in this step. */
13
+ readonly commands: string[];
14
+ }
15
+ /**
16
+ * Configuration interface for a GitHub Actions step.
17
+ */
18
+ export interface GithubStepConfig {
19
+ /** Dependencies which need to be completed before this step. */
20
+ readonly needs: string[];
21
+ /** Commands wrapped as GitHub Action job steps. */
22
+ readonly steps: JobStep[];
23
+ }
24
+ /**
25
+ * Configuration interface for a bash script step.
26
+ */
27
+ export interface BashStepConfig {
28
+ /** Shell commands to execute. */
29
+ readonly commands: string[];
30
+ }
31
+ /**
32
+ * Abstract class defining the structure of a pipeline step.
33
+ */
34
+ export declare abstract class PipelineStep {
35
+ protected project: Project;
36
+ /**
37
+ * Initializes a new instance of a PipelineStep with a reference to a projen project.
38
+ * @param project - The projen project reference.
39
+ */
40
+ constructor(project: Project);
41
+ /**
42
+ * Generates a configuration for a GitLab CI step. Must be implemented by subclasses.
43
+ */
44
+ abstract toGitlab(): GitlabStepConfig;
45
+ /**
46
+ * Generates a configuration for a GitHub Actions step. Must be implemented by subclasses.
47
+ */
48
+ abstract toGithub(): GithubStepConfig;
49
+ /**
50
+ * Generates a configuration for a bash script step. Must be implemented by subclasses.
51
+ */
52
+ abstract toBash(): BashStepConfig;
53
+ }
54
+ /**
55
+ * Concrete implementation of PipelineStep that executes simple commands.
56
+ */
57
+ export declare class SimpleCommandStep extends PipelineStep {
58
+ protected commands: string[];
59
+ /**
60
+ * Constructs a simple command step with a specified set of commands.
61
+ * @param project - The projen project reference.
62
+ * @param commands - Shell commands to execute.
63
+ */
64
+ constructor(project: Project, commands: string[]);
65
+ /**
66
+ * Converts the step into a GitLab CI configuration.
67
+ */
68
+ toGitlab(): GitlabStepConfig;
69
+ /**
70
+ * Converts the step into a Bash script configuration.
71
+ */
72
+ toBash(): BashStepConfig;
73
+ /**
74
+ * Converts the step into a GitHub Actions step configuration.
75
+ */
76
+ toGithub(): GithubStepConfig;
77
+ }
@@ -0,0 +1,66 @@
1
+ "use strict";
2
+ var _a, _b;
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.SimpleCommandStep = exports.PipelineStep = void 0;
5
+ const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
6
+ /**
7
+ * Abstract class defining the structure of a pipeline step.
8
+ */
9
+ class PipelineStep {
10
+ /**
11
+ * Initializes a new instance of a PipelineStep with a reference to a projen project.
12
+ * @param project - The projen project reference.
13
+ */
14
+ constructor(project) {
15
+ this.project = project;
16
+ // Constructor can be extended to include more setup logic.
17
+ }
18
+ }
19
+ exports.PipelineStep = PipelineStep;
20
+ _a = JSII_RTTI_SYMBOL_1;
21
+ PipelineStep[_a] = { fqn: "projen-pipelines.PipelineStep", version: "0.0.57" };
22
+ /**
23
+ * Concrete implementation of PipelineStep that executes simple commands.
24
+ */
25
+ class SimpleCommandStep extends PipelineStep {
26
+ /**
27
+ * Constructs a simple command step with a specified set of commands.
28
+ * @param project - The projen project reference.
29
+ * @param commands - Shell commands to execute.
30
+ */
31
+ constructor(project, commands) {
32
+ super(project);
33
+ this.commands = commands;
34
+ }
35
+ /**
36
+ * Converts the step into a GitLab CI configuration.
37
+ */
38
+ toGitlab() {
39
+ return {
40
+ extensions: [],
41
+ commands: this.commands,
42
+ needs: [],
43
+ };
44
+ }
45
+ /**
46
+ * Converts the step into a Bash script configuration.
47
+ */
48
+ toBash() {
49
+ return {
50
+ commands: this.commands,
51
+ };
52
+ }
53
+ /**
54
+ * Converts the step into a GitHub Actions step configuration.
55
+ */
56
+ toGithub() {
57
+ return {
58
+ needs: [],
59
+ steps: this.commands.map(c => ({ run: c })),
60
+ };
61
+ }
62
+ }
63
+ exports.SimpleCommandStep = SimpleCommandStep;
64
+ _b = JSII_RTTI_SYMBOL_1;
65
+ SimpleCommandStep[_b] = { fqn: "projen-pipelines.SimpleCommandStep", version: "0.0.57" };
66
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RlcC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9zdGVwcy9zdGVwLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBd0NBOztHQUVHO0FBQ0gsTUFBc0IsWUFBWTtJQUVoQzs7O09BR0c7SUFDSCxZQUFzQixPQUFnQjtRQUFoQixZQUFPLEdBQVAsT0FBTyxDQUFTO1FBQ3BDLDJEQUEyRDtJQUM3RCxDQUFDOztBQVJILG9DQXdCQzs7O0FBRUQ7O0dBRUc7QUFDSCxNQUFhLGlCQUFrQixTQUFRLFlBQVk7SUFFakQ7Ozs7T0FJRztJQUNILFlBQVksT0FBZ0IsRUFBWSxRQUFrQjtRQUN4RCxLQUFLLENBQUMsT0FBTyxDQUFDLENBQUM7UUFEdUIsYUFBUSxHQUFSLFFBQVEsQ0FBVTtJQUUxRCxDQUFDO0lBRUQ7O09BRUc7SUFDSSxRQUFRO1FBQ2IsT0FBTztZQUNMLFVBQVUsRUFBRSxFQUFFO1lBQ2QsUUFBUSxFQUFFLElBQUksQ0FBQyxRQUFRO1lBQ3ZCLEtBQUssRUFBRSxFQUFFO1NBQ1YsQ0FBQztJQUNKLENBQUM7SUFFRDs7T0FFRztJQUNJLE1BQU07UUFDWCxPQUFPO1lBQ0wsUUFBUSxFQUFFLElBQUksQ0FBQyxRQUFRO1NBQ3hCLENBQUM7SUFDSixDQUFDO0lBRUQ7O09BRUc7SUFDSSxRQUFRO1FBQ2IsT0FBTztZQUNMLEtBQUssRUFBRSxFQUFFO1lBQ1QsS0FBSyxFQUFFLElBQUksQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxFQUFFLEdBQUcsRUFBRSxDQUFDLEVBQUUsQ0FBQyxDQUFDO1NBQzVDLENBQUM7SUFDSixDQUFDOztBQXZDSCw4Q0F3Q0MiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQcm9qZWN0IH0gZnJvbSAncHJvamVuJztcbmltcG9ydCB7IEpvYlN0ZXAgfSBmcm9tICdwcm9qZW4vbGliL2dpdGh1Yi93b3JrZmxvd3MtbW9kZWwnO1xuaW1wb3J0IHsgTmVlZCB9IGZyb20gJ3Byb2plbi9saWIvZ2l0bGFiJztcblxuLyoqXG4gKiBDb25maWd1cmF0aW9uIGludGVyZmFjZSBmb3IgYSBHaXRMYWIgQ0kgc3RlcC5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBHaXRsYWJTdGVwQ29uZmlnIHtcblxuICAvKiogTGlzdCBvZiBqb2IgZXh0ZW5zaW9ucyByZWxhdGVkIHRvIHRoZSBzdGVwLiAqL1xuICByZWFkb25seSBleHRlbnNpb25zOiBzdHJpbmdbXTtcblxuICAvKiogRGVwZW5kZW5jaWVzIHdoaWNoIG5lZWQgdG8gYmUgY29tcGxldGVkIGJlZm9yZSB0aGlzIHN0ZXAuICovXG4gIHJlYWRvbmx5IG5lZWRzOiBOZWVkW107XG5cbiAgLyoqIFNoZWxsIGNvbW1hbmRzIHRvIGV4ZWN1dGUgaW4gdGhpcyBzdGVwLiAqL1xuICByZWFkb25seSBjb21tYW5kczogc3RyaW5nW107XG59XG5cbi8qKlxuICogQ29uZmlndXJhdGlvbiBpbnRlcmZhY2UgZm9yIGEgR2l0SHViIEFjdGlvbnMgc3RlcC5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBHaXRodWJTdGVwQ29uZmlnIHtcblxuICAvKiogRGVwZW5kZW5jaWVzIHdoaWNoIG5lZWQgdG8gYmUgY29tcGxldGVkIGJlZm9yZSB0aGlzIHN0ZXAuICovXG4gIHJlYWRvbmx5IG5lZWRzOiBzdHJpbmdbXTtcblxuICAvKiogQ29tbWFuZHMgd3JhcHBlZCBhcyBHaXRIdWIgQWN0aW9uIGpvYiBzdGVwcy4gKi9cbiAgcmVhZG9ubHkgc3RlcHM6IEpvYlN0ZXBbXTtcbn1cblxuLyoqXG4gKiBDb25maWd1cmF0aW9uIGludGVyZmFjZSBmb3IgYSBiYXNoIHNjcmlwdCBzdGVwLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIEJhc2hTdGVwQ29uZmlnIHtcblxuICAvKiogU2hlbGwgY29tbWFuZHMgdG8gZXhlY3V0ZS4gKi9cbiAgcmVhZG9ubHkgY29tbWFuZHM6IHN0cmluZ1tdO1xufVxuXG4vKipcbiAqIEFic3RyYWN0IGNsYXNzIGRlZmluaW5nIHRoZSBzdHJ1Y3R1cmUgb2YgYSBwaXBlbGluZSBzdGVwLlxuICovXG5leHBvcnQgYWJzdHJhY3QgY2xhc3MgUGlwZWxpbmVTdGVwIHtcblxuICAvKipcbiAgICogSW5pdGlhbGl6ZXMgYSBuZXcgaW5zdGFuY2Ugb2YgYSBQaXBlbGluZVN0ZXAgd2l0aCBhIHJlZmVyZW5jZSB0byBhIHByb2plbiBwcm9qZWN0LlxuICAgKiBAcGFyYW0gcHJvamVjdCAtIFRoZSBwcm9qZW4gcHJvamVjdCByZWZlcmVuY2UuXG4gICAqL1xuICBjb25zdHJ1Y3Rvcihwcm90ZWN0ZWQgcHJvamVjdDogUHJvamVjdCkge1xuICAgIC8vIENvbnN0cnVjdG9yIGNhbiBiZSBleHRlbmRlZCB0byBpbmNsdWRlIG1vcmUgc2V0dXAgbG9naWMuXG4gIH1cblxuICAvKipcbiAgICogR2VuZXJhdGVzIGEgY29uZmlndXJhdGlvbiBmb3IgYSBHaXRMYWIgQ0kgc3RlcC4gTXVzdCBiZSBpbXBsZW1lbnRlZCBieSBzdWJjbGFzc2VzLlxuICAgKi9cbiAgcHVibGljIGFic3RyYWN0IHRvR2l0bGFiKCk6IEdpdGxhYlN0ZXBDb25maWc7XG5cbiAgLyoqXG4gICAqIEdlbmVyYXRlcyBhIGNvbmZpZ3VyYXRpb24gZm9yIGEgR2l0SHViIEFjdGlvbnMgc3RlcC4gTXVzdCBiZSBpbXBsZW1lbnRlZCBieSBzdWJjbGFzc2VzLlxuICAgKi9cbiAgcHVibGljIGFic3RyYWN0IHRvR2l0aHViKCk6IEdpdGh1YlN0ZXBDb25maWc7XG5cbiAgLyoqXG4gICAqIEdlbmVyYXRlcyBhIGNvbmZpZ3VyYXRpb24gZm9yIGEgYmFzaCBzY3JpcHQgc3RlcC4gTXVzdCBiZSBpbXBsZW1lbnRlZCBieSBzdWJjbGFzc2VzLlxuICAgKi9cbiAgcHVibGljIGFic3RyYWN0IHRvQmFzaCgpOiBCYXNoU3RlcENvbmZpZztcbn1cblxuLyoqXG4gKiBDb25jcmV0ZSBpbXBsZW1lbnRhdGlvbiBvZiBQaXBlbGluZVN0ZXAgdGhhdCBleGVjdXRlcyBzaW1wbGUgY29tbWFuZHMuXG4gKi9cbmV4cG9ydCBjbGFzcyBTaW1wbGVDb21tYW5kU3RlcCBleHRlbmRzIFBpcGVsaW5lU3RlcCB7XG5cbiAgLyoqXG4gICAqIENvbnN0cnVjdHMgYSBzaW1wbGUgY29tbWFuZCBzdGVwIHdpdGggYSBzcGVjaWZpZWQgc2V0IG9mIGNvbW1hbmRzLlxuICAgKiBAcGFyYW0gcHJvamVjdCAtIFRoZSBwcm9qZW4gcHJvamVjdCByZWZlcmVuY2UuXG4gICAqIEBwYXJhbSBjb21tYW5kcyAtIFNoZWxsIGNvbW1hbmRzIHRvIGV4ZWN1dGUuXG4gICAqL1xuICBjb25zdHJ1Y3Rvcihwcm9qZWN0OiBQcm9qZWN0LCBwcm90ZWN0ZWQgY29tbWFuZHM6IHN0cmluZ1tdKSB7XG4gICAgc3VwZXIocHJvamVjdCk7XG4gIH1cblxuICAvKipcbiAgICogQ29udmVydHMgdGhlIHN0ZXAgaW50byBhIEdpdExhYiBDSSBjb25maWd1cmF0aW9uLlxuICAgKi9cbiAgcHVibGljIHRvR2l0bGFiKCk6IEdpdGxhYlN0ZXBDb25maWcge1xuICAgIHJldHVybiB7XG4gICAgICBleHRlbnNpb25zOiBbXSwgLy8gTm8gam9iIGV4dGVuc2lvbnMgc3BlY2lmaWVkIGZvciB0aGlzIHN0ZXAuXG4gICAgICBjb21tYW5kczogdGhpcy5jb21tYW5kcywgLy8gQ29tbWFuZHMgdG8gYmUgcnVuLlxuICAgICAgbmVlZHM6IFtdLCAvLyBObyBkZXBlbmRlbmNpZXMuXG4gICAgfTtcbiAgfVxuXG4gIC8qKlxuICAgKiBDb252ZXJ0cyB0aGUgc3RlcCBpbnRvIGEgQmFzaCBzY3JpcHQgY29uZmlndXJhdGlvbi5cbiAgICovXG4gIHB1YmxpYyB0b0Jhc2goKTogQmFzaFN0ZXBDb25maWcge1xuICAgIHJldHVybiB7XG4gICAgICBjb21tYW5kczogdGhpcy5jb21tYW5kcywgLy8gQ29tbWFuZHMgdG8gYmUgcnVuLlxuICAgIH07XG4gIH1cblxuICAvKipcbiAgICogQ29udmVydHMgdGhlIHN0ZXAgaW50byBhIEdpdEh1YiBBY3Rpb25zIHN0ZXAgY29uZmlndXJhdGlvbi5cbiAgICovXG4gIHB1YmxpYyB0b0dpdGh1YigpOiBHaXRodWJTdGVwQ29uZmlnIHtcbiAgICByZXR1cm4ge1xuICAgICAgbmVlZHM6IFtdLCAvLyBObyBkZXBlbmRlbmNpZXMuXG4gICAgICBzdGVwczogdGhpcy5jb21tYW5kcy5tYXAoYyA9PiAoeyBydW46IGMgfSkpLCAvLyBNYXBzIGVhY2ggY29tbWFuZCBpbnRvIGEgR2l0SHViIEFjdGlvbiBqb2Igc3RlcC5cbiAgICB9O1xuICB9XG59XG4iXX0=
package/package.json CHANGED
@@ -43,7 +43,7 @@
43
43
  "@types/standard-version": "^7.1.3",
44
44
  "@typescript-eslint/eslint-plugin": "^6",
45
45
  "@typescript-eslint/parser": "^6",
46
- "constructs": "^10.3.0",
46
+ "constructs": "10.3.0",
47
47
  "eslint": "^8",
48
48
  "eslint-import-resolver-typescript": "^3.6.1",
49
49
  "eslint-plugin-import": "^2.29.1",
@@ -55,7 +55,7 @@
55
55
  "jsii-docgen": "^10.4.1",
56
56
  "jsii-pacmak": "^1.97.0",
57
57
  "jsii-rosetta": "1.x",
58
- "projen": "^0.81.1",
58
+ "projen": "0.81.0",
59
59
  "standard-version": "^9",
60
60
  "ts-jest": "^27",
61
61
  "ts-node": "^10.9.2",
@@ -66,7 +66,7 @@
66
66
  "projen": ">=0.81.0 <1.0.0"
67
67
  },
68
68
  "dependencies": {
69
- "projen": "^0.81.1",
69
+ "projen": "0.81.0",
70
70
  "standard-version": "^9.5.0"
71
71
  },
72
72
  "bundledDependencies": [
@@ -82,7 +82,7 @@
82
82
  ],
83
83
  "main": "lib/index.js",
84
84
  "license": "Apache-2.0",
85
- "version": "0.0.55",
85
+ "version": "0.0.57",
86
86
  "jest": {
87
87
  "testMatch": [
88
88
  "<rootDir>/src/**/__tests__/**/*.ts?(x)",