UNPKG

projen

Version:

CDK for software projects

73 lines 15.2 kB
"use strict"; var _a; Object.defineProperty(exports, "__esModule", { value: true }); exports.GitHubProject = void 0; const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti"); const auto_approve_1 = require("./auto-approve"); const github_1 = require("./github"); const stale_1 = require("./stale"); const clobber_1 = require("../clobber"); const gitpod_1 = require("../gitpod"); const project_1 = require("../project"); const readme_1 = require("../readme"); const util_1 = require("../util"); const vscode_1 = require("../vscode"); /** * GitHub-based project. * * @deprecated This is a *temporary* class. At the moment, our base project * types such as `NodeProject` and `JavaProject` are derived from this, but we * want to be able to use these project types outside of GitHub as well. One of * the next steps to address this is to abstract workflows so that different * "engines" can be used to implement our CI/CD solutions. */ class GitHubProject extends project_1.Project { constructor(options) { super(options); this.projectType = options.projectType ?? project_1.ProjectType.UNKNOWN; // we only allow these global services to be used in root projects const github = options.github ?? !this.parent; this.github = github ? new github_1.GitHub(this, { projenTokenSecret: options.projenTokenSecret, projenCredentials: options.projenCredentials, mergify: options.mergify, mergifyOptions: options.mergifyOptions, ...options.githubOptions, }) : undefined; const vscode = options.vscode ?? !this.parent; this.vscode = vscode ? new vscode_1.VsCode(this) : undefined; this.gitpod = options.gitpod ? new gitpod_1.Gitpod(this) : undefined; this.devContainer = options.devContainer ? new vscode_1.DevContainer(this) : undefined; if (options.clobber ?? !this.parent) { new clobber_1.Clobber(this); } new readme_1.SampleReadme(this, options.readme); if (options.autoApproveOptions && this.github) { this.autoApprove = new auto_approve_1.AutoApprove(this.github, options.autoApproveOptions); } const stale = options.stale ?? false; if (stale && this.github) { new stale_1.Stale(this.github, options.staleOptions); } } /** * Marks the provided file(s) as being generated. This is achieved using the * github-linguist attributes. Generated files do not count against the * repository statistics and language breakdown. * * @param glob the glob pattern to match (could be a file path). * * @see https://github.com/github/linguist/blob/master/docs/overrides.md */ annotateGenerated(glob) { this.gitattributes.addAttributes((0, util_1.normalizePersistedPath)(glob), "linguist-generated"); } } exports.GitHubProject = GitHubProject; _a = JSII_RTTI_SYMBOL_1; GitHubProject[_a] = { fqn: "projen.github.GitHubProject", version: "0.95.2" }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"github-project.js","sourceRoot":"","sources":["../../src/github/github-project.ts"],"names":[],"mappings":";;;;;AAAA,iDAAiE;AAEjE,qCAAiD;AAGjD,mCAA8C;AAC9C,wCAAqC;AACrC,sCAAmC;AACnC,wCAAkE;AAClE,sCAA4D;AAC5D,kCAAiD;AACjD,sCAAiD;AAuIjD;;;;;;;;GAQG;AACH,MAAa,aAAc,SAAQ,iBAAO;IAyCxC,YAAY,OAA6B;QACvC,KAAK,CAAC,OAAO,CAAC,CAAC;QAEf,IAAI,CAAC,WAAW,GAAG,OAAO,CAAC,WAAW,IAAI,qBAAW,CAAC,OAAO,CAAC;QAC9D,kEAAkE;QAClE,MAAM,MAAM,GAAG,OAAO,CAAC,MAAM,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC;QAC9C,IAAI,CAAC,MAAM,GAAG,MAAM;YAClB,CAAC,CAAC,IAAI,eAAM,CAAC,IAAI,EAAE;gBACf,iBAAiB,EAAE,OAAO,CAAC,iBAAiB;gBAC5C,iBAAiB,EAAE,OAAO,CAAC,iBAAiB;gBAC5C,OAAO,EAAE,OAAO,CAAC,OAAO;gBACxB,cAAc,EAAE,OAAO,CAAC,cAAc;gBACtC,GAAG,OAAO,CAAC,aAAa;aACzB,CAAC;YACJ,CAAC,CAAC,SAAS,CAAC;QAEd,MAAM,MAAM,GAAG,OAAO,CAAC,MAAM,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC;QAC9C,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC,CAAC,CAAC,IAAI,eAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;QAEpD,IAAI,CAAC,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,eAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;QAC5D,IAAI,CAAC,YAAY,GAAG,OAAO,CAAC,YAAY;YACtC,CAAC,CAAC,IAAI,qBAAY,CAAC,IAAI,CAAC;YACxB,CAAC,CAAC,SAAS,CAAC;QAEd,IAAI,OAAO,CAAC,OAAO,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC;YACpC,IAAI,iBAAO,CAAC,IAAI,CAAC,CAAC;QACpB,CAAC;QAED,IAAI,qBAAY,CAAC,IAAI,EAAE,OAAO,CAAC,MAAM,CAAC,CAAC;QAEvC,IAAI,OAAO,CAAC,kBAAkB,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;YAC9C,IAAI,CAAC,WAAW,GAAG,IAAI,0BAAW,CAChC,IAAI,CAAC,MAAM,EACX,OAAO,CAAC,kBAAkB,CAC3B,CAAC;QACJ,CAAC;QAED,MAAM,KAAK,GAAG,OAAO,CAAC,KAAK,IAAI,KAAK,CAAC;QACrC,IAAI,KAAK,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;YACzB,IAAI,aAAK,CAAC,IAAI,CAAC,MAAM,EAAE,OAAO,CAAC,YAAY,CAAC,CAAC;QAC/C,CAAC;IACH,CAAC;IAED;;;;;;;;OAQG;IACI,iBAAiB,CAAC,IAAY;QACnC,IAAI,CAAC,aAAa,CAAC,aAAa,CAC9B,IAAA,6BAAsB,EAAC,IAAI,CAAC,EAC5B,oBAAoB,CACrB,CAAC;IACJ,CAAC;;AAlGH,sCAmGC","sourcesContent":["import { AutoApprove, AutoApproveOptions } from \"./auto-approve\";\nimport { AutoMergeOptions } from \"./auto-merge\";\nimport { GitHub, GitHubOptions } from \"./github\";\nimport { GithubCredentials } from \"./github-credentials\";\nimport { MergifyOptions } from \"./mergify\";\nimport { Stale, StaleOptions } from \"./stale\";\nimport { Clobber } from \"../clobber\";\nimport { Gitpod } from \"../gitpod\";\nimport { Project, ProjectOptions, ProjectType } from \"../project\";\nimport { SampleReadme, SampleReadmeProps } from \"../readme\";\nimport { normalizePersistedPath } from \"../util\";\nimport { DevContainer, VsCode } from \"../vscode\";\n\n/**\n * Options for `GitHubProject`.\n */\nexport interface GitHubProjectOptions extends ProjectOptions {\n  /**\n   * Add a Gitpod development environment\n   *\n   * @default false\n   */\n  readonly gitpod?: boolean;\n\n  /**\n   * Enable VSCode integration.\n   *\n   * Enabled by default for root projects. Disabled for non-root projects.\n   *\n   * @default true\n   */\n  readonly vscode?: boolean;\n\n  /**\n   * Enable GitHub integration.\n   *\n   * Enabled by default for root projects. Disabled for non-root projects.\n   *\n   * @default true\n   */\n  readonly github?: boolean;\n\n  /**\n   * Options for GitHub integration\n   *\n   * @default - see GitHubOptions\n   */\n  readonly githubOptions?: GitHubOptions;\n\n  /**\n   * Whether mergify should be enabled on this repository or not.\n   *\n   * @default true\n   * @deprecated use `githubOptions.mergify` instead\n   */\n  readonly mergify?: boolean;\n\n  /**\n   * Options for mergify\n   *\n   * @default - default options\n   * @deprecated use `githubOptions.mergifyOptions` instead\n   */\n  readonly mergifyOptions?: MergifyOptions;\n\n  /**\n   * Add a VSCode development environment (used for GitHub Codespaces)\n   *\n   * @default false\n   */\n  readonly devContainer?: boolean;\n\n  /**\n   * Add a `clobber` task which resets the repo to origin.\n   * @default - true, but false for subprojects\n   */\n  readonly clobber?: boolean;\n\n  /**\n   * The README setup.\n   *\n   * @default - { filename: 'README.md', contents: '# replace this' }\n   * @example \"{ filename: 'readme.md', contents: '# title' }\"\n   */\n  readonly readme?: SampleReadmeProps;\n\n  /**\n   * Which type of project this is (library/app).\n   * @default ProjectType.UNKNOWN\n   * @deprecated no longer supported at the base project level\n   */\n  readonly projectType?: ProjectType;\n\n  /**\n   * Enable and configure the 'auto approve' workflow.\n   * @default - auto approve is disabled\n   */\n  readonly autoApproveOptions?: AutoApproveOptions;\n\n  /**\n   * Enable automatic merging on GitHub. Has no effect if `github.mergify`\n   * is set to false.\n   * @default true\n   */\n  readonly autoMerge?: boolean;\n\n  /**\n   * Configure options for automatic merging on GitHub. Has no effect if\n   * `github.mergify` or `autoMerge` is set to false.\n   *\n   * @default - see defaults in `AutoMergeOptions`\n   */\n  readonly autoMergeOptions?: AutoMergeOptions;\n\n  /**\n   * Auto-close stale issues and pull requests. To disable set `stale` to `false`.\n   *\n   * @default - see defaults in `StaleOptions`\n   */\n  readonly staleOptions?: StaleOptions;\n\n  /**\n   * Auto-close of stale issues and pull request. See `staleOptions` for options.\n   *\n   * @default false\n   */\n  readonly stale?: boolean;\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/**\n * GitHub-based project.\n *\n * @deprecated This is a *temporary* class. At the moment, our base project\n * types such as `NodeProject` and `JavaProject` are derived from this, but we\n * want to be able to use these project types outside of GitHub as well. One of\n * the next steps to address this is to abstract workflows so that different\n * \"engines\" can be used to implement our CI/CD solutions.\n */\nexport class GitHubProject extends Project {\n  /**\n   * Access all github components.\n   *\n   * This will be `undefined` for subprojects.\n   */\n  public readonly github: GitHub | undefined;\n\n  /**\n   * Access all VSCode components.\n   *\n   * This will be `undefined` for subprojects.\n   */\n  public readonly vscode: VsCode | undefined;\n\n  /**\n   * Access for Gitpod\n   *\n   * This will be `undefined` if gitpod boolean is false\n   */\n  public readonly gitpod: Gitpod | undefined;\n\n  /**\n   * Access for .devcontainer.json (used for GitHub Codespaces)\n   *\n   * This will be `undefined` if devContainer boolean is false\n   */\n  public readonly devContainer: DevContainer | undefined;\n\n  /*\n   * Which project type this is.\n   *\n   * @deprecated\n   */\n  public readonly projectType: ProjectType;\n\n  /**\n   * Auto approve set up for this project.\n   */\n  public readonly autoApprove?: AutoApprove;\n\n  constructor(options: GitHubProjectOptions) {\n    super(options);\n\n    this.projectType = options.projectType ?? ProjectType.UNKNOWN;\n    // we only allow these global services to be used in root projects\n    const github = options.github ?? !this.parent;\n    this.github = github\n      ? new GitHub(this, {\n          projenTokenSecret: options.projenTokenSecret,\n          projenCredentials: options.projenCredentials,\n          mergify: options.mergify,\n          mergifyOptions: options.mergifyOptions,\n          ...options.githubOptions,\n        })\n      : undefined;\n\n    const vscode = options.vscode ?? !this.parent;\n    this.vscode = vscode ? new VsCode(this) : undefined;\n\n    this.gitpod = options.gitpod ? new Gitpod(this) : undefined;\n    this.devContainer = options.devContainer\n      ? new DevContainer(this)\n      : undefined;\n\n    if (options.clobber ?? !this.parent) {\n      new Clobber(this);\n    }\n\n    new SampleReadme(this, options.readme);\n\n    if (options.autoApproveOptions && this.github) {\n      this.autoApprove = new AutoApprove(\n        this.github,\n        options.autoApproveOptions\n      );\n    }\n\n    const stale = options.stale ?? false;\n    if (stale && this.github) {\n      new Stale(this.github, options.staleOptions);\n    }\n  }\n\n  /**\n   * Marks the provided file(s) as being generated. This is achieved using the\n   * github-linguist attributes. Generated files do not count against the\n   * repository statistics and language breakdown.\n   *\n   * @param glob the glob pattern to match (could be a file path).\n   *\n   * @see https://github.com/github/linguist/blob/master/docs/overrides.md\n   */\n  public annotateGenerated(glob: string): void {\n    this.gitattributes.addAttributes(\n      normalizePersistedPath(glob),\n      \"linguist-generated\"\n    );\n  }\n}\n"]}