electron/script/upload-to-github.js

64 lines
2.1 KiB
JavaScript
Raw Normal View History

2018-07-19 18:48:13 +00:00
if (!process.env.CI) require('dotenv-safe').load()
2018-07-11 18:02:03 +00:00
const GitHub = require('github')
const github = new GitHub()
2018-09-13 16:10:51 +00:00
github.authenticate({ type: 'token', token: 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 targetRepo = releaseVersion.indexOf('nightly') > 0 ? 'nightlies' : 'electron'
const githubOpts = {
owner: 'electron',
repo: targetRepo,
id: releaseId,
filePath: filePath,
name: fileName
}
let retry = 0
function uploadToGitHub () {
github.repos.uploadAsset(githubOpts).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++
github.repos.getRelease(githubOpts).then(release => {
console.log('Got list of assets for existing release:')
console.log(JSON.stringify(release.data.assets, null, ' '))
const existingAssets = release.data.assets.filter(asset => asset.name === fileName)
2017-10-18 20:49:32 +00:00
if (existingAssets.length > 0) {
console.log(`${fileName} already exists; will delete before retrying upload.`)
github.repos.deleteAsset({
owner: 'electron',
repo: targetRepo,
2017-10-18 20:49:32 +00:00
id: existingAssets[0].id
}).catch((deleteErr) => {
console.log(`Failed to delete existing asset ${fileName}. Error was:`, deleteErr)
}).then(uploadToGitHub)
2017-10-18 20:49:32 +00:00
} else {
console.log(`Current asset ${fileName} not found in existing assets; retrying upload.`)
2017-10-18 20:49:32 +00:00
uploadToGitHub()
}
}).catch((getReleaseErr) => {
console.log(`Fatal: Unable to get current release assets via getRelease! Error was:`, getReleaseErr)
2017-10-18 20:49:32 +00:00
})
} else {
console.log(`Error retrying uploading ${fileName} to GitHub:`, err)
process.exitCode = 1
}
})
}
uploadToGitHub()