UNPKG

aws-delivlib

Version:

A fabulous library for defining continuous pipelines for building, testing and releasing code libraries.

123 lines • 18.6 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.WritableGitHubRepo = exports.GitHubRepo = exports.CodeCommitRepo = void 0; const aws_cdk_lib_1 = require("aws-cdk-lib"); class CodeCommitRepo { constructor(repository) { this.repository = repository; this.allowsBadge = false; } createSourceStage(pipeline, branch) { const stage = pipeline.addStage({ stageName: 'Source', }); const sourceOutput = new aws_cdk_lib_1.aws_codepipeline.Artifact('Source'); stage.addAction(new aws_cdk_lib_1.aws_codepipeline_actions.CodeCommitSourceAction({ actionName: 'Pull', repository: this.repository, branch, output: sourceOutput, })); return sourceOutput; } get repositoryUrlHttp() { return this.repository.repositoryCloneUrlHttp; } get repositoryUrlSsh() { return this.repository.repositoryCloneUrlSsh; } createBuildSource(_, _webhook, options = {}) { return aws_cdk_lib_1.aws_codebuild.Source.codeCommit({ repository: this.repository, cloneDepth: options.cloneDepth, }); } describe() { return this.repository.repositoryName; } } exports.CodeCommitRepo = CodeCommitRepo; class GitHubRepo { constructor(props) { this.allowsBadge = true; const repository = props.repository; if (repository.indexOf('/') == -1) { throw new Error('Repository must be of the form "account/repo"'); } const [owner, repo] = repository.split('/'); this.owner = owner; this.repo = repo; this.tokenSecretArn = props.tokenSecretArn; this.tokenSecretOptions = props.tokenSecretOptions; } get repositoryUrlHttp() { return `https://github.com/${this.owner}/${this.repo}.git`; } get repositoryUrlSsh() { return `git@github.com:${this.owner}/${this.repo}.git`; } createSourceStage(pipeline, branch) { const stage = pipeline.addStage({ stageName: 'Source' }); const sourceOutput = new aws_cdk_lib_1.aws_codepipeline.Artifact('Source'); stage.addAction(new aws_cdk_lib_1.aws_codepipeline_actions.GitHubSourceAction({ actionName: 'Pull', branch, oauthToken: aws_cdk_lib_1.SecretValue.secretsManager(this.tokenSecretArn, this.tokenSecretOptions), owner: this.owner, repo: this.repo, output: sourceOutput, })); return sourceOutput; } createBuildSource(_, webhook, options = {}) { if (options.branch && options.branches) { throw new Error('Specify at most one of \'branch\' and \'branches\''); } const branches = options.branches ?? (options.branch ? [options.branch] : []); return aws_cdk_lib_1.aws_codebuild.Source.gitHub({ owner: this.owner, repo: this.repo, webhook, cloneDepth: options.cloneDepth, reportBuildStatus: webhook, webhookFilters: webhook ? this.createWebhookFilters(branches) : undefined, }); } describe() { return `${this.owner}/${this.repo}`; } createWebhookFilters(branches) { if (branches.length > 0) { // Turn the list of branches into a regex const branchExpr = branches.map(b => `^refs/heads/${b}$`).join('|'); return [ aws_cdk_lib_1.aws_codebuild.FilterGroup.inEventOf(aws_cdk_lib_1.aws_codebuild.EventAction.PUSH) .andHeadRefIs(branchExpr), aws_cdk_lib_1.aws_codebuild.FilterGroup.inEventOf(aws_cdk_lib_1.aws_codebuild.EventAction.PULL_REQUEST_CREATED, aws_cdk_lib_1.aws_codebuild.EventAction.PULL_REQUEST_UPDATED) .andBaseRefIs(branchExpr), ]; } return [ aws_cdk_lib_1.aws_codebuild.FilterGroup.inEventOf(aws_cdk_lib_1.aws_codebuild.EventAction.PUSH, aws_cdk_lib_1.aws_codebuild.EventAction.PULL_REQUEST_CREATED, aws_cdk_lib_1.aws_codebuild.EventAction.PULL_REQUEST_UPDATED), ]; } } exports.GitHubRepo = GitHubRepo; class WritableGitHubRepo extends GitHubRepo { static isWritableGitHubRepo(repo) { const obj = repo; return 'sshKeySecret' in obj && 'commitEmail' in obj && 'commitUsername' in obj; } constructor(props) { super(props); this.sshKeySecret = props.sshKeySecret; this.commitEmail = props.commitEmail; this.commitUsername = props.commitUsername; } } exports.WritableGitHubRepo = WritableGitHubRepo; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"repo.js","sourceRoot":"","sources":["repo.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  SecretValue, SecretsManagerSecretOptions,\n  aws_codebuild as cbuild, aws_codecommit as ccommit,\n  aws_codepipeline as cpipeline, aws_codepipeline_actions as cpipeline_actions,\n} from 'aws-cdk-lib';\nimport { Construct } from 'constructs';\nimport { ExternalSecret } from './permissions';\n\nexport interface IRepo {\n  repositoryUrlHttp: string;\n  repositoryUrlSsh: string;\n  readonly allowsBadge: boolean;\n  readonly tokenSecretArn?: string;\n  createBuildSource(parent: Construct, webhook: boolean, options?: BuildSourceOptions): cbuild.ISource;\n  createSourceStage(pipeline: cpipeline.Pipeline, branch: string): cpipeline.Artifact;\n  describe(): any;\n}\n\nexport interface BuildSourceOptions {\n  /**\n   * Single branch\n   *\n   * Cannot be specified together with `branches`.\n   *\n   * @default - All branches\n   * @deprecated Use `branches` instead.\n   */\n  branch?: string;\n\n  /**\n   * Multiple branches\n   *\n   * Cannot be specified together with `branch`.\n   *\n   * @default - All branches\n   */\n  branches?: string[];\n  cloneDepth?: number;\n}\n\nexport class CodeCommitRepo implements IRepo {\n  public readonly allowsBadge = false;\n  public readonly tokenSecretArn?: string;\n\n  constructor(private readonly repository: ccommit.IRepository) {\n\n  }\n\n  public createSourceStage(pipeline: cpipeline.Pipeline, branch: string): cpipeline.Artifact {\n    const stage = pipeline.addStage({\n      stageName: 'Source',\n    });\n    const sourceOutput = new cpipeline.Artifact('Source');\n    stage.addAction(new cpipeline_actions.CodeCommitSourceAction({\n      actionName: 'Pull',\n      repository: this.repository,\n      branch,\n      output: sourceOutput,\n    }));\n    return sourceOutput;\n  }\n\n  public get repositoryUrlHttp() {\n    return this.repository.repositoryCloneUrlHttp;\n  }\n\n  public get repositoryUrlSsh() {\n    return this.repository.repositoryCloneUrlSsh;\n  }\n\n  public createBuildSource(_: Construct, _webhook: boolean, options: BuildSourceOptions = { }): cbuild.ISource {\n    return cbuild.Source.codeCommit({\n      repository: this.repository,\n      cloneDepth: options.cloneDepth,\n    });\n  }\n\n  public describe(): any {\n    return this.repository.repositoryName;\n  }\n}\n\ninterface GitHubRepoProps {\n  /**\n   * Secrets Manager ARN of the OAuth token secret that allows access to your github repo.\n   */\n  tokenSecretArn: string;\n\n  /**\n   * Options for referencing a secret value from Secrets Manager\n   */\n  tokenSecretOptions?: SecretsManagerSecretOptions;\n\n  /**\n   * In the form \"account/repo\".\n   */\n  repository: string;\n}\n\nexport class GitHubRepo implements IRepo {\n  public readonly allowsBadge = true;\n  public readonly owner: string;\n  public readonly repo: string;\n  public readonly tokenSecretArn: string;\n  public readonly tokenSecretOptions?: SecretsManagerSecretOptions;\n\n  constructor(props: GitHubRepoProps) {\n    const repository = props.repository;\n    if (repository.indexOf('/') == -1) {\n      throw new Error('Repository must be of the form \"account/repo\"');\n    }\n    const [owner, repo] = repository.split('/');\n\n    this.owner = owner;\n    this.repo = repo;\n    this.tokenSecretArn = props.tokenSecretArn;\n    this.tokenSecretOptions = props.tokenSecretOptions;\n  }\n\n  public get repositoryUrlHttp() {\n    return `https://github.com/${this.owner}/${this.repo}.git`;\n  }\n\n  public get repositoryUrlSsh() {\n    return `git@github.com:${this.owner}/${this.repo}.git`;\n  }\n\n  public createSourceStage(pipeline: cpipeline.Pipeline, branch: string): cpipeline.Artifact {\n    const stage = pipeline.addStage({ stageName: 'Source' });\n\n    const sourceOutput = new cpipeline.Artifact('Source');\n    stage.addAction(new cpipeline_actions.GitHubSourceAction({\n      actionName: 'Pull',\n      branch,\n      oauthToken: SecretValue.secretsManager(this.tokenSecretArn, this.tokenSecretOptions),\n      owner: this.owner,\n      repo: this.repo,\n      output: sourceOutput,\n    }));\n    return sourceOutput;\n  }\n\n  public createBuildSource(_: Construct, webhook: boolean, options: BuildSourceOptions = { }): cbuild.ISource {\n    if (options.branch && options.branches) {\n      throw new Error('Specify at most one of \\'branch\\' and \\'branches\\'');\n    }\n    const branches = options.branches ?? (options.branch ? [options.branch] : []);\n\n    return cbuild.Source.gitHub({\n      owner: this.owner,\n      repo: this.repo,\n      webhook,\n      cloneDepth: options.cloneDepth,\n      reportBuildStatus: webhook,\n      webhookFilters: webhook\n        ? this.createWebhookFilters(branches)\n        : undefined,\n    });\n  }\n\n  public describe() {\n    return `${this.owner}/${this.repo}`;\n  }\n\n  private createWebhookFilters(branches: string[]) {\n    if (branches.length > 0) {\n      // Turn the list of branches into a regex\n      const branchExpr = branches.map(b => `^refs/heads/${b}$`).join('|');\n\n      return [\n        cbuild.FilterGroup.inEventOf(cbuild.EventAction.PUSH)\n          .andHeadRefIs(branchExpr),\n        cbuild.FilterGroup.inEventOf(cbuild.EventAction.PULL_REQUEST_CREATED, cbuild.EventAction.PULL_REQUEST_UPDATED)\n          .andBaseRefIs(branchExpr),\n      ];\n    }\n    return [\n      cbuild.FilterGroup.inEventOf(\n        cbuild.EventAction.PUSH,\n        cbuild.EventAction.PULL_REQUEST_CREATED,\n        cbuild.EventAction.PULL_REQUEST_UPDATED,\n      ),\n    ];\n  }\n}\n\nexport interface WritableGitHubRepoProps extends GitHubRepoProps {\n  /**\n   * SSH key associated with this repository.\n   *\n   * This is required if you wish to be able to use actions that write to the repo\n   * such as docs publishing and automatic bumps.\n   */\n  sshKeySecret: ExternalSecret;\n\n  /**\n   * The username to use for the published commits\n   */\n  commitUsername: string;\n\n  /**\n   * The email address to use for the published commits\n   */\n  commitEmail: string;\n\n}\n\nexport class WritableGitHubRepo extends GitHubRepo {\n\n  public static isWritableGitHubRepo(repo: IRepo): repo is WritableGitHubRepo {\n    const obj = repo as any;\n\n    return 'sshKeySecret' in obj\n      && 'commitEmail' in obj\n      && 'commitUsername' in obj;\n  }\n\n  public readonly sshKeySecret: ExternalSecret;\n  public readonly commitEmail: string;\n  public readonly commitUsername: string;\n\n  constructor(props: WritableGitHubRepoProps) {\n    super(props);\n\n    this.sshKeySecret = props.sshKeySecret;\n    this.commitEmail = props.commitEmail;\n    this.commitUsername = props.commitUsername;\n  }\n}\n"]}