way faster

This commit is contained in:
biglyderv 2025-01-30 09:37:33 -05:00
parent 9f190d796b
commit 316d8d0ded

30
site.js
View file

@ -14,7 +14,7 @@ async function siteCollector(user, path, site) {
if (site == 'darflen') { if (site == 'darflen') {
p = `https://api.darflen.com/users/${user}/${path}/${i}`; p = `https://api.darflen.com/users/${user}/${path}/${i}`;
} else if (site == 'scratch') { } else if (site == 'scratch') {
p = `https://api.scratch.mit.edu/users/${user}/${path}/?offset=${i * 20}`; p = `https://api.scratch.mit.edu/users/${user}/${path}/?limit=40&offset=${i * 40}`;
} else { } else {
throw 'That site is not supported.'; throw 'That site is not supported.';
} }
@ -37,7 +37,7 @@ async function siteCollector(user, path, site) {
users2 = j1.map(x => x.username); users2 = j1.map(x => x.username);
} }
users = [...users, ...users2]; users = users.concat(users2);
if (users2.length == 0) break; if (users2.length == 0) break;
@ -53,12 +53,25 @@ async function siteCollector(user, path, site) {
let data = {}; let data = {};
let p = []; let p = [];
let fails = users;
let congested = [];
for (let u of users) { for (let u of users) {
if (p.length >= 10) { let it = 0;
await Promise.all(p); while (p.length >= 15) {
p = []; p = p.filter(x => x != 'hi');
if (p == []) break;
let pv = await Promise.any(p);
it++;
if (it > 10) {
console.warn(`Promises got congested. Moving to another array...`)
congested = congested.concat(p);
p = [];
break;
}
} }
p.push((async function () { let i = p.length;
p[i] = (async function (i) {
let j1 = await siteCollector(u, 'followers', site); let j1 = await siteCollector(u, 'followers', site);
let j2 = await siteCollector(u, 'following', site); let j2 = await siteCollector(u, 'following', site);
@ -68,9 +81,12 @@ async function siteCollector(user, path, site) {
following: j2, following: j2,
} }
console.log(`User ${u} fully calculated`); console.log(`User ${u} fully calculated`);
})())
p[i] = 'hi';
})(i);
} }
p = p.concat(congested);
await Promise.all(p); await Promise.all(p);
let dat = Object.entries(rankCalc(data, 100)); let dat = Object.entries(rankCalc(data, 100));