@jubbio/core 1.3.3 → 1.3.5

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.
Files changed (131) hide show
  1. package/dist/Client.js +50 -10
  2. package/dist/rest/REST.d.ts +1 -0
  3. package/dist/rest/REST.js +1 -1
  4. package/dist/structures/Channel.d.ts +1 -1
  5. package/dist/structures/Channel.js +11 -4
  6. package/dist/structures/Guild.d.ts +1 -1
  7. package/dist/structures/Guild.js +7 -3
  8. package/dist/structures/Interaction.js +11 -3
  9. package/dist/structures/Message.d.ts +2 -0
  10. package/dist/structures/Message.js +13 -33
  11. package/package.json +4 -14
  12. package/dist/cjs/Client.d.ts +0 -157
  13. package/dist/cjs/Client.js +0 -640
  14. package/dist/cjs/builders/ActionRowBuilder.d.ts +0 -53
  15. package/dist/cjs/builders/ActionRowBuilder.js +0 -68
  16. package/dist/cjs/builders/ButtonBuilder.d.ts +0 -77
  17. package/dist/cjs/builders/ButtonBuilder.js +0 -96
  18. package/dist/cjs/builders/EmbedBuilder.d.ts +0 -157
  19. package/dist/cjs/builders/EmbedBuilder.js +0 -208
  20. package/dist/cjs/builders/ModalBuilder.d.ts +0 -122
  21. package/dist/cjs/builders/ModalBuilder.js +0 -162
  22. package/dist/cjs/builders/SelectMenuBuilder.d.ts +0 -123
  23. package/dist/cjs/builders/SelectMenuBuilder.js +0 -165
  24. package/dist/cjs/builders/SlashCommandBuilder.d.ts +0 -197
  25. package/dist/cjs/builders/SlashCommandBuilder.js +0 -324
  26. package/dist/cjs/builders/index.d.ts +0 -9
  27. package/dist/cjs/builders/index.js +0 -26
  28. package/dist/cjs/enums.d.ts +0 -191
  29. package/dist/cjs/enums.js +0 -211
  30. package/dist/cjs/index.d.ts +0 -25
  31. package/dist/cjs/index.js +0 -130
  32. package/dist/cjs/managers/BaseManager.d.ts +0 -69
  33. package/dist/cjs/managers/BaseManager.js +0 -106
  34. package/dist/cjs/managers/ChannelManager.d.ts +0 -95
  35. package/dist/cjs/managers/ChannelManager.js +0 -205
  36. package/dist/cjs/managers/GuildMemberManager.d.ts +0 -74
  37. package/dist/cjs/managers/GuildMemberManager.js +0 -157
  38. package/dist/cjs/managers/RoleManager.d.ts +0 -84
  39. package/dist/cjs/managers/RoleManager.js +0 -207
  40. package/dist/cjs/managers/index.d.ts +0 -7
  41. package/dist/cjs/managers/index.js +0 -24
  42. package/dist/cjs/rest/REST.d.ts +0 -527
  43. package/dist/cjs/rest/REST.js +0 -904
  44. package/dist/cjs/rest/index.d.ts +0 -1
  45. package/dist/cjs/rest/index.js +0 -18
  46. package/dist/cjs/sharding/ShardingManager.d.ts +0 -179
  47. package/dist/cjs/sharding/ShardingManager.js +0 -375
  48. package/dist/cjs/sharding/index.d.ts +0 -4
  49. package/dist/cjs/sharding/index.js +0 -21
  50. package/dist/cjs/structures/Channel.d.ts +0 -122
  51. package/dist/cjs/structures/Channel.js +0 -240
  52. package/dist/cjs/structures/Collection.d.ts +0 -53
  53. package/dist/cjs/structures/Collection.js +0 -115
  54. package/dist/cjs/structures/Guild.d.ts +0 -59
  55. package/dist/cjs/structures/Guild.js +0 -94
  56. package/dist/cjs/structures/GuildMember.d.ts +0 -174
  57. package/dist/cjs/structures/GuildMember.js +0 -311
  58. package/dist/cjs/structures/Interaction.d.ts +0 -245
  59. package/dist/cjs/structures/Interaction.js +0 -450
  60. package/dist/cjs/structures/Message.d.ts +0 -98
  61. package/dist/cjs/structures/Message.js +0 -195
  62. package/dist/cjs/structures/User.d.ts +0 -37
  63. package/dist/cjs/structures/User.js +0 -65
  64. package/dist/cjs/structures/index.d.ts +0 -7
  65. package/dist/cjs/structures/index.js +0 -25
  66. package/dist/cjs/structures.d.ts +0 -1
  67. package/dist/cjs/structures.js +0 -19
  68. package/dist/cjs/types.d.ts +0 -255
  69. package/dist/cjs/types.js +0 -3
  70. package/dist/cjs/utils/BitField.d.ts +0 -66
  71. package/dist/cjs/utils/BitField.js +0 -138
  72. package/dist/cjs/utils/Collection.d.ts +0 -116
  73. package/dist/cjs/utils/Collection.js +0 -265
  74. package/dist/cjs/utils/Collector.d.ts +0 -152
  75. package/dist/cjs/utils/Collector.js +0 -314
  76. package/dist/cjs/utils/DataResolver.d.ts +0 -61
  77. package/dist/cjs/utils/DataResolver.js +0 -146
  78. package/dist/cjs/utils/Formatters.d.ts +0 -145
  79. package/dist/cjs/utils/Formatters.js +0 -213
  80. package/dist/cjs/utils/IntentsBitField.d.ts +0 -85
  81. package/dist/cjs/utils/IntentsBitField.js +0 -99
  82. package/dist/cjs/utils/Partials.d.ts +0 -104
  83. package/dist/cjs/utils/Partials.js +0 -148
  84. package/dist/cjs/utils/PermissionsBitField.d.ts +0 -118
  85. package/dist/cjs/utils/PermissionsBitField.js +0 -145
  86. package/dist/cjs/utils/SnowflakeUtil.d.ts +0 -63
  87. package/dist/cjs/utils/SnowflakeUtil.js +0 -93
  88. package/dist/cjs/utils/Sweepers.d.ts +0 -119
  89. package/dist/cjs/utils/Sweepers.js +0 -249
  90. package/dist/cjs/utils/index.d.ts +0 -13
  91. package/dist/cjs/utils/index.js +0 -30
  92. package/dist/esm/Client.js +0 -634
  93. package/dist/esm/builders/ActionRowBuilder.js +0 -64
  94. package/dist/esm/builders/ButtonBuilder.js +0 -92
  95. package/dist/esm/builders/EmbedBuilder.js +0 -204
  96. package/dist/esm/builders/ModalBuilder.js +0 -157
  97. package/dist/esm/builders/SelectMenuBuilder.js +0 -161
  98. package/dist/esm/builders/SlashCommandBuilder.js +0 -311
  99. package/dist/esm/builders/index.js +0 -10
  100. package/dist/esm/enums.js +0 -208
  101. package/dist/esm/index.js +0 -34
  102. package/dist/esm/managers/BaseManager.js +0 -100
  103. package/dist/esm/managers/ChannelManager.js +0 -200
  104. package/dist/esm/managers/GuildMemberManager.js +0 -153
  105. package/dist/esm/managers/RoleManager.js +0 -203
  106. package/dist/esm/managers/index.js +0 -8
  107. package/dist/esm/rest/REST.js +0 -900
  108. package/dist/esm/rest/index.js +0 -2
  109. package/dist/esm/sharding/ShardingManager.js +0 -366
  110. package/dist/esm/sharding/index.js +0 -5
  111. package/dist/esm/structures/Channel.js +0 -232
  112. package/dist/esm/structures/Collection.js +0 -111
  113. package/dist/esm/structures/Guild.js +0 -90
  114. package/dist/esm/structures/GuildMember.js +0 -306
  115. package/dist/esm/structures/Interaction.js +0 -438
  116. package/dist/esm/structures/Message.js +0 -191
  117. package/dist/esm/structures/User.js +0 -61
  118. package/dist/esm/structures/index.js +0 -9
  119. package/dist/esm/structures.js +0 -3
  120. package/dist/esm/types.js +0 -2
  121. package/dist/esm/utils/BitField.js +0 -134
  122. package/dist/esm/utils/Collection.js +0 -261
  123. package/dist/esm/utils/Collector.js +0 -305
  124. package/dist/esm/utils/DataResolver.js +0 -142
  125. package/dist/esm/utils/Formatters.js +0 -191
  126. package/dist/esm/utils/IntentsBitField.js +0 -93
  127. package/dist/esm/utils/Partials.js +0 -137
  128. package/dist/esm/utils/PermissionsBitField.js +0 -141
  129. package/dist/esm/utils/SnowflakeUtil.js +0 -89
  130. package/dist/esm/utils/Sweepers.js +0 -245
  131. package/dist/esm/utils/index.js +0 -14
