Move igdb api functions to separate file
This commit is contained in:
parent
193f172ced
commit
b79b6cdfe0
|
@ -1,4 +1,5 @@
|
|||
const { SlashCommandBuilder, EmbedBuilder } = require('discord.js');
|
||||
const { getCoverURL, getGameJson } = require('../../igdbHelperFunctions.js');
|
||||
|
||||
module.exports = {
|
||||
data: new SlashCommandBuilder()
|
||||
|
@ -44,77 +45,3 @@ module.exports = {
|
|||
return interaction.reply({ embeds: [embed] });
|
||||
},
|
||||
};
|
||||
|
||||
async function getGameJson(body) {
|
||||
let res;
|
||||
|
||||
await fetch(
|
||||
'https://api.igdb.com/v4/games',
|
||||
{ method: 'POST',
|
||||
headers: {
|
||||
'Accept': 'application/json',
|
||||
'Client-ID': `${process.env.igdbClientId}`,
|
||||
'Authorization': `Bearer ${process.env.igdbAccessToken}`,
|
||||
},
|
||||
body: body,
|
||||
})
|
||||
.then(response => response.json())
|
||||
.then(response => {
|
||||
res = response;
|
||||
})
|
||||
.catch(err => {
|
||||
console.error(err);
|
||||
});
|
||||
|
||||
return res;
|
||||
}
|
||||
|
||||
async function getPlatformID(platform) {
|
||||
|
||||
await fetch(
|
||||
'https://api.igdb.com/v4/platforms',
|
||||
{ method: 'POST',
|
||||
headers: {
|
||||
'Accept': 'application/json',
|
||||
'Client-ID': `${process.env.igdbClientId}`,
|
||||
'Authorization': `Bearer ${process.env.igdbAccessToken}`,
|
||||
},
|
||||
body: `where name = "${platform}", alternative_name = "${platform}"; fields id;`,
|
||||
})
|
||||
.then(response => response.json())
|
||||
.then(response => {
|
||||
return response;
|
||||
})
|
||||
.catch(err => {
|
||||
console.error(err);
|
||||
});
|
||||
}
|
||||
|
||||
async function getCoverURL(id) {
|
||||
let url = 'https://upload.wikimedia.org/wikipedia/commons/d/d1/Image_not_available.png';
|
||||
|
||||
await fetch(
|
||||
'https://api.igdb.com/v4/covers',
|
||||
{ method: 'POST',
|
||||
headers: {
|
||||
'Accept': 'application/json',
|
||||
'Client-ID': `${process.env.igdbClientId}`,
|
||||
'Authorization': `Bearer ${process.env.igdbAccessToken}`,
|
||||
},
|
||||
body: `where id = ${id}; fields url;`,
|
||||
})
|
||||
.then(response => response.json())
|
||||
.then(response => {
|
||||
if (response[0]) {
|
||||
url = 'https:'.concat(response[0].url);
|
||||
}
|
||||
})
|
||||
.then(response => {
|
||||
url = url.replace('t_thumb', 't_1080p_2x');
|
||||
})
|
||||
.catch(err => {
|
||||
console.error(err);
|
||||
});
|
||||
|
||||
return url;
|
||||
}
|
|
@ -1,4 +1,5 @@
|
|||
const { SlashCommandBuilder, EmbedBuilder } = require('discord.js');
|
||||
const { getGameJson } = require('../../igdbHelperFunctions.js');
|
||||
|
||||
module.exports = {
|
||||
data: new SlashCommandBuilder()
|
||||
|
@ -55,51 +56,3 @@ async function searchGamesWithoutMinimumReview(gamename) {
|
|||
|
||||
return games;
|
||||
}
|
||||
|
||||
async function getGameJson(body) {
|
||||
let res;
|
||||
|
||||
await fetch(
|
||||
'https://api.igdb.com/v4/games',
|
||||
{ method: 'POST',
|
||||
headers: {
|
||||
'Accept': 'application/json',
|
||||
'Client-ID': `${process.env.igdbClientId}`,
|
||||
'Authorization': `Bearer ${process.env.igdbAccessToken}`,
|
||||
},
|
||||
body: body,
|
||||
})
|
||||
.then(response => response.json())
|
||||
.then(response => {
|
||||
res = response;
|
||||
})
|
||||
.catch(err => {
|
||||
console.error(err);
|
||||
});
|
||||
|
||||
return res;
|
||||
}
|
||||
|
||||
async function getReleaseDates(id) {
|
||||
let date;
|
||||
|
||||
await fetch(
|
||||
'https://api.igdb.com/v4/release_dates',
|
||||
{ method: 'POST',
|
||||
headers: {
|
||||
'Accept': 'application/json',
|
||||
'Client-ID': `${process.env.igdbClientId}`,
|
||||
'Authorization': `Bearer ${process.env.igdbAccessToken}`,
|
||||
},
|
||||
body: `where id = ${id}; fields category,checksum,created_at,date,game,human,m,platform,region,status,updated_at,y;`,
|
||||
})
|
||||
.then(response => response.json())
|
||||
.then(response => {
|
||||
date = response[0].human;
|
||||
})
|
||||
.catch(err => {
|
||||
console.error(err);
|
||||
});
|
||||
|
||||
return date;
|
||||
}
|
|
@ -0,0 +1,104 @@
|
|||
async function getCoverURL(id) {
|
||||
let url = 'https://upload.wikimedia.org/wikipedia/commons/d/d1/Image_not_available.png';
|
||||
|
||||
await fetch(
|
||||
'https://api.igdb.com/v4/covers',
|
||||
{ method: 'POST',
|
||||
headers: {
|
||||
'Accept': 'application/json',
|
||||
'Client-ID': `${process.env.igdbClientId}`,
|
||||
'Authorization': `Bearer ${process.env.igdbAccessToken}`,
|
||||
},
|
||||
body: `where id = ${id}; fields url;`,
|
||||
})
|
||||
.then(response => response.json())
|
||||
.then(response => {
|
||||
if (response[0]) {
|
||||
url = 'https:'.concat(response[0].url);
|
||||
}
|
||||
})
|
||||
.then(response => {
|
||||
url = url.replace('t_thumb', 't_1080p_2x');
|
||||
})
|
||||
.catch(err => {
|
||||
console.error(err);
|
||||
});
|
||||
|
||||
return url;
|
||||
}
|
||||
|
||||
async function getPlatformID(platform) {
|
||||
|
||||
await fetch(
|
||||
'https://api.igdb.com/v4/platforms',
|
||||
{ method: 'POST',
|
||||
headers: {
|
||||
'Accept': 'application/json',
|
||||
'Client-ID': `${process.env.igdbClientId}`,
|
||||
'Authorization': `Bearer ${process.env.igdbAccessToken}`,
|
||||
},
|
||||
body: `where name = "${platform}", alternative_name = "${platform}"; fields id;`,
|
||||
})
|
||||
.then(response => response.json())
|
||||
.then(response => {
|
||||
return response;
|
||||
})
|
||||
.catch(err => {
|
||||
console.error(err);
|
||||
});
|
||||
}
|
||||
|
||||
async function getGameJson(body) {
|
||||
let res;
|
||||
|
||||
await fetch(
|
||||
'https://api.igdb.com/v4/games',
|
||||
{ method: 'POST',
|
||||
headers: {
|
||||
'Accept': 'application/json',
|
||||
'Client-ID': `${process.env.igdbClientId}`,
|
||||
'Authorization': `Bearer ${process.env.igdbAccessToken}`,
|
||||
},
|
||||
body: body,
|
||||
})
|
||||
.then(response => response.json())
|
||||
.then(response => {
|
||||
res = response;
|
||||
})
|
||||
.catch(err => {
|
||||
console.error(err);
|
||||
});
|
||||
|
||||
return res;
|
||||
}
|
||||
|
||||
async function getReleaseDates(id) {
|
||||
let date;
|
||||
|
||||
await fetch(
|
||||
'https://api.igdb.com/v4/release_dates',
|
||||
{ method: 'POST',
|
||||
headers: {
|
||||
'Accept': 'application/json',
|
||||
'Client-ID': `${process.env.igdbClientId}`,
|
||||
'Authorization': `Bearer ${process.env.igdbAccessToken}`,
|
||||
},
|
||||
body: `where id = ${id}; fields category,checksum,created_at,date,game,human,m,platform,region,status,updated_at,y;`,
|
||||
})
|
||||
.then(response => response.json())
|
||||
.then(response => {
|
||||
date = response[0].human;
|
||||
})
|
||||
.catch(err => {
|
||||
console.error(err);
|
||||
});
|
||||
|
||||
return date;
|
||||
}
|
||||
|
||||
module.exports = {
|
||||
getCoverURL,
|
||||
getPlatformID,
|
||||
getGameJson,
|
||||
getReleaseDates,
|
||||
};
|
Loading…
Reference in New Issue