Skip to content

Commit

Permalink
Merge branch 'main' into add-hanko
Browse files Browse the repository at this point in the history
  • Loading branch information
coolaj86 authored Dec 19, 2024
2 parents a79cab4 + 9766022 commit 6d5ffd8
Show file tree
Hide file tree
Showing 53 changed files with 1,561 additions and 886 deletions.
4 changes: 2 additions & 2 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -145,8 +145,8 @@ It looks like this:
`releases.js`:

```js
module.exports = function (request) {
return github(request, owner, repo).then(function (all) {
module.exports = function () {
return github(null, owner, repo).then(function (all) {
// if you need to do something special, you can do it here
// ...
return all;
Expand Down
75 changes: 41 additions & 34 deletions _common/brew.js
Original file line number Diff line number Diff line change
@@ -1,49 +1,56 @@
'use strict';

let Fetcher = require('../_common/fetcher.js');

/**
* Gets releases from 'brew'.
*
* @param {null} _
* @param {string} formula
* @returns {PromiseLike<any> | Promise<any>}
* @returns {Promise<any>}
*/
function getDistributables(_, formula) {
async function getDistributables(_, formula) {
if (!formula) {
return Promise.reject('missing formula for brew');
}
return fetch('https://formulae.brew.sh/api/formula/' + formula + '.json')
.then(function (resp) {
if (!resp.ok) {
throw new Error(`HTTP error! Status: ${resp.status}`);
}
return resp.json(); // Parse JSON response
})
.then(function (body) {
var ver = body.versions.stable;
var dl = (
body.bottle.stable.files.high_sierra ||
body.bottle.stable.files.catalina
).url.replace(new RegExp(ver.replace(/\./g, '\\.'), 'g'), '{{ v }}');
return [
{
version: ver,
download: dl.replace(/{{ v }}/g, ver),
},
].concat(
body.versioned_formulae.map(function (f) {
var ver = f.replace(/.*@/, '');
return {
version: ver,
download: dl,
};
}),
);
})
.catch(function (err) {
console.error('Error fetching MariaDB versions (brew)');
console.error(err);
return [];

let resp;
try {
let url = `https://formulae.brew.sh/api/formula/${formula}.json`;
resp = await Fetcher.fetch(url, {
headers: { Accept: 'application/json' },
});
} catch (e) {
/** @type {Error & { code: string, response: { status: number, body: string } }} */ //@ts-expect-error
let err = e;
if (err.code === 'E_FETCH_RELEASES') {
err.message = `failed to fetch '${formula}' release data from 'brew': ${err.response.status} ${err.response.body}`;
}
throw e;
}
let body = JSON.parse(resp.body);

var ver = body.versions.stable;
var dl = (
body.bottle.stable.files.high_sierra || body.bottle.stable.files.catalina
).url.replace(new RegExp(ver.replace(/\./g, '\\.'), 'g'), '{{ v }}');
return [
{
version: ver,
download: dl.replace(/{{ v }}/g, ver),
},
].concat(
body.versioned_formulae.map(
/** @param {String} f */
function (f) {
var ver = f.replace(/.*@/, '');
return {
version: ver,
download: dl,
};
},
),
);
}

module.exports = getDistributables;
Expand Down
56 changes: 56 additions & 0 deletions _common/fetcher.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,56 @@
'use strict';

let Fetcher = module.exports;

/**
* @typedef ResponseSummary
* @prop {Boolean} ok
* @prop {Headers} headers
* @prop {Number} status
* @prop {String} body
*/

/**
* @param {String} url
* @param {RequestInit} opts
* @returns {Promise<ResponseSummary>}
*/
Fetcher.fetch = async function (url, opts) {
let resp = await fetch(url, opts);
let summary = Fetcher.throwIfNotOk(resp);

return summary;
};

