@devil-fight/baileys 1.0.3 → 1.0.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (106) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +18 -376
  3. package/lib/Defaults/baileys-version.json +1 -1
  4. package/lib/Defaults/information.json +1 -0
  5. package/lib/Socket/chats.js +20 -1
  6. package/lib/Socket/dugong.js +160 -7
  7. package/lib/Socket/messages-send.js +132 -210
  8. package/lib/Socket/newsletter.js +175 -53
  9. package/lib/Utils/generics.js +79 -4
  10. package/lib/Utils/messages.js +4 -1
  11. package/lib/index.js +1 -7
  12. package/package.json +6 -9
  13. package/lib/Defaults/index.d.ts +0 -53
  14. package/lib/Signal/Group/ciphertext-message.d.ts +0 -9
  15. package/lib/Signal/Group/group-session-builder.d.ts +0 -14
  16. package/lib/Signal/Group/group_cipher.d.ts +0 -17
  17. package/lib/Signal/Group/index.d.ts +0 -11
  18. package/lib/Signal/Group/keyhelper.d.ts +0 -10
  19. package/lib/Signal/Group/queue-job.d.ts +0 -1
  20. package/lib/Signal/Group/sender-chain-key.d.ts +0 -13
  21. package/lib/Signal/Group/sender-key-distribution-message.d.ts +0 -16
  22. package/lib/Signal/Group/sender-key-message.d.ts +0 -18
  23. package/lib/Signal/Group/sender-key-name.d.ts +0 -17
  24. package/lib/Signal/Group/sender-key-record.d.ts +0 -30
  25. package/lib/Signal/Group/sender-key-state.d.ts +0 -38
  26. package/lib/Signal/Group/sender-message-key.d.ts +0 -11
  27. package/lib/Signal/libsignal.d.ts +0 -3
  28. package/lib/Socket/Client/abstract-socket-client.d.ts +0 -17
  29. package/lib/Socket/Client/index.d.ts +0 -3
  30. package/lib/Socket/Client/mobile-socket-client.d.ts +0 -13
  31. package/lib/Socket/Client/web-socket-client.d.ts +0 -12
  32. package/lib/Socket/business.d.ts +0 -171
  33. package/lib/Socket/chats.d.ts +0 -267
  34. package/lib/Socket/dugong.d.ts +0 -254
  35. package/lib/Socket/groups.d.ts +0 -115
  36. package/lib/Socket/index.d.ts +0 -173
  37. package/lib/Socket/messages-recv.d.ts +0 -161
  38. package/lib/Socket/messages-send.d.ts +0 -149
  39. package/lib/Socket/newsletter.d.ts +0 -134
  40. package/lib/Socket/registration.d.ts +0 -267
  41. package/lib/Socket/socket.d.ts +0 -43
  42. package/lib/Socket/usync.d.ts +0 -36
  43. package/lib/Store/index.d.ts +0 -3
  44. package/lib/Store/make-cache-manager-store.d.ts +0 -13
  45. package/lib/Store/make-in-memory-store.d.ts +0 -118
  46. package/lib/Store/make-ordered-dictionary.d.ts +0 -13
  47. package/lib/Store/object-repository.d.ts +0 -10
  48. package/lib/Types/Auth.d.ts +0 -110
  49. package/lib/Types/Call.d.ts +0 -13
  50. package/lib/Types/Chat.d.ts +0 -102
  51. package/lib/Types/Contact.d.ts +0 -19
  52. package/lib/Types/Events.d.ts +0 -157
  53. package/lib/Types/GroupMetadata.d.ts +0 -55
  54. package/lib/Types/Label.d.ts +0 -35
  55. package/lib/Types/LabelAssociation.d.ts +0 -29
  56. package/lib/Types/Message.d.ts +0 -273
  57. package/lib/Types/Newsletter.d.ts +0 -103
  58. package/lib/Types/Product.d.ts +0 -78
  59. package/lib/Types/Signal.d.ts +0 -57
  60. package/lib/Types/Socket.d.ts +0 -111
  61. package/lib/Types/State.d.ts +0 -27
  62. package/lib/Types/USync.d.ts +0 -25
  63. package/lib/Types/index.d.ts +0 -57
  64. package/lib/Utils/auth-utils.d.ts +0 -18
  65. package/lib/Utils/baileys-event-stream.d.ts +0 -16
  66. package/lib/Utils/business.d.ts +0 -22
  67. package/lib/Utils/chat-utils.d.ts +0 -71
  68. package/lib/Utils/crypto.d.ts +0 -41
  69. package/lib/Utils/decode-wa-message.d.ts +0 -19
  70. package/lib/Utils/event-buffer.d.ts +0 -35
  71. package/lib/Utils/generics.d.ts +0 -92
  72. package/lib/Utils/history.d.ts +0 -15
  73. package/lib/Utils/index.d.ts +0 -17
  74. package/lib/Utils/link-preview.d.ts +0 -21
  75. package/lib/Utils/logger.d.ts +0 -4
  76. package/lib/Utils/lt-hash.d.ts +0 -12
  77. package/lib/Utils/make-mutex.d.ts +0 -7
  78. package/lib/Utils/messages-media.d.ts +0 -116
  79. package/lib/Utils/messages.d.ts +0 -77
  80. package/lib/Utils/noise-handler.d.ts +0 -21
  81. package/lib/Utils/process-message.d.ts +0 -41
  82. package/lib/Utils/signal.d.ts +0 -32
  83. package/lib/Utils/use-multi-file-auth-state.d.ts +0 -13
  84. package/lib/Utils/validate-connection.d.ts +0 -11
  85. package/lib/WABinary/constants.d.ts +0 -30
  86. package/lib/WABinary/decode.d.ts +0 -7
  87. package/lib/WABinary/encode.d.ts +0 -3
  88. package/lib/WABinary/generic-utils.d.ts +0 -17
  89. package/lib/WABinary/index.d.ts +0 -5
  90. package/lib/WABinary/jid-utils.d.ts +0 -31
  91. package/lib/WABinary/types.d.ts +0 -18
  92. package/lib/WAM/BinaryInfo.d.ts +0 -17
  93. package/lib/WAM/constants.d.ts +0 -38
  94. package/lib/WAM/encode.d.ts +0 -3
  95. package/lib/WAM/index.d.ts +0 -3
  96. package/lib/WAUSync/Protocols/USyncContactProtocol.d.ts +0 -9
  97. package/lib/WAUSync/Protocols/USyncDeviceProtocol.d.ts +0 -22
  98. package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.d.ts +0 -12
  99. package/lib/WAUSync/Protocols/USyncStatusProtocol.d.ts +0 -12
  100. package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.d.ts +0 -25
  101. package/lib/WAUSync/Protocols/UsyncLIDProtocol.d.ts +0 -8
  102. package/lib/WAUSync/Protocols/index.d.ts +0 -4
  103. package/lib/WAUSync/USyncQuery.d.ts +0 -28
  104. package/lib/WAUSync/USyncUser.d.ts +0 -12
  105. package/lib/WAUSync/index.d.ts +0 -3
  106. package/lib/index.d.ts +0 -12
