@jubbio/core 1.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -0
- package/README.md +166 -0
- package/dist/Client.d.ts +147 -0
- package/dist/Client.js +471 -0
- package/dist/builders/ActionRowBuilder.d.ts +53 -0
- package/dist/builders/ActionRowBuilder.js +68 -0
- package/dist/builders/ButtonBuilder.d.ts +77 -0
- package/dist/builders/ButtonBuilder.js +96 -0
- package/dist/builders/EmbedBuilder.d.ts +157 -0
- package/dist/builders/EmbedBuilder.js +199 -0
- package/dist/builders/ModalBuilder.d.ts +122 -0
- package/dist/builders/ModalBuilder.js +162 -0
- package/dist/builders/SelectMenuBuilder.d.ts +123 -0
- package/dist/builders/SelectMenuBuilder.js +165 -0
- package/dist/builders/SlashCommandBuilder.d.ts +197 -0
- package/dist/builders/SlashCommandBuilder.js +324 -0
- package/dist/builders/index.d.ts +9 -0
- package/dist/builders/index.js +26 -0
- package/dist/enums.d.ts +196 -0
- package/dist/enums.js +216 -0
- package/dist/index.d.ts +25 -0
- package/dist/index.js +128 -0
- package/dist/managers/BaseManager.d.ts +69 -0
- package/dist/managers/BaseManager.js +106 -0
- package/dist/managers/ChannelManager.d.ts +98 -0
- package/dist/managers/ChannelManager.js +209 -0
- package/dist/managers/GuildMemberManager.d.ts +74 -0
- package/dist/managers/GuildMemberManager.js +156 -0
- package/dist/managers/RoleManager.d.ts +84 -0
- package/dist/managers/RoleManager.js +207 -0
- package/dist/managers/index.d.ts +7 -0
- package/dist/managers/index.js +24 -0
- package/dist/rest/REST.d.ts +483 -0
- package/dist/rest/REST.js +805 -0
- package/dist/rest/index.d.ts +1 -0
- package/dist/rest/index.js +18 -0
- package/dist/sharding/ShardingManager.d.ts +179 -0
- package/dist/sharding/ShardingManager.js +375 -0
- package/dist/sharding/index.d.ts +4 -0
- package/dist/sharding/index.js +21 -0
- package/dist/structures/Channel.d.ts +120 -0
- package/dist/structures/Channel.js +224 -0
- package/dist/structures/Collection.d.ts +53 -0
- package/dist/structures/Collection.js +115 -0
- package/dist/structures/Guild.d.ts +59 -0
- package/dist/structures/Guild.js +90 -0
- package/dist/structures/GuildMember.d.ts +130 -0
- package/dist/structures/GuildMember.js +208 -0
- package/dist/structures/Interaction.d.ts +224 -0
- package/dist/structures/Interaction.js +404 -0
- package/dist/structures/Message.d.ts +93 -0
- package/dist/structures/Message.js +145 -0
- package/dist/structures/User.d.ts +37 -0
- package/dist/structures/User.js +65 -0
- package/dist/structures/index.d.ts +7 -0
- package/dist/structures/index.js +25 -0
- package/dist/structures.d.ts +1 -0
- package/dist/structures.js +19 -0
- package/dist/types.d.ts +255 -0
- package/dist/types.js +3 -0
- package/dist/utils/BitField.d.ts +66 -0
- package/dist/utils/BitField.js +138 -0
- package/dist/utils/Collection.d.ts +116 -0
- package/dist/utils/Collection.js +265 -0
- package/dist/utils/Collector.d.ts +152 -0
- package/dist/utils/Collector.js +314 -0
- package/dist/utils/DataResolver.d.ts +61 -0
- package/dist/utils/DataResolver.js +146 -0
- package/dist/utils/Formatters.d.ts +145 -0
- package/dist/utils/Formatters.js +213 -0
- package/dist/utils/IntentsBitField.d.ts +85 -0
- package/dist/utils/IntentsBitField.js +99 -0
- package/dist/utils/Partials.d.ts +105 -0
- package/dist/utils/Partials.js +149 -0
- package/dist/utils/PermissionsBitField.d.ts +118 -0
- package/dist/utils/PermissionsBitField.js +145 -0
- package/dist/utils/SnowflakeUtil.d.ts +63 -0
- package/dist/utils/SnowflakeUtil.js +93 -0
- package/dist/utils/Sweepers.d.ts +127 -0
- package/dist/utils/Sweepers.js +270 -0
- package/dist/utils/index.d.ts +13 -0
- package/dist/utils/index.js +30 -0
- package/package.json +37 -0
package/dist/Client.js
ADDED
|
@@ -0,0 +1,471 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.GatewayIntentBits = exports.Client = void 0;
|
|
7
|
+
const events_1 = require("events");
|
|
8
|
+
const ws_1 = __importDefault(require("ws"));
|
|
9
|
+
const enums_1 = require("./enums");
|
|
10
|
+
Object.defineProperty(exports, "GatewayIntentBits", { enumerable: true, get: function () { return enums_1.GatewayIntentBits; } });
|
|
11
|
+
const Collection_1 = require("./structures/Collection");
|
|
12
|
+
const User_1 = require("./structures/User");
|
|
13
|
+
const Guild_1 = require("./structures/Guild");
|
|
14
|
+
const Message_1 = require("./structures/Message");
|
|
15
|
+
const Interaction_1 = require("./structures/Interaction");
|
|
16
|
+
const REST_1 = require("./rest/REST");
|
|
17
|
+
/**
|
|
18
|
+
* Main client class
|
|
19
|
+
*/
|
|
20
|
+
class Client extends events_1.EventEmitter {
|
|
21
|
+
/** Client options */
|
|
22
|
+
options;
|
|
23
|
+
/** REST API client */
|
|
24
|
+
rest;
|
|
25
|
+
/** The bot user */
|
|
26
|
+
user = null;
|
|
27
|
+
/** Application ID */
|
|
28
|
+
applicationId = null;
|
|
29
|
+
/** Cached guilds */
|
|
30
|
+
guilds = new Collection_1.Collection();
|
|
31
|
+
/** Cached channels */
|
|
32
|
+
channels = new Collection_1.Collection();
|
|
33
|
+
/** Cached users */
|
|
34
|
+
users = new Collection_1.Collection();
|
|
35
|
+
/** Voice adapter management */
|
|
36
|
+
voice;
|
|
37
|
+
/** WebSocket connection */
|
|
38
|
+
ws = null;
|
|
39
|
+
/** Bot token */
|
|
40
|
+
token = '';
|
|
41
|
+
/** Session ID */
|
|
42
|
+
sessionId = null;
|
|
43
|
+
/** Sequence number */
|
|
44
|
+
sequence = null;
|
|
45
|
+
/** Heartbeat interval */
|
|
46
|
+
heartbeatInterval = null;
|
|
47
|
+
/** Gateway URL */
|
|
48
|
+
gatewayUrl;
|
|
49
|
+
/** Voice state update handlers (for voice adapters) */
|
|
50
|
+
voiceStateHandlers = new Map();
|
|
51
|
+
voiceServerHandlers = new Map();
|
|
52
|
+
constructor(options) {
|
|
53
|
+
super();
|
|
54
|
+
this.options = options;
|
|
55
|
+
this.gatewayUrl = options.gatewayUrl || 'ws://localhost:5003/ws/bot';
|
|
56
|
+
this.rest = new REST_1.REST(options.apiUrl);
|
|
57
|
+
// Initialize voice adapter system
|
|
58
|
+
this.voice = {
|
|
59
|
+
adapters: new Map()
|
|
60
|
+
};
|
|
61
|
+
}
|
|
62
|
+
/**
|
|
63
|
+
* Calculate intents value
|
|
64
|
+
*/
|
|
65
|
+
getIntentsValue() {
|
|
66
|
+
if (typeof this.options.intents === 'number') {
|
|
67
|
+
return this.options.intents;
|
|
68
|
+
}
|
|
69
|
+
return this.options.intents.reduce((acc, intent) => acc | intent, 0);
|
|
70
|
+
}
|
|
71
|
+
/**
|
|
72
|
+
* Login to the gateway
|
|
73
|
+
*/
|
|
74
|
+
async login(token) {
|
|
75
|
+
this.token = token.replace(/^Bot\s+/i, '');
|
|
76
|
+
this.rest.setToken(this.token);
|
|
77
|
+
return new Promise((resolve, reject) => {
|
|
78
|
+
this.connect();
|
|
79
|
+
// Wait for ready event
|
|
80
|
+
const timeout = setTimeout(() => {
|
|
81
|
+
reject(new Error('Login timeout'));
|
|
82
|
+
}, 30000);
|
|
83
|
+
this.once('ready', () => {
|
|
84
|
+
clearTimeout(timeout);
|
|
85
|
+
resolve(this.token);
|
|
86
|
+
});
|
|
87
|
+
this.once('error', (error) => {
|
|
88
|
+
clearTimeout(timeout);
|
|
89
|
+
reject(error);
|
|
90
|
+
});
|
|
91
|
+
});
|
|
92
|
+
}
|
|
93
|
+
/**
|
|
94
|
+
* Connect to the gateway
|
|
95
|
+
*/
|
|
96
|
+
connect() {
|
|
97
|
+
this.ws = new ws_1.default(this.gatewayUrl);
|
|
98
|
+
this.ws.on('open', () => {
|
|
99
|
+
this.emit('debug', 'WebSocket connection opened');
|
|
100
|
+
});
|
|
101
|
+
this.ws.on('message', (data) => {
|
|
102
|
+
this.handleMessage(data.toString());
|
|
103
|
+
});
|
|
104
|
+
this.ws.on('close', (code, reason) => {
|
|
105
|
+
this.emit('debug', `WebSocket closed: ${code} - ${reason}`);
|
|
106
|
+
this.cleanup();
|
|
107
|
+
// Reconnect on certain close codes
|
|
108
|
+
if (code !== 1000 && code !== 4004) {
|
|
109
|
+
setTimeout(() => this.connect(), 5000);
|
|
110
|
+
}
|
|
111
|
+
});
|
|
112
|
+
this.ws.on('error', (error) => {
|
|
113
|
+
this.emit('error', error);
|
|
114
|
+
});
|
|
115
|
+
}
|
|
116
|
+
/**
|
|
117
|
+
* Handle incoming gateway message
|
|
118
|
+
*/
|
|
119
|
+
handleMessage(data) {
|
|
120
|
+
// Handle multiple messages in one frame
|
|
121
|
+
const messages = data.split('\n').filter(m => m.trim());
|
|
122
|
+
for (const msg of messages) {
|
|
123
|
+
try {
|
|
124
|
+
const payload = JSON.parse(msg);
|
|
125
|
+
this.handlePayload(payload);
|
|
126
|
+
}
|
|
127
|
+
catch (e) {
|
|
128
|
+
this.emit('debug', `Failed to parse message: ${msg}`);
|
|
129
|
+
}
|
|
130
|
+
}
|
|
131
|
+
}
|
|
132
|
+
/**
|
|
133
|
+
* Handle gateway payload
|
|
134
|
+
*/
|
|
135
|
+
handlePayload(payload) {
|
|
136
|
+
if (payload.s) {
|
|
137
|
+
this.sequence = payload.s;
|
|
138
|
+
}
|
|
139
|
+
switch (payload.op) {
|
|
140
|
+
case enums_1.GatewayOpcodes.Hello:
|
|
141
|
+
this.handleHello(payload.d);
|
|
142
|
+
break;
|
|
143
|
+
case enums_1.GatewayOpcodes.Dispatch:
|
|
144
|
+
this.handleDispatch(payload.t, payload.d);
|
|
145
|
+
break;
|
|
146
|
+
case enums_1.GatewayOpcodes.HeartbeatAck:
|
|
147
|
+
this.emit('debug', 'Heartbeat acknowledged');
|
|
148
|
+
break;
|
|
149
|
+
case enums_1.GatewayOpcodes.InvalidSession:
|
|
150
|
+
this.emit('debug', 'Invalid session, re-identifying...');
|
|
151
|
+
setTimeout(() => this.identify(), 5000);
|
|
152
|
+
break;
|
|
153
|
+
case enums_1.GatewayOpcodes.Reconnect:
|
|
154
|
+
this.emit('debug', 'Reconnect requested');
|
|
155
|
+
this.ws?.close();
|
|
156
|
+
setTimeout(() => this.connect(), 1000);
|
|
157
|
+
break;
|
|
158
|
+
}
|
|
159
|
+
}
|
|
160
|
+
/**
|
|
161
|
+
* Handle Hello payload
|
|
162
|
+
*/
|
|
163
|
+
handleHello(data) {
|
|
164
|
+
this.emit('debug', `Received Hello, heartbeat interval: ${data.heartbeat_interval}ms`);
|
|
165
|
+
this.startHeartbeat(data.heartbeat_interval);
|
|
166
|
+
this.identify();
|
|
167
|
+
}
|
|
168
|
+
/**
|
|
169
|
+
* Handle Dispatch events
|
|
170
|
+
*/
|
|
171
|
+
handleDispatch(eventType, data) {
|
|
172
|
+
this.emit('debug', `Dispatch: ${eventType}`);
|
|
173
|
+
switch (eventType) {
|
|
174
|
+
case 'READY':
|
|
175
|
+
this.handleReady(data);
|
|
176
|
+
break;
|
|
177
|
+
case 'GUILD_CREATE':
|
|
178
|
+
this.handleGuildCreate(data);
|
|
179
|
+
break;
|
|
180
|
+
case 'GUILD_UPDATE':
|
|
181
|
+
this.handleGuildUpdate(data);
|
|
182
|
+
break;
|
|
183
|
+
case 'GUILD_DELETE':
|
|
184
|
+
this.handleGuildDelete(data);
|
|
185
|
+
break;
|
|
186
|
+
case 'MESSAGE_CREATE':
|
|
187
|
+
this.handleMessageCreate(data);
|
|
188
|
+
break;
|
|
189
|
+
case 'MESSAGE_UPDATE':
|
|
190
|
+
this.emit('messageUpdate', data);
|
|
191
|
+
break;
|
|
192
|
+
case 'MESSAGE_DELETE':
|
|
193
|
+
this.emit('messageDelete', data);
|
|
194
|
+
break;
|
|
195
|
+
case 'MESSAGE_DELETE_BULK':
|
|
196
|
+
this.emit('messageDeleteBulk', data);
|
|
197
|
+
break;
|
|
198
|
+
case 'CHANNEL_CREATE':
|
|
199
|
+
this.emit('channelCreate', data);
|
|
200
|
+
break;
|
|
201
|
+
case 'CHANNEL_UPDATE':
|
|
202
|
+
this.emit('channelUpdate', data);
|
|
203
|
+
break;
|
|
204
|
+
case 'CHANNEL_DELETE':
|
|
205
|
+
this.emit('channelDelete', data);
|
|
206
|
+
break;
|
|
207
|
+
case 'GUILD_MEMBER_ADD':
|
|
208
|
+
this.emit('guildMemberAdd', data);
|
|
209
|
+
break;
|
|
210
|
+
case 'GUILD_MEMBER_UPDATE':
|
|
211
|
+
this.emit('guildMemberUpdate', data);
|
|
212
|
+
break;
|
|
213
|
+
case 'GUILD_MEMBER_REMOVE':
|
|
214
|
+
this.emit('guildMemberRemove', data);
|
|
215
|
+
break;
|
|
216
|
+
case 'GUILD_ROLE_CREATE':
|
|
217
|
+
this.emit('roleCreate', data);
|
|
218
|
+
break;
|
|
219
|
+
case 'GUILD_ROLE_UPDATE':
|
|
220
|
+
this.emit('roleUpdate', data);
|
|
221
|
+
break;
|
|
222
|
+
case 'GUILD_ROLE_DELETE':
|
|
223
|
+
this.emit('roleDelete', data);
|
|
224
|
+
break;
|
|
225
|
+
case 'GUILD_BAN_ADD':
|
|
226
|
+
this.emit('guildBanAdd', data);
|
|
227
|
+
break;
|
|
228
|
+
case 'GUILD_BAN_REMOVE':
|
|
229
|
+
this.emit('guildBanRemove', data);
|
|
230
|
+
break;
|
|
231
|
+
case 'INVITE_CREATE':
|
|
232
|
+
this.emit('inviteCreate', data);
|
|
233
|
+
break;
|
|
234
|
+
case 'INVITE_DELETE':
|
|
235
|
+
this.emit('inviteDelete', data);
|
|
236
|
+
break;
|
|
237
|
+
case 'THREAD_CREATE':
|
|
238
|
+
this.emit('threadCreate', data);
|
|
239
|
+
break;
|
|
240
|
+
case 'THREAD_UPDATE':
|
|
241
|
+
this.emit('threadUpdate', data);
|
|
242
|
+
break;
|
|
243
|
+
case 'THREAD_DELETE':
|
|
244
|
+
this.emit('threadDelete', data);
|
|
245
|
+
break;
|
|
246
|
+
case 'TYPING_START':
|
|
247
|
+
this.emit('typingStart', data);
|
|
248
|
+
break;
|
|
249
|
+
case 'PRESENCE_UPDATE':
|
|
250
|
+
this.emit('presenceUpdate', data);
|
|
251
|
+
break;
|
|
252
|
+
case 'INTERACTION_CREATE':
|
|
253
|
+
this.handleInteractionCreate(data);
|
|
254
|
+
break;
|
|
255
|
+
case 'VOICE_STATE_UPDATE':
|
|
256
|
+
this.handleVoiceStateUpdate(data);
|
|
257
|
+
break;
|
|
258
|
+
case 'VOICE_SERVER_UPDATE':
|
|
259
|
+
this.handleVoiceServerUpdate(data);
|
|
260
|
+
break;
|
|
261
|
+
default:
|
|
262
|
+
// Emit raw event for unhandled types
|
|
263
|
+
this.emit('raw', { t: eventType, d: data });
|
|
264
|
+
}
|
|
265
|
+
}
|
|
266
|
+
/**
|
|
267
|
+
* Handle Ready event
|
|
268
|
+
*/
|
|
269
|
+
handleReady(data) {
|
|
270
|
+
this.sessionId = data.session_id;
|
|
271
|
+
this.user = new User_1.User(data.user);
|
|
272
|
+
// Handle both string and number application IDs
|
|
273
|
+
this.applicationId = data.application?.id ? String(data.application.id) : null;
|
|
274
|
+
if (this.applicationId) {
|
|
275
|
+
this.rest.setApplicationId(this.applicationId);
|
|
276
|
+
}
|
|
277
|
+
// Cache guilds (as unavailable initially)
|
|
278
|
+
if (data.guilds) {
|
|
279
|
+
for (const guild of data.guilds) {
|
|
280
|
+
this.guilds.set(String(guild.id), new Guild_1.Guild(this, guild));
|
|
281
|
+
}
|
|
282
|
+
}
|
|
283
|
+
// Setup voice adapters for each guild
|
|
284
|
+
this.setupVoiceAdapters();
|
|
285
|
+
console.log(`✅ Bot hazır! User: ${this.user.username} (${this.user.id}), App: ${this.applicationId}`);
|
|
286
|
+
this.emit('ready', this);
|
|
287
|
+
}
|
|
288
|
+
/**
|
|
289
|
+
* Setup voice adapters for all guilds
|
|
290
|
+
*/
|
|
291
|
+
setupVoiceAdapters() {
|
|
292
|
+
for (const [guildId] of this.guilds) {
|
|
293
|
+
this.createVoiceAdapter(guildId);
|
|
294
|
+
}
|
|
295
|
+
}
|
|
296
|
+
/**
|
|
297
|
+
* Create a voice adapter for a guild
|
|
298
|
+
*/
|
|
299
|
+
createVoiceAdapter(guildId) {
|
|
300
|
+
const adapter = (methods) => {
|
|
301
|
+
// Store handlers for this guild
|
|
302
|
+
this.voiceStateHandlers.set(guildId, methods.onVoiceStateUpdate);
|
|
303
|
+
this.voiceServerHandlers.set(guildId, methods.onVoiceServerUpdate);
|
|
304
|
+
return {
|
|
305
|
+
sendPayload: (payload) => {
|
|
306
|
+
if (this.ws?.readyState === ws_1.default.OPEN) {
|
|
307
|
+
this.ws.send(JSON.stringify(payload));
|
|
308
|
+
return true;
|
|
309
|
+
}
|
|
310
|
+
return false;
|
|
311
|
+
},
|
|
312
|
+
destroy: () => {
|
|
313
|
+
this.voiceStateHandlers.delete(guildId);
|
|
314
|
+
this.voiceServerHandlers.delete(guildId);
|
|
315
|
+
}
|
|
316
|
+
};
|
|
317
|
+
};
|
|
318
|
+
this.voice.adapters.set(guildId, adapter);
|
|
319
|
+
}
|
|
320
|
+
/**
|
|
321
|
+
* Handle Guild Create event
|
|
322
|
+
*/
|
|
323
|
+
handleGuildCreate(data) {
|
|
324
|
+
let guild = this.guilds.get(data.id);
|
|
325
|
+
if (guild) {
|
|
326
|
+
guild._patch(data);
|
|
327
|
+
}
|
|
328
|
+
else {
|
|
329
|
+
guild = new Guild_1.Guild(this, data);
|
|
330
|
+
this.guilds.set(data.id, guild);
|
|
331
|
+
this.createVoiceAdapter(data.id);
|
|
332
|
+
}
|
|
333
|
+
this.emit('guildCreate', guild);
|
|
334
|
+
}
|
|
335
|
+
/**
|
|
336
|
+
* Handle Guild Update event
|
|
337
|
+
*/
|
|
338
|
+
handleGuildUpdate(data) {
|
|
339
|
+
const guild = this.guilds.get(data.id);
|
|
340
|
+
if (guild) {
|
|
341
|
+
guild._patch(data);
|
|
342
|
+
this.emit('guildUpdate', guild);
|
|
343
|
+
}
|
|
344
|
+
}
|
|
345
|
+
/**
|
|
346
|
+
* Handle Guild Delete event
|
|
347
|
+
*/
|
|
348
|
+
handleGuildDelete(data) {
|
|
349
|
+
const guild = this.guilds.get(data.id);
|
|
350
|
+
if (guild) {
|
|
351
|
+
this.guilds.delete(data.id);
|
|
352
|
+
this.voice.adapters.delete(data.id);
|
|
353
|
+
this.emit('guildDelete', guild);
|
|
354
|
+
}
|
|
355
|
+
}
|
|
356
|
+
/**
|
|
357
|
+
* Handle Message Create event
|
|
358
|
+
*/
|
|
359
|
+
handleMessageCreate(data) {
|
|
360
|
+
// Backend sends user_id separately, map it to author.id for compatibility
|
|
361
|
+
if (data.user_id && data.author && !data.author.id) {
|
|
362
|
+
data.author.id = data.user_id;
|
|
363
|
+
}
|
|
364
|
+
// Cache the author
|
|
365
|
+
if (data.author) {
|
|
366
|
+
const user = new User_1.User(data.author);
|
|
367
|
+
this.users.set(user.id, user);
|
|
368
|
+
// Also cache in REST for mention resolution
|
|
369
|
+
this.rest.cacheUser(data.author);
|
|
370
|
+
}
|
|
371
|
+
const message = new Message_1.Message(this, data);
|
|
372
|
+
this.emit('messageCreate', message);
|
|
373
|
+
}
|
|
374
|
+
/**
|
|
375
|
+
* Handle Interaction Create event
|
|
376
|
+
*/
|
|
377
|
+
handleInteractionCreate(data) {
|
|
378
|
+
console.log('[DEBUG] handleInteractionCreate called with:', JSON.stringify(data, null, 2));
|
|
379
|
+
// Cache the user
|
|
380
|
+
const userData = data.member?.user || data.user;
|
|
381
|
+
if (userData) {
|
|
382
|
+
const user = new User_1.User(userData);
|
|
383
|
+
this.users.set(user.id, user);
|
|
384
|
+
this.rest.cacheUser(userData);
|
|
385
|
+
}
|
|
386
|
+
const interaction = (0, Interaction_1.createInteraction)(this, data);
|
|
387
|
+
console.log('[DEBUG] Created interaction type:', interaction.constructor.name, 'customId:', interaction.customId);
|
|
388
|
+
this.emit('interactionCreate', interaction);
|
|
389
|
+
}
|
|
390
|
+
/**
|
|
391
|
+
* Handle Voice State Update event
|
|
392
|
+
*/
|
|
393
|
+
handleVoiceStateUpdate(data) {
|
|
394
|
+
const guildId = data.guild_id;
|
|
395
|
+
// Forward to voice adapter if exists
|
|
396
|
+
const handler = this.voiceStateHandlers.get(guildId);
|
|
397
|
+
if (handler) {
|
|
398
|
+
handler(data);
|
|
399
|
+
}
|
|
400
|
+
this.emit('voiceStateUpdate', data);
|
|
401
|
+
}
|
|
402
|
+
/**
|
|
403
|
+
* Handle Voice Server Update event
|
|
404
|
+
*/
|
|
405
|
+
handleVoiceServerUpdate(data) {
|
|
406
|
+
const guildId = data.guild_id;
|
|
407
|
+
// Forward to voice adapter if exists
|
|
408
|
+
const handler = this.voiceServerHandlers.get(guildId);
|
|
409
|
+
if (handler) {
|
|
410
|
+
handler({
|
|
411
|
+
token: data.token,
|
|
412
|
+
endpoint: data.endpoint,
|
|
413
|
+
room: data.room
|
|
414
|
+
});
|
|
415
|
+
}
|
|
416
|
+
this.emit('voiceServerUpdate', data);
|
|
417
|
+
}
|
|
418
|
+
/**
|
|
419
|
+
* Send Identify payload
|
|
420
|
+
*/
|
|
421
|
+
identify() {
|
|
422
|
+
const payload = {
|
|
423
|
+
op: enums_1.GatewayOpcodes.Identify,
|
|
424
|
+
d: {
|
|
425
|
+
token: `Bot ${this.token}`,
|
|
426
|
+
intents: this.getIntentsValue(),
|
|
427
|
+
shard: this.options.shards || [0, 1]
|
|
428
|
+
}
|
|
429
|
+
};
|
|
430
|
+
this.send(payload);
|
|
431
|
+
}
|
|
432
|
+
/**
|
|
433
|
+
* Start heartbeat
|
|
434
|
+
*/
|
|
435
|
+
startHeartbeat(interval) {
|
|
436
|
+
this.heartbeatInterval = setInterval(() => {
|
|
437
|
+
this.send({
|
|
438
|
+
op: enums_1.GatewayOpcodes.Heartbeat,
|
|
439
|
+
d: this.sequence
|
|
440
|
+
});
|
|
441
|
+
}, interval);
|
|
442
|
+
}
|
|
443
|
+
/**
|
|
444
|
+
* Send payload to gateway
|
|
445
|
+
*/
|
|
446
|
+
send(payload) {
|
|
447
|
+
if (this.ws?.readyState === ws_1.default.OPEN) {
|
|
448
|
+
this.ws.send(JSON.stringify(payload));
|
|
449
|
+
}
|
|
450
|
+
}
|
|
451
|
+
/**
|
|
452
|
+
* Cleanup on disconnect
|
|
453
|
+
*/
|
|
454
|
+
cleanup() {
|
|
455
|
+
if (this.heartbeatInterval) {
|
|
456
|
+
clearInterval(this.heartbeatInterval);
|
|
457
|
+
this.heartbeatInterval = null;
|
|
458
|
+
}
|
|
459
|
+
}
|
|
460
|
+
/**
|
|
461
|
+
* Destroy the client
|
|
462
|
+
*/
|
|
463
|
+
destroy() {
|
|
464
|
+
this.cleanup();
|
|
465
|
+
this.ws?.close(1000);
|
|
466
|
+
this.ws = null;
|
|
467
|
+
this.removeAllListeners();
|
|
468
|
+
}
|
|
469
|
+
}
|
|
470
|
+
exports.Client = Client;
|
|
471
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Client.js","sourceRoot":"","sources":["../src/Client.ts"],"names":[],"mappings":";;;;;;AAAA,mCAAsC;AACtC,4CAA2B;AAY3B,mCAA4D;AA+jBnD,kGA/jBgB,yBAAiB,OA+jBhB;AA9jB1B,wDAAqD;AACrD,4CAAyC;AACzC,8CAA2C;AAC3C,kDAA+C;AAC/C,0DAA0E;AAE1E,sCAAmC;AAcnC;;GAEG;AACH,MAAa,MAAO,SAAQ,qBAAY;IACtC,qBAAqB;IACL,OAAO,CAAgB;IAEvC,sBAAsB;IACN,IAAI,CAAO;IAE3B,mBAAmB;IACZ,IAAI,GAAgB,IAAI,CAAC;IAEhC,qBAAqB;IACd,aAAa,GAAkB,IAAI,CAAC;IAE3C,oBAAoB;IACb,MAAM,GAA8B,IAAI,uBAAU,EAAE,CAAC;IAE5D,sBAAsB;IACf,QAAQ,GAAoC,IAAI,uBAAU,EAAE,CAAC;IAEpE,mBAAmB;IACZ,KAAK,GAA6B,IAAI,uBAAU,EAAE,CAAC;IAE1D,+BAA+B;IACxB,KAAK,CAEV;IAEF,2BAA2B;IACnB,EAAE,GAAqB,IAAI,CAAC;IAEpC,gBAAgB;IACR,KAAK,GAAW,EAAE,CAAC;IAE3B,iBAAiB;IACT,SAAS,GAAkB,IAAI,CAAC;IAExC,sBAAsB;IACd,QAAQ,GAAkB,IAAI,CAAC;IAEvC,yBAAyB;IACjB,iBAAiB,GAA0B,IAAI,CAAC;IAExD,kBAAkB;IACV,UAAU,CAAS;IAE3B,uDAAuD;IAC/C,kBAAkB,GAAqC,IAAI,GAAG,EAAE,CAAC;IACjE,mBAAmB,GAAqC,IAAI,GAAG,EAAE,CAAC;IAE1E,YAAY,OAAsB;QAChC,KAAK,EAAE,CAAC;QACR,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;QACvB,IAAI,CAAC,UAAU,GAAG,OAAO,CAAC,UAAU,IAAI,4BAA4B,CAAC;QACrE,IAAI,CAAC,IAAI,GAAG,IAAI,WAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;QAErC,kCAAkC;QAClC,IAAI,CAAC,KAAK,GAAG;YACX,QAAQ,EAAE,IAAI,GAAG,EAAE;SACpB,CAAC;IACJ,CAAC;IAED;;OAEG;IACK,eAAe;QACrB,IAAI,OAAO,IAAI,CAAC,OAAO,CAAC,OAAO,KAAK,QAAQ,EAAE,CAAC;YAC7C,OAAO,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC;QAC9B,CAAC;QACD,OAAO,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,MAAM,EAAE,EAAE,CAAC,GAAG,GAAG,MAAM,EAAE,CAAC,CAAC,CAAC;IACvE,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,KAAK,CAAC,KAAa;QACvB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC,OAAO,CAAC,UAAU,EAAE,EAAE,CAAC,CAAC;QAC3C,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAE/B,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YACrC,IAAI,CAAC,OAAO,EAAE,CAAC;YAEf,uBAAuB;YACvB,MAAM,OAAO,GAAG,UAAU,CAAC,GAAG,EAAE;gBAC9B,MAAM,CAAC,IAAI,KAAK,CAAC,eAAe,CAAC,CAAC,CAAC;YACrC,CAAC,EAAE,KAAK,CAAC,CAAC;YAEV,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,GAAG,EAAE;gBACtB,YAAY,CAAC,OAAO,CAAC,CAAC;gBACtB,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YACtB,CAAC,CAAC,CAAC;YAEH,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,KAAK,EAAE,EAAE;gBAC3B,YAAY,CAAC,OAAO,CAAC,CAAC;gBACtB,MAAM,CAAC,KAAK,CAAC,CAAC;YAChB,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACL,CAAC;IAED;;OAEG;IACK,OAAO;QACb,IAAI,CAAC,EAAE,GAAG,IAAI,YAAS,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QAEzC,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,MAAM,EAAE,GAAG,EAAE;YACtB,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,6BAA6B,CAAC,CAAC;QACpD,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,SAAS,EAAE,CAAC,IAAI,EAAE,EAAE;YAC7B,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;QACtC,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,OAAO,EAAE,CAAC,IAAI,EAAE,MAAM,EAAE,EAAE;YACnC,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,qBAAqB,IAAI,MAAM,MAAM,EAAE,CAAC,CAAC;YAC5D,IAAI,CAAC,OAAO,EAAE,CAAC;YAEf,mCAAmC;YACnC,IAAI,IAAI,KAAK,IAAI,IAAI,IAAI,KAAK,IAAI,EAAE,CAAC;gBACnC,UAAU,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,OAAO,EAAE,EAAE,IAAI,CAAC,CAAC;YACzC,CAAC;QACH,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,OAAO,EAAE,CAAC,KAAK,EAAE,EAAE;YAC5B,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC;QAC5B,CAAC,CAAC,CAAC;IACL,CAAC;IAED;;OAEG;IACK,aAAa,CAAC,IAAY;QAChC,wCAAwC;QACxC,MAAM,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC;QAExD,KAAK,MAAM,GAAG,IAAI,QAAQ,EAAE,CAAC;YAC3B,IAAI,CAAC;gBACH,MAAM,OAAO,GAAmB,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;gBAChD,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC;YAC9B,CAAC;YAAC,OAAO,CAAC,EAAE,CAAC;gBACX,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,4BAA4B,GAAG,EAAE,CAAC,CAAC;YACxD,CAAC;QACH,CAAC;IACH,CAAC;IAED;;OAEG;IACK,aAAa,CAAC,OAAuB;QAC3C,IAAI,OAAO,CAAC,CAAC,EAAE,CAAC;YACd,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAC,CAAC,CAAC;QAC5B,CAAC;QAED,QAAQ,OAAO,CAAC,EAAE,EAAE,CAAC;YACnB,KAAK,sBAAc,CAAC,KAAK;gBACvB,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;gBAC5B,MAAM;YAER,KAAK,sBAAc,CAAC,QAAQ;gBAC1B,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,CAAE,EAAE,OAAO,CAAC,CAAC,CAAC,CAAC;gBAC3C,MAAM;YAER,KAAK,sBAAc,CAAC,YAAY;gBAC9B,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,wBAAwB,CAAC,CAAC;gBAC7C,MAAM;YAER,KAAK,sBAAc,CAAC,cAAc;gBAChC,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,oCAAoC,CAAC,CAAC;gBACzD,UAAU,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,QAAQ,EAAE,EAAE,IAAI,CAAC,CAAC;gBACxC,MAAM;YAER,KAAK,sBAAc,CAAC,SAAS;gBAC3B,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,qBAAqB,CAAC,CAAC;gBAC1C,IAAI,CAAC,EAAE,EAAE,KAAK,EAAE,CAAC;gBACjB,UAAU,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,OAAO,EAAE,EAAE,IAAI,CAAC,CAAC;gBACvC,MAAM;QACV,CAAC;IACH,CAAC;IAED;;OAEG;IACK,WAAW,CAAC,IAAoC;QACtD,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,uCAAuC,IAAI,CAAC,kBAAkB,IAAI,CAAC,CAAC;QACvF,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC;QAC7C,IAAI,CAAC,QAAQ,EAAE,CAAC;IAClB,CAAC;IAED;;OAEG;IACK,cAAc,CAAC,SAAiB,EAAE,IAAS;QACjD,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,aAAa,SAAS,EAAE,CAAC,CAAC;QAE7C,QAAQ,SAAS,EAAE,CAAC;YAClB,KAAK,OAAO;gBACV,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;gBACvB,MAAM;YAER,KAAK,cAAc;gBACjB,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC;gBAC7B,MAAM;YAER,KAAK,cAAc;gBACjB,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC;gBAC7B,MAAM;YAER,KAAK,cAAc;gBACjB,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC;gBAC7B,MAAM;YAER,KAAK,gBAAgB;gBACnB,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,CAAC;gBAC/B,MAAM;YAER,KAAK,gBAAgB;gBACnB,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE,IAAI,CAAC,CAAC;gBACjC,MAAM;YAER,KAAK,gBAAgB;gBACnB,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE,IAAI,CAAC,CAAC;gBACjC,MAAM;YAER,KAAK,qBAAqB;gBACxB,IAAI,CAAC,IAAI,CAAC,mBAAmB,EAAE,IAAI,CAAC,CAAC;gBACrC,MAAM;YAER,KAAK,gBAAgB;gBACnB,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE,IAAI,CAAC,CAAC;gBACjC,MAAM;YAER,KAAK,gBAAgB;gBACnB,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE,IAAI,CAAC,CAAC;gBACjC,MAAM;YAER,KAAK,gBAAgB;gBACnB,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE,IAAI,CAAC,CAAC;gBACjC,MAAM;YAER,KAAK,kBAAkB;gBACrB,IAAI,CAAC,IAAI,CAAC,gBAAgB,EAAE,IAAI,CAAC,CAAC;gBAClC,MAAM;YAER,KAAK,qBAAqB;gBACxB,IAAI,CAAC,IAAI,CAAC,mBAAmB,EAAE,IAAI,CAAC,CAAC;gBACrC,MAAM;YAER,KAAK,qBAAqB;gBACxB,IAAI,CAAC,IAAI,CAAC,mBAAmB,EAAE,IAAI,CAAC,CAAC;gBACrC,MAAM;YAER,KAAK,mBAAmB;gBACtB,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,IAAI,CAAC,CAAC;gBAC9B,MAAM;YAER,KAAK,mBAAmB;gBACtB,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,IAAI,CAAC,CAAC;gBAC9B,MAAM;YAER,KAAK,mBAAmB;gBACtB,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,IAAI,CAAC,CAAC;gBAC9B,MAAM;YAER,KAAK,eAAe;gBAClB,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,IAAI,CAAC,CAAC;gBAC/B,MAAM;YAER,KAAK,kBAAkB;gBACrB,IAAI,CAAC,IAAI,CAAC,gBAAgB,EAAE,IAAI,CAAC,CAAC;gBAClC,MAAM;YAER,KAAK,eAAe;gBAClB,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE,IAAI,CAAC,CAAC;gBAChC,MAAM;YAER,KAAK,eAAe;gBAClB,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE,IAAI,CAAC,CAAC;gBAChC,MAAM;YAER,KAAK,eAAe;gBAClB,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE,IAAI,CAAC,CAAC;gBAChC,MAAM;YAER,KAAK,eAAe;gBAClB,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE,IAAI,CAAC,CAAC;gBAChC,MAAM;YAER,KAAK,eAAe;gBAClB,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE,IAAI,CAAC,CAAC;gBAChC,MAAM;YAER,KAAK,cAAc;gBACjB,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,IAAI,CAAC,CAAC;gBAC/B,MAAM;YAER,KAAK,iBAAiB;gBACpB,IAAI,CAAC,IAAI,CAAC,gBAAgB,EAAE,IAAI,CAAC,CAAC;gBAClC,MAAM;YAER,KAAK,oBAAoB;gBACvB,IAAI,CAAC,uBAAuB,CAAC,IAAI,CAAC,CAAC;gBACnC,MAAM;YAER,KAAK,oBAAoB;gBACvB,IAAI,CAAC,sBAAsB,CAAC,IAAI,CAAC,CAAC;gBAClC,MAAM;YAER,KAAK,qBAAqB;gBACxB,IAAI,CAAC,uBAAuB,CAAC,IAAI,CAAC,CAAC;gBACnC,MAAM;YAER;gBACE,qCAAqC;gBACrC,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,EAAE,CAAC,EAAE,SAAS,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,CAAC;QAChD,CAAC;IACH,CAAC;IAED;;OAEG;IACK,WAAW,CAAC,IAAoB;QACtC,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,UAAU,CAAC;QACjC,IAAI,CAAC,IAAI,GAAG,IAAI,WAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAChC,gDAAgD;QAChD,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,WAAW,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;QAC/E,IAAI,IAAI,CAAC,aAAa,EAAE,CAAC;YACvB,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;QACjD,CAAC;QAED,0CAA0C;QAC1C,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;YAChB,KAAK,MAAM,KAAK,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;gBAChC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC,EAAE,IAAI,aAAK,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC,CAAC;YAC5D,CAAC;QACH,CAAC;QAED,sCAAsC;QACtC,IAAI,CAAC,kBAAkB,EAAE,CAAC;QAE1B,OAAO,CAAC,GAAG,CAAC,sBAAsB,IAAI,CAAC,IAAI,CAAC,QAAQ,KAAK,IAAI,CAAC,IAAI,CAAC,EAAE,WAAW,IAAI,CAAC,aAAa,EAAE,CAAC,CAAC;QACtG,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;IAC3B,CAAC;IAED;;OAEG;IACK,kBAAkB;QACxB,KAAK,MAAM,CAAC,OAAO,CAAC,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;YACpC,IAAI,CAAC,kBAAkB,CAAC,OAAO,CAAC,CAAC;QACnC,CAAC;IACH,CAAC;IAED;;OAEG;IACK,kBAAkB,CAAC,OAAe;QACxC,MAAM,OAAO,GAAwB,CAAC,OAAO,EAAE,EAAE;YAC/C,gCAAgC;YAChC,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,OAAO,EAAE,OAAO,CAAC,kBAAkB,CAAC,CAAC;YACjE,IAAI,CAAC,mBAAmB,CAAC,GAAG,CAAC,OAAO,EAAE,OAAO,CAAC,mBAAmB,CAAC,CAAC;YAEnE,OAAO;gBACL,WAAW,EAAE,CAAC,OAAO,EAAE,EAAE;oBACvB,IAAI,IAAI,CAAC,EAAE,EAAE,UAAU,KAAK,YAAS,CAAC,IAAI,EAAE,CAAC;wBAC3C,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,CAAC;wBACtC,OAAO,IAAI,CAAC;oBACd,CAAC;oBACD,OAAO,KAAK,CAAC;gBACf,CAAC;gBACD,OAAO,EAAE,GAAG,EAAE;oBACZ,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;oBACxC,IAAI,CAAC,mBAAmB,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;gBAC3C,CAAC;aACF,CAAC;QACJ,CAAC,CAAC;QAEF,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,GAAG,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC;IAC5C,CAAC;IAED;;OAEG;IACK,iBAAiB,CAAC,IAAc;QACtC,IAAI,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QAErC,IAAI,KAAK,EAAE,CAAC;YACV,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;QACrB,CAAC;aAAM,CAAC;YACN,KAAK,GAAG,IAAI,aAAK,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;YAC9B,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,EAAE,KAAK,CAAC,CAAC;YAChC,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QACnC,CAAC;QAED,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,KAAK,CAAC,CAAC;IAClC,CAAC;IAED;;OAEG;IACK,iBAAiB,CAAC,IAAc;QACtC,MAAM,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QACvC,IAAI,KAAK,EAAE,CAAC;YACV,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;YACnB,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,KAAK,CAAC,CAAC;QAClC,CAAC;IACH,CAAC;IAED;;OAEG;IACK,iBAAiB,CAAC,IAAoB;QAC5C,MAAM,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QACvC,IAAI,KAAK,EAAE,CAAC;YACV,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;YAC5B,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;YACpC,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,KAAK,CAAC,CAAC;QAClC,CAAC;IACH,CAAC;IAED;;OAEG;IACK,mBAAmB,CAAC,IAAgB;QAC1C,0EAA0E;QAC1E,IAAI,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,MAAM,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,EAAE,CAAC;YAClD,IAAI,CAAC,MAAc,CAAC,EAAE,GAAG,IAAI,CAAC,OAAO,CAAC;QACzC,CAAC;QAED,mBAAmB;QACnB,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;YAChB,MAAM,IAAI,GAAG,IAAI,WAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YACnC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,EAAE,IAAI,CAAC,CAAC;YAC9B,4CAA4C;YAC5C,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QACnC,CAAC;QAED,MAAM,OAAO,GAAG,IAAI,iBAAO,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;QACxC,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE,OAAO,CAAC,CAAC;IACtC,CAAC;IAED;;OAEG;IACK,uBAAuB,CAAC,IAAoB;QAClD,OAAO,CAAC,GAAG,CAAC,8CAA8C,EAAE,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;QAE3F,iBAAiB;QACjB,MAAM,QAAQ,GAAG,IAAI,CAAC,MAAM,EAAE,IAAI,IAAI,IAAI,CAAC,IAAI,CAAC;QAChD,IAAI,QAAQ,EAAE,CAAC;YACb,MAAM,IAAI,GAAG,IAAI,WAAI,CAAC,QAAQ,CAAC,CAAC;YAChC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,EAAE,IAAI,CAAC,CAAC;YAC9B,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC;QAChC,CAAC;QAED,MAAM,WAAW,GAAG,IAAA,+BAAiB,EAAC,IAAI,EAAE,IAAI,CAAC,CAAC;QAClD,OAAO,CAAC,GAAG,CAAC,mCAAmC,EAAE,WAAW,CAAC,WAAW,CAAC,IAAI,EAAE,WAAW,EAAG,WAAmB,CAAC,QAAQ,CAAC,CAAC;QAC3H,IAAI,CAAC,IAAI,CAAC,mBAAmB,EAAE,WAAW,CAAC,CAAC;IAC9C,CAAC;IAED;;OAEG;IACK,sBAAsB,CAAC,IAAS;QACtC,MAAM,OAAO,GAAG,IAAI,CAAC,QAAQ,CAAC;QAE9B,qCAAqC;QACrC,MAAM,OAAO,GAAG,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;QACrD,IAAI,OAAO,EAAE,CAAC;YACZ,OAAO,CAAC,IAAI,CAAC,CAAC;QAChB,CAAC;QAED,IAAI,CAAC,IAAI,CAAC,kBAAkB,EAAE,IAAI,CAAC,CAAC;IACtC,CAAC;IAED;;OAEG;IACK,uBAAuB,CAAC,IAA0B;QACxD,MAAM,OAAO,GAAG,IAAI,CAAC,QAAQ,CAAC;QAE9B,qCAAqC;QACrC,MAAM,OAAO,GAAG,IAAI,CAAC,mBAAmB,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;QACtD,IAAI,OAAO,EAAE,CAAC;YACZ,OAAO,CAAC;gBACN,KAAK,EAAE,IAAI,CAAC,KAAK;gBACjB,QAAQ,EAAE,IAAI,CAAC,QAAQ;gBACvB,IAAI,EAAE,IAAI,CAAC,IAAI;aAChB,CAAC,CAAC;QACL,CAAC;QAED,IAAI,CAAC,IAAI,CAAC,mBAAmB,EAAE,IAAI,CAAC,CAAC;IACvC,CAAC;IAED;;OAEG;IACK,QAAQ;QACd,MAAM,OAAO,GAAmB;YAC9B,EAAE,EAAE,sBAAc,CAAC,QAAQ;YAC3B,CAAC,EAAE;gBACD,KAAK,EAAE,OAAO,IAAI,CAAC,KAAK,EAAE;gBAC1B,OAAO,EAAE,IAAI,CAAC,eAAe,EAAE;gBAC/B,KAAK,EAAE,IAAI,CAAC,OAAO,CAAC,MAAM,IAAI,CAAC,CAAC,EAAE,CAAC,CAAC;aACrC;SACF,CAAC;QAEF,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IACrB,CAAC;IAED;;OAEG;IACK,cAAc,CAAC,QAAgB;QACrC,IAAI,CAAC,iBAAiB,GAAG,WAAW,CAAC,GAAG,EAAE;YACxC,IAAI,CAAC,IAAI,CAAC;gBACR,EAAE,EAAE,sBAAc,CAAC,SAAS;gBAC5B,CAAC,EAAE,IAAI,CAAC,QAAQ;aACjB,CAAC,CAAC;QACL,CAAC,EAAE,QAAQ,CAAC,CAAC;IACf,CAAC;IAED;;OAEG;IACK,IAAI,CAAC,OAAuB;QAClC,IAAI,IAAI,CAAC,EAAE,EAAE,UAAU,KAAK,YAAS,CAAC,IAAI,EAAE,CAAC;YAC3C,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,CAAC;QACxC,CAAC;IACH,CAAC;IAED;;OAEG;IACK,OAAO;QACb,IAAI,IAAI,CAAC,iBAAiB,EAAE,CAAC;YAC3B,aAAa,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;YACtC,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;QAChC,CAAC;IACH,CAAC;IAED;;OAEG;IACH,OAAO;QACL,IAAI,CAAC,OAAO,EAAE,CAAC;QACf,IAAI,CAAC,EAAE,EAAE,KAAK,CAAC,IAAI,CAAC,CAAC;QACrB,IAAI,CAAC,EAAE,GAAG,IAAI,CAAC;QACf,IAAI,CAAC,kBAAkB,EAAE,CAAC;IAC5B,CAAC;CACF;AApiBD,wBAoiBC","sourcesContent":["import { EventEmitter } from 'events';\r\nimport WebSocket from 'ws';\r\nimport { \r\n  ClientOptions, \r\n  GatewayPayload, \r\n  ReadyEventData,\r\n  APIGuild,\r\n  APIInteraction,\r\n  APIMessage,\r\n  APIVoiceServerUpdate,\r\n  APIChannel,\r\n  APIUser\r\n} from './types';\r\nimport { GatewayOpcodes, GatewayIntentBits } from './enums';\r\nimport { Collection } from './structures/Collection';\r\nimport { User } from './structures/User';\r\nimport { Guild } from './structures/Guild';\r\nimport { Message } from './structures/Message';\r\nimport { createInteraction, Interaction } from './structures/Interaction';\r\nimport { BaseChannel, createChannel } from './structures/Channel';\r\nimport { REST } from './rest/REST';\r\n\r\n/**\r\n * Voice adapter creator type for @jubbio/voice compatibility\r\n */\r\ntype VoiceAdapterCreator = (methods: {\r\n  onVoiceServerUpdate(data: any): void;\r\n  onVoiceStateUpdate(data: any): void;\r\n  destroy(): void;\r\n}) => {\r\n  sendPayload(payload: any): boolean;\r\n  destroy(): void;\r\n};\r\n\r\n/**\r\n * Main client class\r\n */\r\nexport class Client extends EventEmitter {\r\n  /** Client options */\r\n  public readonly options: ClientOptions;\r\n  \r\n  /** REST API client */\r\n  public readonly rest: REST;\r\n  \r\n  /** The bot user */\r\n  public user: User | null = null;\r\n  \r\n  /** Application ID */\r\n  public applicationId: string | null = null;\r\n  \r\n  /** Cached guilds */\r\n  public guilds: Collection<string, Guild> = new Collection();\r\n  \r\n  /** Cached channels */\r\n  public channels: Collection<string, BaseChannel> = new Collection();\r\n  \r\n  /** Cached users */\r\n  public users: Collection<string, User> = new Collection();\r\n  \r\n  /** Voice adapter management */\r\n  public voice: {\r\n    adapters: Map<string, VoiceAdapterCreator>;\r\n  };\r\n  \r\n  /** WebSocket connection */\r\n  private ws: WebSocket | null = null;\r\n  \r\n  /** Bot token */\r\n  private token: string = '';\r\n  \r\n  /** Session ID */\r\n  private sessionId: string | null = null;\r\n  \r\n  /** Sequence number */\r\n  private sequence: number | null = null;\r\n  \r\n  /** Heartbeat interval */\r\n  private heartbeatInterval: NodeJS.Timeout | null = null;\r\n  \r\n  /** Gateway URL */\r\n  private gatewayUrl: string;\r\n  \r\n  /** Voice state update handlers (for voice adapters) */\r\n  private voiceStateHandlers: Map<string, (data: any) => void> = new Map();\r\n  private voiceServerHandlers: Map<string, (data: any) => void> = new Map();\r\n\r\n  constructor(options: ClientOptions) {\r\n    super();\r\n    this.options = options;\r\n    this.gatewayUrl = options.gatewayUrl || 'ws://localhost:5003/ws/bot';\r\n    this.rest = new REST(options.apiUrl);\r\n    \r\n    // Initialize voice adapter system\r\n    this.voice = {\r\n      adapters: new Map()\r\n    };\r\n  }\r\n\r\n  /**\r\n   * Calculate intents value\r\n   */\r\n  private getIntentsValue(): number {\r\n    if (typeof this.options.intents === 'number') {\r\n      return this.options.intents;\r\n    }\r\n    return this.options.intents.reduce((acc, intent) => acc | intent, 0);\r\n  }\r\n\r\n  /**\r\n   * Login to the gateway\r\n   */\r\n  async login(token: string): Promise<string> {\r\n    this.token = token.replace(/^Bot\\s+/i, '');\r\n    this.rest.setToken(this.token);\r\n    \r\n    return new Promise((resolve, reject) => {\r\n      this.connect();\r\n      \r\n      // Wait for ready event\r\n      const timeout = setTimeout(() => {\r\n        reject(new Error('Login timeout'));\r\n      }, 30000);\r\n      \r\n      this.once('ready', () => {\r\n        clearTimeout(timeout);\r\n        resolve(this.token);\r\n      });\r\n      \r\n      this.once('error', (error) => {\r\n        clearTimeout(timeout);\r\n        reject(error);\r\n      });\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Connect to the gateway\r\n   */\r\n  private connect(): void {\r\n    this.ws = new WebSocket(this.gatewayUrl);\r\n    \r\n    this.ws.on('open', () => {\r\n      this.emit('debug', 'WebSocket connection opened');\r\n    });\r\n    \r\n    this.ws.on('message', (data) => {\r\n      this.handleMessage(data.toString());\r\n    });\r\n    \r\n    this.ws.on('close', (code, reason) => {\r\n      this.emit('debug', `WebSocket closed: ${code} - ${reason}`);\r\n      this.cleanup();\r\n      \r\n      // Reconnect on certain close codes\r\n      if (code !== 1000 && code !== 4004) {\r\n        setTimeout(() => this.connect(), 5000);\r\n      }\r\n    });\r\n    \r\n    this.ws.on('error', (error) => {\r\n      this.emit('error', error);\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Handle incoming gateway message\r\n   */\r\n  private handleMessage(data: string): void {\r\n    // Handle multiple messages in one frame\r\n    const messages = data.split('\\n').filter(m => m.trim());\r\n    \r\n    for (const msg of messages) {\r\n      try {\r\n        const payload: GatewayPayload = JSON.parse(msg);\r\n        this.handlePayload(payload);\r\n      } catch (e) {\r\n        this.emit('debug', `Failed to parse message: ${msg}`);\r\n      }\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Handle gateway payload\r\n   */\r\n  private handlePayload(payload: GatewayPayload): void {\r\n    if (payload.s) {\r\n      this.sequence = payload.s;\r\n    }\r\n\r\n    switch (payload.op) {\r\n      case GatewayOpcodes.Hello:\r\n        this.handleHello(payload.d);\r\n        break;\r\n        \r\n      case GatewayOpcodes.Dispatch:\r\n        this.handleDispatch(payload.t!, payload.d);\r\n        break;\r\n        \r\n      case GatewayOpcodes.HeartbeatAck:\r\n        this.emit('debug', 'Heartbeat acknowledged');\r\n        break;\r\n        \r\n      case GatewayOpcodes.InvalidSession:\r\n        this.emit('debug', 'Invalid session, re-identifying...');\r\n        setTimeout(() => this.identify(), 5000);\r\n        break;\r\n        \r\n      case GatewayOpcodes.Reconnect:\r\n        this.emit('debug', 'Reconnect requested');\r\n        this.ws?.close();\r\n        setTimeout(() => this.connect(), 1000);\r\n        break;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Handle Hello payload\r\n   */\r\n  private handleHello(data: { heartbeat_interval: number }): void {\r\n    this.emit('debug', `Received Hello, heartbeat interval: ${data.heartbeat_interval}ms`);\r\n    this.startHeartbeat(data.heartbeat_interval);\r\n    this.identify();\r\n  }\r\n\r\n  /**\r\n   * Handle Dispatch events\r\n   */\r\n  private handleDispatch(eventType: string, data: any): void {\r\n    this.emit('debug', `Dispatch: ${eventType}`);\r\n    \r\n    switch (eventType) {\r\n      case 'READY':\r\n        this.handleReady(data);\r\n        break;\r\n        \r\n      case 'GUILD_CREATE':\r\n        this.handleGuildCreate(data);\r\n        break;\r\n        \r\n      case 'GUILD_UPDATE':\r\n        this.handleGuildUpdate(data);\r\n        break;\r\n        \r\n      case 'GUILD_DELETE':\r\n        this.handleGuildDelete(data);\r\n        break;\r\n        \r\n      case 'MESSAGE_CREATE':\r\n        this.handleMessageCreate(data);\r\n        break;\r\n        \r\n      case 'MESSAGE_UPDATE':\r\n        this.emit('messageUpdate', data);\r\n        break;\r\n        \r\n      case 'MESSAGE_DELETE':\r\n        this.emit('messageDelete', data);\r\n        break;\r\n        \r\n      case 'MESSAGE_DELETE_BULK':\r\n        this.emit('messageDeleteBulk', data);\r\n        break;\r\n        \r\n      case 'CHANNEL_CREATE':\r\n        this.emit('channelCreate', data);\r\n        break;\r\n        \r\n      case 'CHANNEL_UPDATE':\r\n        this.emit('channelUpdate', data);\r\n        break;\r\n        \r\n      case 'CHANNEL_DELETE':\r\n        this.emit('channelDelete', data);\r\n        break;\r\n        \r\n      case 'GUILD_MEMBER_ADD':\r\n        this.emit('guildMemberAdd', data);\r\n        break;\r\n        \r\n      case 'GUILD_MEMBER_UPDATE':\r\n        this.emit('guildMemberUpdate', data);\r\n        break;\r\n        \r\n      case 'GUILD_MEMBER_REMOVE':\r\n        this.emit('guildMemberRemove', data);\r\n        break;\r\n        \r\n      case 'GUILD_ROLE_CREATE':\r\n        this.emit('roleCreate', data);\r\n        break;\r\n        \r\n      case 'GUILD_ROLE_UPDATE':\r\n        this.emit('roleUpdate', data);\r\n        break;\r\n        \r\n      case 'GUILD_ROLE_DELETE':\r\n        this.emit('roleDelete', data);\r\n        break;\r\n        \r\n      case 'GUILD_BAN_ADD':\r\n        this.emit('guildBanAdd', data);\r\n        break;\r\n        \r\n      case 'GUILD_BAN_REMOVE':\r\n        this.emit('guildBanRemove', data);\r\n        break;\r\n        \r\n      case 'INVITE_CREATE':\r\n        this.emit('inviteCreate', data);\r\n        break;\r\n        \r\n      case 'INVITE_DELETE':\r\n        this.emit('inviteDelete', data);\r\n        break;\r\n        \r\n      case 'THREAD_CREATE':\r\n        this.emit('threadCreate', data);\r\n        break;\r\n        \r\n      case 'THREAD_UPDATE':\r\n        this.emit('threadUpdate', data);\r\n        break;\r\n        \r\n      case 'THREAD_DELETE':\r\n        this.emit('threadDelete', data);\r\n        break;\r\n        \r\n      case 'TYPING_START':\r\n        this.emit('typingStart', data);\r\n        break;\r\n        \r\n      case 'PRESENCE_UPDATE':\r\n        this.emit('presenceUpdate', data);\r\n        break;\r\n        \r\n      case 'INTERACTION_CREATE':\r\n        this.handleInteractionCreate(data);\r\n        break;\r\n        \r\n      case 'VOICE_STATE_UPDATE':\r\n        this.handleVoiceStateUpdate(data);\r\n        break;\r\n        \r\n      case 'VOICE_SERVER_UPDATE':\r\n        this.handleVoiceServerUpdate(data);\r\n        break;\r\n        \r\n      default:\r\n        // Emit raw event for unhandled types\r\n        this.emit('raw', { t: eventType, d: data });\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Handle Ready event\r\n   */\r\n  private handleReady(data: ReadyEventData): void {\r\n    this.sessionId = data.session_id;\r\n    this.user = new User(data.user);\r\n    // Handle both string and number application IDs\r\n    this.applicationId = data.application?.id ? String(data.application.id) : null;\r\n    if (this.applicationId) {\r\n      this.rest.setApplicationId(this.applicationId);\r\n    }\r\n    \r\n    // Cache guilds (as unavailable initially)\r\n    if (data.guilds) {\r\n      for (const guild of data.guilds) {\r\n        this.guilds.set(String(guild.id), new Guild(this, guild));\r\n      }\r\n    }\r\n    \r\n    // Setup voice adapters for each guild\r\n    this.setupVoiceAdapters();\r\n    \r\n    console.log(`✅ Bot hazır! User: ${this.user.username} (${this.user.id}), App: ${this.applicationId}`);\r\n    this.emit('ready', this);\r\n  }\r\n\r\n  /**\r\n   * Setup voice adapters for all guilds\r\n   */\r\n  private setupVoiceAdapters(): void {\r\n    for (const [guildId] of this.guilds) {\r\n      this.createVoiceAdapter(guildId);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Create a voice adapter for a guild\r\n   */\r\n  private createVoiceAdapter(guildId: string): void {\r\n    const adapter: VoiceAdapterCreator = (methods) => {\r\n      // Store handlers for this guild\r\n      this.voiceStateHandlers.set(guildId, methods.onVoiceStateUpdate);\r\n      this.voiceServerHandlers.set(guildId, methods.onVoiceServerUpdate);\r\n      \r\n      return {\r\n        sendPayload: (payload) => {\r\n          if (this.ws?.readyState === WebSocket.OPEN) {\r\n            this.ws.send(JSON.stringify(payload));\r\n            return true;\r\n          }\r\n          return false;\r\n        },\r\n        destroy: () => {\r\n          this.voiceStateHandlers.delete(guildId);\r\n          this.voiceServerHandlers.delete(guildId);\r\n        }\r\n      };\r\n    };\r\n    \r\n    this.voice.adapters.set(guildId, adapter);\r\n  }\r\n\r\n  /**\r\n   * Handle Guild Create event\r\n   */\r\n  private handleGuildCreate(data: APIGuild): void {\r\n    let guild = this.guilds.get(data.id);\r\n    \r\n    if (guild) {\r\n      guild._patch(data);\r\n    } else {\r\n      guild = new Guild(this, data);\r\n      this.guilds.set(data.id, guild);\r\n      this.createVoiceAdapter(data.id);\r\n    }\r\n    \r\n    this.emit('guildCreate', guild);\r\n  }\r\n\r\n  /**\r\n   * Handle Guild Update event\r\n   */\r\n  private handleGuildUpdate(data: APIGuild): void {\r\n    const guild = this.guilds.get(data.id);\r\n    if (guild) {\r\n      guild._patch(data);\r\n      this.emit('guildUpdate', guild);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Handle Guild Delete event\r\n   */\r\n  private handleGuildDelete(data: { id: string }): void {\r\n    const guild = this.guilds.get(data.id);\r\n    if (guild) {\r\n      this.guilds.delete(data.id);\r\n      this.voice.adapters.delete(data.id);\r\n      this.emit('guildDelete', guild);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Handle Message Create event\r\n   */\r\n  private handleMessageCreate(data: APIMessage): void {\r\n    // Backend sends user_id separately, map it to author.id for compatibility\r\n    if (data.user_id && data.author && !data.author.id) {\r\n      (data.author as any).id = data.user_id;\r\n    }\r\n    \r\n    // Cache the author\r\n    if (data.author) {\r\n      const user = new User(data.author);\r\n      this.users.set(user.id, user);\r\n      // Also cache in REST for mention resolution\r\n      this.rest.cacheUser(data.author);\r\n    }\r\n    \r\n    const message = new Message(this, data);\r\n    this.emit('messageCreate', message);\r\n  }\r\n\r\n  /**\r\n   * Handle Interaction Create event\r\n   */\r\n  private handleInteractionCreate(data: APIInteraction): void {\r\n    console.log('[DEBUG] handleInteractionCreate called with:', JSON.stringify(data, null, 2));\r\n    \r\n    // Cache the user\r\n    const userData = data.member?.user || data.user;\r\n    if (userData) {\r\n      const user = new User(userData);\r\n      this.users.set(user.id, user);\r\n      this.rest.cacheUser(userData);\r\n    }\r\n    \r\n    const interaction = createInteraction(this, data);\r\n    console.log('[DEBUG] Created interaction type:', interaction.constructor.name, 'customId:', (interaction as any).customId);\r\n    this.emit('interactionCreate', interaction);\r\n  }\r\n\r\n  /**\r\n   * Handle Voice State Update event\r\n   */\r\n  private handleVoiceStateUpdate(data: any): void {\r\n    const guildId = data.guild_id;\r\n    \r\n    // Forward to voice adapter if exists\r\n    const handler = this.voiceStateHandlers.get(guildId);\r\n    if (handler) {\r\n      handler(data);\r\n    }\r\n    \r\n    this.emit('voiceStateUpdate', data);\r\n  }\r\n\r\n  /**\r\n   * Handle Voice Server Update event\r\n   */\r\n  private handleVoiceServerUpdate(data: APIVoiceServerUpdate): void {\r\n    const guildId = data.guild_id;\r\n    \r\n    // Forward to voice adapter if exists\r\n    const handler = this.voiceServerHandlers.get(guildId);\r\n    if (handler) {\r\n      handler({\r\n        token: data.token,\r\n        endpoint: data.endpoint,\r\n        room: data.room\r\n      });\r\n    }\r\n    \r\n    this.emit('voiceServerUpdate', data);\r\n  }\r\n\r\n  /**\r\n   * Send Identify payload\r\n   */\r\n  private identify(): void {\r\n    const payload: GatewayPayload = {\r\n      op: GatewayOpcodes.Identify,\r\n      d: {\r\n        token: `Bot ${this.token}`,\r\n        intents: this.getIntentsValue(),\r\n        shard: this.options.shards || [0, 1]\r\n      }\r\n    };\r\n    \r\n    this.send(payload);\r\n  }\r\n\r\n  /**\r\n   * Start heartbeat\r\n   */\r\n  private startHeartbeat(interval: number): void {\r\n    this.heartbeatInterval = setInterval(() => {\r\n      this.send({\r\n        op: GatewayOpcodes.Heartbeat,\r\n        d: this.sequence\r\n      });\r\n    }, interval);\r\n  }\r\n\r\n  /**\r\n   * Send payload to gateway\r\n   */\r\n  private send(payload: GatewayPayload): void {\r\n    if (this.ws?.readyState === WebSocket.OPEN) {\r\n      this.ws.send(JSON.stringify(payload));\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Cleanup on disconnect\r\n   */\r\n  private cleanup(): void {\r\n    if (this.heartbeatInterval) {\r\n      clearInterval(this.heartbeatInterval);\r\n      this.heartbeatInterval = null;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Destroy the client\r\n   */\r\n  destroy(): void {\r\n    this.cleanup();\r\n    this.ws?.close(1000);\r\n    this.ws = null;\r\n    this.removeAllListeners();\r\n  }\r\n}\r\n\r\n// Re-export for convenience\r\nexport { GatewayIntentBits };\r\n"]}
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* ActionRowBuilder for creating component rows
|
|
3
|
+
*/
|
|
4
|
+
import { APIButtonComponent } from './ButtonBuilder';
|
|
5
|
+
import { APISelectMenuComponent } from './SelectMenuBuilder';
|
|
6
|
+
export type APIActionRowComponent = APIButtonComponent | APISelectMenuComponent;
|
|
7
|
+
export interface APIActionRow {
|
|
8
|
+
type: 1;
|
|
9
|
+
components: APIActionRowComponent[];
|
|
10
|
+
}
|
|
11
|
+
/**
|
|
12
|
+
* A builder for creating action rows
|
|
13
|
+
*/
|
|
14
|
+
export declare class ActionRowBuilder<T extends APIActionRowComponent = APIActionRowComponent> {
|
|
15
|
+
readonly data: {
|
|
16
|
+
type: 1;
|
|
17
|
+
components: T[];
|
|
18
|
+
};
|
|
19
|
+
constructor(data?: Partial<APIActionRow>);
|
|
20
|
+
/**
|
|
21
|
+
* Adds components to this action row
|
|
22
|
+
* @param components The components to add
|
|
23
|
+
*/
|
|
24
|
+
addComponents(...components: (T | {
|
|
25
|
+
toJSON(): T;
|
|
26
|
+
})[]): this;
|
|
27
|
+
/**
|
|
28
|
+
* Sets the components of this action row
|
|
29
|
+
* @param components The components to set
|
|
30
|
+
*/
|
|
31
|
+
setComponents(...components: (T | {
|
|
32
|
+
toJSON(): T;
|
|
33
|
+
})[]): this;
|
|
34
|
+
/**
|
|
35
|
+
* Removes, replaces, or inserts components
|
|
36
|
+
* @param index The index to start at
|
|
37
|
+
* @param deleteCount The number of components to remove
|
|
38
|
+
* @param components The components to insert
|
|
39
|
+
*/
|
|
40
|
+
spliceComponents(index: number, deleteCount: number, ...components: (T | {
|
|
41
|
+
toJSON(): T;
|
|
42
|
+
})[]): this;
|
|
43
|
+
/**
|
|
44
|
+
* Returns the JSON representation of this action row
|
|
45
|
+
*/
|
|
46
|
+
toJSON(): APIActionRow;
|
|
47
|
+
/**
|
|
48
|
+
* Creates a new action row builder from existing data
|
|
49
|
+
* @param other The action row data to copy
|
|
50
|
+
*/
|
|
51
|
+
static from<T extends APIActionRowComponent>(other: Partial<APIActionRow> | ActionRowBuilder<T>): ActionRowBuilder<T>;
|
|
52
|
+
}
|
|
53
|
+
export default ActionRowBuilder;
|