Compare commits

...

2 Commits

Author SHA1 Message Date
baz
e01dfd8291 Add initial batching to wrapped 2025-05-13 23:53:54 +01:00
baz
7cb3ca3e58 Batch genre calls 2025-05-13 23:47:23 +01:00
3 changed files with 38 additions and 34 deletions

View File

@ -52,32 +52,34 @@ module.exports = {
return interaction.editReply({ embeds: [embed] }); return interaction.editReply({ embeds: [embed] });
} }
const beatGameIGDBEntries = []; const gameIds = [];
for (let i = 0; i < beatenGamesDatabaseEntries.length; i++) { for (let i = 0; i < beatenGamesDatabaseEntries.length; i++) {
const game = await checkGameStorageId(beatenGamesDatabaseEntries[i].gameId); const game = await checkGameStorageId(beatenGamesDatabaseEntries[i].gameId);
const json = await getGameJson(String.prototype.concat('where id = ', game.igdb_id, '; fields *;')); gameIds.push(game.igdb_id);
beatGameIGDBEntries.push(json[0]);
} }
const genres = []; const beatGameIGDBEntries = await getGameJson(String.prototype.concat(`where id = (${gameIds}); fields *; limit ${gameIds.length};`));
const counts = []; const counts = [];
const cachedGenres = new Map(); const cachedGenres = new Set();
for (let i = 0; i < beatGameIGDBEntries.length; i++) { for (let i = 0; i < beatGameIGDBEntries.length; i++) {
if (beatGameIGDBEntries[i].genres) { if (beatGameIGDBEntries[i].genres) {
for (let j = 0; j < beatGameIGDBEntries[i].genres.length; j++) { for (let j = 0; j < beatGameIGDBEntries[i].genres.length; j++) {
cachedGenres.add(beatGameIGDBEntries[i].genres[j]);
}
}
}
if (cachedGenres.has(beatGameIGDBEntries[i].genres[j])) const genresinfo = await getGenres([...cachedGenres]);
{
genres.push(cachedGenres.get(beatGameIGDBEntries[i].genres[j])); const genres = [];
}
else for (let i = 0; i < beatGameIGDBEntries.length; i++) {
{ if (beatGameIGDBEntries[i].genres) {
const genre = await getGenres(beatGameIGDBEntries[i].genres[j]); for (let j = 0; j < beatGameIGDBEntries[i].genres.length; j++) {
cachedGenres.set(beatGameIGDBEntries[i].genres[j], genre); genres.push(genresinfo.find(item => item.id === beatGameIGDBEntries[i].genres[j]).name);
genres.push(genre);
}
} }
} }
} }

View File

@ -103,13 +103,14 @@ async function GetBeatenGamesForYear(userDatabaseEntry, year) {
} }
async function GetIGDBEntries(array) { async function GetIGDBEntries(array) {
beatGameIGDBEntries = []; const gameIds = [];
for (let i = 0; i < array.length; i++) { for (let i = 0; i < array.length; i++) {
const game = await checkGameStorageId(array[i].gameId); const game = await checkGameStorageId(array[i].gameId);
const json = await getGameJson(String.prototype.concat('where id = ', game.igdb_id, '; fields *;')); gameIds.push(game.igdb_id);
beatGameIGDBEntries.push(json[0]);
} }
beatGameIGDBEntries = await getGameJson(String.prototype.concat(`where id = (${gameIds}); fields *; limit ${gameIds.length};`));
} }
async function GetDevelopers() { async function GetDevelopers() {
@ -257,24 +258,25 @@ async function GetAverageGameAge() {
} }
async function GetFavouriteGenres() { async function GetFavouriteGenres() {
const genres = [];
const counts = []; const counts = [];
const cachedGenres = new Map(); const cachedGenres = new Set();
for (let i = 0; i < beatGameIGDBEntries.length; i++) { for (let i = 0; i < beatGameIGDBEntries.length; i++) {
if (beatGameIGDBEntries[i].genres) { if (beatGameIGDBEntries[i].genres) {
for (let j = 0; j < beatGameIGDBEntries[i].genres.length; j++) { for (let j = 0; j < beatGameIGDBEntries[i].genres.length; j++) {
cachedGenres.add(beatGameIGDBEntries[i].genres[j]);
}
}
}
if (cachedGenres.has(beatGameIGDBEntries[i].genres[j])) const genresinfo = await getGenres([...cachedGenres]);
{
genres.push(cachedGenres.get(beatGameIGDBEntries[i].genres[j])); const genres = [];
}
else for (let i = 0; i < beatGameIGDBEntries.length; i++) {
{ if (beatGameIGDBEntries[i].genres) {
const genre = await getGenres(beatGameIGDBEntries[i].genres[j]); for (let j = 0; j < beatGameIGDBEntries[i].genres.length; j++) {
cachedGenres.set(beatGameIGDBEntries[i].genres[j], genre); genres.push(genresinfo.find(item => item.id === beatGameIGDBEntries[i].genres[j]).name);
genres.push(genre);
}
} }
} }
} }

View File

@ -150,17 +150,17 @@ async function getGenres(id) {
'Client-ID': `${process.env.igdbClientId}`, 'Client-ID': `${process.env.igdbClientId}`,
'Authorization': `Bearer ${process.env.igdbAccessToken}`, 'Authorization': `Bearer ${process.env.igdbAccessToken}`,
}, },
body: `where id = ${id}; fields *;`, body: `where id = (${id}); fields *; limit ${id.length};`,
}) })
.then(response => response.json()) .then(response => response.json())
.then(response => { .then(response => {
genre = response[0]; genre = response;
}) })
.catch(err => { .catch(err => {
console.error(err); console.error(err);
}); });
return genre.name; return genre;
} }
async function getFranchise(id) { async function getFranchise(id) {