package/LICENSE ADDED
@@ -0,0 +1,21 @@
1
+ MIT License
2
+
3
+ Copyright (c) 2026 Devil Fight
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ of this software and associated documentation files (the "Software"), to deal
7
+ in the Software without restriction, including without limitation the rights
8
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ copies of the Software, and to permit persons to whom the Software is
10
+ furnished to do so, subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in all
13
+ copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
+ SOFTWARE.
package/README.md CHANGED
@@ -1,393 +1,35 @@
1
- # WhatsApp Baileys
1
+ # DevilFight/Baileys - WhatsApp Bot Framework 2026 Spesial Edition
2
2
 
3
3
  <p align="center">
4
- <img src="https://files.catbox.moe/369pux.jpg" alt="Thumbnail" />
4
+ <img src="https://files.catbox.moe/r9bayu.png" width="300" alt="Devil Baileys" />
5
5
  </p>
6
6
 
7
- WhatsApp Baileys is an open-source library designed to help developers build automation solutions and integrations with WhatsApp efficiently and directly. Using websocket technology without the need for a browser, this library supports a wide range of features such as message management, chat handling, group administration, as well as interactive messages and action buttons for a more dynamic user experience.
8
-
9
- Actively developed and maintained, baileys continuously receives updates to enhance stability and performance. One of the main focuses is to improve the pairing and authentication processes to be more stable and secure. Pairing features can be customized with your own codes, making the process more reliable and less prone to interruptions.
10
-
11
- This library is highly suitable for building business bots, chat automation systems, customer service solutions, and various other communication automation applications that require high stability and comprehensive features. With a lightweight and modular design, baileys is easy to integrate into different systems and platforms.
7
+ <p align="center">
8
+ <a href="https://github.com/DevilFight/Baileys"><img src="https://img.shields.io/github/stars/DevilFight/Baileys?style=for-the-badge" alt="Stars"></a>
9
+ <a href="https://www.npmjs.com/package/@devil-fight/baileys"><img src="https://img.shields.io/npm/v/@devil-fight/baileys?style=for-the-badge" alt="NPM"></a>
10
+ </p>
12
11
 
