mirror of
https://github.com/DIYgod/RSSHub.git
synced 2025-12-03 02:28:23 +08:00
* style: add eslint-unicorn * style: fix unicorn/no-useless-spread * style: fix unicorn/no-useless-promise-resolve-reject * style: fix unicorn/no-for-loop * fix: codeql bad HTML filtering regexp * fix: codeql incomplete replace * fix: unicorn/no-abusive-eslint-disable * style: fix unicorn/no-new-array * style: fix unicorn/no-typeof-undefined * style: fix unicorn/no-zero-fractions * style: fix unicorn/no-empty-file * style: fix unicorn/prefer-date-now * revert: auto fix unicorn/prefer-switch on lib/v2/kuaidi100/utils.js * style: fix unicorn/prefer-array-find * style: fix unicorn/prefer-array-flat * style: fix unicorn/prefer-array-flat-map * style: fix unicorn/prefer-at * style: fix unicorn/prefer-string-starts-ends-with * style: fix unicorn/prefer-includes * fix: codeql URL substring sanitization * style: fix unicorn/prefer-optional-catch-binding * style: fix unicorn/catch-error-name * style: fix unicorn/escape-case * style: fix unicorn/prefer-native-coercion-functions * style: fix unicorn/prefer-regexp-test * style: fix unicorn/require-array-join-separator * style: fix unicorn/prefer-math-trunc * style: fix unicorn/prefer-negative-index * style: fix unicorn/prefer-dom-node-dataset * style: fix unicorn/prefer-dom-node-text-content * style: fix unicorn/prefer-query-selector * style: fix unicorn/no-array-for-each * style: fix unicorn/no-negated-condition * style: fix unicorn/prefer-add-event-listener * style: fix unicorn/import-style * style: fix prefer-regex-literals * style: disable unicorn/no-useless-switch-case * style: disable unicorn/text-encoding-identifier-case * style: fix unicorn/prefer-set-has * style: fix unicorn/prefer-spread * revert: auto fix on lib/routes/universities/ynnu/edu/base64.js * style: fix unicorn/no-useless-undefined * style: fix unicorn/no-array-push-push * style: fix unicorn/no-useless-undefined again * style: fix unicorn/no-lonely-if * style: fix unicorn/prefer-reflect-apply * style: fix unicorn/switch-case-braces * style: fix unicorn/prefer-switch * style: fix unicorn/prefer-array-some * fix: deepscan UNUSED_VAR_ASSIGN * style: fix unicorn/prefer-ternary * fix: follow-up of unicorn/prefer-ternary * revert: auto fix of unicorn/prefer-string-slice for substring() * style: disable unicorn/prefer-string-slice fix: auto fix slice over deprecated substr * style: fix unicorn/throw-new-error * style: fix unicorn/filename-case * test: fix dateParser renaming * style: fix unicorn/better-regex * style: fix unicorn/prefer-string-replace-all * fix(deps): add sanitize-html * style: fix no-prototype-builtins * style: fix unicorn/consistent-destructuring * style: fix unicorn/consistent-function-scoping * style: fix unicorn/prefer-regexp-test * style: fix unicorn/prefer-logical-operator-over-ternary * style: fix unicorn/no-array-callback-reference * style: add prefer-object-has-own * style: warn unicorn/no-empty-file * style: fix unicorn/prefer-number-properties * style: fix no-useless-undefined again * style: fix unicorn/numeric-separators-style * style: disable unicorn/no-array-callback-reference false postive with cheerio
121 lines
3.7 KiB
JavaScript
121 lines
3.7 KiB
JavaScript
const noFound = 'Auto: Route No Found';
|
|
const allowedUser = new Set(['dependabot[bot]', 'pull[bot]']); // dependabot and downstream PR requested by pull[bot]
|
|
|
|
module.exports = async ({ github, context, core }, body, number, sender) => {
|
|
core.debug(`sender: ${sender}`);
|
|
core.debug(`body: ${body}`);
|
|
const m = body.match(/```routes\s+([\S\s]*?)```/);
|
|
core.debug(`match: ${m}`);
|
|
let res = null;
|
|
|
|
const issueFacts = {
|
|
owner: context.repo.owner,
|
|
repo: context.repo.repo,
|
|
issue_number: number,
|
|
};
|
|
const prFacts = {
|
|
owner: context.repo.owner,
|
|
repo: context.repo.repo,
|
|
pull_number: number,
|
|
};
|
|
|
|
const addLabels = (labels) =>
|
|
github.rest.issues
|
|
.addLabels({
|
|
...issueFacts,
|
|
labels,
|
|
})
|
|
.catch((error) => {
|
|
core.warning(error);
|
|
});
|
|
|
|
const removeLabel = () =>
|
|
github.rest.issues
|
|
.removeLabel({
|
|
...issueFacts,
|
|
name: noFound,
|
|
})
|
|
.catch((error) => {
|
|
core.warning(error);
|
|
});
|
|
|
|
const updatePrState = (state) =>
|
|
github.rest.pulls
|
|
.update({
|
|
...prFacts,
|
|
state,
|
|
})
|
|
.catch((error) => {
|
|
core.warning(error);
|
|
});
|
|
|
|
const createComment = (body) =>
|
|
github.rest.issues
|
|
.createComment({
|
|
...issueFacts,
|
|
body,
|
|
})
|
|
.catch((error) => {
|
|
core.warning(error);
|
|
});
|
|
|
|
const createFailedComment = () => {
|
|
const logUrl = `${process.env.GITHUB_SERVER_URL}/${context.repo.owner}/${context.repo.repo}/actions/runs/${context.runId}`;
|
|
|
|
if (process.env.PULL_REQUEST) {
|
|
return createComment(`Auto Route Test failed, please check your PR body format and reopen pull request. Check [logs](${logUrl}) for more details.
|
|
自动路由测试失败,请确认 PR 正文部分符合格式规范并重新开启,详情请检查 [日志](${logUrl})。`);
|
|
}
|
|
|
|
return createComment(`Route Test failed, please check your comment body. Check [logs](${logUrl}) for more details.
|
|
路由测试失败,请确认评论部分符合格式规范,详情请检查 [日志](${logUrl})。`);
|
|
};
|
|
|
|
const pr = await github.rest.issues
|
|
.get({
|
|
...issueFacts,
|
|
})
|
|
.catch((error) => {
|
|
core.warning(error);
|
|
});
|
|
if (pr.pull_request && pr.state === 'closed') {
|
|
await updatePrState('open');
|
|
}
|
|
|
|
if (allowedUser.has(sender)) {
|
|
core.info('PR created by a allowed user, passing');
|
|
await removeLabel();
|
|
await addLabels(['Auto: allowed']);
|
|
return;
|
|
} else {
|
|
core.debug('PR created by ' + sender);
|
|
}
|
|
|
|
if (m && m[1]) {
|
|
res = m[1].trim().split(/\r?\n/);
|
|
core.info(`routes detected: ${res}`);
|
|
|
|
if (res.length && res[0] === 'NOROUTE') {
|
|
core.info('PR stated no route, passing');
|
|
await removeLabel();
|
|
await addLabels(['Auto: Route Test Skipped']);
|
|
|
|
return;
|
|
} else if (res.length && !res.some((e) => e.includes('/:'))) {
|
|
core.exportVariable('TEST_CONTINUE', true);
|
|
await removeLabel();
|
|
return res;
|
|
}
|
|
}
|
|
|
|
core.warning('Seems like no valid routes can be found. Failing.');
|
|
|
|
await createFailedComment();
|
|
if (process.env.PULL_REQUEST) {
|
|
await addLabels([noFound]);
|
|
await updatePrState('closed');
|
|
}
|
|
|
|
throw new Error('Please follow the PR rules: failed to detect route');
|
|
};
|