@jubbio/core 1.1.6 → 1.1.8

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/dist/Client.js CHANGED
@@ -262,15 +262,6 @@ class Client extends events_1.EventEmitter {
262
262
  case 'INVITE_DELETE':
263
263
  this.emit('inviteDelete', data);
264
264
  break;
265
- case 'THREAD_CREATE':
266
- this.emit('threadCreate', data);
267
- break;
268
- case 'THREAD_UPDATE':
269
- this.emit('threadUpdate', data);
270
- break;
271
- case 'THREAD_DELETE':
272
- this.emit('threadDelete', data);
273
- break;
274
265
  case 'TYPING_START':
275
266
  this.emit('typingStart', data);
276
267
  break;
@@ -500,4 +491,4 @@ class Client extends events_1.EventEmitter {
500
491
  }
501
492
  }
502
493
  exports.Client = Client;
503
- //# 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  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   * 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        // 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        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\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    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"]}
494
+ //# 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  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   * 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        // 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        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 '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    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"]}
package/dist/enums.d.ts CHANGED
@@ -82,9 +82,6 @@ export declare enum ChannelType {
82
82
  GroupDM = 3,
83
83
  GuildCategory = 4,
84
84
  GuildAnnouncement = 5,
85
- AnnouncementThread = 10,
86
- PublicThread = 11,
87
- PrivateThread = 12,
88
85
  GuildStageVoice = 13,
89
86
  GuildDirectory = 14,
90
87
  GuildForum = 15
@@ -110,10 +107,8 @@ export declare enum MessageFlags {
110
107
  SuppressEmbeds = 4,
111
108
  SourceMessageDeleted = 8,
112
109
  Urgent = 16,
113
- HasThread = 32,
114
110
  Ephemeral = 64,
115
111
  Loading = 128,
116
- FailedToMentionSomeRolesInThread = 256,
117
112
  SuppressNotifications = 4096
118
113
  }
119
114
  /**
package/dist/enums.js CHANGED
@@ -91,9 +91,6 @@ var ChannelType;
91
91
  ChannelType[ChannelType["GroupDM"] = 3] = "GroupDM";
92
92
  ChannelType[ChannelType["GuildCategory"] = 4] = "GuildCategory";
93
93
  ChannelType[ChannelType["GuildAnnouncement"] = 5] = "GuildAnnouncement";
94
- ChannelType[ChannelType["AnnouncementThread"] = 10] = "AnnouncementThread";
95
- ChannelType[ChannelType["PublicThread"] = 11] = "PublicThread";
96
- ChannelType[ChannelType["PrivateThread"] = 12] = "PrivateThread";
97
94
  ChannelType[ChannelType["GuildStageVoice"] = 13] = "GuildStageVoice";
98
95
  ChannelType[ChannelType["GuildDirectory"] = 14] = "GuildDirectory";
99
96
  ChannelType[ChannelType["GuildForum"] = 15] = "GuildForum";
@@ -121,10 +118,8 @@ var MessageFlags;
121
118
  MessageFlags[MessageFlags["SuppressEmbeds"] = 4] = "SuppressEmbeds";
122
119
  MessageFlags[MessageFlags["SourceMessageDeleted"] = 8] = "SourceMessageDeleted";
123
120
  MessageFlags[MessageFlags["Urgent"] = 16] = "Urgent";
124
- MessageFlags[MessageFlags["HasThread"] = 32] = "HasThread";
125
121
  MessageFlags[MessageFlags["Ephemeral"] = 64] = "Ephemeral";
126
122
  MessageFlags[MessageFlags["Loading"] = 128] = "Loading";
127
- MessageFlags[MessageFlags["FailedToMentionSomeRolesInThread"] = 256] = "FailedToMentionSomeRolesInThread";
128
123
  MessageFlags[MessageFlags["SuppressNotifications"] = 4096] = "SuppressNotifications";
129
124
  })(MessageFlags || (exports.MessageFlags = MessageFlags = {}));
130
125
  /**
@@ -213,4 +208,4 @@ var OverwriteType;
213
208
  OverwriteType[OverwriteType["Role"] = 0] = "Role";
214
209
  OverwriteType[OverwriteType["Member"] = 1] = "Member";
215
210
  })(OverwriteType || (exports.OverwriteType = OverwriteType = {}));
216
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"enums.js","sourceRoot":"","sources":["../src/enums.ts"],"names":[],"mappings":"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","sourcesContent":["/**\r\n * Gateway Intent Bits\r\n */\r\nexport enum GatewayIntentBits {\r\n  Guilds = 1 << 0,\r\n  GuildMembers = 1 << 1,\r\n  GuildModeration = 1 << 2,\r\n  GuildEmojisAndStickers = 1 << 3,\r\n  GuildIntegrations = 1 << 4,\r\n  GuildWebhooks = 1 << 5,\r\n  GuildInvites = 1 << 6,\r\n  GuildVoiceStates = 1 << 7,\r\n  GuildPresences = 1 << 8,\r\n  GuildMessages = 1 << 9,\r\n  GuildMessageReactions = 1 << 10,\r\n  GuildMessageTyping = 1 << 11,\r\n  DirectMessages = 1 << 12,\r\n  DirectMessageReactions = 1 << 13,\r\n  DirectMessageTyping = 1 << 14,\r\n  MessageContent = 1 << 15,\r\n  GuildScheduledEvents = 1 << 16,\r\n  AutoModerationConfiguration = 1 << 20,\r\n  AutoModerationExecution = 1 << 21\r\n}\r\n\r\n/**\r\n * Gateway Opcodes\r\n */\r\nexport enum GatewayOpcodes {\r\n  Dispatch = 0,\r\n  Heartbeat = 1,\r\n  Identify = 2,\r\n  PresenceUpdate = 3,\r\n  VoiceStateUpdate = 4,\r\n  Resume = 6,\r\n  Reconnect = 7,\r\n  RequestGuildMembers = 8,\r\n  InvalidSession = 9,\r\n  Hello = 10,\r\n  HeartbeatAck = 11\r\n}\r\n\r\n/**\r\n * Interaction Types\r\n */\r\nexport enum InteractionType {\r\n  Ping = 1,\r\n  ApplicationCommand = 2,\r\n  MessageComponent = 3,\r\n  ApplicationCommandAutocomplete = 4,\r\n  ModalSubmit = 5\r\n}\r\n\r\n/**\r\n * Application Command Types\r\n */\r\nexport enum ApplicationCommandType {\r\n  ChatInput = 1,\r\n  User = 2,\r\n  Message = 3\r\n}\r\n\r\n/**\r\n * Application Command Option Types\r\n */\r\nexport enum ApplicationCommandOptionType {\r\n  Subcommand = 1,\r\n  SubcommandGroup = 2,\r\n  String = 3,\r\n  Integer = 4,\r\n  Boolean = 5,\r\n  User = 6,\r\n  Channel = 7,\r\n  Role = 8,\r\n  Mentionable = 9,\r\n  Number = 10,\r\n  Attachment = 11\r\n}\r\n\r\n/**\r\n * Channel Types\r\n */\r\nexport enum ChannelType {\r\n  GuildText = 0,\r\n  DM = 1,\r\n  GuildVoice = 2,\r\n  GroupDM = 3,\r\n  GuildCategory = 4,\r\n  GuildAnnouncement = 5,\r\n  AnnouncementThread = 10,\r\n  PublicThread = 11,\r\n  PrivateThread = 12,\r\n  GuildStageVoice = 13,\r\n  GuildDirectory = 14,\r\n  GuildForum = 15\r\n}\r\n\r\n/**\r\n * Interaction Response Types\r\n */\r\nexport enum InteractionResponseType {\r\n  Pong = 1,\r\n  ChannelMessageWithSource = 4,\r\n  DeferredChannelMessageWithSource = 5,\r\n  DeferredUpdateMessage = 6,\r\n  UpdateMessage = 7,\r\n  ApplicationCommandAutocompleteResult = 8,\r\n  Modal = 9\r\n}\r\n\r\n/**\r\n * Message Flags\r\n */\r\nexport enum MessageFlags {\r\n  Crossposted = 1 << 0,\r\n  IsCrosspost = 1 << 1,\r\n  SuppressEmbeds = 1 << 2,\r\n  SourceMessageDeleted = 1 << 3,\r\n  Urgent = 1 << 4,\r\n  HasThread = 1 << 5,\r\n  Ephemeral = 1 << 6,\r\n  Loading = 1 << 7,\r\n  FailedToMentionSomeRolesInThread = 1 << 8,\r\n  SuppressNotifications = 1 << 12\r\n}\r\n\r\n/**\r\n * Activity Types\r\n */\r\nexport enum ActivityType {\r\n  Playing = 0,\r\n  Streaming = 1,\r\n  Listening = 2,\r\n  Watching = 3,\r\n  Custom = 4,\r\n  Competing = 5\r\n}\r\n\r\n/**\r\n * Presence Status\r\n */\r\nexport enum PresenceStatus {\r\n  Online = 'online',\r\n  Idle = 'idle',\r\n  DoNotDisturb = 'dnd',\r\n  Invisible = 'invisible',\r\n  Offline = 'offline'\r\n}\r\n\r\n/**\r\n * Permission Flags Bits\r\n * Used for channel permission overwrites\r\n */\r\nexport const PermissionFlagsBits = {\r\n  // General (0-9)\r\n  CreateInstantInvite: 1n << 0n,\r\n  KickMembers: 1n << 1n,\r\n  BanMembers: 1n << 2n,\r\n  Administrator: 1n << 3n,\r\n  ManageChannels: 1n << 4n,\r\n  ManageGuild: 1n << 5n,\r\n  AddReactions: 1n << 6n,\r\n  ViewAuditLog: 1n << 7n,\r\n  ViewGuildInsights: 1n << 8n,\r\n  Stream: 1n << 9n,\r\n  ViewChannel: 1n << 10n,\r\n\r\n  // Messages (11-19)\r\n  SendMessages: 1n << 11n,\r\n  SendTTSMessages: 1n << 12n,\r\n  ManageMessages: 1n << 13n,\r\n  EmbedLinks: 1n << 14n,\r\n  AttachFiles: 1n << 15n,\r\n  ReadMessageHistory: 1n << 16n,\r\n  UseExternalEmojis: 1n << 17n,\r\n  UseSlashCommands: 1n << 18n,\r\n  MentionEveryone: 1n << 19n,\r\n\r\n  // Voice (20-27)\r\n  Connect: 1n << 20n,\r\n  Speak: 1n << 21n,\r\n  MuteMembers: 1n << 22n,\r\n  DeafenMembers: 1n << 23n,\r\n  MoveMembers: 1n << 24n,\r\n  UseVAD: 1n << 25n,\r\n  ChangeCodec: 1n << 26n,\r\n  AudioQualityAdmin: 1n << 27n,\r\n\r\n  // Video and Screen Sharing (28-37)\r\n  VideoCall: 1n << 28n,\r\n  ShareScreen: 1n << 29n,\r\n  ShareCamera: 1n << 30n,\r\n  ControlQuality: 1n << 31n,\r\n  RequestToSpeak: 1n << 32n,\r\n  ManageEvents: 1n << 33n,\r\n  AddMembers: 1n << 34n,\r\n  RemoveMembers: 1n << 35n,\r\n  ChangeGroupIcon: 1n << 36n,\r\n  ChangeDMSettings: 1n << 37n,\r\n\r\n  // Advanced (38-43)\r\n  ManageGroup: 1n << 38n,\r\n  UseActivities: 1n << 39n,\r\n  ModerateMembers: 1n << 40n,\r\n  ManageRoles: 1n << 41n,\r\n  ManageEmojis: 1n << 42n,\r\n  PrioritySpeaker: 1n << 43n,\r\n} as const;\r\n\r\n/**\r\n * Overwrite Type - for permission overwrites\r\n */\r\nexport enum OverwriteType {\r\n  Role = 0,\r\n  Member = 1,\r\n}\r\n"]}
211
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"enums.js","sourceRoot":"","sources":["../src/enums.ts"],"names":[],"mappings":"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","sourcesContent":["/**\r\n * Gateway Intent Bits\r\n */\r\nexport enum GatewayIntentBits {\r\n  Guilds = 1 << 0,\r\n  GuildMembers = 1 << 1,\r\n  GuildModeration = 1 << 2,\r\n  GuildEmojisAndStickers = 1 << 3,\r\n  GuildIntegrations = 1 << 4,\r\n  GuildWebhooks = 1 << 5,\r\n  GuildInvites = 1 << 6,\r\n  GuildVoiceStates = 1 << 7,\r\n  GuildPresences = 1 << 8,\r\n  GuildMessages = 1 << 9,\r\n  GuildMessageReactions = 1 << 10,\r\n  GuildMessageTyping = 1 << 11,\r\n  DirectMessages = 1 << 12,\r\n  DirectMessageReactions = 1 << 13,\r\n  DirectMessageTyping = 1 << 14,\r\n  MessageContent = 1 << 15,\r\n  GuildScheduledEvents = 1 << 16,\r\n  AutoModerationConfiguration = 1 << 20,\r\n  AutoModerationExecution = 1 << 21\r\n}\r\n\r\n/**\r\n * Gateway Opcodes\r\n */\r\nexport enum GatewayOpcodes {\r\n  Dispatch = 0,\r\n  Heartbeat = 1,\r\n  Identify = 2,\r\n  PresenceUpdate = 3,\r\n  VoiceStateUpdate = 4,\r\n  Resume = 6,\r\n  Reconnect = 7,\r\n  RequestGuildMembers = 8,\r\n  InvalidSession = 9,\r\n  Hello = 10,\r\n  HeartbeatAck = 11\r\n}\r\n\r\n/**\r\n * Interaction Types\r\n */\r\nexport enum InteractionType {\r\n  Ping = 1,\r\n  ApplicationCommand = 2,\r\n  MessageComponent = 3,\r\n  ApplicationCommandAutocomplete = 4,\r\n  ModalSubmit = 5\r\n}\r\n\r\n/**\r\n * Application Command Types\r\n */\r\nexport enum ApplicationCommandType {\r\n  ChatInput = 1,\r\n  User = 2,\r\n  Message = 3\r\n}\r\n\r\n/**\r\n * Application Command Option Types\r\n */\r\nexport enum ApplicationCommandOptionType {\r\n  Subcommand = 1,\r\n  SubcommandGroup = 2,\r\n  String = 3,\r\n  Integer = 4,\r\n  Boolean = 5,\r\n  User = 6,\r\n  Channel = 7,\r\n  Role = 8,\r\n  Mentionable = 9,\r\n  Number = 10,\r\n  Attachment = 11\r\n}\r\n\r\n/**\r\n * Channel Types\r\n */\r\nexport enum ChannelType {\r\n  GuildText = 0,\r\n  DM = 1,\r\n  GuildVoice = 2,\r\n  GroupDM = 3,\r\n  GuildCategory = 4,\r\n  GuildAnnouncement = 5,\r\n  GuildStageVoice = 13,\r\n  GuildDirectory = 14,\r\n  GuildForum = 15\r\n}\r\n\r\n/**\r\n * Interaction Response Types\r\n */\r\nexport enum InteractionResponseType {\r\n  Pong = 1,\r\n  ChannelMessageWithSource = 4,\r\n  DeferredChannelMessageWithSource = 5,\r\n  DeferredUpdateMessage = 6,\r\n  UpdateMessage = 7,\r\n  ApplicationCommandAutocompleteResult = 8,\r\n  Modal = 9\r\n}\r\n\r\n/**\r\n * Message Flags\r\n */\r\nexport enum MessageFlags {\r\n  Crossposted = 1 << 0,\r\n  IsCrosspost = 1 << 1,\r\n  SuppressEmbeds = 1 << 2,\r\n  SourceMessageDeleted = 1 << 3,\r\n  Urgent = 1 << 4,\r\n  Ephemeral = 1 << 6,\r\n  Loading = 1 << 7,\r\n  SuppressNotifications = 1 << 12\r\n}\r\n\r\n/**\r\n * Activity Types\r\n */\r\nexport enum ActivityType {\r\n  Playing = 0,\r\n  Streaming = 1,\r\n  Listening = 2,\r\n  Watching = 3,\r\n  Custom = 4,\r\n  Competing = 5\r\n}\r\n\r\n/**\r\n * Presence Status\r\n */\r\nexport enum PresenceStatus {\r\n  Online = 'online',\r\n  Idle = 'idle',\r\n  DoNotDisturb = 'dnd',\r\n  Invisible = 'invisible',\r\n  Offline = 'offline'\r\n}\r\n\r\n/**\r\n * Permission Flags Bits\r\n * Used for channel permission overwrites\r\n */\r\nexport const PermissionFlagsBits = {\r\n  // General (0-9)\r\n  CreateInstantInvite: 1n << 0n,\r\n  KickMembers: 1n << 1n,\r\n  BanMembers: 1n << 2n,\r\n  Administrator: 1n << 3n,\r\n  ManageChannels: 1n << 4n,\r\n  ManageGuild: 1n << 5n,\r\n  AddReactions: 1n << 6n,\r\n  ViewAuditLog: 1n << 7n,\r\n  ViewGuildInsights: 1n << 8n,\r\n  Stream: 1n << 9n,\r\n  ViewChannel: 1n << 10n,\r\n\r\n  // Messages (11-19)\r\n  SendMessages: 1n << 11n,\r\n  SendTTSMessages: 1n << 12n,\r\n  ManageMessages: 1n << 13n,\r\n  EmbedLinks: 1n << 14n,\r\n  AttachFiles: 1n << 15n,\r\n  ReadMessageHistory: 1n << 16n,\r\n  UseExternalEmojis: 1n << 17n,\r\n  UseSlashCommands: 1n << 18n,\r\n  MentionEveryone: 1n << 19n,\r\n\r\n  // Voice (20-27)\r\n  Connect: 1n << 20n,\r\n  Speak: 1n << 21n,\r\n  MuteMembers: 1n << 22n,\r\n  DeafenMembers: 1n << 23n,\r\n  MoveMembers: 1n << 24n,\r\n  UseVAD: 1n << 25n,\r\n  ChangeCodec: 1n << 26n,\r\n  AudioQualityAdmin: 1n << 27n,\r\n\r\n  // Video and Screen Sharing (28-37)\r\n  VideoCall: 1n << 28n,\r\n  ShareScreen: 1n << 29n,\r\n  ShareCamera: 1n << 30n,\r\n  ControlQuality: 1n << 31n,\r\n  RequestToSpeak: 1n << 32n,\r\n  ManageEvents: 1n << 33n,\r\n  AddMembers: 1n << 34n,\r\n  RemoveMembers: 1n << 35n,\r\n  ChangeGroupIcon: 1n << 36n,\r\n  ChangeDMSettings: 1n << 37n,\r\n\r\n  // Advanced (38-43)\r\n  ManageGroup: 1n << 38n,\r\n  UseActivities: 1n << 39n,\r\n  ModerateMembers: 1n << 40n,\r\n  ManageRoles: 1n << 41n,\r\n  ManageEmojis: 1n << 42n,\r\n  PrioritySpeaker: 1n << 43n,\r\n} as const;\r\n\r\n/**\r\n * Overwrite Type - for permission overwrites\r\n */\r\nexport enum OverwriteType {\r\n  Role = 0,\r\n  Member = 1,\r\n}\r\n"]}
@@ -11,9 +11,6 @@ export declare enum ChannelType {
11
11
  GroupDM = 3,
12
12
  GuildCategory = 4,
13
13
  GuildAnnouncement = 5,
14
- AnnouncementThread = 10,
15
- PublicThread = 11,
16
- PrivateThread = 12,
17
14
  GuildStageVoice = 13,
18
15
  GuildDirectory = 14,
19
16
  GuildForum = 15
@@ -15,9 +15,6 @@ var ChannelType;
15
15
  ChannelType[ChannelType["GroupDM"] = 3] = "GroupDM";
16
16
  ChannelType[ChannelType["GuildCategory"] = 4] = "GuildCategory";
17
17
  ChannelType[ChannelType["GuildAnnouncement"] = 5] = "GuildAnnouncement";
18
- ChannelType[ChannelType["AnnouncementThread"] = 10] = "AnnouncementThread";
19
- ChannelType[ChannelType["PublicThread"] = 11] = "PublicThread";
20
- ChannelType[ChannelType["PrivateThread"] = 12] = "PrivateThread";
21
18
  ChannelType[ChannelType["GuildStageVoice"] = 13] = "GuildStageVoice";
22
19
  ChannelType[ChannelType["GuildDirectory"] = 14] = "GuildDirectory";
23
20
  ChannelType[ChannelType["GuildForum"] = 15] = "GuildForum";
@@ -59,7 +56,6 @@ class GuildChannelManager extends BaseManager_1.CachedManager {
59
56
  get isText() { return [ChannelType.GuildText, ChannelType.GuildAnnouncement].includes(this.type); },
60
57
  get isVoice() { return [ChannelType.GuildVoice, ChannelType.GuildStageVoice].includes(this.type); },
61
58
  get isCategory() { return this.type === ChannelType.GuildCategory; },
62
- get isThread() { return [ChannelType.PublicThread, ChannelType.PrivateThread, ChannelType.AnnouncementThread].includes(this.type); },
63
59
  toString() { return `<#${this.id}>`; },
64
60
  async send(content) {
65
61
  return this.guild.client.rest.request('POST', `/channels/${this.id}/messages`, typeof content === 'string' ? { content } : content);
@@ -206,4 +202,4 @@ class ChannelManager extends BaseManager_1.CachedManager {
206
202
  }
207
203
  exports.ChannelManager = ChannelManager;
208
204
  exports.default = GuildChannelManager;
209
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ChannelManager.js","sourceRoot":"","sources":["../../src/managers/ChannelManager.ts"],"names":[],"mappings":"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","sourcesContent":["/**\r\n * Manager for channels with caching and lazy loading\r\n */\r\n\r\nimport { CachedManager } from './BaseManager';\r\nimport { Collection } from '../utils/Collection';\r\n\r\n/** Channel types */\r\nexport enum ChannelType {\r\n  GuildText = 0,\r\n  DM = 1,\r\n  GuildVoice = 2,\r\n  GroupDM = 3,\r\n  GuildCategory = 4,\r\n  GuildAnnouncement = 5,\r\n  AnnouncementThread = 10,\r\n  PublicThread = 11,\r\n  PrivateThread = 12,\r\n  GuildStageVoice = 13,\r\n  GuildDirectory = 14,\r\n  GuildForum = 15,\r\n}\r\n\r\n/**\r\n * Manages channels for a guild\r\n */\r\nexport class GuildChannelManager extends CachedManager<string, any> {\r\n  /** The guild this manager belongs to */\r\n  public readonly guild: any;\r\n\r\n  constructor(guild: any, iterable?: Iterable<any>) {\r\n    super(guild.client, Object as any, iterable);\r\n    this.guild = guild;\r\n  }\r\n\r\n  /**\r\n   * Add a channel to the cache\r\n   */\r\n  _add(data: any, cache = true): any {\r\n    const id = data.id;\r\n    const existing = this.cache.get(id);\r\n    \r\n    if (existing) {\r\n      if (cache) Object.assign(existing, data);\r\n      return existing;\r\n    }\r\n    \r\n    const channel = {\r\n      id,\r\n      guildId: this.guild.id,\r\n      name: data.name,\r\n      type: data.type,\r\n      position: data.position ?? 0,\r\n      parentId: data.parent_id ?? null,\r\n      permissionOverwrites: data.permission_overwrites ?? [],\r\n      topic: data.topic ?? null,\r\n      nsfw: data.nsfw ?? false,\r\n      rateLimitPerUser: data.rate_limit_per_user ?? 0,\r\n      bitrate: data.bitrate,\r\n      userLimit: data.user_limit,\r\n      \r\n      get isText() { return [ChannelType.GuildText, ChannelType.GuildAnnouncement].includes(this.type); },\r\n      get isVoice() { return [ChannelType.GuildVoice, ChannelType.GuildStageVoice].includes(this.type); },\r\n      get isCategory() { return this.type === ChannelType.GuildCategory; },\r\n      get isThread() { return [ChannelType.PublicThread, ChannelType.PrivateThread, ChannelType.AnnouncementThread].includes(this.type); },\r\n      \r\n      toString() { return `<#${this.id}>`; },\r\n      \r\n      async send(content: any) {\r\n        return this.guild.client.rest.request('POST', `/channels/${this.id}/messages`, \r\n          typeof content === 'string' ? { content } : content\r\n        );\r\n      },\r\n      \r\n      async delete(reason?: string) {\r\n        return this.guild.client.rest.request('DELETE', `/channels/${this.id}`, reason ? { reason } : undefined);\r\n      },\r\n      \r\n      async edit(data: any) {\r\n        return this.guild.client.rest.request('PATCH', `/channels/${this.id}`, data);\r\n      },\r\n    };\r\n    \r\n    if (cache) this.cache.set(id, channel);\r\n    return channel;\r\n  }\r\n\r\n  /**\r\n   * Fetch a channel from the API\r\n   */\r\n  async fetch(id: string, options?: { cache?: boolean; force?: boolean }): Promise<any> {\r\n    if (!options?.force) {\r\n      const existing = this.cache.get(id);\r\n      if (existing) return existing;\r\n    }\r\n    \r\n    const data = await this.client.rest.request('GET', `/channels/${id}`);\r\n    return this._add(data, options?.cache ?? true);\r\n  }\r\n\r\n  /**\r\n   * Fetch all channels for the guild\r\n   */\r\n  async fetchAll(): Promise<Collection<string, any>> {\r\n    const data = await this.client.rest.request('GET', `/guilds/${this.guild.id}/channels`);\r\n    const channels = new Collection<string, any>();\r\n    for (const channelData of data) {\r\n      const channel = this._add(channelData);\r\n      channels.set(channel.id, channel);\r\n    }\r\n    return channels;\r\n  }\r\n\r\n  /**\r\n   * Create a new channel\r\n   */\r\n  async create(options: {\r\n    name: string;\r\n    type?: ChannelType;\r\n    topic?: string;\r\n    bitrate?: number;\r\n    userLimit?: number;\r\n    rateLimitPerUser?: number;\r\n    position?: number;\r\n    permissionOverwrites?: any[];\r\n    parent?: string;\r\n    nsfw?: boolean;\r\n    reason?: string;\r\n  }): Promise<any> {\r\n    const body: any = {\r\n      name: options.name,\r\n      type: options.type ?? ChannelType.GuildText,\r\n    };\r\n    if (options.topic) body.topic = options.topic;\r\n    if (options.bitrate) body.bitrate = options.bitrate;\r\n    if (options.userLimit) body.user_limit = options.userLimit;\r\n    if (options.rateLimitPerUser) body.rate_limit_per_user = options.rateLimitPerUser;\r\n    if (options.position !== undefined) body.position = options.position;\r\n    if (options.permissionOverwrites) body.permission_overwrites = options.permissionOverwrites;\r\n    if (options.parent) body.parent_id = options.parent;\r\n    if (options.nsfw !== undefined) body.nsfw = options.nsfw;\r\n    \r\n    const data = await this.client.rest.request('POST', `/guilds/${this.guild.id}/channels`, body);\r\n    return this._add(data);\r\n  }\r\n\r\n  /**\r\n   * Delete a channel\r\n   */\r\n  async delete(id: string, reason?: string): Promise<void> {\r\n    await this.client.rest.request('DELETE', `/channels/${id}`, reason ? { reason } : undefined);\r\n    this.cache.delete(id);\r\n  }\r\n\r\n  /**\r\n   * Edit a channel\r\n   */\r\n  async edit(id: string, data: {\r\n    name?: string;\r\n    type?: ChannelType;\r\n    position?: number;\r\n    topic?: string;\r\n    nsfw?: boolean;\r\n    rateLimitPerUser?: number;\r\n    bitrate?: number;\r\n    userLimit?: number;\r\n    permissionOverwrites?: any[];\r\n    parent?: string | null;\r\n  }): Promise<any> {\r\n    const body: any = {};\r\n    if (data.name) body.name = data.name;\r\n    if (data.type !== undefined) body.type = data.type;\r\n    if (data.position !== undefined) body.position = data.position;\r\n    if (data.topic !== undefined) body.topic = data.topic;\r\n    if (data.nsfw !== undefined) body.nsfw = data.nsfw;\r\n    if (data.rateLimitPerUser !== undefined) body.rate_limit_per_user = data.rateLimitPerUser;\r\n    if (data.bitrate !== undefined) body.bitrate = data.bitrate;\r\n    if (data.userLimit !== undefined) body.user_limit = data.userLimit;\r\n    if (data.permissionOverwrites) body.permission_overwrites = data.permissionOverwrites;\r\n    if (data.parent !== undefined) body.parent_id = data.parent;\r\n    \r\n    const result = await this.client.rest.request('PATCH', `/channels/${id}`, body);\r\n    return this._add(result);\r\n  }\r\n\r\n  /**\r\n   * Set channel positions\r\n   */\r\n  async setPositions(positions: Array<{ channel: string; position: number; parent?: string | null }>): Promise<void> {\r\n    const body = positions.map(p => ({\r\n      id: p.channel,\r\n      position: p.position,\r\n      parent_id: p.parent,\r\n    }));\r\n    await this.client.rest.request('PATCH', `/guilds/${this.guild.id}/channels`, body);\r\n  }\r\n}\r\n\r\n/**\r\n * Global channel manager for the client\r\n */\r\nexport class ChannelManager extends CachedManager<string, any> {\r\n  constructor(client: any, iterable?: Iterable<any>) {\r\n    super(client, Object as any, iterable);\r\n  }\r\n\r\n  _add(data: any, cache = true): any {\r\n    const id = data.id;\r\n    const existing = this.cache.get(id);\r\n    if (existing) {\r\n      if (cache) Object.assign(existing, data);\r\n      return existing;\r\n    }\r\n    \r\n    const channel = { ...data, id };\r\n    if (cache) this.cache.set(id, channel);\r\n    return channel;\r\n  }\r\n\r\n  async fetch(id: string, options?: { cache?: boolean; force?: boolean }): Promise<any> {\r\n    if (!options?.force) {\r\n      const existing = this.cache.get(id);\r\n      if (existing) return existing;\r\n    }\r\n    const data = await this.client.rest.request('GET', `/channels/${id}`);\r\n    return this._add(data, options?.cache ?? true);\r\n  }\r\n}\r\n\r\nexport default GuildChannelManager;\r\n"]}
205
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ChannelManager.js","sourceRoot":"","sources":["../../src/managers/ChannelManager.ts"],"names":[],"mappings":"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","sourcesContent":["/**\r\n * Manager for channels with caching and lazy loading\r\n */\r\n\r\nimport { CachedManager } from './BaseManager';\r\nimport { Collection } from '../utils/Collection';\r\n\r\n/** Channel types */\r\nexport enum ChannelType {\r\n  GuildText = 0,\r\n  DM = 1,\r\n  GuildVoice = 2,\r\n  GroupDM = 3,\r\n  GuildCategory = 4,\r\n  GuildAnnouncement = 5,\r\n  GuildStageVoice = 13,\r\n  GuildDirectory = 14,\r\n  GuildForum = 15,\r\n}\r\n\r\n/**\r\n * Manages channels for a guild\r\n */\r\nexport class GuildChannelManager extends CachedManager<string, any> {\r\n  /** The guild this manager belongs to */\r\n  public readonly guild: any;\r\n\r\n  constructor(guild: any, iterable?: Iterable<any>) {\r\n    super(guild.client, Object as any, iterable);\r\n    this.guild = guild;\r\n  }\r\n\r\n  /**\r\n   * Add a channel to the cache\r\n   */\r\n  _add(data: any, cache = true): any {\r\n    const id = data.id;\r\n    const existing = this.cache.get(id);\r\n    \r\n    if (existing) {\r\n      if (cache) Object.assign(existing, data);\r\n      return existing;\r\n    }\r\n    \r\n    const channel = {\r\n      id,\r\n      guildId: this.guild.id,\r\n      name: data.name,\r\n      type: data.type,\r\n      position: data.position ?? 0,\r\n      parentId: data.parent_id ?? null,\r\n      permissionOverwrites: data.permission_overwrites ?? [],\r\n      topic: data.topic ?? null,\r\n      nsfw: data.nsfw ?? false,\r\n      rateLimitPerUser: data.rate_limit_per_user ?? 0,\r\n      bitrate: data.bitrate,\r\n      userLimit: data.user_limit,\r\n      \r\n      get isText() { return [ChannelType.GuildText, ChannelType.GuildAnnouncement].includes(this.type); },\r\n      get isVoice() { return [ChannelType.GuildVoice, ChannelType.GuildStageVoice].includes(this.type); },\r\n      get isCategory() { return this.type === ChannelType.GuildCategory; },\r\n      \r\n      toString() { return `<#${this.id}>`; },\r\n      \r\n      async send(content: any) {\r\n        return this.guild.client.rest.request('POST', `/channels/${this.id}/messages`, \r\n          typeof content === 'string' ? { content } : content\r\n        );\r\n      },\r\n      \r\n      async delete(reason?: string) {\r\n        return this.guild.client.rest.request('DELETE', `/channels/${this.id}`, reason ? { reason } : undefined);\r\n      },\r\n      \r\n      async edit(data: any) {\r\n        return this.guild.client.rest.request('PATCH', `/channels/${this.id}`, data);\r\n      },\r\n    };\r\n    \r\n    if (cache) this.cache.set(id, channel);\r\n    return channel;\r\n  }\r\n\r\n  /**\r\n   * Fetch a channel from the API\r\n   */\r\n  async fetch(id: string, options?: { cache?: boolean; force?: boolean }): Promise<any> {\r\n    if (!options?.force) {\r\n      const existing = this.cache.get(id);\r\n      if (existing) return existing;\r\n    }\r\n    \r\n    const data = await this.client.rest.request('GET', `/channels/${id}`);\r\n    return this._add(data, options?.cache ?? true);\r\n  }\r\n\r\n  /**\r\n   * Fetch all channels for the guild\r\n   */\r\n  async fetchAll(): Promise<Collection<string, any>> {\r\n    const data = await this.client.rest.request('GET', `/guilds/${this.guild.id}/channels`);\r\n    const channels = new Collection<string, any>();\r\n    for (const channelData of data) {\r\n      const channel = this._add(channelData);\r\n      channels.set(channel.id, channel);\r\n    }\r\n    return channels;\r\n  }\r\n\r\n  /**\r\n   * Create a new channel\r\n   */\r\n  async create(options: {\r\n    name: string;\r\n    type?: ChannelType;\r\n    topic?: string;\r\n    bitrate?: number;\r\n    userLimit?: number;\r\n    rateLimitPerUser?: number;\r\n    position?: number;\r\n    permissionOverwrites?: any[];\r\n    parent?: string;\r\n    nsfw?: boolean;\r\n    reason?: string;\r\n  }): Promise<any> {\r\n    const body: any = {\r\n      name: options.name,\r\n      type: options.type ?? ChannelType.GuildText,\r\n    };\r\n    if (options.topic) body.topic = options.topic;\r\n    if (options.bitrate) body.bitrate = options.bitrate;\r\n    if (options.userLimit) body.user_limit = options.userLimit;\r\n    if (options.rateLimitPerUser) body.rate_limit_per_user = options.rateLimitPerUser;\r\n    if (options.position !== undefined) body.position = options.position;\r\n    if (options.permissionOverwrites) body.permission_overwrites = options.permissionOverwrites;\r\n    if (options.parent) body.parent_id = options.parent;\r\n    if (options.nsfw !== undefined) body.nsfw = options.nsfw;\r\n    \r\n    const data = await this.client.rest.request('POST', `/guilds/${this.guild.id}/channels`, body);\r\n    return this._add(data);\r\n  }\r\n\r\n  /**\r\n   * Delete a channel\r\n   */\r\n  async delete(id: string, reason?: string): Promise<void> {\r\n    await this.client.rest.request('DELETE', `/channels/${id}`, reason ? { reason } : undefined);\r\n    this.cache.delete(id);\r\n  }\r\n\r\n  /**\r\n   * Edit a channel\r\n   */\r\n  async edit(id: string, data: {\r\n    name?: string;\r\n    type?: ChannelType;\r\n    position?: number;\r\n    topic?: string;\r\n    nsfw?: boolean;\r\n    rateLimitPerUser?: number;\r\n    bitrate?: number;\r\n    userLimit?: number;\r\n    permissionOverwrites?: any[];\r\n    parent?: string | null;\r\n  }): Promise<any> {\r\n    const body: any = {};\r\n    if (data.name) body.name = data.name;\r\n    if (data.type !== undefined) body.type = data.type;\r\n    if (data.position !== undefined) body.position = data.position;\r\n    if (data.topic !== undefined) body.topic = data.topic;\r\n    if (data.nsfw !== undefined) body.nsfw = data.nsfw;\r\n    if (data.rateLimitPerUser !== undefined) body.rate_limit_per_user = data.rateLimitPerUser;\r\n    if (data.bitrate !== undefined) body.bitrate = data.bitrate;\r\n    if (data.userLimit !== undefined) body.user_limit = data.userLimit;\r\n    if (data.permissionOverwrites) body.permission_overwrites = data.permissionOverwrites;\r\n    if (data.parent !== undefined) body.parent_id = data.parent;\r\n    \r\n    const result = await this.client.rest.request('PATCH', `/channels/${id}`, body);\r\n    return this._add(result);\r\n  }\r\n\r\n  /**\r\n   * Set channel positions\r\n   */\r\n  async setPositions(positions: Array<{ channel: string; position: number; parent?: string | null }>): Promise<void> {\r\n    const body = positions.map(p => ({\r\n      id: p.channel,\r\n      position: p.position,\r\n      parent_id: p.parent,\r\n    }));\r\n    await this.client.rest.request('PATCH', `/guilds/${this.guild.id}/channels`, body);\r\n  }\r\n}\r\n\r\n/**\r\n * Global channel manager for the client\r\n */\r\nexport class ChannelManager extends CachedManager<string, any> {\r\n  constructor(client: any, iterable?: Iterable<any>) {\r\n    super(client, Object as any, iterable);\r\n  }\r\n\r\n  _add(data: any, cache = true): any {\r\n    const id = data.id;\r\n    const existing = this.cache.get(id);\r\n    if (existing) {\r\n      if (cache) Object.assign(existing, data);\r\n      return existing;\r\n    }\r\n    \r\n    const channel = { ...data, id };\r\n    if (cache) this.cache.set(id, channel);\r\n    return channel;\r\n  }\r\n\r\n  async fetch(id: string, options?: { cache?: boolean; force?: boolean }): Promise<any> {\r\n    if (!options?.force) {\r\n      const existing = this.cache.get(id);\r\n      if (existing) return existing;\r\n    }\r\n    const data = await this.client.rest.request('GET', `/channels/${id}`);\r\n    return this._add(data, options?.cache ?? true);\r\n  }\r\n}\r\n\r\nexport default GuildChannelManager;\r\n"]}
@@ -440,30 +440,6 @@ export declare class REST {
440
440
  * Get guild invites
441
441
  */
442
442
  getGuildInvites(guildId: string): Promise<any[]>;
443
- /**
444
- * Create a thread from a message
445
- */
446
- createThreadFromMessage(guildId: string, channelId: string, messageId: string, data: {
447
- name: string;
448
- auto_archive_duration?: number;
449
- }): Promise<any>;
450
- /**
451
- * Create a thread without a message
452
- */
453
- createThread(guildId: string, channelId: string, data: {
454
- name: string;
455
- type?: number;
456
- auto_archive_duration?: number;
457
- invitable?: boolean;
458
- }): Promise<any>;
459
- /**
460
- * Join a thread
461
- */
462
- joinThread(channelId: string): Promise<void>;
463
- /**
464
- * Leave a thread
465
- */
466
- leaveThread(channelId: string): Promise<void>;
467
443
  /**
468
444
  * Pin a message
469
445
  */
package/dist/rest/REST.js CHANGED
@@ -156,6 +156,32 @@ class REST {
156
156
  // Support EmbedBuilder instances - extract raw data via toJSON()
157
157
  const rawEmbed = typeof embed.toJSON === 'function' ? embed.toJSON() : embed;
158
158
  const processedEmbed = { ...rawEmbed };
159
+ // Normalize thumbnail: string → { url: string }
160
+ if (typeof processedEmbed.thumbnail === 'string') {
161
+ processedEmbed.thumbnail = { url: processedEmbed.thumbnail };
162
+ }
163
+ // Normalize image: string → { url: string }
164
+ if (typeof processedEmbed.image === 'string') {
165
+ processedEmbed.image = { url: processedEmbed.image };
166
+ }
167
+ // Normalize color: hex string → number
168
+ if (typeof processedEmbed.color === 'string') {
169
+ processedEmbed.color = parseInt(processedEmbed.color.replace('#', ''), 16);
170
+ }
171
+ // Normalize timestamp: Date → ISO string
172
+ if (processedEmbed.timestamp instanceof Date) {
173
+ processedEmbed.timestamp = processedEmbed.timestamp.toISOString();
174
+ }
175
+ else if (typeof processedEmbed.timestamp === 'number') {
176
+ processedEmbed.timestamp = new Date(processedEmbed.timestamp).toISOString();
177
+ }
178
+ // Normalize footer.iconURL → footer.icon_url
179
+ if (processedEmbed.footer) {
180
+ if (processedEmbed.footer.iconURL && !processedEmbed.footer.icon_url) {
181
+ processedEmbed.footer = { ...processedEmbed.footer, icon_url: processedEmbed.footer.iconURL };
182
+ delete processedEmbed.footer.iconURL;
183
+ }
184
+ }
159
185
  // Process description
160
186
  if (rawEmbed.description) {
161
187
  const { content, mentions } = this.processMentions(rawEmbed.description, allMentions);
@@ -772,31 +798,6 @@ class REST {
772
798
  async getGuildInvites(guildId) {
773
799
  return this.request('GET', `/bot/guilds/${guildId}/invites`);
774
800
  }
775
- // ==================== Threads ====================
776
- /**
777
- * Create a thread from a message
778
- */
779
- async createThreadFromMessage(guildId, channelId, messageId, data) {
780
- return this.request('POST', `/bot/guilds/${guildId}/channels/${channelId}/messages/${messageId}/threads`, data);
781
- }
782
- /**
783
- * Create a thread without a message
784
- */
785
- async createThread(guildId, channelId, data) {
786
- return this.request('POST', `/bot/guilds/${guildId}/channels/${channelId}/threads`, data);
787
- }
788
- /**
789
- * Join a thread
790
- */
791
- async joinThread(channelId) {
792
- await this.request('PUT', `/bot/channels/${channelId}/thread-members/@me`);
793
- }
794
- /**
795
- * Leave a thread
796
- */
797
- async leaveThread(channelId) {
798
- await this.request('DELETE', `/bot/channels/${channelId}/thread-members/@me`);
799
- }
800
801
  // ==================== Pins ====================
801
802
  /**
802
803
  * Pin a message
@@ -863,4 +864,4 @@ class REST {
863
864
  }
864
865
  }
865
866
  exports.REST = REST;
866
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"REST.js","sourceRoot":"","sources":["../../src/rest/REST.ts"],"names":[],"mappings":"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","sourcesContent":["import { APIMessage, APIApplicationCommand, APIEmbed } from '../types';\r\n\r\n/**\r\n * Mention data structure for our system\r\n */\r\nexport interface MentionUser {\r\n  id: number;\r\n  username: string;\r\n}\r\n\r\nexport interface MentionRole {\r\n  id: string;\r\n  name?: string;\r\n}\r\n\r\nexport interface MentionsData {\r\n  users?: MentionUser[];\r\n  roles?: MentionRole[];\r\n  everyone?: boolean;\r\n}\r\n\r\n/**\r\n * User cache entry\r\n */\r\ninterface CachedUser {\r\n  id: number;\r\n  username: string;\r\n  displayName?: string;\r\n  cachedAt: number;\r\n}\r\n\r\n/**\r\n * REST API client for Jubbio\r\n */\r\nexport class REST {\r\n  private baseUrl: string;\r\n  private token: string = '';\r\n  \r\n  // User cache for mention resolution (ID -> username)\r\n  private userCache: Map<number, CachedUser> = new Map();\r\n  private readonly USER_CACHE_TTL = 5 * 60 * 1000; // 5 dakika\r\n\r\n  constructor(baseUrl: string = 'https://gateway.jubbio.com/api/v1') {\r\n    this.baseUrl = baseUrl;\r\n  }\r\n\r\n  // ==================== Mention Helpers ====================\r\n\r\n  /**\r\n   * Cache a user for mention resolution\r\n   * Bot'lar interaction'dan gelen user bilgisini cache'leyebilir\r\n   */\r\n  cacheUser(user: { id: string | number; username: string; displayName?: string; display_name?: string }): void {\r\n    const userId = typeof user.id === 'string' ? parseInt(user.id, 10) : user.id;\r\n    this.userCache.set(userId, {\r\n      id: userId,\r\n      username: user.username,\r\n      displayName: user.displayName || user.display_name,\r\n      cachedAt: Date.now()\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Cache multiple users\r\n   */\r\n  cacheUsers(users: Array<{ id: string | number; username: string; displayName?: string; display_name?: string }>): void {\r\n    users.forEach(user => this.cacheUser(user));\r\n  }\r\n\r\n  /**\r\n   * Get cached user by ID\r\n   */\r\n  getCachedUser(userId: number): CachedUser | undefined {\r\n    const cached = this.userCache.get(userId);\r\n    if (cached && Date.now() - cached.cachedAt < this.USER_CACHE_TTL) {\r\n      return cached;\r\n    }\r\n    // Expired, remove from cache\r\n    if (cached) {\r\n      this.userCache.delete(userId);\r\n    }\r\n    return undefined;\r\n  }\r\n\r\n  /**\r\n   * Format a user mention\r\n   * Returns both the text format and mentions data\r\n   * \r\n   * @example\r\n   * const mention = rest.formatMention(user);\r\n   * // mention.text = \"@ilkay\"\r\n   * // mention.data = { users: [{ id: 1, username: \"ilkay\" }] }\r\n   */\r\n  formatMention(user: { id: string | number; username: string }): { text: string; data: MentionsData } {\r\n    const userId = typeof user.id === 'string' ? parseInt(user.id, 10) : user.id;\r\n    return {\r\n      text: `@${user.username}`,\r\n      data: {\r\n        users: [{ id: userId, username: user.username }]\r\n      }\r\n    };\r\n  }\r\n\r\n  /**\r\n   * Parse mentions (<@ID>) and convert to our format (@username)\r\n   * Also builds the mentions data structure\r\n   * \r\n   * @param content - Message content with mentions\r\n   * @param existingMentions - Existing mentions data to merge with\r\n   * @returns Processed content and mentions data\r\n   */\r\n  private processMentions(content: string, existingMentions?: MentionsData): { content: string; mentions: MentionsData } {\r\n    const mentions: MentionsData = {\r\n      users: [...(existingMentions?.users || [])],\r\n      roles: [...(existingMentions?.roles || [])],\r\n      everyone: existingMentions?.everyone\r\n    };\r\n\r\n    // Track already added user IDs to avoid duplicates\r\n    const addedUserIds = new Set(mentions.users?.map(u => u.id) || []);\r\n\r\n    // Parse <@ID> format (user mentions)\r\n    const userMentionRegex = /<@!?(\\d+)>/g;\r\n    let processedContent = content;\r\n    let match;\r\n\r\n    while ((match = userMentionRegex.exec(content)) !== null) {\r\n      const userId = parseInt(match[1], 10);\r\n      const fullMatch = match[0];\r\n\r\n      // Try to get username from cache\r\n      const cachedUser = this.getCachedUser(userId);\r\n      \r\n      if (cachedUser) {\r\n        // Replace <@ID> with @username\r\n        processedContent = processedContent.replace(fullMatch, `@${cachedUser.username}`);\r\n        \r\n        // Add to mentions if not already added\r\n        if (!addedUserIds.has(userId)) {\r\n          mentions.users!.push({ id: userId, username: cachedUser.username });\r\n          addedUserIds.add(userId);\r\n        }\r\n      } else {\r\n        // User not in cache - keep as @User_ID format (backend will resolve)\r\n        processedContent = processedContent.replace(fullMatch, `@User_${userId}`);\r\n        \r\n        // Still add to mentions with placeholder username\r\n        if (!addedUserIds.has(userId)) {\r\n          mentions.users!.push({ id: userId, username: `User_${userId}` });\r\n          addedUserIds.add(userId);\r\n        }\r\n      }\r\n    }\r\n\r\n    // Parse <@&ID> format (role mentions)\r\n    const roleMentionRegex = /<@&(\\d+)>/g;\r\n    const addedRoleIds = new Set(mentions.roles?.map(r => r.id) || []);\r\n\r\n    while ((match = roleMentionRegex.exec(content)) !== null) {\r\n      const roleId = match[1];\r\n      const fullMatch = match[0];\r\n\r\n      // Replace with @role format (backend handles role resolution)\r\n      processedContent = processedContent.replace(fullMatch, `@role_${roleId}`);\r\n      \r\n      if (!addedRoleIds.has(roleId)) {\r\n        mentions.roles!.push({ id: roleId });\r\n        addedRoleIds.add(roleId);\r\n      }\r\n    }\r\n\r\n    // Parse @everyone and @here\r\n    if (content.includes('@everyone')) {\r\n      mentions.everyone = true;\r\n    }\r\n\r\n    // Clean up empty arrays\r\n    if (mentions.users?.length === 0) delete mentions.users;\r\n    if (mentions.roles?.length === 0) delete mentions.roles;\r\n\r\n    return { content: processedContent, mentions };\r\n  }\r\n\r\n  /**\r\n   * Prepare message data with processed mentions\r\n   * Automatically converts mentions to our format\r\n   */\r\n  private prepareMessageData(data: {\r\n    content?: string;\r\n    embeds?: APIEmbed[];\r\n    components?: any[];\r\n    mentions?: MentionsData;\r\n    message_reference?: { message_id: string };\r\n  }): any {\r\n    const result: any = { ...data };\r\n\r\n    // Resolve components (ActionRowBuilder / ButtonBuilder instances)\r\n    if (data.components && data.components.length > 0) {\r\n      result.components = data.components.map((c: any) =>\r\n        typeof c.toJSON === 'function' ? c.toJSON() : c\r\n      );\r\n    }\r\n\r\n    let allMentions: MentionsData = { ...data.mentions };\r\n\r\n    // Process mentions in content if present\r\n    if (data.content) {\r\n      const { content, mentions } = this.processMentions(data.content, allMentions);\r\n      result.content = content;\r\n      allMentions = mentions;\r\n    }\r\n\r\n    // Process mentions in embeds (description, title, footer, fields)\r\n    if (data.embeds && data.embeds.length > 0) {\r\n      result.embeds = data.embeds.map(embed => {\r\n        // Support EmbedBuilder instances - extract raw data via toJSON()\r\n        const rawEmbed = typeof (embed as any).toJSON === 'function' ? (embed as any).toJSON() : embed;\r\n        const processedEmbed: any = { ...rawEmbed };\r\n        \r\n        // Process description\r\n        if (rawEmbed.description) {\r\n          const { content, mentions } = this.processMentions(rawEmbed.description, allMentions);\r\n          processedEmbed.description = content;\r\n          allMentions = mentions;\r\n        }\r\n        \r\n        // Process title\r\n        if (rawEmbed.title) {\r\n          const { content, mentions } = this.processMentions(rawEmbed.title, allMentions);\r\n          processedEmbed.title = content;\r\n          allMentions = mentions;\r\n        }\r\n        \r\n        // Process footer text\r\n        if (rawEmbed.footer?.text) {\r\n          const { content, mentions } = this.processMentions(rawEmbed.footer.text, allMentions);\r\n          processedEmbed.footer = { ...rawEmbed.footer, text: content };\r\n          allMentions = mentions;\r\n        }\r\n        \r\n        // Process fields\r\n        if (rawEmbed.fields && rawEmbed.fields.length > 0) {\r\n          processedEmbed.fields = rawEmbed.fields.map((field: any) => {\r\n            const processedField: any = { ...field };\r\n            if (field.value) {\r\n              const { content, mentions } = this.processMentions(field.value, allMentions);\r\n              processedField.value = content;\r\n              allMentions = mentions;\r\n            }\r\n            if (field.name) {\r\n              const { content, mentions } = this.processMentions(field.name, allMentions);\r\n              processedField.name = content;\r\n              allMentions = mentions;\r\n            }\r\n            return processedField;\r\n          });\r\n        }\r\n        \r\n        return processedEmbed;\r\n      });\r\n    }\r\n\r\n    // Add merged mentions to result\r\n    if (allMentions.users?.length || allMentions.roles?.length || allMentions.everyone) {\r\n      result.mentions = allMentions;\r\n    }\r\n\r\n    return result;\r\n  }\r\n\r\n  /**\r\n   * Set the bot token\r\n   */\r\n  setToken(token: string): this {\r\n    this.token = token;\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Make an authenticated request\r\n   */\r\n  private async request<T>(method: string, path: string, body?: any): Promise<T> {\r\n    const url = `${this.baseUrl}${path}`;\r\n    \r\n    // Debug log\r\n    console.log(`[REST] ${method} ${url}`, body ? JSON.stringify(body) : '');\r\n    \r\n    const response = await fetch(url, {\r\n      method,\r\n      headers: {\r\n        'Authorization': `Bot ${this.token}`,\r\n        'Content-Type': 'application/json'\r\n      },\r\n      body: body ? JSON.stringify(body) : undefined\r\n    });\r\n\r\n    if (!response.ok) {\r\n      const error = await response.text();\r\n      throw new Error(`API Error ${response.status}: ${error}`);\r\n    }\r\n\r\n    // Handle empty responses\r\n    const text = await response.text();\r\n    if (!text) return {} as T;\r\n    \r\n    return JSON.parse(text);\r\n  }\r\n\r\n  // ==================== Messages ====================\r\n\r\n  /**\r\n   * Create a message in a channel\r\n   * Automatically processes mentions (<@ID>) to our format (@username)\r\n   * \r\n   * @example\r\n   * // Mention style (auto-converted):\r\n   * await rest.createMessage(guildId, channelId, {\r\n   *   content: 'Hello <@123>!',  // Becomes \"Hello @username!\"\r\n   * });\r\n   * \r\n   * // Our native format:\r\n   * await rest.createMessage(guildId, channelId, {\r\n   *   content: 'Hello @ilkay!',\r\n   *   mentions: { users: [{ id: 123, username: 'ilkay' }] }\r\n   * });\r\n   */\r\n  async createMessage(guildIdOrChannelId: string, channelIdOrData: string | {\r\n    content?: string;\r\n    embeds?: APIEmbed[];\r\n    components?: any[];\r\n    mentions?: MentionsData;\r\n    files?: Array<{ name: string; data: Buffer }>;\r\n    message_reference?: { message_id: string };\r\n    interactionId?: string;\r\n  }, data?: {\r\n    content?: string;\r\n    embeds?: APIEmbed[];\r\n    components?: any[];\r\n    mentions?: MentionsData;\r\n    files?: Array<{ name: string; data: Buffer }>;\r\n    message_reference?: { message_id: string };\r\n    interactionId?: string;\r\n  }): Promise<APIMessage> {\r\n    // İki kullanım şekli:\r\n    // 1. createMessage(guildId, channelId, data) - guildId ile (tercih edilen)\r\n    // 2. createMessage(channelId, data) - guildId olmadan (eski format, hata verir)\r\n    \r\n    let guildId: string;\r\n    let channelId: string;\r\n    let messageData: any;\r\n    \r\n    if (typeof channelIdOrData === 'string' && data) {\r\n      // Yeni format: createMessage(guildId, channelId, data)\r\n      guildId = guildIdOrChannelId;\r\n      channelId = channelIdOrData;\r\n      messageData = this.prepareMessageData(data);\r\n      \r\n      // Add interaction_id if provided\r\n      if (data.interactionId) {\r\n        messageData.interaction_id = data.interactionId;\r\n      }\r\n    } else if (typeof channelIdOrData === 'object') {\r\n      // Eski format: createMessage(channelId, data) - guildId yok\r\n      // Bu format artık desteklenmiyor, hata fırlat\r\n      throw new Error('createMessage requires guildId: createMessage(guildId, channelId, data)');\r\n    } else {\r\n      throw new Error('Invalid createMessage arguments');\r\n    }\r\n    \r\n    return this.request<APIMessage>('POST', `/bot/guilds/${guildId}/channels/${channelId}/messages`, messageData);\r\n  }\r\n\r\n  /**\r\n   * Create an ephemeral message that is only visible to a specific user\r\n   * Ephemeral messages are NOT saved to database - they are only sent via WebSocket\r\n   * \r\n   * @example\r\n   * // Send a warning only visible to the user\r\n   * await rest.createEphemeralMessage(guildId, channelId, targetUserId, {\r\n   *   embeds: [warningEmbed]\r\n   * });\r\n   */\r\n  async createEphemeralMessage(guildId: string, channelId: string, targetUserId: string | number, data: {\r\n    content?: string;\r\n    embeds?: APIEmbed[];\r\n  }): Promise<{ id: string; ephemeral: boolean; flags: number }> {\r\n    const messageData = this.prepareMessageData(data);\r\n    \r\n    return this.request<{ id: string; ephemeral: boolean; flags: number }>('POST', `/bot/guilds/${guildId}/channels/${channelId}/messages`, {\r\n      ...messageData,\r\n      flags: 64, // EPHEMERAL flag\r\n      target_user_id: typeof targetUserId === 'string' ? parseInt(targetUserId, 10) : targetUserId\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Create a DM message\r\n   */\r\n  async createDMMessage(channelId: string, data: {\r\n    content?: string;\r\n    embeds?: APIEmbed[];\r\n  }): Promise<APIMessage> {\r\n    return this.request<APIMessage>('POST', `/bot/dm/${channelId}`, data);\r\n  }\r\n\r\n  /**\r\n   * Edit a message\r\n   * Automatically processes mentions\r\n   */\r\n  async editMessage(guildId: string, channelId: string, messageId: string, data: {\r\n    content?: string;\r\n    embeds?: APIEmbed[];\r\n    components?: any[];\r\n    mentions?: MentionsData;\r\n  }): Promise<APIMessage> {\r\n    const path = `/bot/guilds/${guildId}/channels/${channelId}/messages/${messageId}`;\r\n    const processedData = this.prepareMessageData(data);\r\n    return this.request<APIMessage>('PATCH', path, processedData);\r\n  }\r\n\r\n  /**\r\n   * Delete a message\r\n   */\r\n  async deleteMessage(guildId: string, channelId: string, messageId: string): Promise<void> {\r\n    const path = `/bot/guilds/${guildId}/channels/${channelId}/messages/${messageId}`;\r\n    await this.request<void>('DELETE', path);\r\n  }\r\n\r\n  /**\r\n   * Add a reaction to a message\r\n   */\r\n  async addReaction(guildId: string, channelId: string, messageId: string, emoji: string): Promise<void> {\r\n    const path = `/bot/guilds/${guildId}/channels/${channelId}/messages/${messageId}/reactions/${encodeURIComponent(emoji)}/@me`;\r\n    await this.request<void>('PUT', path);\r\n  }\r\n\r\n  /**\r\n   * Upload an attachment to a channel\r\n   */\r\n  async uploadAttachment(guildId: string, channelId: string, file: { name: string; data: Buffer; contentType?: string }): Promise<{ id: string; url: string; filename: string }> {\r\n    const FormData = require('form-data');\r\n    const form = new FormData();\r\n    \r\n    // form-data expects the buffer directly with options\r\n    form.append('file', file.data, {\r\n      filename: file.name,\r\n      contentType: file.contentType || 'text/plain'\r\n    });\r\n    \r\n    const url = `${this.baseUrl}/bot/guilds/${guildId}/channels/${channelId}/attachments`;\r\n    \r\n    console.log(`[REST] Uploading attachment: ${file.name} (${file.data.length} bytes)`);\r\n    \r\n    const response = await fetch(url, {\r\n      method: 'POST',\r\n      headers: {\r\n        'Authorization': `Bot ${this.token}`,\r\n        ...form.getHeaders()\r\n      },\r\n      body: form.getBuffer()\r\n    });\r\n    \r\n    if (!response.ok) {\r\n      const error = await response.text();\r\n      throw new Error(`API Error ${response.status}: ${error}`);\r\n    }\r\n    \r\n    return response.json() as Promise<{ id: string; url: string; filename: string }>;\r\n  }\r\n\r\n  /**\r\n   * Create a message with a file attachment\r\n   */\r\n  async createMessageWithFile(guildId: string, channelId: string, data: {\r\n    content?: string;\r\n    file: { name: string; data: Buffer; contentType?: string };\r\n    interactionId?: string;\r\n  }): Promise<APIMessage> {\r\n    const FormData = require('form-data');\r\n    const form = new FormData();\r\n    \r\n    // Add content if provided\r\n    if (data.content) {\r\n      form.append('content', data.content);\r\n    }\r\n    \r\n    // Add interaction_id if provided (for deferred response matching)\r\n    if (data.interactionId) {\r\n      form.append('interaction_id', data.interactionId);\r\n    }\r\n    \r\n    // Add file\r\n    form.append('files', data.file.data, {\r\n      filename: data.file.name,\r\n      contentType: data.file.contentType || 'text/plain'\r\n    });\r\n    \r\n    const url = `${this.baseUrl}/bot/guilds/${guildId}/channels/${channelId}/messages`;\r\n    \r\n    console.log(`[REST] Creating message with file: ${data.file.name} (${data.file.data.length} bytes)${data.interactionId ? ` [interaction: ${data.interactionId}]` : ''}`);\r\n    \r\n    const response = await fetch(url, {\r\n      method: 'POST',\r\n      headers: {\r\n        'Authorization': `Bot ${this.token}`,\r\n        ...form.getHeaders()\r\n      },\r\n      body: form.getBuffer()\r\n    });\r\n    \r\n    if (!response.ok) {\r\n      const error = await response.text();\r\n      throw new Error(`API Error ${response.status}: ${error}`);\r\n    }\r\n    \r\n    return response.json() as Promise<APIMessage>;\r\n  }\r\n\r\n  // ==================== Interactions ====================\r\n\r\n  /**\r\n   * Create an interaction response\r\n   * Automatically processes mentions in content and embeds\r\n   */\r\n  async createInteractionResponse(interactionId: string, token: string, data: {\r\n    type: number;\r\n    data?: any;\r\n  }): Promise<void> {\r\n    console.log(`📤 Interaction response: ${interactionId} -> type ${data.type}`);\r\n    try {\r\n      // Process mentions in response data if present\r\n      let processedData = data;\r\n      if (data.data && (data.data.content || data.data.embeds)) {\r\n        processedData = {\r\n          ...data,\r\n          data: this.prepareMessageData(data.data)\r\n        };\r\n      }\r\n      \r\n      await this.request<void>('POST', `/interactions/${interactionId}/${token}/callback`, processedData);\r\n      console.log(`✅ Interaction response sent`);\r\n    } catch (error) {\r\n      console.error(`❌ Interaction response error:`, error);\r\n      throw error;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Edit the original interaction response\r\n   * If files are provided, creates a new message with files (since webhook edit doesn't support file upload)\r\n   * Automatically processes mentions\r\n   */\r\n  async editInteractionResponse(token: string, data: {\r\n    content?: string;\r\n    embeds?: APIEmbed[];\r\n    components?: any[];\r\n    mentions?: MentionsData;\r\n    files?: Array<{ name: string; data: Buffer; contentType?: string }>;\r\n  }, guildId?: string, channelId?: string, interactionId?: string): Promise<void> {\r\n    const appId = this.getApplicationId();\r\n    \r\n    // Process mentions in content\r\n    const processedData = this.prepareMessageData(data);\r\n    \r\n    // If files are present and we have guild/channel info, create message with file instead\r\n    if (data.files && data.files.length > 0 && guildId && channelId) {\r\n      console.log(`[REST] editInteractionResponse with ${data.files.length} files - using createMessageWithFile`);\r\n      \r\n      // Create message with file\r\n      const file = data.files[0]; // For now, support single file\r\n      await this.createMessageWithFile(guildId, channelId, {\r\n        content: processedData.content,\r\n        file: file,\r\n        interactionId: interactionId\r\n      });\r\n      return;\r\n    }\r\n    \r\n    // If we have guildId, channelId and interactionId, create a new message with interaction_id\r\n    // This is needed because our deferred response doesn't create a message\r\n    if (guildId && channelId && interactionId) {\r\n      console.log(`[REST] editInteractionResponse - creating message with interaction_id: ${interactionId}`);\r\n      \r\n      const payload: any = {\r\n        interaction_id: interactionId\r\n      };\r\n      if (processedData.content !== undefined) payload.content = processedData.content;\r\n      if (processedData.embeds) payload.embeds = processedData.embeds;\r\n      if (processedData.components) payload.components = processedData.components;\r\n      if (processedData.mentions) payload.mentions = processedData.mentions;\r\n      \r\n      await this.request<void>('POST', `/bot/guilds/${guildId}/channels/${channelId}/messages`, payload);\r\n      return;\r\n    }\r\n    \r\n    // Fallback: Regular edit without files (webhook PATCH)\r\n    const payload: any = {};\r\n    if (processedData.content !== undefined) payload.content = processedData.content;\r\n    if (processedData.embeds) payload.embeds = processedData.embeds;\r\n    if (processedData.components) payload.components = processedData.components;\r\n    if (processedData.mentions) payload.mentions = processedData.mentions;\r\n    \r\n    await this.request<void>('PATCH', `/webhooks/${appId}/${token}/messages/@original`, payload);\r\n  }\r\n\r\n  /**\r\n   * Delete the original interaction response\r\n   */\r\n  async deleteInteractionResponse(token: string): Promise<void> {\r\n    const appId = this.getApplicationId();\r\n    await this.request<void>('DELETE', `/webhooks/${appId}/${token}/messages/@original`);\r\n  }\r\n\r\n  /**\r\n   * Create a followup message\r\n   * Automatically processes mentions\r\n   */\r\n  async createFollowup(token: string, data: {\r\n    content?: string;\r\n    embeds?: APIEmbed[];\r\n    mentions?: MentionsData;\r\n    flags?: number;\r\n  }): Promise<void> {\r\n    const appId = this.getApplicationId();\r\n    const processedData = this.prepareMessageData(data);\r\n    await this.request<void>('POST', `/webhooks/${appId}/${token}`, processedData);\r\n  }\r\n\r\n  // ==================== Commands ====================\r\n\r\n  /**\r\n   * Register global application commands\r\n   */\r\n  async registerGlobalCommands(commands: APIApplicationCommand[]): Promise<void> {\r\n    const appId = this.getApplicationId();\r\n    \r\n    for (const command of commands) {\r\n      await this.request<void>('POST', `/applications/${appId}/commands`, command);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Register guild-specific commands\r\n   */\r\n  async registerGuildCommands(guildId: string, commands: APIApplicationCommand[]): Promise<void> {\r\n    const appId = this.getApplicationId();\r\n    \r\n    for (const command of commands) {\r\n      await this.request<void>('POST', `/applications/${appId}/guilds/${guildId}/commands`, command);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Delete a global command\r\n   */\r\n  async deleteGlobalCommand(commandId: string): Promise<void> {\r\n    const appId = this.getApplicationId();\r\n    await this.request<void>('DELETE', `/applications/${appId}/commands/${commandId}`);\r\n  }\r\n\r\n  /**\r\n   * Delete a guild-specific command\r\n   */\r\n  async deleteGuildCommand(guildId: string, commandId: string): Promise<void> {\r\n    const appId = this.getApplicationId();\r\n    await this.request<void>('DELETE', `/applications/${appId}/guilds/${guildId}/commands/${commandId}`);\r\n  }\r\n\r\n  /**\r\n   * List all global commands for this application\r\n   */\r\n  async listGlobalCommands(): Promise<APIApplicationCommand[]> {\r\n    const appId = this.getApplicationId();\r\n    return this.request<APIApplicationCommand[]>('GET', `/applications/${appId}/commands`);\r\n  }\r\n\r\n  /**\r\n   * List all guild-specific commands for this application\r\n   */\r\n  async listGuildCommands(guildId: string): Promise<APIApplicationCommand[]> {\r\n    const appId = this.getApplicationId();\r\n    return this.request<APIApplicationCommand[]>('GET', `/applications/${appId}/guilds/${guildId}/commands`);\r\n  }\r\n\r\n  /**\r\n   * Get a specific global command\r\n   */\r\n  async getGlobalCommand(commandId: string): Promise<APIApplicationCommand> {\r\n    const appId = this.getApplicationId();\r\n    return this.request<APIApplicationCommand>('GET', `/applications/${appId}/commands/${commandId}`);\r\n  }\r\n\r\n  /**\r\n   * Get a specific guild command\r\n   */\r\n  async getGuildCommand(guildId: string, commandId: string): Promise<APIApplicationCommand> {\r\n    const appId = this.getApplicationId();\r\n    return this.request<APIApplicationCommand>('GET', `/applications/${appId}/guilds/${guildId}/commands/${commandId}`);\r\n  }\r\n\r\n  /**\r\n   * Update a global command\r\n   */\r\n  async updateGlobalCommand(commandId: string, data: Partial<APIApplicationCommand>): Promise<APIApplicationCommand> {\r\n    const appId = this.getApplicationId();\r\n    return this.request<APIApplicationCommand>('PATCH', `/applications/${appId}/commands/${commandId}`, data);\r\n  }\r\n\r\n  /**\r\n   * Update a guild-specific command\r\n   */\r\n  async updateGuildCommand(guildId: string, commandId: string, data: Partial<APIApplicationCommand>): Promise<APIApplicationCommand> {\r\n    const appId = this.getApplicationId();\r\n    return this.request<APIApplicationCommand>('PATCH', `/applications/${appId}/guilds/${guildId}/commands/${commandId}`, data);\r\n  }\r\n\r\n  // ==================== Helpers ====================\r\n\r\n  private applicationId: string = '';\r\n\r\n  /**\r\n   * Set the application ID\r\n   */\r\n  setApplicationId(id: string): void {\r\n    this.applicationId = id;\r\n  }\r\n\r\n  /**\r\n   * Get the application ID\r\n   */\r\n  private getApplicationId(): string {\r\n    if (!this.applicationId) {\r\n      throw new Error('Application ID not set. Call setApplicationId() first.');\r\n    }\r\n    return this.applicationId;\r\n  }\r\n\r\n  // ==================== Channels ====================\r\n\r\n  /**\r\n   * Create a channel in a guild\r\n   */\r\n  async createChannel(guildId: string, data: {\r\n    name: string;\r\n    type?: number;\r\n    parent_id?: string | null;\r\n    category_id?: string | null;\r\n    permission_overwrites?: Array<{\r\n      id: string;\r\n      type: number;\r\n      allow?: string;\r\n      deny?: string;\r\n    }>;\r\n  }): Promise<{ id: string; name: string }> {\r\n    // Map parent_id to category_id for backend compatibility\r\n    const requestData: any = {\r\n      name: data.name,\r\n      type: data.type ?? 0, // Default to text channel\r\n    };\r\n    \r\n    // Backend expects category_id, not parent_id\r\n    if (data.category_id) {\r\n      requestData.category_id = data.category_id;\r\n    } else if (data.parent_id) {\r\n      requestData.category_id = data.parent_id;\r\n    }\r\n    \r\n    // Add permission_overwrites if provided\r\n    if (data.permission_overwrites && data.permission_overwrites.length > 0) {\r\n      requestData.permission_overwrites = data.permission_overwrites;\r\n    }\r\n    \r\n    return this.request('POST', `/bot/guilds/${guildId}/channels`, requestData);\r\n  }\r\n\r\n  /**\r\n   * Delete a channel\r\n   */\r\n  /**\r\n   * Delete a channel\r\n   */\r\n  async deleteChannel(guildId: string, channelId: string): Promise<void> {\r\n    await this.request('DELETE', `/bot/guilds/${guildId}/channels/${channelId}`);\r\n  }\r\n\r\n  /**\r\n   * Delete a category\r\n   */\r\n  async deleteCategory(guildId: string, categoryId: string): Promise<void> {\r\n    await this.request('DELETE', `/bot/guilds/${guildId}/categories/${categoryId}`);\r\n  }\r\n\r\n  /**\r\n   * Edit channel permission overwrites\r\n   */\r\n  async editChannelPermissions(channelId: string, overwriteId: string, data: {\r\n    type: number;\r\n    allow?: string;\r\n    deny?: string;\r\n  }): Promise<void> {\r\n    await this.request('PUT', `/bot/channels/${channelId}/permissions/${overwriteId}`, data);\r\n  }\r\n\r\n  /**\r\n   * Delete channel permission overwrite\r\n   */\r\n  async deleteChannelPermission(channelId: string, overwriteId: string): Promise<void> {\r\n    await this.request('DELETE', `/bot/channels/${channelId}/permissions/${overwriteId}`);\r\n  }\r\n\r\n  /**\r\n   * Get messages from a channel\r\n   */\r\n  async getMessages(guildId: string, channelId: string, options?: {\r\n    limit?: number;\r\n    before?: string;\r\n    after?: string;\r\n  }): Promise<APIMessage[]> {\r\n    const params = new URLSearchParams();\r\n    if (options?.limit) params.append('limit', String(options.limit));\r\n    if (options?.before) params.append('before', options.before);\r\n    if (options?.after) params.append('after', options.after);\r\n    \r\n    const query = params.toString() ? `?${params.toString()}` : '';\r\n    const response = await this.request<{ messages: APIMessage[]; page_info: any }>('GET', `/bot/guilds/${guildId}/channels/${channelId}/messages${query}`);\r\n    return response.messages || [];\r\n  }\r\n\r\n  // ==================== Members ====================\r\n\r\n  /**\r\n   * Get a guild member\r\n   */\r\n  async getMember(guildId: string, userId: string): Promise<any> {\r\n    return this.request('GET', `/bot/guilds/${guildId}/members/${userId}`);\r\n  }\r\n\r\n  /**\r\n   * Timeout a guild member\r\n   */\r\n  async timeoutMember(guildId: string, userId: string, duration: number | null, reason?: string): Promise<void> {\r\n    if (duration === null) {\r\n      // Clear timeout\r\n      await this.request('POST', `/bot/guilds/${guildId}/members/${userId}/timeout/clear`, {\r\n        reason\r\n      });\r\n    } else {\r\n      // Set timeout\r\n      const until = new Date(Date.now() + duration).toISOString();\r\n      await this.request('POST', `/bot/guilds/${guildId}/members/${userId}/timeout`, {\r\n        until,\r\n        reason\r\n      });\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Kick a guild member\r\n   */\r\n  async kickMember(guildId: string, userId: string, reason?: string): Promise<void> {\r\n    const query = reason ? `?reason=${encodeURIComponent(reason)}` : '';\r\n    await this.request('DELETE', `/bot/guilds/${guildId}/members/${userId}${query}`);\r\n  }\r\n\r\n  /**\r\n   * Ban a guild member\r\n   */\r\n  async banMember(guildId: string, userId: string, options?: {\r\n    deleteMessageDays?: number;\r\n    deleteMessageSeconds?: number;\r\n    reason?: string;\r\n  }): Promise<void> {\r\n    await this.request('PUT', `/bot/guilds/${guildId}/bans/${userId}`, {\r\n      delete_message_days: options?.deleteMessageDays,\r\n      delete_message_seconds: options?.deleteMessageSeconds,\r\n      reason: options?.reason\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Unban a user\r\n   */\r\n  async unbanMember(guildId: string, userId: string, reason?: string): Promise<void> {\r\n    const query = reason ? `?reason=${encodeURIComponent(reason)}` : '';\r\n    await this.request('DELETE', `/bot/guilds/${guildId}/bans/${userId}${query}`);\r\n  }\r\n\r\n  /**\r\n   * Edit a guild member\r\n   */\r\n  async editMember(guildId: string, userId: string, data: {\r\n    nick?: string | null;\r\n    roles?: string[];\r\n    mute?: boolean;\r\n    deaf?: boolean;\r\n    channel_id?: string | null;\r\n    communication_disabled_until?: string | null;\r\n    reason?: string;\r\n  }): Promise<any> {\r\n    return this.request('PATCH', `/bot/guilds/${guildId}/members/${userId}`, data);\r\n  }\r\n\r\n  /**\r\n   * Add a role to a member\r\n   */\r\n  async addMemberRole(guildId: string, userId: string, roleId: string, reason?: string): Promise<void> {\r\n    const query = reason ? `?reason=${encodeURIComponent(reason)}` : '';\r\n    await this.request('PUT', `/bot/guilds/${guildId}/members/${userId}/roles/${roleId}${query}`);\r\n  }\r\n\r\n  /**\r\n   * Remove a role from a member\r\n   */\r\n  async removeMemberRole(guildId: string, userId: string, roleId: string, reason?: string): Promise<void> {\r\n    const query = reason ? `?reason=${encodeURIComponent(reason)}` : '';\r\n    await this.request('DELETE', `/bot/guilds/${guildId}/members/${userId}/roles/${roleId}${query}`);\r\n  }\r\n\r\n  /**\r\n   * Bulk delete messages\r\n   */\r\n  async bulkDeleteMessages(guildId: string, channelId: string, messageIds: string[]): Promise<void> {\r\n    await this.request('POST', `/bot/guilds/${guildId}/channels/${channelId}/messages/bulk-delete`, {\r\n      messages: messageIds\r\n    });\r\n  }\r\n\r\n  // ==================== Guilds ====================\r\n\r\n  /**\r\n   * Get a guild\r\n   */\r\n  async getGuild(guildId: string): Promise<any> {\r\n    return this.request('GET', `/bot/guilds/${guildId}`);\r\n  }\r\n\r\n  /**\r\n   * Get guild channels\r\n   */\r\n  async getGuildChannels(guildId: string): Promise<any[]> {\r\n    return this.request('GET', `/bot/guilds/${guildId}/channels`);\r\n  }\r\n\r\n  /**\r\n   * Get guild roles\r\n   */\r\n  async getRoles(guildId: string): Promise<any[]> {\r\n    return this.request('GET', `/bot/guilds/${guildId}/roles`);\r\n  }\r\n\r\n  /**\r\n   * Create a role\r\n   */\r\n  async createRole(guildId: string, data: {\r\n    name?: string;\r\n    color?: number;\r\n    hoist?: boolean;\r\n    mentionable?: boolean;\r\n    permissions?: string;\r\n  }): Promise<any> {\r\n    return this.request('POST', `/bot/guilds/${guildId}/roles`, data);\r\n  }\r\n\r\n  /**\r\n   * Edit a role\r\n   */\r\n  async editRole(guildId: string, roleId: string, data: {\r\n    name?: string;\r\n    color?: number;\r\n    hoist?: boolean;\r\n    mentionable?: boolean;\r\n    permissions?: string;\r\n  }): Promise<any> {\r\n    return this.request('PATCH', `/bot/guilds/${guildId}/roles/${roleId}`, data);\r\n  }\r\n\r\n  /**\r\n   * Delete a role\r\n   */\r\n  async deleteRole(guildId: string, roleId: string): Promise<void> {\r\n    await this.request('DELETE', `/bot/guilds/${guildId}/roles/${roleId}`);\r\n  }\r\n\r\n  /**\r\n   * Get guild emojis\r\n   */\r\n  async getEmojis(guildId: string): Promise<any[]> {\r\n    return this.request('GET', `/bot/guilds/${guildId}/emojis`);\r\n  }\r\n\r\n  /**\r\n   * Get guild bans\r\n   */\r\n  async getBans(guildId: string): Promise<any[]> {\r\n    return this.request('GET', `/bot/guilds/${guildId}/bans`);\r\n  }\r\n\r\n  /**\r\n   * Get a specific ban\r\n   */\r\n  async getBan(guildId: string, userId: string): Promise<any> {\r\n    return this.request('GET', `/bot/guilds/${guildId}/bans/${userId}`);\r\n  }\r\n\r\n  /**\r\n   * Get guild invites\r\n   */\r\n  async getGuildInvites(guildId: string): Promise<any[]> {\r\n    return this.request('GET', `/bot/guilds/${guildId}/invites`);\r\n  }\r\n\r\n  // ==================== Threads ====================\r\n\r\n  /**\r\n   * Create a thread from a message\r\n   */\r\n  async createThreadFromMessage(guildId: string, channelId: string, messageId: string, data: {\r\n    name: string;\r\n    auto_archive_duration?: number;\r\n  }): Promise<any> {\r\n    return this.request('POST', `/bot/guilds/${guildId}/channels/${channelId}/messages/${messageId}/threads`, data);\r\n  }\r\n\r\n  /**\r\n   * Create a thread without a message\r\n   */\r\n  async createThread(guildId: string, channelId: string, data: {\r\n    name: string;\r\n    type?: number;\r\n    auto_archive_duration?: number;\r\n    invitable?: boolean;\r\n  }): Promise<any> {\r\n    return this.request('POST', `/bot/guilds/${guildId}/channels/${channelId}/threads`, data);\r\n  }\r\n\r\n  /**\r\n   * Join a thread\r\n   */\r\n  async joinThread(channelId: string): Promise<void> {\r\n    await this.request('PUT', `/bot/channels/${channelId}/thread-members/@me`);\r\n  }\r\n\r\n  /**\r\n   * Leave a thread\r\n   */\r\n  async leaveThread(channelId: string): Promise<void> {\r\n    await this.request('DELETE', `/bot/channels/${channelId}/thread-members/@me`);\r\n  }\r\n\r\n  // ==================== Pins ====================\r\n\r\n  /**\r\n   * Pin a message\r\n   */\r\n  async pinMessage(guildId: string, channelId: string, messageId: string): Promise<void> {\r\n    await this.request('PUT', `/bot/guilds/${guildId}/channels/${channelId}/pins/${messageId}`);\r\n  }\r\n\r\n  /**\r\n   * Unpin a message\r\n   */\r\n  async unpinMessage(guildId: string, channelId: string, messageId: string): Promise<void> {\r\n    await this.request('DELETE', `/bot/guilds/${guildId}/channels/${channelId}/pins/${messageId}`);\r\n  }\r\n\r\n  /**\r\n   * Get pinned messages\r\n   */\r\n  async getPinnedMessages(guildId: string, channelId: string): Promise<APIMessage[]> {\r\n    return this.request('GET', `/bot/guilds/${guildId}/channels/${channelId}/pins`);\r\n  }\r\n\r\n  // ==================== Users ====================\r\n\r\n  /**\r\n   * Get a user\r\n   */\r\n  async getUser(userId: string): Promise<any> {\r\n    return this.request('GET', `/bot/users/${userId}`);\r\n  }\r\n\r\n  /**\r\n   * Get current bot user\r\n   */\r\n  async getCurrentUser(): Promise<any> {\r\n    return this.request('GET', `/bot/users/@me`);\r\n  }\r\n\r\n  // ==================== Invites ====================\r\n\r\n  /**\r\n   * Create an invite\r\n   */\r\n  async createInvite(guildId: string, channelId: string, data?: {\r\n    max_age?: number;\r\n    max_uses?: number;\r\n    temporary?: boolean;\r\n    unique?: boolean;\r\n  }): Promise<any> {\r\n    return this.request('POST', `/bot/guilds/${guildId}/channels/${channelId}/invites`, data || {});\r\n  }\r\n\r\n  /**\r\n   * Delete an invite\r\n   */\r\n  async deleteInvite(inviteCode: string): Promise<void> {\r\n    await this.request('DELETE', `/bot/invites/${inviteCode}`);\r\n  }\r\n\r\n  /**\r\n   * Get an invite\r\n   */\r\n  async getInvite(inviteCode: string): Promise<any> {\r\n    return this.request('GET', `/bot/invites/${inviteCode}`);\r\n  }\r\n\r\n  // ==================== Webhooks ====================\r\n\r\n  /**\r\n   * Get channel webhooks\r\n   */\r\n  async getChannelWebhooks(guildId: string, channelId: string): Promise<any[]> {\r\n    return this.request('GET', `/bot/guilds/${guildId}/channels/${channelId}/webhooks`);\r\n  }\r\n\r\n  /**\r\n   * Create a webhook\r\n   */\r\n  async createWebhook(guildId: string, channelId: string, data: {\r\n    name: string;\r\n    avatar?: string;\r\n  }): Promise<any> {\r\n    return this.request('POST', `/bot/guilds/${guildId}/channels/${channelId}/webhooks`, data);\r\n  }\r\n}\r\n"]}
867
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"REST.js","sourceRoot":"","sources":["../../src/rest/REST.ts"],"names":[],"mappings":"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","sourcesContent":["import { APIMessage, APIApplicationCommand, APIEmbed } from '../types';\r\n\r\n/**\r\n * Mention data structure for our system\r\n */\r\nexport interface MentionUser {\r\n  id: number;\r\n  username: string;\r\n}\r\n\r\nexport interface MentionRole {\r\n  id: string;\r\n  name?: string;\r\n}\r\n\r\nexport interface MentionsData {\r\n  users?: MentionUser[];\r\n  roles?: MentionRole[];\r\n  everyone?: boolean;\r\n}\r\n\r\n/**\r\n * User cache entry\r\n */\r\ninterface CachedUser {\r\n  id: number;\r\n  username: string;\r\n  displayName?: string;\r\n  cachedAt: number;\r\n}\r\n\r\n/**\r\n * REST API client for Jubbio\r\n */\r\nexport class REST {\r\n  private baseUrl: string;\r\n  private token: string = '';\r\n  \r\n  // User cache for mention resolution (ID -> username)\r\n  private userCache: Map<number, CachedUser> = new Map();\r\n  private readonly USER_CACHE_TTL = 5 * 60 * 1000; // 5 dakika\r\n\r\n  constructor(baseUrl: string = 'https://gateway.jubbio.com/api/v1') {\r\n    this.baseUrl = baseUrl;\r\n  }\r\n\r\n  // ==================== Mention Helpers ====================\r\n\r\n  /**\r\n   * Cache a user for mention resolution\r\n   * Bot'lar interaction'dan gelen user bilgisini cache'leyebilir\r\n   */\r\n  cacheUser(user: { id: string | number; username: string; displayName?: string; display_name?: string }): void {\r\n    const userId = typeof user.id === 'string' ? parseInt(user.id, 10) : user.id;\r\n    this.userCache.set(userId, {\r\n      id: userId,\r\n      username: user.username,\r\n      displayName: user.displayName || user.display_name,\r\n      cachedAt: Date.now()\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Cache multiple users\r\n   */\r\n  cacheUsers(users: Array<{ id: string | number; username: string; displayName?: string; display_name?: string }>): void {\r\n    users.forEach(user => this.cacheUser(user));\r\n  }\r\n\r\n  /**\r\n   * Get cached user by ID\r\n   */\r\n  getCachedUser(userId: number): CachedUser | undefined {\r\n    const cached = this.userCache.get(userId);\r\n    if (cached && Date.now() - cached.cachedAt < this.USER_CACHE_TTL) {\r\n      return cached;\r\n    }\r\n    // Expired, remove from cache\r\n    if (cached) {\r\n      this.userCache.delete(userId);\r\n    }\r\n    return undefined;\r\n  }\r\n\r\n  /**\r\n   * Format a user mention\r\n   * Returns both the text format and mentions data\r\n   * \r\n   * @example\r\n   * const mention = rest.formatMention(user);\r\n   * // mention.text = \"@ilkay\"\r\n   * // mention.data = { users: [{ id: 1, username: \"ilkay\" }] }\r\n   */\r\n  formatMention(user: { id: string | number; username: string }): { text: string; data: MentionsData } {\r\n    const userId = typeof user.id === 'string' ? parseInt(user.id, 10) : user.id;\r\n    return {\r\n      text: `@${user.username}`,\r\n      data: {\r\n        users: [{ id: userId, username: user.username }]\r\n      }\r\n    };\r\n  }\r\n\r\n  /**\r\n   * Parse mentions (<@ID>) and convert to our format (@username)\r\n   * Also builds the mentions data structure\r\n   * \r\n   * @param content - Message content with mentions\r\n   * @param existingMentions - Existing mentions data to merge with\r\n   * @returns Processed content and mentions data\r\n   */\r\n  private processMentions(content: string, existingMentions?: MentionsData): { content: string; mentions: MentionsData } {\r\n    const mentions: MentionsData = {\r\n      users: [...(existingMentions?.users || [])],\r\n      roles: [...(existingMentions?.roles || [])],\r\n      everyone: existingMentions?.everyone\r\n    };\r\n\r\n    // Track already added user IDs to avoid duplicates\r\n    const addedUserIds = new Set(mentions.users?.map(u => u.id) || []);\r\n\r\n    // Parse <@ID> format (user mentions)\r\n    const userMentionRegex = /<@!?(\\d+)>/g;\r\n    let processedContent = content;\r\n    let match;\r\n\r\n    while ((match = userMentionRegex.exec(content)) !== null) {\r\n      const userId = parseInt(match[1], 10);\r\n      const fullMatch = match[0];\r\n\r\n      // Try to get username from cache\r\n      const cachedUser = this.getCachedUser(userId);\r\n      \r\n      if (cachedUser) {\r\n        // Replace <@ID> with @username\r\n        processedContent = processedContent.replace(fullMatch, `@${cachedUser.username}`);\r\n        \r\n        // Add to mentions if not already added\r\n        if (!addedUserIds.has(userId)) {\r\n          mentions.users!.push({ id: userId, username: cachedUser.username });\r\n          addedUserIds.add(userId);\r\n        }\r\n      } else {\r\n        // User not in cache - keep as @User_ID format (backend will resolve)\r\n        processedContent = processedContent.replace(fullMatch, `@User_${userId}`);\r\n        \r\n        // Still add to mentions with placeholder username\r\n        if (!addedUserIds.has(userId)) {\r\n          mentions.users!.push({ id: userId, username: `User_${userId}` });\r\n          addedUserIds.add(userId);\r\n        }\r\n      }\r\n    }\r\n\r\n    // Parse <@&ID> format (role mentions)\r\n    const roleMentionRegex = /<@&(\\d+)>/g;\r\n    const addedRoleIds = new Set(mentions.roles?.map(r => r.id) || []);\r\n\r\n    while ((match = roleMentionRegex.exec(content)) !== null) {\r\n      const roleId = match[1];\r\n      const fullMatch = match[0];\r\n\r\n      // Replace with @role format (backend handles role resolution)\r\n      processedContent = processedContent.replace(fullMatch, `@role_${roleId}`);\r\n      \r\n      if (!addedRoleIds.has(roleId)) {\r\n        mentions.roles!.push({ id: roleId });\r\n        addedRoleIds.add(roleId);\r\n      }\r\n    }\r\n\r\n    // Parse @everyone and @here\r\n    if (content.includes('@everyone')) {\r\n      mentions.everyone = true;\r\n    }\r\n\r\n    // Clean up empty arrays\r\n    if (mentions.users?.length === 0) delete mentions.users;\r\n    if (mentions.roles?.length === 0) delete mentions.roles;\r\n\r\n    return { content: processedContent, mentions };\r\n  }\r\n\r\n  /**\r\n   * Prepare message data with processed mentions\r\n   * Automatically converts mentions to our format\r\n   */\r\n  private prepareMessageData(data: {\r\n    content?: string;\r\n    embeds?: APIEmbed[];\r\n    components?: any[];\r\n    mentions?: MentionsData;\r\n    message_reference?: { message_id: string };\r\n  }): any {\r\n    const result: any = { ...data };\r\n\r\n    // Resolve components (ActionRowBuilder / ButtonBuilder instances)\r\n    if (data.components && data.components.length > 0) {\r\n      result.components = data.components.map((c: any) =>\r\n        typeof c.toJSON === 'function' ? c.toJSON() : c\r\n      );\r\n    }\r\n\r\n    let allMentions: MentionsData = { ...data.mentions };\r\n\r\n    // Process mentions in content if present\r\n    if (data.content) {\r\n      const { content, mentions } = this.processMentions(data.content, allMentions);\r\n      result.content = content;\r\n      allMentions = mentions;\r\n    }\r\n\r\n    // Process mentions in embeds (description, title, footer, fields)\r\n    if (data.embeds && data.embeds.length > 0) {\r\n      result.embeds = data.embeds.map(embed => {\r\n        // Support EmbedBuilder instances - extract raw data via toJSON()\r\n        const rawEmbed = typeof (embed as any).toJSON === 'function' ? (embed as any).toJSON() : embed;\r\n        const processedEmbed: any = { ...rawEmbed };\r\n\r\n        // Normalize thumbnail: string → { url: string }\r\n        if (typeof processedEmbed.thumbnail === 'string') {\r\n          processedEmbed.thumbnail = { url: processedEmbed.thumbnail };\r\n        }\r\n\r\n        // Normalize image: string → { url: string }\r\n        if (typeof processedEmbed.image === 'string') {\r\n          processedEmbed.image = { url: processedEmbed.image };\r\n        }\r\n\r\n        // Normalize color: hex string → number\r\n        if (typeof processedEmbed.color === 'string') {\r\n          processedEmbed.color = parseInt(processedEmbed.color.replace('#', ''), 16);\r\n        }\r\n\r\n        // Normalize timestamp: Date → ISO string\r\n        if (processedEmbed.timestamp instanceof Date) {\r\n          processedEmbed.timestamp = processedEmbed.timestamp.toISOString();\r\n        } else if (typeof processedEmbed.timestamp === 'number') {\r\n          processedEmbed.timestamp = new Date(processedEmbed.timestamp).toISOString();\r\n        }\r\n\r\n        // Normalize footer.iconURL → footer.icon_url\r\n        if (processedEmbed.footer) {\r\n          if (processedEmbed.footer.iconURL && !processedEmbed.footer.icon_url) {\r\n            processedEmbed.footer = { ...processedEmbed.footer, icon_url: processedEmbed.footer.iconURL };\r\n            delete processedEmbed.footer.iconURL;\r\n          }\r\n        }\r\n        \r\n        // Process description\r\n        if (rawEmbed.description) {\r\n          const { content, mentions } = this.processMentions(rawEmbed.description, allMentions);\r\n          processedEmbed.description = content;\r\n          allMentions = mentions;\r\n        }\r\n        \r\n        // Process title\r\n        if (rawEmbed.title) {\r\n          const { content, mentions } = this.processMentions(rawEmbed.title, allMentions);\r\n          processedEmbed.title = content;\r\n          allMentions = mentions;\r\n        }\r\n        \r\n        // Process footer text\r\n        if (rawEmbed.footer?.text) {\r\n          const { content, mentions } = this.processMentions(rawEmbed.footer.text, allMentions);\r\n          processedEmbed.footer = { ...rawEmbed.footer, text: content };\r\n          allMentions = mentions;\r\n        }\r\n        \r\n        // Process fields\r\n        if (rawEmbed.fields && rawEmbed.fields.length > 0) {\r\n          processedEmbed.fields = rawEmbed.fields.map((field: any) => {\r\n            const processedField: any = { ...field };\r\n            if (field.value) {\r\n              const { content, mentions } = this.processMentions(field.value, allMentions);\r\n              processedField.value = content;\r\n              allMentions = mentions;\r\n            }\r\n            if (field.name) {\r\n              const { content, mentions } = this.processMentions(field.name, allMentions);\r\n              processedField.name = content;\r\n              allMentions = mentions;\r\n            }\r\n            return processedField;\r\n          });\r\n        }\r\n        \r\n        return processedEmbed;\r\n      });\r\n    }\r\n\r\n    // Add merged mentions to result\r\n    if (allMentions.users?.length || allMentions.roles?.length || allMentions.everyone) {\r\n      result.mentions = allMentions;\r\n    }\r\n\r\n    return result;\r\n  }\r\n\r\n  /**\r\n   * Set the bot token\r\n   */\r\n  setToken(token: string): this {\r\n    this.token = token;\r\n    return this;\r\n  }\r\n\r\n  /**\r\n   * Make an authenticated request\r\n   */\r\n  private async request<T>(method: string, path: string, body?: any): Promise<T> {\r\n    const url = `${this.baseUrl}${path}`;\r\n    \r\n    // Debug log\r\n    console.log(`[REST] ${method} ${url}`, body ? JSON.stringify(body) : '');\r\n    \r\n    const response = await fetch(url, {\r\n      method,\r\n      headers: {\r\n        'Authorization': `Bot ${this.token}`,\r\n        'Content-Type': 'application/json'\r\n      },\r\n      body: body ? JSON.stringify(body) : undefined\r\n    });\r\n\r\n    if (!response.ok) {\r\n      const error = await response.text();\r\n      throw new Error(`API Error ${response.status}: ${error}`);\r\n    }\r\n\r\n    // Handle empty responses\r\n    const text = await response.text();\r\n    if (!text) return {} as T;\r\n    \r\n    return JSON.parse(text);\r\n  }\r\n\r\n  // ==================== Messages ====================\r\n\r\n  /**\r\n   * Create a message in a channel\r\n   * Automatically processes mentions (<@ID>) to our format (@username)\r\n   * \r\n   * @example\r\n   * // Mention style (auto-converted):\r\n   * await rest.createMessage(guildId, channelId, {\r\n   *   content: 'Hello <@123>!',  // Becomes \"Hello @username!\"\r\n   * });\r\n   * \r\n   * // Our native format:\r\n   * await rest.createMessage(guildId, channelId, {\r\n   *   content: 'Hello @ilkay!',\r\n   *   mentions: { users: [{ id: 123, username: 'ilkay' }] }\r\n   * });\r\n   */\r\n  async createMessage(guildIdOrChannelId: string, channelIdOrData: string | {\r\n    content?: string;\r\n    embeds?: APIEmbed[];\r\n    components?: any[];\r\n    mentions?: MentionsData;\r\n    files?: Array<{ name: string; data: Buffer }>;\r\n    message_reference?: { message_id: string };\r\n    interactionId?: string;\r\n  }, data?: {\r\n    content?: string;\r\n    embeds?: APIEmbed[];\r\n    components?: any[];\r\n    mentions?: MentionsData;\r\n    files?: Array<{ name: string; data: Buffer }>;\r\n    message_reference?: { message_id: string };\r\n    interactionId?: string;\r\n  }): Promise<APIMessage> {\r\n    // İki kullanım şekli:\r\n    // 1. createMessage(guildId, channelId, data) - guildId ile (tercih edilen)\r\n    // 2. createMessage(channelId, data) - guildId olmadan (eski format, hata verir)\r\n    \r\n    let guildId: string;\r\n    let channelId: string;\r\n    let messageData: any;\r\n    \r\n    if (typeof channelIdOrData === 'string' && data) {\r\n      // Yeni format: createMessage(guildId, channelId, data)\r\n      guildId = guildIdOrChannelId;\r\n      channelId = channelIdOrData;\r\n      messageData = this.prepareMessageData(data);\r\n      \r\n      // Add interaction_id if provided\r\n      if (data.interactionId) {\r\n        messageData.interaction_id = data.interactionId;\r\n      }\r\n    } else if (typeof channelIdOrData === 'object') {\r\n      // Eski format: createMessage(channelId, data) - guildId yok\r\n      // Bu format artık desteklenmiyor, hata fırlat\r\n      throw new Error('createMessage requires guildId: createMessage(guildId, channelId, data)');\r\n    } else {\r\n      throw new Error('Invalid createMessage arguments');\r\n    }\r\n    \r\n    return this.request<APIMessage>('POST', `/bot/guilds/${guildId}/channels/${channelId}/messages`, messageData);\r\n  }\r\n\r\n  /**\r\n   * Create an ephemeral message that is only visible to a specific user\r\n   * Ephemeral messages are NOT saved to database - they are only sent via WebSocket\r\n   * \r\n   * @example\r\n   * // Send a warning only visible to the user\r\n   * await rest.createEphemeralMessage(guildId, channelId, targetUserId, {\r\n   *   embeds: [warningEmbed]\r\n   * });\r\n   */\r\n  async createEphemeralMessage(guildId: string, channelId: string, targetUserId: string | number, data: {\r\n    content?: string;\r\n    embeds?: APIEmbed[];\r\n  }): Promise<{ id: string; ephemeral: boolean; flags: number }> {\r\n    const messageData = this.prepareMessageData(data);\r\n    \r\n    return this.request<{ id: string; ephemeral: boolean; flags: number }>('POST', `/bot/guilds/${guildId}/channels/${channelId}/messages`, {\r\n      ...messageData,\r\n      flags: 64, // EPHEMERAL flag\r\n      target_user_id: typeof targetUserId === 'string' ? parseInt(targetUserId, 10) : targetUserId\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Create a DM message\r\n   */\r\n  async createDMMessage(channelId: string, data: {\r\n    content?: string;\r\n    embeds?: APIEmbed[];\r\n  }): Promise<APIMessage> {\r\n    return this.request<APIMessage>('POST', `/bot/dm/${channelId}`, data);\r\n  }\r\n\r\n  /**\r\n   * Edit a message\r\n   * Automatically processes mentions\r\n   */\r\n  async editMessage(guildId: string, channelId: string, messageId: string, data: {\r\n    content?: string;\r\n    embeds?: APIEmbed[];\r\n    components?: any[];\r\n    mentions?: MentionsData;\r\n  }): Promise<APIMessage> {\r\n    const path = `/bot/guilds/${guildId}/channels/${channelId}/messages/${messageId}`;\r\n    const processedData = this.prepareMessageData(data);\r\n    return this.request<APIMessage>('PATCH', path, processedData);\r\n  }\r\n\r\n  /**\r\n   * Delete a message\r\n   */\r\n  async deleteMessage(guildId: string, channelId: string, messageId: string): Promise<void> {\r\n    const path = `/bot/guilds/${guildId}/channels/${channelId}/messages/${messageId}`;\r\n    await this.request<void>('DELETE', path);\r\n  }\r\n\r\n  /**\r\n   * Add a reaction to a message\r\n   */\r\n  async addReaction(guildId: string, channelId: string, messageId: string, emoji: string): Promise<void> {\r\n    const path = `/bot/guilds/${guildId}/channels/${channelId}/messages/${messageId}/reactions/${encodeURIComponent(emoji)}/@me`;\r\n    await this.request<void>('PUT', path);\r\n  }\r\n\r\n  /**\r\n   * Upload an attachment to a channel\r\n   */\r\n  async uploadAttachment(guildId: string, channelId: string, file: { name: string; data: Buffer; contentType?: string }): Promise<{ id: string; url: string; filename: string }> {\r\n    const FormData = require('form-data');\r\n    const form = new FormData();\r\n    \r\n    // form-data expects the buffer directly with options\r\n    form.append('file', file.data, {\r\n      filename: file.name,\r\n      contentType: file.contentType || 'text/plain'\r\n    });\r\n    \r\n    const url = `${this.baseUrl}/bot/guilds/${guildId}/channels/${channelId}/attachments`;\r\n    \r\n    console.log(`[REST] Uploading attachment: ${file.name} (${file.data.length} bytes)`);\r\n    \r\n    const response = await fetch(url, {\r\n      method: 'POST',\r\n      headers: {\r\n        'Authorization': `Bot ${this.token}`,\r\n        ...form.getHeaders()\r\n      },\r\n      body: form.getBuffer()\r\n    });\r\n    \r\n    if (!response.ok) {\r\n      const error = await response.text();\r\n      throw new Error(`API Error ${response.status}: ${error}`);\r\n    }\r\n    \r\n    return response.json() as Promise<{ id: string; url: string; filename: string }>;\r\n  }\r\n\r\n  /**\r\n   * Create a message with a file attachment\r\n   */\r\n  async createMessageWithFile(guildId: string, channelId: string, data: {\r\n    content?: string;\r\n    file: { name: string; data: Buffer; contentType?: string };\r\n    interactionId?: string;\r\n  }): Promise<APIMessage> {\r\n    const FormData = require('form-data');\r\n    const form = new FormData();\r\n    \r\n    // Add content if provided\r\n    if (data.content) {\r\n      form.append('content', data.content);\r\n    }\r\n    \r\n    // Add interaction_id if provided (for deferred response matching)\r\n    if (data.interactionId) {\r\n      form.append('interaction_id', data.interactionId);\r\n    }\r\n    \r\n    // Add file\r\n    form.append('files', data.file.data, {\r\n      filename: data.file.name,\r\n      contentType: data.file.contentType || 'text/plain'\r\n    });\r\n    \r\n    const url = `${this.baseUrl}/bot/guilds/${guildId}/channels/${channelId}/messages`;\r\n    \r\n    console.log(`[REST] Creating message with file: ${data.file.name} (${data.file.data.length} bytes)${data.interactionId ? ` [interaction: ${data.interactionId}]` : ''}`);\r\n    \r\n    const response = await fetch(url, {\r\n      method: 'POST',\r\n      headers: {\r\n        'Authorization': `Bot ${this.token}`,\r\n        ...form.getHeaders()\r\n      },\r\n      body: form.getBuffer()\r\n    });\r\n    \r\n    if (!response.ok) {\r\n      const error = await response.text();\r\n      throw new Error(`API Error ${response.status}: ${error}`);\r\n    }\r\n    \r\n    return response.json() as Promise<APIMessage>;\r\n  }\r\n\r\n  // ==================== Interactions ====================\r\n\r\n  /**\r\n   * Create an interaction response\r\n   * Automatically processes mentions in content and embeds\r\n   */\r\n  async createInteractionResponse(interactionId: string, token: string, data: {\r\n    type: number;\r\n    data?: any;\r\n  }): Promise<void> {\r\n    console.log(`📤 Interaction response: ${interactionId} -> type ${data.type}`);\r\n    try {\r\n      // Process mentions in response data if present\r\n      let processedData = data;\r\n      if (data.data && (data.data.content || data.data.embeds)) {\r\n        processedData = {\r\n          ...data,\r\n          data: this.prepareMessageData(data.data)\r\n        };\r\n      }\r\n      \r\n      await this.request<void>('POST', `/interactions/${interactionId}/${token}/callback`, processedData);\r\n      console.log(`✅ Interaction response sent`);\r\n    } catch (error) {\r\n      console.error(`❌ Interaction response error:`, error);\r\n      throw error;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Edit the original interaction response\r\n   * If files are provided, creates a new message with files (since webhook edit doesn't support file upload)\r\n   * Automatically processes mentions\r\n   */\r\n  async editInteractionResponse(token: string, data: {\r\n    content?: string;\r\n    embeds?: APIEmbed[];\r\n    components?: any[];\r\n    mentions?: MentionsData;\r\n    files?: Array<{ name: string; data: Buffer; contentType?: string }>;\r\n  }, guildId?: string, channelId?: string, interactionId?: string): Promise<void> {\r\n    const appId = this.getApplicationId();\r\n    \r\n    // Process mentions in content\r\n    const processedData = this.prepareMessageData(data);\r\n    \r\n    // If files are present and we have guild/channel info, create message with file instead\r\n    if (data.files && data.files.length > 0 && guildId && channelId) {\r\n      console.log(`[REST] editInteractionResponse with ${data.files.length} files - using createMessageWithFile`);\r\n      \r\n      // Create message with file\r\n      const file = data.files[0]; // For now, support single file\r\n      await this.createMessageWithFile(guildId, channelId, {\r\n        content: processedData.content,\r\n        file: file,\r\n        interactionId: interactionId\r\n      });\r\n      return;\r\n    }\r\n    \r\n    // If we have guildId, channelId and interactionId, create a new message with interaction_id\r\n    // This is needed because our deferred response doesn't create a message\r\n    if (guildId && channelId && interactionId) {\r\n      console.log(`[REST] editInteractionResponse - creating message with interaction_id: ${interactionId}`);\r\n      \r\n      const payload: any = {\r\n        interaction_id: interactionId\r\n      };\r\n      if (processedData.content !== undefined) payload.content = processedData.content;\r\n      if (processedData.embeds) payload.embeds = processedData.embeds;\r\n      if (processedData.components) payload.components = processedData.components;\r\n      if (processedData.mentions) payload.mentions = processedData.mentions;\r\n      \r\n      await this.request<void>('POST', `/bot/guilds/${guildId}/channels/${channelId}/messages`, payload);\r\n      return;\r\n    }\r\n    \r\n    // Fallback: Regular edit without files (webhook PATCH)\r\n    const payload: any = {};\r\n    if (processedData.content !== undefined) payload.content = processedData.content;\r\n    if (processedData.embeds) payload.embeds = processedData.embeds;\r\n    if (processedData.components) payload.components = processedData.components;\r\n    if (processedData.mentions) payload.mentions = processedData.mentions;\r\n    \r\n    await this.request<void>('PATCH', `/webhooks/${appId}/${token}/messages/@original`, payload);\r\n  }\r\n\r\n  /**\r\n   * Delete the original interaction response\r\n   */\r\n  async deleteInteractionResponse(token: string): Promise<void> {\r\n    const appId = this.getApplicationId();\r\n    await this.request<void>('DELETE', `/webhooks/${appId}/${token}/messages/@original`);\r\n  }\r\n\r\n  /**\r\n   * Create a followup message\r\n   * Automatically processes mentions\r\n   */\r\n  async createFollowup(token: string, data: {\r\n    content?: string;\r\n    embeds?: APIEmbed[];\r\n    mentions?: MentionsData;\r\n    flags?: number;\r\n  }): Promise<void> {\r\n    const appId = this.getApplicationId();\r\n    const processedData = this.prepareMessageData(data);\r\n    await this.request<void>('POST', `/webhooks/${appId}/${token}`, processedData);\r\n  }\r\n\r\n  // ==================== Commands ====================\r\n\r\n  /**\r\n   * Register global application commands\r\n   */\r\n  async registerGlobalCommands(commands: APIApplicationCommand[]): Promise<void> {\r\n    const appId = this.getApplicationId();\r\n    \r\n    for (const command of commands) {\r\n      await this.request<void>('POST', `/applications/${appId}/commands`, command);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Register guild-specific commands\r\n   */\r\n  async registerGuildCommands(guildId: string, commands: APIApplicationCommand[]): Promise<void> {\r\n    const appId = this.getApplicationId();\r\n    \r\n    for (const command of commands) {\r\n      await this.request<void>('POST', `/applications/${appId}/guilds/${guildId}/commands`, command);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Delete a global command\r\n   */\r\n  async deleteGlobalCommand(commandId: string): Promise<void> {\r\n    const appId = this.getApplicationId();\r\n    await this.request<void>('DELETE', `/applications/${appId}/commands/${commandId}`);\r\n  }\r\n\r\n  /**\r\n   * Delete a guild-specific command\r\n   */\r\n  async deleteGuildCommand(guildId: string, commandId: string): Promise<void> {\r\n    const appId = this.getApplicationId();\r\n    await this.request<void>('DELETE', `/applications/${appId}/guilds/${guildId}/commands/${commandId}`);\r\n  }\r\n\r\n  /**\r\n   * List all global commands for this application\r\n   */\r\n  async listGlobalCommands(): Promise<APIApplicationCommand[]> {\r\n    const appId = this.getApplicationId();\r\n    return this.request<APIApplicationCommand[]>('GET', `/applications/${appId}/commands`);\r\n  }\r\n\r\n  /**\r\n   * List all guild-specific commands for this application\r\n   */\r\n  async listGuildCommands(guildId: string): Promise<APIApplicationCommand[]> {\r\n    const appId = this.getApplicationId();\r\n    return this.request<APIApplicationCommand[]>('GET', `/applications/${appId}/guilds/${guildId}/commands`);\r\n  }\r\n\r\n  /**\r\n   * Get a specific global command\r\n   */\r\n  async getGlobalCommand(commandId: string): Promise<APIApplicationCommand> {\r\n    const appId = this.getApplicationId();\r\n    return this.request<APIApplicationCommand>('GET', `/applications/${appId}/commands/${commandId}`);\r\n  }\r\n\r\n  /**\r\n   * Get a specific guild command\r\n   */\r\n  async getGuildCommand(guildId: string, commandId: string): Promise<APIApplicationCommand> {\r\n    const appId = this.getApplicationId();\r\n    return this.request<APIApplicationCommand>('GET', `/applications/${appId}/guilds/${guildId}/commands/${commandId}`);\r\n  }\r\n\r\n  /**\r\n   * Update a global command\r\n   */\r\n  async updateGlobalCommand(commandId: string, data: Partial<APIApplicationCommand>): Promise<APIApplicationCommand> {\r\n    const appId = this.getApplicationId();\r\n    return this.request<APIApplicationCommand>('PATCH', `/applications/${appId}/commands/${commandId}`, data);\r\n  }\r\n\r\n  /**\r\n   * Update a guild-specific command\r\n   */\r\n  async updateGuildCommand(guildId: string, commandId: string, data: Partial<APIApplicationCommand>): Promise<APIApplicationCommand> {\r\n    const appId = this.getApplicationId();\r\n    return this.request<APIApplicationCommand>('PATCH', `/applications/${appId}/guilds/${guildId}/commands/${commandId}`, data);\r\n  }\r\n\r\n  // ==================== Helpers ====================\r\n\r\n  private applicationId: string = '';\r\n\r\n  /**\r\n   * Set the application ID\r\n   */\r\n  setApplicationId(id: string): void {\r\n    this.applicationId = id;\r\n  }\r\n\r\n  /**\r\n   * Get the application ID\r\n   */\r\n  private getApplicationId(): string {\r\n    if (!this.applicationId) {\r\n      throw new Error('Application ID not set. Call setApplicationId() first.');\r\n    }\r\n    return this.applicationId;\r\n  }\r\n\r\n  // ==================== Channels ====================\r\n\r\n  /**\r\n   * Create a channel in a guild\r\n   */\r\n  async createChannel(guildId: string, data: {\r\n    name: string;\r\n    type?: number;\r\n    parent_id?: string | null;\r\n    category_id?: string | null;\r\n    permission_overwrites?: Array<{\r\n      id: string;\r\n      type: number;\r\n      allow?: string;\r\n      deny?: string;\r\n    }>;\r\n  }): Promise<{ id: string; name: string }> {\r\n    // Map parent_id to category_id for backend compatibility\r\n    const requestData: any = {\r\n      name: data.name,\r\n      type: data.type ?? 0, // Default to text channel\r\n    };\r\n    \r\n    // Backend expects category_id, not parent_id\r\n    if (data.category_id) {\r\n      requestData.category_id = data.category_id;\r\n    } else if (data.parent_id) {\r\n      requestData.category_id = data.parent_id;\r\n    }\r\n    \r\n    // Add permission_overwrites if provided\r\n    if (data.permission_overwrites && data.permission_overwrites.length > 0) {\r\n      requestData.permission_overwrites = data.permission_overwrites;\r\n    }\r\n    \r\n    return this.request('POST', `/bot/guilds/${guildId}/channels`, requestData);\r\n  }\r\n\r\n  /**\r\n   * Delete a channel\r\n   */\r\n  /**\r\n   * Delete a channel\r\n   */\r\n  async deleteChannel(guildId: string, channelId: string): Promise<void> {\r\n    await this.request('DELETE', `/bot/guilds/${guildId}/channels/${channelId}`);\r\n  }\r\n\r\n  /**\r\n   * Delete a category\r\n   */\r\n  async deleteCategory(guildId: string, categoryId: string): Promise<void> {\r\n    await this.request('DELETE', `/bot/guilds/${guildId}/categories/${categoryId}`);\r\n  }\r\n\r\n  /**\r\n   * Edit channel permission overwrites\r\n   */\r\n  async editChannelPermissions(channelId: string, overwriteId: string, data: {\r\n    type: number;\r\n    allow?: string;\r\n    deny?: string;\r\n  }): Promise<void> {\r\n    await this.request('PUT', `/bot/channels/${channelId}/permissions/${overwriteId}`, data);\r\n  }\r\n\r\n  /**\r\n   * Delete channel permission overwrite\r\n   */\r\n  async deleteChannelPermission(channelId: string, overwriteId: string): Promise<void> {\r\n    await this.request('DELETE', `/bot/channels/${channelId}/permissions/${overwriteId}`);\r\n  }\r\n\r\n  /**\r\n   * Get messages from a channel\r\n   */\r\n  async getMessages(guildId: string, channelId: string, options?: {\r\n    limit?: number;\r\n    before?: string;\r\n    after?: string;\r\n  }): Promise<APIMessage[]> {\r\n    const params = new URLSearchParams();\r\n    if (options?.limit) params.append('limit', String(options.limit));\r\n    if (options?.before) params.append('before', options.before);\r\n    if (options?.after) params.append('after', options.after);\r\n    \r\n    const query = params.toString() ? `?${params.toString()}` : '';\r\n    const response = await this.request<{ messages: APIMessage[]; page_info: any }>('GET', `/bot/guilds/${guildId}/channels/${channelId}/messages${query}`);\r\n    return response.messages || [];\r\n  }\r\n\r\n  // ==================== Members ====================\r\n\r\n  /**\r\n   * Get a guild member\r\n   */\r\n  async getMember(guildId: string, userId: string): Promise<any> {\r\n    return this.request('GET', `/bot/guilds/${guildId}/members/${userId}`);\r\n  }\r\n\r\n  /**\r\n   * Timeout a guild member\r\n   */\r\n  async timeoutMember(guildId: string, userId: string, duration: number | null, reason?: string): Promise<void> {\r\n    if (duration === null) {\r\n      // Clear timeout\r\n      await this.request('POST', `/bot/guilds/${guildId}/members/${userId}/timeout/clear`, {\r\n        reason\r\n      });\r\n    } else {\r\n      // Set timeout\r\n      const until = new Date(Date.now() + duration).toISOString();\r\n      await this.request('POST', `/bot/guilds/${guildId}/members/${userId}/timeout`, {\r\n        until,\r\n        reason\r\n      });\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Kick a guild member\r\n   */\r\n  async kickMember(guildId: string, userId: string, reason?: string): Promise<void> {\r\n    const query = reason ? `?reason=${encodeURIComponent(reason)}` : '';\r\n    await this.request('DELETE', `/bot/guilds/${guildId}/members/${userId}${query}`);\r\n  }\r\n\r\n  /**\r\n   * Ban a guild member\r\n   */\r\n  async banMember(guildId: string, userId: string, options?: {\r\n    deleteMessageDays?: number;\r\n    deleteMessageSeconds?: number;\r\n    reason?: string;\r\n  }): Promise<void> {\r\n    await this.request('PUT', `/bot/guilds/${guildId}/bans/${userId}`, {\r\n      delete_message_days: options?.deleteMessageDays,\r\n      delete_message_seconds: options?.deleteMessageSeconds,\r\n      reason: options?.reason\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Unban a user\r\n   */\r\n  async unbanMember(guildId: string, userId: string, reason?: string): Promise<void> {\r\n    const query = reason ? `?reason=${encodeURIComponent(reason)}` : '';\r\n    await this.request('DELETE', `/bot/guilds/${guildId}/bans/${userId}${query}`);\r\n  }\r\n\r\n  /**\r\n   * Edit a guild member\r\n   */\r\n  async editMember(guildId: string, userId: string, data: {\r\n    nick?: string | null;\r\n    roles?: string[];\r\n    mute?: boolean;\r\n    deaf?: boolean;\r\n    channel_id?: string | null;\r\n    communication_disabled_until?: string | null;\r\n    reason?: string;\r\n  }): Promise<any> {\r\n    return this.request('PATCH', `/bot/guilds/${guildId}/members/${userId}`, data);\r\n  }\r\n\r\n  /**\r\n   * Add a role to a member\r\n   */\r\n  async addMemberRole(guildId: string, userId: string, roleId: string, reason?: string): Promise<void> {\r\n    const query = reason ? `?reason=${encodeURIComponent(reason)}` : '';\r\n    await this.request('PUT', `/bot/guilds/${guildId}/members/${userId}/roles/${roleId}${query}`);\r\n  }\r\n\r\n  /**\r\n   * Remove a role from a member\r\n   */\r\n  async removeMemberRole(guildId: string, userId: string, roleId: string, reason?: string): Promise<void> {\r\n    const query = reason ? `?reason=${encodeURIComponent(reason)}` : '';\r\n    await this.request('DELETE', `/bot/guilds/${guildId}/members/${userId}/roles/${roleId}${query}`);\r\n  }\r\n\r\n  /**\r\n   * Bulk delete messages\r\n   */\r\n  async bulkDeleteMessages(guildId: string, channelId: string, messageIds: string[]): Promise<void> {\r\n    await this.request('POST', `/bot/guilds/${guildId}/channels/${channelId}/messages/bulk-delete`, {\r\n      messages: messageIds\r\n    });\r\n  }\r\n\r\n  // ==================== Guilds ====================\r\n\r\n  /**\r\n   * Get a guild\r\n   */\r\n  async getGuild(guildId: string): Promise<any> {\r\n    return this.request('GET', `/bot/guilds/${guildId}`);\r\n  }\r\n\r\n  /**\r\n   * Get guild channels\r\n   */\r\n  async getGuildChannels(guildId: string): Promise<any[]> {\r\n    return this.request('GET', `/bot/guilds/${guildId}/channels`);\r\n  }\r\n\r\n  /**\r\n   * Get guild roles\r\n   */\r\n  async getRoles(guildId: string): Promise<any[]> {\r\n    return this.request('GET', `/bot/guilds/${guildId}/roles`);\r\n  }\r\n\r\n  /**\r\n   * Create a role\r\n   */\r\n  async createRole(guildId: string, data: {\r\n    name?: string;\r\n    color?: number;\r\n    hoist?: boolean;\r\n    mentionable?: boolean;\r\n    permissions?: string;\r\n  }): Promise<any> {\r\n    return this.request('POST', `/bot/guilds/${guildId}/roles`, data);\r\n  }\r\n\r\n  /**\r\n   * Edit a role\r\n   */\r\n  async editRole(guildId: string, roleId: string, data: {\r\n    name?: string;\r\n    color?: number;\r\n    hoist?: boolean;\r\n    mentionable?: boolean;\r\n    permissions?: string;\r\n  }): Promise<any> {\r\n    return this.request('PATCH', `/bot/guilds/${guildId}/roles/${roleId}`, data);\r\n  }\r\n\r\n  /**\r\n   * Delete a role\r\n   */\r\n  async deleteRole(guildId: string, roleId: string): Promise<void> {\r\n    await this.request('DELETE', `/bot/guilds/${guildId}/roles/${roleId}`);\r\n  }\r\n\r\n  /**\r\n   * Get guild emojis\r\n   */\r\n  async getEmojis(guildId: string): Promise<any[]> {\r\n    return this.request('GET', `/bot/guilds/${guildId}/emojis`);\r\n  }\r\n\r\n  /**\r\n   * Get guild bans\r\n   */\r\n  async getBans(guildId: string): Promise<any[]> {\r\n    return this.request('GET', `/bot/guilds/${guildId}/bans`);\r\n  }\r\n\r\n  /**\r\n   * Get a specific ban\r\n   */\r\n  async getBan(guildId: string, userId: string): Promise<any> {\r\n    return this.request('GET', `/bot/guilds/${guildId}/bans/${userId}`);\r\n  }\r\n\r\n  /**\r\n   * Get guild invites\r\n   */\r\n  async getGuildInvites(guildId: string): Promise<any[]> {\r\n    return this.request('GET', `/bot/guilds/${guildId}/invites`);\r\n  }\r\n\r\n  // ==================== Pins ====================\r\n\r\n  /**\r\n   * Pin a message\r\n   */\r\n  async pinMessage(guildId: string, channelId: string, messageId: string): Promise<void> {\r\n    await this.request('PUT', `/bot/guilds/${guildId}/channels/${channelId}/pins/${messageId}`);\r\n  }\r\n\r\n  /**\r\n   * Unpin a message\r\n   */\r\n  async unpinMessage(guildId: string, channelId: string, messageId: string): Promise<void> {\r\n    await this.request('DELETE', `/bot/guilds/${guildId}/channels/${channelId}/pins/${messageId}`);\r\n  }\r\n\r\n  /**\r\n   * Get pinned messages\r\n   */\r\n  async getPinnedMessages(guildId: string, channelId: string): Promise<APIMessage[]> {\r\n    return this.request('GET', `/bot/guilds/${guildId}/channels/${channelId}/pins`);\r\n  }\r\n\r\n  // ==================== Users ====================\r\n\r\n  /**\r\n   * Get a user\r\n   */\r\n  async getUser(userId: string): Promise<any> {\r\n    return this.request('GET', `/bot/users/${userId}`);\r\n  }\r\n\r\n  /**\r\n   * Get current bot user\r\n   */\r\n  async getCurrentUser(): Promise<any> {\r\n    return this.request('GET', `/bot/users/@me`);\r\n  }\r\n\r\n  // ==================== Invites ====================\r\n\r\n  /**\r\n   * Create an invite\r\n   */\r\n  async createInvite(guildId: string, channelId: string, data?: {\r\n    max_age?: number;\r\n    max_uses?: number;\r\n    temporary?: boolean;\r\n    unique?: boolean;\r\n  }): Promise<any> {\r\n    return this.request('POST', `/bot/guilds/${guildId}/channels/${channelId}/invites`, data || {});\r\n  }\r\n\r\n  /**\r\n   * Delete an invite\r\n   */\r\n  async deleteInvite(inviteCode: string): Promise<void> {\r\n    await this.request('DELETE', `/bot/invites/${inviteCode}`);\r\n  }\r\n\r\n  /**\r\n   * Get an invite\r\n   */\r\n  async getInvite(inviteCode: string): Promise<any> {\r\n    return this.request('GET', `/bot/invites/${inviteCode}`);\r\n  }\r\n\r\n  // ==================== Webhooks ====================\r\n\r\n  /**\r\n   * Get channel webhooks\r\n   */\r\n  async getChannelWebhooks(guildId: string, channelId: string): Promise<any[]> {\r\n    return this.request('GET', `/bot/guilds/${guildId}/channels/${channelId}/webhooks`);\r\n  }\r\n\r\n  /**\r\n   * Create a webhook\r\n   */\r\n  async createWebhook(guildId: string, channelId: string, data: {\r\n    name: string;\r\n    avatar?: string;\r\n  }): Promise<any> {\r\n    return this.request('POST', `/bot/guilds/${guildId}/channels/${channelId}/webhooks`, data);\r\n  }\r\n}\r\n"]}
@@ -10,8 +10,7 @@ export declare enum Partials {
10
10
  GuildMember = 2,
11
11
  Message = 3,
12
12
  Reaction = 4,
13
- GuildScheduledEvent = 5,
14
- ThreadMember = 6
13
+ GuildScheduledEvent = 5
15
14
  }
16
15
  /**
17
16
  * Check if a structure is partial (missing data)
@@ -23,7 +23,6 @@ var Partials;
23
23
  Partials[Partials["Message"] = 3] = "Message";
24
24
  Partials[Partials["Reaction"] = 4] = "Reaction";
25
25
  Partials[Partials["GuildScheduledEvent"] = 5] = "GuildScheduledEvent";
26
- Partials[Partials["ThreadMember"] = 6] = "ThreadMember";
27
26
  })(Partials || (exports.Partials = Partials = {}));
28
27
  /**
29
28
  * Check if a structure is partial (missing data)
@@ -146,4 +145,4 @@ function hasPartial(client, partial) {
146
145
  return client.options?.partials?.includes(partial) ?? false;
147
146
  }
148
147
  exports.default = Partials;
149
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Partials.js","sourceRoot":"","sources":["../../src/utils/Partials.ts"],"names":[],"mappings":"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","sourcesContent":["/**\r\n * Partials - Handle uncached/partial data structures\r\n */\r\n\r\n/**\r\n * Partial types that can be enabled\r\n */\r\nexport enum Partials {\r\n  User = 0,\r\n  Channel = 1,\r\n  GuildMember = 2,\r\n  Message = 3,\r\n  Reaction = 4,\r\n  GuildScheduledEvent = 5,\r\n  ThreadMember = 6,\r\n}\r\n\r\n/**\r\n * Check if a structure is partial (missing data)\r\n */\r\nexport function isPartial(obj: any): boolean {\r\n  return obj?.partial === true;\r\n}\r\n\r\n/**\r\n * Create a partial user structure\r\n */\r\nexport function createPartialUser(id: string): PartialUser {\r\n  return {\r\n    id,\r\n    partial: true,\r\n    username: null,\r\n    discriminator: null,\r\n    avatar: null,\r\n    bot: null,\r\n    \r\n    async fetch() {\r\n      throw new Error('Cannot fetch partial user without client context');\r\n    },\r\n    \r\n    toString() {\r\n      return `<@${id}>`;\r\n    },\r\n  };\r\n}\r\n\r\n/**\r\n * Create a partial channel structure\r\n */\r\nexport function createPartialChannel(id: string): PartialChannel {\r\n  return {\r\n    id,\r\n    partial: true,\r\n    type: null,\r\n    name: null,\r\n    \r\n    async fetch() {\r\n      throw new Error('Cannot fetch partial channel without client context');\r\n    },\r\n    \r\n    toString() {\r\n      return `<#${id}>`;\r\n    },\r\n  };\r\n}\r\n\r\n/**\r\n * Create a partial message structure\r\n */\r\nexport function createPartialMessage(id: string, channelId: string): PartialMessage {\r\n  return {\r\n    id,\r\n    channelId,\r\n    partial: true,\r\n    content: null,\r\n    author: null,\r\n    embeds: null,\r\n    attachments: null,\r\n    \r\n    async fetch() {\r\n      throw new Error('Cannot fetch partial message without client context');\r\n    },\r\n    \r\n    toString() {\r\n      return `Message(${id})`;\r\n    },\r\n  };\r\n}\r\n\r\n/**\r\n * Create a partial guild member structure\r\n */\r\nexport function createPartialGuildMember(userId: string, guildId: string): PartialGuildMember {\r\n  return {\r\n    id: userId,\r\n    guildId,\r\n    partial: true,\r\n    user: null,\r\n    nick: null,\r\n    roles: null,\r\n    joinedAt: null,\r\n    \r\n    async fetch() {\r\n      throw new Error('Cannot fetch partial member without client context');\r\n    },\r\n    \r\n    toString() {\r\n      return `<@${userId}>`;\r\n    },\r\n  };\r\n}\r\n\r\n/**\r\n * Create a partial reaction structure\r\n */\r\nexport function createPartialReaction(messageId: string, emoji: string): PartialReaction {\r\n  return {\r\n    messageId,\r\n    emoji,\r\n    partial: true,\r\n    count: null,\r\n    me: null,\r\n    \r\n    async fetch() {\r\n      throw new Error('Cannot fetch partial reaction without client context');\r\n    },\r\n    \r\n    toString() {\r\n      return emoji;\r\n    },\r\n  };\r\n}\r\n\r\n/**\r\n * Partial structure types\r\n */\r\nexport interface PartialUser {\r\n  id: string;\r\n  partial: true;\r\n  username: string | null;\r\n  discriminator: string | null;\r\n  avatar: string | null;\r\n  bot: boolean | null;\r\n  fetch(): Promise<any>;\r\n  toString(): string;\r\n}\r\n\r\nexport interface PartialChannel {\r\n  id: string;\r\n  partial: true;\r\n  type: number | null;\r\n  name: string | null;\r\n  fetch(): Promise<any>;\r\n  toString(): string;\r\n}\r\n\r\nexport interface PartialMessage {\r\n  id: string;\r\n  channelId: string;\r\n  partial: true;\r\n  content: string | null;\r\n  author: any | null;\r\n  embeds: any[] | null;\r\n  attachments: any[] | null;\r\n  fetch(): Promise<any>;\r\n  toString(): string;\r\n}\r\n\r\nexport interface PartialGuildMember {\r\n  id: string;\r\n  guildId: string;\r\n  partial: true;\r\n  user: any | null;\r\n  nick: string | null;\r\n  roles: string[] | null;\r\n  joinedAt: Date | null;\r\n  fetch(): Promise<any>;\r\n  toString(): string;\r\n}\r\n\r\nexport interface PartialReaction {\r\n  messageId: string;\r\n  emoji: string;\r\n  partial: true;\r\n  count: number | null;\r\n  me: boolean | null;\r\n  fetch(): Promise<any>;\r\n  toString(): string;\r\n}\r\n\r\n/**\r\n * Make a structure partial-aware with fetch capability\r\n */\r\nexport function makePartialAware<T extends { id: string }>(\r\n  structure: T,\r\n  client: any,\r\n  fetchFn: (id: string) => Promise<T>\r\n): T & { partial: boolean; fetch: () => Promise<T> } {\r\n  return {\r\n    ...structure,\r\n    partial: false,\r\n    async fetch() {\r\n      const fetched = await fetchFn(structure.id);\r\n      Object.assign(this, fetched, { partial: false });\r\n      return this as T;\r\n    },\r\n  };\r\n}\r\n\r\n/**\r\n * Check if partials are enabled for a type\r\n */\r\nexport function hasPartial(client: any, partial: Partials): boolean {\r\n  return client.options?.partials?.includes(partial) ?? false;\r\n}\r\n\r\nexport default Partials;\r\n"]}
148
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Partials.js","sourceRoot":"","sources":["../../src/utils/Partials.ts"],"names":[],"mappings":"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","sourcesContent":["/**\r\n * Partials - Handle uncached/partial data structures\r\n */\r\n\r\n/**\r\n * Partial types that can be enabled\r\n */\r\nexport enum Partials {\r\n  User = 0,\r\n  Channel = 1,\r\n  GuildMember = 2,\r\n  Message = 3,\r\n  Reaction = 4,\r\n  GuildScheduledEvent = 5,\r\n}\r\n\r\n/**\r\n * Check if a structure is partial (missing data)\r\n */\r\nexport function isPartial(obj: any): boolean {\r\n  return obj?.partial === true;\r\n}\r\n\r\n/**\r\n * Create a partial user structure\r\n */\r\nexport function createPartialUser(id: string): PartialUser {\r\n  return {\r\n    id,\r\n    partial: true,\r\n    username: null,\r\n    discriminator: null,\r\n    avatar: null,\r\n    bot: null,\r\n    \r\n    async fetch() {\r\n      throw new Error('Cannot fetch partial user without client context');\r\n    },\r\n    \r\n    toString() {\r\n      return `<@${id}>`;\r\n    },\r\n  };\r\n}\r\n\r\n/**\r\n * Create a partial channel structure\r\n */\r\nexport function createPartialChannel(id: string): PartialChannel {\r\n  return {\r\n    id,\r\n    partial: true,\r\n    type: null,\r\n    name: null,\r\n    \r\n    async fetch() {\r\n      throw new Error('Cannot fetch partial channel without client context');\r\n    },\r\n    \r\n    toString() {\r\n      return `<#${id}>`;\r\n    },\r\n  };\r\n}\r\n\r\n/**\r\n * Create a partial message structure\r\n */\r\nexport function createPartialMessage(id: string, channelId: string): PartialMessage {\r\n  return {\r\n    id,\r\n    channelId,\r\n    partial: true,\r\n    content: null,\r\n    author: null,\r\n    embeds: null,\r\n    attachments: null,\r\n    \r\n    async fetch() {\r\n      throw new Error('Cannot fetch partial message without client context');\r\n    },\r\n    \r\n    toString() {\r\n      return `Message(${id})`;\r\n    },\r\n  };\r\n}\r\n\r\n/**\r\n * Create a partial guild member structure\r\n */\r\nexport function createPartialGuildMember(userId: string, guildId: string): PartialGuildMember {\r\n  return {\r\n    id: userId,\r\n    guildId,\r\n    partial: true,\r\n    user: null,\r\n    nick: null,\r\n    roles: null,\r\n    joinedAt: null,\r\n    \r\n    async fetch() {\r\n      throw new Error('Cannot fetch partial member without client context');\r\n    },\r\n    \r\n    toString() {\r\n      return `<@${userId}>`;\r\n    },\r\n  };\r\n}\r\n\r\n/**\r\n * Create a partial reaction structure\r\n */\r\nexport function createPartialReaction(messageId: string, emoji: string): PartialReaction {\r\n  return {\r\n    messageId,\r\n    emoji,\r\n    partial: true,\r\n    count: null,\r\n    me: null,\r\n    \r\n    async fetch() {\r\n      throw new Error('Cannot fetch partial reaction without client context');\r\n    },\r\n    \r\n    toString() {\r\n      return emoji;\r\n    },\r\n  };\r\n}\r\n\r\n/**\r\n * Partial structure types\r\n */\r\nexport interface PartialUser {\r\n  id: string;\r\n  partial: true;\r\n  username: string | null;\r\n  discriminator: string | null;\r\n  avatar: string | null;\r\n  bot: boolean | null;\r\n  fetch(): Promise<any>;\r\n  toString(): string;\r\n}\r\n\r\nexport interface PartialChannel {\r\n  id: string;\r\n  partial: true;\r\n  type: number | null;\r\n  name: string | null;\r\n  fetch(): Promise<any>;\r\n  toString(): string;\r\n}\r\n\r\nexport interface PartialMessage {\r\n  id: string;\r\n  channelId: string;\r\n  partial: true;\r\n  content: string | null;\r\n  author: any | null;\r\n  embeds: any[] | null;\r\n  attachments: any[] | null;\r\n  fetch(): Promise<any>;\r\n  toString(): string;\r\n}\r\n\r\nexport interface PartialGuildMember {\r\n  id: string;\r\n  guildId: string;\r\n  partial: true;\r\n  user: any | null;\r\n  nick: string | null;\r\n  roles: string[] | null;\r\n  joinedAt: Date | null;\r\n  fetch(): Promise<any>;\r\n  toString(): string;\r\n}\r\n\r\nexport interface PartialReaction {\r\n  messageId: string;\r\n  emoji: string;\r\n  partial: true;\r\n  count: number | null;\r\n  me: boolean | null;\r\n  fetch(): Promise<any>;\r\n  toString(): string;\r\n}\r\n\r\n/**\r\n * Make a structure partial-aware with fetch capability\r\n */\r\nexport function makePartialAware<T extends { id: string }>(\r\n  structure: T,\r\n  client: any,\r\n  fetchFn: (id: string) => Promise<T>\r\n): T & { partial: boolean; fetch: () => Promise<T> } {\r\n  return {\r\n    ...structure,\r\n    partial: false,\r\n    async fetch() {\r\n      const fetched = await fetchFn(structure.id);\r\n      Object.assign(this, fetched, { partial: false });\r\n      return this as T;\r\n    },\r\n  };\r\n}\r\n\r\n/**\r\n * Check if partials are enabled for a type\r\n */\r\nexport function hasPartial(client: any, partial: Partials): boolean {\r\n  return client.options?.partials?.includes(partial) ?? false;\r\n}\r\n\r\nexport default Partials;\r\n"]}
@@ -35,10 +35,6 @@ export interface SweeperDefinitions {
35
35
  stageInstances?: SweeperOptions;
36
36
  /** Sweep stickers */
37
37
  stickers?: SweeperOptions;
38
- /** Sweep thread members */
39
- threadMembers?: SweeperOptions;
40
- /** Sweep threads */
41
- threads?: SweeperOptions;
42
38
  /** Sweep users */
43
39
  users?: SweeperOptions;
44
40
  /** Sweep voice states */
@@ -59,10 +55,6 @@ export declare const Sweepers: {
59
55
  getComparisonTimestamp?: (value: T) => number;
60
56
  excludeFromSweep?: (value: T) => boolean;
61
57
  }): () => (value: T) => boolean;
62
- /**
63
- * Filter that sweeps archived threads
64
- */
65
- archivedThreadSweepFilter(lifetime?: number): () => (thread: any) => boolean;
66
58
  /**
67
59
  * Filter that sweeps expired invites
68
60
  */
@@ -27,21 +27,6 @@ exports.Sweepers = {
27
27
  };
28
28
  };
29
29
  },
30
- /**
31
- * Filter that sweeps archived threads
32
- */
33
- archivedThreadSweepFilter(lifetime = 14400) {
34
- return () => {
35
- const now = Date.now();
36
- const cutoff = now - (lifetime * 1000);
37
- return (thread) => {
38
- if (!thread.archived)
39
- return false;
40
- const archivedAt = thread.archivedAt?.getTime() ?? thread.archiveTimestamp ?? 0;
41
- return archivedAt < cutoff;
42
- };
43
- };
44
- },
45
30
  /**
46
31
  * Filter that sweeps expired invites
47
32
  */
@@ -172,8 +157,6 @@ class SweeperManager {
172
157
  }
173
158
  });
174
159
  return null;
175
- case 'threads':
176
- return this.client.channels?.cache.filter((c) => c.isThread?.()) ?? null;
177
160
  case 'presences':
178
161
  // Sweep across all guilds
179
162
  this.client.guilds?.cache.forEach((guild) => {
@@ -257,14 +240,10 @@ exports.DefaultSweeperOptions = {
257
240
  interval: 3600, // 1 hour
258
241
  filter: exports.Sweepers.filterByLifetime({ lifetime: 1800 }), // 30 minutes
259
242
  },
260
- threads: {
261
- interval: 3600,
262
- filter: exports.Sweepers.archivedThreadSweepFilter(14400), // 4 hours
263
- },
264
243
  invites: {
265
244
  interval: 3600,
266
245
  filter: exports.Sweepers.expiredInviteSweepFilter(),
267
246
  },
268
247
  };
269
248
  exports.default = SweeperManager;
270
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Sweepers.js","sourceRoot":"","sources":["../../src/utils/Sweepers.ts"],"names":[],"mappings":"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","sourcesContent":["/**\r\n * Sweepers - Automatic cache cleanup utilities\r\n */\r\n\r\nimport { Collection } from './Collection';\r\n\r\n/**\r\n * Sweeper options for a specific cache\r\n */\r\nexport interface SweeperOptions {\r\n  /** Interval in seconds between sweeps */\r\n  interval: number;\r\n  /** Filter function to determine what to sweep */\r\n  filter: () => (value: any, key: string, collection: Collection<string, any>) => boolean;\r\n}\r\n\r\n/**\r\n * Global sweeper configuration\r\n */\r\nexport interface SweeperDefinitions {\r\n  /** Sweep application commands */\r\n  applicationCommands?: SweeperOptions;\r\n  /** Sweep bans */\r\n  bans?: SweeperOptions;\r\n  /** Sweep emojis */\r\n  emojis?: SweeperOptions;\r\n  /** Sweep invites */\r\n  invites?: SweeperOptions;\r\n  /** Sweep guild members */\r\n  guildMembers?: SweeperOptions;\r\n  /** Sweep messages */\r\n  messages?: SweeperOptions;\r\n  /** Sweep presences */\r\n  presences?: SweeperOptions;\r\n  /** Sweep reactions */\r\n  reactions?: SweeperOptions;\r\n  /** Sweep stage instances */\r\n  stageInstances?: SweeperOptions;\r\n  /** Sweep stickers */\r\n  stickers?: SweeperOptions;\r\n  /** Sweep thread members */\r\n  threadMembers?: SweeperOptions;\r\n  /** Sweep threads */\r\n  threads?: SweeperOptions;\r\n  /** Sweep users */\r\n  users?: SweeperOptions;\r\n  /** Sweep voice states */\r\n  voiceStates?: SweeperOptions;\r\n}\r\n\r\n/**\r\n * Sweeper filters - predefined filter functions\r\n */\r\nexport const Sweepers = {\r\n  /**\r\n   * Filter that sweeps items older than a certain lifetime\r\n   */\r\n  filterByLifetime<T extends { createdTimestamp?: number; createdAt?: Date }>(options: {\r\n    lifetime?: number;\r\n    getComparisonTimestamp?: (value: T) => number;\r\n    excludeFromSweep?: (value: T) => boolean;\r\n  } = {}) {\r\n    const lifetime = options.lifetime ?? 14400; // 4 hours default\r\n    const getTimestamp = options.getComparisonTimestamp ?? \r\n      ((v: T) => v.createdTimestamp ?? v.createdAt?.getTime() ?? 0);\r\n    const exclude = options.excludeFromSweep ?? (() => false);\r\n    \r\n    return () => {\r\n      const now = Date.now();\r\n      const cutoff = now - (lifetime * 1000);\r\n      \r\n      return (value: T) => {\r\n        if (exclude(value)) return false;\r\n        const timestamp = getTimestamp(value);\r\n        return timestamp < cutoff;\r\n      };\r\n    };\r\n  },\r\n\r\n  /**\r\n   * Filter that sweeps archived threads\r\n   */\r\n  archivedThreadSweepFilter(lifetime = 14400) {\r\n    return () => {\r\n      const now = Date.now();\r\n      const cutoff = now - (lifetime * 1000);\r\n      \r\n      return (thread: any) => {\r\n        if (!thread.archived) return false;\r\n        const archivedAt = thread.archivedAt?.getTime() ?? thread.archiveTimestamp ?? 0;\r\n        return archivedAt < cutoff;\r\n      };\r\n    };\r\n  },\r\n\r\n  /**\r\n   * Filter that sweeps expired invites\r\n   */\r\n  expiredInviteSweepFilter() {\r\n    return () => {\r\n      const now = Date.now();\r\n      return (invite: any) => {\r\n        if (!invite.expiresAt && !invite.expiresTimestamp) return false;\r\n        const expiresAt = invite.expiresAt?.getTime() ?? invite.expiresTimestamp ?? Infinity;\r\n        return expiresAt < now;\r\n      };\r\n    };\r\n  },\r\n\r\n  /**\r\n   * Filter that sweeps outdated presences\r\n   */\r\n  outdatedPresenceSweepFilter(lifetime = 21600) {\r\n    return () => {\r\n      const now = Date.now();\r\n      const cutoff = now - (lifetime * 1000);\r\n      \r\n      return (presence: any) => {\r\n        const lastUpdate = presence.lastModified ?? presence.updatedAt?.getTime() ?? 0;\r\n        return lastUpdate < cutoff;\r\n      };\r\n    };\r\n  },\r\n\r\n  /**\r\n   * Filter that sweeps all items (use with caution)\r\n   */\r\n  sweepAll() {\r\n    return () => () => true;\r\n  },\r\n\r\n  /**\r\n   * Filter that sweeps nothing\r\n   */\r\n  sweepNone() {\r\n    return () => () => false;\r\n  },\r\n};\r\n\r\n/**\r\n * Sweeper manager class\r\n */\r\nexport class SweeperManager {\r\n  private client: any;\r\n  private intervals: Map<string, NodeJS.Timeout> = new Map();\r\n  private options: SweeperDefinitions;\r\n\r\n  constructor(client: any, options: SweeperDefinitions = {}) {\r\n    this.client = client;\r\n    this.options = options;\r\n  }\r\n\r\n  /**\r\n   * Start all configured sweepers\r\n   */\r\n  start(): void {\r\n    for (const [key, config] of Object.entries(this.options)) {\r\n      if (config && config.interval > 0) {\r\n        this.startSweeper(key as keyof SweeperDefinitions, config);\r\n      }\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Start a specific sweeper\r\n   */\r\n  private startSweeper(name: keyof SweeperDefinitions, config: SweeperOptions): void {\r\n    // Clear existing interval if any\r\n    this.stopSweeper(name);\r\n    \r\n    const interval = setInterval(() => {\r\n      this.sweep(name, config.filter);\r\n    }, config.interval * 1000);\r\n    \r\n    this.intervals.set(name, interval);\r\n  }\r\n\r\n  /**\r\n   * Stop a specific sweeper\r\n   */\r\n  stopSweeper(name: keyof SweeperDefinitions): void {\r\n    const interval = this.intervals.get(name);\r\n    if (interval) {\r\n      clearInterval(interval);\r\n      this.intervals.delete(name);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Stop all sweepers\r\n   */\r\n  stop(): void {\r\n    for (const name of this.intervals.keys()) {\r\n      this.stopSweeper(name as keyof SweeperDefinitions);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Manually trigger a sweep\r\n   */\r\n  sweep(name: keyof SweeperDefinitions, filter?: () => (value: any, key: string, collection: Collection<string, any>) => boolean): number {\r\n    const cache = this.getCache(name);\r\n    if (!cache) return 0;\r\n    \r\n    const filterFn = filter ?? this.options[name]?.filter;\r\n    if (!filterFn) return 0;\r\n    \r\n    return cache.sweep(filterFn());\r\n  }\r\n\r\n  /**\r\n   * Get the cache for a sweeper type\r\n   */\r\n  private getCache(name: keyof SweeperDefinitions): Collection<string, any> | null {\r\n    switch (name) {\r\n      case 'users':\r\n        return this.client.users?.cache ?? null;\r\n      case 'guildMembers':\r\n        // Sweep across all guilds\r\n        let memberCount = 0;\r\n        this.client.guilds?.cache.forEach((guild: any) => {\r\n          if (guild.members?.cache) {\r\n            const filter = this.options.guildMembers?.filter;\r\n            if (filter) memberCount += guild.members.cache.sweep(filter());\r\n          }\r\n        });\r\n        return null; // Already handled\r\n      case 'messages':\r\n        // Sweep across all channels\r\n        this.client.channels?.cache.forEach((channel: any) => {\r\n          if (channel.messages?.cache) {\r\n            const filter = this.options.messages?.filter;\r\n            if (filter) channel.messages.cache.sweep(filter());\r\n          }\r\n        });\r\n        return null;\r\n      case 'threads':\r\n        return this.client.channels?.cache.filter((c: any) => c.isThread?.()) ?? null;\r\n      case 'presences':\r\n        // Sweep across all guilds\r\n        this.client.guilds?.cache.forEach((guild: any) => {\r\n          if (guild.presences?.cache) {\r\n            const filter = this.options.presences?.filter;\r\n            if (filter) guild.presences.cache.sweep(filter());\r\n          }\r\n        });\r\n        return null;\r\n      case 'voiceStates':\r\n        this.client.guilds?.cache.forEach((guild: any) => {\r\n          if (guild.voiceStates?.cache) {\r\n            const filter = this.options.voiceStates?.filter;\r\n            if (filter) guild.voiceStates.cache.sweep(filter());\r\n          }\r\n        });\r\n        return null;\r\n      case 'reactions':\r\n        // Sweep reactions from all messages\r\n        this.client.channels?.cache.forEach((channel: any) => {\r\n          channel.messages?.cache.forEach((message: any) => {\r\n            if (message.reactions?.cache) {\r\n              const filter = this.options.reactions?.filter;\r\n              if (filter) message.reactions.cache.sweep(filter());\r\n            }\r\n          });\r\n        });\r\n        return null;\r\n      case 'emojis':\r\n        return this.client.emojis?.cache ?? null;\r\n      case 'stickers':\r\n        return this.client.stickers?.cache ?? null;\r\n      case 'invites':\r\n        // Sweep across all guilds\r\n        this.client.guilds?.cache.forEach((guild: any) => {\r\n          if (guild.invites?.cache) {\r\n            const filter = this.options.invites?.filter;\r\n            if (filter) guild.invites.cache.sweep(filter());\r\n          }\r\n        });\r\n        return null;\r\n      case 'bans':\r\n        this.client.guilds?.cache.forEach((guild: any) => {\r\n          if (guild.bans?.cache) {\r\n            const filter = this.options.bans?.filter;\r\n            if (filter) guild.bans.cache.sweep(filter());\r\n          }\r\n        });\r\n        return null;\r\n      default:\r\n        return null;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Get sweeper statistics\r\n   */\r\n  getStats(): Record<string, { interval: number; running: boolean }> {\r\n    const stats: Record<string, { interval: number; running: boolean }> = {};\r\n    \r\n    for (const [name, config] of Object.entries(this.options)) {\r\n      if (config) {\r\n        stats[name] = {\r\n          interval: config.interval,\r\n          running: this.intervals.has(name),\r\n        };\r\n      }\r\n    }\r\n    \r\n    return stats;\r\n  }\r\n}\r\n\r\n/**\r\n * Default sweeper options for common use cases\r\n */\r\nexport const DefaultSweeperOptions: SweeperDefinitions = {\r\n  messages: {\r\n    interval: 3600, // 1 hour\r\n    filter: Sweepers.filterByLifetime({ lifetime: 1800 }), // 30 minutes\r\n  },\r\n  threads: {\r\n    interval: 3600,\r\n    filter: Sweepers.archivedThreadSweepFilter(14400), // 4 hours\r\n  },\r\n  invites: {\r\n    interval: 3600,\r\n    filter: Sweepers.expiredInviteSweepFilter(),\r\n  },\r\n};\r\n\r\nexport default SweeperManager;\r\n"]}
249
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Sweepers.js","sourceRoot":"","sources":["../../src/utils/Sweepers.ts"],"names":[],"mappings":"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","sourcesContent":["/**\r\n * Sweepers - Automatic cache cleanup utilities\r\n */\r\n\r\nimport { Collection } from './Collection';\r\n\r\n/**\r\n * Sweeper options for a specific cache\r\n */\r\nexport interface SweeperOptions {\r\n  /** Interval in seconds between sweeps */\r\n  interval: number;\r\n  /** Filter function to determine what to sweep */\r\n  filter: () => (value: any, key: string, collection: Collection<string, any>) => boolean;\r\n}\r\n\r\n/**\r\n * Global sweeper configuration\r\n */\r\nexport interface SweeperDefinitions {\r\n  /** Sweep application commands */\r\n  applicationCommands?: SweeperOptions;\r\n  /** Sweep bans */\r\n  bans?: SweeperOptions;\r\n  /** Sweep emojis */\r\n  emojis?: SweeperOptions;\r\n  /** Sweep invites */\r\n  invites?: SweeperOptions;\r\n  /** Sweep guild members */\r\n  guildMembers?: SweeperOptions;\r\n  /** Sweep messages */\r\n  messages?: SweeperOptions;\r\n  /** Sweep presences */\r\n  presences?: SweeperOptions;\r\n  /** Sweep reactions */\r\n  reactions?: SweeperOptions;\r\n  /** Sweep stage instances */\r\n  stageInstances?: SweeperOptions;\r\n  /** Sweep stickers */\r\n  stickers?: SweeperOptions;\r\n  /** Sweep users */\r\n  users?: SweeperOptions;\r\n  /** Sweep voice states */\r\n  voiceStates?: SweeperOptions;\r\n}\r\n\r\n/**\r\n * Sweeper filters - predefined filter functions\r\n */\r\nexport const Sweepers = {\r\n  /**\r\n   * Filter that sweeps items older than a certain lifetime\r\n   */\r\n  filterByLifetime<T extends { createdTimestamp?: number; createdAt?: Date }>(options: {\r\n    lifetime?: number;\r\n    getComparisonTimestamp?: (value: T) => number;\r\n    excludeFromSweep?: (value: T) => boolean;\r\n  } = {}) {\r\n    const lifetime = options.lifetime ?? 14400; // 4 hours default\r\n    const getTimestamp = options.getComparisonTimestamp ?? \r\n      ((v: T) => v.createdTimestamp ?? v.createdAt?.getTime() ?? 0);\r\n    const exclude = options.excludeFromSweep ?? (() => false);\r\n    \r\n    return () => {\r\n      const now = Date.now();\r\n      const cutoff = now - (lifetime * 1000);\r\n      \r\n      return (value: T) => {\r\n        if (exclude(value)) return false;\r\n        const timestamp = getTimestamp(value);\r\n        return timestamp < cutoff;\r\n      };\r\n    };\r\n  },\r\n\r\n  /**\r\n   * Filter that sweeps expired invites\r\n   */\r\n  expiredInviteSweepFilter() {\r\n    return () => {\r\n      const now = Date.now();\r\n      return (invite: any) => {\r\n        if (!invite.expiresAt && !invite.expiresTimestamp) return false;\r\n        const expiresAt = invite.expiresAt?.getTime() ?? invite.expiresTimestamp ?? Infinity;\r\n        return expiresAt < now;\r\n      };\r\n    };\r\n  },\r\n\r\n  /**\r\n   * Filter that sweeps outdated presences\r\n   */\r\n  outdatedPresenceSweepFilter(lifetime = 21600) {\r\n    return () => {\r\n      const now = Date.now();\r\n      const cutoff = now - (lifetime * 1000);\r\n      \r\n      return (presence: any) => {\r\n        const lastUpdate = presence.lastModified ?? presence.updatedAt?.getTime() ?? 0;\r\n        return lastUpdate < cutoff;\r\n      };\r\n    };\r\n  },\r\n\r\n  /**\r\n   * Filter that sweeps all items (use with caution)\r\n   */\r\n  sweepAll() {\r\n    return () => () => true;\r\n  },\r\n\r\n  /**\r\n   * Filter that sweeps nothing\r\n   */\r\n  sweepNone() {\r\n    return () => () => false;\r\n  },\r\n};\r\n\r\n/**\r\n * Sweeper manager class\r\n */\r\nexport class SweeperManager {\r\n  private client: any;\r\n  private intervals: Map<string, NodeJS.Timeout> = new Map();\r\n  private options: SweeperDefinitions;\r\n\r\n  constructor(client: any, options: SweeperDefinitions = {}) {\r\n    this.client = client;\r\n    this.options = options;\r\n  }\r\n\r\n  /**\r\n   * Start all configured sweepers\r\n   */\r\n  start(): void {\r\n    for (const [key, config] of Object.entries(this.options)) {\r\n      if (config && config.interval > 0) {\r\n        this.startSweeper(key as keyof SweeperDefinitions, config);\r\n      }\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Start a specific sweeper\r\n   */\r\n  private startSweeper(name: keyof SweeperDefinitions, config: SweeperOptions): void {\r\n    // Clear existing interval if any\r\n    this.stopSweeper(name);\r\n    \r\n    const interval = setInterval(() => {\r\n      this.sweep(name, config.filter);\r\n    }, config.interval * 1000);\r\n    \r\n    this.intervals.set(name, interval);\r\n  }\r\n\r\n  /**\r\n   * Stop a specific sweeper\r\n   */\r\n  stopSweeper(name: keyof SweeperDefinitions): void {\r\n    const interval = this.intervals.get(name);\r\n    if (interval) {\r\n      clearInterval(interval);\r\n      this.intervals.delete(name);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Stop all sweepers\r\n   */\r\n  stop(): void {\r\n    for (const name of this.intervals.keys()) {\r\n      this.stopSweeper(name as keyof SweeperDefinitions);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Manually trigger a sweep\r\n   */\r\n  sweep(name: keyof SweeperDefinitions, filter?: () => (value: any, key: string, collection: Collection<string, any>) => boolean): number {\r\n    const cache = this.getCache(name);\r\n    if (!cache) return 0;\r\n    \r\n    const filterFn = filter ?? this.options[name]?.filter;\r\n    if (!filterFn) return 0;\r\n    \r\n    return cache.sweep(filterFn());\r\n  }\r\n\r\n  /**\r\n   * Get the cache for a sweeper type\r\n   */\r\n  private getCache(name: keyof SweeperDefinitions): Collection<string, any> | null {\r\n    switch (name) {\r\n      case 'users':\r\n        return this.client.users?.cache ?? null;\r\n      case 'guildMembers':\r\n        // Sweep across all guilds\r\n        let memberCount = 0;\r\n        this.client.guilds?.cache.forEach((guild: any) => {\r\n          if (guild.members?.cache) {\r\n            const filter = this.options.guildMembers?.filter;\r\n            if (filter) memberCount += guild.members.cache.sweep(filter());\r\n          }\r\n        });\r\n        return null; // Already handled\r\n      case 'messages':\r\n        // Sweep across all channels\r\n        this.client.channels?.cache.forEach((channel: any) => {\r\n          if (channel.messages?.cache) {\r\n            const filter = this.options.messages?.filter;\r\n            if (filter) channel.messages.cache.sweep(filter());\r\n          }\r\n        });\r\n        return null;\r\n      case 'presences':\r\n        // Sweep across all guilds\r\n        this.client.guilds?.cache.forEach((guild: any) => {\r\n          if (guild.presences?.cache) {\r\n            const filter = this.options.presences?.filter;\r\n            if (filter) guild.presences.cache.sweep(filter());\r\n          }\r\n        });\r\n        return null;\r\n      case 'voiceStates':\r\n        this.client.guilds?.cache.forEach((guild: any) => {\r\n          if (guild.voiceStates?.cache) {\r\n            const filter = this.options.voiceStates?.filter;\r\n            if (filter) guild.voiceStates.cache.sweep(filter());\r\n          }\r\n        });\r\n        return null;\r\n      case 'reactions':\r\n        // Sweep reactions from all messages\r\n        this.client.channels?.cache.forEach((channel: any) => {\r\n          channel.messages?.cache.forEach((message: any) => {\r\n            if (message.reactions?.cache) {\r\n              const filter = this.options.reactions?.filter;\r\n              if (filter) message.reactions.cache.sweep(filter());\r\n            }\r\n          });\r\n        });\r\n        return null;\r\n      case 'emojis':\r\n        return this.client.emojis?.cache ?? null;\r\n      case 'stickers':\r\n        return this.client.stickers?.cache ?? null;\r\n      case 'invites':\r\n        // Sweep across all guilds\r\n        this.client.guilds?.cache.forEach((guild: any) => {\r\n          if (guild.invites?.cache) {\r\n            const filter = this.options.invites?.filter;\r\n            if (filter) guild.invites.cache.sweep(filter());\r\n          }\r\n        });\r\n        return null;\r\n      case 'bans':\r\n        this.client.guilds?.cache.forEach((guild: any) => {\r\n          if (guild.bans?.cache) {\r\n            const filter = this.options.bans?.filter;\r\n            if (filter) guild.bans.cache.sweep(filter());\r\n          }\r\n        });\r\n        return null;\r\n      default:\r\n        return null;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Get sweeper statistics\r\n   */\r\n  getStats(): Record<string, { interval: number; running: boolean }> {\r\n    const stats: Record<string, { interval: number; running: boolean }> = {};\r\n    \r\n    for (const [name, config] of Object.entries(this.options)) {\r\n      if (config) {\r\n        stats[name] = {\r\n          interval: config.interval,\r\n          running: this.intervals.has(name),\r\n        };\r\n      }\r\n    }\r\n    \r\n    return stats;\r\n  }\r\n}\r\n\r\n/**\r\n * Default sweeper options for common use cases\r\n */\r\nexport const DefaultSweeperOptions: SweeperDefinitions = {\r\n  messages: {\r\n    interval: 3600, // 1 hour\r\n    filter: Sweepers.filterByLifetime({ lifetime: 1800 }), // 30 minutes\r\n  },\r\n  invites: {\r\n    interval: 3600,\r\n    filter: Sweepers.expiredInviteSweepFilter(),\r\n  },\r\n};\r\n\r\nexport default SweeperManager;\r\n"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@jubbio/core",
3
- "version": "1.1.6",
3
+ "version": "1.1.8",
4
4
  "description": "Core library for Jubbio bots",
5
5
  "main": "dist/index.js",
6
6
  "types": "dist/index.d.ts",