Convert everything to superagent properly

This commit is contained in:
Daniel Odendahl Jr
2018-06-08 15:36:21 +00:00
parent 63f3398858
commit b4c815f403
17 changed files with 163 additions and 155 deletions
+2 -2
View File
@@ -21,10 +21,10 @@ module.exports = class HttpCatCommand extends Command {
async run(msg, { code }) {
try {
const { body, headers } = await request.get(`https://http.cat/${code}.jpg`);
if (headers['content-type'] === 'text/html') return msg.say('Could not find any results.');
const { body } = await request.get(`https://http.cat/${code}.jpg`);
return msg.say({ files: [{ attachment: body, name: `${code}.jpg` }] });
} catch (err) {
if (err.status === 404) return msg.say('Could not find any results.');
return msg.reply(`Oh no, an error occurred: \`${err.message}\`. Try again later!`);
}
}
+48
View File
@@ -0,0 +1,48 @@
const Command = require('../../structures/Command');
const { MessageEmbed } = require('discord.js');
const request = require('superagent');
const { shorten } = require('../../util/Util');
module.exports = class KitsuAnimeCommand extends Command {
constructor(client) {
super(client, {
name: 'kitsu-anime',
aliases: ['my-anime-list-anime', 'mal-anime', 'anime'],
group: 'search',
memberName: 'kitsu-anime',
description: 'Searches Kitsu.io for your query, getting anime results.',
clientPermissions: ['EMBED_LINKS'],
args: [
{
key: 'query',
prompt: 'What anime would you like to search for?',
type: 'string'
}
]
});
}
async run(msg, { query }) {
try {
const { body } = await request
.get('https://kitsu.io/api/edge/anime')
.query({ 'filter[text]': query });
if (!body.data.length) return msg.say('Could not find any results.');
const data = body.data[0].attributes;
const embed = new MessageEmbed()
.setColor(0xF75239)
.setAuthor('Kitsu.io', 'https://i.imgur.com/lVqooyd.png', 'https://kitsu.io/explore/anime')
.setURL(`https://kitsu.io/anime/${data.slug}`)
.setThumbnail(data.posterImage ? data.posterImage.original : null)
.setTitle(data.canonicalTitle)
.setDescription(shorten(data.synopsis))
.addField(' Type', `${data.showType} - ${data.status}`, true)
.addField(' Episodes', data.episodeCount || '???', true)
.addField(' Start Date', data.startDate ? new Date(data.startDate).toDateString() : '???', true)
.addField(' End Date', data.endDate ? new Date(data.endDate).toDateString() : '???', true);
return msg.embed(embed);
} catch (err) {
return msg.reply(`Oh no, an error occurred: \`${err.message}\`. Try again later!`);
}
}
};
+48
View File
@@ -0,0 +1,48 @@
const Command = require('../../structures/Command');
const { MessageEmbed } = require('discord.js');
const request = require('superagent');
const { shorten } = require('../../util/Util');
module.exports = class KitsuMangaCommand extends Command {
constructor(client) {
super(client, {
name: 'kitsu-manga',
aliases: ['my-anime-list-manga', 'mal-manga', 'manga'],
group: 'search',
memberName: 'kitsu-manga',
description: 'Searches Kitsu.io for your query, getting manga results.',
clientPermissions: ['EMBED_LINKS'],
args: [
{
key: 'query',
prompt: 'What manga would you like to search for?',
type: 'string'
}
]
});
}
async run(msg, { query }) {
try {
const { body } = await request
.get('https://kitsu.io/api/edge/manga')
.query({ 'filter[text]': query });
if (!body.data.length) return msg.say('Could not find any results.');
const data = body.data[0].attributes;
const embed = new MessageEmbed()
.setColor(0xF75239)
.setAuthor('Kitsu.io', 'https://i.imgur.com/lVqooyd.png', 'https://kitsu.io/explore/manga')
.setURL(`https://kitsu.io/manga/${data.slug}`)
.setThumbnail(data.posterImage ? data.posterImage.original : null)
.setTitle(data.canonicalTitle)
.setDescription(shorten(data.synopsis))
.addField(' Type', `${data.subtype} - ${data.status}`, true)
.addField(' Volumes / Chapters', `${data.volumeCount || '???'} / ${data.chapterCount || '???'}`, true)
.addField(' Start Date', data.startDate ? new Date(data.startDate).toDateString() : '???', true)
.addField(' End Date', data.endDate ? new Date(data.endDate).toDateString() : '???', true);
return msg.embed(embed);
} catch (err) {
return msg.reply(`Oh no, an error occurred: \`${err.message}\`. Try again later!`);
}
}
};
-54
View File
@@ -1,54 +0,0 @@
const Command = require('../../structures/Command');
const { MessageEmbed } = require('discord.js');
const request = require('superagent');
const { parseString } = require('xml2js');
const { promisify } = require('util');
const xml = promisify(parseString);
const { shorten, base64, cleanXML } = require('../../util/Util');
const { MAL_USERNAME, MAL_PASSWORD } = process.env;
module.exports = class MyAnimeListAnimeCommand extends Command {
constructor(client) {
super(client, {
name: 'my-anime-list-anime',
aliases: ['mal-anime', 'anime'],
group: 'search',
memberName: 'my-anime-list-anime',
description: 'Searches My Anime List for your query, getting anime results.',
clientPermissions: ['EMBED_LINKS'],
args: [
{
key: 'query',
prompt: 'What anime would you like to search for?',
type: 'string'
}
]
});
}
async run(msg, { query }) {
try {
const { text } = await request
.get('https://myanimelist.net/api/anime/search.xml')
.query({ q: query })
.set({ Authorization: `Basic ${base64(`${MAL_USERNAME}:${MAL_PASSWORD}`)}` });
const body = await xml(text);
const data = body.anime.entry[0];
const embed = new MessageEmbed()
.setColor(0x2D54A2)
.setAuthor('My Anime List', 'https://i.imgur.com/5rivpMM.png', 'https://myanimelist.net/')
.setURL(`https://myanimelist.net/anime/${data.id[0]}`)
.setThumbnail(data.image[0])
.setTitle(data.title[0])
.setDescription(shorten(cleanXML(data.synopsis[0])))
.addField(' Type', `${data.type[0]} - ${data.status[0]}`, true)
.addField(' Episodes', data.episodes[0], true)
.addField(' Start Date', data.start_date[0] !== '0000-00-00' ? data.start_date[0] : '???', true)
.addField(' End Date', data.end_date[0] !== '0000-00-00' ? data.end_date[0] : '???', true);
return msg.embed(embed);
} catch (err) {
if (err.message === 'Parse Error') return msg.say('Could not find any results.');
return msg.reply(`Oh no, an error occurred: \`${err.message}\`. Try again later!`);
}
}
};
-55
View File
@@ -1,55 +0,0 @@
const Command = require('../../structures/Command');
const { MessageEmbed } = require('discord.js');
const request = require('superagent');
const { parseString } = require('xml2js');
const { promisify } = require('util');
const xml = promisify(parseString);
const { shorten, base64, cleanXML } = require('../../util/Util');
const { MAL_USERNAME, MAL_PASSWORD } = process.env;
module.exports = class MyAnimeListMangaCommand extends Command {
constructor(client) {
super(client, {
name: 'my-anime-list-manga',
aliases: ['mal-manga', 'manga'],
group: 'search',
memberName: 'my-anime-list-manga',
description: 'Searches My Anime List for your query, getting manga results.',
clientPermissions: ['EMBED_LINKS'],
args: [
{
key: 'query',
prompt: 'What manga would you like to search for?',
type: 'string'
}
]
});
}
async run(msg, { query }) {
try {
const { text } = await request
.get('https://myanimelist.net/api/manga/search.xml')
.query({ q: query })
.set({ Authorization: `Basic ${base64(`${MAL_USERNAME}:${MAL_PASSWORD}`)}` });
const body = await xml(text);
const data = body.manga.entry[0];
const embed = new MessageEmbed()
.setColor(0x2D54A2)
.setAuthor('My Anime List', 'https://i.imgur.com/5rivpMM.png', 'https://myanimelist.net/')
.setURL(`https://myanimelist.net/manga/${data.id[0]}`)
.setThumbnail(data.image[0])
.setTitle(data.title[0])
.setDescription(shorten(cleanXML(data.synopsis[0])))
.addField(' Type', `${data.type[0]} - ${data.status[0]}`, true)
.addField(' Volumes / Chapters',
`${Number.parseInt(data.volumes[0], 10) || '???'} / ${Number.parseInt(data.chapters[0], 10) || '???'}`, true)
.addField(' Start Date', data.start_date[0] !== '0000-00-00' ? data.start_date[0] : '???', true)
.addField(' End Date', data.end_date[0] !== '0000-00-00' ? data.end_date[0] : '???', true);
return msg.embed(embed);
} catch (err) {
if (err.message === 'Parse Error') return msg.say('Could not find any results.');
return msg.reply(`Oh no, an error occurred: \`${err.message}\`. Try again later!`);
}
}
};
+1 -1
View File
@@ -51,7 +51,7 @@ module.exports = class NeopetsItemCommand extends Command {
const price = text.match(/([0-9,]+) (NP|NC)/);
const url = `https://items.jellyneo.net/item/${id[1]}/`;
const details = await request.get(url);
const detailsText = details.raw.toString();
const detailsText = details.text;
return {
id: id[1],
url,
@@ -3,13 +3,13 @@ const { MessageEmbed } = require('discord.js');
const request = require('superagent');
const { shorten } = require('../../util/Util');
module.exports = class VocaloidCommand extends Command {
module.exports = class VocaDBCommand extends Command {
constructor(client) {
super(client, {
name: 'vocaloid',
aliases: ['vocadb', 'vocaloid-song', 'vocaloid-music'],
name: 'vocadb',
aliases: ['vocaloid', 'vocaloid-song', 'vocaloid-music'],
group: 'search',
memberName: 'vocaloid',
memberName: 'vocadb',
description: 'Searches VocaDB for your query.',
clientPermissions: ['EMBED_LINKS'],
args: [