TravBot-v3/src/commands/info.ts

195 lines
10 KiB
TypeScript
Raw Normal View History

2020-12-15 01:44:28 +00:00
import {MessageEmbed, version as djsversion} from "discord.js";
import ms from "ms";
import os from "os";
import Command from "../core/command";
import {CommonLibrary, formatBytes, trimArray} from "../core/lib";
import {verificationLevels, filterLevels, regions, flags} from "../defs/info";
import moment from "moment";
import utc from "moment";
export default new Command({
2020-12-15 07:56:09 +00:00
description: "Command to provide all sorts of info about the current server, a user, etc.",
2020-12-15 01:44:28 +00:00
run: "Please provide an argument.\nFor help, run `%prefix%help info`.",
subcommands: {
avatar: new Command({
description: "Shows your own, or another user's avatar.",
usage: "(<user>)",
async run($: CommonLibrary): Promise<any> {
2020-12-15 07:56:09 +00:00
$.channel.send($.author.displayAvatarURL({dynamic: true, size: 2048}));
2020-12-15 01:44:28 +00:00
},
user: new Command({
description: "Shows your own, or another user's avatar.",
async run($: CommonLibrary): Promise<any> {
$.channel.send(
$.args[0].displayAvatarURL({
dynamic: true,
size: 2048
})
);
}
})
}),
bot: new Command({
description: "Displays info about the bot.",
async run($: CommonLibrary): Promise<any> {
const core = os.cpus()[0];
const embed = new MessageEmbed()
.setThumbnail(
/// @ts-ignore
$.client.user?.displayAvatarURL({
dynamic: true,
size: 2048
})
)
.setColor($.guild?.me?.displayHexColor || "BLUE")
.addField("General", [
`** Client:** ${$.client.user?.tag} (${$.client.user?.id})`,
`** Servers:** ${$.client.guilds.cache.size.toLocaleString()}`,
`** Users:** ${$.client.guilds.cache
2020-12-15 07:56:09 +00:00
.reduce((a: any, b: {memberCount: any}) => a + b.memberCount, 0)
2020-12-15 01:44:28 +00:00
.toLocaleString()}`,
`** Channels:** ${$.client.channels.cache.size.toLocaleString()}`,
2020-12-15 07:56:09 +00:00
`** Creation Date:** ${utc($.client.user?.createdTimestamp).format("Do MMMM YYYY HH:mm:ss")}`,
2020-12-15 01:44:28 +00:00
`** Node.JS:** ${process.version}`,
`** Version:** v${process.env.npm_package_version}`,
2020-12-15 01:44:28 +00:00
`** Discord.JS:** ${djsversion}`,
"\u200b"
])
.addField("System", [
`** Platform:** ${process.platform}`,
`** Uptime:** ${ms(os.uptime() * 1000, {
long: true
})}`,
`** CPU:**`,
`\u3000 • Cores: ${os.cpus().length}`,
`\u3000 • Model: ${core.model}`,
`\u3000 • Speed: ${core.speed}MHz`,
`** Memory:**`,
2020-12-15 07:56:09 +00:00
`\u3000 • Total: ${formatBytes(process.memoryUsage().heapTotal)}`,
`\u3000 • Used: ${formatBytes(process.memoryUsage().heapTotal)}`
2020-12-15 01:44:28 +00:00
])
.setTimestamp();
$.channel.send(embed);
}
}),
guild: new Command({
description: "Displays info about the current guild.",
async run($: CommonLibrary): Promise<any> {
if ($.guild) {
const roles = $.guild.roles.cache
.sort((a, b) => b.position - a.position)
.map((role) => role.toString());
const members = $.guild.members.cache;
const channels = $.guild.channels.cache;
const emojis = $.guild.emojis.cache;
const iconURL = $.guild.iconURL({dynamic: true});
const embed = new MessageEmbed()
2020-12-15 07:56:09 +00:00
.setDescription(`**Guild information for __${$.guild.name}__**`)
2020-12-15 01:44:28 +00:00
.setColor("BLUE");
if (iconURL)
embed
.setThumbnail(iconURL)
.addField("General", [
`** Name:** ${$.guild.name}`,
`** ID:** ${$.guild.id}`,
`** Owner:** ${$.guild.owner?.user.tag} (${$.guild.ownerID})`,
`** Region:** ${regions[$.guild.region]}`,
2020-12-15 07:56:09 +00:00
`** Boost Tier:** ${$.guild.premiumTier ? `Tier ${$.guild.premiumTier}` : "None"}`,
`** Explicit Filter:** ${filterLevels[$.guild.explicitContentFilter]}`,
`** Verification Level:** ${verificationLevels[$.guild.verificationLevel]}`,
`** Time Created:** ${moment($.guild.createdTimestamp).format("LT")} ${moment(
2020-12-15 01:44:28 +00:00
$.guild.createdTimestamp
2020-12-15 07:56:09 +00:00
).format("LL")} ${moment($.guild.createdTimestamp).fromNow()})`,
2020-12-15 01:44:28 +00:00
"\u200b"
])
.addField("Statistics", [
`** Role Count:** ${roles.length}`,
`** Emoji Count:** ${emojis.size}`,
2020-12-15 07:56:09 +00:00
`** Regular Emoji Count:** ${emojis.filter((emoji) => !emoji.animated).size}`,
`** Animated Emoji Count:** ${emojis.filter((emoji) => emoji.animated).size}`,
2020-12-15 01:44:28 +00:00
`** Member Count:** ${$.guild.memberCount}`,
2020-12-15 07:56:09 +00:00
`** Humans:** ${members.filter((member) => !member.user.bot).size}`,
`** Bots:** ${members.filter((member) => member.user.bot).size}`,
`** Text Channels:** ${channels.filter((channel) => channel.type === "text").size}`,
`** Voice Channels:** ${channels.filter((channel) => channel.type === "voice").size}`,
`** Boost Count:** ${$.guild.premiumSubscriptionCount || "0"}`,
2020-12-15 01:44:28 +00:00
`\u200b`
])
.addField("Presence", [
2020-12-15 07:56:09 +00:00
`** Online:** ${members.filter((member) => member.presence.status === "online").size}`,
`** Idle:** ${members.filter((member) => member.presence.status === "idle").size}`,
2020-12-15 01:44:28 +00:00
`** Do Not Disturb:** ${
2020-12-15 07:56:09 +00:00
members.filter((member) => member.presence.status === "dnd").size
2020-12-15 01:44:28 +00:00
}`,
`** Offline:** ${
2020-12-15 07:56:09 +00:00
members.filter((member) => member.presence.status === "offline").size
2020-12-15 01:44:28 +00:00
}`,
"\u200b"
])
.addField(
`Roles [${roles.length - 1}]`,
2020-12-15 07:56:09 +00:00
roles.length < 10 ? roles.join(", ") : roles.length > 10 ? trimArray(roles) : "None"
2020-12-15 01:44:28 +00:00
)
.setTimestamp();
$.channel.send(embed);
} else {
$.channel.send("Please execute this command in a guild.");
}
}
})
},
user: new Command({
description: "Displays info about mentioned user.",
async run($: CommonLibrary): Promise<any> {
// Transforms the User object into a GuildMember object of the current guild.
const member = $.guild?.members.resolve($.args[0]) ?? (await $.guild?.members.fetch($.args[0]));
2020-12-15 01:44:28 +00:00
if (!member)
return $.channel.send(
"No member object was found by that user! Are you sure you used this command in a server?"
);
const roles = member.roles.cache
2020-12-15 07:56:09 +00:00
.sort((a: {position: number}, b: {position: number}) => b.position - a.position)
2020-12-15 01:44:28 +00:00
.map((role: {toString: () => any}) => role.toString())
.slice(0, -1);
// @ts-ignore - Discord.js' typings seem to be outdated here. According to their v12 docs, it's User.fetchFlags() instead of User.flags.
const userFlags = ((await member.user.fetchFlags()) as UserFlags).toArray();
const embed = new MessageEmbed()
2020-12-15 07:56:09 +00:00
.setThumbnail(member.user.displayAvatarURL({dynamic: true, size: 512}))
2020-12-15 01:44:28 +00:00
.setColor(member.displayHexColor || "BLUE")
.addField("User", [
`** Username:** ${member.user.username}`,
`** Discriminator:** ${member.user.discriminator}`,
`** ID:** ${member.id}`,
2020-12-15 07:56:09 +00:00
`** Flags:** ${userFlags.length ? userFlags.join(", ") : "None"}`,
`** Avatar:** [Link to avatar](${member.user.displayAvatarURL({
dynamic: true
})})`,
`** Time Created:** ${moment(member.user.createdTimestamp).format("LT")} ${moment(
2020-12-15 01:44:28 +00:00
member.user.createdTimestamp
2020-12-15 07:56:09 +00:00
).format("LL")} ${moment(member.user.createdTimestamp).fromNow()}`,
2020-12-15 01:44:28 +00:00
`** Status:** ${member.user.presence.status}`,
2020-12-15 07:56:09 +00:00
`** Game:** ${member.user.presence.activities || "Not playing a game."}`
2020-12-15 01:44:28 +00:00
])
.addField("Member", [
`** Highest Role:** ${
2020-12-15 07:56:09 +00:00
member.roles.highest.id === $.guild?.id ? "None" : member.roles.highest.name
2020-12-15 01:44:28 +00:00
}`,
2020-12-15 07:56:09 +00:00
`** Server Join Date:** ${moment(member.joinedAt).format("LL LTS")}`,
`** Hoist Role:** ${member.roles.hoist ? member.roles.hoist.name : "None"}`,
2020-12-15 01:44:28 +00:00
`** Roles:** [${roles.length}]: ${
roles.length < 10 && roles.length > 0
2020-12-15 01:44:28 +00:00
? roles.join(", ")
: roles.length >= 10
? roles.slice(0, 10)
2020-12-15 01:44:28 +00:00
: "None"
}`
]);
$.channel.send(embed);
}
})
});