mirror of
https://github.com/discordjs/discord.js.git
synced 2026-03-09 16:13:31 +01:00
ci(release): use app user (#11038)
* ci(release): set git user * ci(release): refactor to use app * ci(release): use only app token --------- Co-authored-by: kodiakhq[bot] <49736102+kodiakhq[bot]@users.noreply.github.com>
This commit is contained in:
12
.github/workflows/release.yml
vendored
12
.github/workflows/release.yml
vendored
@@ -42,17 +42,23 @@ jobs:
|
|||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
permissions:
|
permissions:
|
||||||
id-token: write
|
id-token: write
|
||||||
contents: write
|
|
||||||
env:
|
env:
|
||||||
TURBO_TOKEN: ${{ secrets.TURBO_TOKEN }}
|
TURBO_TOKEN: ${{ secrets.TURBO_TOKEN }}
|
||||||
TURBO_TEAM: ${{ secrets.TURBO_TEAM }}
|
TURBO_TEAM: ${{ secrets.TURBO_TEAM }}
|
||||||
if: github.repository_owner == 'discordjs'
|
if: github.repository_owner == 'discordjs'
|
||||||
steps:
|
steps:
|
||||||
|
- uses: actions/create-github-app-token@v2
|
||||||
|
id: app-token
|
||||||
|
with:
|
||||||
|
app-id: ${{ vars.DISCORDJS_APP_ID }}
|
||||||
|
private-key: ${{ secrets.DISCORDJS_APP_KEY_RELEASE }}
|
||||||
|
permission-contents: write
|
||||||
|
|
||||||
- name: Checkout repository
|
- name: Checkout repository
|
||||||
uses: actions/checkout@v4
|
uses: actions/checkout@v4
|
||||||
with:
|
with:
|
||||||
|
token: ${{ steps.app-token.outputs.token }}
|
||||||
ref: ${{ inputs.ref || '' }}
|
ref: ${{ inputs.ref || '' }}
|
||||||
ssh-key: ${{ secrets.DEPLOY_KEY_CI_RELEASE_TAGS }}
|
|
||||||
|
|
||||||
- name: Install Node.js v22
|
- name: Install Node.js v22
|
||||||
uses: actions/setup-node@v4
|
uses: actions/setup-node@v4
|
||||||
@@ -74,4 +80,4 @@ jobs:
|
|||||||
dry: ${{ inputs.dry_run }}
|
dry: ${{ inputs.dry_run }}
|
||||||
env:
|
env:
|
||||||
NODE_AUTH_TOKEN: ${{ secrets.NPM_PUBLISH_TOKEN }}
|
NODE_AUTH_TOKEN: ${{ secrets.NPM_PUBLISH_TOKEN }}
|
||||||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
GITHUB_TOKEN: ${{ steps.app-token.outputs.token }}
|
||||||
|
|||||||
@@ -18,20 +18,19 @@ async function checkRegistry(release: ReleaseEntry) {
|
|||||||
|
|
||||||
async function gitTagAndRelease(release: ReleaseEntry, dry: boolean) {
|
async function gitTagAndRelease(release: ReleaseEntry, dry: boolean) {
|
||||||
const tagName = `${release.name === 'discord.js' ? `` : `${release.name}@`}${release.version}`;
|
const tagName = `${release.name === 'discord.js' ? `` : `${release.name}@`}${release.version}`;
|
||||||
// Don't throw, if this exits non-zero it's probably because the tag already exists
|
|
||||||
await $`git tag ${tagName}`.nothrow();
|
|
||||||
|
|
||||||
if (dry) {
|
if (dry) {
|
||||||
info(`[DRY] Tag "${tagName}" created, skipping push and release creation.`);
|
info(`[DRY] Release would be "${tagName}", skipping release creation.`);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
await $`git push origin ${tagName}`;
|
const commitHash = (await $`git rev-parse --short HEAD`.text()).trim();
|
||||||
|
|
||||||
try {
|
try {
|
||||||
await octokit?.rest.repos.createRelease({
|
await octokit?.rest.repos.createRelease({
|
||||||
...context.repo,
|
...context.repo,
|
||||||
tag_name: tagName,
|
tag_name: tagName,
|
||||||
|
target_commitish: commitHash,
|
||||||
name: tagName,
|
name: tagName,
|
||||||
body: release.changelog ?? '',
|
body: release.changelog ?? '',
|
||||||
generate_release_notes: release.changelog === undefined,
|
generate_release_notes: release.changelog === undefined,
|
||||||
|
|||||||
Reference in New Issue
Block a user