/**
* @param {Response} resp
* @returns {Promise<ResponseSummary>}
*/
Fetcher.throwIfNotOk = async function (resp) {
let text = await resp.text();

if (!resp.ok) {
let headers = Array.from(resp.headers);
console.error('[Fetcher] error: Response Headers:', headers);
console.error('[Fetcher] error: Response Text:', text);
let err = new Error(`fetch was not ok`);
Object.assign({
status: 503,
code: 'E_FETCH_RELEASES',
response: {
status: resp.status,
headers: headers,
body: text,
},
});
throw err;
}

let summary = {
ok: resp.ok,
headers: resp.headers,
status: resp.status,
body: text,
};
return summary;
};
8 changes: 3 additions & 5 deletions _common/gitea.js
Original file line number Diff line number Diff line change
Expand Up @@ -41,9 +41,7 @@ if (module === require.main) {
'https://git.rootprojects.org',
'',
'',
).then(
function (all) {
console.info(JSON.stringify(all, null, 2));
},
);
).then(function (all) {
console.info(JSON.stringify(all, null, 2));
});
}
2 changes: 1 addition & 1 deletion _common/github-source.js
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ let GitHubishSource = require('./githubish-source.js');
* @param {Object} opts
* @param {String} opts.owner
* @param {String} opts.repo
* @param {String} opts.baseurl
* @param {String} [opts.baseurl]
* @param {String} [opts.username]
* @param {String} [opts.token]
*/
Expand Down
57 changes: 39 additions & 18 deletions _common/githubish-source.js
Original file line number Diff line number Diff line change
@@ -1,5 +1,7 @@
'use strict';

let Fetcher = require('../_common/fetcher.js');

let GitHubishSource = module.exports;

/**
Expand Down Expand Up @@ -44,30 +46,22 @@ GitHubishSource.getDistributables = async function ({
});
}

let resp = await fetch(url, opts);
if (!resp.ok) {
let headers = Array.from(resp.headers);
console.error('Bad Resp Headers:', headers);
let text = await resp.text();
console.error('Bad Resp Body:', text);
let msg = `failed to fetch releases from '${baseurl}' with user '${username}'`;
throw new Error(msg);
}

let respText = await resp.text();
let gHubResp;
let resp;
try {
gHubResp = JSON.parse(respText);
resp = await Fetcher.fetch(url, opts);
} catch (e) {
console.error('Bad Resp JSON:', respText);
console.error(e.message);
let msg = `failed to parse releases from '${baseurl}' with user '${username}'`;
throw new Error(msg);
/** @type {Error & { code: string, response: { status: number, body: string } }} */ //@ts-expect-error
let err = e;
if (err.code === 'E_FETCH_RELEASES') {
err.message = `failed to fetch '${baseurl}' (githubish-source, user '${username}) release data: ${err.response.status} ${err.response.body}`;
}
throw e;
}
let gHubResp = JSON.parse(resp.body);

let all = {
/** @type {Array<BuildInfo>} */
releases: [],
// TODO make this ':baseurl' + ':releasename'
download: '',
};

