-
-
Notifications
You must be signed in to change notification settings - Fork 11
/
Copy pathbot.js
121 lines (115 loc) · 4.75 KB
/
bot.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
import {
Client,
GatewayIntentBits,
Partials,
Collection,
ApplicationCommandType,
ActivityType,
InteractionContextType,
ApplicationIntegrationType,
PresenceUpdateStatus,
AllowedMentionsTypes
} from "discord.js";
import fs from 'fs';
import path from 'path';
import globalVars from "./objects/globalVars.json" with { type: "json" };
const intents = [
GatewayIntentBits.Guilds,
GatewayIntentBits.GuildModeration,
GatewayIntentBits.GuildMessages,
GatewayIntentBits.GuildMessageReactions,
GatewayIntentBits.DirectMessages,
// Privileged intents
// GatewayIntentBits.GuildPresences, // Ungranted
GatewayIntentBits.GuildMembers,
GatewayIntentBits.MessageContent
];
const partials = [
Partials.Channel,
Partials.GuildMember,
Partials.Message,
Partials.Reaction,
Partials.User
];
// Presence
const customStatus = "💤 Chilling in Valor Cavern";
// When setting multiple activities including a custom status, only the custom status will be displayed which is weird behaviour inconsistent with normal users but it's no big deal for a bot anyways, it's just visual flair.
const presenceObject = {
activities: [{
name: customStatus, // Not visible but a required feel, only visible through the API
state: customStatus, // This is what shows up on users' clients
type: ActivityType.Custom
}, {
name: "the lake theme",
type: ActivityType.Listening
}], status: PresenceUpdateStatus.Idle
};
globalVars.presence = presenceObject;
const client = new Client({
presence: presenceObject,
intents: intents,
partials: partials,
allowedMentions: {
parse: [AllowedMentionsTypes.User, AllowedMentionsTypes.Role],
repliedUser: true
},
shards: "auto"
});
// This loop reads the /events/ folder and attaches each event file to the appropriate event.
await fs.promises.readdir("./events/").then(async (files) => {
for await (const file of files) {
// If the file is not a JS file, ignore it.
if (!file.endsWith(".js")) return;
// Load the event file itself
let event = await import(`./events/${file}`);
event = event.default;
// Get just the event name from the file name
let eventName = file.split(".")[0];
// Each event will be called with the client argument,
// followed by its "normal" arguments, like message, member, etc.
client.on(eventName, event.bind(null, client));
};
}).catch((err) => {
console.log(err);
});
console.log("Loaded events!");
client.commands = new Collection();
await walk(`./commands/`);
console.log("Loaded commands!");
client.login(process.env.TOKEN);
// This loop reads the /commands/ folder and attaches each command file to the appropriate command.
async function walk(dir, callback) {
await fs.promises.readdir(dir).then(async (files) => {
for (const file of files) {
let filepath = path.join(dir, file);
await fs.promises.stat(filepath).then(async (stats) => {
if (stats.isDirectory()) {
await walk(filepath, callback);
} else if (stats.isFile() && file.endsWith('.js')) {
let props = await import(`./${filepath}`);
if (!props.commandObject.type) props.commandObject.type = ApplicationCommandType.ChatInput;
// Set default contexts (all). This is already the API default (null acts the same) but this lets me keep the later checks simpler
if (!props.commandObject.contexts) props.commandObject.contexts = [
InteractionContextType.Guild,
InteractionContextType.BotDM,
InteractionContextType.PrivateChannel
];
// If command requires a guild; limit to guild installs
if (!props.commandObject.integration_types &&
props.commandObject.contexts.includes(InteractionContextType.Guild) &&
props.commandObject.contexts.length == 1) props.commandObject.integration_types = [ApplicationIntegrationType.GuildInstall];
// All install types by default
if (!props.commandObject.integration_types) props.commandObject.integration_types = [
ApplicationIntegrationType.GuildInstall,
ApplicationIntegrationType.UserInstall
];
let commandName = file.split(".")[0].toLowerCase();
// console.log(`Loaded command: ${commandName} ✔`);
client.commands.set(commandName, props);
};
});
};
}).catch((err) => {
console.log(err);
});
};