projen
Version:
CDK for software projects
117 lines • 20.6 kB
JavaScript
;
var _a;
Object.defineProperty(exports, "__esModule", { value: true });
exports.GitHub = void 0;
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
const actions_provider_1 = require("./actions-provider");
const dependabot_1 = require("./dependabot");
const dependency_review_1 = require("./dependency-review");
const github_credentials_1 = require("./github-credentials");
const merge_queue_1 = require("./merge-queue");
const mergify_1 = require("./mergify");
const pr_template_1 = require("./pr-template");
const pull_request_backport_1 = require("./pull-request-backport");
const pull_request_lint_1 = require("./pull-request-lint");
const workflow_steps_1 = require("./workflow-steps");
const workflows_1 = require("./workflows");
const component_1 = require("../component");
class GitHub extends component_1.Component {
/**
* Returns the `GitHub` component of a project or `undefined` if the project
* does not have a GitHub component.
*/
static of(project) {
const isGitHub = (c) => c instanceof GitHub;
return project.components.find(isGitHub);
}
constructor(project, options = {}) {
super(project);
this.actions = new actions_provider_1.GitHubActionsProvider();
this.workflowsEnabled = options.workflows ?? true;
this._downloadLfs = options.downloadLfs;
this._checkoutSubmodules = options.checkoutSubmodules;
if (options.projenCredentials && options.projenTokenSecret) {
throw new Error("projenTokenSecret is deprecated, please use projenCredentials instead");
}
// @deprecated
if (options.projenTokenSecret) {
this.projenCredentials = github_credentials_1.GithubCredentials.fromPersonalAccessToken({
secret: options.projenTokenSecret,
});
}
else if (options.projenCredentials) {
this.projenCredentials = options.projenCredentials;
}
else {
// default
this.projenCredentials = github_credentials_1.GithubCredentials.fromPersonalAccessToken({
secret: "PROJEN_GITHUB_TOKEN",
});
}
if (options.mergify ?? true) {
this.mergify = new mergify_1.Mergify(this, options.mergifyOptions);
}
if (options.mergeQueue ?? false) {
this.mergeQueue = new merge_queue_1.MergeQueue(this, options.mergeQueueOptions);
}
if (options.pullRequestLint ?? true) {
new pull_request_lint_1.PullRequestLint(this, options.pullRequestLintOptions);
}
if (options.pullRequestBackport ?? false) {
if (options.mergify) {
this.project.logger.warn("pullRequestBackport should not be used with mergify as mergify provides its own backport functionality. Please disable pullRequestBackport or mergify.");
}
new pull_request_backport_1.PullRequestBackport(this, options.pullRequestBackportOptions);
}
if (options.dependencyReview ?? false) {
new dependency_review_1.DependencyReview(this, options.dependencyReviewOptions);
}
}
/**
* All workflows.
*/
get workflows() {
const isWorkflow = (c) => c instanceof workflows_1.GithubWorkflow;
return this.project.components
.filter(isWorkflow)
.sort((w1, w2) => w1.name.localeCompare(w2.name));
}
/**
* Adds a workflow to the project.
* @param name Name of the workflow
* @returns a GithubWorkflow instance
*/
addWorkflow(name) {
const workflow = new workflows_1.GithubWorkflow(this, name);
return workflow;
}
addPullRequestTemplate(...content) {
return new pr_template_1.PullRequestTemplate(this, { lines: content });
}
addDependabot(options) {
return new dependabot_1.Dependabot(this, options);
}
/**
* Finds a GitHub workflow by name. Returns `undefined` if the workflow cannot be found.
* @param name The name of the GitHub workflow
*/
tryFindWorkflow(name) {
return this.workflows.find((w) => w.name === name);
}
/**
* Whether downloading from LFS is enabled for this GitHub project
*/
get downloadLfs() {
return this._downloadLfs ?? this.project.gitattributes.hasLfsPatterns;
}
/**
* Whether checking out Git submodules is enabled for this GitHub project.
*/
get checkoutSubmodules() {
return this._checkoutSubmodules ?? workflow_steps_1.CheckoutSubmodules.DISABLED;
}
}
exports.GitHub = GitHub;
_a = JSII_RTTI_SYMBOL_1;
GitHub[_a] = { fqn: "projen.github.GitHub", version: "0.99.64" };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"github.js","sourceRoot":"","sources":["../../src/github/github.ts"],"names":[],"mappings":"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","sourcesContent":["import { GitHubActionsProvider } from \"./actions-provider\";\nimport type { DependabotOptions } from \"./dependabot\";\nimport { Dependabot } from \"./dependabot\";\nimport type { DependencyReviewOptions } from \"./dependency-review\";\nimport { DependencyReview } from \"./dependency-review\";\nimport { GithubCredentials } from \"./github-credentials\";\nimport type { MergeQueueOptions } from \"./merge-queue\";\nimport { MergeQueue } from \"./merge-queue\";\nimport type { MergifyOptions } from \"./mergify\";\nimport { Mergify } from \"./mergify\";\nimport { PullRequestTemplate } from \"./pr-template\";\nimport type { PullRequestBackportOptions } from \"./pull-request-backport\";\nimport { PullRequestBackport } from \"./pull-request-backport\";\nimport type { PullRequestLintOptions } from \"./pull-request-lint\";\nimport { PullRequestLint } from \"./pull-request-lint\";\nimport { CheckoutSubmodules } from \"./workflow-steps\";\nimport { GithubWorkflow } from \"./workflows\";\nimport { Component } from \"../component\";\nimport type { Project } from \"../project\";\n\nexport interface GitHubOptions {\n  /**\n   * Whether mergify should be enabled on this repository or not.\n   *\n   * @default true\n   */\n  readonly mergify?: boolean;\n\n  /**\n   * Options for Mergify.\n   *\n   * @default - default options\n   */\n  readonly mergifyOptions?: MergifyOptions;\n\n  /**\n   * Whether a merge queue should be used on this repository to merge pull requests.\n   * Requires additional configuration of the repositories branch protection rules.\n   *\n   * @default false\n   */\n  readonly mergeQueue?: boolean;\n\n  /**\n   * Options for MergeQueue.\n   *\n   * @default - default options\n   */\n  readonly mergeQueueOptions?: MergeQueueOptions;\n\n  /**\n   * Enables GitHub workflows. If this is set to `false`, workflows will not be created.\n   *\n   * @default true\n   */\n  readonly workflows?: boolean;\n\n  /**\n   * Add a workflow that allows backport of PRs to other branches using labels.\n   * When opening a new PR add a backport label to it,\n   * and the PR will be backported to the target branches once the PR is merged.\n   *\n   * Should not be used together with mergify.\n   *\n   * @default false\n   */\n  readonly pullRequestBackport?: boolean;\n\n  /**\n   * Options for configuring pull request backport.\n   *\n   * @default - see defaults in `PullRequestBackportOptions`\n   */\n  readonly pullRequestBackportOptions?: PullRequestBackportOptions;\n\n  /**\n   * Add a workflow that performs basic checks for pull requests, like\n   * validating that PRs follow Conventional Commits.\n   *\n   * @default true\n   */\n  readonly pullRequestLint?: boolean;\n\n  /**\n   * Options for configuring a pull request linter.\n   *\n   * @default - see defaults in `PullRequestLintOptions`\n   */\n  readonly pullRequestLintOptions?: PullRequestLintOptions;\n\n  /**\n   * Choose a method of providing GitHub API access for projen workflows.\n   *\n   * @default - use a personal access token named PROJEN_GITHUB_TOKEN\n   */\n  readonly projenCredentials?: GithubCredentials;\n\n  /**\n   * The name of a secret which includes a GitHub Personal Access Token to be\n   * used by projen workflows. This token needs to have the `repo`, `workflows`\n   * and `packages` scope.\n   *\n   * @default \"PROJEN_GITHUB_TOKEN\"\n   * @deprecated - use `projenCredentials`\n   */\n  readonly projenTokenSecret?: string;\n\n  /**\n   * Download files in LFS in workflows\n   *\n   * @default true if the associated project has `lfsPatterns`, `false` otherwise\n   */\n  readonly downloadLfs?: boolean;\n\n  /**\n   * Enable the dependency-review-action workflow on pull requests.\n   *\n   * Adds a separate workflow that runs `actions/dependency-review-action`\n   * to scan pull requests for newly introduced vulnerable or non-compliant\n   * dependencies.\n   *\n   * @default false\n   */\n  readonly dependencyReview?: boolean;\n\n  /**\n   * Options for the dependency review workflow.\n   *\n   * Only used when `dependencyReview` is `true`.\n   *\n   * @default - default options\n   */\n  readonly dependencyReviewOptions?: DependencyReviewOptions;\n\n  /**\n   * Whether to checkout Git submodules.\n   *\n   * @default CheckoutSubmodules.DISABLED\n   */\n  readonly checkoutSubmodules?: CheckoutSubmodules;\n}\n\nexport class GitHub extends Component {\n  /**\n   * Returns the `GitHub` component of a project or `undefined` if the project\n   * does not have a GitHub component.\n   */\n  public static of(project: Project): GitHub | undefined {\n    const isGitHub = (c: Component): c is GitHub => c instanceof GitHub;\n    return project.components.find(isGitHub);\n  }\n\n  /**\n   * The `Mergify` component configured on this repository\n   * This is `undefined` if Mergify is not enabled for this repository.\n   */\n  public readonly mergify?: Mergify;\n\n  /**\n   * The `MergeQueue` component configured on this repository\n   * This is `undefined` if merge queues are not enabled for this repository.\n   */\n  public readonly mergeQueue?: MergeQueue;\n\n  /**\n   * Are workflows enabled?\n   */\n  public readonly workflowsEnabled: boolean;\n\n  /**\n   * GitHub API authentication method used by projen workflows.\n   */\n  public readonly projenCredentials: GithubCredentials;\n\n  /**\n   * The GitHub Actions provider used to manage the versions of actions used in steps\n   */\n  public readonly actions: GitHubActionsProvider;\n\n  private readonly _downloadLfs?: boolean;\n  private readonly _checkoutSubmodules?: CheckoutSubmodules;\n\n  public constructor(project: Project, options: GitHubOptions = {}) {\n    super(project);\n\n    this.actions = new GitHubActionsProvider();\n\n    this.workflowsEnabled = options.workflows ?? true;\n\n    this._downloadLfs = options.downloadLfs;\n    this._checkoutSubmodules = options.checkoutSubmodules;\n\n    if (options.projenCredentials && options.projenTokenSecret) {\n      throw new Error(\n        \"projenTokenSecret is deprecated, please use projenCredentials instead\",\n      );\n    }\n\n    // @deprecated\n    if (options.projenTokenSecret) {\n      this.projenCredentials = GithubCredentials.fromPersonalAccessToken({\n        secret: options.projenTokenSecret,\n      });\n    } else if (options.projenCredentials) {\n      this.projenCredentials = options.projenCredentials;\n    } else {\n      // default\n      this.projenCredentials = GithubCredentials.fromPersonalAccessToken({\n        secret: \"PROJEN_GITHUB_TOKEN\",\n      });\n    }\n\n    if (options.mergify ?? true) {\n      this.mergify = new Mergify(this, options.mergifyOptions);\n    }\n\n    if (options.mergeQueue ?? false) {\n      this.mergeQueue = new MergeQueue(this, options.mergeQueueOptions);\n    }\n\n    if (options.pullRequestLint ?? true) {\n      new PullRequestLint(this, options.pullRequestLintOptions);\n    }\n\n    if (options.pullRequestBackport ?? false) {\n      if (options.mergify) {\n        this.project.logger.warn(\n          \"pullRequestBackport should not be used with mergify as mergify provides its own backport functionality. Please disable pullRequestBackport or mergify.\",\n        );\n      }\n      new PullRequestBackport(this, options.pullRequestBackportOptions);\n    }\n\n    if (options.dependencyReview ?? false) {\n      new DependencyReview(this, options.dependencyReviewOptions);\n    }\n  }\n\n  /**\n   * All workflows.\n   */\n  public get workflows(): GithubWorkflow[] {\n    const isWorkflow = (c: Component): c is GithubWorkflow =>\n      c instanceof GithubWorkflow;\n    return this.project.components\n      .filter(isWorkflow)\n      .sort((w1, w2) => w1.name.localeCompare(w2.name));\n  }\n\n  /**\n   * Adds a workflow to the project.\n   * @param name Name of the workflow\n   * @returns a GithubWorkflow instance\n   */\n  public addWorkflow(name: string) {\n    const workflow = new GithubWorkflow(this, name);\n    return workflow;\n  }\n\n  public addPullRequestTemplate(...content: string[]) {\n    return new PullRequestTemplate(this, { lines: content });\n  }\n\n  public addDependabot(options?: DependabotOptions) {\n    return new Dependabot(this, options);\n  }\n\n  /**\n   * Finds a GitHub workflow by name. Returns `undefined` if the workflow cannot be found.\n   * @param name The name of the GitHub workflow\n   */\n  public tryFindWorkflow(name: string): undefined | GithubWorkflow {\n    return this.workflows.find((w) => w.name === name);\n  }\n\n  /**\n   * Whether downloading from LFS is enabled for this GitHub project\n   */\n  public get downloadLfs() {\n    return this._downloadLfs ?? this.project.gitattributes.hasLfsPatterns;\n  }\n\n  /**\n   * Whether checking out Git submodules is enabled for this GitHub project.\n   */\n  public get checkoutSubmodules(): CheckoutSubmodules {\n    return this._checkoutSubmodules ?? CheckoutSubmodules.DISABLED;\n  }\n}\n"]}