Expand All @@ -84,6 +78,29 @@ GitHubishSource.getDistributables = async function ({
return all;
};

/**
* @typedef BuildInfo
* @prop {String} [name] - name to use instead of filename for hash urls
* @prop {String} version
* @prop {String} [_version]
* @prop {String} [arch]
* @prop {String} channel
* @prop {String} date
* @prop {String} download
* @prop {String} [ext]
* @prop {String} [_filename]
* @prop {String} [hash]
* @prop {String} [libc]
* @prop {Boolean} [_musl]
* @prop {Boolean} [lts]
* @prop {String} [size]
* @prop {String} os
*/

/**
* @param {any} ghRelease - TODO
* @returns {Array<BuildInfo>}
*/
GitHubishSource.releaseToDistributables = function (ghRelease) {
let ghTag = ghRelease['tag_name']; // TODO tags aren't always semver / sensical
let lts = /(\b|_)(lts)(\b|_)/.test(ghRelease['tag_name']);
Expand All @@ -95,6 +112,7 @@ GitHubishSource.releaseToDistributables = function (ghRelease) {
date = date.replace(/T.*/, '');

let urls = [ghRelease.tarball_url, ghRelease.zipball_url];
/** @type {Array<BuildInfo>} */
let dists = [];
for (let url of urls) {
dists.push({
Expand All @@ -114,6 +132,9 @@ GitHubishSource.releaseToDistributables = function (ghRelease) {
return dists;
};

/**
* @param {BuildInfo} dist
*/
GitHubishSource.followDistributableDownloadAttachment = async function (dist) {
let abortCtrl = new AbortController();
let resp = await fetch(dist.download, {
Expand Down
35 changes: 17 additions & 18 deletions _common/githubish.js
Original file line number Diff line number Diff line change
@@ -1,5 +1,7 @@
'use strict';

let Fetcher = require('../_common/fetcher.js');

/**
* @typedef DistributableRaw
* @prop {String} name
Expand Down Expand Up @@ -57,26 +59,18 @@ GitHubish.getDistributables = async function ({
});
}

let resp = await fetch(url, opts);
if (!resp.ok) {
let headers = Array.from(resp.headers);
console.error('Bad Resp Headers:', headers);
let text = await resp.text();
console.error('Bad Resp Body:', text);
let msg = `failed to fetch releases from '${baseurl}' with user '${username}'`;
throw new Error(msg);
}

let respText = await resp.text();
let gHubResp;
let resp;
try {
gHubResp = JSON.parse(respText);
resp = await Fetcher.fetch(url, opts);
} catch (e) {
console.error('Bad Resp JSON:', respText);
console.error(e.message);
let msg = `failed to parse releases from '${baseurl}' with user '${username}'`;
throw new Error(msg);
/** @type {Error & { code: string, response: { status: number, body: string } }} */ //@ts-expect-error
let err = e;
if (err.code === 'E_FETCH_RELEASES') {
err.message = `failed to fetch '${baseurl}' (githubish, user '${username}) release data: ${err.response.status} ${err.response.body}`;
}
throw e;
}
let gHubResp = JSON.parse(resp.body);

let all = {
/** @type {Array<DistributableRaw>} */
Expand All @@ -88,13 +82,18 @@ GitHubish.getDistributables = async function ({
try {
gHubResp.forEach(transformReleases);
} catch (e) {
console.error(e.message);
/** @type {Error & { code: string, response: { status: number, body: string } }} */ //@ts-expect-error
let err = e;
console.error(err.message);
console.error('Error Headers:', resp.headers);
console.error('Error Body:', resp.body);
let msg = `failed to transform releases from '${baseurl}' with user '${username}'`;
throw new Error(msg);
}

/**
* @param {any} release - TODO
*/
function transformReleases(release) {
for (let asset of release['assets']) {
let name = asset['name'];
Expand Down
4 changes: 1 addition & 3 deletions _webi/builds-cacher.js
Original file line number Diff line number Diff line change
Expand Up @@ -9,8 +9,6 @@ let HostTargets = require('./build-classifier/host-targets.js');
let Lexver = require('./build-classifier/lexver.js');
let Triplet = require('./build-classifier/triplet.js');

let request = require('@root/request');

var ALIAS_RE = /^alias: (\w+)$/m;

var LEGACY_ARCH_MAP = {
Expand Down Expand Up @@ -153,7 +151,7 @@ async function getLatestBuilds(Releases, installersDir, cacheDir, name, date) {
}

async function getLatestBuildsInner(Releases, cacheDir, name, date) {
let data = await Releases.latest(request);
let data = await Releases.latest();

if (!date) {
date = new Date();
Expand Down
4 changes: 1 addition & 3 deletions _webi/classify-one.js
Original file line number Diff line number Diff line change
Expand Up @@ -6,8 +6,6 @@ let Path = require('node:path');
let BuildsCacher = require('./builds-cacher.js');
let Triplet = require('./build-classifier/triplet.js');

let request = require('@root/request');

async function main() {
let projName = process.argv[2];
if (!projName) {
Expand Down Expand Up @@ -47,7 +45,7 @@ async function main() {
Releases.latest = Releases;
}

let projInfo = await Releases.latest(request);
let projInfo = await Releases.latest();

// let packages = await Builds.getPackage({ name: projName });
// console.log(packages);
Expand Down
Loading

0 comments on commit 6d5ffd8

Please sign in to comment.