mirror of
https://github.com/actions/stale.git
synced 2025-12-28 11:08:18 +00:00
Compare commits
1 Commits
ethomson/u
...
package-ni
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
0d4fcbf2f9 |
@@ -11,7 +11,7 @@ Basic:
|
|||||||
name: "Close stale issues"
|
name: "Close stale issues"
|
||||||
on:
|
on:
|
||||||
schedule:
|
schedule:
|
||||||
- cron: "0 0 * * *"
|
- cron: "0 * * * *"
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
stale:
|
stale:
|
||||||
@@ -29,7 +29,7 @@ Configure stale timeouts:
|
|||||||
name: "Close stale issues"
|
name: "Close stale issues"
|
||||||
on:
|
on:
|
||||||
schedule:
|
schedule:
|
||||||
- cron: "0 0 * * *"
|
- cron: "0 * * * *"
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
stale:
|
stale:
|
||||||
@@ -48,7 +48,7 @@ Configure labels:
|
|||||||
name: "Close stale issues"
|
name: "Close stale issues"
|
||||||
on:
|
on:
|
||||||
schedule:
|
schedule:
|
||||||
- cron: "0 0 * * *"
|
- cron: "0 * * * *"
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
stale:
|
stale:
|
||||||
@@ -60,7 +60,5 @@ jobs:
|
|||||||
stale-issue-message: 'Stale issue message'
|
stale-issue-message: 'Stale issue message'
|
||||||
stale-pr-message: 'Stale issue message'
|
stale-pr-message: 'Stale issue message'
|
||||||
stale-issue-label: 'no-issue-activity'
|
stale-issue-label: 'no-issue-activity'
|
||||||
exempt-issue-label: 'awaiting-approval'
|
|
||||||
stale-pr-label: 'no-pr-activity'
|
stale-pr-label: 'no-pr-activity'
|
||||||
exempt-pr-label: 'awaiting-approval'
|
|
||||||
```
|
```
|
||||||
|
|||||||
18
action.yml
18
action.yml
@@ -1,33 +1,29 @@
|
|||||||
name: 'Close Stale Issues'
|
name: 'Close Stale Issues'
|
||||||
description: 'Close issues and pull requests with no recent activity'
|
description: 'Action to close stale issues'
|
||||||
author: 'GitHub'
|
author: 'GitHub'
|
||||||
inputs:
|
inputs:
|
||||||
repo-token:
|
repo-token:
|
||||||
description: 'Token for the repository. Can be passed in using {{ secrets.GITHUB_TOKEN }}'
|
description: 'Token for the repo. Can be passed in using {{ secrets.GITHUB_TOKEN }}'
|
||||||
required: true
|
required: true
|
||||||
stale-issue-message:
|
stale-issue-message:
|
||||||
description: 'The message to post on the issue when tagging it. If none provided, will not mark issues stale.'
|
description: 'The message to post on the issue when tagging it. If none provided, will not mark iusses stale.'
|
||||||
stale-pr-message:
|
stale-pr-message:
|
||||||
description: 'The message to post on the pr when tagging it. If none provided, will not mark pull requests stale.'
|
description: 'The message to post on the pr when tagging it. If none provided, will not mark prs stale.'
|
||||||
days-before-stale:
|
days-before-stale:
|
||||||
description: 'The number of days old an issue can be before marking it stale'
|
description: 'The number of days old an issue can be before marking it stale'
|
||||||
default: 60
|
default: 60
|
||||||
days-before-close:
|
days-before-close:
|
||||||
description: 'The number of days to wait to close an issue or pull request after it being marked stale'
|
description: 'The number of days to wait to close an issue or pr after it being marked stale'
|
||||||
default: 7
|
default: 7
|
||||||
stale-issue-label:
|
stale-issue-label:
|
||||||
description: 'The label to apply when an issue is stale'
|
description: 'The label to apply when an issue is stale'
|
||||||
default: 'Stale'
|
default: 'Stale'
|
||||||
exempt-issue-label:
|
|
||||||
description: 'The label to apply when an issue is exempt from being marked stale'
|
|
||||||
stale-pr-label:
|
stale-pr-label:
|
||||||
description: 'The label to apply when a pull request is stale'
|
description: 'The label to apply when a pr is stale'
|
||||||
default: 'Stale'
|
default: 'Stale'
|
||||||
exempt-pr-label:
|
|
||||||
description: 'The label to apply when a pull request is exempt from being marked stale'
|
|
||||||
operations-per-run:
|
operations-per-run:
|
||||||
description: 'The maximum number of operations per run, used to control rate limiting'
|
description: 'The maximum number of operations per run, used to control rate limiting'
|
||||||
default: 30
|
default: 30
|
||||||
runs:
|
runs:
|
||||||
using: 'node12'
|
using: 'node12'
|
||||||
main: 'lib/main.js'
|
main: 'lib/main.js'
|
||||||
@@ -12,12 +12,12 @@
|
|||||||
},
|
},
|
||||||
"repository": {
|
"repository": {
|
||||||
"type": "git",
|
"type": "git",
|
||||||
"url": "git+https://github.com/actions/stale.git"
|
"url": "git+https://github.com/actions/start-vm-action.git"
|
||||||
},
|
},
|
||||||
"keywords": [
|
"keywords": [
|
||||||
"actions",
|
"actions",
|
||||||
"node",
|
"node",
|
||||||
"stale"
|
"setup"
|
||||||
],
|
],
|
||||||
"author": "GitHub",
|
"author": "GitHub",
|
||||||
"license": "MIT",
|
"license": "MIT",
|
||||||
|
|||||||
34
src/main.ts
34
src/main.ts
@@ -2,9 +2,6 @@ import * as core from '@actions/core';
|
|||||||
import * as github from '@actions/github';
|
import * as github from '@actions/github';
|
||||||
import * as Octokit from '@octokit/rest';
|
import * as Octokit from '@octokit/rest';
|
||||||
|
|
||||||
type Issue = Octokit.IssuesListForRepoResponseItem;
|
|
||||||
type IssueLabel = Octokit.IssuesListForRepoResponseItemLabelsItem;
|
|
||||||
|
|
||||||
type Args = {
|
type Args = {
|
||||||
repoToken: string;
|
repoToken: string;
|
||||||
staleIssueMessage: string;
|
staleIssueMessage: string;
|
||||||
@@ -12,9 +9,7 @@ type Args = {
|
|||||||
daysBeforeStale: number;
|
daysBeforeStale: number;
|
||||||
daysBeforeClose: number;
|
daysBeforeClose: number;
|
||||||
staleIssueLabel: string;
|
staleIssueLabel: string;
|
||||||
exemptIssueLabel: string;
|
|
||||||
stalePrLabel: string;
|
stalePrLabel: string;
|
||||||
exemptPrLabel: string;
|
|
||||||
operationsPerRun: number;
|
operationsPerRun: number;
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -56,16 +51,13 @@ async function processIssues(
|
|||||||
|
|
||||||
let staleMessage = isPr ? args.stalePrMessage : args.staleIssueMessage;
|
let staleMessage = isPr ? args.stalePrMessage : args.staleIssueMessage;
|
||||||
if (!staleMessage) {
|
if (!staleMessage) {
|
||||||
core.debug(`skipping ${isPr ? 'pr' : 'issue'} due to empty message`);
|
core.debug(`skipping ${isPr ? "pr" : "issue"} due to empty message`);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
let staleLabel = isPr ? args.stalePrLabel : args.staleIssueLabel;
|
let staleLabel = isPr ? args.stalePrLabel : args.staleIssueLabel;
|
||||||
let exemptLabel = isPr ? args.exemptPrLabel : args.exemptIssueLabel;
|
|
||||||
|
|
||||||
if (exemptLabel && isLabeled(issue, exemptLabel)) {
|
if (isLabeledStale(issue, staleLabel)) {
|
||||||
continue;
|
|
||||||
} else if (isLabeled(issue, staleLabel)) {
|
|
||||||
if (wasLastUpdatedBefore(issue, args.daysBeforeClose)) {
|
if (wasLastUpdatedBefore(issue, args.daysBeforeClose)) {
|
||||||
operationsLeft -= await closeIssue(client, issue);
|
operationsLeft -= await closeIssue(client, issue);
|
||||||
} else {
|
} else {
|
||||||
@@ -90,14 +82,20 @@ async function processIssues(
|
|||||||
return await processIssues(client, args, operationsLeft, page + 1);
|
return await processIssues(client, args, operationsLeft, page + 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
function isLabeled(issue: Issue, label: string): boolean {
|
function isLabeledStale(
|
||||||
const labelComparer: (l: IssueLabel) => boolean = l =>
|
issue: Octokit.IssuesListForRepoResponseItem,
|
||||||
label.localeCompare(l.name, undefined, {sensitivity: 'accent'}) === 0;
|
label: string
|
||||||
|
): boolean {
|
||||||
|
const labelComparer = l =>
|
||||||
|
label.localeCompare(l.name, undefined, {sensitivity: 'accent'});
|
||||||
return issue.labels.filter(labelComparer).length > 0;
|
return issue.labels.filter(labelComparer).length > 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
function wasLastUpdatedBefore(issue: Issue, num_days: number): boolean {
|
function wasLastUpdatedBefore(
|
||||||
const daysInMillis = 1000 * 60 * 60 * 24 * num_days;
|
issue: Octokit.IssuesListForRepoResponseItem,
|
||||||
|
num_days: number
|
||||||
|
): boolean {
|
||||||
|
const daysInMillis = 1000 * 60 * 60 * num_days;
|
||||||
const millisSinceLastUpdated =
|
const millisSinceLastUpdated =
|
||||||
new Date().getTime() - new Date(issue.updated_at).getTime();
|
new Date().getTime() - new Date(issue.updated_at).getTime();
|
||||||
return millisSinceLastUpdated >= daysInMillis;
|
return millisSinceLastUpdated >= daysInMillis;
|
||||||
@@ -105,7 +103,7 @@ function wasLastUpdatedBefore(issue: Issue, num_days: number): boolean {
|
|||||||
|
|
||||||
async function markStale(
|
async function markStale(
|
||||||
client: github.GitHub,
|
client: github.GitHub,
|
||||||
issue: Issue,
|
issue: Octokit.IssuesListForRepoResponseItem,
|
||||||
staleMessage: string,
|
staleMessage: string,
|
||||||
staleLabel: string
|
staleLabel: string
|
||||||
): Promise<number> {
|
): Promise<number> {
|
||||||
@@ -130,7 +128,7 @@ async function markStale(
|
|||||||
|
|
||||||
async function closeIssue(
|
async function closeIssue(
|
||||||
client: github.GitHub,
|
client: github.GitHub,
|
||||||
issue: Issue
|
issue: Octokit.IssuesListForRepoResponseItem
|
||||||
): Promise<number> {
|
): Promise<number> {
|
||||||
core.debug(`closing issue ${issue.title} for being stale`);
|
core.debug(`closing issue ${issue.title} for being stale`);
|
||||||
|
|
||||||
@@ -156,9 +154,7 @@ function getAndValidateArgs(): Args {
|
|||||||
core.getInput('days-before-close', {required: true})
|
core.getInput('days-before-close', {required: true})
|
||||||
),
|
),
|
||||||
staleIssueLabel: core.getInput('stale-issue-label', {required: true}),
|
staleIssueLabel: core.getInput('stale-issue-label', {required: true}),
|
||||||
exemptIssueLabel: core.getInput('exempt-issue-label'),
|
|
||||||
stalePrLabel: core.getInput('stale-pr-label', {required: true}),
|
stalePrLabel: core.getInput('stale-pr-label', {required: true}),
|
||||||
exemptPrLabel: core.getInput('exempt-pr-label'),
|
|
||||||
operationsPerRun: parseInt(
|
operationsPerRun: parseInt(
|
||||||
core.getInput('operations-per-run', {required: true})
|
core.getInput('operations-per-run', {required: true})
|
||||||
)
|
)
|
||||||
|
|||||||
Reference in New Issue
Block a user