@hdriel/whatsapp-socket 1.2.1 → 1.2.3

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/index.d.ts CHANGED
@@ -1,8 +1,425 @@
1
- export { WhatsappSocket } from './private.js';
2
- export { WhatsappSocketGroup } from './group.js';
3
- import 'node:fs';
4
- import 'stream';
5
- import './decs-u-xMMNZ4.js';
6
- import '@fadzzzslebew/baileys';
7
- import 'ms';
8
- import 'stack-trace-logger';
1
+ import { ReadStream } from 'node:fs';
2
+ import { Readable } from 'stream';
3
+ import { WAMessage, MessageUpsertType, WASocket, UserFacingSocketConfig, GroupMetadata } from '@fadzzzslebew/baileys';
4
+ import { StringValue } from 'ms';
5
+ import { Logger } from 'stack-trace-logger';
6
+
7
+ type WhatsappSocketBaseProps = ({
8
+ mongoURL: string;
9
+ fileAuthStateDirectoryPath?: string | undefined;
10
+ } | {
11
+ mongoURL?: string | undefined;
12
+ fileAuthStateDirectoryPath: string;
13
+ }) & {
14
+ appName?: string;
15
+ logger?: Logger;
16
+ mongoCollection?: string;
17
+ onOpen?: () => Promise<void> | void;
18
+ onClose?: () => Promise<void> | void;
19
+ onConnectionStatusChange?: (connectionStatus: 'connecting' | 'close' | 'open') => Promise<void> | void;
20
+ onReceiveMessages?: (messages: WAMessage[], type: MessageUpsertType) => Promise<void> | void;
21
+ onPreConnectionSendMessageFailed?: (error: Error | string) => Promise<void> | void;
22
+ onQR?: (qr: string, code?: string | null) => Promise<void> | void;
23
+ debug?: boolean;
24
+ printQRInTerminal?: boolean;
25
+ pairingPhone?: string;
26
+ customPairingCode?: string;
27
+ };
28
+ declare class WhatsappSocketBase {
29
+ protected readonly fileAuthStateDirectoryPath?: string;
30
+ protected readonly mongoURL?: string;
31
+ protected readonly mongoCollection: string;
32
+ protected readonly logger?: Logger;
33
+ protected readonly debug?: boolean;
34
+ protected readonly printQRInTerminal?: boolean;
35
+ protected readonly pairingPhone?: string;
36
+ protected readonly customPairingCode?: string;
37
+ protected readonly appName?: string;
38
+ private readonly onPreConnectionSendMessageFailed?;
39
+ private onOpen?;
40
+ private onClose?;
41
+ private onQR?;
42
+ private onConnectionStatusChange?;
43
+ private readonly onReceiveMessages?;
44
+ static DEFAULT_COUNTRY_CODE: string;
45
+ static CONNECTION_TIMEOUT: StringValue;
46
+ static formatPhoneNumber(phone: string, countryCode?: string): string;
47
+ static formatPhoneNumberToWhatsappPattern(phone: string, countryCode?: string): string;
48
+ static getWhatsappPhoneLink({ phone, message, countryCode, }: {
49
+ phone: string;
50
+ countryCode?: string;
51
+ message?: string;
52
+ }): string;
53
+ static qrToImage(qr: string, options?: {
54
+ errorCorrectionLevel?: 'H' | 'L' | 'M';
55
+ width?: number;
56
+ margin?: number;
57
+ [key: string]: any;
58
+ }): Promise<string>;
59
+ static qrToTerminalString(qr: string, options?: {
60
+ small?: boolean;
61
+ [key: string]: any;
62
+ }): Promise<string>;
63
+ static randomPairingCode(pattern: string, length?: number): string;
64
+ private static instances;
65
+ static getInstance(props: WhatsappSocketBaseProps): WASocket;
66
+ static clearInstance(key?: string): void;
67
+ constructor(props: WhatsappSocketBaseProps);
68
+ private getLatestWhatsAppVersion;
69
+ private getAuthCollection;
70
+ private authenticate;
71
+ static buildSocketKey(props: Partial<WhatsappSocketBaseProps>): string;
72
+ get socketKey(): string;
73
+ get socket(): WASocket | null;
74
+ set socket(sock: WASocket | null);
75
+ startConnection({ options, connectionAttempts, onOpen, onClose, onQR, onConnectionStatusChange, pairingPhone: _pairingPhone, debug: _debug, }?: {
76
+ options?: UserFacingSocketConfig;
77
+ debug?: boolean;
78
+ pairingPhone?: string;
79
+ connectionAttempts?: number;
80
+ onOpen?: () => Promise<void> | void;
81
+ onClose?: () => Promise<void> | void;
82
+ onQR?: (qr: string, code?: string | null) => Promise<void> | void;
83
+ onConnectionStatusChange?: (status: 'open' | 'close' | 'connecting') => Promise<void> | void;
84
+ }): Promise<WASocket | null>;
85
+ ensureSocketConnected(): Promise<WASocket | null>;
86
+ closeConnection(): Promise<void>;
87
+ clearAuthState(): Promise<void>;
88
+ resetConnection({ pairingPhone, autoConnect }?: {
89
+ pairingPhone?: string;
90
+ autoConnect?: boolean;
91
+ }): Promise<void>;
92
+ isConnected(): boolean;
93
+ /**
94
+ * Delete a message for everyone (if within time limit) or just for yourself
95
+ * @param messageId - The message ID to delete
96
+ * @param chatJid - The chat JID (phone number in WhatsApp format)
97
+ * @param deleteForEveryone - If true, deletes for everyone (only works if you sent the message and within ~48h)
98
+ * @returns Promise with the result
99
+ */
100
+ deleteMessage(messageId: string, chatJid: string, deleteForEveryone?: true): Promise<any>;
101
+ /**
102
+ * Delete multiple messages at once
103
+ * @param messages - Array of {messageId, chatJid} objects
104
+ * @param deleteForEveryone - If true, deletes for everyone
105
+ * @returns Promise with array of results
106
+ */
107
+ deleteMessages(messages: Array<{
108
+ messageId: string;
109
+ chatJid: string;
110
+ }>, deleteForEveryone?: true): Promise<any[]>;
111
+ loadRecentMessages(chatJid: string, messageId: string): Promise<WAMessage | null>;
112
+ }
113
+
114
+ type ButtonURL = {
115
+ label: string;
116
+ url: string;
117
+ };
118
+ type ButtonCopy = {
119
+ label: string;
120
+ copy: string;
121
+ };
122
+ type ButtonPhone = {
123
+ label: string;
124
+ tel: string;
125
+ };
126
+ type CallToActionButtons = Array<ButtonURL | ButtonCopy | ButtonPhone>;
127
+ type GroupMessageOptions = {
128
+ mentions?: string[];
129
+ replyToMessageId?: string;
130
+ };
131
+ type CreateGroupOptions = {
132
+ name: string;
133
+ participants?: string[];
134
+ description?: string;
135
+ };
136
+ type GroupSettingsType = 'announcement' | 'not_announcement' | 'locked' | 'unlocked';
137
+
138
+ declare class WhatsappSocketPrivateMessages extends WhatsappSocketBase {
139
+ constructor(props: WhatsappSocketBaseProps);
140
+ /**
141
+ * Delete a sent message
142
+ * @param messageId - The message ID to delete
143
+ * @param chatJid - The recipient's phone number
144
+ * @returns Promise with the result
145
+ */
146
+ deleteMessageById(messageId: string, chatJid: string): Promise<any>;
147
+ sendTextMessage(to: string, text: string): Promise<any>;
148
+ sendButtonsMessage(to: string, { subtitle, title, buttons }: {
149
+ title: string;
150
+ subtitle?: string;
151
+ buttons: CallToActionButtons;
152
+ }): Promise<any>;
153
+ sendReplyButtonsMessage(to: string, { title, subtitle, buttons, }: {
154
+ title: string;
155
+ subtitle?: string;
156
+ buttons: Array<string | {
157
+ id: number | string;
158
+ label: string;
159
+ }>;
160
+ }): Promise<any>;
161
+ sendLocation(to: string, { latitude, longitude, name, address, }: {
162
+ latitude: number;
163
+ longitude: number;
164
+ name?: string;
165
+ address?: string;
166
+ }): Promise<any>;
167
+ }
168
+
169
+ declare class WhatsappSocketPrivateStream extends WhatsappSocketPrivateMessages {
170
+ constructor(props: WhatsappSocketBaseProps);
171
+ protected sendFileFromStream(to: string, stream: Readable | Buffer, options: {
172
+ filename: string;
173
+ mimetype?: string;
174
+ caption?: string;
175
+ replyToMessageId?: string;
176
+ ptt?: boolean;
177
+ seconds?: number;
178
+ gifPlayback?: boolean;
179
+ jpegThumbnail?: Buffer | string;
180
+ }): Promise<any>;
181
+ private streamToBuffer;
182
+ private getMimetypeFromFilename;
183
+ private createFileMessage;
184
+ protected sendImage(to: string, imageBuffer: Buffer | Readable, options?: {
185
+ caption?: string;
186
+ filename?: string;
187
+ replyToMessageId?: string;
188
+ }): Promise<any>;
189
+ protected sendVideo(to: string, videoBuffer: Buffer | Readable, options?: {
190
+ caption?: string;
191
+ filename?: string;
192
+ gifPlayback?: boolean;
193
+ replyToMessageId?: string;
194
+ jpegThumbnail?: Buffer;
195
+ }): Promise<any>;
196
+ protected sendAudio(to: string, audioBuffer: Buffer | Readable, options?: {
197
+ filename?: string;
198
+ ptt?: boolean;
199
+ seconds?: number;
200
+ replyToMessageId?: string;
201
+ }): Promise<any>;
202
+ protected sendDocument(to: string, documentBuffer: Buffer | Readable, options: {
203
+ filename: string;
204
+ caption?: string;
205
+ mimetype?: string;
206
+ replyToMessageId?: string;
207
+ jpegThumbnail?: Buffer;
208
+ }): Promise<any>;
209
+ protected sendVoiceNote(to: string, audioBuffer: Buffer | Readable, options?: {
210
+ seconds?: number;
211
+ replyToMessageId?: string;
212
+ }): Promise<any>;
213
+ protected sendSticker(to: string, stickerBuffer: Buffer | Readable, options?: {
214
+ replyToMessageId?: string;
215
+ }): Promise<any>;
216
+ }
217
+
218
+ declare class WhatsappSocketPrivateFiles extends WhatsappSocketPrivateStream {
219
+ constructor(props: WhatsappSocketBaseProps);
220
+ sendImageMessage(to: string, imageSrc: string | Buffer<any> | ReadStream, { caption, filename }?: {
221
+ caption?: string;
222
+ filename?: string;
223
+ }): Promise<any>;
224
+ sendVideoMessage(to: string, videoSrc: string | Buffer<any> | ReadStream, { caption, filename, sendAsGifPlayback: gifPlayback, }?: {
225
+ caption?: string;
226
+ sendAsGifPlayback?: boolean;
227
+ filename?: string;
228
+ }): Promise<any>;
229
+ sendFileMessage(to: string, fileSrc: string | Buffer<any> | ReadStream, { caption, mimetype, replyToMessageId, jpegThumbnailSrc, filename: _filename, }?: {
230
+ caption?: string;
231
+ mimetype?: string;
232
+ filename?: string;
233
+ replyToMessageId?: string;
234
+ jpegThumbnailSrc?: string | Buffer<any> | ReadStream;
235
+ }): Promise<any>;
236
+ sendAudioMessage(to: string, audioSrc: string | Buffer<any> | ReadStream, { filename, replyToMessageId, mimetype, seconds, }?: {
237
+ filename?: string;
238
+ replyToMessageId?: string;
239
+ mimetype?: string;
240
+ seconds?: number;
241
+ }): Promise<any>;
242
+ /**
243
+ * requirements:
244
+ * * format .webp
245
+ * * imageSize 512pxx512px
246
+ * * maxSize: 100kb
247
+ * * transparent background
248
+ * @param to
249
+ * @param imageSrc
250
+ * @param replyToMessageId
251
+ */
252
+ sendStickerMessage(to: string, imageSrc: string | Buffer<any> | ReadStream, { replyToMessageId }?: {
253
+ replyToMessageId?: string;
254
+ }): Promise<any>;
255
+ }
256
+
257
+ declare class WhatsappSocketGroups extends WhatsappSocketBase {
258
+ /**
259
+ * פורמט Group ID לתבנית WhatsApp
260
+ * Format Group ID to WhatsApp pattern
261
+ * Group IDs end with @g.us instead of @s.whatsapp.net
262
+ */
263
+ static formatGroupId(groupId: string): string;
264
+ /**
265
+ * בדיקה האם מדובר ב-Group ID או Phone Number
266
+ * Check if this is a group ID or phone number
267
+ */
268
+ static isGroupId(jid: string): boolean;
269
+ constructor(props: WhatsappSocketBaseProps);
270
+ /**
271
+ * Create a new WhatsApp group
272
+ */
273
+ createGroup({ name, participants, description }: CreateGroupOptions): Promise<any>;
274
+ /**
275
+ * Update group name (subject)
276
+ */
277
+ updateGroupName(groupId: string, newName: string): Promise<any>;
278
+ /**
279
+ * Update group description
280
+ */
281
+ updateGroupDescription(groupId: string, description: string, fetchMetaData?: boolean): Promise<any>;
282
+ /**
283
+ * Update group settings (who can send messages, edit info, etc.)
284
+ */
285
+ updateGroupSettings(groupId: string, setting: GroupSettingsType): Promise<any>;
286
+ private updateGroupParticipants;
287
+ /**
288
+ * Add participants to group
289
+ */
290
+ addParticipants(groupId: string, participant: string | string[]): Promise<any>;
291
+ /**
292
+ * Remove participants from group
293
+ */
294
+ removeParticipants(groupId: string, participant: string | string[]): Promise<any>;
295
+ /**
296
+ * Promote participant to admin
297
+ */
298
+ promoteToAdmin(groupId: string, participant: string | string[]): Promise<any>;
299
+ /**
300
+ * הורדת משתתף ממנהל
301
+ * Demote participant from admin
302
+ */
303
+ demoteFromAdmin(groupId: string, participant: string | string[]): Promise<any>;
304
+ /**
305
+ * Leave a group
306
+ */
307
+ leaveGroup(groupId: string): Promise<any>;
308
+ /**
309
+ * Get group metadata
310
+ */
311
+ getGroupMetadata(groupId: string): Promise<GroupMetadata | undefined>;
312
+ /**
313
+ * Get all groups
314
+ */
315
+ getAllGroups(): Promise<GroupMetadata[]>;
316
+ /**
317
+ * Get group invite code
318
+ */
319
+ getGroupInviteCode(groupId: string, urlLink?: boolean): Promise<string | undefined>;
320
+ /**
321
+ * Revoke group invite code (creates new one)
322
+ */
323
+ revokeGroupInviteCode(groupId: string): Promise<string | undefined>;
324
+ /**
325
+ * Join group using invite code
326
+ */
327
+ joinGroupViaInvite(inviteCode: string): Promise<string | undefined>;
328
+ /**
329
+ * Get group info from invite code
330
+ */
331
+ getGroupInfoFromInvite(inviteCode: string): Promise<any>;
332
+ /**
333
+ * Update group profile picture
334
+ */
335
+ updateGroupProfilePicture(groupId: string, imageBuffer: Buffer): Promise<any>;
336
+ /**
337
+ * Remove group profile picture
338
+ */
339
+ removeGroupProfilePicture(groupId: string): Promise<any>;
340
+ /**
341
+ * Get group profile picture URL
342
+ */
343
+ getGroupProfilePicture(groupId: string, highRes?: boolean): Promise<string | undefined | null>;
344
+ }
345
+
346
+ declare class WhatsappSocketGroupMessages extends WhatsappSocketGroups {
347
+ constructor(props: WhatsappSocketBaseProps);
348
+ /**
349
+ * Send text message to group
350
+ */
351
+ sendTextMessage(groupId: string, text: string, options?: GroupMessageOptions): Promise<any>;
352
+ /**
353
+ * Send buttons message to group
354
+ */
355
+ sendButtonsMessage(groupId: string, { title, subtitle, buttons, }: {
356
+ title: string;
357
+ subtitle?: string;
358
+ buttons: CallToActionButtons;
359
+ }): Promise<any>;
360
+ /**
361
+ * Send reply buttons message to group
362
+ */
363
+ sendReplyButtonsMessage(groupId: string, { title, subtitle, buttons, mentions, }: {
364
+ title: string;
365
+ subtitle?: string;
366
+ buttons: Array<string | {
367
+ id: number | string;
368
+ label: string;
369
+ }>;
370
+ mentions?: string[];
371
+ }): Promise<any>;
372
+ /**
373
+ * Send image to group
374
+ */
375
+ sendImageMessage(groupId: string, imageBuffer: Buffer, // todo: handle also stream and string url
376
+ { caption, mentions }?: GroupMessageOptions & {
377
+ caption?: string;
378
+ }): Promise<any>;
379
+ /**
380
+ * Send video to group
381
+ */
382
+ sendVideoMessage(groupId: string, videoBuffer: Buffer, // todo: handle also stream and string url
383
+ caption?: string, options?: GroupMessageOptions): Promise<any>;
384
+ /**
385
+ * Send audio to group
386
+ */
387
+ sendAudioMessage(groupId: string, audioBuffer: Buffer, // todo: handle also stream and string url
388
+ options?: {
389
+ ptt?: boolean;
390
+ mentions?: string[];
391
+ }): Promise<any>;
392
+ /**
393
+ * Send document to group
394
+ */
395
+ sendDocumentMessage(groupId: string, documentBuffer: Buffer, // todo: handle also stream and string url
396
+ fileName: string, mimeType?: string, options?: GroupMessageOptions): Promise<any>;
397
+ /**
398
+ * Send location to group
399
+ */
400
+ sendLocationMessage(groupId: string, latitude: number, longitude: number, name?: string, address?: string): Promise<any>;
401
+ /**
402
+ * Send message mentioning all group participants
403
+ */
404
+ sendMentionAll(groupId: string, text: string): Promise<any>;
405
+ /**
406
+ * Send reaction to a message in group
407
+ */
408
+ sendReactionMessage(groupId: string, messageId: string, emoji: string): Promise<any>;
409
+ /**
410
+ * Delete a message in group (only works for own messages)
411
+ */
412
+ deleteGroupMessage(groupId: string, messageId: string): Promise<any>;
413
+ }
414
+
415
+ type WhatsappSocketProps = WhatsappSocketBaseProps;
416
+ declare class WhatsappSocket extends WhatsappSocketPrivateFiles {
417
+ constructor(props: WhatsappSocketProps);
418
+ }
419
+
420
+ type WhatsappSocketGroupProps = WhatsappSocketBaseProps;
421
+ declare class WhatsappSocketGroup extends WhatsappSocketGroupMessages {
422
+ constructor(props: WhatsappSocketGroupProps);
423
+ }
424
+
425
+ export { WhatsappSocket, WhatsappSocketGroup, type WhatsappSocketGroupProps, type WhatsappSocketProps };
package/dist/index.js CHANGED
@@ -1,3 +1,4 @@
1
- import ue,{ReadStream}from'fs';import oe,{generateWAMessageFromContent,WAProto,useMultiFileAuthState,makeCacheableSignalKeyStore,DisconnectReason,initAuthCreds}from'@fadzzzslebew/baileys';import H from'ms';import V from'qrcode';import {MongoClient}from'mongodb';import ge from'pino';import {basename}from'path';var O={replacer:(n,e)=>Buffer.isBuffer(e)||e instanceof Uint8Array||e?.type==="Buffer"?{type:"Buffer",data:Buffer.from(e?.data||e).toString("base64")}:e,reviver:(n,e)=>{if(typeof e=="object"&&e&&(e.buffer===true||e.type==="Buffer")){let t=e.data||e.value;return typeof t=="string"?Buffer.from(t,"base64"):Buffer.from(t||[])}return e}},_=async n=>{let e=(o,a)=>{let u={$set:{...JSON.parse(JSON.stringify(o,O.replacer))}};return n.updateOne({_id:a},u,{upsert:true})},t=async o=>{try{let a=JSON.stringify(await n.findOne({_id:o}));return JSON.parse(a,O.reviver)}catch{return null}},r=async o=>{try{await n.deleteOne({_id:o});}catch{}},s=await t("creds")||initAuthCreds();return {state:{creds:s,keys:{get:async(o,a)=>{let i={};return await Promise.all(a.map(async u=>{let c=await t(`${o}-${u}`);o==="app-state-sync-key"&&c&&(c=WAProto.Message.AppStateSyncKeyData.fromObject(c)),i[u]=c;})),i},set:async o=>{let a=[];for(let i of Object.keys(o))for(let u of Object.keys(o[i])){let c=o[i][u],g=`${i}-${u}`;a.push(c?e(c,g):r(g));}await Promise.all(a);}}},saveCreds:()=>e(s,"creds")}},F=_;var U=n=>H(n)/1e3;async function f(n){let t=await(await fetch(n)).arrayBuffer();return Buffer.from(t)}async function re(n,e){try{let{parseStream:t}=await import('music-metadata'),r=await t(n,{mimeType:e||"audio/mpeg"});return Math.floor(r.format.duration||0)}catch(t){throw console.error("Error parsing stream:",t),t}finally{n.destroyed||n.destroy();}}async function se(n,e){try{let{parseBuffer:t}=await import('music-metadata'),r=await t(n,e||"audio/mpeg").catch(()=>null);return r?Math.floor(r.format.duration||0):0}catch(t){throw console.error("Error parsing buffer:",t),t}}async function L(n,e){return n instanceof ReadStream?re(n,e):se(n,e)}async function q(n){let e=[];for await(let t of n)e.push(t);return Buffer.concat(e)}function j(n){if(n.path){let e=n.path.toString();return basename(e)}}var S=n=>new Promise(e=>setTimeout(e,typeof n=="number"?n:H(n))),J={jpg:"image/jpeg",jpeg:"image/jpeg",png:"image/png",gif:"image/gif",webp:"image/webp",bmp:"image/bmp",svg:"image/svg+xml",mp4:"video/mp4",avi:"video/x-msvideo",mov:"video/quicktime",mkv:"video/x-matroska",webm:"video/webm",mp3:"audio/mpeg",wav:"audio/wav",ogg:"audio/ogg",opus:"audio/opus",aac:"audio/aac",m4a:"audio/mp4",pdf:"application/pdf",doc:"application/msword",docx:"application/vnd.openxmlformats-officedocument.wordprocessingml.document",xls:"application/vnd.ms-excel",xlsx:"application/vnd.openxmlformats-officedocument.spreadsheetml.sheet",ppt:"application/vnd.ms-powerpoint",pptx:"application/vnd.openxmlformats-officedocument.presentationml.presentation",txt:"text/plain",zip:"application/zip",rar:"application/x-rar-compressed","7z":"application/x-7z-compressed"};var Q=ge({level:"silent"}),y=class n{fileAuthStateDirectoryPath;mongoURL;mongoCollection="whatsapp-auth";logger;debug;printQRInTerminal;pairingPhone;customPairingCode;appName;onPreConnectionSendMessageFailed;onOpen;onClose;onQR;onConnectionStatusChange;onReceiveMessages;static DEFAULT_COUNTRY_CODE="972";static CONNECTION_TIMEOUT="2s";static formatPhoneNumber(e,t=n.DEFAULT_COUNTRY_CODE){if(e.endsWith("@s.whatsapp.net"))return e;let r=e.replace(/[^0-9]/g,"");return r.startsWith("05")&&(r=r.substring(1)),r.startsWith(t)||(r=t+r),r}static formatPhoneNumberToWhatsappPattern(e,t=n.DEFAULT_COUNTRY_CODE){if(e.endsWith("@s.whatsapp.net"))return e;let r=n.formatPhoneNumber(e,t);return r=`${r}@s.whatsapp.net`,r.replace(/:\d+@/,"@")}static getWhatsappPhoneLink({phone:e,message:t,countryCode:r=n.DEFAULT_COUNTRY_CODE}){let s=this.formatPhoneNumber(e,r),o=t?`?text=${encodeURI(t)}`:"";return `https://wa.me/${s}${o}`}static async qrToImage(e,t={}){return V.toDataURL(e,{errorCorrectionLevel:"H",width:400,margin:2,...t})}static async qrToTerminalString(e,t={}){return V.toString(e,{type:"terminal",small:true,...t})}static randomPairingCode(e,t=8){if(!e.includes("[")&&e.length===t)return e;let r="",s=[],o=i=>{let u=[];for(let c=0;c<i.length;c++)if(i[c+1]==="-"&&i[c+2]){let g=i.charCodeAt(c),p=i.charCodeAt(c+2);for(let d=g;d<=p;d++)u.push(String.fromCharCode(d));c+=2;}else u.push(i[c]);return u};for(let i=0;i<e.length&&r.length<t;i++){let u=e[i];if(u==="["){let c=e.indexOf("]",i),g=e.slice(i+1,c);s=o(g),i=c;}else r+=u;}for(;r.length<t&&s.length;)r+=s[Math.floor(Math.random()*s.length)];let a=r.toUpperCase();return a.padEnd(t,a)}static instances=new Map;static getInstance(e){let t=n.buildSocketKey(e);return n.instances.has(t)||new n(e),n.instances.get(t)}static clearInstance(e){e?n.instances.delete(e):n.instances.clear();}constructor(e){let{fileAuthStateDirectoryPath:t,mongoURL:r,mongoCollection:s="whatsapp-auth",logger:o,onOpen:a,onClose:i,onQR:u,onReceiveMessages:c,onConnectionStatusChange:g,debug:p,printQRInTerminal:d,pairingPhone:D,customPairingCode:k,onPreConnectionSendMessageFailed:x,appName:P}=e;this.appName=P,this.mongoURL=r,this.fileAuthStateDirectoryPath=t,this.mongoCollection=s,this.logger=o,this.debug=p,this.printQRInTerminal=d,this.pairingPhone=D,this.customPairingCode=k,this.onPreConnectionSendMessageFailed=x,this.onConnectionStatusChange=g,this.onReceiveMessages=c,this.onOpen=a,this.onClose=i,this.onQR=u,n.instances.has(this.socketKey)&&(this.socket=n.instances.get(this.socketKey));}async getLatestWhatsAppVersion(){try{let e=["https://raw.githubusercontent.com/WhiskeySockets/Baileys/master/src/Defaults/baileys-version.json","https://raw.githubusercontent.com/whiskeysockets/baileys/master/src/Defaults/baileys-version.json"];for(let t of e)try{let r=await fetch(t);if(r.ok)return (await r.json()).version}catch{continue}return console.log("Could not fetch version, using fallback"),[2,3e3,1015901307]}catch(e){return console.error("Error fetching version:",e),[2,3e3,1015901307]}}async getAuthCollection(){if(!this.mongoURL)return [];let e=new MongoClient(this.mongoURL);return await e.connect(),[e.db().collection(this.mongoCollection),e]}async authenticate(){if(!this.mongoURL&&!this.fileAuthStateDirectoryPath)throw new Error("fileAuthStateDirectoryPath/MongoURL is missing");if(!this.mongoURL){let{saveCreds:o,state:a}=await useMultiFileAuthState(this.fileAuthStateDirectoryPath);return {auth:a,saveCreds:o}}let[e]=await this.getAuthCollection(),{state:t,saveCreds:r}=await F(e);return {auth:{creds:t.creds,keys:makeCacheableSignalKeyStore(t.keys,Q)},saveCreds:r}}static buildSocketKey(e){return e.appName||e.pairingPhone||e.mongoCollection||e.fileAuthStateDirectoryPath||"default"}get socketKey(){return this.appName||this.pairingPhone||this.mongoCollection||this.fileAuthStateDirectoryPath||"default"}get socket(){return n.instances.get(this.socketKey)??null}set socket(e){n.instances.set(this.socketKey,e);}async startConnection({options:e,connectionAttempts:t=3,onOpen:r=this.onOpen,onClose:s=this.onClose,onQR:o=this.onQR,onConnectionStatusChange:a=this.onConnectionStatusChange,pairingPhone:i,debug:u}={}){let c=i??this.pairingPhone,{saveCreds:g,auth:p}=await this.authenticate(),d=u===void 0?this.debug:u,D=await this.getLatestWhatsAppVersion(),k=async()=>new Promise(P=>{let b=oe({version:D,logger:Q,browser:[this.appName||"baileys","1.0.0",""],syncFullHistory:true,shouldIgnoreJid:h=>h.includes("@newsletter"),...e,printQRInTerminal:false,auth:p});b.ev.on("connection.update",async h=>{let{connection:A,lastDisconnect:E,qr:M}=h;if(M){if(d&&this.logger?.info("WHATSAPP","QR Code received",{qr:M}),this.printQRInTerminal){let Y=await n.qrToTerminalString(M,{small:true}).catch(()=>null);console.log(Y);}this.customPairingCode?n.randomPairingCode(this.customPairingCode):void 0;let w=c?n.formatPhoneNumber(c):null,T=w?await b.requestPairingCode(w):null;d&&this.printQRInTerminal&&this.logger?.info("WHATSAPP","QR Pairing Code",{code:T,pairingPhone:w}),await o?.(M,T);}switch(A){case "connecting":{d&&this.logger?.debug("WHATSAPP","Connecting..."),a?.("connecting");break}case "open":{d&&this.logger?.info("WHATSAPP","Connection opened successfully!"),this.socket=b,await r?.(),a?.("open"),P(this.socket);break}case "close":{let N=t-- >0&&E?.error?.output?.statusCode!==DisconnectReason.loggedOut,w=E?.error?.output?.statusCode,T=E?.error?.message;d&&this.logger?.info("WHATSAPP","Connection closed",{statusCode:w,errorMessage:T,shouldReconnect:N}),N&&t?(d&&this.logger?.info("WHATSAPP","Reconnecting..."),await S(n.CONNECTION_TIMEOUT),P(k())):(d&&this.logger?.warn("WHATSAPP","Logged out, clearing auth state"),await s?.(),this.socket=null,P(this.socket)),a?.("close");break}}}),b.ev.on("creds.update",g),this.onReceiveMessages&&typeof this.onReceiveMessages=="function"&&b.ev.on("messages.upsert",async({messages:h,type:A})=>{this.logger?.info("WHATSAPP","Received messages",{type:A,totalMessages:h.length}),this.onReceiveMessages?.(h,A);});}),x=await k();return await S(n.CONNECTION_TIMEOUT),x}async ensureSocketConnected(){return this.socket||(this.debug&&this.logger?.warn("WHATSAPP","Client not connected, attempting to connect..."),this.socket=await this.startConnection().catch(e=>(this.onPreConnectionSendMessageFailed?.(e),null))),this.socket}async closeConnection(){this.socket&&(this.debug&&this.logger?.info("WHATSAPP","Closing connection"),this.socket.end(void 0),this.socket=null);}async clearAuthState(){if(await this.closeConnection(),this.mongoURL){let[e,t]=await this.getAuthCollection();this.debug&&this.logger?.info("WHATSAPP","Deleting auth state, required to scanning QR again"),await e?.deleteMany({}),await t?.close();}else this.fileAuthStateDirectoryPath&&ue.rmSync(this.fileAuthStateDirectoryPath,{recursive:true,force:true});}async resetConnection({pairingPhone:e,autoConnect:t=true}={}){await this.clearAuthState(),t&&(await S(n.CONNECTION_TIMEOUT),await this.startConnection({pairingPhone:e}));}isConnected(){return !!this.socket?.user}async deleteMessage(e,t,r=true){if(await this.ensureSocketConnected(),!this.socket)throw new Error("Socket not connected");let s=n.formatPhoneNumberToWhatsappPattern(t);try{if(r){let o=await this.socket.sendMessage(s,{delete:{remoteJid:s,fromMe:!0,id:e,participant:void 0}});return this.debug&&this.logger?.info("WHATSAPP","Message deleted for everyone",{messageId:e,chatJid:s}),o}else throw this.debug&&this.logger?.warn("WHATSAPP","Delete for me is not supported via API",{messageId:e,chatJid:s,reason:["Delete for me only (clear message locally)",`Note: This doesn't work via API - WhatsApp doesn't support "delete for me" via Baileys`,"We can only revoke messages (delete for everyone)"].join(`
2
- `)}),new Error("Delete for me is not supported via WhatsApp API. Use deleteForEveryone=true to revoke the message.")}catch(o){throw this.debug&&this.logger?.error("WHATSAPP","Failed to delete message",{messageId:e,chatJid:s,error:o.message}),o}}async deleteMessages(e,t=true){await this.ensureSocketConnected();let r=[];for(let{messageId:s,chatJid:o}of e)try{let a=await this.deleteMessage(s,o,t);r.push({success:!0,messageId:s,result:a}),await S("500ms");}catch(a){r.push({success:false,messageId:s,error:a.message});}return r}async loadRecentMessages(e,t){await this.ensureSocketConnected();let r=n.formatPhoneNumberToWhatsappPattern(e);try{return await this.socket?.waitForMessage(t,3e3)||null}catch(s){return this.debug&&this.logger?.error("WHATSAPP","Failed to load message history",{chatJid:r,error:s.message}),null}}};var I=class n extends y{constructor(e){super(e);}async deleteMessageById(e,t){return this.deleteMessage(e,t,true)}async sendTextMessage(e,t){await this.ensureSocketConnected();let r=n.formatPhoneNumberToWhatsappPattern(e);return this.socket?.sendMessage(r,{text:t})}async sendButtonsMessage(e,{subtitle:t,title:r,buttons:s}){if(!r||!s.length)throw new Error("sendButtonsMessage: No title or buttons required field found.");await this.ensureSocketConnected();let o=n.formatPhoneNumberToWhatsappPattern(e),a=s?.map(u=>{let c={display_text:u.label},g;switch(true){case !!u.url:g="cta_url",c.url=u.url;break;case !!u.copy:g="cta_copy",c.copy_code=u.copy;break;case !!u.tel:g="cta_call",c.phone_number=u.tel;break;case !!u.email:g="cta_email",c.email=u.email;break;case !!(u.reminderOn||u.reminderDate):g="cta_reminder";let{reminderOn:p,reminderDate:d}=u;c.reminder_name=u.reminderName,c.reminder_timestamp=d?Math.floor(+new Date(d)/1e3):Math.floor(Date.now()/1e3)+U(p??"0s");break;default:g="";break}return {name:g,buttonParamsJson:JSON.stringify(c)}}).filter(u=>u.name),i=generateWAMessageFromContent(o,{viewOnceMessage:{message:{interactiveMessage:WAProto.Message.InteractiveMessage.create({...r&&{body:WAProto.Message.InteractiveMessage.Body.create({text:r})},...t&&{footer:WAProto.Message.InteractiveMessage.Footer.create({text:t})},...!!a?.length&&{nativeFlowMessage:WAProto.Message.InteractiveMessage.NativeFlowMessage.create({buttons:a})}})}}},{userJid:o});return this.debug&&this.logger?.debug("WHATSAPP","send buttons message",{jid:o,footer:t,body:r,buttons:a}),this.socket?.relayMessage(o,i.message,{messageId:i.key.id})}async sendReplyButtonsMessage(e,{title:t,subtitle:r,buttons:s}){if(!t||!s.length)throw new Error("sendReplyButtonsMessage: No title or buttons required field found.");await this.ensureSocketConnected();let o=n.formatPhoneNumberToWhatsappPattern(e),a=s.filter(i=>i).map((i,u)=>typeof i=="string"?{buttonId:`id-${u}`,buttonText:{displayText:i},type:1}:{buttonId:`${i.id}`,buttonText:{displayText:i.label},type:1});return this.debug&&this.logger?.debug("WHATSAPP","send reply buttons message",{jid:o,text:t,footer:r,buttons:a}),this.socket?.sendMessage(o,{text:t,...r&&{footer:r},buttons:a})}async sendLocation(e,{latitude:t,longitude:r,name:s,address:o}){if(t===void 0||r===void 0)throw new Error("sendLocation: latitude and longitude are required fields.");if(t<-90||t>90)throw new Error("sendLocation: latitude must be between -90 and 90.");if(r<-180||r>180)throw new Error("sendLocation: longitude must be between -180 and 180.");await this.ensureSocketConnected();let a=n.formatPhoneNumberToWhatsappPattern(e);return this.debug&&this.logger?.debug("WHATSAPP","send location message",{jid:a,latitude:t,longitude:r,name:s,address:o}),this.socket?.sendMessage(a,{location:{degreesLatitude:t,degreesLongitude:r,...s&&{name:s},...o&&{address:o}}})}};var v=class n extends I{constructor(e){super(e);}async sendFileFromStream(e,t,r){await this.ensureSocketConnected();let s=n.formatPhoneNumberToWhatsappPattern(e),o=t instanceof Buffer?t:await this.streamToBuffer(t),a=r.mimetype||this.getMimetypeFromFilename(r.filename),i=await this.createFileMessage(o,a,r),u={...r.replyToMessageId&&{quoted:{key:{id:r.replyToMessageId}}}};return this.socket?.sendMessage(s,i,u)}async streamToBuffer(e){return new Promise((t,r)=>{let s=[];e.on("data",o=>s.push(Buffer.from(o))),e.on("error",o=>r(o)),e.on("end",()=>t(Buffer.concat(s)));})}getMimetypeFromFilename(e){let t=e.split(".").pop()?.toLowerCase();return J[t||""]||"application/octet-stream"}async createFileMessage(e,t,r){let[s]=t.split("/");switch(s){case "image":return {image:e,caption:r.caption,mimetype:t,fileName:r.filename};case "video":return {video:e,caption:r.caption,mimetype:t,fileName:r.filename,gifPlayback:r.gifPlayback||false,jpegThumbnail:r.jpegThumbnail,...r.seconds&&{seconds:r.seconds}};case "audio":return r.ptt?{audio:e,mimetype:"audio/ogg; codecs=opus",ptt:true,...r.seconds&&{seconds:r.seconds}}:{audio:e,mimetype:t,fileName:r.filename,...r.seconds&&{seconds:r.seconds}};default:return {document:e,mimetype:t,fileName:r.filename,caption:r.caption,jpegThumbnail:r.jpegThumbnail}}}async sendImage(e,t,r={}){return this.sendFileFromStream(e,t,{filename:r.filename||"image.jpg",caption:r.caption,replyToMessageId:r.replyToMessageId})}async sendVideo(e,t,r={}){return this.sendFileFromStream(e,t,{filename:r.filename||"video.mp4",caption:r.caption,gifPlayback:r.gifPlayback,replyToMessageId:r.replyToMessageId,jpegThumbnail:r.jpegThumbnail})}async sendAudio(e,t,r={}){return this.sendFileFromStream(e,t,{filename:r.filename||"audio.mp3",mimetype:r.ptt?"audio/ogg; codecs=opus":"",ptt:r.ptt,seconds:r.seconds,replyToMessageId:r.replyToMessageId})}async sendDocument(e,t,r){return this.sendFileFromStream(e,t,{filename:r.filename,mimetype:r.mimetype,caption:r.caption,replyToMessageId:r.replyToMessageId,jpegThumbnail:r.jpegThumbnail})}async sendVoiceNote(e,t,r={}){return this.sendAudio(e,t,{ptt:true,seconds:r.seconds,replyToMessageId:r.replyToMessageId})}async sendSticker(e,t,r={}){await this.ensureSocketConnected();let s=n.formatPhoneNumberToWhatsappPattern(e),o=t instanceof Buffer?t:await this.streamToBuffer(t),a={...r.replyToMessageId&&{quoted:{key:{id:r.replyToMessageId}}}};return this.socket?.sendMessage(s,{sticker:o},a)}};var G=class n extends v{constructor(e){super(e);}async sendImageMessage(e,t,{caption:r="",filename:s}={}){await this.ensureSocketConnected();let o=n.formatPhoneNumberToWhatsappPattern(e),a=typeof t=="string"?await f(t):t;return this.debug&&this.logger?.debug("WHATSAPP","send image message",{jid:o,caption:r,filename:s}),await this.sendImage(o,a,{caption:r,...s&&{filename:s}})}async sendVideoMessage(e,t,{caption:r="",filename:s,sendAsGifPlayback:o=false}={}){await this.ensureSocketConnected();let a=n.formatPhoneNumberToWhatsappPattern(e),i=typeof t=="string"?await f(t):t;return this.debug&&this.logger?.debug("WHATSAPP","send video message",{jid:a,caption:r,filename:s,gifPlayback:o}),await this.sendVideo(a,i,{caption:r,gifPlayback:o,...s&&{filename:s}})}async sendFileMessage(e,t,{caption:r="",mimetype:s="application/vnd.openxmlformats-officedocument.wordprocessingml.document",replyToMessageId:o,jpegThumbnailSrc:a,filename:i}={}){await this.ensureSocketConnected();let u=n.formatPhoneNumberToWhatsappPattern(e),c=typeof t=="string"?await f(t):t,g;typeof a=="string"?g=await f(a):a instanceof ReadStream?g=await q(a):g=a;let p="mu-document";if(t instanceof ReadStream){let d=j(t);d&&(p=d);}else typeof t=="string"&&(p=basename(t));return this.debug&&this.logger?.debug("WHATSAPP","send file message",{jid:u,caption:r,mimetype:s,filename:p,replyToMessageId:o,includeJpegThumbnail:!!g}),await this.sendDocument(u,c,{caption:r,mimetype:s,filename:p,replyToMessageId:o,jpegThumbnail:g})}async sendAudioMessage(e,t,{filename:r,replyToMessageId:s,mimetype:o,seconds:a}={}){await this.ensureSocketConnected();let i=n.formatPhoneNumberToWhatsappPattern(e),u=typeof t=="string"?await f(t):t,c=a||await L(u,o).catch(()=>0);return this.debug&&this.logger?.debug("WHATSAPP","send audio message",{jid:i,mimetype:o,filename:r,seconds:c,replyToMessageId:s}),await this.sendAudio(i,u,{...r&&{filename:r},...o&&{mimetype:o},...c&&{seconds:c},...s&&{replyToMessageId:s}})}async sendStickerMessage(e,t,{replyToMessageId:r}={}){await this.ensureSocketConnected();let s=n.formatPhoneNumberToWhatsappPattern(e),o=typeof t=="string"?await f(t):t;return this.debug&&this.logger?.debug("WHATSAPP","send sticker message",{jid:s,replyToMessageId:r}),await this.sendSticker(s,o,{replyToMessageId:r})}};var K=class extends G{constructor(e){super(e);}};var W=class n extends y{static formatGroupId(e){return e.endsWith("@g.us")?e:`${e.replace(/@s\.whatsapp\.net|@g\.us/g,"")}@g.us`}static isGroupId(e){return e.endsWith("@g.us")}constructor(e){super(e);}async createGroup({name:e,participants:t,description:r}){if(!e)throw new Error("createGroup: Group name is required.");await this.ensureSocketConnected();let s=(t??[]).map(a=>n.formatPhoneNumberToWhatsappPattern(a));if(s.length===0){let a=this.socket?.user?.id;if(!a)throw new Error("createGroup: Could not get bot user ID. Make sure socket is connected.");let i=n.formatPhoneNumberToWhatsappPattern(a);s.push(i),this.debug&&this.logger?.debug("WHATSAPP","No participants provided, creating group with self only",{selfJid:a});}this.debug&&this.logger?.debug("WHATSAPP","Creating group",{name:e,description:r,participants:s});let o=await this.socket?.groupCreate(e,s);if(r&&o?.id){let a=n.formatGroupId(o.id);await this.updateGroupDescription(a,r);}return o}async updateGroupName(e,t){if(!e||!t)throw new Error("updateGroupName: Group ID and new name are required.");await this.ensureSocketConnected();let r=n.formatGroupId(e);return this.debug&&this.logger?.debug("WHATSAPP","Updating group name",{groupId:r,newName:t}),this.socket?.groupUpdateSubject(r,t)}async updateGroupDescription(e,t){if(!e)throw new Error("updateGroupDescription: Group ID is required.");await this.ensureSocketConnected();let r=n.formatGroupId(e);return this.debug&&this.logger?.debug("WHATSAPP","Updating group description",{groupId:r}),this.socket?.groupUpdateDescription(r,t||"")}async updateGroupSettings(e,t){if(!e||!t)throw new Error("updateGroupSettings: Group ID and setting are required.");await this.ensureSocketConnected();let r=n.formatGroupId(e);return this.debug&&this.logger?.debug("WHATSAPP","Updating group settings",{groupId:r,setting:t}),this.socket?.groupSettingUpdate(r,t)}async updateGroupParticipants(e,t,r){if(!e)throw new Error("addParticipants: Group ID is required.");let s=[].concat(t).filter(i=>i);if(s?.length)return;await this.ensureSocketConnected();let o=n.formatGroupId(e),a=s.map(i=>n.formatPhoneNumberToWhatsappPattern(i));return this.debug&&this.logger?.debug("WHATSAPP",`${r} participants to group`,{groupId:o,participantsCount:a.length}),this.socket?.groupParticipantsUpdate(o,a,r)}async addParticipants(e,t){return this.updateGroupParticipants(e,t,"add")}async removeParticipants(e,t){return this.updateGroupParticipants(e,t,"remove")}async promoteToAdmin(e,t){return this.updateGroupParticipants(e,t,"promote")}async demoteFromAdmin(e,t){return this.updateGroupParticipants(e,t,"demote")}async leaveGroup(e){if(!e)throw new Error("leaveGroup: Group ID is required.");await this.ensureSocketConnected();let t=n.formatGroupId(e);return this.debug&&this.logger?.debug("WHATSAPP","Leaving group",{groupId:t}),this.socket?.groupLeave(t)}async getGroupMetadata(e){if(!e)throw new Error("getGroupMetadata: Group ID is required.");await this.ensureSocketConnected();let t=n.formatGroupId(e);return this.debug&&this.logger?.debug("WHATSAPP","Fetching group metadata",{groupId:t}),this.socket?.groupMetadata(t)}async getAllGroups(){await this.ensureSocketConnected(),this.debug&&this.logger?.debug("WHATSAPP","Fetching all groups");let e=await this.socket?.groupFetchAllParticipating();return e?Object.values(e):[]}async getGroupInviteCode(e){if(!e)throw new Error("getGroupInviteCode: Group ID is required.");await this.ensureSocketConnected();let t=n.formatGroupId(e);return this.debug&&this.logger?.debug("WHATSAPP","Fetching group invite code",{groupId:t}),this.socket?.groupInviteCode(t)}async revokeGroupInviteCode(e){if(!e)throw new Error("revokeGroupInviteCode: Group ID is required.");await this.ensureSocketConnected();let t=n.formatGroupId(e);return this.debug&&this.logger?.debug("WHATSAPP","Revoking group invite code",{groupId:t}),this.socket?.groupRevokeInvite(t)}async joinGroupViaInvite(e){if(!e)throw new Error("joinGroupViaInvite: Invite code is required.");return await this.ensureSocketConnected(),this.debug&&this.logger?.debug("WHATSAPP","Joining group via invite",{inviteCode:e}),this.socket?.groupAcceptInvite(e)}async getGroupInfoFromInvite(e){if(!e)throw new Error("getGroupInfoFromInvite: Invite code is required.");return await this.ensureSocketConnected(),this.debug&&this.logger?.debug("WHATSAPP","Fetching group info from invite",{inviteCode:e}),this.socket?.groupGetInviteInfo(e)}async updateGroupProfilePicture(e,t){if(!e||!t)throw new Error("updateGroupProfilePicture: Group ID and image buffer are required.");await this.ensureSocketConnected();let r=n.formatGroupId(e);return this.debug&&this.logger?.debug("WHATSAPP","Updating group profile picture",{groupId:r}),this.socket?.updateProfilePicture(r,t)}async removeGroupProfilePicture(e){if(!e)throw new Error("removeGroupProfilePicture: Group ID is required.");await this.ensureSocketConnected();let t=n.formatGroupId(e);return this.debug&&this.logger?.debug("WHATSAPP","Removing group profile picture",{groupId:t}),this.socket?.removeProfilePicture(t)}async getGroupProfilePicture(e,t=false){if(!e)throw new Error("getGroupProfilePicture: Group ID is required.");await this.ensureSocketConnected();let r=n.formatGroupId(e);return this.debug&&this.logger?.debug("WHATSAPP","Fetching group profile picture",{groupId:r,highRes:t}),this.socket?.profilePictureUrl(r,t?"image":"preview")}};var R=class n extends W{constructor(e){super(e);}async sendTextMessage(e,t,r){if(!e||!t)throw new Error("sendTextMessage: Group ID and text are required.");await this.ensureSocketConnected();let s=n.formatGroupId(e),o={};return r?.replyToMessageId&&(o.quoted={key:{id:r.replyToMessageId}}),this.debug&&this.logger?.debug("WHATSAPP","Sending text message to group",{groupId:s,textLength:t.length,hasMentions:!!r?.mentions?.length}),this.socket?.sendMessage(s,{text:t},o)}async sendButtonsMessage(e,{title:t,subtitle:r,buttons:s}){if(!e||!t||!s?.length)throw new Error("sendButtonsMessage: Group ID, title, and buttons are required.");await this.ensureSocketConnected();let o=n.formatGroupId(e),a=s?.map(u=>{let c={display_text:u.label},g;switch(true){case !!u.url:g="cta_url",c.url=u.url;break;case !!u.copy:g="cta_copy",c.copy_code=u.copy;break;case !!u.tel:g="cta_call",c.phone_number=u.tel;break;default:g="";break}return {name:g,buttonParamsJson:JSON.stringify(c)}}).filter(u=>u.name),i=generateWAMessageFromContent(o,{viewOnceMessage:{message:{interactiveMessage:WAProto.Message.InteractiveMessage.create({body:WAProto.Message.InteractiveMessage.Body.create({text:t}),...r&&{footer:WAProto.Message.InteractiveMessage.Footer.create({text:r})},nativeFlowMessage:WAProto.Message.InteractiveMessage.NativeFlowMessage.create({buttons:a})})}}},{userJid:o});return this.debug&&this.logger?.debug("WHATSAPP","Sending buttons message to group",{groupId:o,title:t,buttonsCount:a.length}),this.socket?.relayMessage(o,i.message,{messageId:i.key.id})}async sendReplyButtonsMessage(e,{title:t,subtitle:r,buttons:s,mentions:o}){if(!e||!t||!s?.length)throw new Error("sendReplyButtonsMessage: Group ID, title, and buttons are required.");await this.ensureSocketConnected();let a=n.formatGroupId(e),i=s.filter(c=>c).map((c,g)=>typeof c=="string"?{buttonId:`id-${g}`,buttonText:{displayText:c},type:1}:{buttonId:`${c.id}`,buttonText:{displayText:c.label},type:1}),u={text:t,buttons:i,...r&&{footer:r}};return o?.length&&(u.mentions=o.map(c=>n.formatPhoneNumberToWhatsappPattern(c))),this.debug&&this.logger?.debug("WHATSAPP","Sending reply buttons message to group",{groupId:a,title:t,buttonsCount:i.length}),this.socket?.sendMessage(a,u)}async sendImageMessage(e,t,{caption:r,mentions:s}={}){if(!e||!t)throw new Error("sendImage: Group ID and image buffer are required.");await this.ensureSocketConnected();let o=n.formatGroupId(e),a={image:t,...r&&{caption:r}};return s?.length&&(a.mentions=s.map(i=>n.formatPhoneNumberToWhatsappPattern(i))),this.debug&&this.logger?.debug("WHATSAPP","Sending image to group",{groupId:o,hasCaption:!!r}),this.socket?.sendMessage(o,a)}async sendVideoMessage(e,t,r,s){if(!e||!t)throw new Error("sendVideo: Group ID and video buffer are required.");await this.ensureSocketConnected();let o=n.formatGroupId(e),a={video:t,...r&&{caption:r}};return s?.mentions?.length&&(a.mentions=s.mentions.map(i=>n.formatPhoneNumberToWhatsappPattern(i))),this.debug&&this.logger?.debug("WHATSAPP","Sending video to group",{groupId:o,hasCaption:!!r}),this.socket?.sendMessage(o,a)}async sendAudioMessage(e,t,r){if(!e||!t)throw new Error("sendAudio: Group ID and audio buffer are required.");await this.ensureSocketConnected();let s=n.formatGroupId(e),o={audio:t,ptt:r?.ptt??false};return r?.mentions?.length&&(o.mentions=r.mentions.map(a=>n.formatPhoneNumberToWhatsappPattern(a))),this.debug&&this.logger?.debug("WHATSAPP","Sending audio to group",{groupId:s,isPTT:o.ptt}),this.socket?.sendMessage(s,o)}async sendDocumentMessage(e,t,r,s,o){if(!e||!t||!r)throw new Error("sendDocument: Group ID, document buffer, and fileName are required.");await this.ensureSocketConnected();let a=n.formatGroupId(e),i={document:t,fileName:r,...s&&{mimetype:s}};return o?.mentions?.length&&(i.mentions=o.mentions.map(u=>n.formatPhoneNumberToWhatsappPattern(u))),this.debug&&this.logger?.debug("WHATSAPP","Sending document to group",{groupId:a,fileName:r}),this.socket?.sendMessage(a,i)}async sendLocationMessage(e,t,r,s,o){if(!e||t===void 0||r===void 0)throw new Error("sendLocation: Group ID, latitude, and longitude are required.");await this.ensureSocketConnected();let a=n.formatGroupId(e);return this.debug&&this.logger?.debug("WHATSAPP","Sending location to group",{groupId:a,latitude:t,longitude:r}),this.socket?.sendMessage(a,{location:{degreesLatitude:t,degreesLongitude:r,...s&&{name:s},...o&&{address:o}}})}async sendMentionAll(e,t){if(!e||!t)throw new Error("sendMentionAll: Group ID and text are required.");await this.ensureSocketConnected();let r=n.formatGroupId(e),s=await this.getGroupMetadata(r);if(!s)throw new Error("Could not fetch group metadata");let o=s.participants.map(a=>a.id);return this.debug&&this.logger?.debug("WHATSAPP","Sending mention all message to group",{groupId:r,participantsCount:o.length}),this.socket?.sendMessage(r,{text:t,mentions:o})}async sendReactionMessage(e,t,r){if(!e||!t||!r)throw new Error("sendReaction: Group ID, message ID, and emoji are required.");await this.ensureSocketConnected();let s=n.formatGroupId(e);return this.debug&&this.logger?.debug("WHATSAPP","Sending reaction to group message",{groupId:s,messageId:t,emoji:r}),this.socket?.sendMessage(s,{react:{text:r,key:{id:t,remoteJid:s}}})}async deleteGroupMessage(e,t){if(!e||!t)throw new Error("deleteGroupMessage: Group ID and message ID are required.");await this.ensureSocketConnected();let r=n.formatGroupId(e);return this.debug&&this.logger?.debug("WHATSAPP","Deleting message in group",{groupId:r,messageId:t}),this.socket?.sendMessage(r,{delete:{id:t,remoteJid:r,fromMe:true}})}};var z=class extends R{constructor(e){super(e);}};export{K as WhatsappSocket,z as WhatsappSocketGroup};//# sourceMappingURL=index.js.map
1
+ import ue,{ReadStream}from'fs';import oe,{generateWAMessageFromContent,WAProto,useMultiFileAuthState,makeCacheableSignalKeyStore,DisconnectReason,initAuthCreds}from'@fadzzzslebew/baileys';import H from'ms';import V from'qrcode';import {MongoClient}from'mongodb';import ge from'pino';import {basename}from'path';var O={replacer:(n,e)=>Buffer.isBuffer(e)||e instanceof Uint8Array||e?.type==="Buffer"?{type:"Buffer",data:Buffer.from(e?.data||e).toString("base64")}:e,reviver:(n,e)=>{if(typeof e=="object"&&e&&(e.buffer===true||e.type==="Buffer")){let t=e.data||e.value;return typeof t=="string"?Buffer.from(t,"base64"):Buffer.from(t||[])}return e}},_=async n=>{let e=(o,a)=>{let u={$set:{...JSON.parse(JSON.stringify(o,O.replacer))}};return n.updateOne({_id:a},u,{upsert:true})},t=async o=>{try{let a=JSON.stringify(await n.findOne({_id:o}));return JSON.parse(a,O.reviver)}catch{return null}},r=async o=>{try{await n.deleteOne({_id:o});}catch{}},s=await t("creds")||initAuthCreds();return {state:{creds:s,keys:{get:async(o,a)=>{let i={};return await Promise.all(a.map(async u=>{let c=await t(`${o}-${u}`);o==="app-state-sync-key"&&c&&(c=WAProto.Message.AppStateSyncKeyData.fromObject(c)),i[u]=c;})),i},set:async o=>{let a=[];for(let i of Object.keys(o))for(let u of Object.keys(o[i])){let c=o[i][u],g=`${i}-${u}`;a.push(c?e(c,g):r(g));}await Promise.all(a);}}},saveCreds:()=>e(s,"creds")}},F=_;var U=n=>H(n)/1e3;async function h(n){let t=await(await fetch(n)).arrayBuffer();return Buffer.from(t)}async function re(n,e){try{let{parseStream:t}=await import('music-metadata'),r=await t(n,{mimeType:e||"audio/mpeg"});return Math.floor(r.format.duration||0)}catch(t){throw console.error("Error parsing stream:",t),t}finally{n.destroyed||n.destroy();}}async function se(n,e){try{let{parseBuffer:t}=await import('music-metadata'),r=await t(n,e||"audio/mpeg").catch(()=>null);return r?Math.floor(r.format.duration||0):0}catch(t){throw console.error("Error parsing buffer:",t),t}}async function L(n,e){return n instanceof ReadStream?re(n,e):se(n,e)}async function q(n){let e=[];for await(let t of n)e.push(t);return Buffer.concat(e)}function j(n){if(n.path){let e=n.path.toString();return basename(e)}}var S=n=>new Promise(e=>setTimeout(e,typeof n=="number"?n:H(n))),J={jpg:"image/jpeg",jpeg:"image/jpeg",png:"image/png",gif:"image/gif",webp:"image/webp",bmp:"image/bmp",svg:"image/svg+xml",mp4:"video/mp4",avi:"video/x-msvideo",mov:"video/quicktime",mkv:"video/x-matroska",webm:"video/webm",mp3:"audio/mpeg",wav:"audio/wav",ogg:"audio/ogg",opus:"audio/opus",aac:"audio/aac",m4a:"audio/mp4",pdf:"application/pdf",doc:"application/msword",docx:"application/vnd.openxmlformats-officedocument.wordprocessingml.document",xls:"application/vnd.ms-excel",xlsx:"application/vnd.openxmlformats-officedocument.spreadsheetml.sheet",ppt:"application/vnd.ms-powerpoint",pptx:"application/vnd.openxmlformats-officedocument.presentationml.presentation",txt:"text/plain",zip:"application/zip",rar:"application/x-rar-compressed","7z":"application/x-7z-compressed"};var Q=ge({level:"silent"}),y=class n{fileAuthStateDirectoryPath;mongoURL;mongoCollection="whatsapp-auth";logger;debug;printQRInTerminal;pairingPhone;customPairingCode;appName;onPreConnectionSendMessageFailed;onOpen;onClose;onQR;onConnectionStatusChange;onReceiveMessages;static DEFAULT_COUNTRY_CODE="972";static CONNECTION_TIMEOUT="2s";static formatPhoneNumber(e,t=n.DEFAULT_COUNTRY_CODE){if(e.endsWith("@s.whatsapp.net"))return e;let r=e.replace(/[^0-9]/g,"");return r.startsWith("05")&&(r=r.substring(1)),r.startsWith(t)||(r=t+r),r}static formatPhoneNumberToWhatsappPattern(e,t=n.DEFAULT_COUNTRY_CODE){if(e.endsWith("@s.whatsapp.net"))return e.replace(/:\d+@/,"@");let r=n.formatPhoneNumber(e,t);return r=`${r}@s.whatsapp.net`,r=r.replace(/:\d+@/,"@"),r}static getWhatsappPhoneLink({phone:e,message:t,countryCode:r=n.DEFAULT_COUNTRY_CODE}){let s=this.formatPhoneNumber(e,r),o=t?`?text=${encodeURI(t)}`:"";return `https://wa.me/${s}${o}`}static async qrToImage(e,t={}){return V.toDataURL(e,{errorCorrectionLevel:"H",width:400,margin:2,...t})}static async qrToTerminalString(e,t={}){return V.toString(e,{type:"terminal",small:true,...t})}static randomPairingCode(e,t=8){if(!e.includes("[")&&e.length===t)return e;let r="",s=[],o=i=>{let u=[];for(let c=0;c<i.length;c++)if(i[c+1]==="-"&&i[c+2]){let g=i.charCodeAt(c),p=i.charCodeAt(c+2);for(let d=g;d<=p;d++)u.push(String.fromCharCode(d));c+=2;}else u.push(i[c]);return u};for(let i=0;i<e.length&&r.length<t;i++){let u=e[i];if(u==="["){let c=e.indexOf("]",i),g=e.slice(i+1,c);s=o(g),i=c;}else r+=u;}for(;r.length<t&&s.length;)r+=s[Math.floor(Math.random()*s.length)];let a=r.toUpperCase();return a.padEnd(t,a)}static instances=new Map;static getInstance(e){let t=n.buildSocketKey(e);return n.instances.has(t)||new n(e),n.instances.get(t)}static clearInstance(e){e?n.instances.delete(e):n.instances.clear();}constructor(e){let{fileAuthStateDirectoryPath:t,mongoURL:r,mongoCollection:s="whatsapp-auth",logger:o,onOpen:a,onClose:i,onQR:u,onReceiveMessages:c,onConnectionStatusChange:g,debug:p,printQRInTerminal:d,pairingPhone:D,customPairingCode:k,onPreConnectionSendMessageFailed:x,appName:P}=e;this.appName=P,this.mongoURL=r,this.fileAuthStateDirectoryPath=t,this.mongoCollection=s,this.logger=o,this.debug=p,this.printQRInTerminal=d,this.pairingPhone=D,this.customPairingCode=k,this.onPreConnectionSendMessageFailed=x,this.onConnectionStatusChange=g,this.onReceiveMessages=c,this.onOpen=a,this.onClose=i,this.onQR=u,n.instances.has(this.socketKey)&&(this.socket=n.instances.get(this.socketKey));}async getLatestWhatsAppVersion(){try{let e=["https://raw.githubusercontent.com/WhiskeySockets/Baileys/master/src/Defaults/baileys-version.json","https://raw.githubusercontent.com/whiskeysockets/baileys/master/src/Defaults/baileys-version.json"];for(let t of e)try{let r=await fetch(t);if(r.ok)return (await r.json()).version}catch{continue}return console.log("Could not fetch version, using fallback"),[2,3e3,1015901307]}catch(e){return console.error("Error fetching version:",e),[2,3e3,1015901307]}}async getAuthCollection(){if(!this.mongoURL)return [];let e=new MongoClient(this.mongoURL);return await e.connect(),[e.db().collection(this.mongoCollection),e]}async authenticate(){if(!this.mongoURL&&!this.fileAuthStateDirectoryPath)throw new Error("fileAuthStateDirectoryPath/MongoURL is missing");if(!this.mongoURL){let{saveCreds:o,state:a}=await useMultiFileAuthState(this.fileAuthStateDirectoryPath);return {auth:a,saveCreds:o}}let[e]=await this.getAuthCollection(),{state:t,saveCreds:r}=await F(e);return {auth:{creds:t.creds,keys:makeCacheableSignalKeyStore(t.keys,Q)},saveCreds:r}}static buildSocketKey(e){return e.appName||e.pairingPhone||e.mongoCollection||e.fileAuthStateDirectoryPath||"default"}get socketKey(){return this.appName||this.pairingPhone||this.mongoCollection||this.fileAuthStateDirectoryPath||"default"}get socket(){return n.instances.get(this.socketKey)??null}set socket(e){n.instances.set(this.socketKey,e);}async startConnection({options:e,connectionAttempts:t=3,onOpen:r=this.onOpen,onClose:s=this.onClose,onQR:o=this.onQR,onConnectionStatusChange:a=this.onConnectionStatusChange,pairingPhone:i,debug:u}={}){let c=i??this.pairingPhone,{saveCreds:g,auth:p}=await this.authenticate(),d=u===void 0?this.debug:u,D=await this.getLatestWhatsAppVersion(),k=async()=>new Promise(P=>{let b=oe({version:D,logger:Q,browser:[this.appName||"baileys","1.0.0",""],syncFullHistory:true,shouldIgnoreJid:f=>f.includes("@newsletter"),...e,printQRInTerminal:false,auth:p});b.ev.on("connection.update",async f=>{let{connection:A,lastDisconnect:E,qr:M}=f;if(M){if(d&&this.logger?.info("WHATSAPP","QR Code received",{qr:M}),this.printQRInTerminal){let Y=await n.qrToTerminalString(M,{small:true}).catch(()=>null);console.log(Y);}this.customPairingCode?n.randomPairingCode(this.customPairingCode):void 0;let w=c?n.formatPhoneNumber(c):null,T=w?await b.requestPairingCode(w):null;d&&this.printQRInTerminal&&this.logger?.info("WHATSAPP","QR Pairing Code",{code:T,pairingPhone:w}),await o?.(M,T);}switch(A){case "connecting":{d&&this.logger?.debug("WHATSAPP","Connecting..."),a?.("connecting");break}case "open":{d&&this.logger?.info("WHATSAPP","Connection opened successfully!"),this.socket=b,await r?.(),a?.("open"),P(this.socket);break}case "close":{let N=t-- >0&&E?.error?.output?.statusCode!==DisconnectReason.loggedOut,w=E?.error?.output?.statusCode,T=E?.error?.message;d&&this.logger?.info("WHATSAPP","Connection closed",{statusCode:w,errorMessage:T,shouldReconnect:N}),N&&t?(d&&this.logger?.info("WHATSAPP","Reconnecting..."),await S(n.CONNECTION_TIMEOUT),P(k())):(d&&this.logger?.warn("WHATSAPP","Logged out, clearing auth state"),await s?.(),this.socket=null,P(this.socket)),a?.("close");break}}}),b.ev.on("creds.update",g),this.onReceiveMessages&&typeof this.onReceiveMessages=="function"&&b.ev.on("messages.upsert",async({messages:f,type:A})=>{this.logger?.info("WHATSAPP","Received messages",{type:A,totalMessages:f.length}),this.onReceiveMessages?.(f,A);});}),x=await k();return await S(n.CONNECTION_TIMEOUT),x}async ensureSocketConnected(){return this.socket||(this.debug&&this.logger?.warn("WHATSAPP","Client not connected, attempting to connect..."),this.socket=await this.startConnection().catch(e=>(this.onPreConnectionSendMessageFailed?.(e),null))),this.socket}async closeConnection(){this.socket&&(this.debug&&this.logger?.info("WHATSAPP","Closing connection"),this.socket.end(void 0),this.socket=null);}async clearAuthState(){if(await this.closeConnection(),this.mongoURL){let[e,t]=await this.getAuthCollection();this.debug&&this.logger?.info("WHATSAPP","Deleting auth state, required to scanning QR again"),await e?.deleteMany({}),await t?.close();}else this.fileAuthStateDirectoryPath&&ue.rmSync(this.fileAuthStateDirectoryPath,{recursive:true,force:true});}async resetConnection({pairingPhone:e,autoConnect:t=true}={}){await this.clearAuthState(),t&&(await S(n.CONNECTION_TIMEOUT),await this.startConnection({pairingPhone:e}));}isConnected(){return !!this.socket?.user}async deleteMessage(e,t,r=true){if(await this.ensureSocketConnected(),!this.socket)throw new Error("Socket not connected");let s=n.formatPhoneNumberToWhatsappPattern(t);try{if(r){let o=await this.socket.sendMessage(s,{delete:{remoteJid:s,fromMe:!0,id:e,participant:void 0}});return this.debug&&this.logger?.info("WHATSAPP","Message deleted for everyone",{messageId:e,chatJid:s}),o}else throw this.debug&&this.logger?.warn("WHATSAPP","Delete for me is not supported via API",{messageId:e,chatJid:s,reason:["Delete for me only (clear message locally)",`Note: This doesn't work via API - WhatsApp doesn't support "delete for me" via Baileys`,"We can only revoke messages (delete for everyone)"].join(`
2
+ `)}),new Error("Delete for me is not supported via WhatsApp API. Use deleteForEveryone=true to revoke the message.")}catch(o){throw this.debug&&this.logger?.error("WHATSAPP","Failed to delete message",{messageId:e,chatJid:s,error:o.message}),o}}async deleteMessages(e,t=true){await this.ensureSocketConnected();let r=[];for(let{messageId:s,chatJid:o}of e)try{let a=await this.deleteMessage(s,o,t);r.push({success:!0,messageId:s,result:a}),await S("500ms");}catch(a){r.push({success:false,messageId:s,error:a.message});}return r}async loadRecentMessages(e,t){await this.ensureSocketConnected();let r=n.formatPhoneNumberToWhatsappPattern(e);try{return await this.socket?.waitForMessage(t,3e3)||null}catch(s){return this.debug&&this.logger?.error("WHATSAPP","Failed to load message history",{chatJid:r,error:s.message}),null}}};var v=class n extends y{constructor(e){super(e);}async deleteMessageById(e,t){return this.deleteMessage(e,t,true)}async sendTextMessage(e,t){await this.ensureSocketConnected();let r=n.formatPhoneNumberToWhatsappPattern(e);return this.socket?.sendMessage(r,{text:t})}async sendButtonsMessage(e,{subtitle:t,title:r,buttons:s}){if(!r||!s.length)throw new Error("sendButtonsMessage: No title or buttons required field found.");await this.ensureSocketConnected();let o=n.formatPhoneNumberToWhatsappPattern(e),a=s?.map(u=>{let c={display_text:u.label},g;switch(true){case !!u.url:g="cta_url",c.url=u.url;break;case !!u.copy:g="cta_copy",c.copy_code=u.copy;break;case !!u.tel:g="cta_call",c.phone_number=u.tel;break;case !!u.email:g="cta_email",c.email=u.email;break;case !!(u.reminderOn||u.reminderDate):g="cta_reminder";let{reminderOn:p,reminderDate:d}=u;c.reminder_name=u.reminderName,c.reminder_timestamp=d?Math.floor(+new Date(d)/1e3):Math.floor(Date.now()/1e3)+U(p??"0s");break;default:g="";break}return {name:g,buttonParamsJson:JSON.stringify(c)}}).filter(u=>u.name),i=generateWAMessageFromContent(o,{viewOnceMessage:{message:{interactiveMessage:WAProto.Message.InteractiveMessage.create({...r&&{body:WAProto.Message.InteractiveMessage.Body.create({text:r})},...t&&{footer:WAProto.Message.InteractiveMessage.Footer.create({text:t})},...!!a?.length&&{nativeFlowMessage:WAProto.Message.InteractiveMessage.NativeFlowMessage.create({buttons:a})}})}}},{userJid:o});return this.debug&&this.logger?.debug("WHATSAPP","send buttons message",{jid:o,footer:t,body:r,buttons:a}),this.socket?.relayMessage(o,i.message,{messageId:i.key.id})}async sendReplyButtonsMessage(e,{title:t,subtitle:r,buttons:s}){if(!t||!s.length)throw new Error("sendReplyButtonsMessage: No title or buttons required field found.");await this.ensureSocketConnected();let o=n.formatPhoneNumberToWhatsappPattern(e),a=s.filter(i=>i).map((i,u)=>typeof i=="string"?{buttonId:`id-${u}`,buttonText:{displayText:i},type:1}:{buttonId:`${i.id}`,buttonText:{displayText:i.label},type:1});return this.debug&&this.logger?.debug("WHATSAPP","send reply buttons message",{jid:o,text:t,footer:r,buttons:a}),this.socket?.sendMessage(o,{text:t,...r&&{footer:r},buttons:a})}async sendLocation(e,{latitude:t,longitude:r,name:s,address:o}){if(t===void 0||r===void 0)throw new Error("sendLocation: latitude and longitude are required fields.");if(t<-90||t>90)throw new Error("sendLocation: latitude must be between -90 and 90.");if(r<-180||r>180)throw new Error("sendLocation: longitude must be between -180 and 180.");await this.ensureSocketConnected();let a=n.formatPhoneNumberToWhatsappPattern(e);return this.debug&&this.logger?.debug("WHATSAPP","send location message",{jid:a,latitude:t,longitude:r,name:s,address:o}),this.socket?.sendMessage(a,{location:{degreesLatitude:t,degreesLongitude:r,...s&&{name:s},...o&&{address:o}}})}};var I=class n extends v{constructor(e){super(e);}async sendFileFromStream(e,t,r){await this.ensureSocketConnected();let s=n.formatPhoneNumberToWhatsappPattern(e),o=t instanceof Buffer?t:await this.streamToBuffer(t),a=r.mimetype||this.getMimetypeFromFilename(r.filename),i=await this.createFileMessage(o,a,r),u={...r.replyToMessageId&&{quoted:{key:{id:r.replyToMessageId}}}};return this.socket?.sendMessage(s,i,u)}async streamToBuffer(e){return new Promise((t,r)=>{let s=[];e.on("data",o=>s.push(Buffer.from(o))),e.on("error",o=>r(o)),e.on("end",()=>t(Buffer.concat(s)));})}getMimetypeFromFilename(e){let t=e.split(".").pop()?.toLowerCase();return J[t||""]||"application/octet-stream"}async createFileMessage(e,t,r){let[s]=t.split("/");switch(s){case "image":return {image:e,caption:r.caption,mimetype:t,fileName:r.filename};case "video":return {video:e,caption:r.caption,mimetype:t,fileName:r.filename,gifPlayback:r.gifPlayback||false,jpegThumbnail:r.jpegThumbnail,...r.seconds&&{seconds:r.seconds}};case "audio":return r.ptt?{audio:e,mimetype:"audio/ogg; codecs=opus",ptt:true,...r.seconds&&{seconds:r.seconds}}:{audio:e,mimetype:t,fileName:r.filename,...r.seconds&&{seconds:r.seconds}};default:return {document:e,mimetype:t,fileName:r.filename,caption:r.caption,jpegThumbnail:r.jpegThumbnail}}}async sendImage(e,t,r={}){return this.sendFileFromStream(e,t,{filename:r.filename||"image.jpg",caption:r.caption,replyToMessageId:r.replyToMessageId})}async sendVideo(e,t,r={}){return this.sendFileFromStream(e,t,{filename:r.filename||"video.mp4",caption:r.caption,gifPlayback:r.gifPlayback,replyToMessageId:r.replyToMessageId,jpegThumbnail:r.jpegThumbnail})}async sendAudio(e,t,r={}){return this.sendFileFromStream(e,t,{filename:r.filename||"audio.mp3",mimetype:r.ptt?"audio/ogg; codecs=opus":"",ptt:r.ptt,seconds:r.seconds,replyToMessageId:r.replyToMessageId})}async sendDocument(e,t,r){return this.sendFileFromStream(e,t,{filename:r.filename,mimetype:r.mimetype,caption:r.caption,replyToMessageId:r.replyToMessageId,jpegThumbnail:r.jpegThumbnail})}async sendVoiceNote(e,t,r={}){return this.sendAudio(e,t,{ptt:true,seconds:r.seconds,replyToMessageId:r.replyToMessageId})}async sendSticker(e,t,r={}){await this.ensureSocketConnected();let s=n.formatPhoneNumberToWhatsappPattern(e),o=t instanceof Buffer?t:await this.streamToBuffer(t),a={...r.replyToMessageId&&{quoted:{key:{id:r.replyToMessageId}}}};return this.socket?.sendMessage(s,{sticker:o},a)}};var G=class n extends I{constructor(e){super(e);}async sendImageMessage(e,t,{caption:r="",filename:s}={}){await this.ensureSocketConnected();let o=n.formatPhoneNumberToWhatsappPattern(e),a=typeof t=="string"?await h(t):t;return this.debug&&this.logger?.debug("WHATSAPP","send image message",{jid:o,caption:r,filename:s}),await this.sendImage(o,a,{caption:r,...s&&{filename:s}})}async sendVideoMessage(e,t,{caption:r="",filename:s,sendAsGifPlayback:o=false}={}){await this.ensureSocketConnected();let a=n.formatPhoneNumberToWhatsappPattern(e),i=typeof t=="string"?await h(t):t;return this.debug&&this.logger?.debug("WHATSAPP","send video message",{jid:a,caption:r,filename:s,gifPlayback:o}),await this.sendVideo(a,i,{caption:r,gifPlayback:o,...s&&{filename:s}})}async sendFileMessage(e,t,{caption:r="",mimetype:s="application/vnd.openxmlformats-officedocument.wordprocessingml.document",replyToMessageId:o,jpegThumbnailSrc:a,filename:i}={}){await this.ensureSocketConnected();let u=n.formatPhoneNumberToWhatsappPattern(e),c=typeof t=="string"?await h(t):t,g;typeof a=="string"?g=await h(a):a instanceof ReadStream?g=await q(a):g=a;let p="mu-document";if(t instanceof ReadStream){let d=j(t);d&&(p=d);}else typeof t=="string"&&(p=basename(t));return this.debug&&this.logger?.debug("WHATSAPP","send file message",{jid:u,caption:r,mimetype:s,filename:p,replyToMessageId:o,includeJpegThumbnail:!!g}),await this.sendDocument(u,c,{caption:r,mimetype:s,filename:p,replyToMessageId:o,jpegThumbnail:g})}async sendAudioMessage(e,t,{filename:r,replyToMessageId:s,mimetype:o,seconds:a}={}){await this.ensureSocketConnected();let i=n.formatPhoneNumberToWhatsappPattern(e),u=typeof t=="string"?await h(t):t,c=a||await L(u,o).catch(()=>0);return this.debug&&this.logger?.debug("WHATSAPP","send audio message",{jid:i,mimetype:o,filename:r,seconds:c,replyToMessageId:s}),await this.sendAudio(i,u,{...r&&{filename:r},...o&&{mimetype:o},...c&&{seconds:c},...s&&{replyToMessageId:s}})}async sendStickerMessage(e,t,{replyToMessageId:r}={}){await this.ensureSocketConnected();let s=n.formatPhoneNumberToWhatsappPattern(e),o=typeof t=="string"?await h(t):t;return this.debug&&this.logger?.debug("WHATSAPP","send sticker message",{jid:s,replyToMessageId:r}),await this.sendSticker(s,o,{replyToMessageId:r})}};var K=class extends G{constructor(e){super(e);}};var W=class n extends y{static formatGroupId(e){return e.endsWith("@g.us")?e:`${e.replace(/@s\.whatsapp\.net|@g\.us/g,"")}@g.us`}static isGroupId(e){return e.endsWith("@g.us")}constructor(e){super(e);}async createGroup({name:e,participants:t,description:r}){if(!e)throw new Error("createGroup: Group name is required.");await this.ensureSocketConnected();let s=(t??[]).map(a=>n.formatPhoneNumberToWhatsappPattern(a));if(s.length===0){let a=this.socket?.user?.id;if(!a)throw new Error("createGroup: Could not get bot user ID. Make sure socket is connected.");let i=n.formatPhoneNumberToWhatsappPattern(a);s.push(i),this.debug&&this.logger?.debug("WHATSAPP","No participants provided, creating group with self only",{selfJid:a});}this.debug&&this.logger?.debug("WHATSAPP","Creating group",{name:e,description:r,participants:s});let o=await this.socket?.groupCreate(e,s);if(r&&o?.id){let a=n.formatGroupId(o.id);await this.updateGroupDescription(a,r);}return o}async updateGroupName(e,t){if(!e||!t)throw new Error("updateGroupName: Group ID and new name are required.");await this.ensureSocketConnected();let r=n.formatGroupId(e);return this.debug&&this.logger?.debug("WHATSAPP","Updating group name",{groupId:r,newName:t}),this.socket?.groupUpdateSubject(r,t)}async updateGroupDescription(e,t,r=false){if(!e)throw new Error("updateGroupDescription: Group ID is required.");await this.ensureSocketConnected();let s=n.formatGroupId(e);return r&&await this.socket?.groupMetadata(s).then(o=>{this.debug&&this.logger?.debug("WHATSAPP","Fetch group description metadata",o);}).catch(o=>{this.debug&&this.logger?.warn("WHATSAPP","Failed to update group description metadata",{error:o});}),this.debug&&this.logger?.debug("WHATSAPP","Updating group description",{groupId:s}),this.socket?.groupUpdateDescription(s,t||"")}async updateGroupSettings(e,t){if(!e||!t)throw new Error("updateGroupSettings: Group ID and setting are required.");await this.ensureSocketConnected();let r=n.formatGroupId(e);return this.debug&&this.logger?.debug("WHATSAPP","Updating group settings",{groupId:r,setting:t}),this.socket?.groupSettingUpdate(r,t)}async updateGroupParticipants(e,t,r){if(!e)throw new Error("addParticipants: Group ID is required.");let s=[].concat(t).filter(i=>i);if(!s?.length)return;await this.ensureSocketConnected();let o=n.formatGroupId(e),a=s.map(i=>n.formatPhoneNumberToWhatsappPattern(i));return this.debug&&this.logger?.debug("WHATSAPP",`${r} participants to group`,{groupId:o,participantsCount:a.length}),this.socket?.groupParticipantsUpdate(o,a,r)}async addParticipants(e,t){return this.updateGroupParticipants(e,t,"add")}async removeParticipants(e,t){return this.updateGroupParticipants(e,t,"remove")}async promoteToAdmin(e,t){return this.updateGroupParticipants(e,t,"promote")}async demoteFromAdmin(e,t){return this.updateGroupParticipants(e,t,"demote")}async leaveGroup(e){if(!e)throw new Error("leaveGroup: Group ID is required.");await this.ensureSocketConnected();let t=n.formatGroupId(e);return this.debug&&this.logger?.debug("WHATSAPP","Leaving group",{groupId:t}),this.socket?.groupLeave(t)}async getGroupMetadata(e){if(!e)throw new Error("getGroupMetadata: Group ID is required.");await this.ensureSocketConnected();let t=n.formatGroupId(e);return this.debug&&this.logger?.debug("WHATSAPP","Fetching group metadata",{groupId:t}),this.socket?.groupMetadata(t)}async getAllGroups(){await this.ensureSocketConnected(),this.debug&&this.logger?.debug("WHATSAPP","Fetching all groups");let e=await this.socket?.groupFetchAllParticipating();return e?Object.values(e):[]}async getGroupInviteCode(e,t){if(!e)throw new Error("getGroupInviteCode: Group ID is required.");await this.ensureSocketConnected();let r=n.formatGroupId(e);this.debug&&this.logger?.debug("WHATSAPP","Fetching group invite code",{groupId:r});let s=await this.socket?.groupInviteCode(r);return t&&s?`https://chat.whatsapp.com/${s}`:s}async revokeGroupInviteCode(e){if(!e)throw new Error("revokeGroupInviteCode: Group ID is required.");await this.ensureSocketConnected();let t=n.formatGroupId(e);return this.debug&&this.logger?.debug("WHATSAPP","Revoking group invite code",{groupId:t}),this.socket?.groupRevokeInvite(t)}async joinGroupViaInvite(e){if(!e)throw new Error("joinGroupViaInvite: Invite code is required.");return await this.ensureSocketConnected(),this.debug&&this.logger?.debug("WHATSAPP","Joining group via invite",{inviteCode:e}),this.socket?.groupAcceptInvite(e)}async getGroupInfoFromInvite(e){if(!e)throw new Error("getGroupInfoFromInvite: Invite code is required.");return await this.ensureSocketConnected(),this.debug&&this.logger?.debug("WHATSAPP","Fetching group info from invite",{inviteCode:e}),this.socket?.groupGetInviteInfo(e)}async updateGroupProfilePicture(e,t){if(!e||!t)throw new Error("updateGroupProfilePicture: Group ID and image buffer are required.");await this.ensureSocketConnected();let r=n.formatGroupId(e);return this.debug&&this.logger?.debug("WHATSAPP","Updating group profile picture",{groupId:r}),this.socket?.updateProfilePicture(r,t)}async removeGroupProfilePicture(e){if(!e)throw new Error("removeGroupProfilePicture: Group ID is required.");await this.ensureSocketConnected();let t=n.formatGroupId(e);return this.debug&&this.logger?.debug("WHATSAPP","Removing group profile picture",{groupId:t}),this.socket?.removeProfilePicture(t)}async getGroupProfilePicture(e,t=false){if(!e)throw new Error("getGroupProfilePicture: Group ID is required.");await this.ensureSocketConnected();let r=n.formatGroupId(e);return this.debug&&this.logger?.debug("WHATSAPP","Fetching group profile picture",{groupId:r,highRes:t}),this.socket?.profilePictureUrl(r,t?"image":"preview").catch(s=>{if(s.message==="item-not-found")return null;throw s})}};var R=class n extends W{constructor(e){super(e);}async sendTextMessage(e,t,r){if(!e||!t)throw new Error("sendTextMessage: Group ID and text are required.");await this.ensureSocketConnected();let s=n.formatGroupId(e),o={};return r?.replyToMessageId&&(o.quoted={key:{id:r.replyToMessageId}}),this.debug&&this.logger?.debug("WHATSAPP","Sending text message to group",{groupId:s,textLength:t.length,hasMentions:!!r?.mentions?.length}),this.socket?.sendMessage(s,{text:t},o)}async sendButtonsMessage(e,{title:t,subtitle:r,buttons:s}){if(!e||!t||!s?.length)throw new Error("sendButtonsMessage: Group ID, title, and buttons are required.");await this.ensureSocketConnected();let o=n.formatGroupId(e),a=s?.map(u=>{let c={display_text:u.label},g;switch(true){case !!u.url:g="cta_url",c.url=u.url;break;case !!u.copy:g="cta_copy",c.copy_code=u.copy;break;case !!u.tel:g="cta_call",c.phone_number=u.tel;break;default:g="";break}return {name:g,buttonParamsJson:JSON.stringify(c)}}).filter(u=>u.name),i=generateWAMessageFromContent(o,{viewOnceMessage:{message:{interactiveMessage:WAProto.Message.InteractiveMessage.create({body:WAProto.Message.InteractiveMessage.Body.create({text:t}),...r&&{footer:WAProto.Message.InteractiveMessage.Footer.create({text:r})},nativeFlowMessage:WAProto.Message.InteractiveMessage.NativeFlowMessage.create({buttons:a})})}}},{userJid:o});return this.debug&&this.logger?.debug("WHATSAPP","Sending buttons message to group",{groupId:o,title:t,buttonsCount:a.length}),this.socket?.relayMessage(o,i.message,{messageId:i.key.id})}async sendReplyButtonsMessage(e,{title:t,subtitle:r,buttons:s,mentions:o}){if(!e||!t||!s?.length)throw new Error("sendReplyButtonsMessage: Group ID, title, and buttons are required.");await this.ensureSocketConnected();let a=n.formatGroupId(e),i=s.filter(c=>c).map((c,g)=>typeof c=="string"?{buttonId:`id-${g}`,buttonText:{displayText:c},type:1}:{buttonId:`${c.id}`,buttonText:{displayText:c.label},type:1}),u={text:t,buttons:i,...r&&{footer:r}};return o?.length&&(u.mentions=o.map(c=>n.formatPhoneNumberToWhatsappPattern(c))),this.debug&&this.logger?.debug("WHATSAPP","Sending reply buttons message to group",{groupId:a,title:t,buttonsCount:i.length}),this.socket?.sendMessage(a,u)}async sendImageMessage(e,t,{caption:r,mentions:s}={}){if(!e||!t)throw new Error("sendImage: Group ID and image buffer are required.");await this.ensureSocketConnected();let o=n.formatGroupId(e),a={image:t,...r&&{caption:r}};return s?.length&&(a.mentions=s.map(i=>n.formatPhoneNumberToWhatsappPattern(i))),this.debug&&this.logger?.debug("WHATSAPP","Sending image to group",{groupId:o,hasCaption:!!r}),this.socket?.sendMessage(o,a)}async sendVideoMessage(e,t,r,s){if(!e||!t)throw new Error("sendVideo: Group ID and video buffer are required.");await this.ensureSocketConnected();let o=n.formatGroupId(e),a={video:t,...r&&{caption:r}};return s?.mentions?.length&&(a.mentions=s.mentions.map(i=>n.formatPhoneNumberToWhatsappPattern(i))),this.debug&&this.logger?.debug("WHATSAPP","Sending video to group",{groupId:o,hasCaption:!!r}),this.socket?.sendMessage(o,a)}async sendAudioMessage(e,t,r){if(!e||!t)throw new Error("sendAudio: Group ID and audio buffer are required.");await this.ensureSocketConnected();let s=n.formatGroupId(e),o={audio:t,ptt:r?.ptt??false};return r?.mentions?.length&&(o.mentions=r.mentions.map(a=>n.formatPhoneNumberToWhatsappPattern(a))),this.debug&&this.logger?.debug("WHATSAPP","Sending audio to group",{groupId:s,isPTT:o.ptt}),this.socket?.sendMessage(s,o)}async sendDocumentMessage(e,t,r,s,o){if(!e||!t||!r)throw new Error("sendDocument: Group ID, document buffer, and fileName are required.");await this.ensureSocketConnected();let a=n.formatGroupId(e),i={document:t,fileName:r,...s&&{mimetype:s}};return o?.mentions?.length&&(i.mentions=o.mentions.map(u=>n.formatPhoneNumberToWhatsappPattern(u))),this.debug&&this.logger?.debug("WHATSAPP","Sending document to group",{groupId:a,fileName:r}),this.socket?.sendMessage(a,i)}async sendLocationMessage(e,t,r,s,o){if(!e||t===void 0||r===void 0)throw new Error("sendLocation: Group ID, latitude, and longitude are required.");await this.ensureSocketConnected();let a=n.formatGroupId(e);return this.debug&&this.logger?.debug("WHATSAPP","Sending location to group",{groupId:a,latitude:t,longitude:r}),this.socket?.sendMessage(a,{location:{degreesLatitude:t,degreesLongitude:r,...s&&{name:s},...o&&{address:o}}})}async sendMentionAll(e,t){if(!e||!t)throw new Error("sendMentionAll: Group ID and text are required.");await this.ensureSocketConnected();let r=n.formatGroupId(e),s=await this.getGroupMetadata(r);if(!s)throw new Error("Could not fetch group metadata");let o=s.participants.map(a=>a.id);return this.debug&&this.logger?.debug("WHATSAPP","Sending mention all message to group",{groupId:r,participantsCount:o.length}),this.socket?.sendMessage(r,{text:t,mentions:o})}async sendReactionMessage(e,t,r){if(!e||!t||!r)throw new Error("sendReaction: Group ID, message ID, and emoji are required.");await this.ensureSocketConnected();let s=n.formatGroupId(e);return this.debug&&this.logger?.debug("WHATSAPP","Sending reaction to group message",{groupId:s,messageId:t,emoji:r}),this.socket?.sendMessage(s,{react:{text:r,key:{id:t,remoteJid:s}}})}async deleteGroupMessage(e,t){if(!e||!t)throw new Error("deleteGroupMessage: Group ID and message ID are required.");await this.ensureSocketConnected();let r=n.formatGroupId(e);return this.debug&&this.logger?.debug("WHATSAPP","Deleting message in group",{groupId:r,messageId:t}),this.socket?.sendMessage(r,{delete:{id:t,remoteJid:r,fromMe:true}})}};var z=class extends R{constructor(e){super(e);}};
3
+ export{K as WhatsappSocket,z as WhatsappSocketGroup};//# sourceMappingURL=index.js.map
3
4
  //# sourceMappingURL=index.js.map