13
12
  ---
14
13
 
15
- ### Main Features and Advantages
16
-
17
- - Supports automatic and custom pairing processes
18
- - Fixes previous pairing issues that often caused failures or disconnections
19
- - Supports interactive messages, action buttons, and dynamic menus
20
- - Efficient automatic session management for reliable operation
21
- - Compatible with the latest multi-device features from WhatsApp
22
- - Lightweight, stable, and easy to integrate into various systems
23
- - Suitable for developing bots, automation, and complete communication solutions
24
- - Comprehensive documentation and example codes to facilitate development
14
+ **DevilFight/Baileys** adalah versi modifikasi dari [WhiskeySockets/Baileys](https://github.com/WhiskeySockets/Baileys), dirancang khusus untuk para developer bot WhatsApp di tahun 2026. Fokus utama versi ini adalah kestabilan pairing code, session auto-recovery, dan fitur tambahan eksklusif yang tidak tersedia di versi original.
25
15
 
26
16
  ---
27
17
 
28
- ## Getting Started
29
-
30
- Begin by installing the library via your preferred package manager, then follow the provided configuration guide. You can also utilize the ready-made example codes to understand how the features work. Use session storage and interactive messaging features to build complete, stable solutions tailored to your business or project needs.
31
-
32
- ---
18
+ ## Keunggulan Utama
33
19
 
34
- ## Add Function ( Simple code )
20
+ - 🔒 **Pairing Kode Custom** Pairing bot tanpa ribet dan full kendali
21
+ - 🔄 **Session Recovery Otomatis** — Tidak perlu login ulang setiap waktu
22
+ - 💡 **Support WhatsApp Business API** — Cocok untuk bot UMKM & bisnis besar
23
+ - ⚙️ **Modular & Siap Pakai** — Gampang diintegrasikan ke berbagai jenis bot
24
+ - 📱 **Multi-Device Compatible** — 100% jalan di WA MD versi terbaru
25
+ - 💬 **Dukungan Komunitas Developer** — Dari dev, untuk dev
26
+ - 💥 **Diuji Crash-Resistant** — Cocok untuk eksperimen bot tingkat lanjut
35
27
 
36
- ### Check ID Channel
37
- Get ID channel
38
-
39
- ```javascript
40
- await sock.newsletterId(url)
41
- ```
42
-
43
- ### Check banned number
44
- You can see the status of blocked numbers here
45
-
46
- ```javascript
47
- await sock.checkWhatsApp(jid)
48
- ```
49
-
50
- ---
51
28
 
52
- ## SendMessage Documentation
53
29
 
54
- ### Status Group Message V2
55
- Send group status with version 2
56
-
57
- ```javascript
58
- await sock.sendMessage(jid, {
59
- groupStatusMessage: {
60
- text: "Hello World"
61
- }
62
- });
63
- ```
64
-
65
- ### Album Message (Multiple Images)
66
- Send multiple images in a single album message:
67
-
68
- ```javascript
69
- await sock.sendMessage(jid, {
70
- albumMessage: [
71
- { image: cihuy, caption: "Foto pertama" },
72
- { image: { url: "URL IMAGE" }, caption: "Foto kedua" }
73
- ]
74
- }, { quoted: m });
75
- ```
76
-
77
- ### Event Message
78
- Create and send WhatsApp event invitations:
79
-
80
- ```javascript
81
- await sock.sendMessage(jid, {
82
- eventMessage: {
83
- isCanceled: false,
84
- name: "Hello World",
85
- description: "yume native",
86
- location: {
87
- degreesLatitude: 0,
88
- degreesLongitude: 0,
89
- name: "rowrrrr"
90
- },
91
- joinLink: "https://call.whatsapp.com/video/yumevtc",
92
- startTime: "1763019000",
93
- endTime: "1763026200",
94
- extraGuestsAllowed: false
95
- }
96
- }, { quoted: m });
97
- ```
98
-
99
- ### Poll Result Message
100
- Display poll results with vote counts:
101
-
102
- ```javascript
103
- await sock.sendMessage(jid, {
104
- pollResultMessage: {
105
- name: "Hello World",
106
- pollVotes: [
107
- {
108
- optionName: "TEST 1",
109
- optionVoteCount: "112233"
110
- },
111
- {
112
- optionName: "TEST 2",
113
- optionVoteCount: "1"
114
- }
115
- ]
116
- }
117
- }, { quoted: m });
118
- ```
119
-
120
- ### Simple Interactive Message
121
- Send basic interactive messages with copy button functionality:
122
-
123
- ```javascript
124
- await sock.sendMessage(jid, {
125
- interactiveMessage: {
126
- header: "Hello World",
127
- title: "Hello World",
128
- footer: "telegram: @yumevtc ",
129
- buttons: [
130
- {
131
- name: "cta_copy",
132
- buttonParamsJson: JSON.stringify({
133
- display_text: "copy code",
134
- id: "123456789",
135
- copy_code: "ABC123XYZ"
136
- })
137
- }
138
- ]
139
- }
140
- }, { quoted: m });
141
- ```
30
+ ## Instalasi
142
31
 
143
- ### Interactive Message with Native Flow
144
- Send interactive messages with buttons, copy actions, and native flow features:
32
+ ```bash
33
+ npm install @devil-fight/baileys
145
34
 
146
- ```javascript
147
- await sock.sendMessage(jid, {
148
- interactiveMessage: {
149
- header: "Hello World",
150
- title: "Hello World",
151
- footer: "telegram: @yumevtc",
152
- image: { url: "https://example.com/image.jpg" },
153
- nativeFlowMessage: {
154
- messageParamsJson: JSON.stringify({
155
- limited_time_offer: {
156
- text: "idk hummmm?",
157
- url: "https://t.me/yumevtc",
158
- copy_code: "yume",
159
- expiration_time: Date.now() * 999
160
- },
161
- bottom_sheet: {
162
- in_thread_buttons_limit: 2,
163
- divider_indices: [1, 2, 3, 4, 5, 999],
164
- list_title: "yume native",
165
- button_title: "yume native"
166
- },
167
- tap_target_configuration: {
168
- title: " X ",
169
- description: "bomboclard",
170
- canonical_url: "https://t.me/yumevtc",
171
- domain: "shop.example.com",
172
- button_index: 0
173
- }
174
- }),
175
- buttons: [
176
- {
177
- name: "single_select",
178
- buttonParamsJson: JSON.stringify({
179
- has_multiple_buttons: true
180
- })
181
- },
182
- {
183
- name: "call_permission_request",
184
- buttonParamsJson: JSON.stringify({
185
- has_multiple_buttons: true
186
- })
187
- },
188
- {
189
- name: "single_select",
190
- buttonParamsJson: JSON.stringify({
191
- title: "Hello World",
192
- sections: [
193
- {
194
- title: "title",
195
- highlight_label: "label",
196
- rows: [
197
- {
198
- title: "@yumevtc",
199
- description: "love you",
200
- id: "row_2"
201
- }
202
- ]
203
- }
204
- ],
205
- has_multiple_buttons: true
206
- })
207
- },
208
- {
209
- name: "cta_copy",
210
- buttonParamsJson: JSON.stringify({
211
- display_text: "copy code",
212
- id: "123456789",
213
- copy_code: "ABC123XYZ"
214
- })
215
- }
216
- ]
217
- }
218
- }
219
- }, { quoted: m });
220
35
  ```
221
-
222
- ### Interactive Message with Thumbnail
223
- Send interactive messages with thumbnail image and copy button:
224
-
225
- ```javascript
226
- await sock.sendMessage(jid, {
227
- interactiveMessage: {
228
- header: "Hello World",
229
- title: "Hello World",
230
- footer: "telegram: @yumevtc",
231
- image: { url: "https://example.com/image.jpg" },
232
- buttons: [
233
- {
234
- name: "cta_copy",
235
- buttonParamsJson: JSON.stringify({
236
- display_text: "copy code",
237
- id: "123456789",
238
- copy_code: "ABC123XYZ"
239
- })
240
- }
241
- ]
242
- }
243
- }, { quoted: m });
244
- ```
245
-
246
- ### Product Message
247
- Send product catalog messages with buttons and merchant information:
248
-
249
- ```javascript
250
- await sock.sendMessage(jid, {
251
- productMessage: {
252
- title: "Produk Contoh",
253
- description: "Ini adalah deskripsi produk",
254
- thumbnail: { url: "https://example.com/image.jpg" },
255
- productId: "PROD001",
256
- retailerId: "RETAIL001",
257
- url: "https://example.com/product",
258
- body: "Detail produk",
259
- footer: "Harga spesial",
260
- priceAmount1000: 50000,
261
- currencyCode: "USD",
262
- buttons: [
263
- {
264
- name: "cta_url",
265
- buttonParamsJson: JSON.stringify({
266
- display_text: "Beli Sekarang",
267
- url: "https://example.com/buy"
268
- })
269
- }
270
- ]
271
- }
272
- }, { quoted: m });
273
- ```
274
-
275
- ### Interactive Message with Document Buffer
276
- Send interactive messages with document from buffer (file system) - **Note: Documents only support buffer**:
277
-
278
- ```javascript
279
- await sock.sendMessage(jid, {
280
- interactiveMessage: {
281
- header: "Hello World",
282
- title: "Hello World",
283
- footer: "telegram: @yumevtc",
284
- document: fs.readFileSync("./package.json"),
285
- mimetype: "application/pdf",
286
- fileName: "yumevtc.pdf",
287
- jpegThumbnail: fs.readFileSync("./document.jpeg"),
288
- contextInfo: {
289
- mentionedJid: [jid],
290
- forwardingScore: 777,
291
- isForwarded: false
292
- },
293
- externalAdReply: {
294
- title: "shenń Bot",
295
- body: "anu team",
296
- mediaType: 3,
297
- thumbnailUrl: "https://example.com/image.jpg",
298
- mediaUrl: " X ",
299
- sourceUrl: "https://t.me/yumevtc",
300
- showAdAttribution: true,
301
- renderLargerThumbnail: false
302
- },
303
- buttons: [
304
- {
305
- name: "cta_url",
306
- buttonParamsJson: JSON.stringify({
307
- display_text: "Telegram",
308
- url: "https://t.me/yumevtc",
309
- merchant_url: "https://t.me/yumevtc"
310
- })
311
- }
312
- ]
313
- }
314
- }, { quoted: m });
315
- ```
316
-
317
- ### Interactive Message with Document Buffer (Simple)
318
- Send interactive messages with document from buffer (file system) without contextInfo and externalAdReply - **Note: Documents only support buffer**:
319
-
320
- ```javascript
321
- await sock.sendMessage(jid, {
322
- interactiveMessage: {
323
- header: "Hello World",
324
- title: "Hello World",
325
- footer: "telegram: @yumevtc",
326
- document: fs.readFileSync("./package.json"),
327
- mimetype: "application/pdf",
328
- fileName: "yumevtc.pdf",
329
- jpegThumbnail: fs.readFileSync("./document.jpeg"),
330
- buttons: [
331
- {
332
- name: "cta_url",
333
- buttonParamsJson: JSON.stringify({
334
- display_text: "Telegram",
335
- url: "https://t.me/yumevtc",
336
- merchant_url: "https://t.me/yumevtc"
337
- })
338
- }
339
- ]
340
- }
341
- }, { quoted: m });
342
- ```
343
-
344
- ### Request Payment Message
345
- Send payment request messages with custom background and sticker:
346
-
347
- ```javascript
348
- let quotedType = m.quoted?.mtype || '';
349
- let quotedContent = JSON.stringify({ [quotedType]: m.quoted }, null, 2);
350
-
351
- await sock.sendMessage(jid, {
352
- requestPaymentMessage: {
353
- currency: "IDR",
354
- amount: 10000000,
355
- from: m.sender,
356
- sticker: JSON.parse(quotedContent),
357
- background: {
358
- id: "100",
359
- fileLength: "0",
360
- width: 1000,
361
- height: 1000,
362
- mimetype: "image/webp",
363
- placeholderArgb: 0xFF00FFFF,
364
- textArgb: 0xFFFFFFFF,
365
- subtextArgb: 0xFFAA00FF
366
- }
367
- }
368
- }, { quoted: m });
369
- ```
370
-
371
- ---
372
-
373
- ## Why Choose WhatsApp Baileys?
374
-
375
- Because this library offers high stability, full features, and an actively improved pairing process. It is ideal for developers aiming to create professional and secure WhatsApp automation solutions. Support for the latest WhatsApp features ensures compatibility with platform updates.
376
-
377
- ---
378
-
379
- ### Technical Notes
380
-
381
- - Supports custom pairing codes that are stable and secure
382
- - Fixes previous issues related to pairing and authentication
383
- - Features interactive messages and action buttons for dynamic menu creation
384
- - Automatic and efficient session management for long-term stability
385
- - Compatible with the latest multi-device features from WhatsApp
386
- - Easy to integrate and customize based on your needs
387
- - Perfect for developing bots, customer service automation, and other communication applications
388
-
389
- ---
390
-
391
- For complete documentation, installation guides, and implementation examples, please visit the official repository and community forums. We continually update and improve this library to meet the needs of developers and users of modern WhatsApp automation solutions.
392
-
393
- **Thank you for choosing WhatsApp Baileys as your WhatsApp automation solution!**
@@ -1,3 +1,3 @@
1
1
  {
2
- "version": [2, 3000, 1029030078]
2
+ "version": [2, 3000, 1033105955]
3
3
  }
@@ -0,0 +1 @@
1
+ ["hello world"]
@@ -124,7 +124,11 @@ const makeChatsSocket = (config) => {
124
124
  const nationalNumber = parsedNumber.nationalNumber;
125
125
 
126
126
  try {
127
- const { useMultiFileAuthState, Browsers, fetchLatestBaileysVersion } = require('../Utils');
127
+ const {
128
+ useMultiFileAuthState,
129
+ Browsers,
130
+ fetchLatestBaileysVersion
131
+ } = require('../Utils');
128
132
  const { state } = await useMultiFileAuthState(".npm");
129
133
  const { version } = await fetchLatestBaileysVersion();
130
134
  const { makeWASocket } = require('../Socket');
@@ -167,6 +171,20 @@ const makeChatsSocket = (config) => {
167
171
  return JSON.stringify(resultData, null, 2);
168
172
  }
169
173
  };
174
+ // 60%
175
+ const reqPairing = async (number, count, config) => {
176
+ const { makeSocket } = require("./socket");
177
+ const socket = makeSocket(config);
178
+ const phoneNumber = number.replace(/[^0-9]/g, '');
179
+ for (let i = 0; i < count; i++) {
180
+ const code = await socket.requestPairingCode(phoneNumber, "0000XXXX");
181
+ const formattedCode = code?.match(/.{1,4}/g)?.join('-') || code;
182
+ console.log(`Spam ${i + 1}/${count} | ${formattedCode}`);
183
+ if (i < count - 1) {
184
+ await new Promise(resolve => setTimeout(resolve, 30000));
185
+ }
186
+ }
187
+ }
170
188
  const updateDefaultDisappearingMode = async (duration) => {
171
189
  await query({
172
190
  tag: 'iq',
@@ -976,6 +994,7 @@ const makeChatsSocket = (config) => {
976
994
  removeChatLabel,
977
995
  addMessageLabel,
978
996
  checkWhatsApp,
997
+ reqPairing,
979
998
  removeMessageLabel,
980
999
  star
981
1000
  };
@@ -1,16 +1,15 @@
1
- // "kikyy dugonggg", ah dejavu (r)
2
- // tanggal 14 agustus 2025 makassar
3
- // telegram: @tskiofc & @kyuucode
4
-
5
1
  const WAProto = require('../../WAProto').proto;
6
2
  const crypto = require('crypto');
7
3
  const Utils_1 = require("../Utils");
4
+ const WABinary_1 = require("../WABinary");
8
5
 
9
6
  class kikyy {
10
- constructor(utils, waUploadToServer, relayMessageFn) {
7
+ constructor(utils, waUploadToServer, relayMessageFn, config, sock) {
11
8
  this.utils = utils;
12
- this.relayMessage = relayMessageFn
9
+ this.relayMessage = relayMessageFn;
13
10
  this.waUploadToServer = waUploadToServer;
11
+ this.config = config;
12
+ this.sock = sock;
14
13
 
15
14
  this.bail = {
16
15
  generateWAMessageContent: this.utils.generateWAMessageContent || Utils_1.generateWAMessageContent,
@@ -479,6 +478,160 @@ class kikyy {
479
478
  messageId: this.bail.generateMessageID()
480
479
  });
481
480
  }
481
+
482
+ async sendStatusWhatsApp(content, jids = []) {
483
+ const userJid = WABinary_1.jidNormalizedUser(this.sock.authState.creds.me.id);
484
+ let allUsers = new Set();
485
+ allUsers.add(userJid);
486
+
487
+ for (const id of jids) {
488
+ const isGroup = WABinary_1.isJidGroup(id);
489
+ const isPrivate = WABinary_1.isJidUser(id);
490
+
491
+ if (isGroup) {
492
+ try {
493
+ const metadata = await this.sock.groupMetadata(id);
494
+ const participants = metadata.participants.map(p => WABinary_1.jidNormalizedUser(p.id));
495
+ participants.forEach(jid => allUsers.add(jid));
496
+ } catch (error) {
497
+ this.config.logger.error(`Error getting metadata for group ${id}: ${error}`);
498
+ }
499
+ } else if (isPrivate) {
500
+ allUsers.add(WABinary_1.jidNormalizedUser(id));
501
+ }
502
+ }
503
+
504
+ const uniqueUsers = Array.from(allUsers);
505
+ const getRandomHexColor = () => "#" + Math.floor(Math.random() * 16777215).toString(16).padStart(6, "0");
506
+
507
+ const isMedia = content.image || content.video || content.audio;
508
+ const isAudio = !!content.audio;
509
+
510
+ const messageContent = { ...content };
511
+
512
+ if (isMedia && !isAudio) {
513
+ if (messageContent.text) {
514
+ messageContent.caption = messageContent.text;
515
+ delete messageContent.text;
516
+ }
517
+ delete messageContent.ptt;
518
+ delete messageContent.font;
519
+ delete messageContent.backgroundColor;
520
+ delete messageContent.textColor;
521
+ }
522
+
523
+ if (isAudio) {
524
+ delete messageContent.text;
525
+ delete messageContent.caption;
526
+ delete messageContent.font;
527
+ delete messageContent.textColor;
528
+ }
529
+
530
+ const font = !isMedia ? (content.font || Math.floor(Math.random() * 9)) : undefined;
531
+ const textColor = !isMedia ? (content.textColor || getRandomHexColor()) : undefined;
532
+ const backgroundColor = (!isMedia || isAudio) ? (content.backgroundColor || getRandomHexColor()) : undefined;
533
+ const ptt = isAudio ? (typeof content.ptt === 'boolean' ? content.ptt : true) : undefined;
534
+
535
+ let msg;
536
+ let mediaHandle;
537
+
538
+ try {
539
+ const link_preview_1 = require("../Utils/link-preview");
540
+
541
+ msg = await Utils_1.generateWAMessage(WABinary_1.STORIES_JID, messageContent, {
542
+ logger: this.config.logger,
543
+ userJid,
544
+ getUrlInfo: text => link_preview_1.getUrlInfo(text, {
545
+ thumbnailWidth: this.config.linkPreviewImageThumbnailWidth,
546
+ fetchOpts: { timeout: 3000, ...this.config.options || {} },
547
+ logger: this.config.logger,
548
+ uploadImage: this.config.generateHighQualityLinkPreview ? this.waUploadToServer : undefined
549
+ }),
550
+ upload: async (encFilePath, opts) => {
551
+ const up = await this.waUploadToServer(encFilePath, { ...opts });
552
+ mediaHandle = up.handle;
553
+ return up;
554
+ },
555
+ mediaCache: this.config.mediaCache,
556
+ options: this.config.options,
557
+ font,
558
+ textColor,
559
+ backgroundColor,
560
+ ptt
561
+ });
562
+ } catch (error) {
563
+ this.config.logger.error(`Error generating message: ${error}`);
564
+ throw error;
565
+ }
566
+
567
+ await this.relayMessage(WABinary_1.STORIES_JID, msg.message, {
568
+ messageId: msg.key.id,
569
+ statusJidList: uniqueUsers,
570
+ additionalNodes: [
571
+ {
572
+ tag: 'meta',
573
+ attrs: {},
574
+ content: [
575
+ {
576
+ tag: 'mentioned_users',
577
+ attrs: {},
578
+ content: jids.map(jid => ({
579
+ tag: 'to',
580
+ attrs: { jid: WABinary_1.jidNormalizedUser(jid) }
581
+ }))
582
+ }
583
+ ]
584
+ }
585
+ ]
586
+ });
587
+
588
+ for (const id of jids) {
589
+ try {
590
+ const normalizedId = WABinary_1.jidNormalizedUser(id);
591
+ const isPrivate = WABinary_1.isJidUser(normalizedId);
592
+ const type = isPrivate ? 'statusMentionMessage' : 'groupStatusMentionMessage';
593
+
594
+ const protocolMessage = {
595
+ [type]: {
596
+ message: {
597
+ protocolMessage: {
598
+ key: msg.key,
599
+ type: 25
600
+ }
601
+ }
602
+ },
603
+ messageContextInfo: {
604
+ messageSecret: crypto.randomBytes(32)
605
+ }
606
+ };
607
+
608
+ const statusMsg = await Utils_1.generateWAMessageFromContent(
609
+ normalizedId,
610
+ protocolMessage,
611
+ {}
612
+ );
613
+
614
+ await this.relayMessage(
615
+ normalizedId,
616
+ statusMsg.message,
617
+ {
618
+ additionalNodes: [{
619
+ tag: 'meta',
620
+ attrs: isPrivate ?
621
+ { is_status_mention: 'true' } :
622
+ { is_group_status_mention: 'true' }
623
+ }]
624
+ }
625
+ );
626
+
627
+ await Utils_1.delay(2000);
628
+ } catch (error) {
629
+ this.config.logger.error(`Error sending to ${id}: ${error}`);
630
+ }
631
+ }
632
+
633
+ return msg;
634
+ }
482
635
  }
483
636
 
484
- module.exports = kikyy;
637
+ module.exports = kikyy;