fix(ssr): only use 1 network request to fetch map ids
All checks were successful
deploy / deploy (push) Successful in 58s
All checks were successful
deploy / deploy (push) Successful in 58s
This commit is contained in:
@ -19,14 +19,15 @@ export async function GET(request: Request) {
|
||||
const map = await BeatsaverAPI.fetchMapByHash(mapHash);
|
||||
if (map) {
|
||||
maps[mapHash] = map;
|
||||
mapCache.set(mapHash, map);
|
||||
}
|
||||
if (map && idOnly) {
|
||||
maps[mapHash] = { id: map.id };
|
||||
}
|
||||
}
|
||||
|
||||
return new Response(JSON.stringify(maps), {
|
||||
headers: { "content-type": "application/json;charset=UTF-8" },
|
||||
});
|
||||
}
|
||||
|
||||
return new Response(JSON.stringify(maps), {
|
||||
headers: { "content-type": "application/json;charset=UTF-8" },
|
||||
});
|
||||
}
|
||||
|
@ -162,24 +162,28 @@ async function fetchScoresWithBeatsaverData(
|
||||
string,
|
||||
ScoresaberScoreWithBeatsaverData
|
||||
> = {};
|
||||
|
||||
let url = `${
|
||||
isProduction() ? ssrSettings.siteUrl : "http://localhost:3000"
|
||||
}/api/beatsaver/mapdata?hashes=`;
|
||||
for (const score of scores) {
|
||||
const mapResponse = await fetch(
|
||||
`${
|
||||
isProduction() ? ssrSettings.siteUrl : "http://localhost:3000"
|
||||
}/api/beatsaver/mapdata?hashes=${score.leaderboard.songHash}&idonly=true`,
|
||||
{
|
||||
next: {
|
||||
revalidate: 60 * 60 * 24 * 7, // 1 week
|
||||
},
|
||||
},
|
||||
);
|
||||
const mapData = await mapResponse.json();
|
||||
const mapId = mapData[score.leaderboard.songHash].id;
|
||||
scoresWithBeatsaverData[score.score.id] = {
|
||||
score: score.score,
|
||||
leaderboard: score.leaderboard,
|
||||
mapId: mapId,
|
||||
};
|
||||
url += `${score.leaderboard.songHash},`;
|
||||
}
|
||||
const mapResponse = await fetch(url, {
|
||||
next: {
|
||||
revalidate: 60 * 60 * 24 * 7, // 1 week
|
||||
},
|
||||
});
|
||||
const mapJson = await mapResponse.json();
|
||||
for (const score of scores) {
|
||||
const mapData = mapJson[score.leaderboard.songHash];
|
||||
if (mapData) {
|
||||
scoresWithBeatsaverData[score.leaderboard.songHash] = {
|
||||
score: score.score,
|
||||
leaderboard: score.leaderboard,
|
||||
mapId: mapData.id,
|
||||
};
|
||||
}
|
||||
}
|
||||
|
||||
return {
|
||||
|
Reference in New Issue
Block a user