UNPKG

projen

Version:

CDK for software projects

97 lines 13.3 kB
"use strict"; var _a; Object.defineProperty(exports, "__esModule", { value: true }); exports.GithubCredentials = void 0; const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti"); const Case = require("case"); /** * Represents a method of providing GitHub API access for projen workflows. */ class GithubCredentials { /** * Provide API access through a GitHub personal access token. * * The token must be added as a secret to the GitHub repo, and the name of the * secret can be specified here. * * @see https://docs.github.com/en/authentication/keeping-your-account-and-data-secure/creating-a-personal-access-token * @default - a secret named "PROJEN_GITHUB_TOKEN" */ static fromPersonalAccessToken(options = {}) { return new GithubCredentials({ setupSteps: [], tokenRef: `\${{ secrets.${options.secret ?? "PROJEN_GITHUB_TOKEN"} }}`, environment: options.environment, }); } /** * Provide API access through a GitHub App. * * The GitHub App must be installed on the GitHub repo, its App ID and a * private key must be added as secrets to the repo. The name of the secrets * can be specified here. * * @see https://docs.github.com/en/developers/apps/building-github-apps/creating-a-github-app * @see https://projen.io/docs/integrations/github/#github-app * @default - app id stored in "PROJEN_APP_ID" and private key stored in "PROJEN_APP_PRIVATE_KEY" with all permissions attached to the app */ static fromApp(options = {}) { const appIdSecret = options.appIdSecret ?? "PROJEN_APP_ID"; const privateKeySecret = options.privateKeySecret ?? "PROJEN_APP_PRIVATE_KEY"; const actionConfig = { "app-id": `\${{ secrets.${appIdSecret} }}`, "private-key": `\${{ secrets.${privateKeySecret} }}`, }; if (options.owner) { actionConfig.owner = options.owner; } if (options.repositories) { actionConfig.repositories = options.repositories.join(","); } const permissions = Object.entries(options.permissions ?? {}).reduce((map, [name, val]) => { map[`permission-${Case.kebab(name)}`] = val; return map; }, {}); return new GithubCredentials({ setupSteps: [ { name: "Generate token", id: "generate_token", uses: "actions/create-github-app-token@3ff1caaa28b64c9cc276ce0a02e2ff584f3900c5", with: { ...actionConfig, ...permissions, }, }, ], tokenRef: "${{ steps.generate_token.outputs.token }}", environment: options.environment, }); } constructor(options) { this.options = options; } /** * Setup steps to obtain GitHub credentials. */ get setupSteps() { return [...this.options.setupSteps]; } /** * The value to use in a workflow when a GitHub token is expected. This * typically looks like "${{ some.path.to.a.value }}". */ get tokenRef() { return this.options.tokenRef; } /** * The GitHub Actions environment the credentials have been added to. */ get environment() { return this.options.environment; } } exports.GithubCredentials = GithubCredentials; _a = JSII_RTTI_SYMBOL_1; GithubCredentials[_a] = { fqn: "projen.github.GithubCredentials", version: "0.99.16" }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"github-credentials.js","sourceRoot":"","sources":["../../src/github/github-credentials.ts"],"names":[],"mappings":";;;;;AAAA,6BAA6B;AA4E7B;;GAEG;AACH,MAAa,iBAAiB;IAC5B;;;;;;;;OAQG;IACI,MAAM,CAAC,uBAAuB,CACnC,UAAuD,EAAE;QAEzD,OAAO,IAAI,iBAAiB,CAAC;YAC3B,UAAU,EAAE,EAAE;YACd,QAAQ,EAAE,gBAAgB,OAAO,CAAC,MAAM,IAAI,qBAAqB,KAAK;YACtE,WAAW,EAAE,OAAO,CAAC,WAAW;SACjC,CAAC,CAAC;IACL,CAAC;IAED;;;;;;;;;;OAUG;IACI,MAAM,CAAC,OAAO,CAAC,UAAuC,EAAE;QAC7D,MAAM,WAAW,GAAG,OAAO,CAAC,WAAW,IAAI,eAAe,CAAC;QAC3D,MAAM,gBAAgB,GACpB,OAAO,CAAC,gBAAgB,IAAI,wBAAwB,CAAC;QAEvD,MAAM,YAAY,GAA2B;YAC3C,QAAQ,EAAE,gBAAgB,WAAW,KAAK;YAC1C,aAAa,EAAE,gBAAgB,gBAAgB,KAAK;SACrD,CAAC;QAEF,IAAI,OAAO,CAAC,KAAK,EAAE,CAAC;YAClB,YAAY,CAAC,KAAK,GAAG,OAAO,CAAC,KAAK,CAAC;QACrC,CAAC;QACD,IAAI,OAAO,CAAC,YAAY,EAAE,CAAC;YACzB,YAAY,CAAC,YAAY,GAAG,OAAO,CAAC,YAAY,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QAC7D,CAAC;QAED,MAAM,WAAW,GAAG,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,WAAW,IAAI,EAAE,CAAC,CAAC,MAAM,CAElE,CAAC,GAAG,EAAE,CAAC,IAAI,EAAE,GAAG,CAAC,EAAE,EAAE;YACrB,GAAG,CAAC,cAAc,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC;YAC5C,OAAO,GAAG,CAAC;QACb,CAAC,EAAE,EAAE,CAAC,CAAC;QAEP,OAAO,IAAI,iBAAiB,CAAC;YAC3B,UAAU,EAAE;gBACV;oBACE,IAAI,EAAE,gBAAgB;oBACtB,EAAE,EAAE,gBAAgB;oBACpB,IAAI,EAAE,0EAA0E;oBAChF,IAAI,EAAE;wBACJ,GAAG,YAAY;wBACf,GAAG,WAAW;qBACf;iBACF;aACF;YACD,QAAQ,EAAE,2CAA2C;YACrD,WAAW,EAAE,OAAO,CAAC,WAAW;SACjC,CAAC,CAAC;IACL,CAAC;IAED,YAAqC,OAAiC;QAAjC,YAAO,GAAP,OAAO,CAA0B;IAAG,CAAC;IAE1E;;OAEG;IACH,IAAW,UAAU;QACnB,OAAO,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;IACtC,CAAC;IAED;;;OAGG;IACH,IAAW,QAAQ;QACjB,OAAO,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC;IAC/B,CAAC;IAED;;OAEG;IACH,IAAW,WAAW;QACpB,OAAO,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC;IAClC,CAAC;;AA9FH,8CA+FC","sourcesContent":["import * as Case from \"case\";\nimport { JobStep, AppPermissions } from \"./workflows-model\";\n\n/**\n * Options for `GithubCredentials.fromPersonalAccessToken`\n */\nexport interface GithubCredentialsPersonalAccessTokenOptions {\n  /**\n   * The name of the secret that holds the GitHub personal access token.\n   *\n   * @default \"PROJEN_GITHUB_TOKEN\"\n   */\n  readonly secret?: string;\n\n  /**\n   * The GitHub Actions environment the secrets is added to.\n   *\n   * This can be used to add explicit approval steps to access the secret.\n   *\n   * @default - no environment used\n   */\n  readonly environment?: string;\n}\n\n/**\n * Options for `GithubCredentials.fromApp`\n */\nexport interface GithubCredentialsAppOptions {\n  /**\n   * The secret containing the GitHub App ID\n   *\n   * @default \"PROJEN_APP_ID\"\n   */\n  readonly appIdSecret?: string;\n\n  /**\n   * The secret containing the GitHub App private key\n   *\n   * Escaped newlines (\\\\n) will be automatically replaced with actual newlines.\n   *\n   * @default \"PROJEN_APP_PRIVATE_KEY\"\n   */\n  readonly privateKeySecret?: string;\n\n  /**\n   * The owner of the GitHub App installation\n   *\n   * @default - if empty, defaults to the current repository owner\n   */\n  readonly owner?: string;\n\n  /**\n   * List of repositories to grant access to\n   *\n   * @default - if owner is set and repositories is empty, access will be scoped to all repositories in the provided repository owner's installation.\n   * If owner and repositories are empty, access will be scoped to only the current repository.\n   */\n  readonly repositories?: string[];\n\n  /**\n   * The permissions granted to the token.\n   *\n   * @default - all permissions granted to the app\n   */\n  readonly permissions?: AppPermissions;\n\n  /**\n   * The GitHub Actions environment the secrets are added to.\n   *\n   * This can be used to add explicit approval steps to access the secrets.\n   *\n   * @default - no environment used\n   */\n  readonly environment?: string;\n}\n\n/**\n * Represents a method of providing GitHub API access for projen workflows.\n */\nexport class GithubCredentials {\n  /**\n   * Provide API access through a GitHub personal access token.\n   *\n   * The token must be added as a secret to the GitHub repo, and the name of the\n   * secret can be specified here.\n   *\n   * @see https://docs.github.com/en/authentication/keeping-your-account-and-data-secure/creating-a-personal-access-token\n   * @default - a secret named \"PROJEN_GITHUB_TOKEN\"\n   */\n  public static fromPersonalAccessToken(\n    options: GithubCredentialsPersonalAccessTokenOptions = {},\n  ) {\n    return new GithubCredentials({\n      setupSteps: [],\n      tokenRef: `\\${{ secrets.${options.secret ?? \"PROJEN_GITHUB_TOKEN\"} }}`,\n      environment: options.environment,\n    });\n  }\n\n  /**\n   * Provide API access through a GitHub App.\n   *\n   * The GitHub App must be installed on the GitHub repo, its App ID and a\n   * private key must be added as secrets to the repo. The name of the secrets\n   * can be specified here.\n   *\n   * @see https://docs.github.com/en/developers/apps/building-github-apps/creating-a-github-app\n   * @see https://projen.io/docs/integrations/github/#github-app\n   * @default - app id stored in \"PROJEN_APP_ID\" and private key stored in \"PROJEN_APP_PRIVATE_KEY\" with all permissions attached to the app\n   */\n  public static fromApp(options: GithubCredentialsAppOptions = {}) {\n    const appIdSecret = options.appIdSecret ?? \"PROJEN_APP_ID\";\n    const privateKeySecret =\n      options.privateKeySecret ?? \"PROJEN_APP_PRIVATE_KEY\";\n\n    const actionConfig: Record<string, string> = {\n      \"app-id\": `\\${{ secrets.${appIdSecret} }}`,\n      \"private-key\": `\\${{ secrets.${privateKeySecret} }}`,\n    };\n\n    if (options.owner) {\n      actionConfig.owner = options.owner;\n    }\n    if (options.repositories) {\n      actionConfig.repositories = options.repositories.join(\",\");\n    }\n\n    const permissions = Object.entries(options.permissions ?? {}).reduce<\n      Record<string, string>\n    >((map, [name, val]) => {\n      map[`permission-${Case.kebab(name)}`] = val;\n      return map;\n    }, {});\n\n    return new GithubCredentials({\n      setupSteps: [\n        {\n          name: \"Generate token\",\n          id: \"generate_token\",\n          uses: \"actions/create-github-app-token@3ff1caaa28b64c9cc276ce0a02e2ff584f3900c5\",\n          with: {\n            ...actionConfig,\n            ...permissions,\n          },\n        },\n      ],\n      tokenRef: \"${{ steps.generate_token.outputs.token }}\",\n      environment: options.environment,\n    });\n  }\n\n  private constructor(private readonly options: GithubCredentialsOptions) {}\n\n  /**\n   * Setup steps to obtain GitHub credentials.\n   */\n  public get setupSteps(): JobStep[] {\n    return [...this.options.setupSteps];\n  }\n\n  /**\n   * The value to use in a workflow when a GitHub token is expected. This\n   * typically looks like \"${{ some.path.to.a.value }}\".\n   */\n  public get tokenRef(): string {\n    return this.options.tokenRef;\n  }\n\n  /**\n   * The GitHub Actions environment the credentials have been added to.\n   */\n  public get environment(): string | undefined {\n    return this.options.environment;\n  }\n}\n\ninterface GithubCredentialsOptions {\n  readonly setupSteps: JobStep[];\n  readonly tokenRef: string;\n  readonly environment?: string;\n}\n"]}