Update to newer Octokit

This commit is contained in:
Sven-Hendrik Haase 2023-01-19 13:01:59 +01:00
parent 9093186278
commit 8250434419
No known key found for this signature in database
GPG Key ID: 39E4B877E62EB915
4 changed files with 3497 additions and 7474 deletions

10771
dist/index.js vendored

File diff suppressed because one or more lines are too long

85
package-lock.json generated
View File

@ -10,7 +10,7 @@
"license": "MIT", "license": "MIT",
"dependencies": { "dependencies": {
"@actions/core": "^1.10.0", "@actions/core": "^1.10.0",
"@actions/github": "^4.0.0", "@actions/github": "^5",
"glob": "^7" "glob": "^7"
}, },
"devDependencies": { "devDependencies": {
@ -40,22 +40,14 @@
} }
}, },
"node_modules/@actions/github": { "node_modules/@actions/github": {
"version": "4.0.0", "version": "5.1.1",
"resolved": "https://registry.npmjs.org/@actions/github/-/github-4.0.0.tgz", "resolved": "https://registry.npmjs.org/@actions/github/-/github-5.1.1.tgz",
"integrity": "sha512-Ej/Y2E+VV6sR9X7pWL5F3VgEWrABaT292DRqRU6R4hnQjPtC/zD3nagxVdXWiRQvYDh8kHXo7IDmG42eJ/dOMA==", "integrity": "sha512-Nk59rMDoJaV+mHCOJPXuvB1zIbomlKS0dmSIqPGxd0enAXBnOfn4VWF+CGtRCwXZG9Epa54tZA7VIRlJDS8A6g==",
"dependencies": { "dependencies": {
"@actions/http-client": "^1.0.8", "@actions/http-client": "^2.0.1",
"@octokit/core": "^3.0.0", "@octokit/core": "^3.6.0",
"@octokit/plugin-paginate-rest": "^2.2.3", "@octokit/plugin-paginate-rest": "^2.17.0",
"@octokit/plugin-rest-endpoint-methods": "^4.0.0" "@octokit/plugin-rest-endpoint-methods": "^5.13.0"
}
},
"node_modules/@actions/github/node_modules/@actions/http-client": {
"version": "1.0.11",
"resolved": "https://registry.npmjs.org/@actions/http-client/-/http-client-1.0.11.tgz",
"integrity": "sha512-VRYHGQV1rqnROJqdMvGUbY/Kn8vriQe/F9HR2AlYHzmKuM/p3kjNuXhmdBfcVgsvRWTz5C5XW5xvndZrVBuAYg==",
"dependencies": {
"tunnel": "0.0.6"
} }
}, },
"node_modules/@actions/http-client": { "node_modules/@actions/http-client": {
@ -1279,11 +1271,11 @@
} }
}, },
"node_modules/@octokit/plugin-rest-endpoint-methods": { "node_modules/@octokit/plugin-rest-endpoint-methods": {
"version": "4.15.1", "version": "5.16.2",
"resolved": "https://registry.npmjs.org/@octokit/plugin-rest-endpoint-methods/-/plugin-rest-endpoint-methods-4.15.1.tgz", "resolved": "https://registry.npmjs.org/@octokit/plugin-rest-endpoint-methods/-/plugin-rest-endpoint-methods-5.16.2.tgz",
"integrity": "sha512-4gQg4ySoW7ktKB0Mf38fHzcSffVZd6mT5deJQtpqkuPuAqzlED5AJTeW8Uk7dPRn7KaOlWcXB0MedTFJU1j4qA==", "integrity": "sha512-8QFz29Fg5jDuTPXVtey05BLm7OB+M8fnvE64RNegzX7U+5NUXcOcnpTIK0YfSHBg8gYd0oxIq3IZTe9SfPZiRw==",
"dependencies": { "dependencies": {
"@octokit/types": "^6.13.0", "@octokit/types": "^6.39.0",
"deprecation": "^2.3.1" "deprecation": "^2.3.1"
}, },
"peerDependencies": { "peerDependencies": {
@ -3250,20 +3242,6 @@
"resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz",
"integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==" "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw=="
}, },
"node_modules/fsevents": {
"version": "2.3.2",
"resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz",
"integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==",
"dev": true,
"hasInstallScript": true,
"optional": true,
"os": [
"darwin"
],
"engines": {
"node": "^8.16.0 || ^10.6.0 || >=11.0.0"
}
},
"node_modules/function-bind": { "node_modules/function-bind": {
"version": "1.1.1", "version": "1.1.1",
"resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz",
@ -6386,24 +6364,14 @@
} }
}, },
"@actions/github": { "@actions/github": {
"version": "4.0.0", "version": "5.1.1",
"resolved": "https://registry.npmjs.org/@actions/github/-/github-4.0.0.tgz", "resolved": "https://registry.npmjs.org/@actions/github/-/github-5.1.1.tgz",
"integrity": "sha512-Ej/Y2E+VV6sR9X7pWL5F3VgEWrABaT292DRqRU6R4hnQjPtC/zD3nagxVdXWiRQvYDh8kHXo7IDmG42eJ/dOMA==", "integrity": "sha512-Nk59rMDoJaV+mHCOJPXuvB1zIbomlKS0dmSIqPGxd0enAXBnOfn4VWF+CGtRCwXZG9Epa54tZA7VIRlJDS8A6g==",
"requires": { "requires": {
"@actions/http-client": "^1.0.8", "@actions/http-client": "^2.0.1",
"@octokit/core": "^3.0.0", "@octokit/core": "^3.6.0",
"@octokit/plugin-paginate-rest": "^2.2.3", "@octokit/plugin-paginate-rest": "^2.17.0",
"@octokit/plugin-rest-endpoint-methods": "^4.0.0" "@octokit/plugin-rest-endpoint-methods": "^5.13.0"
},
"dependencies": {
"@actions/http-client": {
"version": "1.0.11",
"resolved": "https://registry.npmjs.org/@actions/http-client/-/http-client-1.0.11.tgz",
"integrity": "sha512-VRYHGQV1rqnROJqdMvGUbY/Kn8vriQe/F9HR2AlYHzmKuM/p3kjNuXhmdBfcVgsvRWTz5C5XW5xvndZrVBuAYg==",
"requires": {
"tunnel": "0.0.6"
}
}
} }
}, },
"@actions/http-client": { "@actions/http-client": {
@ -7357,11 +7325,11 @@
} }
}, },
"@octokit/plugin-rest-endpoint-methods": { "@octokit/plugin-rest-endpoint-methods": {
"version": "4.15.1", "version": "5.16.2",
"resolved": "https://registry.npmjs.org/@octokit/plugin-rest-endpoint-methods/-/plugin-rest-endpoint-methods-4.15.1.tgz", "resolved": "https://registry.npmjs.org/@octokit/plugin-rest-endpoint-methods/-/plugin-rest-endpoint-methods-5.16.2.tgz",
"integrity": "sha512-4gQg4ySoW7ktKB0Mf38fHzcSffVZd6mT5deJQtpqkuPuAqzlED5AJTeW8Uk7dPRn7KaOlWcXB0MedTFJU1j4qA==", "integrity": "sha512-8QFz29Fg5jDuTPXVtey05BLm7OB+M8fnvE64RNegzX7U+5NUXcOcnpTIK0YfSHBg8gYd0oxIq3IZTe9SfPZiRw==",
"requires": { "requires": {
"@octokit/types": "^6.13.0", "@octokit/types": "^6.39.0",
"deprecation": "^2.3.1" "deprecation": "^2.3.1"
} }
}, },
@ -8843,13 +8811,6 @@
"resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz",
"integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==" "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw=="
}, },
"fsevents": {
"version": "2.3.2",
"resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz",
"integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==",
"dev": true,
"optional": true
},
"function-bind": { "function-bind": {
"version": "1.1.1", "version": "1.1.1",
"resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz",

View File

@ -28,7 +28,7 @@
"license": "MIT", "license": "MIT",
"dependencies": { "dependencies": {
"@actions/core": "^1.10.0", "@actions/core": "^1.10.0",
"@actions/github": "^4.0.0", "@actions/github": "^5",
"glob": "^7" "glob": "^7"
}, },
"devDependencies": { "devDependencies": {

View File

@ -6,14 +6,19 @@ import * as github from '@actions/github'
import * as path from 'path' import * as path from 'path'
import * as glob from 'glob' import * as glob from 'glob'
type RepoAssetsResp = const releaseByTag = 'GET /repos/{owner}/{repo}/releases/tags/{tag}' as const
Endpoints['GET /repos/:owner/:repo/releases/:release_id/assets']['response']['data'] const createRelease = 'POST /repos/{owner}/{repo}/releases' as const
type ReleaseByTagResp = const repoAssets =
Endpoints['GET /repos/:owner/:repo/releases/tags/:tag']['response'] 'GET /repos/{owner}/{repo}/releases/{release_id}/assets' as const
type CreateReleaseResp = const uploadAssets =
Endpoints['POST /repos/:owner/:repo/releases']['response'] 'POST {origin}/repos/{owner}/{repo}/releases/{release_id}/assets{?name,label}' as const
type UploadAssetResp = const deleteAssets =
Endpoints['POST /repos/:owner/:repo/releases/:release_id/assets{?name,label}']['response'] 'DELETE /repos/{owner}/{repo}/releases/assets/{asset_id}' as const
type ReleaseByTagResp = Endpoints[typeof releaseByTag]['response']
type CreateReleaseResp = Endpoints[typeof createRelease]['response']
type RepoAssetsResp = Endpoints[typeof repoAssets]['response']['data']
type UploadAssetResp = Endpoints[typeof uploadAssets]['response']
async function get_release_by_tag( async function get_release_by_tag(
tag: string, tag: string,
@ -24,7 +29,7 @@ async function get_release_by_tag(
): Promise<ReleaseByTagResp | CreateReleaseResp> { ): Promise<ReleaseByTagResp | CreateReleaseResp> {
try { try {
core.debug(`Getting release by tag ${tag}.`) core.debug(`Getting release by tag ${tag}.`)
return await octokit.repos.getReleaseByTag({ return await octokit.request(releaseByTag, {
...repo(), ...repo(),
tag: tag tag: tag
}) })
@ -34,7 +39,7 @@ async function get_release_by_tag(
core.debug( core.debug(
`Release for tag ${tag} doesn't exist yet so we'll create it now.` `Release for tag ${tag} doesn't exist yet so we'll create it now.`
) )
return await octokit.repos.createRelease({ return await octokit.request(createRelease, {
...repo(), ...repo(),
tag_name: tag, tag_name: tag,
prerelease: prerelease, prerelease: prerelease,
@ -53,7 +58,7 @@ async function upload_to_release(
asset_name: string, asset_name: string,
tag: string, tag: string,
overwrite: boolean, overwrite: boolean,
octokit: Octokit octokit: ReturnType<(typeof github)['getOctokit']>
): Promise<undefined | string> { ): Promise<undefined | string> {
const stat = fs.statSync(file) const stat = fs.statSync(file)
if (!stat.isFile()) { if (!stat.isFile()) {
@ -61,23 +66,20 @@ async function upload_to_release(
return return
} }
const file_size = stat.size const file_size = stat.size
const file_bytes = fs.readFileSync(file) const file_bytes = fs.readFileSync(file).toString('binary')
// Check for duplicates. // Check for duplicates.
const assets: RepoAssetsResp = await octokit.paginate( const assets: RepoAssetsResp = await octokit.paginate(repoAssets, {
octokit.repos.listReleaseAssets,
{
...repo(), ...repo(),
release_id: release.data.id release_id: release.data.id
} })
)
const duplicate_asset = assets.find(a => a.name === asset_name) const duplicate_asset = assets.find(a => a.name === asset_name)
if (duplicate_asset !== undefined) { if (duplicate_asset !== undefined) {
if (overwrite) { if (overwrite) {
core.debug( core.debug(
`An asset called ${asset_name} already exists in release ${tag} so we'll overwrite it.` `An asset called ${asset_name} already exists in release ${tag} so we'll overwrite it.`
) )
await octokit.repos.deleteReleaseAsset({ await octokit.request(deleteAssets, {
...repo(), ...repo(),
asset_id: duplicate_asset.id asset_id: duplicate_asset.id
}) })
@ -92,8 +94,9 @@ async function upload_to_release(
} }
core.debug(`Uploading ${file} to ${asset_name} in release ${tag}.`) core.debug(`Uploading ${file} to ${asset_name} in release ${tag}.`)
const uploaded_asset: UploadAssetResp = const uploaded_asset: UploadAssetResp = await octokit.request(uploadAssets, {
await octokit.repos.uploadReleaseAsset({ ...repo(),
release_id: release.data.id,
url: release.data.upload_url, url: release.data.upload_url,
name: asset_name, name: asset_name,
data: file_bytes, data: file_bytes,
@ -111,11 +114,11 @@ function repo(): {owner: string; repo: string} {
if (!repo_name) { if (!repo_name) {
return github.context.repo return github.context.repo
} }
const owner = repo_name.substr(0, repo_name.indexOf('/')) const owner = repo_name.substring(0, repo_name.indexOf('/'))
if (!owner) { if (!owner) {
throw new Error(`Could not extract 'owner' from 'repo_name': ${repo_name}.`) throw new Error(`Could not extract 'owner' from 'repo_name': ${repo_name}.`)
} }
const repo_ = repo_name.substr(repo_name.indexOf('/') + 1) const repo_ = repo_name.substring(repo_name.indexOf('/') + 1)
if (!repo_) { if (!repo_) {
throw new Error(`Could not extract 'repo' from 'repo_name': ${repo_name}.`) throw new Error(`Could not extract 'repo' from 'repo_name': ${repo_name}.`)
} }
@ -141,7 +144,7 @@ async function run(): Promise<void> {
const release_name = core.getInput('release_name') const release_name = core.getInput('release_name')
const body = core.getInput('body') const body = core.getInput('body')
const octokit: Octokit = github.getOctokit(token) const octokit = github.getOctokit(token)
const release = await get_release_by_tag( const release = await get_release_by_tag(
tag, tag,
prerelease, prerelease,