@@ -1,634 +0,0 @@
1
- import { EventEmitter } from 'events';
2
- import WebSocket from 'ws';
3
- import { GatewayOpcodes, GatewayIntentBits } from './enums';
4
- import { Collection } from './structures/Collection';
5
- import { User } from './structures/User';
6
- import { Guild } from './structures/Guild';
7
- import { Message } from './structures/Message';
8
- import { createInteraction } from './structures/Interaction';
9
- import { REST } from './rest/REST';
10
- /**
11
- * Main client class
12
- */
13
- export class Client extends EventEmitter {
14
- /** Client options */
15
- options;
16
- /** REST API client */
17
- rest;
18
- /** The bot user */
19
- user = null;
20
- /** Application ID */
21
- applicationId = null;
22
- /** Cached guilds */
23
- guilds = new Collection();
24
- /** Cached channels */
25
- channels = new Collection();
26
- /** Cached users */
27
- users = new Collection();
28
- /** Voice adapter management */
29
- voice;
30
- /** WebSocket connection */
31
- ws = null;
32
- /** Bot token */
33
- token = '';
34
- /** Session ID */
35
- sessionId = null;
36
- /** Sequence number */
37
- sequence = null;
38
- /** Heartbeat interval */
39
- heartbeatInterval = null;
40
- /** Gateway URL */
41
- gatewayUrl;
42
- /** Voice state update handlers (for voice adapters) */
43
- voiceStateHandlers = new Map();
44
- voiceServerHandlers = new Map();
45
- /** Whether the client is currently in the login flow */
46
- _loginState = 'idle';
47
- /** Reconnect attempt counter */
48
- _reconnectAttempts = 0;
49
- /** Maximum reconnect attempts before giving up */
50
- _maxReconnectAttempts = 5;
51
- constructor(options) {
52
- super();
53
- this.options = options;
54
- this.gatewayUrl = options.gatewayUrl || 'wss://realtime.jubbio.com/ws/bot';
55
- this.rest = new REST(options.apiUrl);
56
- // Initialize voice adapter system
57
- this.voice = {
58
- adapters: new Map()
59
- };
60
- }
61
- /**
62
- * Calculate intents value
63
- */
64
- getIntentsValue() {
65
- if (typeof this.options.intents === 'number') {
66
- return this.options.intents;
67
- }
68
- return this.options.intents.reduce((acc, intent) => acc | intent, 0);
69
- }
70
- /**
71
- * Gateway close code descriptions
72
- */
73
- static CLOSE_CODES = {
74
- 4000: { message: 'Bilinmeyen hata (Unknown error)', reconnectable: true },
75
- 4001: { message: 'Bilinmeyen opcode gönderildi (Unknown opcode)', reconnectable: true },
76
- 4002: { message: 'Geçersiz payload gönderildi (Decode error)', reconnectable: true },
77
- 4003: { message: 'Henüz kimlik doğrulaması yapılmadı (Not authenticated)', reconnectable: true },
78
- 4004: { message: 'Geçersiz bot token\'ı (Authentication failed)', reconnectable: false },
79
- 4005: { message: 'Zaten kimlik doğrulaması yapılmış (Already authenticated)', reconnectable: true },
80
- 4007: { message: 'Geçersiz sequence numarası (Invalid seq)', reconnectable: true },
81
- 4008: { message: 'Rate limit aşıldı (Rate limited)', reconnectable: true },
82
- 4009: { message: 'Oturum zaman aşımına uğradı (Session timed out)', reconnectable: true },
83
- 4010: { message: 'Geçersiz shard yapılandırması (Invalid shard)', reconnectable: false },
84
- 4011: { message: 'Sharding gerekli (Sharding required)', reconnectable: false },
85
- 4014: { message: 'İzin verilmeyen intent\'ler istendi (Disallowed intents)', reconnectable: false },
86
- };
87
- /**
88
- * Login to the gateway
89
- */
90
- async login(token) {
91
- if (!token || typeof token !== 'string') {
92
- throw new Error('Geçerli bir bot token\'ı sağlanmalıdır. Örnek: client.login(process.env.BOT_TOKEN)');
93
- }
94
- this.token = token.replace(/^Bot\s+/i, '');
95
- this.rest.setToken(this.token);
96
- this._loginState = 'connecting';
97
- this._reconnectAttempts = 0;
98
- return new Promise((resolve, reject) => {
99
- const cleanup = () => {
100
- clearTimeout(timeout);
101
- this.removeListener('ready', onReady);
102
- this.removeListener('error', onError);
103
- this.removeListener('gatewayClose', onGatewayClose);
104
- };
105
- const timeout = setTimeout(() => {
106
- cleanup();
107
- this._loginState = 'idle';
108
- reject(new Error('Gateway\'e bağlanılamadı: 30 saniye içinde READY event\'i alınamadı. ' +
109
- 'Olası sebepler: gateway sunucusu erişilemez, token geçersiz veya ağ sorunu.'));
110
- }, 30000);
111
- const onReady = () => {
112
- cleanup();
113
- this._loginState = 'ready';
114
- this._reconnectAttempts = 0;
115
- resolve(this.token);
116
- };
117
- const onError = (error) => {
118
- cleanup();
119
- this._loginState = 'idle';
120
- reject(error);
121
- };
122
- const onGatewayClose = (code, reason) => {
123
- const info = Client.CLOSE_CODES[code];
124
- if (info && !info.reconnectable) {
125
- cleanup();
126
- this._loginState = 'idle';
127
- reject(new Error(`Gateway bağlantısı reddedildi [${code}]: ${info.message}${reason ? ' - ' + reason : ''}`));
128
- }
129
- // Reconnectable codes: login promise stays alive, connect() will retry
130
- };
131
- this.once('ready', onReady);
132
- this.once('error', onError);
133
- this.on('gatewayClose', onGatewayClose);
134
- this.connect();
135
- });
136
- }
137
- /**
138
- * Connect to the gateway
139
- */
140
- connect() {
141
- this.ws = new WebSocket(this.gatewayUrl);
142
- this.ws.on('open', () => {
143
- this.emit('debug', 'WebSocket bağlantısı açıldı');
144
- this._reconnectAttempts = 0;
145
- });
146
- this.ws.on('message', (data) => {
147
- this.handleMessage(data.toString());
148
- });
149
- this.ws.on('close', (code, reason) => {
150
- const reasonStr = reason?.toString() || '';
151
- const info = Client.CLOSE_CODES[code];
152
- if (info) {
153
- this.emit('debug', `Gateway bağlantısı kapandı [${code}]: ${info.message}${reasonStr ? ' - ' + reasonStr : ''}`);
154
- }
155
- else {
156
- this.emit('debug', `WebSocket kapandı: ${code} - ${reasonStr}`);
157
- }
158
- this.cleanup();
159
- // Emit gatewayClose so login() can handle non-reconnectable codes
160
- this.emit('gatewayClose', code, reasonStr);
161
- // Non-reconnectable codes: don't retry
162
- if (info && !info.reconnectable) {
163
- this.emit('debug', `Kod ${code} yeniden bağlanılamaz, bağlantı sonlandırılıyor.`);
164
- return;
165
- }
166
- // Normal close: don't retry
167
- if (code === 1000) {
168
- return;
169
- }
170
- // Reconnectable: retry with backoff
171
- this._reconnectAttempts++;
172
- if (this._reconnectAttempts > this._maxReconnectAttempts) {
173
- this.emit('debug', `Maksimum yeniden bağlanma denemesi aşıldı (${this._maxReconnectAttempts})`);
174
- this.emit('error', new Error(`Gateway bağlantısı ${this._maxReconnectAttempts} denemeden sonra kurulamadı. Son kapanma kodu: ${code}`));
175
- return;
176
- }
177
- const delay = Math.min(1000 * Math.pow(2, this._reconnectAttempts - 1), 30000);
178
- this.emit('debug', `Yeniden bağlanılıyor (deneme ${this._reconnectAttempts}/${this._maxReconnectAttempts}), ${delay}ms sonra...`);
179
- setTimeout(() => this.connect(), delay);
180
- });
181
- this.ws.on('error', (error) => {
182
- this.emit('debug', `WebSocket hatası: ${error.message}`);
183
- this.emit('error', error);
184
- });
185
- }
186
- /**
187
- * Handle incoming gateway message
188
- */
189
- handleMessage(data) {
190
- // Handle multiple messages in one frame
191
- const messages = data.split('\n').filter(m => m.trim());
192
- for (const msg of messages) {
193
- try {
194
- const payload = JSON.parse(msg);
195
- this.handlePayload(payload);
196
- }
197
- catch (e) {
198
- this.emit('debug', `Failed to parse message: ${msg}`);
199
- }
200
- }
201
- }
202
- /**
203
- * Handle gateway payload
204
- */
205
- handlePayload(payload) {
206
- if (payload.s) {
207
- this.sequence = payload.s;
208
- }
209
- switch (payload.op) {
210
- case GatewayOpcodes.Hello:
211
- this.handleHello(payload.d);
212
- break;
213
- case GatewayOpcodes.Dispatch:
214
- this.handleDispatch(payload.t, payload.d);
215
- break;
216
- case GatewayOpcodes.HeartbeatAck:
217
- this.emit('debug', 'Heartbeat acknowledged');
218
- break;
219
- case GatewayOpcodes.InvalidSession:
220
- this.emit('debug', 'Geçersiz oturum, yeniden kimlik doğrulanıyor...');
221
- // InvalidSession may carry error data from sendError()
222
- if (payload.d && typeof payload.d === 'object' && payload.d.code && payload.d.message) {
223
- this.emit('debug', `Sunucu hatası [${payload.d.code}]: ${payload.d.message}`);
224
- const info = Client.CLOSE_CODES[payload.d.code];
225
- if (info && !info.reconnectable) {
226
- this.emit('error', new Error(`Gateway hatası [${payload.d.code}]: ${info.message}`));
227
- return;
228
- }
229
- }
230
- setTimeout(() => this.identify(), 5000);
231
- break;
232
- case GatewayOpcodes.Reconnect:
233
- this.emit('debug', 'Reconnect requested');
234
- this.ws?.close();
235
- setTimeout(() => this.connect(), 1000);
236
- break;
237
- }
238
- }
239
- /**
240
- * Handle Hello payload
241
- */
242
- handleHello(data) {
243
- this.emit('debug', `Received Hello, heartbeat interval: ${data.heartbeat_interval}ms`);
244
- this.startHeartbeat(data.heartbeat_interval);
245
- this.identify();
246
- }
247
- /**
248
- * Handle Dispatch events
249
- */
250
- handleDispatch(eventType, data) {
251
- this.emit('debug', `Dispatch: ${eventType}`);
252
- switch (eventType) {
253
- case 'READY':
254
- this.handleReady(data);
255
- break;
256
- case 'GUILD_CREATE':
257
- this.handleGuildCreate(data);
258
- break;
259
- case 'GUILD_UPDATE':
260
- this.handleGuildUpdate(data);
261
- break;
262
- case 'GUILD_DELETE':
263
- this.handleGuildDelete(data);
264
- break;
265
- case 'MESSAGE_CREATE':
266
- this.handleMessageCreate(data);
267
- break;
268
- case 'MESSAGE_UPDATE':
269
- this.emit('messageUpdate', data);
270
- break;
271
- case 'MESSAGE_DELETE':
272
- this.emit('messageDelete', data);
273
- break;
274
- case 'MESSAGE_DELETE_BULK':
275
- this.emit('messageDeleteBulk', data);
276
- break;
277
- case 'CHANNEL_CREATE': {
278
- // Update guild channel cache
279
- const guildId = data.guild_id;
280
- const channelId = data.id || data.channel_id;
281
- if (guildId && channelId) {
282
- const guild = this.guilds.get(guildId);
283
- if (guild) {
284
- guild.channels.set(channelId, data);
285
- }
286
- }
287
- this.emit('channelCreate', data);
288
- break;
289
- }
290
- case 'CHANNEL_UPDATE': {
291
- const guildId = data.guild_id;
292
- const channelId = data.id || data.channel_id;
293
- if (guildId && channelId) {
294
- const guild = this.guilds.get(guildId);
295
- if (guild) {
296
- guild.channels.set(channelId, data);
297
- }
298
- }
299
- this.emit('channelUpdate', data);
300
- break;
301
- }
302
- case 'CHANNEL_DELETE': {
303
- const guildId = data.guild_id;
304
- const channelId = data.id || data.channel_id;
305
- if (guildId && channelId) {
306
- const guild = this.guilds.get(guildId);
307
- if (guild) {
308
- guild.channels.delete(channelId);
309
- }
310
- }
311
- this.emit('channelDelete', data);
312
- break;
313
- }
314
- case 'GUILD_MEMBER_ADD': {
315
- const guild = this.guilds.get(String(data.guild_id));
316
- if (guild && data.user) {
317
- const member = guild._addMember(data);
318
- this.emit('guildMemberAdd', member);
319
- }
320
- else {
321
- this.emit('guildMemberAdd', data);
322
- }
323
- break;
324
- }
325
- case 'GUILD_MEMBER_UPDATE': {
326
- const guild = this.guilds.get(String(data.guild_id));
327
- const rawUserId = data.user?.id || data.user_id;
328
- if (guild && rawUserId) {
329
- const existing = guild.members.get(String(rawUserId));
330
- if (existing) {
331
- existing._patch(data);
332
- this.emit('guildMemberUpdate', existing);
333
- }
334
- else {
335
- this.emit('guildMemberUpdate', data);
336
- }
337
- }
338
- else {
339
- this.emit('guildMemberUpdate', data);
340
- }
341
- break;
342
- }
343
- case 'GUILD_MEMBER_REMOVE': {
344
- const guild = this.guilds.get(String(data.guild_id));
345
- const rawUserId = data.user?.id || data.user_id;
346
- if (guild && rawUserId) {
347
- const userId = String(rawUserId);
348
- const member = guild.members.get(userId);
349
- guild.members.delete(userId);
350
- this.emit('guildMemberRemove', member || data);
351
- }
352
- else {
353
- this.emit('guildMemberRemove', data);
354
- }
355
- break;
356
- }
357
- case 'GUILD_ROLE_CREATE':
358
- this.emit('roleCreate', data);
359
- break;
360
- case 'GUILD_ROLE_UPDATE':
361
- this.emit('roleUpdate', data);
362
- break;
363
- case 'GUILD_ROLE_DELETE':
364
- this.emit('roleDelete', data);
365
- break;
366
- case 'GUILD_BAN_ADD':
367
- this.emit('guildBanAdd', data);
368
- break;
369
- case 'GUILD_BAN_REMOVE':
370
- this.emit('guildBanRemove', data);
371
- break;
372
- case 'INVITE_CREATE':
373
- this.emit('inviteCreate', data);
374
- break;
375
- case 'INVITE_DELETE':
376
- this.emit('inviteDelete', data);
377
- break;
378
- case 'TYPING_START':
379
- this.emit('typingStart', data);
380
- break;
381
- case 'PRESENCE_UPDATE':
382
- this.emit('presenceUpdate', data);
383
- break;
384
- case 'INTERACTION_CREATE':
385
- this.handleInteractionCreate(data);
386
- break;
387
- case 'VOICE_STATE_UPDATE':
388
- this.handleVoiceStateUpdate(data);
389
- break;
390
- case 'VOICE_SERVER_UPDATE':
391
- this.handleVoiceServerUpdate(data);
392
- break;
393
- default:
394
- // Emit raw event for unhandled types
395
- this.emit('raw', { t: eventType, d: data });
396
- }
397
- }
398
- /**
399
- * Handle Ready event
400
- */
401
- handleReady(data) {
402
- this.sessionId = data.session_id;
403
- this.user = new User(data.user);
404
- // Handle both string and number application IDs
405
- this.applicationId = data.application?.id ? String(data.application.id) : null;
406
- if (this.applicationId) {
407
- this.rest.setApplicationId(this.applicationId);
408
- }
409
- // Cache guilds (as unavailable initially)
410
- if (data.guilds) {
411
- for (const guild of data.guilds) {
412
- this.guilds.set(String(guild.id), new Guild(this, guild));
413
- }
414
- }
415
- // Setup voice adapters for each guild
416
- this.setupVoiceAdapters();
417
- console.log(`✅ Bot hazır! User: ${this.user.username} (${this.user.id}), App: ${this.applicationId}`);
418
- this.emit('ready', this);
419
- }
420
- /**
421
- * Setup voice adapters for all guilds
422
- */
423
- setupVoiceAdapters() {
424
- for (const [guildId] of this.guilds) {
425
- this.createVoiceAdapter(guildId);
426
- }
427
- }
428
- /**
429
- * Create a voice adapter for a guild
430
- */
431
- createVoiceAdapter(guildId) {
432
- const adapter = (methods) => {
433
- // Store handlers for this guild
434
- this.voiceStateHandlers.set(guildId, methods.onVoiceStateUpdate);
435
- this.voiceServerHandlers.set(guildId, methods.onVoiceServerUpdate);
436
- return {
437
- sendPayload: (payload) => {
438
- if (this.ws?.readyState === WebSocket.OPEN) {
439
- this.ws.send(JSON.stringify(payload));
440
- return true;
441
- }
442
- return false;
443
- },
444
- destroy: () => {
445
- this.voiceStateHandlers.delete(guildId);
446
- this.voiceServerHandlers.delete(guildId);
447
- }
448
- };
449
- };
450
- this.voice.adapters.set(guildId, adapter);
451
- }
452
- /**
453
- * Handle Guild Create event
454
- */
455
- handleGuildCreate(data) {
456
- let guild = this.guilds.get(data.id);
457
- if (guild) {
458
- guild._patch(data);
459
- }
460
- else {
461
- guild = new Guild(this, data);
462
- this.guilds.set(data.id, guild);
463
- this.createVoiceAdapter(data.id);
464
- }
465
- this.emit('guildCreate', guild);
466
- }
467
- /**
468
- * Handle Guild Update event
469
- */
470
- handleGuildUpdate(data) {
471
- const guild = this.guilds.get(data.id);
472
- if (guild) {
473
- guild._patch(data);
474
- this.emit('guildUpdate', guild);
475
- }
476
- }
477
- /**
478
- * Handle Guild Delete event
479
- */
480
- handleGuildDelete(data) {
481
- const guild = this.guilds.get(data.id);
482
- if (guild) {
483
- this.guilds.delete(data.id);
484
- this.voice.adapters.delete(data.id);
485
- this.emit('guildDelete', guild);
486
- }
487
- }
488
- /**
489
- * Handle Message Create event
490
- */
491
- handleMessageCreate(data) {
492
- // Backend sends user_id separately, map it to author.id for compatibility
493
- if (data.user_id && data.author && !data.author.id) {
494
- data.author.id = data.user_id;
495
- }
496
- // Cache the author
497
- if (data.author) {
498
- const user = new User(data.author);
499
- this.users.set(user.id, user);
500
- // Also cache in REST for mention resolution
501
- this.rest.cacheUser(data.author);
502
- }
503
- const message = new Message(this, data);
504
- // Mark message as from bot if author ID matches the bot's own user ID
505
- if (this.user && String(message.author.id) === String(this.user.id)) {
506
- message.author.bot = true;
507
- }
508
- // Resolve guild member if in a guild
509
- if (message.guildId) {
510
- const guild = this.guilds.get(message.guildId);
511
- const memberData = data.member;
512
- if (memberData && guild) {
513
- // Gateway sent member data with the message — cache it
514
- memberData.user = data.author;
515
- const member = guild._addMember(memberData);
516
- message.member = member;
517
- }
518
- else if (memberData) {
519
- // No guild in cache but member data exists
520
- memberData.user = data.author;
521
- const resolvedGuild = { id: message.guildId, ownerId: null };
522
- message.member = new (require('./structures/GuildMember').GuildMember)(this, resolvedGuild, memberData);
523
- }
524
- else if (guild) {
525
- // Try cache
526
- const cached = guild.members?.get(String(message.author.id));
527
- if (cached?.permissions?.has) {
528
- message.member = cached;
529
- }
530
- }
531
- }
532
- this.emit('messageCreate', message);
533
- }
534
- /**
535
- * Handle Interaction Create event
536
- */
537
- handleInteractionCreate(data) {
538
- console.log('[DEBUG] handleInteractionCreate called with:', JSON.stringify(data, null, 2));
539
- // Cache the user
540
- const userData = data.member?.user || data.user;
541
- if (userData) {
542
- const user = new User(userData);
543
- this.users.set(user.id, user);
544
- this.rest.cacheUser(userData);
545
- }
546
- const interaction = createInteraction(this, data);
547
- console.log('[DEBUG] Created interaction type:', interaction.constructor.name, 'customId:', interaction.customId);
548
- this.emit('interactionCreate', interaction);
549
- }
550
- /**
551
- * Handle Voice State Update event
552
- */
553
- handleVoiceStateUpdate(data) {
554
- const guildId = data.guild_id;
555
- // Forward to voice adapter if exists
556
- const handler = this.voiceStateHandlers.get(guildId);
557
- if (handler) {
558
- handler(data);
559
- }
560
- this.emit('voiceStateUpdate', data);
561
- }
562
- /**
563
- * Handle Voice Server Update event
564
- */
565
- handleVoiceServerUpdate(data) {
566
- const guildId = data.guild_id;
567
- // Forward to voice adapter if exists
568
- const handler = this.voiceServerHandlers.get(guildId);
569
- if (handler) {
570
- handler({
571
- token: data.token,
572
- endpoint: data.endpoint,
573
- room: data.room
574
- });
575
- }
576
- this.emit('voiceServerUpdate', data);
577
- }
578
- /**
579
- * Send Identify payload
580
- */
581
- identify() {
582
- const payload = {
583
- op: GatewayOpcodes.Identify,
584
- d: {
585
- token: `Bot ${this.token}`,
586
- intents: this.getIntentsValue(),
587
- shard: this.options.shards || [0, 1]
588
- }
589
- };
590
- this.send(payload);
591
- }
592
- /**
593
- * Start heartbeat
594
- */
595
- startHeartbeat(interval) {
596
- this.heartbeatInterval = setInterval(() => {
597
- this.send({
598
- op: GatewayOpcodes.Heartbeat,
599
- d: this.sequence
600
- });
601
- }, interval);
602
- }
603
- /**
604
- * Send payload to gateway
605
- */
606
- send(payload) {
607
- if (this.ws?.readyState === WebSocket.OPEN) {
608
- this.ws.send(JSON.stringify(payload));
609
- }
610
- }
611
- /**
612
- * Cleanup on disconnect
613
- */
614
- cleanup() {
615
- if (this.heartbeatInterval) {
616
- clearInterval(this.heartbeatInterval);
617
- this.heartbeatInterval = null;
618
- }
619
- }
620
- /**
621
- * Destroy the client
622
- */
623
- destroy() {
624
- this._loginState = 'idle';
625
- this._reconnectAttempts = this._maxReconnectAttempts + 1; // Prevent reconnect
626
- this.cleanup();
627
- this.ws?.close(1000);
628
- this.ws = null;
629
- this.removeAllListeners();
630
- }
631
- }
632
- // Re-export for convenience
633
- export { GatewayIntentBits };
634
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Client.js","sourceRoot":"","sources":["../../src/Client.ts"],"names":[],"mappings":"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","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  /** Whether the client is currently in the login flow */\r\n  private _loginState: 'idle' | 'connecting' | 'ready' = 'idle';\r\n\r\n  /** Reconnect attempt counter */\r\n  private _reconnectAttempts: number = 0;\r\n\r\n  /** Maximum reconnect attempts before giving up */\r\n  private readonly _maxReconnectAttempts: number = 5;\r\n\r\n  constructor(options: ClientOptions) {\r\n    super();\r\n    this.options = options;\r\n    this.gatewayUrl = options.gatewayUrl || 'wss://realtime.jubbio.com/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   * Gateway close code descriptions\r\n   */\r\n  private static readonly CLOSE_CODES: Record<number, { message: string; reconnectable: boolean }> = {\r\n    4000: { message: 'Bilinmeyen hata (Unknown error)', reconnectable: true },\r\n    4001: { message: 'Bilinmeyen opcode gönderildi (Unknown opcode)', reconnectable: true },\r\n    4002: { message: 'Geçersiz payload gönderildi (Decode error)', reconnectable: true },\r\n    4003: { message: 'Henüz kimlik doğrulaması yapılmadı (Not authenticated)', reconnectable: true },\r\n    4004: { message: 'Geçersiz bot token\\'ı (Authentication failed)', reconnectable: false },\r\n    4005: { message: 'Zaten kimlik doğrulaması yapılmış (Already authenticated)', reconnectable: true },\r\n    4007: { message: 'Geçersiz sequence numarası (Invalid seq)', reconnectable: true },\r\n    4008: { message: 'Rate limit aşıldı (Rate limited)', reconnectable: true },\r\n    4009: { message: 'Oturum zaman aşımına uğradı (Session timed out)', reconnectable: true },\r\n    4010: { message: 'Geçersiz shard yapılandırması (Invalid shard)', reconnectable: false },\r\n    4011: { message: 'Sharding gerekli (Sharding required)', reconnectable: false },\r\n    4014: { message: 'İzin verilmeyen intent\\'ler istendi (Disallowed intents)', reconnectable: false },\r\n  };\r\n\r\n  /**\r\n   * Login to the gateway\r\n   */\r\n  async login(token: string): Promise<string> {\r\n    if (!token || typeof token !== 'string') {\r\n      throw new Error(\r\n        'Geçerli bir bot token\\'ı sağlanmalıdır. Örnek: client.login(process.env.BOT_TOKEN)'\r\n      );\r\n    }\r\n\r\n    this.token = token.replace(/^Bot\\s+/i, '');\r\n    this.rest.setToken(this.token);\r\n    this._loginState = 'connecting';\r\n    this._reconnectAttempts = 0;\r\n\r\n    return new Promise((resolve, reject) => {\r\n      const cleanup = () => {\r\n        clearTimeout(timeout);\r\n        this.removeListener('ready', onReady);\r\n        this.removeListener('error', onError);\r\n        this.removeListener('gatewayClose', onGatewayClose);\r\n      };\r\n\r\n      const timeout = setTimeout(() => {\r\n        cleanup();\r\n        this._loginState = 'idle';\r\n        reject(new Error(\r\n          'Gateway\\'e bağlanılamadı: 30 saniye içinde READY event\\'i alınamadı. ' +\r\n          'Olası sebepler: gateway sunucusu erişilemez, token geçersiz veya ağ sorunu.'\r\n        ));\r\n      }, 30000);\r\n\r\n      const onReady = () => {\r\n        cleanup();\r\n        this._loginState = 'ready';\r\n        this._reconnectAttempts = 0;\r\n        resolve(this.token);\r\n      };\r\n\r\n      const onError = (error: Error) => {\r\n        cleanup();\r\n        this._loginState = 'idle';\r\n        reject(error);\r\n      };\r\n\r\n      const onGatewayClose = (code: number, reason: string) => {\r\n        const info = Client.CLOSE_CODES[code];\r\n        if (info && !info.reconnectable) {\r\n          cleanup();\r\n          this._loginState = 'idle';\r\n          reject(new Error(`Gateway bağlantısı reddedildi [${code}]: ${info.message}${reason ? ' - ' + reason : ''}`));\r\n        }\r\n        // Reconnectable codes: login promise stays alive, connect() will retry\r\n      };\r\n\r\n      this.once('ready', onReady);\r\n      this.once('error', onError);\r\n      this.on('gatewayClose', onGatewayClose);\r\n\r\n      this.connect();\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 bağlantısı açıldı');\r\n      this._reconnectAttempts = 0;\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      const reasonStr = reason?.toString() || '';\r\n      const info = Client.CLOSE_CODES[code];\r\n      \r\n      if (info) {\r\n        this.emit('debug', `Gateway bağlantısı kapandı [${code}]: ${info.message}${reasonStr ? ' - ' + reasonStr : ''}`);\r\n      } else {\r\n        this.emit('debug', `WebSocket kapandı: ${code} - ${reasonStr}`);\r\n      }\r\n      \r\n      this.cleanup();\r\n\r\n      // Emit gatewayClose so login() can handle non-reconnectable codes\r\n      this.emit('gatewayClose', code, reasonStr);\r\n\r\n      // Non-reconnectable codes: don't retry\r\n      if (info && !info.reconnectable) {\r\n        this.emit('debug', `Kod ${code} yeniden bağlanılamaz, bağlantı sonlandırılıyor.`);\r\n        return;\r\n      }\r\n\r\n      // Normal close: don't retry\r\n      if (code === 1000) {\r\n        return;\r\n      }\r\n\r\n      // Reconnectable: retry with backoff\r\n      this._reconnectAttempts++;\r\n      if (this._reconnectAttempts > this._maxReconnectAttempts) {\r\n        this.emit('debug', `Maksimum yeniden bağlanma denemesi aşıldı (${this._maxReconnectAttempts})`);\r\n        this.emit('error', new Error(\r\n          `Gateway bağlantısı ${this._maxReconnectAttempts} denemeden sonra kurulamadı. Son kapanma kodu: ${code}`\r\n        ));\r\n        return;\r\n      }\r\n\r\n      const delay = Math.min(1000 * Math.pow(2, this._reconnectAttempts - 1), 30000);\r\n      this.emit('debug', `Yeniden bağlanılıyor (deneme ${this._reconnectAttempts}/${this._maxReconnectAttempts}), ${delay}ms sonra...`);\r\n      setTimeout(() => this.connect(), delay);\r\n    });\r\n    \r\n    this.ws.on('error', (error) => {\r\n      this.emit('debug', `WebSocket hatası: ${error.message}`);\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', 'Geçersiz oturum, yeniden kimlik doğrulanıyor...');\r\n        // InvalidSession may carry error data from sendError()\r\n        if (payload.d && typeof payload.d === 'object' && payload.d.code && payload.d.message) {\r\n          this.emit('debug', `Sunucu hatası [${payload.d.code}]: ${payload.d.message}`);\r\n          const info = Client.CLOSE_CODES[payload.d.code];\r\n          if (info && !info.reconnectable) {\r\n            this.emit('error', new Error(`Gateway hatası [${payload.d.code}]: ${info.message}`));\r\n            return;\r\n          }\r\n        }\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        // Update guild channel cache\r\n        const guildId = data.guild_id;\r\n        const channelId = data.id || data.channel_id;\r\n        if (guildId && channelId) {\r\n          const guild = this.guilds.get(guildId);\r\n          if (guild) {\r\n            guild.channels.set(channelId, data);\r\n          }\r\n        }\r\n        this.emit('channelCreate', data);\r\n        break;\r\n      }\r\n        \r\n      case 'CHANNEL_UPDATE': {\r\n        const guildId = data.guild_id;\r\n        const channelId = data.id || data.channel_id;\r\n        if (guildId && channelId) {\r\n          const guild = this.guilds.get(guildId);\r\n          if (guild) {\r\n            guild.channels.set(channelId, data);\r\n          }\r\n        }\r\n        this.emit('channelUpdate', data);\r\n        break;\r\n      }\r\n        \r\n      case 'CHANNEL_DELETE': {\r\n        const guildId = data.guild_id;\r\n        const channelId = data.id || data.channel_id;\r\n        if (guildId && channelId) {\r\n          const guild = this.guilds.get(guildId);\r\n          if (guild) {\r\n            guild.channels.delete(channelId);\r\n          }\r\n        }\r\n        this.emit('channelDelete', data);\r\n        break;\r\n      }\r\n        \r\n      case 'GUILD_MEMBER_ADD': {\r\n        const guild = this.guilds.get(String(data.guild_id));\r\n        if (guild && data.user) {\r\n          const member = guild._addMember(data);\r\n          this.emit('guildMemberAdd', member);\r\n        } else {\r\n          this.emit('guildMemberAdd', data);\r\n        }\r\n        break;\r\n      }\r\n        \r\n      case 'GUILD_MEMBER_UPDATE': {\r\n        const guild = this.guilds.get(String(data.guild_id));\r\n        const rawUserId = data.user?.id || data.user_id;\r\n        if (guild && rawUserId) {\r\n          const existing = guild.members.get(String(rawUserId));\r\n          if (existing) {\r\n            existing._patch(data);\r\n            this.emit('guildMemberUpdate', existing);\r\n          } else {\r\n            this.emit('guildMemberUpdate', data);\r\n          }\r\n        } else {\r\n          this.emit('guildMemberUpdate', data);\r\n        }\r\n        break;\r\n      }\r\n        \r\n      case 'GUILD_MEMBER_REMOVE': {\r\n        const guild = this.guilds.get(String(data.guild_id));\r\n        const rawUserId = data.user?.id || data.user_id;\r\n        if (guild && rawUserId) {\r\n          const userId = String(rawUserId);\r\n          const member = guild.members.get(userId);\r\n          guild.members.delete(userId);\r\n          this.emit('guildMemberRemove', member || data);\r\n        } else {\r\n          this.emit('guildMemberRemove', data);\r\n        }\r\n        break;\r\n      }\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 '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\r\n    // Mark message as from bot if author ID matches the bot's own user ID\r\n    if (this.user && String(message.author.id) === String(this.user.id)) {\r\n      (message.author as any).bot = true;\r\n    }\r\n\r\n    // Resolve guild member if in a guild\r\n    if (message.guildId) {\r\n      const guild = this.guilds.get(message.guildId);\r\n      const memberData = (data as any).member;\r\n      if (memberData && guild) {\r\n        // Gateway sent member data with the message — cache it\r\n        memberData.user = data.author;\r\n        const member = guild._addMember(memberData);\r\n        message.member = member;\r\n      } else if (memberData) {\r\n        // No guild in cache but member data exists\r\n        memberData.user = data.author;\r\n        const resolvedGuild = { id: message.guildId, ownerId: null } as any;\r\n        message.member = new (require('./structures/GuildMember').GuildMember)(this, resolvedGuild, memberData);\r\n      } else if (guild) {\r\n        // Try cache\r\n        const cached = guild.members?.get(String(message.author.id));\r\n        if (cached?.permissions?.has) {\r\n          message.member = cached;\r\n        }\r\n      }\r\n    }\r\n\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._loginState = 'idle';\r\n    this._reconnectAttempts = this._maxReconnectAttempts + 1; // Prevent reconnect\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"]}