/[sudobot]/branches/4.x/src/commands/fun/HttpcatCommand.ts
ViewVC logotype

Contents of /branches/4.x/src/commands/fun/HttpcatCommand.ts

Parent Directory Parent Directory | Revision Log Revision Log


Revision 577 - (show annotations)
Mon Jul 29 18:52:37 2024 UTC (8 months, 1 week ago) by rakinar2
File MIME type: application/typescript
File size: 3159 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 HttpcatCommand extends BaseCommand {
28 supportsInteractions: boolean = true;
29
30 constructor() {
31 super('httpcat', 'fun', []);
32 }
33
34 async run(client: DiscordClient, msg: Message | CommandInteraction, options: CommandOptions | InteractionOptions) {
35 if (!options.isInteraction && options.args[0] === undefined) {
36 await msg.reply({
37 embeds: [
38 new MessageEmbed()
39 .setColor('#f14a60')
40 .setDescription('This command requires at least 1 argument.')
41 ]
42 });
43
44 return;
45 }
46
47 if (msg instanceof CommandInteraction)
48 await msg.deferReply();
49
50 let status = parseInt((options.isInteraction ? options.options.getInteger('status') : options.args[0]) + '');
51
52 if (typeof status !== 'number' || status < 100 || status > 515) {
53 await this.deferReply(msg, {
54 embeds: [
55 new MessageEmbed()
56 .setColor('#f14a60')
57 .setDescription('Argument #1 must be a valid HTTP status code.')
58 ]
59 });
60
61 return;
62 }
63
64 let url = "https://http.cat/" + status;
65
66 axios.get(url)
67 .then(async (data) => {
68 await this.deferReply(msg, {
69 content: url
70 });
71 })
72 .catch(async err => {
73 if (err.response.status === 404) {
74 await this.deferReply(msg, {
75 embeds: [
76 new MessageEmbed()
77 .setColor('#f14a60')
78 .setDescription('Argument #1 must be a valid HTTP status code.')
79 ]
80 });
81
82 return;
83 }
84
85 await this.deferReply(msg, {
86 embeds: [
87 new MessageEmbed()
88 .setColor('#f14a60')
89 .setDescription('Failed to fetch data from the API.')
90 ]
91 });
92 });
93 }
94 }

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26