More fixes

This commit is contained in:
Daniel Odendahl Jr
2019-05-16 14:57:13 +00:00
parent 3bc076319c
commit c6f65d1774
5 changed files with 3 additions and 138 deletions
+1 -3
View File
@@ -45,7 +45,7 @@ Xiao is a Discord bot coded in JavaScript with
6. Run `npm i -g pm2` to install PM2.
7. Run `pm2 start Xiao.js --name xiao` to run the bot.
## Commands (343)
## Commands (341)
### Utility:
* **eval:** Executes JavaScript code.
@@ -169,7 +169,6 @@ Xiao is a Discord bot coded in JavaScript with
* **derpibooru:** Responds with an image from Derpibooru.
* **deviantart:** Responds with an image from a DeviantArt section, with optional query.
* **docs:** Searches the Discord.js docs for your query.
* **eshop:** Searches the Nintendo eShop for your query.
* **esrb:** Searches ESRB for your query.
* **flickr:** Searches Flickr for your query.
* **giphy:** Searches Giphy for your query.
@@ -376,7 +375,6 @@ Xiao is a Discord bot coded in JavaScript with
* **sha-1:** Creates a hash of text with the SHA-1 algorithm.
* **sha-256:** Creates a hash of text with the SHA-256 algorithm.
* **ship-name:** Creates a ship name from two names.
* **shorten-url:** Creates a goo.gl short URL from another URL.
* **shuffle:** Shuffles text.
* **snake-speak:** Convertsssss text to sssssnake ssssspeak.
* **spoiler-letter:** Sends text with each and every character as an individual spoiler.
-93
View File
@@ -1,93 +0,0 @@
const Command = require('../../structures/Command');
const moment = require('moment');
const { MessageEmbed } = require('discord.js');
const request = require('node-superfetch');
const { list } = require('../../util/Util');
const systems = ['3ds', 'switch', 'wii_u'];
module.exports = class EshopCommand extends Command {
constructor(client) {
super(client, {
name: 'eshop',
aliases: ['nintendo-eshop'],
group: 'search',
memberName: 'eshop',
description: 'Searches the Nintendo eShop for your query.',
clientPermissions: ['EMBED_LINKS'],
credit: [
{
name: 'Nintendo',
url: 'https://www.nintendo.com/'
}
],
args: [
{
key: 'system',
prompt: `What system's store do you want to search? Either ${list(systems, 'or')}.`,
type: 'string',
oneOf: systems,
parse: system => system.toLowerCase()
},
{
key: 'query',
prompt: 'What game would you like to search for?',
type: 'string'
}
]
});
}
async run(msg, { system, query }) {
try {
const id = await this.search(system, query);
if (!id) return msg.say('Could not find any results.');
const data = await this.fetchGame(id);
const embed = new MessageEmbed()
.setColor(0xFF7D01)
.setAuthor(
`Nintendo eShop (${system})`,
'https://i.imgur.com/lMh73lz.png',
'https://www.nintendo.com/games/buy-digital'
)
.setURL(data.microsite_ref ? data.microsite_ref.microsite.url : null)
.setThumbnail(data.front_box_art.image.image.url)
.setTitle(data.title)
.addField(' Price', data.eshop_price
? data.eshop_price === '0.00' ? 'Free!' : `$${data.eshop_price}`
: '???', true)
.addField(' Category', data.game_category_ref
? data.game_category_ref.length ? data.game_category_ref[0].title : data.game_category_ref.title
: '???', true)
.addField(' Release Date',
data.release_date ? moment.utc(data.release_date).format('MM/DD/YYYY') : '???', true)
.addField(' Player Count', data.number_of_players || '???', true)
.addField(' DLC?', data.dlc === 'true' ? 'Yes' : 'No', true)
.addField(' Demo?', data.demo === 'true' ? 'Yes' : 'No', true)
.addField(' Developer', data.developer_ref ? data.developer_ref.title : '???', true)
.addField(' Publisher', data.publisher_ref ? data.publisher_ref.title : '???', true);
return msg.embed(embed);
} catch (err) {
return msg.reply(`Oh no, an error occurred: \`${err.message}\`. Try again later!`);
}
}
async search(system, query) {
const { text } = await request
.get('https://www.nintendo.com/json/content/get/filter/game')
.query({
system,
sort: 'title',
direction: 'asc',
search: query,
limit: 1,
availability: 'now'
});
const body = JSON.parse(text);
return body.games.game ? body.games.game.id : null;
}
async fetchGame(id) {
const { text } = await request.get(`https://www.nintendo.com/json/content/get/game/${id}`);
return JSON.parse(text).game;
}
};
+1 -1
View File
@@ -27,7 +27,7 @@ module.exports = class HttpCatCommand extends Command {
async run(msg, { code }) {
try {
const { body, headers } = await request.get(`https://http.cat/${code}.jpg`);
const { body, headers } = await request.get(`https://http.cat/${code}`);
if (headers['content-type'].includes('text/html')) return msg.say('Could not find any results.');
return msg.say({ files: [{ attachment: body, name: `${code}.jpg` }] });
} catch (err) {
-40
View File
@@ -1,40 +0,0 @@
const Command = require('../../structures/Command');
const request = require('node-superfetch');
const { GOOGLE_KEY } = process.env;
module.exports = class ShortenURLCommand extends Command {
constructor(client) {
super(client, {
name: 'shorten-url',
aliases: ['short-url', 'url-shorten'],
group: 'text-edit',
memberName: 'shorten-url',
description: 'Creates a goo.gl short URL from another URL.',
credit: [
{
name: 'Google URL Shortener API',
url: 'https://developers.google.com/url-shortener/'
}
],
args: [
{
key: 'url',
prompt: 'What url do you want to shorten?',
type: 'string'
}
]
});
}
async run(msg, { url }) {
try {
const { body } = await request
.post('https://www.googleapis.com/urlshortener/v1/url')
.query({ key: GOOGLE_KEY })
.send({ longUrl: url });
return msg.say(`<${body.id}>`);
} catch (err) {
return msg.reply(`Oh no, an error occurred: \`${err.message}\`. Try again later!`);
}
}
};
+1 -1
View File
@@ -1,6 +1,6 @@
{
"name": "xiao",
"version": "104.0.0",
"version": "105.0.0",
"description": "Your personal server companion.",
"main": "Xiao.js",
"scripts": {