projen
Version:
CDK for software projects
83 lines • 13.1 kB
JavaScript
;
var _a;
Object.defineProperty(exports, "__esModule", { value: true });
exports.Stale = void 0;
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
const stale_util_1 = require("./stale-util");
const workflows_model_1 = require("./workflows-model");
const component_1 = require("../component");
const runner_options_1 = require("../runner-options");
/**
* Warns and then closes issues and PRs that have had no activity for a specified amount of time.
*
* The default configuration will:
*
* * Add a "Stale" label to pull requests after 14 days and closed after 2 days
* * Add a "Stale" label to issues after 60 days and closed after 7 days
* * If a comment is added, the label will be removed and timer is restarted.
*
* @see https://github.com/actions/stale
*/
class Stale extends component_1.Component {
constructor(github, options = {}) {
super(github.project);
const stale = github.addWorkflow("stale");
stale.on({
schedule: [{ cron: "0 1 * * *" }], // at 1am every day
workflowDispatch: {},
});
const pullRequests = (0, stale_util_1.renderBehavior)(options.pullRequest, {
stale: 14,
close: 2,
type: "pull request",
});
const issues = (0, stale_util_1.renderBehavior)(options.issues, {
stale: 60,
close: 7,
type: "issue",
});
const renderExemptLabels = (exemptLabels) => {
if (!exemptLabels || exemptLabels.length === 0) {
return undefined;
}
return exemptLabels.join(",");
};
stale.addJobs({
stale: {
...(0, runner_options_1.filteredRunsOnOptions)(options.runsOn, options.runsOnGroup),
permissions: {
issues: workflows_model_1.JobPermission.WRITE,
pullRequests: workflows_model_1.JobPermission.WRITE,
},
steps: [
{
uses: "actions/stale@v4",
with: {
// disable global
"days-before-stale": -1,
"days-before-close": -1,
// pull requests
"days-before-pr-stale": pullRequests.daysBeforeStale,
"days-before-pr-close": pullRequests.daysBeforeClose,
"stale-pr-message": pullRequests.staleMessage,
"close-pr-message": pullRequests.closeMessage,
"stale-pr-label": pullRequests.staleLabel,
"exempt-pr-labels": renderExemptLabels(pullRequests.exemptLabels),
// issues
"days-before-issue-stale": issues.daysBeforeStale,
"days-before-issue-close": issues.daysBeforeClose,
"stale-issue-message": issues.staleMessage,
"close-issue-message": issues.closeMessage,
"stale-issue-label": issues.staleLabel,
"exempt-issue-labels": renderExemptLabels(issues.exemptLabels),
},
},
],
},
});
}
}
exports.Stale = Stale;
_a = JSII_RTTI_SYMBOL_1;
Stale[_a] = { fqn: "projen.github.Stale", version: "0.95.2" };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"stale.js","sourceRoot":"","sources":["../../src/github/stale.ts"],"names":[],"mappings":";;;;;AACA,6CAA8C;AAC9C,uDAAkD;AAClD,4CAAyC;AACzC,sDAA8E;AA0F9E;;;;;;;;;;GAUG;AACH,MAAa,KAAM,SAAQ,qBAAS;IAClC,YAAY,MAAc,EAAE,UAAwB,EAAE;QACpD,KAAK,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;QAEtB,MAAM,KAAK,GAAG,MAAM,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;QAC1C,KAAK,CAAC,EAAE,CAAC;YACP,QAAQ,EAAE,CAAC,EAAE,IAAI,EAAE,WAAW,EAAE,CAAC,EAAE,mBAAmB;YACtD,gBAAgB,EAAE,EAAE;SACrB,CAAC,CAAC;QAEH,MAAM,YAAY,GAAG,IAAA,2BAAc,EAAC,OAAO,CAAC,WAAW,EAAE;YACvD,KAAK,EAAE,EAAE;YACT,KAAK,EAAE,CAAC;YACR,IAAI,EAAE,cAAc;SACrB,CAAC,CAAC;QACH,MAAM,MAAM,GAAG,IAAA,2BAAc,EAAC,OAAO,CAAC,MAAM,EAAE;YAC5C,KAAK,EAAE,EAAE;YACT,KAAK,EAAE,CAAC;YACR,IAAI,EAAE,OAAO;SACd,CAAC,CAAC;QAEH,MAAM,kBAAkB,GAAG,CAAC,YAAuB,EAAE,EAAE;YACrD,IAAI,CAAC,YAAY,IAAI,YAAY,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;gBAC/C,OAAO,SAAS,CAAC;YACnB,CAAC;YACD,OAAO,YAAY,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QAChC,CAAC,CAAC;QAEF,KAAK,CAAC,OAAO,CAAC;YACZ,KAAK,EAAE;gBACL,GAAG,IAAA,sCAAqB,EAAC,OAAO,CAAC,MAAM,EAAE,OAAO,CAAC,WAAW,CAAC;gBAC7D,WAAW,EAAE;oBACX,MAAM,EAAE,+BAAa,CAAC,KAAK;oBAC3B,YAAY,EAAE,+BAAa,CAAC,KAAK;iBAClC;gBACD,KAAK,EAAE;oBACL;wBACE,IAAI,EAAE,kBAAkB;wBACxB,IAAI,EAAE;4BACJ,iBAAiB;4BACjB,mBAAmB,EAAE,CAAC,CAAC;4BACvB,mBAAmB,EAAE,CAAC,CAAC;4BAEvB,gBAAgB;4BAChB,sBAAsB,EAAE,YAAY,CAAC,eAAe;4BACpD,sBAAsB,EAAE,YAAY,CAAC,eAAe;4BACpD,kBAAkB,EAAE,YAAY,CAAC,YAAY;4BAC7C,kBAAkB,EAAE,YAAY,CAAC,YAAY;4BAC7C,gBAAgB,EAAE,YAAY,CAAC,UAAU;4BACzC,kBAAkB,EAAE,kBAAkB,CAAC,YAAY,CAAC,YAAY,CAAC;4BAEjE,SAAS;4BACT,yBAAyB,EAAE,MAAM,CAAC,eAAe;4BACjD,yBAAyB,EAAE,MAAM,CAAC,eAAe;4BACjD,qBAAqB,EAAE,MAAM,CAAC,YAAY;4BAC1C,qBAAqB,EAAE,MAAM,CAAC,YAAY;4BAC1C,mBAAmB,EAAE,MAAM,CAAC,UAAU;4BACtC,qBAAqB,EAAE,kBAAkB,CAAC,MAAM,CAAC,YAAY,CAAC;yBAC/D;qBACF;iBACF;aACF;SACF,CAAC,CAAC;IACL,CAAC;;AA/DH,sBAgEC","sourcesContent":["import { GitHub } from \"./github\";\nimport { renderBehavior } from \"./stale-util\";\nimport { JobPermission } from \"./workflows-model\";\nimport { Component } from \"../component\";\nimport { GroupRunnerOptions, filteredRunsOnOptions } from \"../runner-options\";\n\n/**\n * Options for `Stale`.\n */\nexport interface StaleOptions {\n  /**\n   * How to handle stale pull requests.\n   *\n   * @default - By default, pull requests with no activity will be marked as\n   * stale after 14 days and closed within 2 days with relevant comments.\n   */\n  readonly pullRequest?: StaleBehavior;\n\n  /**\n   * How to handle stale issues.\n   *\n   * @default - By default, stale issues with no activity will be marked as\n   * stale after 60 days and closed within 7 days.\n   */\n  readonly issues?: StaleBehavior;\n\n  /**\n   * Github Runner selection labels\n   * @default [\"ubuntu-latest\"]\n   * @description Defines a target Runner by labels\n   * @throws {Error} if both `runsOn` and `runsOnGroup` are specified\n   */\n  readonly runsOn?: string[];\n\n  /**\n   * Github Runner Group selection options\n   * @description Defines a target Runner Group by name and/or labels\n   * @throws {Error} if both `runsOn` and `runsOnGroup` are specified\n   */\n  readonly runsOnGroup?: GroupRunnerOptions;\n}\n\n/**\n * Stale behavior.\n */\nexport interface StaleBehavior {\n  /**\n   * Determines if this behavior is enabled.\n   *\n   * Same as setting `daysBeforeStale` and `daysBeforeClose` to `-1`.\n   *\n   * @default true\n   */\n  readonly enabled?: boolean;\n\n  /**\n   * How many days until the issue or pull request is marked as \"Stale\". Set to -1 to disable.\n   * @default -\n   */\n  readonly daysBeforeStale?: number;\n\n  /**\n   * Days until the issue/PR is closed after it is marked as \"Stale\". Set to -1 to disable.\n   * @default -\n   */\n  readonly daysBeforeClose?: number;\n\n  /**\n   * The comment to add to the issue/PR when it becomes stale.\n   * @default \"This pull request is now marked as stale because hasn\\'t seen activity for a while. Add a comment or it will be closed soon.\"\n   */\n  readonly staleMessage?: string;\n\n  /**\n   * The comment to add to the issue/PR when it's closed\n   *\n   * @default \"Closing this pull request as it hasn\\'t seen activity for a while. Please add a comment @mentioning a maintainer when you are ready to continue.\"\n   */\n  readonly closeMessage?: string;\n\n  /**\n   * The label to apply to the issue/PR when it becomes stale.\n   * @default \"stale\"\n   */\n  readonly staleLabel?: string;\n\n  /**\n   * Label which exempt an issue/PR from becoming stale. Set to `[]` to disable.\n   *\n   * @default - [\"backlog\"]\n   */\n  readonly exemptLabels?: string[];\n}\n\n/**\n * Warns and then closes issues and PRs that have had no activity for a specified amount of time.\n *\n * The default configuration will:\n *\n *  * Add a \"Stale\" label to pull requests after 14 days and closed after 2 days\n *  * Add a \"Stale\" label to issues after 60 days and closed after 7 days\n *  * If a comment is added, the label will be removed and timer is restarted.\n *\n * @see https://github.com/actions/stale\n */\nexport class Stale extends Component {\n  constructor(github: GitHub, options: StaleOptions = {}) {\n    super(github.project);\n\n    const stale = github.addWorkflow(\"stale\");\n    stale.on({\n      schedule: [{ cron: \"0 1 * * *\" }], // at 1am every day\n      workflowDispatch: {},\n    });\n\n    const pullRequests = renderBehavior(options.pullRequest, {\n      stale: 14,\n      close: 2,\n      type: \"pull request\",\n    });\n    const issues = renderBehavior(options.issues, {\n      stale: 60,\n      close: 7,\n      type: \"issue\",\n    });\n\n    const renderExemptLabels = (exemptLabels?: string[]) => {\n      if (!exemptLabels || exemptLabels.length === 0) {\n        return undefined;\n      }\n      return exemptLabels.join(\",\");\n    };\n\n    stale.addJobs({\n      stale: {\n        ...filteredRunsOnOptions(options.runsOn, options.runsOnGroup),\n        permissions: {\n          issues: JobPermission.WRITE,\n          pullRequests: JobPermission.WRITE,\n        },\n        steps: [\n          {\n            uses: \"actions/stale@v4\",\n            with: {\n              // disable global\n              \"days-before-stale\": -1,\n              \"days-before-close\": -1,\n\n              // pull requests\n              \"days-before-pr-stale\": pullRequests.daysBeforeStale,\n              \"days-before-pr-close\": pullRequests.daysBeforeClose,\n              \"stale-pr-message\": pullRequests.staleMessage,\n              \"close-pr-message\": pullRequests.closeMessage,\n              \"stale-pr-label\": pullRequests.staleLabel,\n              \"exempt-pr-labels\": renderExemptLabels(pullRequests.exemptLabels),\n\n              // issues\n              \"days-before-issue-stale\": issues.daysBeforeStale,\n              \"days-before-issue-close\": issues.daysBeforeClose,\n              \"stale-issue-message\": issues.staleMessage,\n              \"close-issue-message\": issues.closeMessage,\n              \"stale-issue-label\": issues.staleLabel,\n              \"exempt-issue-labels\": renderExemptLabels(issues.exemptLabels),\n            },\n          },\n        ],\n      },\n    });\n  }\n}\n"]}