electron/script/release/uploaders/upload-to-github.js
2020-08-05 11:59:52 -04:00

87 lines
2.7 KiB
JavaScript

if (!process.env.CI) require('dotenv-safe').load();
const fs = require('fs');
const { Octokit } = require('@octokit/rest');
const octokit = new Octokit({
auth: process.env.ELECTRON_GITHUB_TOKEN
});
if (process.argv.length < 6) {
console.log('Usage: upload-to-github filePath fileName releaseId');
process.exit(1);
}
const filePath = process.argv[2];
const fileName = process.argv[3];
const releaseId = process.argv[4];
const releaseVersion = process.argv[5];
const getHeaders = (filePath, fileName) => {
const extension = fileName.split('.').pop();
const size = fs.statSync(filePath).size;
const options = {
json: 'text/json',
zip: 'application/zip',
txt: 'text/plain',
ts: 'application/typescript'
};
return {
'content-type': options[extension],
'content-length': size
};
};
const targetRepo = releaseVersion.indexOf('nightly') > 0 ? 'nightlies' : 'electron';
const uploadUrl = `https://uploads.github.com/repos/electron/${targetRepo}/releases/${releaseId}/assets{?name,label}`;
let retry = 0;
function uploadToGitHub () {
octokit.repos.uploadReleaseAsset({
url: uploadUrl,
headers: getHeaders(filePath, fileName),
file: fs.createReadStream(filePath),
name: fileName
}).then(() => {
console.log(`Successfully uploaded ${fileName} to GitHub.`);
process.exit();
}).catch((err) => {
if (retry < 4) {
console.log(`Error uploading ${fileName} to GitHub, will retry. Error was:`, err);
retry++;
octokit.repos.listAssetsForRelease({
owner: 'electron',
repo: targetRepo,
release_id: releaseId,
per_page: 100
}).then(assets => {
console.log('Got list of assets for existing release:');
console.log(JSON.stringify(assets.data, null, ' '));
const existingAssets = assets.data.filter(asset => asset.name === fileName);
if (existingAssets.length > 0) {
console.log(`${fileName} already exists; will delete before retrying upload.`);
octokit.repos.deleteReleaseAsset({
owner: 'electron',
repo: targetRepo,
asset_id: existingAssets[0].id
}).catch((deleteErr) => {
console.log(`Failed to delete existing asset ${fileName}. Error was:`, deleteErr);
}).then(uploadToGitHub);
} else {
console.log(`Current asset ${fileName} not found in existing assets; retrying upload.`);
uploadToGitHub();
}
}).catch((getReleaseErr) => {
console.log('Fatal: Unable to get current release assets via getRelease! Error was:', getReleaseErr);
});
} else {
console.log(`Error retrying uploading ${fileName} to GitHub:`, err);
process.exitCode = 1;
}
});
}
uploadToGitHub();