scratch support
This commit is contained in:
parent
503db43c4e
commit
e427763245
1 changed files with 27 additions and 8 deletions
31
site.js
31
site.js
|
@ -3,20 +3,39 @@ import { writeFile } from "fs/promises";
|
||||||
import { rankCalc } from "./rank.js";
|
import { rankCalc } from "./rank.js";
|
||||||
|
|
||||||
let cache = {};
|
let cache = {};
|
||||||
|
let site = process.env.site || 'darflen';
|
||||||
|
|
||||||
async function siteCollector(user, path) {
|
async function siteCollector(user, path, site) {
|
||||||
let users = [];
|
let users = [];
|
||||||
let i = 1;
|
let i = 1;
|
||||||
while (true) {
|
while (true) {
|
||||||
let p = `https://api.darflen.com/users/${user}/${path}/${i}`;
|
let p;
|
||||||
|
|
||||||
|
if (site == 'darflen') {
|
||||||
|
p = `https://api.darflen.com/users/${user}/${path}/${i}`;
|
||||||
|
} else if (site == 'scratch') {
|
||||||
|
p = `https://api.scratch.mit.edu/users/${user}/${path}/?offset=${i * 20}`;
|
||||||
|
} else {
|
||||||
|
throw 'That site is not supported.';
|
||||||
|
}
|
||||||
|
|
||||||
let j1 = cache[p];
|
let j1 = cache[p];
|
||||||
if (!j1) {
|
if (!j1) {
|
||||||
let h1 = await fetch(p);
|
let h1 = await fetch(p);
|
||||||
|
try {
|
||||||
j1 = await h1.json();
|
j1 = await h1.json();
|
||||||
|
} catch(err) {
|
||||||
|
j1 = [];
|
||||||
|
}
|
||||||
}
|
}
|
||||||
cache[p] = j1;
|
cache[p] = j1;
|
||||||
|
|
||||||
let users2 = j1[path].map(x => x.profile.username);
|
let users2;
|
||||||
|
if (site == 'darflen') {
|
||||||
|
users2 = j1[path].map(x => x.profile.username);
|
||||||
|
} else if (site == 'scratch') {
|
||||||
|
users2 = j1.map(x => x.username);
|
||||||
|
}
|
||||||
|
|
||||||
users = [...users, ...users2];
|
users = [...users, ...users2];
|
||||||
|
|
||||||
|
@ -30,7 +49,7 @@ async function siteCollector(user, path) {
|
||||||
}
|
}
|
||||||
|
|
||||||
(async function () {
|
(async function () {
|
||||||
let users = await siteCollector('paradock','followers');
|
let users = await siteCollector(process.env.user || 'paradock', 'followers', site);
|
||||||
|
|
||||||
let data = {};
|
let data = {};
|
||||||
let p = [];
|
let p = [];
|
||||||
|
@ -40,9 +59,9 @@ async function siteCollector(user, path) {
|
||||||
p = [];
|
p = [];
|
||||||
}
|
}
|
||||||
p.push((async function () {
|
p.push((async function () {
|
||||||
let j1 = await siteCollector(u,'followers');
|
let j1 = await siteCollector(u, 'followers', site);
|
||||||
|
|
||||||
let j2 = await siteCollector(u,'following');
|
let j2 = await siteCollector(u, 'following', site);
|
||||||
|
|
||||||
data[u] = {
|
data[u] = {
|
||||||
followers: j1,
|
followers: j1,
|
||||||
|
|
Loading…
Reference in a new issue