/[sudobot]/branches/3.x/src/commands/fun/HttpdogCommand.ts
ViewVC logotype

Contents of /branches/3.x/src/commands/fun/HttpdogCommand.ts

Parent Directory Parent Directory | Revision Log Revision Log


Revision 577 - (show annotations)
Mon Jul 29 18:52:37 2024 UTC (8 months ago) by rakinar2
File MIME type: application/typescript
File size: 3189 byte(s)
chore: add old version archive branches (2.x to 9.x-dev)
1 /**
2 * This file is part of SudoBot.
3 *
4 * Copyright (C) 2021-2022 OSN Inc.
5 *
6 * SudoBot is free software; you can redistribute it and/or modify it
7 * under the terms of the GNU Affero General Public License as published by
8 * the Free Software Foundation, either version 3 of the License, or
9 * (at your option) any later version.
10 *
11 * SudoBot is distributed in the hope that it will be useful, but
12 * WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU Affero General Public License for more details.
15 *
16 * You should have received a copy of the GNU Affero General Public License
17 * along with SudoBot. If not, see <https://www.gnu.org/licenses/>.
18 */
19
20 import { CommandInteraction, Message, MessageEmbed } from 'discord.js';
21 import BaseCommand from '../../utils/structures/BaseCommand';
22 import DiscordClient from '../../client/Client';
23 import CommandOptions from '../../types/CommandOptions';
24 import InteractionOptions from '../../types/InteractionOptions';
25 import axios from 'axios';
26
27 export default class HttpdogCommand extends BaseCommand {
28 supportsInteractions: boolean = true;
29 coolDown = 4000;
30
31 constructor() {
32 super('httpdog', 'fun', []);
33 }
34
35 async run(client: DiscordClient, msg: Message | CommandInteraction, options: CommandOptions | InteractionOptions) {
36 if (!options.isInteraction && options.args[0] === undefined) {
37 await msg.reply({
38 embeds: [
39 new MessageEmbed()
40 .setColor('#f14a60')
41 .setDescription('This command requires at least 1 argument.')
42 ]
43 });
44
45 return;
46 }
47
48 if (msg instanceof CommandInteraction)
49 await msg.deferReply();
50
51 let status = parseInt((options.isInteraction ? options.options.getInteger('status') : options.args[0]) + '');
52
53 if (typeof status !== 'number' || status < 100 || status > 515) {
54 await this.deferReply(msg, {
55 embeds: [
56 new MessageEmbed()
57 .setColor('#f14a60')
58 .setDescription('Argument #1 must be a valid HTTP status code.')
59 ]
60 });
61
62 return;
63 }
64
65 let url = "https://http.dog/" + status + '.jpg';
66
67 axios.get(url)
68 .then(async (data) => {
69 await this.deferReply(msg, {
70 content: url
71 });
72 })
73 .catch(async err => {
74 if (err.response.status === 404) {
75 await this.deferReply(msg, {
76 embeds: [
77 new MessageEmbed()
78 .setColor('#f14a60')
79 .setDescription('Argument #1 must be a valid HTTP status code.')
80 ]
81 });
82
83 return;
84 }
85
86 await this.deferReply(msg, {
87 embeds: [
88 new MessageEmbed()
89 .setColor('#f14a60')
90 .setDescription('Failed to fetch data from the API.')
91 ]
92 });
93 });
94 }
95 }

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26