projen-pipelines 0.2.14 → 0.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.
@@ -45,11 +45,11 @@ class GitHubDriftDetectionWorkflow extends base_1.DriftDetectionWorkflow {
45
45
  steps: [
46
46
  {
47
47
  name: 'Checkout',
48
- uses: 'actions/checkout@v4',
48
+ uses: 'actions/checkout@v5',
49
49
  },
50
50
  {
51
51
  name: 'Setup Node.js',
52
- uses: 'actions/setup-node@v4',
52
+ uses: 'actions/setup-node@v5',
53
53
  with: {
54
54
  'node-version': '20',
55
55
  },
@@ -70,7 +70,7 @@ class GitHubDriftDetectionWorkflow extends base_1.DriftDetectionWorkflow {
70
70
  ...(this.createIssues ? [{
71
71
  name: 'Create Issue on Drift',
72
72
  if: 'steps.drift.outcome == \'failure\' && github.event_name == \'schedule\'',
73
- uses: 'actions/github-script@v7',
73
+ uses: 'actions/github-script@v8',
74
74
  with: {
75
75
  script: this.generateIssueCreationScript(stage),
76
76
  },
@@ -90,7 +90,7 @@ class GitHubDriftDetectionWorkflow extends base_1.DriftDetectionWorkflow {
90
90
  steps: [
91
91
  {
92
92
  name: 'Download all artifacts',
93
- uses: 'actions/download-artifact@v4',
93
+ uses: 'actions/download-artifact@v5',
94
94
  with: {
95
95
  path: 'drift-results',
96
96
  },
@@ -228,5 +228,5 @@ fi
228
228
  }
229
229
  exports.GitHubDriftDetectionWorkflow = GitHubDriftDetectionWorkflow;
230
230
  _a = JSII_RTTI_SYMBOL_1;
231
- GitHubDriftDetectionWorkflow[_a] = { fqn: "projen-pipelines.GitHubDriftDetectionWorkflow", version: "0.2.14" };
232
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"github.js","sourceRoot":"","sources":["../../src/drift/github.ts"],"names":[],"mappings":"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","sourcesContent":["import { Project } from 'projen';\nimport { GitHubProject, GithubWorkflow } from 'projen/lib/github';\nimport { JobPermission } from 'projen/lib/github/workflows-model';\nimport { DriftDetectionWorkflow, DriftDetectionWorkflowOptions, DriftDetectionStageOptions } from './base';\nimport { DriftDetectionStep } from './step';\n\nexport interface GitHubDriftDetectionWorkflowOptions extends DriftDetectionWorkflowOptions {\n  /**\n   * Additional permissions for GitHub workflow\n   */\n  readonly permissions?: Record<string, string>;\n\n  /**\n   * Whether to create issues on drift detection\n   * @default false\n   */\n  readonly createIssues?: boolean;\n}\n\nexport class GitHubDriftDetectionWorkflow extends DriftDetectionWorkflow {\n  private readonly permissions?: Record<string, string>;\n  private readonly createIssues: boolean;\n  private readonly workflow: GithubWorkflow;\n\n  constructor(project: Project, options: GitHubDriftDetectionWorkflowOptions) {\n    super(project, options);\n    this.permissions = options.permissions;\n    this.createIssues = options.createIssues ?? false;\n\n    this.workflow = (this.project as GitHubProject).github!.addWorkflow('drift-detection');\n    this.workflow.on({\n      schedule: [{\n        cron: this.schedule,\n      }],\n      workflowDispatch: {\n        inputs: {\n          stage: {\n            description: 'Stage to check for drift (leave empty for all)',\n            required: false,\n            type: 'choice',\n            options: this.stages.map(s => s.name),\n          },\n        },\n      },\n    });\n\n    // Add job for each stage\n    for (const stage of this.stages) {\n      const jobId = `drift-${stage.name}`.toLowerCase().replace(/[^a-z0-9-]/g, '-');\n\n      const driftStep = new DriftDetectionStep(this.project, stage).toGithub();\n\n      this.workflow.addJob(jobId, {\n        name: `Drift Detection - ${stage.name}`,\n        runsOn: ['ubuntu-latest'],\n        if: `\\${{ github.event_name == 'schedule' || github.event.inputs.stage == '' || github.event.inputs.stage == '${stage.name}' }}`,\n        env: driftStep.env,\n        permissions: {\n          contents: JobPermission.READ,\n          ...(driftStep.permissions ?? {}),\n          ...(this.createIssues ? { issues: JobPermission.WRITE } : {}),\n          ...this.permissions,\n        },\n        steps: [\n          {\n            name: 'Checkout',\n            uses: 'actions/checkout@v4',\n          },\n          {\n            name: 'Setup Node.js',\n            uses: 'actions/setup-node@v4',\n            with: {\n              'node-version': '20',\n            },\n          },\n          {\n            name: 'Install dependencies',\n            run: 'npm ci',\n          },\n          ...driftStep.steps,\n          {\n            name: 'Upload results',\n            uses: 'actions/upload-artifact@v4',\n            with: {\n              name: `drift-results-${stage.name}`,\n              path: `drift-results-${stage.name}.json`,\n            },\n          },\n          ...(this.createIssues ? [{\n            name: 'Create Issue on Drift',\n            if: 'steps.drift.outcome == \\'failure\\' && github.event_name == \\'schedule\\'',\n            uses: 'actions/github-script@v7',\n            with: {\n              script: this.generateIssueCreationScript(stage),\n            },\n          }] : []),\n        ],\n      });\n    }\n\n    // Add summary job\n    if (this.stages.length > 0) {\n      this.workflow.addJob('drift-summary', {\n        name: 'Drift Detection Summary',\n        runsOn: ['ubuntu-latest'],\n        permissions: {\n          contents: JobPermission.READ,\n        },\n        needs: this.stages.map(stage => `drift-${stage.name}`),\n        steps: [\n          {\n            name: 'Download all artifacts',\n            uses: 'actions/download-artifact@v4',\n            with: {\n              path: 'drift-results',\n            },\n          },\n          {\n            name: 'Generate summary',\n            run: this.generateSummaryScript(),\n          },\n        ],\n      });\n    }\n  }\n\n  private generateIssueCreationScript(stage: DriftDetectionStageOptions): string {\n    return `\nconst fs = require('fs');\nconst resultsFile = 'drift-results-${stage.name}.json';\n\nif (!fs.existsSync(resultsFile)) {\n  console.log('No results file found');\n  return;\n}\n\nconst results = JSON.parse(fs.readFileSync(resultsFile, 'utf8'));\nconst driftedStacks = results.filter(r => r.driftStatus === 'DRIFTED');\n\nif (driftedStacks.length === 0) {\n  console.log('No drift detected');\n  return;\n}\n\nconst title = 'Drift Detected in ${stage.name}';\nconst body = \\`## Drift Detection Report\n\n**Stage:** ${stage.name}\n**Region:** ${stage.region}\n**Time:** \\${new Date().toISOString()}\n\n### Summary\n- Total stacks checked: \\${results.length}\n- Drifted stacks: \\${driftedStacks.length}\n\n### Drifted Stacks\n\\${driftedStacks.map(stack => {\n  const resources = stack.driftedResources || [];\n  return \\`#### \\${stack.stackName}\n- Drifted resources: \\${resources.length}\n\\${resources.map(r => \\`  - \\${r.logicalResourceId} (\\${r.resourceType})\\`).join('\\\\n')}\n\\`;\n}).join('\\\\n')}\n\n### Action Required\nPlease review the drifted resources and either:\n1. Update the infrastructure code to match the actual state\n2. Restore the resources to match the expected state\n\n[View workflow run](\\${context.serverUrl}/\\${context.repo.owner}/\\${context.repo.repo}/actions/runs/\\${context.runId})\n\\`;\n\n// Check if issue already exists\nconst issues = await github.rest.issues.listForRepo({\n  owner: context.repo.owner,\n  repo: context.repo.repo,\n  state: 'open',\n  labels: ['drift-detection', '${stage.name}'],\n});\n\nif (issues.data.length === 0) {\n  await github.rest.issues.create({\n    owner: context.repo.owner,\n    repo: context.repo.repo,\n    title,\n    body,\n    labels: ['drift-detection', '${stage.name}'],\n  });\n} else {\n  // Update existing issue\n  const issue = issues.data[0];\n  await github.rest.issues.createComment({\n    owner: context.repo.owner,\n    repo: context.repo.repo,\n    issue_number: issue.number,\n    body: body,\n  });\n}\n`;\n  }\n\n  private generateSummaryScript(): string {\n    return `\n#!/bin/bash\necho \"## Drift Detection Summary\" >> $GITHUB_STEP_SUMMARY\necho \"\" >> $GITHUB_STEP_SUMMARY\n\ntotal_stacks=0\ntotal_drifted=0\ntotal_errors=0\n\nfor file in drift-results-*.json; do\n  if [[ -f \"$file\" ]]; then\n    stage=$(basename $(dirname \"$file\"))\n    echo \"### Stage: $stage\" >> $GITHUB_STEP_SUMMARY\n    \n    # Parse JSON and generate summary\n    jq -r '\n      . as $results |\n      \"- Total stacks: \" + ($results | length | tostring) + \"\\\\n\" +\n      \"- Drifted: \" + ([$results[] | select(.driftStatus == \"DRIFTED\")] | length | tostring) + \"\\\\n\" +\n      \"- Errors: \" + ([$results[] | select(.error)] | length | tostring) + \"\\\\n\" +\n      ([$results[] | select(.driftStatus == \"DRIFTED\")] | \n        if length > 0 then\n          \"\\\\n**Drifted stacks:**\\\\n\" + \n          (map(\"  - \" + .stackName + \" (\" + ((.driftedResources // []) | length | tostring) + \" resources)\") | join(\"\\\\n\"))\n        else \"\" end)\n    ' \"$file\" >> $GITHUB_STEP_SUMMARY\n    \n    echo \"\" >> $GITHUB_STEP_SUMMARY\n    \n    # Count totals\n    total_stacks=$((total_stacks + $(jq 'length' \"$file\")))\n    total_drifted=$((total_drifted + $(jq '[.[] | select(.driftStatus == \"DRIFTED\")] | length' \"$file\")))\n    total_errors=$((total_errors + $(jq '[.[] | select(.error)] | length' \"$file\")))\n  fi\ndone\n\necho \"### Overall Summary\" >> $GITHUB_STEP_SUMMARY\necho \"- Total stacks checked: $total_stacks\" >> $GITHUB_STEP_SUMMARY\necho \"- Total drifted stacks: $total_drifted\" >> $GITHUB_STEP_SUMMARY\necho \"- Total errors: $total_errors\" >> $GITHUB_STEP_SUMMARY\n\nif [[ $total_drifted -gt 0 ]]; then\n  echo \"\" >> $GITHUB_STEP_SUMMARY\n  echo \"⚠️ **Action required:** Drift detected in $total_drifted stacks\" >> $GITHUB_STEP_SUMMARY\nfi\n`;\n  }\n\n}"]}
231
+ GitHubDriftDetectionWorkflow[_a] = { fqn: "projen-pipelines.GitHubDriftDetectionWorkflow", version: "0.3.0" };
232
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"github.js","sourceRoot":"","sources":["../../src/drift/github.ts"],"names":[],"mappings":"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","sourcesContent":["import { Project } from 'projen';\nimport { GitHubProject, GithubWorkflow } from 'projen/lib/github';\nimport { JobPermission } from 'projen/lib/github/workflows-model';\nimport { DriftDetectionWorkflow, DriftDetectionWorkflowOptions, DriftDetectionStageOptions } from './base';\nimport { DriftDetectionStep } from './step';\n\nexport interface GitHubDriftDetectionWorkflowOptions extends DriftDetectionWorkflowOptions {\n  /**\n   * Additional permissions for GitHub workflow\n   */\n  readonly permissions?: Record<string, string>;\n\n  /**\n   * Whether to create issues on drift detection\n   * @default false\n   */\n  readonly createIssues?: boolean;\n}\n\nexport class GitHubDriftDetectionWorkflow extends DriftDetectionWorkflow {\n  private readonly permissions?: Record<string, string>;\n  private readonly createIssues: boolean;\n  private readonly workflow: GithubWorkflow;\n\n  constructor(project: Project, options: GitHubDriftDetectionWorkflowOptions) {\n    super(project, options);\n    this.permissions = options.permissions;\n    this.createIssues = options.createIssues ?? false;\n\n    this.workflow = (this.project as GitHubProject).github!.addWorkflow('drift-detection');\n    this.workflow.on({\n      schedule: [{\n        cron: this.schedule,\n      }],\n      workflowDispatch: {\n        inputs: {\n          stage: {\n            description: 'Stage to check for drift (leave empty for all)',\n            required: false,\n            type: 'choice',\n            options: this.stages.map(s => s.name),\n          },\n        },\n      },\n    });\n\n    // Add job for each stage\n    for (const stage of this.stages) {\n      const jobId = `drift-${stage.name}`.toLowerCase().replace(/[^a-z0-9-]/g, '-');\n\n      const driftStep = new DriftDetectionStep(this.project, stage).toGithub();\n\n      this.workflow.addJob(jobId, {\n        name: `Drift Detection - ${stage.name}`,\n        runsOn: ['ubuntu-latest'],\n        if: `\\${{ github.event_name == 'schedule' || github.event.inputs.stage == '' || github.event.inputs.stage == '${stage.name}' }}`,\n        env: driftStep.env,\n        permissions: {\n          contents: JobPermission.READ,\n          ...(driftStep.permissions ?? {}),\n          ...(this.createIssues ? { issues: JobPermission.WRITE } : {}),\n          ...this.permissions,\n        },\n        steps: [\n          {\n            name: 'Checkout',\n            uses: 'actions/checkout@v5',\n          },\n          {\n            name: 'Setup Node.js',\n            uses: 'actions/setup-node@v5',\n            with: {\n              'node-version': '20',\n            },\n          },\n          {\n            name: 'Install dependencies',\n            run: 'npm ci',\n          },\n          ...driftStep.steps,\n          {\n            name: 'Upload results',\n            uses: 'actions/upload-artifact@v4',\n            with: {\n              name: `drift-results-${stage.name}`,\n              path: `drift-results-${stage.name}.json`,\n            },\n          },\n          ...(this.createIssues ? [{\n            name: 'Create Issue on Drift',\n            if: 'steps.drift.outcome == \\'failure\\' && github.event_name == \\'schedule\\'',\n            uses: 'actions/github-script@v8',\n            with: {\n              script: this.generateIssueCreationScript(stage),\n            },\n          }] : []),\n        ],\n      });\n    }\n\n    // Add summary job\n    if (this.stages.length > 0) {\n      this.workflow.addJob('drift-summary', {\n        name: 'Drift Detection Summary',\n        runsOn: ['ubuntu-latest'],\n        permissions: {\n          contents: JobPermission.READ,\n        },\n        needs: this.stages.map(stage => `drift-${stage.name}`),\n        steps: [\n          {\n            name: 'Download all artifacts',\n            uses: 'actions/download-artifact@v5',\n            with: {\n              path: 'drift-results',\n            },\n          },\n          {\n            name: 'Generate summary',\n            run: this.generateSummaryScript(),\n          },\n        ],\n      });\n    }\n  }\n\n  private generateIssueCreationScript(stage: DriftDetectionStageOptions): string {\n    return `\nconst fs = require('fs');\nconst resultsFile = 'drift-results-${stage.name}.json';\n\nif (!fs.existsSync(resultsFile)) {\n  console.log('No results file found');\n  return;\n}\n\nconst results = JSON.parse(fs.readFileSync(resultsFile, 'utf8'));\nconst driftedStacks = results.filter(r => r.driftStatus === 'DRIFTED');\n\nif (driftedStacks.length === 0) {\n  console.log('No drift detected');\n  return;\n}\n\nconst title = 'Drift Detected in ${stage.name}';\nconst body = \\`## Drift Detection Report\n\n**Stage:** ${stage.name}\n**Region:** ${stage.region}\n**Time:** \\${new Date().toISOString()}\n\n### Summary\n- Total stacks checked: \\${results.length}\n- Drifted stacks: \\${driftedStacks.length}\n\n### Drifted Stacks\n\\${driftedStacks.map(stack => {\n  const resources = stack.driftedResources || [];\n  return \\`#### \\${stack.stackName}\n- Drifted resources: \\${resources.length}\n\\${resources.map(r => \\`  - \\${r.logicalResourceId} (\\${r.resourceType})\\`).join('\\\\n')}\n\\`;\n}).join('\\\\n')}\n\n### Action Required\nPlease review the drifted resources and either:\n1. Update the infrastructure code to match the actual state\n2. Restore the resources to match the expected state\n\n[View workflow run](\\${context.serverUrl}/\\${context.repo.owner}/\\${context.repo.repo}/actions/runs/\\${context.runId})\n\\`;\n\n// Check if issue already exists\nconst issues = await github.rest.issues.listForRepo({\n  owner: context.repo.owner,\n  repo: context.repo.repo,\n  state: 'open',\n  labels: ['drift-detection', '${stage.name}'],\n});\n\nif (issues.data.length === 0) {\n  await github.rest.issues.create({\n    owner: context.repo.owner,\n    repo: context.repo.repo,\n    title,\n    body,\n    labels: ['drift-detection', '${stage.name}'],\n  });\n} else {\n  // Update existing issue\n  const issue = issues.data[0];\n  await github.rest.issues.createComment({\n    owner: context.repo.owner,\n    repo: context.repo.repo,\n    issue_number: issue.number,\n    body: body,\n  });\n}\n`;\n  }\n\n  private generateSummaryScript(): string {\n    return `\n#!/bin/bash\necho \"## Drift Detection Summary\" >> $GITHUB_STEP_SUMMARY\necho \"\" >> $GITHUB_STEP_SUMMARY\n\ntotal_stacks=0\ntotal_drifted=0\ntotal_errors=0\n\nfor file in drift-results-*.json; do\n  if [[ -f \"$file\" ]]; then\n    stage=$(basename $(dirname \"$file\"))\n    echo \"### Stage: $stage\" >> $GITHUB_STEP_SUMMARY\n    \n    # Parse JSON and generate summary\n    jq -r '\n      . as $results |\n      \"- Total stacks: \" + ($results | length | tostring) + \"\\\\n\" +\n      \"- Drifted: \" + ([$results[] | select(.driftStatus == \"DRIFTED\")] | length | tostring) + \"\\\\n\" +\n      \"- Errors: \" + ([$results[] | select(.error)] | length | tostring) + \"\\\\n\" +\n      ([$results[] | select(.driftStatus == \"DRIFTED\")] | \n        if length > 0 then\n          \"\\\\n**Drifted stacks:**\\\\n\" + \n          (map(\"  - \" + .stackName + \" (\" + ((.driftedResources // []) | length | tostring) + \" resources)\") | join(\"\\\\n\"))\n        else \"\" end)\n    ' \"$file\" >> $GITHUB_STEP_SUMMARY\n    \n    echo \"\" >> $GITHUB_STEP_SUMMARY\n    \n    # Count totals\n    total_stacks=$((total_stacks + $(jq 'length' \"$file\")))\n    total_drifted=$((total_drifted + $(jq '[.[] | select(.driftStatus == \"DRIFTED\")] | length' \"$file\")))\n    total_errors=$((total_errors + $(jq '[.[] | select(.error)] | length' \"$file\")))\n  fi\ndone\n\necho \"### Overall Summary\" >> $GITHUB_STEP_SUMMARY\necho \"- Total stacks checked: $total_stacks\" >> $GITHUB_STEP_SUMMARY\necho \"- Total drifted stacks: $total_drifted\" >> $GITHUB_STEP_SUMMARY\necho \"- Total errors: $total_errors\" >> $GITHUB_STEP_SUMMARY\n\nif [[ $total_drifted -gt 0 ]]; then\n  echo \"\" >> $GITHUB_STEP_SUMMARY\n  echo \"⚠️ **Action required:** Drift detected in $total_drifted stacks\" >> $GITHUB_STEP_SUMMARY\nfi\n`;\n  }\n\n}"]}
@@ -134,5 +134,5 @@ fi
134
134
  }
135
135
  exports.GitLabDriftDetectionWorkflow = GitLabDriftDetectionWorkflow;
136
136
  _a = JSII_RTTI_SYMBOL_1;
137
- GitLabDriftDetectionWorkflow[_a] = { fqn: "projen-pipelines.GitLabDriftDetectionWorkflow", version: "0.2.14" };
137
+ GitLabDriftDetectionWorkflow[_a] = { fqn: "projen-pipelines.GitLabDriftDetectionWorkflow", version: "0.3.0" };
138
138
  //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gitlab.js","sourceRoot":"","sources":["../../src/drift/gitlab.ts"],"names":[],"mappings":"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","sourcesContent":["import { gitlab, Project } from 'projen';\nimport { DriftDetectionWorkflow, DriftDetectionWorkflowOptions } from './base';\nimport { DriftDetectionStep } from './step';\n\nexport interface GitLabDriftDetectionWorkflowOptions extends DriftDetectionWorkflowOptions {\n  /**\n   * GitLab runner tags\n   */\n  readonly runnerTags?: string[];\n\n  /**\n   * Docker image to use for drift detection\n   * @default \"node:18\"\n   */\n  readonly image?: string;\n}\n\nexport class GitLabDriftDetectionWorkflow extends DriftDetectionWorkflow {\n  private readonly runnerTags: string[];\n  private readonly image: string;\n  private readonly config: gitlab.GitlabConfiguration;\n\n  constructor(project: Project, options: GitLabDriftDetectionWorkflowOptions) {\n    super(project, options);\n    this.runnerTags = options.runnerTags ?? [];\n    this.image = options.image ?? 'node:18';\n    this.config = new gitlab.GitlabConfiguration(project, {\n      stages: [],\n      jobs: {},\n    });\n\n    this.config.addStages('drift-detection', 'summary');\n\n    this.config.addJobs({\n      '.drift-detection': {\n        stage: 'drift-detection',\n        tags: this.runnerTags,\n        image: { name: this.image },\n        idTokens: {\n          AWS_TOKEN: {\n            aud: 'https://sts.amazonaws.com',\n          },\n        },\n        only: {\n          refs: ['schedules'],\n          variables: ['$CI_PIPELINE_SOURCE == \"schedule\"', '$DRIFT_DETECTION == \"true\"'],\n        },\n        beforeScript: [\n          'apt-get update && apt-get install -y python3 python3-pip',\n          'pip3 install awscli',\n          'npm ci',\n        ],\n        artifacts: {\n          paths: ['drift-results-*.json'],\n          expireIn: '1 week',\n          when: gitlab.CacheWhen.ALWAYS,\n        },\n      },\n    });\n\n    // Add job for each stage\n    for (const stage of this.stages) {\n      const jobName = `drift:${stage.name}`;\n\n      const driftStep = new DriftDetectionStep(this.project, stage);\n      const stepConfig = driftStep.toGitlab();\n\n      this.config.addJobs({\n        [jobName]: {\n          extends: ['.drift-detection'],\n          variables: {\n            ...stepConfig.env,\n          },\n          script: stepConfig.commands,\n          allowFailure: !stage.failOnDrift,\n        },\n      });\n    }\n\n    // Add summary job\n    this.config.addJobs({\n      'drift:summary': {\n        stage: 'summary',\n        tags: this.runnerTags,\n        needs: this.stages.map(s => `drift:${s.name}`),\n        only: {\n          refs: ['schedules'],\n          variables: ['$CI_PIPELINE_SOURCE == \"schedule\"', '$DRIFT_DETECTION == \"true\"'],\n        },\n        script: [\n          'echo \"## Drift Detection Summary\"',\n          'echo \"\"',\n          this.generateSummaryScript(),\n        ],\n        when: gitlab.JobWhen.ALWAYS,\n      },\n    });\n\n  }\n\n  private generateSummaryScript(): string {\n    return `\ntotal_stacks=0\ntotal_drifted=0\ntotal_errors=0\n\nfor file in drift-results-*.json; do\n  if [[ -f \"$file\" ]]; then\n    stage=$(echo $file | sed 's/drift-results-//;s/.json//')\n    echo \"### Stage: $stage\"\n    \n    # Count results\n    stacks=$(jq 'length' \"$file\")\n    drifted=$(jq '[.[] | select(.driftStatus == \"DRIFTED\")] | length' \"$file\")\n    errors=$(jq '[.[] | select(.error)] | length' \"$file\")\n    \n    echo \"- Total stacks: $stacks\"\n    echo \"- Drifted: $drifted\"\n    echo \"- Errors: $errors\"\n    \n    # Show drifted stacks\n    if [[ $drifted -gt 0 ]]; then\n      echo \"\"\n      echo \"**Drifted stacks:**\"\n      jq -r '.[] | select(.driftStatus == \"DRIFTED\") | \"  - \" + .stackName + \" (\" + ((.driftedResources // []) | length | tostring) + \" resources)\"' \"$file\"\n    fi\n    \n    echo \"\"\n    \n    # Accumulate totals\n    total_stacks=$((total_stacks + stacks))\n    total_drifted=$((total_drifted + drifted))\n    total_errors=$((total_errors + errors))\n  fi\ndone\n\necho \"### Overall Summary\"\necho \"- Total stacks checked: $total_stacks\"\necho \"- Total drifted stacks: $total_drifted\"\necho \"- Total errors: $total_errors\"\n\nif [[ $total_drifted -gt 0 ]]; then\n  echo \"\"\n  echo \"⚠️ **Action required:** Drift detected in $total_drifted stacks\"\n  \n  # Send notification if webhook is configured\n  if [[ -n \"$DRIFT_NOTIFICATION_WEBHOOK\" ]]; then\n    curl -X POST \"$DRIFT_NOTIFICATION_WEBHOOK\" \\\\\n      -H \"Content-Type: application/json\" \\\\\n      -d \"{\\\\\"text\\\\\": \\\\\"Drift detected in $total_drifted stacks. Check pipeline $CI_PIPELINE_URL for details.\\\\\"}\" || true\n  fi\nfi\n`;\n  }\n\n}"]}
package/lib/drift/step.js CHANGED
@@ -44,5 +44,5 @@ class DriftDetectionStep extends steps_1.StepSequence {
44
44
  }
45
45
  exports.DriftDetectionStep = DriftDetectionStep;
46
46
  _a = JSII_RTTI_SYMBOL_1;
47
- DriftDetectionStep[_a] = { fqn: "projen-pipelines.DriftDetectionStep", version: "0.2.14" };
47
+ DriftDetectionStep[_a] = { fqn: "projen-pipelines.DriftDetectionStep", version: "0.3.0" };
48
48
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RlcC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9kcmlmdC9zdGVwLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBQ0Esb0NBQTRGO0FBVzVGLE1BQWEsa0JBQW1CLFNBQVEsb0JBQVk7SUFDMUMsTUFBTSxDQUFDLGVBQWUsQ0FBQyxLQUE4QjtRQUMzRCxNQUFNLElBQUksR0FBYTtZQUNyQixjQUFjO1lBQ2QsVUFBVSxFQUFFLEtBQUssQ0FBQyxNQUFNO1NBQ3pCLENBQUM7UUFFRixJQUFJLEtBQUssQ0FBQyxVQUFVLElBQUksS0FBSyxDQUFDLFVBQVUsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxFQUFFLENBQUM7WUFDcEQsSUFBSSxDQUFDLElBQUksQ0FBQyxVQUFVLEVBQUUsS0FBSyxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQztRQUNwRCxDQUFDO1FBRUQsSUFBSSxLQUFLLENBQUMsT0FBTyxFQUFFLENBQUM7WUFDbEIsSUFBSSxDQUFDLElBQUksQ0FBQyxXQUFXLEVBQUUsS0FBSyxDQUFDLE9BQU8sQ0FBQyxRQUFRLEVBQUUsQ0FBQyxDQUFDO1FBQ25ELENBQUM7UUFFRCxJQUFJLEtBQUssQ0FBQyxXQUFXLEtBQUssS0FBSyxFQUFFLENBQUM7WUFDaEMsSUFBSSxDQUFDLElBQUksQ0FBQyxvQkFBb0IsQ0FBQyxDQUFDO1FBQ2xDLENBQUM7UUFFRCxPQUFPLElBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUM7SUFDeEIsQ0FBQztJQUVELFlBQVksT0FBZ0IsRUFBRSxLQUE4QjtRQUMxRCxNQUFNLEtBQUssR0FBbUIsRUFBRSxDQUFDO1FBRWpDLGtEQUFrRDtRQUNsRCxJQUFJLEtBQUssQ0FBQyxPQUFPLEVBQUUsQ0FBQztZQUNsQixLQUFLLENBQUMsSUFBSSxDQUFDLElBQUkseUJBQWlCLENBQUMsT0FBTyxFQUFFO2dCQUN4QyxPQUFPLEVBQUUsS0FBSyxDQUFDLE9BQU87Z0JBQ3RCLE1BQU0sRUFBRSxLQUFLLENBQUMsTUFBTTthQUNyQixDQUFDLENBQUMsQ0FBQztRQUNOLENBQUM7UUFFRCwwQ0FBMEM7UUFDMUMsTUFBTSxPQUFPLEdBQUcsa0JBQWtCLENBQUMsZUFBZSxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQzFELEtBQUssQ0FBQyxJQUFJLENBQUMsSUFBSSx5QkFBaUIsQ0FBQyxPQUFPLEVBQUUsQ0FBQyxPQUFPLENBQUMsRUFBRTtZQUNuRCxrQkFBa0IsRUFBRSxLQUFLLENBQUMsTUFBTTtZQUNoQyxzQkFBc0IsRUFBRSxpQkFBaUIsS0FBSyxDQUFDLElBQUksT0FBTztZQUMxRCxVQUFVLEVBQUUsS0FBSyxDQUFDLE1BQU07WUFDeEIsVUFBVSxFQUFFLEtBQUssQ0FBQyxJQUFJO1lBQ3RCLEdBQUcsS0FBSyxDQUFDLFdBQVc7U0FDckIsQ0FBQyxDQUFDLENBQUM7UUFFSixLQUFLLENBQUMsT0FBTyxFQUFFLEtBQUssQ0FBQyxDQUFDO0lBQ3hCLENBQUM7O0FBNUNILGdEQTZDQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFByb2plY3QgfSBmcm9tICdwcm9qZW4nO1xuaW1wb3J0IHsgU3RlcFNlcXVlbmNlLCBQaXBlbGluZVN0ZXAsIEF3c0Fzc3VtZVJvbGVTdGVwLCBTaW1wbGVDb21tYW5kU3RlcCB9IGZyb20gJy4uL3N0ZXBzJztcbmltcG9ydCB7IERyaWZ0RGV0ZWN0aW9uU3RhZ2VPcHRpb25zIH0gZnJvbSAnLi9iYXNlJztcblxuZXhwb3J0IGludGVyZmFjZSBEcmlmdERldGVjdGlvblN0ZXBQcm9wcyBleHRlbmRzIERyaWZ0RGV0ZWN0aW9uU3RhZ2VPcHRpb25zIHtcbiAgLyoqXG4gICAqIFRpbWVvdXQgaW4gbWludXRlcyBmb3IgZHJpZnQgZGV0ZWN0aW9uXG4gICAqIEBkZWZhdWx0IDMwXG4gICAqL1xuICByZWFkb25seSB0aW1lb3V0PzogbnVtYmVyO1xufVxuXG5leHBvcnQgY2xhc3MgRHJpZnREZXRlY3Rpb25TdGVwIGV4dGVuZHMgU3RlcFNlcXVlbmNlIHtcbiAgcHJpdmF0ZSBzdGF0aWMgZ2VuZXJhdGVDb21tYW5kKHByb3BzOiBEcmlmdERldGVjdGlvblN0ZXBQcm9wcyk6IHN0cmluZyB7XG4gICAgY29uc3QgYXJnczogc3RyaW5nW10gPSBbXG4gICAgICAnZGV0ZWN0LWRyaWZ0JyxcbiAgICAgICctLXJlZ2lvbicsIHByb3BzLnJlZ2lvbixcbiAgICBdO1xuXG4gICAgaWYgKHByb3BzLnN0YWNrTmFtZXMgJiYgcHJvcHMuc3RhY2tOYW1lcy5sZW5ndGggPiAwKSB7XG4gICAgICBhcmdzLnB1c2goJy0tc3RhY2tzJywgcHJvcHMuc3RhY2tOYW1lcy5qb2luKCcsJykpO1xuICAgIH1cblxuICAgIGlmIChwcm9wcy50aW1lb3V0KSB7XG4gICAgICBhcmdzLnB1c2goJy0tdGltZW91dCcsIHByb3BzLnRpbWVvdXQudG9TdHJpbmcoKSk7XG4gICAgfVxuXG4gICAgaWYgKHByb3BzLmZhaWxPbkRyaWZ0ID09PSBmYWxzZSkge1xuICAgICAgYXJncy5wdXNoKCctLW5vLWZhaWwtb24tZHJpZnQnKTtcbiAgICB9XG5cbiAgICByZXR1cm4gYXJncy5qb2luKCcgJyk7XG4gIH1cblxuICBjb25zdHJ1Y3Rvcihwcm9qZWN0OiBQcm9qZWN0LCBwcm9wczogRHJpZnREZXRlY3Rpb25TdGVwUHJvcHMpIHtcbiAgICBjb25zdCBzdGVwczogUGlwZWxpbmVTdGVwW10gPSBbXTtcblxuICAgIC8vIEFkZCBBV1MgYXNzdW1lIHJvbGUgc3RlcCBpZiByb2xlQXJuIGlzIHByb3ZpZGVkXG4gICAgaWYgKHByb3BzLnJvbGVBcm4pIHtcbiAgICAgIHN0ZXBzLnB1c2gobmV3IEF3c0Fzc3VtZVJvbGVTdGVwKHByb2plY3QsIHtcbiAgICAgICAgcm9sZUFybjogcHJvcHMucm9sZUFybixcbiAgICAgICAgcmVnaW9uOiBwcm9wcy5yZWdpb24sXG4gICAgICB9KSk7XG4gICAgfVxuXG4gICAgLy8gQWRkIGNvbW1hbmQgc3RlcCB0byBydW4gZHJpZnQgZGV0ZWN0aW9uXG4gICAgY29uc3QgY29tbWFuZCA9IERyaWZ0RGV0ZWN0aW9uU3RlcC5nZW5lcmF0ZUNvbW1hbmQocHJvcHMpO1xuICAgIHN0ZXBzLnB1c2gobmV3IFNpbXBsZUNvbW1hbmRTdGVwKHByb2plY3QsIFtjb21tYW5kXSwge1xuICAgICAgQVdTX0RFRkFVTFRfUkVHSU9OOiBwcm9wcy5yZWdpb24sXG4gICAgICBEUklGVF9ERVRFQ1RJT05fT1VUUFVUOiBgZHJpZnQtcmVzdWx0cy0ke3Byb3BzLm5hbWV9Lmpzb25gLFxuICAgICAgQVdTX1JFR0lPTjogcHJvcHMucmVnaW9uLFxuICAgICAgU1RBR0VfTkFNRTogcHJvcHMubmFtZSxcbiAgICAgIC4uLnByb3BzLmVudmlyb25tZW50LFxuICAgIH0pKTtcblxuICAgIHN1cGVyKHByb2plY3QsIHN0ZXBzKTtcbiAgfVxufSJdfQ==
@@ -0,0 +1,40 @@
1
+ import { Project } from 'projen';
2
+ import { BashStepConfig, CodeCatalystStepConfig, GithubStepConfig, GitlabStepConfig, PipelineStep } from './step';
3
+ /**
4
+ * Configuration for an AWS Amplify deployment step
5
+ */
6
+ export interface AmplifyDeployStepConfig {
7
+ /** The Amplify app ID (static value) */
8
+ readonly appId?: string;
9
+ /** Command to retrieve the Amplify app ID dynamically */
10
+ readonly appIdCommand?: string;
11
+ /** The artifact file to deploy (zip file containing the build) */
12
+ readonly artifactFile: string;
13
+ /** The branch name to deploy to (defaults to 'main') */
14
+ readonly branchName?: string;
15
+ /** The AWS region (defaults to 'eu-central-1') */
16
+ readonly region?: string;
17
+ /** Environment name */
18
+ readonly environment?: string;
19
+ }
20
+ /**
21
+ * A step that deploys a web application to AWS Amplify
22
+ */
23
+ export declare class AmplifyDeployStep extends PipelineStep {
24
+ private readonly config;
25
+ private readonly branchName;
26
+ private readonly region;
27
+ constructor(project: Project, config: AmplifyDeployStepConfig);
28
+ /**
29
+ * Generate the core Amplify deployment commands
30
+ */
31
+ private getDeploymentCommands;
32
+ /**
33
+ * Get the command to set the Amplify App ID
34
+ */
35
+ private getAppIdCommand;
36
+ toGitlab(): GitlabStepConfig;
37
+ toGithub(): GithubStepConfig;
38
+ toBash(): BashStepConfig;
39
+ toCodeCatalyst(): CodeCatalystStepConfig;
40
+ }
@@ -0,0 +1,148 @@
1
+ "use strict";
2
+ var _a;
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.AmplifyDeployStep = void 0;
5
+ const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
6
+ const step_1 = require("./step");
7
+ /**
8
+ * A step that deploys a web application to AWS Amplify
9
+ */
10
+ class AmplifyDeployStep extends step_1.PipelineStep {
11
+ constructor(project, config) {
12
+ super(project);
13
+ this.config = config;
14
+ if (!config.appId && !config.appIdCommand) {
15
+ throw new Error('Either appId or appIdCommand must be provided');
16
+ }
17
+ if (config.appId && config.appIdCommand) {
18
+ throw new Error('Cannot provide both appId and appIdCommand');
19
+ }
20
+ this.branchName = config.branchName ?? 'main';
21
+ this.region = config.region ?? 'eu-central-1';
22
+ }
23
+ /**
24
+ * Generate the core Amplify deployment commands
25
+ */
26
+ getDeploymentCommands() {
27
+ const commands = [];
28
+ // Check and stop any pending jobs
29
+ commands.push('echo "Checking for pending Amplify jobs..."');
30
+ commands.push(`aws amplify list-jobs --app-id $AMPLIFY_APP_ID --branch-name ${this.branchName} --max-items 1 > amplify-last-job.json`);
31
+ commands.push('AMPLIFY_LAST_JOB_STATUS=$(cat amplify-last-job.json | jq -r \'.jobSummaries[].status\')');
32
+ commands.push('AMPLIFY_LAST_JOB_ID=$(cat amplify-last-job.json | jq -r \'.jobSummaries[].jobId\')');
33
+ commands.push('if [ "$AMPLIFY_LAST_JOB_STATUS" = "PENDING" ]; then');
34
+ commands.push(` aws amplify stop-job --app-id $AMPLIFY_APP_ID --branch-name ${this.branchName} --job-id $AMPLIFY_LAST_JOB_ID`);
35
+ commands.push('fi');
36
+ // Create deployment
37
+ commands.push('echo "Creating Amplify deployment..."');
38
+ commands.push(`aws amplify create-deployment --app-id $AMPLIFY_APP_ID --branch-name ${this.branchName} > amplify-deploy.json`);
39
+ commands.push('AMPLIFY_ZIP_UPLOAD_URL=$(cat amplify-deploy.json | jq -r \'.zipUploadUrl\')');
40
+ commands.push('AMPLIFY_JOB_ID=$(cat amplify-deploy.json | jq -r \'.jobId\')');
41
+ // Upload artifact
42
+ commands.push('echo "Uploading deployment artifact..."');
43
+ commands.push(`curl -H "Content-Type: application/zip" $AMPLIFY_ZIP_UPLOAD_URL --upload-file ${this.config.artifactFile}`);
44
+ // Start deployment
45
+ commands.push('echo "Starting Amplify deployment..."');
46
+ commands.push(`aws amplify start-deployment --app-id $AMPLIFY_APP_ID --branch-name ${this.branchName} --job-id $AMPLIFY_JOB_ID`);
47
+ // Wait for deployment to complete
48
+ commands.push('while :; do');
49
+ commands.push(' sleep 10');
50
+ commands.push(` STATUS=$(aws amplify get-job --app-id $AMPLIFY_APP_ID --branch-name ${this.branchName} --job-id $AMPLIFY_JOB_ID | jq -r '.job.summary.status')`);
51
+ commands.push(' if [ "$STATUS" != "PENDING" ] && [ "$STATUS" != "RUNNING" ]; then');
52
+ commands.push(' break');
53
+ commands.push(' fi');
54
+ commands.push(' echo "Deployment status: $STATUS"');
55
+ commands.push('done');
56
+ // Clean up and check final status
57
+ commands.push('rm -f amplify-last-job.json amplify-deploy.json');
58
+ commands.push('echo "Amplify deployment completed with status: $STATUS"');
59
+ commands.push('if [ "$STATUS" != "SUCCEED" ]; then');
60
+ commands.push(' echo "Deployment failed with status: $STATUS"');
61
+ commands.push(' exit 1');
62
+ commands.push('fi');
63
+ return commands;
64
+ }
65
+ /**
66
+ * Get the command to set the Amplify App ID
67
+ */
68
+ getAppIdCommand() {
69
+ if (this.config.appId) {
70
+ return `AMPLIFY_APP_ID="${this.config.appId}"`;
71
+ }
72
+ else if (this.config.appIdCommand) {
73
+ return `AMPLIFY_APP_ID=$(${this.config.appIdCommand})`;
74
+ }
75
+ return '';
76
+ }
77
+ toGitlab() {
78
+ const commands = [];
79
+ // Set Amplify App ID
80
+ commands.push(this.getAppIdCommand());
81
+ // Add deployment commands
82
+ commands.push(...this.getDeploymentCommands());
83
+ return {
84
+ env: {
85
+ AWS_REGION: this.region,
86
+ AWS_DEFAULT_REGION: this.region,
87
+ },
88
+ commands,
89
+ extensions: [],
90
+ needs: [],
91
+ };
92
+ }
93
+ toGithub() {
94
+ const steps = [];
95
+ // Set Amplify App ID
96
+ if (this.config.appId) {
97
+ steps.push({
98
+ name: 'Set Amplify App ID',
99
+ run: `echo "AMPLIFY_APP_ID=${this.config.appId}" >> $GITHUB_ENV`,
100
+ });
101
+ }
102
+ else if (this.config.appIdCommand) {
103
+ const envStep = {
104
+ name: 'Extract Amplify App ID',
105
+ run: `AMPLIFY_APP_ID=$(${this.config.appIdCommand}) && echo "AMPLIFY_APP_ID=$AMPLIFY_APP_ID" >> $GITHUB_ENV`,
106
+ };
107
+ if (this.config.environment) {
108
+ envStep.env = { ENVIRONMENT: this.config.environment };
109
+ }
110
+ steps.push(envStep);
111
+ }
112
+ // Deploy to Amplify - use the environment variable set above
113
+ const deploymentScript = [
114
+ '#!/bin/bash -e',
115
+ ...this.getDeploymentCommands(),
116
+ ].join('\n');
117
+ steps.push({
118
+ name: 'Deploy to Amplify',
119
+ run: deploymentScript,
120
+ });
121
+ return {
122
+ steps,
123
+ needs: [],
124
+ env: {
125
+ AWS_REGION: this.region,
126
+ AWS_DEFAULT_REGION: this.region,
127
+ },
128
+ };
129
+ }
130
+ toBash() {
131
+ const commands = [];
132
+ // Set AWS region
133
+ commands.push(`export AWS_REGION="${this.region}"`);
134
+ commands.push(`export AWS_DEFAULT_REGION="${this.region}"`);
135
+ // Set Amplify App ID
136
+ commands.push(this.getAppIdCommand());
137
+ // Add deployment commands
138
+ commands.push(...this.getDeploymentCommands());
139
+ return { commands };
140
+ }
141
+ toCodeCatalyst() {
142
+ throw new Error('CodeCatalyst is not supported for Amplify deployment');
143
+ }
144
+ }
145
+ exports.AmplifyDeployStep = AmplifyDeployStep;
146
+ _a = JSII_RTTI_SYMBOL_1;
147
+ AmplifyDeployStep[_a] = { fqn: "projen-pipelines.AmplifyDeployStep", version: "0.3.0" };
148
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"amplify-deploy.step.js","sourceRoot":"","sources":["../../src/steps/amplify-deploy.step.ts"],"names":[],"mappings":"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","sourcesContent":["import { Project } from 'projen';\nimport { BashStepConfig, CodeCatalystStepConfig, GithubStepConfig, GitlabStepConfig, PipelineStep } from './step';\n\n/**\n * Configuration for an AWS Amplify deployment step\n */\nexport interface AmplifyDeployStepConfig {\n  /** The Amplify app ID (static value) */\n  readonly appId?: string;\n  /** Command to retrieve the Amplify app ID dynamically */\n  readonly appIdCommand?: string;\n  /** The artifact file to deploy (zip file containing the build) */\n  readonly artifactFile: string;\n  /** The branch name to deploy to (defaults to 'main') */\n  readonly branchName?: string;\n  /** The AWS region (defaults to 'eu-central-1') */\n  readonly region?: string;\n  /** Environment name */\n  readonly environment?: string;\n}\n\n/**\n * A step that deploys a web application to AWS Amplify\n */\nexport class AmplifyDeployStep extends PipelineStep {\n\n  private readonly branchName: string;\n  private readonly region: string;\n\n  constructor(project: Project, private readonly config: AmplifyDeployStepConfig) {\n    super(project);\n    if (!config.appId && !config.appIdCommand) {\n      throw new Error('Either appId or appIdCommand must be provided');\n    }\n    if (config.appId && config.appIdCommand) {\n      throw new Error('Cannot provide both appId and appIdCommand');\n    }\n    this.branchName = config.branchName ?? 'main';\n    this.region = config.region ?? 'eu-central-1';\n  }\n\n  /**\n   * Generate the core Amplify deployment commands\n   */\n  private getDeploymentCommands(): string[] {\n    const commands: string[] = [];\n\n    // Check and stop any pending jobs\n    commands.push('echo \"Checking for pending Amplify jobs...\"');\n    commands.push(`aws amplify list-jobs --app-id $AMPLIFY_APP_ID --branch-name ${this.branchName} --max-items 1 > amplify-last-job.json`);\n    commands.push('AMPLIFY_LAST_JOB_STATUS=$(cat amplify-last-job.json | jq -r \\'.jobSummaries[].status\\')');\n    commands.push('AMPLIFY_LAST_JOB_ID=$(cat amplify-last-job.json | jq -r \\'.jobSummaries[].jobId\\')');\n    commands.push('if [ \"$AMPLIFY_LAST_JOB_STATUS\" = \"PENDING\" ]; then');\n    commands.push(`  aws amplify stop-job --app-id $AMPLIFY_APP_ID --branch-name ${this.branchName} --job-id $AMPLIFY_LAST_JOB_ID`);\n    commands.push('fi');\n\n    // Create deployment\n    commands.push('echo \"Creating Amplify deployment...\"');\n    commands.push(`aws amplify create-deployment --app-id $AMPLIFY_APP_ID --branch-name ${this.branchName} > amplify-deploy.json`);\n    commands.push('AMPLIFY_ZIP_UPLOAD_URL=$(cat amplify-deploy.json | jq -r \\'.zipUploadUrl\\')');\n    commands.push('AMPLIFY_JOB_ID=$(cat amplify-deploy.json | jq -r \\'.jobId\\')');\n\n    // Upload artifact\n    commands.push('echo \"Uploading deployment artifact...\"');\n    commands.push(`curl -H \"Content-Type: application/zip\" $AMPLIFY_ZIP_UPLOAD_URL --upload-file ${this.config.artifactFile}`);\n\n    // Start deployment\n    commands.push('echo \"Starting Amplify deployment...\"');\n    commands.push(`aws amplify start-deployment --app-id $AMPLIFY_APP_ID --branch-name ${this.branchName} --job-id $AMPLIFY_JOB_ID`);\n\n    // Wait for deployment to complete\n    commands.push('while :; do');\n    commands.push('  sleep 10');\n    commands.push(`  STATUS=$(aws amplify get-job --app-id $AMPLIFY_APP_ID --branch-name ${this.branchName} --job-id $AMPLIFY_JOB_ID | jq -r '.job.summary.status')`);\n    commands.push('  if [ \"$STATUS\" != \"PENDING\" ] && [ \"$STATUS\" != \"RUNNING\" ]; then');\n    commands.push('    break');\n    commands.push('  fi');\n    commands.push('  echo \"Deployment status: $STATUS\"');\n    commands.push('done');\n\n    // Clean up and check final status\n    commands.push('rm -f amplify-last-job.json amplify-deploy.json');\n    commands.push('echo \"Amplify deployment completed with status: $STATUS\"');\n    commands.push('if [ \"$STATUS\" != \"SUCCEED\" ]; then');\n    commands.push('  echo \"Deployment failed with status: $STATUS\"');\n    commands.push('  exit 1');\n    commands.push('fi');\n\n    return commands;\n  }\n\n  /**\n   * Get the command to set the Amplify App ID\n   */\n  private getAppIdCommand(): string {\n    if (this.config.appId) {\n      return `AMPLIFY_APP_ID=\"${this.config.appId}\"`;\n    } else if (this.config.appIdCommand) {\n      return `AMPLIFY_APP_ID=$(${this.config.appIdCommand})`;\n    }\n    return '';\n  }\n\n  public toGitlab(): GitlabStepConfig {\n    const commands: string[] = [];\n\n    // Set Amplify App ID\n    commands.push(this.getAppIdCommand());\n\n    // Add deployment commands\n    commands.push(...this.getDeploymentCommands());\n\n    return {\n      env: {\n        AWS_REGION: this.region,\n        AWS_DEFAULT_REGION: this.region,\n      },\n      commands,\n      extensions: [],\n      needs: [],\n    };\n  }\n\n  public toGithub(): GithubStepConfig {\n    const steps = [];\n\n    // Set Amplify App ID\n    if (this.config.appId) {\n      steps.push({\n        name: 'Set Amplify App ID',\n        run: `echo \"AMPLIFY_APP_ID=${this.config.appId}\" >> $GITHUB_ENV`,\n      });\n    } else if (this.config.appIdCommand) {\n      const envStep: any = {\n        name: 'Extract Amplify App ID',\n        run: `AMPLIFY_APP_ID=$(${this.config.appIdCommand}) && echo \"AMPLIFY_APP_ID=$AMPLIFY_APP_ID\" >> $GITHUB_ENV`,\n      };\n      if (this.config.environment) {\n        envStep.env = { ENVIRONMENT: this.config.environment };\n      }\n      steps.push(envStep);\n    }\n\n    // Deploy to Amplify - use the environment variable set above\n    const deploymentScript = [\n      '#!/bin/bash -e',\n      ...this.getDeploymentCommands(),\n    ].join('\\n');\n\n    steps.push({\n      name: 'Deploy to Amplify',\n      run: deploymentScript,\n    });\n\n    return {\n      steps,\n      needs: [],\n      env: {\n        AWS_REGION: this.region,\n        AWS_DEFAULT_REGION: this.region,\n      },\n    };\n  }\n\n  public toBash(): BashStepConfig {\n    const commands: string[] = [];\n\n    // Set AWS region\n    commands.push(`export AWS_REGION=\"${this.region}\"`);\n    commands.push(`export AWS_DEFAULT_REGION=\"${this.region}\"`);\n\n    // Set Amplify App ID\n    commands.push(this.getAppIdCommand());\n\n    // Add deployment commands\n    commands.push(...this.getDeploymentCommands());\n\n    return { commands };\n  }\n\n  public toCodeCatalyst(): CodeCatalystStepConfig {\n    throw new Error('CodeCatalyst is not supported for Amplify deployment');\n  }\n}"]}
@@ -22,7 +22,7 @@ class DownloadArtifactStep extends step_1.PipelineStep {
22
22
  return {
23
23
  steps: [{
24
24
  name: 'Download Artifact',
25
- uses: 'actions/download-artifact@v4',
25
+ uses: 'actions/download-artifact@v5',
26
26
  with: {
27
27
  name: this.config.name,
28
28
  path: this.config.path,
@@ -45,7 +45,7 @@ class DownloadArtifactStep extends step_1.PipelineStep {
45
45
  }
46
46
  exports.DownloadArtifactStep = DownloadArtifactStep;
47
47
  _a = JSII_RTTI_SYMBOL_1;
48
- DownloadArtifactStep[_a] = { fqn: "projen-pipelines.DownloadArtifactStep", version: "0.2.14" };
48
+ DownloadArtifactStep[_a] = { fqn: "projen-pipelines.DownloadArtifactStep", version: "0.3.0" };
49
49
  class UploadArtifactStep extends step_1.PipelineStep {
50
50
  constructor(project, config) {
51
51
  super(project);
@@ -55,7 +55,7 @@ class UploadArtifactStep extends step_1.PipelineStep {
55
55
  return {
56
56
  steps: [{
57
57
  name: 'Upload Artifact',
58
- uses: 'actions/upload-artifact@v4.3.6',
58
+ uses: 'actions/upload-artifact@v4.6.2',
59
59
  with: {
60
60
  name: this.config.name,
61
61
  path: this.config.path,
@@ -78,5 +78,5 @@ class UploadArtifactStep extends step_1.PipelineStep {
78
78
  }
79
79
  exports.UploadArtifactStep = UploadArtifactStep;
80
80
  _b = JSII_RTTI_SYMBOL_1;
81
- UploadArtifactStep[_b] = { fqn: "projen-pipelines.UploadArtifactStep", version: "0.2.14" };
82
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXJ0aWZhY3Qtc3RlcHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvc3RlcHMvYXJ0aWZhY3Qtc3RlcHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFDQSxpQ0FBa0c7QUFPbEcsTUFBYSxvQkFBcUIsU0FBUSxtQkFBWTtJQUVwRCxZQUFZLE9BQWdCLEVBQW1CLE1BQWtDO1FBQy9FLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUQ4QixXQUFNLEdBQU4sTUFBTSxDQUE0QjtJQUVqRixDQUFDO0lBRU0sUUFBUTtRQUNiLHdEQUF3RDtRQUN4RCxPQUFPO1lBQ0wsR0FBRyxFQUFFLEVBQUU7WUFDUCxVQUFVLEVBQUUsRUFBRTtZQUNkLEtBQUssRUFBRSxFQUFFO1lBQ1QsUUFBUSxFQUFFLEVBQUU7U0FDYixDQUFDO0lBQ0osQ0FBQztJQUNNLFFBQVE7UUFDYixPQUFPO1lBQ0wsS0FBSyxFQUFFLENBQUM7b0JBQ04sSUFBSSxFQUFFLG1CQUFtQjtvQkFDekIsSUFBSSxFQUFFLDhCQUE4QjtvQkFDcEMsSUFBSSxFQUFFO3dCQUNKLElBQUksRUFBRSxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUk7d0JBQ3RCLElBQUksRUFBRSxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUk7cUJBQ3ZCO2lCQUNGLENBQUM7WUFDRixLQUFLLEVBQUUsRUFBRTtZQUNULEdBQUcsRUFBRSxFQUFFO1NBQ1IsQ0FBQztJQUNKLENBQUM7SUFFRDs7T0FFRztJQUNJLGNBQWM7UUFDbkIsT0FBTztZQUNMLEtBQUssRUFBRSxFQUFFLEVBQUUsbUJBQW1CO1lBQzlCLFFBQVEsRUFBRSxFQUFFLEVBQUUseURBQXlEO1lBQ3ZFLEdBQUcsRUFBRSxFQUFFLEVBQUUsNEJBQTRCO1NBQ3RDLENBQUM7SUFDSixDQUFDOztBQXZDSCxvREF3Q0M7OztBQVFELE1BQWEsa0JBQW1CLFNBQVEsbUJBQVk7SUFFbEQsWUFBWSxPQUFnQixFQUFtQixNQUFnQztRQUM3RSxLQUFLLENBQUMsT0FBTyxDQUFDLENBQUM7UUFEOEIsV0FBTSxHQUFOLE1BQU0sQ0FBMEI7SUFFL0UsQ0FBQztJQUVNLFFBQVE7UUFDYixPQUFPO1lBQ0wsS0FBSyxFQUFFLENBQUM7b0JBQ04sSUFBSSxFQUFFLGlCQUFpQjtvQkFDdkIsSUFBSSxFQUFFLGdDQUFnQztvQkFDdEMsSUFBSSxFQUFFO3dCQUNKLElBQUksRUFBRSxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUk7d0JBQ3RCLElBQUksRUFBRSxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUk7cUJBQ3ZCO2lCQUNGLENBQUM7WUFDRixLQUFLLEVBQUUsRUFBRTtZQUNULEdBQUcsRUFBRSxFQUFFO1NBQ1IsQ0FBQztJQUNKLENBQUM7SUFFRDs7T0FFRztJQUNJLGNBQWM7UUFDbkIsT0FBTztZQUNMLEtBQUssRUFBRSxFQUFFLEVBQUUsbUJBQW1CO1lBQzlCLFFBQVEsRUFBRSxFQUFFLEVBQUUseURBQXlEO1lBQ3ZFLEdBQUcsRUFBRSxFQUFFLEVBQUUsNEJBQTRCO1NBQ3RDLENBQUM7SUFDSixDQUFDOztBQTlCSCxnREFnQ0MiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQcm9qZWN0IH0gZnJvbSAncHJvamVuJztcbmltcG9ydCB7IENvZGVDYXRhbHlzdFN0ZXBDb25maWcsIEdpdGh1YlN0ZXBDb25maWcsIEdpdGxhYlN0ZXBDb25maWcsIFBpcGVsaW5lU3RlcCB9IGZyb20gJy4vc3RlcCc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgRG93bmxvYWRBcnRpZmFjdFN0ZXBDb25maWcge1xuICByZWFkb25seSBuYW1lOiBzdHJpbmc7XG4gIHJlYWRvbmx5IHBhdGg6IHN0cmluZztcbn1cblxuZXhwb3J0IGNsYXNzIERvd25sb2FkQXJ0aWZhY3RTdGVwIGV4dGVuZHMgUGlwZWxpbmVTdGVwIHtcblxuICBjb25zdHJ1Y3Rvcihwcm9qZWN0OiBQcm9qZWN0LCBwcml2YXRlIHJlYWRvbmx5IGNvbmZpZzogRG93bmxvYWRBcnRpZmFjdFN0ZXBDb25maWcpIHtcbiAgICBzdXBlcihwcm9qZWN0KTtcbiAgfVxuXG4gIHB1YmxpYyB0b0dpdGxhYigpOiBHaXRsYWJTdGVwQ29uZmlnIHtcbiAgICAvLyBOb3RoaW5nIHRvIGRvOyBhcnRpZmFjdCBpcyBhbHJlYWR5IGRvd25sb2FkZWQgZm9yIHlvdVxuICAgIHJldHVybiB7XG4gICAgICBlbnY6IHt9LFxuICAgICAgZXh0ZW5zaW9uczogW10sXG4gICAgICBuZWVkczogW10sXG4gICAgICBjb21tYW5kczogW10sXG4gICAgfTtcbiAgfVxuICBwdWJsaWMgdG9HaXRodWIoKTogR2l0aHViU3RlcENvbmZpZyB7XG4gICAgcmV0dXJuIHtcbiAgICAgIHN0ZXBzOiBbe1xuICAgICAgICBuYW1lOiAnRG93bmxvYWQgQXJ0aWZhY3QnLFxuICAgICAgICB1c2VzOiAnYWN0aW9ucy9kb3dubG9hZC1hcnRpZmFjdEB2NCcsXG4gICAgICAgIHdpdGg6IHtcbiAgICAgICAgICBuYW1lOiB0aGlzLmNvbmZpZy5uYW1lLFxuICAgICAgICAgIHBhdGg6IHRoaXMuY29uZmlnLnBhdGgsXG4gICAgICAgIH0sXG4gICAgICB9XSxcbiAgICAgIG5lZWRzOiBbXSxcbiAgICAgIGVudjoge30sXG4gICAgfTtcbiAgfVxuXG4gIC8qKlxuICAgKiBDb252ZXJ0cyB0aGUgc3RlcCBpbnRvIGEgQ29kZUNhdGFseXN0IEFjdGlvbnMgc3RlcCBjb25maWd1cmF0aW9uLlxuICAgKi9cbiAgcHVibGljIHRvQ29kZUNhdGFseXN0KCk6IENvZGVDYXRhbHlzdFN0ZXBDb25maWcge1xuICAgIHJldHVybiB7XG4gICAgICBuZWVkczogW10sIC8vIE5vIGRlcGVuZGVuY2llcy5cbiAgICAgIGNvbW1hbmRzOiBbXSwgLy8gTWFwcyBlYWNoIGNvbW1hbmQgaW50byBhIENvZGVDYXRhbHlzdCBBY3Rpb24gam9iIHN0ZXAuXG4gICAgICBlbnY6IHt9LCAvLyBObyBlbnZpcm9ubWVudCB2YXJpYWJsZXMuXG4gICAgfTtcbiAgfVxufVxuXG5cbmV4cG9ydCBpbnRlcmZhY2UgVXBsb2FkQXJ0aWZhY3RTdGVwQ29uZmlnIHtcbiAgcmVhZG9ubHkgbmFtZTogc3RyaW5nO1xuICByZWFkb25seSBwYXRoOiBzdHJpbmc7XG59XG5cbmV4cG9ydCBjbGFzcyBVcGxvYWRBcnRpZmFjdFN0ZXAgZXh0ZW5kcyBQaXBlbGluZVN0ZXAge1xuXG4gIGNvbnN0cnVjdG9yKHByb2plY3Q6IFByb2plY3QsIHByaXZhdGUgcmVhZG9ubHkgY29uZmlnOiBVcGxvYWRBcnRpZmFjdFN0ZXBDb25maWcpIHtcbiAgICBzdXBlcihwcm9qZWN0KTtcbiAgfVxuXG4gIHB1YmxpYyB0b0dpdGh1YigpOiBHaXRodWJTdGVwQ29uZmlnIHtcbiAgICByZXR1cm4ge1xuICAgICAgc3RlcHM6IFt7XG4gICAgICAgIG5hbWU6ICdVcGxvYWQgQXJ0aWZhY3QnLFxuICAgICAgICB1c2VzOiAnYWN0aW9ucy91cGxvYWQtYXJ0aWZhY3RAdjQuMy42JyxcbiAgICAgICAgd2l0aDoge1xuICAgICAgICAgIG5hbWU6IHRoaXMuY29uZmlnLm5hbWUsXG4gICAgICAgICAgcGF0aDogdGhpcy5jb25maWcucGF0aCxcbiAgICAgICAgfSxcbiAgICAgIH1dLFxuICAgICAgbmVlZHM6IFtdLFxuICAgICAgZW52OiB7fSxcbiAgICB9O1xuICB9XG5cbiAgLyoqXG4gICAqIENvbnZlcnRzIHRoZSBzdGVwIGludG8gYSBDb2RlQ2F0YWx5c3QgQWN0aW9ucyBzdGVwIGNvbmZpZ3VyYXRpb24uXG4gICAqL1xuICBwdWJsaWMgdG9Db2RlQ2F0YWx5c3QoKTogQ29kZUNhdGFseXN0U3RlcENvbmZpZyB7XG4gICAgcmV0dXJuIHtcbiAgICAgIG5lZWRzOiBbXSwgLy8gTm8gZGVwZW5kZW5jaWVzLlxuICAgICAgY29tbWFuZHM6IFtdLCAvLyBNYXBzIGVhY2ggY29tbWFuZCBpbnRvIGEgQ29kZUNhdGFseXN0IEFjdGlvbiBqb2Igc3RlcC5cbiAgICAgIGVudjoge30sIC8vIE5vIGVudmlyb25tZW50IHZhcmlhYmxlcy5cbiAgICB9O1xuICB9XG5cbn0iXX0=
81
+ UploadArtifactStep[_b] = { fqn: "projen-pipelines.UploadArtifactStep", version: "0.3.0" };
82
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXJ0aWZhY3Qtc3RlcHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvc3RlcHMvYXJ0aWZhY3Qtc3RlcHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFDQSxpQ0FBa0c7QUFPbEcsTUFBYSxvQkFBcUIsU0FBUSxtQkFBWTtJQUVwRCxZQUFZLE9BQWdCLEVBQW1CLE1BQWtDO1FBQy9FLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUQ4QixXQUFNLEdBQU4sTUFBTSxDQUE0QjtJQUVqRixDQUFDO0lBRU0sUUFBUTtRQUNiLHdEQUF3RDtRQUN4RCxPQUFPO1lBQ0wsR0FBRyxFQUFFLEVBQUU7WUFDUCxVQUFVLEVBQUUsRUFBRTtZQUNkLEtBQUssRUFBRSxFQUFFO1lBQ1QsUUFBUSxFQUFFLEVBQUU7U0FDYixDQUFDO0lBQ0osQ0FBQztJQUNNLFFBQVE7UUFDYixPQUFPO1lBQ0wsS0FBSyxFQUFFLENBQUM7b0JBQ04sSUFBSSxFQUFFLG1CQUFtQjtvQkFDekIsSUFBSSxFQUFFLDhCQUE4QjtvQkFDcEMsSUFBSSxFQUFFO3dCQUNKLElBQUksRUFBRSxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUk7d0JBQ3RCLElBQUksRUFBRSxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUk7cUJBQ3ZCO2lCQUNGLENBQUM7WUFDRixLQUFLLEVBQUUsRUFBRTtZQUNULEdBQUcsRUFBRSxFQUFFO1NBQ1IsQ0FBQztJQUNKLENBQUM7SUFFRDs7T0FFRztJQUNJLGNBQWM7UUFDbkIsT0FBTztZQUNMLEtBQUssRUFBRSxFQUFFLEVBQUUsbUJBQW1CO1lBQzlCLFFBQVEsRUFBRSxFQUFFLEVBQUUseURBQXlEO1lBQ3ZFLEdBQUcsRUFBRSxFQUFFLEVBQUUsNEJBQTRCO1NBQ3RDLENBQUM7SUFDSixDQUFDOztBQXZDSCxvREF3Q0M7OztBQVFELE1BQWEsa0JBQW1CLFNBQVEsbUJBQVk7SUFFbEQsWUFBWSxPQUFnQixFQUFtQixNQUFnQztRQUM3RSxLQUFLLENBQUMsT0FBTyxDQUFDLENBQUM7UUFEOEIsV0FBTSxHQUFOLE1BQU0sQ0FBMEI7SUFFL0UsQ0FBQztJQUVNLFFBQVE7UUFDYixPQUFPO1lBQ0wsS0FBSyxFQUFFLENBQUM7b0JBQ04sSUFBSSxFQUFFLGlCQUFpQjtvQkFDdkIsSUFBSSxFQUFFLGdDQUFnQztvQkFDdEMsSUFBSSxFQUFFO3dCQUNKLElBQUksRUFBRSxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUk7d0JBQ3RCLElBQUksRUFBRSxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUk7cUJBQ3ZCO2lCQUNGLENBQUM7WUFDRixLQUFLLEVBQUUsRUFBRTtZQUNULEdBQUcsRUFBRSxFQUFFO1NBQ1IsQ0FBQztJQUNKLENBQUM7SUFFRDs7T0FFRztJQUNJLGNBQWM7UUFDbkIsT0FBTztZQUNMLEtBQUssRUFBRSxFQUFFLEVBQUUsbUJBQW1CO1lBQzlCLFFBQVEsRUFBRSxFQUFFLEVBQUUseURBQXlEO1lBQ3ZFLEdBQUcsRUFBRSxFQUFFLEVBQUUsNEJBQTRCO1NBQ3RDLENBQUM7SUFDSixDQUFDOztBQTlCSCxnREFnQ0MiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQcm9qZWN0IH0gZnJvbSAncHJvamVuJztcbmltcG9ydCB7IENvZGVDYXRhbHlzdFN0ZXBDb25maWcsIEdpdGh1YlN0ZXBDb25maWcsIEdpdGxhYlN0ZXBDb25maWcsIFBpcGVsaW5lU3RlcCB9IGZyb20gJy4vc3RlcCc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgRG93bmxvYWRBcnRpZmFjdFN0ZXBDb25maWcge1xuICByZWFkb25seSBuYW1lOiBzdHJpbmc7XG4gIHJlYWRvbmx5IHBhdGg6IHN0cmluZztcbn1cblxuZXhwb3J0IGNsYXNzIERvd25sb2FkQXJ0aWZhY3RTdGVwIGV4dGVuZHMgUGlwZWxpbmVTdGVwIHtcblxuICBjb25zdHJ1Y3Rvcihwcm9qZWN0OiBQcm9qZWN0LCBwcml2YXRlIHJlYWRvbmx5IGNvbmZpZzogRG93bmxvYWRBcnRpZmFjdFN0ZXBDb25maWcpIHtcbiAgICBzdXBlcihwcm9qZWN0KTtcbiAgfVxuXG4gIHB1YmxpYyB0b0dpdGxhYigpOiBHaXRsYWJTdGVwQ29uZmlnIHtcbiAgICAvLyBOb3RoaW5nIHRvIGRvOyBhcnRpZmFjdCBpcyBhbHJlYWR5IGRvd25sb2FkZWQgZm9yIHlvdVxuICAgIHJldHVybiB7XG4gICAgICBlbnY6IHt9LFxuICAgICAgZXh0ZW5zaW9uczogW10sXG4gICAgICBuZWVkczogW10sXG4gICAgICBjb21tYW5kczogW10sXG4gICAgfTtcbiAgfVxuICBwdWJsaWMgdG9HaXRodWIoKTogR2l0aHViU3RlcENvbmZpZyB7XG4gICAgcmV0dXJuIHtcbiAgICAgIHN0ZXBzOiBbe1xuICAgICAgICBuYW1lOiAnRG93bmxvYWQgQXJ0aWZhY3QnLFxuICAgICAgICB1c2VzOiAnYWN0aW9ucy9kb3dubG9hZC1hcnRpZmFjdEB2NScsXG4gICAgICAgIHdpdGg6IHtcbiAgICAgICAgICBuYW1lOiB0aGlzLmNvbmZpZy5uYW1lLFxuICAgICAgICAgIHBhdGg6IHRoaXMuY29uZmlnLnBhdGgsXG4gICAgICAgIH0sXG4gICAgICB9XSxcbiAgICAgIG5lZWRzOiBbXSxcbiAgICAgIGVudjoge30sXG4gICAgfTtcbiAgfVxuXG4gIC8qKlxuICAgKiBDb252ZXJ0cyB0aGUgc3RlcCBpbnRvIGEgQ29kZUNhdGFseXN0IEFjdGlvbnMgc3RlcCBjb25maWd1cmF0aW9uLlxuICAgKi9cbiAgcHVibGljIHRvQ29kZUNhdGFseXN0KCk6IENvZGVDYXRhbHlzdFN0ZXBDb25maWcge1xuICAgIHJldHVybiB7XG4gICAgICBuZWVkczogW10sIC8vIE5vIGRlcGVuZGVuY2llcy5cbiAgICAgIGNvbW1hbmRzOiBbXSwgLy8gTWFwcyBlYWNoIGNvbW1hbmQgaW50byBhIENvZGVDYXRhbHlzdCBBY3Rpb24gam9iIHN0ZXAuXG4gICAgICBlbnY6IHt9LCAvLyBObyBlbnZpcm9ubWVudCB2YXJpYWJsZXMuXG4gICAgfTtcbiAgfVxufVxuXG5cbmV4cG9ydCBpbnRlcmZhY2UgVXBsb2FkQXJ0aWZhY3RTdGVwQ29uZmlnIHtcbiAgcmVhZG9ubHkgbmFtZTogc3RyaW5nO1xuICByZWFkb25seSBwYXRoOiBzdHJpbmc7XG59XG5cbmV4cG9ydCBjbGFzcyBVcGxvYWRBcnRpZmFjdFN0ZXAgZXh0ZW5kcyBQaXBlbGluZVN0ZXAge1xuXG4gIGNvbnN0cnVjdG9yKHByb2plY3Q6IFByb2plY3QsIHByaXZhdGUgcmVhZG9ubHkgY29uZmlnOiBVcGxvYWRBcnRpZmFjdFN0ZXBDb25maWcpIHtcbiAgICBzdXBlcihwcm9qZWN0KTtcbiAgfVxuXG4gIHB1YmxpYyB0b0dpdGh1YigpOiBHaXRodWJTdGVwQ29uZmlnIHtcbiAgICByZXR1cm4ge1xuICAgICAgc3RlcHM6IFt7XG4gICAgICAgIG5hbWU6ICdVcGxvYWQgQXJ0aWZhY3QnLFxuICAgICAgICB1c2VzOiAnYWN0aW9ucy91cGxvYWQtYXJ0aWZhY3RAdjQuNi4yJyxcbiAgICAgICAgd2l0aDoge1xuICAgICAgICAgIG5hbWU6IHRoaXMuY29uZmlnLm5hbWUsXG4gICAgICAgICAgcGF0aDogdGhpcy5jb25maWcucGF0aCxcbiAgICAgICAgfSxcbiAgICAgIH1dLFxuICAgICAgbmVlZHM6IFtdLFxuICAgICAgZW52OiB7fSxcbiAgICB9O1xuICB9XG5cbiAgLyoqXG4gICAqIENvbnZlcnRzIHRoZSBzdGVwIGludG8gYSBDb2RlQ2F0YWx5c3QgQWN0aW9ucyBzdGVwIGNvbmZpZ3VyYXRpb24uXG4gICAqL1xuICBwdWJsaWMgdG9Db2RlQ2F0YWx5c3QoKTogQ29kZUNhdGFseXN0U3RlcENvbmZpZyB7XG4gICAgcmV0dXJuIHtcbiAgICAgIG5lZWRzOiBbXSwgLy8gTm8gZGVwZW5kZW5jaWVzLlxuICAgICAgY29tbWFuZHM6IFtdLCAvLyBNYXBzIGVhY2ggY29tbWFuZCBpbnRvIGEgQ29kZUNhdGFseXN0IEFjdGlvbiBqb2Igc3RlcC5cbiAgICAgIGVudjoge30sIC8vIE5vIGVudmlyb25tZW50IHZhcmlhYmxlcy5cbiAgICB9O1xuICB9XG5cbn0iXX0=
@@ -30,7 +30,7 @@ class AwsAssumeRoleStep extends step_1.PipelineStep {
30
30
  return {
31
31
  steps: [{
32
32
  name: 'AWS Credentials',
33
- uses: 'aws-actions/configure-aws-credentials@v4',
33
+ uses: 'aws-actions/configure-aws-credentials@v5',
34
34
  with: {
35
35
  'role-to-assume': this.config.roleArn,
36
36
  'role-session-name': this.config.sessionName ?? 'GitHubAction',
@@ -62,5 +62,5 @@ class AwsAssumeRoleStep extends step_1.PipelineStep {
62
62
  }
63
63
  exports.AwsAssumeRoleStep = AwsAssumeRoleStep;
64
64
  _a = JSII_RTTI_SYMBOL_1;
65
- AwsAssumeRoleStep[_a] = { fqn: "projen-pipelines.AwsAssumeRoleStep", version: "0.2.14" };
66
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXdzLWFzc3VtZS1yb2xlLnN0ZXAuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvc3RlcHMvYXdzLWFzc3VtZS1yb2xlLnN0ZXAudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFDQSx1RUFBa0U7QUFDbEUsaUNBQWtIO0FBZWxIOztHQUVHO0FBQ0gsTUFBYSxpQkFBa0IsU0FBUSxtQkFBWTtJQUVqRCxZQUFZLE9BQWdCLEVBQW1CLE1BQStCO1FBQzVFLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUQ4QixXQUFNLEdBQU4sTUFBTSxDQUF5QjtJQUU5RSxDQUFDO0lBRU0sUUFBUTtRQUNiLE1BQU0sV0FBVyxHQUFHLElBQUksQ0FBQyxNQUFNLENBQUMsV0FBVyxJQUFJLG9EQUFvRCxDQUFDO1FBQ3BHLE9BQU87WUFDTCxHQUFHLEVBQUU7Z0JBQ0gsR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsRUFBRSxVQUFVLEVBQUUsSUFBSSxDQUFDLE1BQU0sQ0FBQyxNQUFNLEVBQUUsQ0FBQyxDQUFDLENBQUMsRUFBRTthQUNoRTtZQUNELFFBQVEsRUFBRTtnQkFDUiw0SUFBNEksSUFBSSxDQUFDLE1BQU0sQ0FBQyxPQUFPLDBCQUEwQixXQUFXLCtJQUErSTthQUNwVjtZQUNELFVBQVUsRUFBRSxFQUFFO1lBQ2QsS0FBSyxFQUFFLEVBQUU7U0FDVixDQUFDO0lBQ0osQ0FBQztJQUVNLFFBQVE7UUFDYixPQUFPO1lBQ0wsS0FBSyxFQUFFLENBQUM7b0JBQ04sSUFBSSxFQUFFLGlCQUFpQjtvQkFDdkIsSUFBSSxFQUFFLDBDQUEwQztvQkFDaEQsSUFBSSxFQUFFO3dCQUNKLGdCQUFnQixFQUFFLElBQUksQ0FBQyxNQUFNLENBQUMsT0FBTzt3QkFDckMsbUJBQW1CLEVBQUUsSUFBSSxDQUFDLE1BQU0sQ0FBQyxXQUFXLElBQUksY0FBYzt3QkFDOUQsR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsRUFBRSxZQUFZLEVBQUUsSUFBSSxDQUFDLE1BQU0sQ0FBQyxNQUFNLEVBQUUsQ0FBQyxDQUFDLENBQUMsRUFBRSxZQUFZLEVBQUUsV0FBVyxFQUFFO3FCQUM3RjtpQkFDRixDQUFDO1lBQ0YsS0FBSyxFQUFFLEVBQUU7WUFDVCxHQUFHLEVBQUUsRUFBRTtZQUNQLFdBQVcsRUFBRTtnQkFDWCxPQUFPLEVBQUUsK0JBQWEsQ0FBQyxLQUFLO2FBQzdCO1NBQ0YsQ0FBQztJQUNKLENBQUM7SUFFTSxNQUFNO1FBQ1gsT0FBTztZQUNMLFFBQVEsRUFBRTtnQkFDUixpQ0FBaUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxPQUFPLGVBQWUsSUFBSSxDQUFDLE1BQU0sQ0FBQyxNQUFNLElBQUksV0FBVyxHQUFHO2FBQ3hHO1NBQ0YsQ0FBQztJQUNKLENBQUM7SUFFTSxjQUFjO1FBQ25CLGdDQUFnQztRQUNoQyxPQUFPO1lBQ0wsUUFBUSxFQUFFLEVBQUU7WUFDWixHQUFHLEVBQUUsRUFBRTtZQUNQLEtBQUssRUFBRSxFQUFFO1NBQ1YsQ0FBQztJQUNKLENBQUM7O0FBdERILDhDQXdEQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFByb2plY3QgfSBmcm9tICdwcm9qZW4nO1xuaW1wb3J0IHsgSm9iUGVybWlzc2lvbiB9IGZyb20gJ3Byb2plbi9saWIvZ2l0aHViL3dvcmtmbG93cy1tb2RlbCc7XG5pbXBvcnQgeyBCYXNoU3RlcENvbmZpZywgQ29kZUNhdGFseXN0U3RlcENvbmZpZywgR2l0aHViU3RlcENvbmZpZywgR2l0bGFiU3RlcENvbmZpZywgUGlwZWxpbmVTdGVwIH0gZnJvbSAnLi9zdGVwJztcblxuXG4vKipcbiAqIENvbmZpZ3VyYXRpb24gZm9yIGFuIEFXUyBBc3N1bWVSb2xlU3RlcFxuICovXG5leHBvcnQgaW50ZXJmYWNlIEF3c0Fzc3VtZVJvbGVTdGVwQ29uZmlnIHtcbiAgLyoqIFRoZSBBUk4gb2YgdGhlIHJvbGUgdG8gYXNzdW1lICovXG4gIHJlYWRvbmx5IHJvbGVBcm46IHN0cmluZztcbiAgLyoqIEFuIGlkZW50aWZpZXIgZm9yIHRoZSBhc3N1bWVkIHJvbGUgc2Vzc2lvbiAqL1xuICByZWFkb25seSBzZXNzaW9uTmFtZT86IHN0cmluZztcbiAgLyoqIFRoZSBBV1MgcmVnaW9uIHRoYXQgc2hvdWxkIGJlIHNldCAqL1xuICByZWFkb25seSByZWdpb24/OiBzdHJpbmc7XG59XG5cbi8qKlxuICogQSBzdGVwIHRoYXQgYXNzdW1lcyBhIHJvbGUgaW4gQVdTXG4gKi9cbmV4cG9ydCBjbGFzcyBBd3NBc3N1bWVSb2xlU3RlcCBleHRlbmRzIFBpcGVsaW5lU3RlcCB7XG5cbiAgY29uc3RydWN0b3IocHJvamVjdDogUHJvamVjdCwgcHJpdmF0ZSByZWFkb25seSBjb25maWc6IEF3c0Fzc3VtZVJvbGVTdGVwQ29uZmlnKSB7XG4gICAgc3VwZXIocHJvamVjdCk7XG4gIH1cblxuICBwdWJsaWMgdG9HaXRsYWIoKTogR2l0bGFiU3RlcENvbmZpZyB7XG4gICAgY29uc3Qgc2Vzc2lvbk5hbWUgPSB0aGlzLmNvbmZpZy5zZXNzaW9uTmFtZSA/PyAnR2l0TGFiUnVubmVyLVxcJHtDSV9QUk9KRUNUX0lEfS1cXCR7Q0lfUElQRUxJTkVfSUR9fSc7XG4gICAgcmV0dXJuIHtcbiAgICAgIGVudjoge1xuICAgICAgICAuLi50aGlzLmNvbmZpZy5yZWdpb24gPyB7IEFXU19SRUdJT046IHRoaXMuY29uZmlnLnJlZ2lvbiB9IDoge30sXG4gICAgICB9LFxuICAgICAgY29tbWFuZHM6IFtcbiAgICAgICAgYGV4cG9ydCAkKHByaW50ZiBcIkFXU19BQ0NFU1NfS0VZX0lEPSVzIEFXU19TRUNSRVRfQUNDRVNTX0tFWT0lcyBBV1NfU0VTU0lPTl9UT0tFTj0lc1wiICQoYXdzIHN0cyBhc3N1bWUtcm9sZS13aXRoLXdlYi1pZGVudGl0eSAtLXJvbGUtYXJuIFwiJHt0aGlzLmNvbmZpZy5yb2xlQXJufVwiIC0tcm9sZS1zZXNzaW9uLW5hbWUgXCIke3Nlc3Npb25OYW1lfVwiIC0td2ViLWlkZW50aXR5LXRva2VuIFxcJHtBV1NfVE9LRU59IC0tZHVyYXRpb24tc2Vjb25kcyAzNjAwIC0tcXVlcnkgJ0NyZWRlbnRpYWxzLltBY2Nlc3NLZXlJZCxTZWNyZXRBY2Nlc3NLZXksU2Vzc2lvblRva2VuXScgLS1vdXRwdXQgdGV4dCkpYCxcbiAgICAgIF0sXG4gICAgICBleHRlbnNpb25zOiBbXSxcbiAgICAgIG5lZWRzOiBbXSxcbiAgICB9O1xuICB9XG5cbiAgcHVibGljIHRvR2l0aHViKCk6IEdpdGh1YlN0ZXBDb25maWcge1xuICAgIHJldHVybiB7XG4gICAgICBzdGVwczogW3tcbiAgICAgICAgbmFtZTogJ0FXUyBDcmVkZW50aWFscycsXG4gICAgICAgIHVzZXM6ICdhd3MtYWN0aW9ucy9jb25maWd1cmUtYXdzLWNyZWRlbnRpYWxzQHY0JyxcbiAgICAgICAgd2l0aDoge1xuICAgICAgICAgICdyb2xlLXRvLWFzc3VtZSc6IHRoaXMuY29uZmlnLnJvbGVBcm4sXG4gICAgICAgICAgJ3JvbGUtc2Vzc2lvbi1uYW1lJzogdGhpcy5jb25maWcuc2Vzc2lvbk5hbWUgPz8gJ0dpdEh1YkFjdGlvbicsXG4gICAgICAgICAgLi4udGhpcy5jb25maWcucmVnaW9uID8geyAnYXdzLXJlZ2lvbic6IHRoaXMuY29uZmlnLnJlZ2lvbiB9IDogeyAnYXdzLXJlZ2lvbic6ICd1cy1lYXN0LTEnIH0sXG4gICAgICAgIH0sXG4gICAgICB9XSxcbiAgICAgIG5lZWRzOiBbXSxcbiAgICAgIGVudjoge30sXG4gICAgICBwZXJtaXNzaW9uczoge1xuICAgICAgICBpZFRva2VuOiBKb2JQZXJtaXNzaW9uLldSSVRFLFxuICAgICAgfSxcbiAgICB9O1xuICB9XG5cbiAgcHVibGljIHRvQmFzaCgpOiBCYXNoU3RlcENvbmZpZyB7XG4gICAgcmV0dXJuIHtcbiAgICAgIGNvbW1hbmRzOiBbXG4gICAgICAgIGBlY2hvIFwiTG9naW4gdG8gQVdTIHVzaW5nIHJvbGUgJHt0aGlzLmNvbmZpZy5yb2xlQXJufSBmb3IgcmVnaW9uICR7dGhpcy5jb25maWcucmVnaW9uID8/ICd1bmRlZmluZWQnfVwiYCxcbiAgICAgIF0sXG4gICAgfTtcbiAgfVxuXG4gIHB1YmxpYyB0b0NvZGVDYXRhbHlzdCgpOiBDb2RlQ2F0YWx5c3RTdGVwQ29uZmlnIHtcbiAgICAvL0ZJWE1FIHVzZSBDQyBlbnZpcm9ubWVudHMgaGVyZVxuICAgIHJldHVybiB7XG4gICAgICBjb21tYW5kczogW10sXG4gICAgICBlbnY6IHt9LFxuICAgICAgbmVlZHM6IFtdLFxuICAgIH07XG4gIH1cblxufSJdfQ==
65
+ AwsAssumeRoleStep[_a] = { fqn: "projen-pipelines.AwsAssumeRoleStep", version: "0.3.0" };
66
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXdzLWFzc3VtZS1yb2xlLnN0ZXAuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvc3RlcHMvYXdzLWFzc3VtZS1yb2xlLnN0ZXAudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFDQSx1RUFBa0U7QUFDbEUsaUNBQWtIO0FBZWxIOztHQUVHO0FBQ0gsTUFBYSxpQkFBa0IsU0FBUSxtQkFBWTtJQUVqRCxZQUFZLE9BQWdCLEVBQW1CLE1BQStCO1FBQzVFLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUQ4QixXQUFNLEdBQU4sTUFBTSxDQUF5QjtJQUU5RSxDQUFDO0lBRU0sUUFBUTtRQUNiLE1BQU0sV0FBVyxHQUFHLElBQUksQ0FBQyxNQUFNLENBQUMsV0FBVyxJQUFJLG9EQUFvRCxDQUFDO1FBQ3BHLE9BQU87WUFDTCxHQUFHLEVBQUU7Z0JBQ0gsR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsRUFBRSxVQUFVLEVBQUUsSUFBSSxDQUFDLE1BQU0sQ0FBQyxNQUFNLEVBQUUsQ0FBQyxDQUFDLENBQUMsRUFBRTthQUNoRTtZQUNELFFBQVEsRUFBRTtnQkFDUiw0SUFBNEksSUFBSSxDQUFDLE1BQU0sQ0FBQyxPQUFPLDBCQUEwQixXQUFXLCtJQUErSTthQUNwVjtZQUNELFVBQVUsRUFBRSxFQUFFO1lBQ2QsS0FBSyxFQUFFLEVBQUU7U0FDVixDQUFDO0lBQ0osQ0FBQztJQUVNLFFBQVE7UUFDYixPQUFPO1lBQ0wsS0FBSyxFQUFFLENBQUM7b0JBQ04sSUFBSSxFQUFFLGlCQUFpQjtvQkFDdkIsSUFBSSxFQUFFLDBDQUEwQztvQkFDaEQsSUFBSSxFQUFFO3dCQUNKLGdCQUFnQixFQUFFLElBQUksQ0FBQyxNQUFNLENBQUMsT0FBTzt3QkFDckMsbUJBQW1CLEVBQUUsSUFBSSxDQUFDLE1BQU0sQ0FBQyxXQUFXLElBQUksY0FBYzt3QkFDOUQsR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsRUFBRSxZQUFZLEVBQUUsSUFBSSxDQUFDLE1BQU0sQ0FBQyxNQUFNLEVBQUUsQ0FBQyxDQUFDLENBQUMsRUFBRSxZQUFZLEVBQUUsV0FBVyxFQUFFO3FCQUM3RjtpQkFDRixDQUFDO1lBQ0YsS0FBSyxFQUFFLEVBQUU7WUFDVCxHQUFHLEVBQUUsRUFBRTtZQUNQLFdBQVcsRUFBRTtnQkFDWCxPQUFPLEVBQUUsK0JBQWEsQ0FBQyxLQUFLO2FBQzdCO1NBQ0YsQ0FBQztJQUNKLENBQUM7SUFFTSxNQUFNO1FBQ1gsT0FBTztZQUNMLFFBQVEsRUFBRTtnQkFDUixpQ0FBaUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxPQUFPLGVBQWUsSUFBSSxDQUFDLE1BQU0sQ0FBQyxNQUFNLElBQUksV0FBVyxHQUFHO2FBQ3hHO1NBQ0YsQ0FBQztJQUNKLENBQUM7SUFFTSxjQUFjO1FBQ25CLGdDQUFnQztRQUNoQyxPQUFPO1lBQ0wsUUFBUSxFQUFFLEVBQUU7WUFDWixHQUFHLEVBQUUsRUFBRTtZQUNQLEtBQUssRUFBRSxFQUFFO1NBQ1YsQ0FBQztJQUNKLENBQUM7O0FBdERILDhDQXdEQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFByb2plY3QgfSBmcm9tICdwcm9qZW4nO1xuaW1wb3J0IHsgSm9iUGVybWlzc2lvbiB9IGZyb20gJ3Byb2plbi9saWIvZ2l0aHViL3dvcmtmbG93cy1tb2RlbCc7XG5pbXBvcnQgeyBCYXNoU3RlcENvbmZpZywgQ29kZUNhdGFseXN0U3RlcENvbmZpZywgR2l0aHViU3RlcENvbmZpZywgR2l0bGFiU3RlcENvbmZpZywgUGlwZWxpbmVTdGVwIH0gZnJvbSAnLi9zdGVwJztcblxuXG4vKipcbiAqIENvbmZpZ3VyYXRpb24gZm9yIGFuIEFXUyBBc3N1bWVSb2xlU3RlcFxuICovXG5leHBvcnQgaW50ZXJmYWNlIEF3c0Fzc3VtZVJvbGVTdGVwQ29uZmlnIHtcbiAgLyoqIFRoZSBBUk4gb2YgdGhlIHJvbGUgdG8gYXNzdW1lICovXG4gIHJlYWRvbmx5IHJvbGVBcm46IHN0cmluZztcbiAgLyoqIEFuIGlkZW50aWZpZXIgZm9yIHRoZSBhc3N1bWVkIHJvbGUgc2Vzc2lvbiAqL1xuICByZWFkb25seSBzZXNzaW9uTmFtZT86IHN0cmluZztcbiAgLyoqIFRoZSBBV1MgcmVnaW9uIHRoYXQgc2hvdWxkIGJlIHNldCAqL1xuICByZWFkb25seSByZWdpb24/OiBzdHJpbmc7XG59XG5cbi8qKlxuICogQSBzdGVwIHRoYXQgYXNzdW1lcyBhIHJvbGUgaW4gQVdTXG4gKi9cbmV4cG9ydCBjbGFzcyBBd3NBc3N1bWVSb2xlU3RlcCBleHRlbmRzIFBpcGVsaW5lU3RlcCB7XG5cbiAgY29uc3RydWN0b3IocHJvamVjdDogUHJvamVjdCwgcHJpdmF0ZSByZWFkb25seSBjb25maWc6IEF3c0Fzc3VtZVJvbGVTdGVwQ29uZmlnKSB7XG4gICAgc3VwZXIocHJvamVjdCk7XG4gIH1cblxuICBwdWJsaWMgdG9HaXRsYWIoKTogR2l0bGFiU3RlcENvbmZpZyB7XG4gICAgY29uc3Qgc2Vzc2lvbk5hbWUgPSB0aGlzLmNvbmZpZy5zZXNzaW9uTmFtZSA/PyAnR2l0TGFiUnVubmVyLVxcJHtDSV9QUk9KRUNUX0lEfS1cXCR7Q0lfUElQRUxJTkVfSUR9fSc7XG4gICAgcmV0dXJuIHtcbiAgICAgIGVudjoge1xuICAgICAgICAuLi50aGlzLmNvbmZpZy5yZWdpb24gPyB7IEFXU19SRUdJT046IHRoaXMuY29uZmlnLnJlZ2lvbiB9IDoge30sXG4gICAgICB9LFxuICAgICAgY29tbWFuZHM6IFtcbiAgICAgICAgYGV4cG9ydCAkKHByaW50ZiBcIkFXU19BQ0NFU1NfS0VZX0lEPSVzIEFXU19TRUNSRVRfQUNDRVNTX0tFWT0lcyBBV1NfU0VTU0lPTl9UT0tFTj0lc1wiICQoYXdzIHN0cyBhc3N1bWUtcm9sZS13aXRoLXdlYi1pZGVudGl0eSAtLXJvbGUtYXJuIFwiJHt0aGlzLmNvbmZpZy5yb2xlQXJufVwiIC0tcm9sZS1zZXNzaW9uLW5hbWUgXCIke3Nlc3Npb25OYW1lfVwiIC0td2ViLWlkZW50aXR5LXRva2VuIFxcJHtBV1NfVE9LRU59IC0tZHVyYXRpb24tc2Vjb25kcyAzNjAwIC0tcXVlcnkgJ0NyZWRlbnRpYWxzLltBY2Nlc3NLZXlJZCxTZWNyZXRBY2Nlc3NLZXksU2Vzc2lvblRva2VuXScgLS1vdXRwdXQgdGV4dCkpYCxcbiAgICAgIF0sXG4gICAgICBleHRlbnNpb25zOiBbXSxcbiAgICAgIG5lZWRzOiBbXSxcbiAgICB9O1xuICB9XG5cbiAgcHVibGljIHRvR2l0aHViKCk6IEdpdGh1YlN0ZXBDb25maWcge1xuICAgIHJldHVybiB7XG4gICAgICBzdGVwczogW3tcbiAgICAgICAgbmFtZTogJ0FXUyBDcmVkZW50aWFscycsXG4gICAgICAgIHVzZXM6ICdhd3MtYWN0aW9ucy9jb25maWd1cmUtYXdzLWNyZWRlbnRpYWxzQHY1JyxcbiAgICAgICAgd2l0aDoge1xuICAgICAgICAgICdyb2xlLXRvLWFzc3VtZSc6IHRoaXMuY29uZmlnLnJvbGVBcm4sXG4gICAgICAgICAgJ3JvbGUtc2Vzc2lvbi1uYW1lJzogdGhpcy5jb25maWcuc2Vzc2lvbk5hbWUgPz8gJ0dpdEh1YkFjdGlvbicsXG4gICAgICAgICAgLi4udGhpcy5jb25maWcucmVnaW9uID8geyAnYXdzLXJlZ2lvbic6IHRoaXMuY29uZmlnLnJlZ2lvbiB9IDogeyAnYXdzLXJlZ2lvbic6ICd1cy1lYXN0LTEnIH0sXG4gICAgICAgIH0sXG4gICAgICB9XSxcbiAgICAgIG5lZWRzOiBbXSxcbiAgICAgIGVudjoge30sXG4gICAgICBwZXJtaXNzaW9uczoge1xuICAgICAgICBpZFRva2VuOiBKb2JQZXJtaXNzaW9uLldSSVRFLFxuICAgICAgfSxcbiAgICB9O1xuICB9XG5cbiAgcHVibGljIHRvQmFzaCgpOiBCYXNoU3RlcENvbmZpZyB7XG4gICAgcmV0dXJuIHtcbiAgICAgIGNvbW1hbmRzOiBbXG4gICAgICAgIGBlY2hvIFwiTG9naW4gdG8gQVdTIHVzaW5nIHJvbGUgJHt0aGlzLmNvbmZpZy5yb2xlQXJufSBmb3IgcmVnaW9uICR7dGhpcy5jb25maWcucmVnaW9uID8/ICd1bmRlZmluZWQnfVwiYCxcbiAgICAgIF0sXG4gICAgfTtcbiAgfVxuXG4gIHB1YmxpYyB0b0NvZGVDYXRhbHlzdCgpOiBDb2RlQ2F0YWx5c3RTdGVwQ29uZmlnIHtcbiAgICAvL0ZJWE1FIHVzZSBDQyBlbnZpcm9ubWVudHMgaGVyZVxuICAgIHJldHVybiB7XG4gICAgICBjb21tYW5kczogW10sXG4gICAgICBlbnY6IHt9LFxuICAgICAgbmVlZHM6IFtdLFxuICAgIH07XG4gIH1cblxufSJdfQ==
@@ -2,3 +2,4 @@ export * from './step';
2
2
  export * from './artifact-steps';
3
3
  export * from './aws-assume-role.step';
4
4
  export * from './registries';
5
+ export * from './amplify-deploy.step';
@@ -18,4 +18,5 @@ __exportStar(require("./step"), exports);
18
18
  __exportStar(require("./artifact-steps"), exports);
19
19
  __exportStar(require("./aws-assume-role.step"), exports);
20
20
  __exportStar(require("./registries"), exports);
21
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvc3RlcHMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLHlDQUF1QjtBQUN2QixtREFBaUM7QUFDakMseURBQXVDO0FBQ3ZDLCtDQUE2QiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vc3RlcCc7XG5leHBvcnQgKiBmcm9tICcuL2FydGlmYWN0LXN0ZXBzJztcbmV4cG9ydCAqIGZyb20gJy4vYXdzLWFzc3VtZS1yb2xlLnN0ZXAnO1xuZXhwb3J0ICogZnJvbSAnLi9yZWdpc3RyaWVzJzsiXX0=
21
+ __exportStar(require("./amplify-deploy.step"), exports);
22
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvc3RlcHMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLHlDQUF1QjtBQUN2QixtREFBaUM7QUFDakMseURBQXVDO0FBQ3ZDLCtDQUE2QjtBQUM3Qix3REFBc0MiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL3N0ZXAnO1xuZXhwb3J0ICogZnJvbSAnLi9hcnRpZmFjdC1zdGVwcyc7XG5leHBvcnQgKiBmcm9tICcuL2F3cy1hc3N1bWUtcm9sZS5zdGVwJztcbmV4cG9ydCAqIGZyb20gJy4vcmVnaXN0cmllcyc7XG5leHBvcnQgKiBmcm9tICcuL2FtcGxpZnktZGVwbG95LnN0ZXAnOyJdfQ==
@@ -8,17 +8,56 @@ export interface GithubPackagesLoginStepOptions {
8
8
  */
9
9
  readonly write?: boolean;
10
10
  }
11
+ /**
12
+ * Step to set the GITHUB_TOKEN environment variable from a secret.
13
+ *
14
+ * Only supported for GitHub as it is GitHub specific.
15
+ */
11
16
  export declare class GithubPackagesLoginStep extends PipelineStep {
12
17
  private options;
13
18
  constructor(project: Project, options: GithubPackagesLoginStepOptions);
14
19
  toGithub(): GithubStepConfig;
15
20
  }
21
+ export interface NpmSecretStepOptions {
22
+ /**
23
+ * Name of the secret to set for the environment variable NPM_TOKEN.
24
+ *
25
+ * @default 'NPM_TOKEN'
26
+ */
27
+ readonly secretName?: string;
28
+ }
29
+ /**
30
+ * Step to set the NPM_TOKEN environment variable from a secret.
31
+ *
32
+ * Currently only supported and needed for GitHub.
33
+ * Gitlab sets the NPM_TOKEN environment variable automatically from the project's settings.
34
+ */
35
+ export declare class NpmSecretStep extends PipelineStep {
36
+ private options;
37
+ constructor(project: Project, options: NpmSecretStepOptions);
38
+ toGithub(): GithubStepConfig;
39
+ }
40
+ /**
41
+ * Options for the CodeArtifactLoginStep.
42
+ */
16
43
  export interface CodeArtifactLoginStepOptions {
17
44
  readonly ownerAccount: string;
18
45
  readonly region: string;
19
46
  readonly domainName: string;
20
47
  readonly role: string;
48
+ /**
49
+ * The environment variable name to set.
50
+ *
51
+ * @default 'CODEARTIFACT_AUTH_TOKEN'
52
+ */
53
+ readonly envVariableName?: string;
21
54
  }
55
+ /**
56
+ * Step to login to CodeArtifact.
57
+ *
58
+ * The environment variable name can be configured to avoid conflicts with other environment variables.
59
+ * The default is CODEARTIFACT_AUTH_TOKEN.
60
+ */
22
61
  export declare class CodeArtifactLoginStep extends StepSequence {
23
62
  protected options: CodeArtifactLoginStepOptions;
24
63
  constructor(project: Project, options: CodeArtifactLoginStepOptions);