mirror of
https://github.com/navidrome/navidrome.git
synced 2025-04-04 21:17:37 +03:00
Revert "Add download link to PR" workflow
This commit is contained in:
parent
2c8c87a980
commit
78f554721a
1 changed files with 27 additions and 34 deletions
61
.github/workflows/download-link-on-pr.yml
vendored
61
.github/workflows/download-link-on-pr.yml
vendored
|
@ -8,43 +8,33 @@ jobs:
|
||||||
if: github.event.workflow_run.event == 'pull_request' && github.event.workflow_run.conclusion == 'success'
|
if: github.event.workflow_run.event == 'pull_request' && github.event.workflow_run.conclusion == 'success'
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/github-script@v6
|
- uses: actions/github-script@v3
|
||||||
with:
|
with:
|
||||||
# This snippet is public-domain, taken from
|
# This snippet is public-domain, taken from
|
||||||
# https://github.com/oprypin/nightly.link/blob/master/.github/workflows/pr-comment.yml
|
# https://github.com/oprypin/nightly.link/blob/master/.github/workflows/pr-comment.yml
|
||||||
script: |
|
script: |
|
||||||
async function upsertComment(owner, repo, issue_number, purpose, body) {
|
|
||||||
const {data: comments} = await github.rest.issues.listComments(
|
|
||||||
{owner, repo, issue_number});
|
|
||||||
|
|
||||||
const marker = `<!-- bot: ${purpose} -->`;
|
|
||||||
body = marker + "\n" + body;
|
|
||||||
|
|
||||||
const existing = comments.filter((c) => c.body.includes(marker));
|
|
||||||
if (existing.length > 0) {
|
|
||||||
const last = existing[existing.length - 1];
|
|
||||||
core.info(`Updating comment ${last.id}`);
|
|
||||||
await github.rest.issues.updateComment({
|
|
||||||
owner, repo,
|
|
||||||
body,
|
|
||||||
comment_id: last.id,
|
|
||||||
});
|
|
||||||
} else {
|
|
||||||
core.info(`Creating a comment in issue / PR #${issue_number}`);
|
|
||||||
await github.rest.issues.createComment({issue_number, body, owner, repo});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
const {owner, repo} = context.repo;
|
const {owner, repo} = context.repo;
|
||||||
const run_id = ${{github.event.workflow_run.id}};
|
const run_id = ${{github.event.workflow_run.id}};
|
||||||
|
const pull_head_sha = '${{github.event.workflow_run.head_sha}}';
|
||||||
|
const pull_user_id = ${{github.event.sender.id}};
|
||||||
|
|
||||||
const pull_requests = ${{ toJSON(github.event.workflow_run.pull_requests) }};
|
const issue_number = await (async () => {
|
||||||
if (!pull_requests.length) {
|
const pulls = await github.pulls.list({owner, repo});
|
||||||
return core.error("This workflow doesn't match any pull requests!");
|
for await (const {data} of github.paginate.iterator(pulls)) {
|
||||||
|
for (const pull of data) {
|
||||||
|
if (pull.head.sha === pull_head_sha && pull.user.id === pull_user_id) {
|
||||||
|
return pull.number;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
})();
|
||||||
|
if (issue_number) {
|
||||||
|
core.info(`Using pull request ${issue_number}`);
|
||||||
|
} else {
|
||||||
|
return core.error(`No matching pull request found`);
|
||||||
}
|
}
|
||||||
|
|
||||||
const artifacts = await github.paginate(
|
const {data: {artifacts}} = await github.actions.listWorkflowRunArtifacts({owner, repo, run_id});
|
||||||
github.rest.actions.listWorkflowRunArtifacts, {owner, repo, run_id});
|
|
||||||
if (!artifacts.length) {
|
if (!artifacts.length) {
|
||||||
return core.error(`No artifacts found`);
|
return core.error(`No artifacts found`);
|
||||||
}
|
}
|
||||||
|
@ -53,9 +43,12 @@ jobs:
|
||||||
body += `\n* [${art.name}.zip](https://nightly.link/${owner}/${repo}/actions/artifacts/${art.id}.zip)`;
|
body += `\n* [${art.name}.zip](https://nightly.link/${owner}/${repo}/actions/artifacts/${art.id}.zip)`;
|
||||||
}
|
}
|
||||||
|
|
||||||
core.info("Review thread message body:", body);
|
const {data: comments} = await github.issues.listComments({repo, owner, issue_number});
|
||||||
|
const existing_comment = comments.find((c) => c.user.login === 'github-actions[bot]');
|
||||||
for (const pr of pull_requests) {
|
if (existing_comment) {
|
||||||
await upsertComment(owner, repo, pr.number,
|
core.info(`Updating comment ${existing_comment.id}`);
|
||||||
"nightly-link", body);
|
await github.issues.updateComment({repo, owner, comment_id: existing_comment.id, body});
|
||||||
}
|
} else {
|
||||||
|
core.info(`Creating a comment`);
|
||||||
|
await github.issues.createComment({repo, owner, issue_number, body});
|
||||||
|
}
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue