X-Git-Url: https://git.josue.xyz/?a=blobdiff_plain;f=_common%2Fgithub.js;h=aa98074ccfc9ed2fc8af7d5e6c13e4f75badded7;hb=60533161805deceeb6e6627614f358d9ccdb264f;hp=1a8f91ee0ca75ead7f828db3a21d4133ff1e686c;hpb=9711309e3fafea992f23659a5100de002ddf98d6;p=webi-installers%2F.git diff --git a/_common/github.js b/_common/github.js index 1a8f91e..aa98074 100644 --- a/_common/github.js +++ b/_common/github.js @@ -1,46 +1,6 @@ 'use strict'; -// this may need customizations between packages -const osMap = { - macos: /\b(apple|mac|darwin|iPhone|iOS|iPad)/i, - linux: /\b(linux)/i, - windows: /\b(win|microsoft|msft)/i, - sunos: /\b(sun)/i, - aix: /\b(aix)/i -}; - -// evaluation order matters -// (i.e. otherwise x86 and x64 can cross match) -var archArr = [ - 'amd64', // first and most likely match - 'arm64', - 'x86', - 'ppc64le', - 'ppc64', - 'armv7l', - 'armv6l', - 's390x' -]; -var archMap = { - amd64: /(amd.?64|x64|[_\-]64)/i, - x86: /(86)\b/i, - ppc64le: /\b(ppc64le)/i, - ppc64: /\b(ppc64)\b/i, - arm64: /\b(arm64|arm)/i, - armv7l: /\b(armv?7l)/i, - armv6l: /\b(armv?6l)/i, - s390x: /\b(s390x)/i -}; - -var fileExtMap = { - deb: /\.deb$/i, - pkg: /\.pkg$/i, - exe: /\.exe$/i, - msi: /\.msi$/i, - zip: /\.zip$/i, - tar: /\.tar\..*$/i, - '7z': /\.7z$/i -}; +require('dotenv').config(); /** * Gets the releases for 'ripgrep'. This function could be trimmed down and made @@ -51,64 +11,52 @@ var fileExtMap = { * @param {string} repo * @returns {PromiseLike | Promise} */ -function getAllReleases(request, owner = 'BurntSushi', repo = 'ripgrep') { +function getAllReleases( + request, + owner, + repo, + baseurl = 'https://api.github.com' +) { if (!owner) { return Promise.reject('missing owner for repo'); } if (!repo) { return Promise.reject('missing repo name'); } - return request({ - url: `https://api.github.com/repos/${owner}/${repo}/releases`, + + var req = { + url: `${baseurl}/repos/${owner}/${repo}/releases`, json: true - }).then((resp) => { + }; + // TODO I really don't like global config, find a way to do better + if (process.env.GITHUB_USERNAME) { + req.auth = { + user: process.env.GITHUB_USERNAME, + pass: process.env.GITHUB_TOKEN + }; + } + + return request(req).then((resp) => { const gHubResp = resp.body; const all = { releases: [], + // todo make this ':baseurl' + ':releasename' download: '' }; gHubResp.forEach((release) => { release['assets'].forEach((asset) => { - // set the primary download to the first of the releases - if (all.download === '') { - all.download = asset['browser_download_url']; - } - const name = asset['name']; - const os = - Object.keys(osMap).find(function (regKey) { - //console.log('github release os:', name, regKey, osMap[regKey]); - return osMap[regKey].test(name); - }) || 'unknown'; - var arch; - archArr.some(function (regKey) { - //console.log('github release arch:', name, regKey, archMap[regKey]); - arch = name.match(archMap[regKey]) && regKey; - if (arch) { - return true; - } - })[0]; - - let fileExt = ''; - Object.keys(fileExtMap).find((regKey) => { - const match = name.match(fileExtMap[regKey]); - if (match) { - fileExt = match[0]; - return true; - } - return false; - }); - all.releases.push({ - download: asset['browser_download_url'], - date: (release['published_at'] || '').replace(/T.*/, ''), + name: name, version: release['tag_name'], // TODO tags aren't always semver / sensical - lts: /\b(lts)\b/.test(release['tag_name']), + lts: /(\b|_)(lts)(\b|_)/.test(release['tag_name']), channel: !release['prerelease'] ? 'stable' : 'beta', - ext: fileExt.slice(1), - arch, - os + date: (release['published_at'] || '').replace(/T.*/, ''), + os: '', // will be guessed by download filename + arch: '', // will be guessed by download filename + ext: '', // will be normalized + download: asset['browser_download_url'] }); }); }); @@ -122,7 +70,7 @@ module.exports = getAllReleases; if (module === require.main) { getAllReleases(require('@root/request'), 'BurntSushi', 'ripgrep').then( function (all) { - console.log(JSON.stringify(all, null, 2)); + console.info(JSON.stringify(all, null, 2)); } ); }