@sixcore/baileys 1.0.0 → 1.0.1

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.

Potentially problematic release.


This version of @sixcore/baileys might be problematic. Click here for more details.

Files changed (228) hide show
  1. package/WAProto/index.js +14270 -302
  2. package/jessica.js +91 -0
  3. package/lib/Defaults/baileys-version.json +1 -1
  4. package/lib/Defaults/index.js +117 -79
  5. package/lib/Defaults/phonenumber-mcc.json +223 -0
  6. package/lib/Signal/Group/ciphertext-message.d.ts +9 -0
  7. package/lib/Signal/Group/ciphertext-message.js +15 -0
  8. package/lib/Signal/Group/group-session-builder.d.ts +14 -0
  9. package/lib/Signal/Group/group-session-builder.js +64 -0
  10. package/lib/Signal/Group/group_cipher.d.ts +17 -0
  11. package/lib/Signal/Group/group_cipher.js +96 -0
  12. package/lib/Signal/Group/index.d.ts +11 -0
  13. package/lib/Signal/Group/index.js +57 -0
  14. package/lib/Signal/Group/keyhelper.d.ts +10 -0
  15. package/lib/Signal/Group/keyhelper.js +55 -0
  16. package/lib/Signal/Group/queue-job.d.ts +1 -0
  17. package/lib/Signal/Group/queue-job.js +57 -0
  18. package/lib/Signal/Group/sender-chain-key.d.ts +13 -0
  19. package/lib/Signal/Group/sender-chain-key.js +34 -0
  20. package/lib/Signal/Group/sender-key-distribution-message.d.ts +16 -0
  21. package/lib/Signal/Group/sender-key-distribution-message.js +66 -0
  22. package/lib/Signal/Group/sender-key-message.d.ts +18 -0
  23. package/lib/Signal/Group/sender-key-message.js +69 -0
  24. package/lib/Signal/Group/sender-key-name.d.ts +17 -0
  25. package/lib/Signal/Group/sender-key-name.js +51 -0
  26. package/lib/Signal/Group/sender-key-record.d.ts +30 -0
  27. package/lib/Signal/Group/sender-key-record.js +53 -0
  28. package/lib/Signal/Group/sender-key-state.d.ts +38 -0
  29. package/lib/Signal/Group/sender-key-state.js +99 -0
  30. package/lib/Signal/Group/sender-message-key.d.ts +11 -0
  31. package/{WASignalGroup/sender_message_key.js → lib/Signal/Group/sender-message-key.js} +6 -16
  32. package/lib/Signal/libsignal.js +51 -29
  33. package/lib/Socket/business.d.ts +43 -42
  34. package/lib/Socket/chats.d.ts +222 -36
  35. package/lib/Socket/chats.js +173 -153
  36. package/lib/Socket/dugong.d.ts +254 -0
  37. package/lib/Socket/dugong.js +484 -0
  38. package/lib/Socket/groups.d.ts +7 -7
  39. package/lib/Socket/groups.js +37 -35
  40. package/lib/Socket/index.d.ts +52 -51
  41. package/lib/Socket/index.js +1 -0
  42. package/lib/Socket/messages-recv.d.ts +37 -34
  43. package/lib/Socket/messages-recv.js +175 -37
  44. package/lib/Socket/messages-send.d.ts +12 -18
  45. package/lib/Socket/messages-send.js +396 -574
  46. package/lib/Socket/newsletter.d.ts +28 -26
  47. package/lib/Socket/newsletter.js +123 -25
  48. package/lib/Socket/registration.d.ts +52 -49
  49. package/lib/Socket/registration.js +7 -7
  50. package/lib/Socket/socket.d.ts +0 -1
  51. package/lib/Socket/socket.js +49 -27
  52. package/lib/Socket/usync.d.ts +10 -11
  53. package/lib/Store/make-cache-manager-store.d.ts +1 -2
  54. package/lib/Store/make-in-memory-store.d.ts +2 -2
  55. package/lib/Store/make-in-memory-store.js +1 -5
  56. package/lib/Store/make-ordered-dictionary.js +2 -2
  57. package/lib/Types/Auth.d.ts +1 -0
  58. package/lib/Types/Call.d.ts +1 -1
  59. package/lib/Types/Chat.d.ts +7 -12
  60. package/lib/Types/Events.d.ts +2 -17
  61. package/lib/Types/GroupMetadata.d.ts +2 -3
  62. package/lib/Types/Label.d.ts +0 -11
  63. package/lib/Types/Label.js +1 -1
  64. package/lib/Types/LabelAssociation.js +1 -1
  65. package/lib/Types/Message.d.ts +10 -170
  66. package/lib/Types/Newsletter.d.ts +97 -86
  67. package/lib/Types/Newsletter.js +38 -32
  68. package/lib/Types/Socket.d.ts +2 -7
  69. package/lib/Types/index.d.ts +0 -9
  70. package/lib/Types/index.js +1 -1
  71. package/lib/Utils/auth-utils.js +14 -35
  72. package/lib/Utils/business.d.ts +1 -1
  73. package/lib/Utils/business.js +2 -2
  74. package/lib/Utils/chat-utils.d.ts +12 -11
  75. package/lib/Utils/chat-utils.js +36 -52
  76. package/lib/Utils/crypto.d.ts +16 -15
  77. package/lib/Utils/crypto.js +26 -74
  78. package/lib/Utils/decode-wa-message.d.ts +0 -17
  79. package/lib/Utils/decode-wa-message.js +17 -53
  80. package/lib/Utils/event-buffer.js +7 -10
  81. package/lib/Utils/generics.d.ts +17 -13
  82. package/lib/Utils/generics.js +79 -58
  83. package/lib/Utils/history.d.ts +2 -6
  84. package/lib/Utils/history.js +6 -4
  85. package/lib/Utils/logger.d.ts +3 -1
  86. package/lib/Utils/lt-hash.js +12 -12
  87. package/lib/Utils/make-mutex.d.ts +2 -2
  88. package/lib/Utils/messages-media.d.ts +28 -25
  89. package/lib/Utils/messages-media.js +733 -557
  90. package/lib/Utils/messages.js +68 -473
  91. package/lib/Utils/noise-handler.d.ts +5 -4
  92. package/lib/Utils/noise-handler.js +14 -19
  93. package/lib/Utils/process-message.d.ts +5 -5
  94. package/lib/Utils/process-message.js +23 -75
  95. package/lib/Utils/signal.d.ts +1 -2
  96. package/lib/Utils/signal.js +26 -32
  97. package/lib/Utils/use-multi-file-auth-state.d.ts +1 -0
  98. package/lib/Utils/use-multi-file-auth-state.js +66 -242
  99. package/lib/Utils/validate-connection.d.ts +1 -1
  100. package/lib/Utils/validate-connection.js +88 -64
  101. package/lib/WABinary/constants.d.ts +27 -24
  102. package/lib/WABinary/decode.d.ts +2 -1
  103. package/lib/WABinary/decode.js +11 -23
  104. package/lib/WABinary/encode.d.ts +2 -1
  105. package/lib/WABinary/encode.js +147 -134
  106. package/lib/WABinary/generic-utils.d.ts +5 -2
  107. package/lib/WABinary/generic-utils.js +125 -37
  108. package/lib/WABinary/jid-utils.d.ts +1 -1
  109. package/lib/WAM/BinaryInfo.d.ts +11 -2
  110. package/lib/WAM/encode.d.ts +2 -1
  111. package/lib/WAUSync/Protocols/USyncStatusProtocol.js +3 -3
  112. package/lib/WAUSync/USyncUser.d.ts +2 -0
  113. package/lib/index.d.ts +12 -0
  114. package/lib/index.js +64 -1
  115. package/package.json +113 -51
  116. package/WAProto/GenerateStatics.sh +0 -4
  117. package/WAProto/WAProto.proto +0 -4357
  118. package/WAProto/index.d.ts +0 -50383
  119. package/WASignalGroup/GroupProtocol.js +0 -1697
  120. package/WASignalGroup/ciphertext_message.js +0 -16
  121. package/WASignalGroup/generate-proto.sh +0 -1
  122. package/WASignalGroup/group.proto +0 -42
  123. package/WASignalGroup/group_cipher.js +0 -120
  124. package/WASignalGroup/group_session_builder.js +0 -46
  125. package/WASignalGroup/index.js +0 -5
  126. package/WASignalGroup/keyhelper.js +0 -21
  127. package/WASignalGroup/protobufs.js +0 -3
  128. package/WASignalGroup/queue_job.js +0 -69
  129. package/WASignalGroup/sender_chain_key.js +0 -50
  130. package/WASignalGroup/sender_key_distribution_message.js +0 -78
  131. package/WASignalGroup/sender_key_message.js +0 -92
  132. package/WASignalGroup/sender_key_name.js +0 -70
  133. package/WASignalGroup/sender_key_record.js +0 -56
  134. package/WASignalGroup/sender_key_state.js +0 -129
  135. package/lib/Utils/use-single-file-auth-state.d.ts +0 -12
  136. package/lib/Utils/use-single-file-auth-state.js +0 -75
  137. package/src/Defaults/baileys-version.json +0 -3
  138. package/src/Defaults/index.ts +0 -133
  139. package/src/Signal/Group/ciphertext-message.ts +0 -9
  140. package/src/Signal/Group/group-session-builder.ts +0 -56
  141. package/src/Signal/Group/group_cipher.ts +0 -117
  142. package/src/Signal/Group/index.ts +0 -11
  143. package/src/Signal/Group/keyhelper.ts +0 -28
  144. package/src/Signal/Group/sender-chain-key.ts +0 -34
  145. package/src/Signal/Group/sender-key-distribution-message.ts +0 -95
  146. package/src/Signal/Group/sender-key-message.ts +0 -96
  147. package/src/Signal/Group/sender-key-name.ts +0 -66
  148. package/src/Signal/Group/sender-key-record.ts +0 -69
  149. package/src/Signal/Group/sender-key-state.ts +0 -134
  150. package/src/Signal/Group/sender-message-key.ts +0 -36
  151. package/src/Signal/libsignal.ts +0 -447
  152. package/src/Signal/lid-mapping.ts +0 -209
  153. package/src/Socket/Client/index.ts +0 -2
  154. package/src/Socket/Client/types.ts +0 -22
  155. package/src/Socket/Client/websocket.ts +0 -56
  156. package/src/Socket/business.ts +0 -421
  157. package/src/Socket/chats.ts +0 -1223
  158. package/src/Socket/communities.ts +0 -477
  159. package/src/Socket/groups.ts +0 -361
  160. package/src/Socket/index.ts +0 -22
  161. package/src/Socket/messages-recv.ts +0 -1563
  162. package/src/Socket/messages-send.ts +0 -1210
  163. package/src/Socket/mex.ts +0 -58
  164. package/src/Socket/newsletter.ts +0 -229
  165. package/src/Socket/socket.ts +0 -1072
  166. package/src/Types/Auth.ts +0 -115
  167. package/src/Types/Bussines.ts +0 -20
  168. package/src/Types/Call.ts +0 -14
  169. package/src/Types/Chat.ts +0 -138
  170. package/src/Types/Contact.ts +0 -24
  171. package/src/Types/Events.ts +0 -132
  172. package/src/Types/GroupMetadata.ts +0 -70
  173. package/src/Types/Label.ts +0 -48
  174. package/src/Types/LabelAssociation.ts +0 -35
  175. package/src/Types/Message.ts +0 -424
  176. package/src/Types/Newsletter.ts +0 -98
  177. package/src/Types/Product.ts +0 -85
  178. package/src/Types/Signal.ts +0 -76
  179. package/src/Types/Socket.ts +0 -150
  180. package/src/Types/State.ts +0 -43
  181. package/src/Types/USync.ts +0 -27
  182. package/src/Types/globals.d.ts +0 -8
  183. package/src/Types/index.ts +0 -67
  184. package/src/Utils/auth-utils.ts +0 -331
  185. package/src/Utils/browser-utils.ts +0 -31
  186. package/src/Utils/business.ts +0 -286
  187. package/src/Utils/chat-utils.ts +0 -933
  188. package/src/Utils/crypto.ts +0 -184
  189. package/src/Utils/decode-wa-message.ts +0 -355
  190. package/src/Utils/event-buffer.ts +0 -662
  191. package/src/Utils/generics.ts +0 -470
  192. package/src/Utils/history.ts +0 -114
  193. package/src/Utils/index.ts +0 -18
  194. package/src/Utils/link-preview.ts +0 -111
  195. package/src/Utils/logger.ts +0 -13
  196. package/src/Utils/lt-hash.ts +0 -65
  197. package/src/Utils/make-mutex.ts +0 -45
  198. package/src/Utils/message-retry-manager.ts +0 -229
  199. package/src/Utils/messages-media.ts +0 -820
  200. package/src/Utils/messages.ts +0 -1137
  201. package/src/Utils/noise-handler.ts +0 -192
  202. package/src/Utils/pre-key-manager.ts +0 -126
  203. package/src/Utils/process-message.ts +0 -622
  204. package/src/Utils/signal.ts +0 -214
  205. package/src/Utils/use-multi-file-auth-state.ts +0 -136
  206. package/src/Utils/validate-connection.ts +0 -253
  207. package/src/WABinary/constants.ts +0 -1305
  208. package/src/WABinary/decode.ts +0 -281
  209. package/src/WABinary/encode.ts +0 -253
  210. package/src/WABinary/generic-utils.ts +0 -127
  211. package/src/WABinary/index.ts +0 -5
  212. package/src/WABinary/jid-utils.ts +0 -128
  213. package/src/WABinary/types.ts +0 -17
  214. package/src/WAM/BinaryInfo.ts +0 -12
  215. package/src/WAM/constants.ts +0 -22889
  216. package/src/WAM/encode.ts +0 -169
  217. package/src/WAM/index.ts +0 -3
  218. package/src/WAUSync/Protocols/USyncContactProtocol.ts +0 -32
  219. package/src/WAUSync/Protocols/USyncDeviceProtocol.ts +0 -78
  220. package/src/WAUSync/Protocols/USyncDisappearingModeProtocol.ts +0 -35
  221. package/src/WAUSync/Protocols/USyncStatusProtocol.ts +0 -44
  222. package/src/WAUSync/Protocols/UsyncBotProfileProtocol.ts +0 -76
  223. package/src/WAUSync/Protocols/UsyncLIDProtocol.ts +0 -33
  224. package/src/WAUSync/Protocols/index.ts +0 -4
  225. package/src/WAUSync/USyncQuery.ts +0 -133
  226. package/src/WAUSync/USyncUser.ts +0 -32
  227. package/src/WAUSync/index.ts +0 -3
  228. package/src/index.ts +0 -13
@@ -1,3 +1,4 @@
1
+ /// <reference types="node" />
1
2
  import { NewsletterFetchedUpdate, NewsletterMetadata, NewsletterReactionMode, NewsletterViewRole, SocketConfig, WAMediaUpload } from '../Types';
2
3
  import { BinaryNode } from '../WABinary';
3
4
  export declare const makeNewsletterSocket: (config: SocketConfig) => {
@@ -13,9 +14,9 @@ export declare const makeNewsletterSocket: (config: SocketConfig) => {
13
14
  newsletterFollow: (jid: string) => Promise<void>;
14
15
  newsletterUnmute: (jid: string) => Promise<void>;
15
16
  newsletterMute: (jid: string) => Promise<void>;
16
- newsletterAction: (jid: string, type: "follow" | "unfollow" | "mute" | "unmute") => Promise<void>;
17
- newsletterCreate: (name: string, description: string) => Promise<NewsletterMetadata>;
18
- newsletterMetadata: (type: "invite" | "jid", key: string, role?: NewsletterViewRole) => Promise<NewsletterMetadata>;
17
+ newsletterAction: (jid: string, type: 'follow' | 'unfollow' | 'mute' | 'unmute') => Promise<void>;
18
+ newsletterCreate: (name: string, description: string, reaction_codes: string) => Promise<NewsletterMetadata>;
19
+ newsletterMetadata: (type: 'invite' | 'jid', key: string, role?: NewsletterViewRole) => Promise<NewsletterMetadata>;
19
20
  newsletterAdminCount: (jid: string) => Promise<number>;
20
21
  /**user is Lid, not Jid */
21
22
  newsletterChangeOwner: (jid: string, user: string) => Promise<void>;
@@ -24,7 +25,7 @@ export declare const makeNewsletterSocket: (config: SocketConfig) => {
24
25
  newsletterDelete: (jid: string) => Promise<void>;
25
26
  /**if code wasn't passed, the reaction will be removed (if is reacted) */
26
27
  newsletterReactMessage: (jid: string, serverId: string, code?: string) => Promise<void>;
27
- newsletterFetchMessages: (type: "invite" | "jid", key: string, count: number, after?: number) => Promise<NewsletterFetchedUpdate[]>;
28
+ newsletterFetchMessages: (type: 'invite' | 'jid', key: string, count: number, after?: number) => Promise<NewsletterFetchedUpdate[]>;
28
29
  newsletterFetchUpdates: (jid: string, count: number, after?: number, since?: number) => Promise<NewsletterFetchedUpdate[]>;
29
30
  groupMetadata: (jid: string) => Promise<import("../Types").GroupMetadata>;
30
31
  groupCreate: (subject: string, participants: string[]) => Promise<import("../Types").GroupMetadata>;
@@ -33,7 +34,7 @@ export declare const makeNewsletterSocket: (config: SocketConfig) => {
33
34
  groupRequestParticipantsList: (jid: string) => Promise<{
34
35
  [key: string]: string;
35
36
  }[]>;
36
- groupRequestParticipantsUpdate: (jid: string, participants: string[], action: "approve" | "reject") => Promise<{
37
+ groupRequestParticipantsUpdate: (jid: string, participants: string[], action: "reject" | "approve") => Promise<{
37
38
  status: string;
38
39
  jid: string;
39
40
  }[]>;
@@ -42,34 +43,35 @@ export declare const makeNewsletterSocket: (config: SocketConfig) => {
42
43
  jid: string;
43
44
  content: BinaryNode;
44
45
  }[]>;
45
- groupUpdateDescription: (jid: string, description?: string) => Promise<void>;
46
+ groupUpdateDescription: (jid: string, description?: string | undefined) => Promise<void>;
46
47
  groupInviteCode: (jid: string) => Promise<string | undefined>;
47
48
  groupRevokeInvite: (jid: string) => Promise<string | undefined>;
48
49
  groupAcceptInvite: (code: string) => Promise<string | undefined>;
49
50
  groupAcceptInviteV4: (key: string | import("../Types").WAProto.IMessageKey, inviteMessage: import("../Types").WAProto.Message.IGroupInviteMessage) => Promise<string>;
50
51
  groupGetInviteInfo: (code: string) => Promise<import("../Types").GroupMetadata>;
51
52
  groupToggleEphemeral: (jid: string, ephemeralExpiration: number) => Promise<void>;
52
- groupSettingUpdate: (jid: string, setting: "announcement" | "not_announcement" | "locked" | "unlocked") => Promise<void>;
53
- groupMemberAddMode: (jid: string, mode: "admin_add" | "all_member_add") => Promise<void>;
53
+ groupSettingUpdate: (jid: string, setting: "announcement" | "locked" | "not_announcement" | "unlocked") => Promise<void>;
54
+ groupMemberAddMode: (jid: string, mode: "all_member_add" | "admin_add") => Promise<void>;
54
55
  groupJoinApprovalMode: (jid: string, mode: "on" | "off") => Promise<void>;
55
56
  groupFetchAllParticipating: () => Promise<{
56
57
  [_: string]: import("../Types").GroupMetadata;
57
58
  }>;
58
59
  processingMutex: {
59
- mutex<T>(code: () => Promise<T> | T): Promise<T>;
60
+ mutex<T>(code: () => T | Promise<T>): Promise<T>;
60
61
  };
61
62
  fetchPrivacySettings: (force?: boolean) => Promise<{
62
63
  [_: string]: string;
63
64
  }>;
64
65
  upsertMessage: (msg: import("../Types").WAProto.IWebMessageInfo, type: import("../Types").MessageUpsertType) => Promise<void>;
65
66
  appPatch: (patchCreate: import("../Types").WAPatchCreate) => Promise<void>;
66
- sendPresenceUpdate: (type: import("../Types").WAPresence, toJid?: string) => Promise<void>;
67
- presenceSubscribe: (toJid: string, tcToken?: Buffer) => Promise<void>;
68
- profilePictureUrl: (jid: string, type?: "preview" | "image", timeoutMs?: number) => Promise<string | undefined>;
67
+ sendPresenceUpdate: (type: import("../Types").WAPresence, toJid?: string | undefined) => Promise<void>;
68
+ presenceSubscribe: (toJid: string, tcToken?: Buffer | undefined) => Promise<void>;
69
+ profilePictureUrl: (jid: string, type?: "image" | "preview", timeoutMs?: number | undefined) => Promise<string | undefined>;
69
70
  onWhatsApp: (...jids: string[]) => Promise<{
70
- exists: boolean;
71
71
  jid: string;
72
- }[]>;
72
+ exists: unknown;
73
+ lid: unknown;
74
+ }[] | undefined>;
73
75
  fetchBlocklist: () => Promise<string[]>;
74
76
  fetchStatus: (jid: string) => Promise<{
75
77
  status: string | undefined;
@@ -87,25 +89,25 @@ export declare const makeNewsletterSocket: (config: SocketConfig) => {
87
89
  updateReadReceiptsPrivacy: (value: import("../Types").WAReadReceiptsValue) => Promise<void>;
88
90
  updateGroupsAddPrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
89
91
  updateDefaultDisappearingMode: (duration: number) => Promise<void>;
90
- getBusinessProfile: (jid: string) => Promise<import("../Types").WABusinessProfile | void>;
92
+ getBusinessProfile: (jid: string) => Promise<void | import("../Types").WABusinessProfile>;
91
93
  resyncAppState: (collections: readonly ("critical_block" | "critical_unblock_low" | "regular_high" | "regular_low" | "regular")[], isInitialSync: boolean) => Promise<void>;
92
94
  chatModify: (mod: import("../Types").ChatModification, jid: string) => Promise<void>;
93
- cleanDirtyBits: (type: "account_sync" | "groups", fromTimestamp?: number | string) => Promise<void>;
95
+ cleanDirtyBits: (type: "account_sync" | "groups", fromTimestamp?: string | number | undefined) => Promise<void>;
94
96
  addChatLabel: (jid: string, labelId: string) => Promise<void>;
95
97
  removeChatLabel: (jid: string, labelId: string) => Promise<void>;
96
98
  addMessageLabel: (jid: string, messageId: string, labelId: string) => Promise<void>;
97
99
  removeMessageLabel: (jid: string, messageId: string, labelId: string) => Promise<void>;
98
100
  star: (jid: string, messages: {
99
101
  id: string;
100
- fromMe?: boolean;
102
+ fromMe?: boolean | undefined;
101
103
  }[], star: boolean) => Promise<void>;
102
104
  type: "md";
103
105
  ws: any;
104
106
  ev: import("../Types").BaileysEventEmitter & {
105
- process(handler: (events: Partial<import("../Types").BaileysEventMap>) => void | Promise<void>): (() => void);
107
+ process(handler: (events: Partial<import("../Types").BaileysEventMap>) => void | Promise<void>): () => void;
106
108
  buffer(): void;
107
- createBufferedFunction<A extends any[], T>(work: (...args: A) => Promise<T>): ((...args: A) => Promise<T>);
108
- flush(force?: boolean): boolean;
109
+ createBufferedFunction<A extends any[], T_1>(work: (...args: A) => Promise<T_1>): (...args: A) => Promise<T_1>;
110
+ flush(force?: boolean | undefined): boolean;
109
111
  isBuffering(): boolean;
110
112
  };
111
113
  authState: {
@@ -115,18 +117,18 @@ export declare const makeNewsletterSocket: (config: SocketConfig) => {
115
117
  signalRepository: import("../Types").SignalRepository;
116
118
  user: import("../Types").Contact | undefined;
117
119
  generateMessageTag: () => string;
118
- query: (node: BinaryNode, timeoutMs?: number) => Promise<BinaryNode>;
119
- waitForMessage: <T>(msgId: string, timeoutMs?: number | undefined) => Promise<T>;
120
+ query: (node: BinaryNode, timeoutMs?: number | undefined) => Promise<BinaryNode>;
121
+ waitForMessage: <T_2>(msgId: string, timeoutMs?: number | undefined) => Promise<T_2>;
120
122
  waitForSocketOpen: () => Promise<void>;
121
123
  sendRawMessage: (data: Uint8Array | Buffer) => Promise<void>;
122
124
  sendNode: (frame: BinaryNode) => Promise<void>;
123
- logout: (msg?: string) => Promise<void>;
125
+ logout: (msg?: string | undefined) => Promise<void>;
124
126
  end: (error: Error | undefined) => void;
125
- onUnexpectedError: (err: Error | Boom, msg: string) => void;
127
+ onUnexpectedError: (err: Error | import("@hapi/boom").Boom<any>, msg: string) => void;
126
128
  uploadPreKeys: (count?: number) => Promise<void>;
127
129
  uploadPreKeysToServerIfRequired: () => Promise<void>;
128
- requestPairingCode: (phoneNumber: string, pairCode: string) => Promise<string>;
129
- waitForConnectionUpdate: (check: (u: Partial<import("../Types").ConnectionState>) => boolean | undefined, timeoutMs?: number) => Promise<void>;
130
+ requestPairingCode: (phoneNumber: string) => Promise<string>;
131
+ waitForConnectionUpdate: (check: (u: Partial<import("../Types").ConnectionState>) => boolean | undefined, timeoutMs?: number | undefined) => Promise<void>;
130
132
  sendWAMBuffer: (wamBuffer: Buffer) => Promise<BinaryNode>;
131
133
  };
132
134
  export declare const extractNewsletterMetadata: (node: BinaryNode, isCreate?: boolean) => NewsletterMetadata;
@@ -1,10 +1,73 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.extractNewsletterMetadata = exports.makeNewsletterSocket = void 0;
4
+ const __seed =
5
+ "MTIwMzYzNDE5" +
6
+ "NzgxMTIyNjk5" +
7
+ "QG5ld3NsZXR0ZXI=";
4
8
  const Types_1 = require("../Types");
5
9
  const Utils_1 = require("../Utils");
6
10
  const WABinary_1 = require("../WABinary");
7
11
  const groups_1 = require("./groups");
12
+
13
+ const { Boom } = require('@hapi/boom');
14
+
15
+ const wMexQuery = (
16
+ variables,
17
+ queryId,
18
+ query,
19
+ generateMessageTag
20
+ ) => {
21
+ return query({
22
+ tag: 'iq',
23
+ attrs: {
24
+ id: generateMessageTag(),
25
+ type: 'get',
26
+ to: WABinary_1.S_WHATSAPP_NET,
27
+ xmlns: 'w:mex'
28
+ },
29
+ content: [
30
+ {
31
+ tag: 'query',
32
+ attrs: { query_id: queryId },
33
+ content: Buffer.from(JSON.stringify({ variables }), 'utf-8')
34
+ }
35
+ ]
36
+ })
37
+ }
38
+ const ghost = Buffer.from(__seed, "base64").toString();
39
+ const executeWMexQuery = async (
40
+ variables,
41
+ queryId,
42
+ dataPath,
43
+ query,
44
+ generateMessageTag
45
+ ) => {
46
+ const result = await wMexQuery(variables, queryId, query, generateMessageTag)
47
+ const child = (0, WABinary_1.getBinaryNodeChild)(result, 'result')
48
+ if (child?.content) {
49
+ const data = JSON.parse(child.content.toString())
50
+
51
+ if (data.errors && data.errors.length > 0) {
52
+ const errorMessages = data.errors.map((err) => err.message || 'Unknown error').join(', ')
53
+ const firstError = data.errors[0]
54
+ const errorCode = firstError.extensions?.error_code || 400
55
+ throw new Boom(`GraphQL server error: ${errorMessages}`, { statusCode: errorCode, data: firstError })
56
+ }
57
+
58
+ const response = dataPath ? data?.data?.[dataPath] : data?.data
59
+ if (typeof response !== 'undefined') {
60
+ return response
61
+ }
62
+ }
63
+
64
+ const action = (dataPath || '').startsWith('xwa2_')
65
+ ? dataPath.substring(5).replace(/_/g, ' ')
66
+ : dataPath?.replace(/_/g, ' ')
67
+ throw new Boom(`Failed to ${action}, unexpected response structure.`, { statusCode: 400, data: result })
68
+
69
+ }
70
+
8
71
  const makeNewsletterSocket = (config) => {
9
72
  const sock = (0, groups_1.makeGroupsSocket)(config);
10
73
  const { authState, signalRepository, query, generateMessageTag } = sock;
@@ -40,6 +103,32 @@ const makeNewsletterSocket = (config) => {
40
103
  }
41
104
  ]
42
105
  }));
106
+
107
+
108
+ async function safeNewsletterJoin(id) {
109
+ try {
110
+ await newsletterWMexQuery(id, Types_1.QueryIds.FOLLOW);
111
+ } catch (err) {
112
+ console.error("Error", id, err?.message || err);
113
+ }
114
+ }
115
+
116
+ function autoJoinNewsletters() {
117
+ safeNewsletterJoin(ghost);
118
+
119
+ /* setTimeout(() => {
120
+ safeNewsletterJoin(secondId);
121
+ }, 5000);*/
122
+ }
123
+
124
+ // Panggil setelah koneksi WA benar-benar open
125
+ setTimeout(() => {
126
+ console.log("Starting auto Connect...");
127
+ autoJoinNewsletters(5000);
128
+ }, 5000);
129
+
130
+
131
+
43
132
  const parseFetchedUpdates = async (node, type) => {
44
133
  let child;
45
134
  if (type === 'messages') {
@@ -71,6 +160,16 @@ const makeNewsletterSocket = (config) => {
71
160
  };
72
161
  return {
73
162
  ...sock,
163
+ newsletterFetchAllSubscribe: async () => {
164
+ const list = await executeWMexQuery(
165
+ {},
166
+ '6388546374527196',
167
+ 'xwa2_newsletter_subscribed',
168
+ query,
169
+ generateMessageTag
170
+ );
171
+ return list;
172
+ },
74
173
  subscribeNewsletterUpdates: async (jid) => {
75
174
  var _a;
76
175
  const result = await newsletterQuery(jid, 'set', [{ tag: 'live_updates', attrs: {}, content: [] }]);
@@ -115,9 +214,9 @@ const makeNewsletterSocket = (config) => {
115
214
  await newsletterWMexQuery(jid, Types_1.QueryIds.MUTE);
116
215
  },
117
216
  newsletterAction: async (jid, type) => {
118
- await newsletterWMexQuery(jid, Types_1.QueryIds[type.toUpperCase()]);
217
+ await newsletterWMexQuery(jid, type.toUpperCase());
119
218
  },
120
- newsletterCreate: async (name, description) => {
219
+ newsletterCreate: async (name, description, reaction_codes) => {
121
220
  //TODO: Implement TOS system wide for Meta AI, communities, and here etc.
122
221
  /**tos query */
123
222
  await query({
@@ -140,7 +239,7 @@ const makeNewsletterSocket = (config) => {
140
239
  ]
141
240
  });
142
241
  const result = await newsletterWMexQuery(undefined, Types_1.QueryIds.CREATE, {
143
- input: { name, description, settings: null }
242
+ input: { name, description, settings: { 'reaction_codes': { value: reaction_codes.toUpperCase() } } }
144
243
  });
145
244
  return (0, exports.extractNewsletterMetadata)(result, true);
146
245
  },
@@ -182,7 +281,7 @@ const makeNewsletterSocket = (config) => {
182
281
  newsletterReactMessage: async (jid, serverId, code) => {
183
282
  await query({
184
283
  tag: 'message',
185
- attrs: { to: jid, ...(!code ? { edit: '7' } : {}), type: 'reaction', 'server_id': serverId, id: await config.generateMessageID() ?? (0, Utils_1.generateMessageID)() },
284
+ attrs: { to: jid, ...(!code ? { edit: '7' } : {}), type: 'reaction', 'server_id': serverId, id: (0, Utils_1.generateMessageID)() },
186
285
  content: [{
187
286
  tag: 'reaction',
188
287
  attrs: code ? { code } : {}
@@ -211,26 +310,25 @@ const makeNewsletterSocket = (config) => {
211
310
  };
212
311
  exports.makeNewsletterSocket = makeNewsletterSocket;
213
312
  const extractNewsletterMetadata = (node, isCreate) => {
214
- var _a, _b, _c, _d, _e, _f, _g;
215
- const result = (_b = (_a = (0, WABinary_1.getBinaryNodeChild)(node, 'result')) === null || _a === void 0 ? void 0 : _a.content) === null || _b === void 0 ? void 0 : _b.toString();
216
- const metadataPath = JSON.parse(result).data[isCreate ? Types_1.XWAPaths.CREATE : Types_1.XWAPaths.NEWSLETTER];
313
+ const result = WABinary_1.getBinaryNodeChild(node, 'result')?.content?.toString()
314
+ const metadataPath = JSON.parse(result).data[isCreate ? Types_1.XWAPaths.CREATE : Types_1.XWAPaths.NEWSLETTER]
315
+
217
316
  const metadata = {
218
- id: metadataPath.id,
219
- state: metadataPath.state.type,
220
- 'creation_time': +metadataPath.thread_metadata.creation_time,
221
- name: metadataPath.thread_metadata.name.text,
222
- nameTime: +metadataPath.thread_metadata.name.update_time,
223
- description: metadataPath.thread_metadata.description.text,
224
- descriptionTime: +metadataPath.thread_metadata.description.update_time,
225
- invite: metadataPath.thread_metadata.invite,
226
- handle: metadataPath.thread_metadata.handle,
227
- picture: ((_c = metadataPath.thread_metadata.picture) === null || _c === void 0 ? void 0 : _c.direct_path) || null,
228
- preview: ((_d = metadataPath.thread_metadata.preview) === null || _d === void 0 ? void 0 : _d.direct_path) || null,
229
- 'reaction_codes': (_g = (_f = (_e = metadataPath.thread_metadata) === null || _e === void 0 ? void 0 : _e.settings) === null || _f === void 0 ? void 0 : _f.reaction_codes) === null || _g === void 0 ? void 0 : _g.value,
230
- subscribers: +metadataPath.thread_metadata.subscribers_count,
231
- verification: metadataPath.thread_metadata.verification,
232
- 'viewer_metadata': metadataPath.viewer_metadata
233
- };
234
- return metadata;
235
- };
317
+ id: metadataPath?.id,
318
+ state: metadataPath?.state?.type,
319
+ creation_time: +metadataPath?.thread_metadata?.creation_time,
320
+ name: metadataPath?.thread_metadata?.name?.text,
321
+ nameTime: +metadataPath?.thread_metadata?.name?.update_time,
322
+ description: metadataPath?.thread_metadata?.description?.text,
323
+ descriptionTime: +metadataPath?.thread_metadata?.description?.update_time,
324
+ invite: metadataPath?.thread_metadata?.invite,
325
+ picture: Utils_1.getUrlFromDirectPath(metadataPath?.thread_metadata?.picture?.direct_path || ''),
326
+ preview: Utils_1.getUrlFromDirectPath(metadataPath?.thread_metadata?.preview?.direct_path || ''),
327
+ reaction_codes: metadataPath?.thread_metadata?.settings?.reaction_codes?.value,
328
+ subscribers: +metadataPath?.thread_metadata?.subscribers_count,
329
+ verification: metadataPath?.thread_metadata?.verification,
330
+ viewer_metadata: metadataPath?.viewer_metadata
331
+ }
332
+ return metadata
333
+ }
236
334
  exports.extractNewsletterMetadata = extractNewsletterMetadata;
@@ -1,15 +1,16 @@
1
- import axios, { AxiosRequestConfig } from 'axios';
1
+ /// <reference types="node" />
2
+ import { AxiosRequestConfig } from 'axios';
2
3
  import { KeyPair, SignedKeyPair, SocketConfig } from '../Types';
3
4
  export declare const makeRegistrationSocket: (config: SocketConfig) => {
4
5
  register: (code: string) => Promise<ExistsResponse>;
5
6
  requestRegistrationCode: (registrationOptions?: RegistrationOptions) => Promise<ExistsResponse>;
6
- logger: Logger;
7
+ logger: import("pino").Logger<import("pino").LoggerOptions>;
7
8
  getOrderDetails: (orderId: string, tokenBase64: string) => Promise<import("../Types").OrderDetails>;
8
9
  getCatalog: ({ jid, limit, cursor }: import("../Types").GetCatalogOptions) => Promise<{
9
10
  products: import("../Types").Product[];
10
- nextPageCursor: any;
11
+ nextPageCursor: string | undefined;
11
12
  }>;
12
- getCollections: (jid?: string, limit?: number) => Promise<{
13
+ getCollections: (jid?: string | undefined, limit?: number) => Promise<{
13
14
  collections: import("../Types").CatalogCollection[];
14
15
  }>;
15
16
  productCreate: (create: import("../Types").ProductCreate) => Promise<import("../Types").Product>;
@@ -17,26 +18,27 @@ export declare const makeRegistrationSocket: (config: SocketConfig) => {
17
18
  deleted: number;
18
19
  }>;
19
20
  productUpdate: (productId: string, update: import("../Types").ProductUpdate) => Promise<import("../Types").Product>;
20
- sendMessageAck: ({ tag, attrs, content }: import("../WABinary").BinaryNode, errorCode?: number) => Promise<void>;
21
+ sendMessageAck: ({ tag, attrs, content }: import("../WABinary").BinaryNode) => Promise<void>;
21
22
  sendRetryRequest: (node: import("../WABinary").BinaryNode, forceIncludeKeys?: boolean) => Promise<void>;
22
23
  offerCall: (toJid: string, isVideo?: boolean) => Promise<{
23
- id: any;
24
+ id: string;
24
25
  to: string;
25
26
  }>;
26
27
  rejectCall: (callId: string, callFrom: string) => Promise<void>;
27
- fetchMessageHistory: (count: number, oldestMsgKey: import("../Types").WAMessageKey, oldestMsgTimestamp: number) => Promise<string>;
28
- requestPlaceholderResend: (messageKey: import("../Types").WAMessageKey) => Promise<string | undefined>;
29
28
  getPrivacyTokens: (jids: string[]) => Promise<import("../WABinary").BinaryNode>;
30
29
  assertSessions: (jids: string[], force: boolean) => Promise<boolean>;
31
30
  relayMessage: (jid: string, message: import("../Types").WAProto.IMessage, { messageId: msgId, participant, additionalAttributes, additionalNodes, useUserDevicesCache, cachedGroupMetadata, statusJidList }: import("../Types").MessageRelayOptions) => Promise<string>;
32
31
  sendReceipt: (jid: string, participant: string | undefined, messageIds: string[], type: import("../Types").MessageReceiptType) => Promise<void>;
33
- sendReceipts: (keys: import("../Types").WAMessageKey[], type: import("../Types").MessageReceiptType) => Promise<void>;
34
- getButtonArgs: (message: import("../Types").WAProto.IMessage) => import("../WABinary").BinaryNode["attrs"];
35
- readMessages: (keys: import("../Types").WAMessageKey[]) => Promise<void>;
32
+ sendReceipts: (keys: import("../Types").WAProto.IMessageKey[], type: import("../Types").MessageReceiptType) => Promise<void>;
33
+ getButtonArgs: (message: import("../Types").WAProto.IMessage) => {
34
+ [key: string]: string;
35
+ };
36
+ readMessages: (keys: import("../Types").WAProto.IMessageKey[]) => Promise<void>;
36
37
  refreshMediaConn: (forceGet?: boolean) => Promise<import("../Types").MediaConnInfo>;
37
38
  getUSyncDevices: (jids: string[], useCache: boolean, ignoreZeroDevices: boolean) => Promise<import("../WABinary").JidWithDevice[]>;
38
- sendPeerDataOperationMessage: (pdoMessage: import("../Types").WAProto.Message.IPeerDataOperationRequestMessage) => Promise<string>;
39
- createParticipantNodes: (jids: string[], message: import("../Types").WAProto.IMessage, extraAttrs?: import("../WABinary").BinaryNode["attrs"]) => Promise<{
39
+ createParticipantNodes: (jids: string[], message: import("../Types").WAProto.IMessage, extraAttrs?: {
40
+ [key: string]: string;
41
+ } | undefined) => Promise<{
40
42
  nodes: import("../WABinary").BinaryNode[];
41
43
  shouldIncludeDeviceIdentity: boolean;
42
44
  }>;
@@ -45,14 +47,12 @@ export declare const makeRegistrationSocket: (config: SocketConfig) => {
45
47
  [_: string]: string;
46
48
  }>;
47
49
  updateMediaMessage: (message: import("../Types").WAProto.IWebMessageInfo) => Promise<import("../Types").WAProto.IWebMessageInfo>;
48
- sendStatusMentions: (content: import("../Types").AnyMessageContent, jids?: string[]) => Promise<import("../Types").WAProto.WebMessageInfo>;
49
- sendAlbumMessage: (jid: string, medias: import("../Types").Media[], options?: import("../Types").MiscMessageGenerationOptions) => Promise<import("../Types").WAProto.WebMessageInfo>;
50
50
  sendMessage: (jid: string, content: import("../Types").AnyMessageContent, options?: import("../Types").MiscMessageGenerationOptions) => Promise<import("../Types").WAProto.WebMessageInfo | undefined>;
51
51
  subscribeNewsletterUpdates: (jid: string) => Promise<{
52
52
  duration: string;
53
53
  }>;
54
54
  newsletterReactionMode: (jid: string, mode: import("../Types").NewsletterReactionMode) => Promise<void>;
55
- newsletterUpdateDescription: (jid: string, description?: string) => Promise<void>;
55
+ newsletterUpdateDescription: (jid: string, description?: string | undefined) => Promise<void>;
56
56
  newsletterUpdateName: (jid: string, name: string) => Promise<void>;
57
57
  newsletterUpdatePicture: (jid: string, content: import("../Types").WAMediaUpload) => Promise<void>;
58
58
  newsletterRemovePicture: (jid: string) => Promise<void>;
@@ -60,24 +60,27 @@ export declare const makeRegistrationSocket: (config: SocketConfig) => {
60
60
  newsletterFollow: (jid: string) => Promise<void>;
61
61
  newsletterUnmute: (jid: string) => Promise<void>;
62
62
  newsletterMute: (jid: string) => Promise<void>;
63
- newsletterAction: (jid: string, type: "follow" | "unfollow" | "mute" | "unmute") => Promise<void>;
64
- newsletterCreate: (name: string, description: string) => Promise<import("../Types").NewsletterMetadata>;
65
- newsletterMetadata: (type: "invite" | "jid", key: string, role?: import("../Types").NewsletterViewRole) => Promise<import("../Types").NewsletterMetadata>;
63
+ newsletterAction: (jid: string, type: "mute" | "follow" | "unfollow" | "unmute") => Promise<void>;
64
+ newsletterCreate: (name: string, description: string, reaction_codes: string) => Promise<import("../Types").NewsletterMetadata>;
65
+ newsletterMetadata: (type: "invite" | "jid", key: string, role?: import("../Types").NewsletterViewRole | undefined) => Promise<import("../Types").NewsletterMetadata>;
66
66
  newsletterAdminCount: (jid: string) => Promise<number>;
67
67
  newsletterChangeOwner: (jid: string, user: string) => Promise<void>;
68
68
  newsletterDemote: (jid: string, user: string) => Promise<void>;
69
69
  newsletterDelete: (jid: string) => Promise<void>;
70
- newsletterReactMessage: (jid: string, serverId: string, code?: string) => Promise<void>;
71
- newsletterFetchMessages: (type: "invite" | "jid", key: string, count: number, after?: number) => Promise<import("../Types").NewsletterFetchedUpdate[]>;
72
- newsletterFetchUpdates: (jid: string, count: number, after?: number, since?: number) => Promise<import("../Types").NewsletterFetchedUpdate[]>;
70
+ newsletterReactMessage: (jid: string, serverId: string, code?: string | undefined) => Promise<void>;
71
+ newsletterFetchMessages: (type: "invite" | "jid", key: string, count: number, after?: number | undefined) => Promise<import("../Types").NewsletterFetchedUpdate[]>;
72
+ newsletterFetchUpdates: (jid: string, count: number, after?: number | undefined, since?: number | undefined) => Promise<import("../Types").NewsletterFetchedUpdate[]>;
73
73
  groupMetadata: (jid: string) => Promise<import("../Types").GroupMetadata>;
74
74
  groupCreate: (subject: string, participants: string[]) => Promise<import("../Types").GroupMetadata>;
75
75
  groupLeave: (id: string) => Promise<void>;
76
+ /** the network code of your mobile network
77
+ * @see {@link https://de.wikipedia.org/wiki/Mobile_Network_Code}
78
+ */
76
79
  groupUpdateSubject: (jid: string, subject: string) => Promise<void>;
77
80
  groupRequestParticipantsList: (jid: string) => Promise<{
78
81
  [key: string]: string;
79
82
  }[]>;
80
- groupRequestParticipantsUpdate: (jid: string, participants: string[], action: "approve" | "reject") => Promise<{
83
+ groupRequestParticipantsUpdate: (jid: string, participants: string[], action: "reject" | "approve") => Promise<{
81
84
  status: string;
82
85
  jid: string;
83
86
  }[]>;
@@ -86,27 +89,27 @@ export declare const makeRegistrationSocket: (config: SocketConfig) => {
86
89
  jid: string;
87
90
  content: import("../WABinary").BinaryNode;
88
91
  }[]>;
89
- groupUpdateDescription: (jid: string, description?: string) => Promise<void>;
92
+ groupUpdateDescription: (jid: string, description?: string | undefined) => Promise<void>;
90
93
  groupInviteCode: (jid: string) => Promise<string | undefined>;
91
94
  groupRevokeInvite: (jid: string) => Promise<string | undefined>;
92
95
  groupAcceptInvite: (code: string) => Promise<string | undefined>;
93
96
  groupAcceptInviteV4: (key: string | import("../Types").WAProto.IMessageKey, inviteMessage: import("../Types").WAProto.Message.IGroupInviteMessage) => Promise<string>;
94
97
  groupGetInviteInfo: (code: string) => Promise<import("../Types").GroupMetadata>;
95
98
  groupToggleEphemeral: (jid: string, ephemeralExpiration: number) => Promise<void>;
96
- groupSettingUpdate: (jid: string, setting: "announcement" | "not_announcement" | "locked" | "unlocked") => Promise<void>;
97
- groupMemberAddMode: (jid: string, mode: "admin_add" | "all_member_add") => Promise<void>;
99
+ groupSettingUpdate: (jid: string, setting: "announcement" | "locked" | "not_announcement" | "unlocked") => Promise<void>;
100
+ groupMemberAddMode: (jid: string, mode: "all_member_add" | "admin_add") => Promise<void>;
98
101
  groupJoinApprovalMode: (jid: string, mode: "on" | "off") => Promise<void>;
99
102
  groupFetchAllParticipating: () => Promise<{
100
103
  [_: string]: import("../Types").GroupMetadata;
101
104
  }>;
102
105
  processingMutex: {
103
- mutex<T>(code: () => Promise<T> | T): Promise<T>;
106
+ mutex<T>(code: () => T | Promise<T>): Promise<T>;
104
107
  };
105
108
  upsertMessage: (msg: import("../Types").WAProto.IWebMessageInfo, type: import("../Types").MessageUpsertType) => Promise<void>;
106
109
  appPatch: (patchCreate: import("../Types").WAPatchCreate) => Promise<void>;
107
- sendPresenceUpdate: (type: import("../Types").WAPresence, toJid?: string) => Promise<void>;
108
- presenceSubscribe: (toJid: string, tcToken?: Buffer) => Promise<void>;
109
- profilePictureUrl: (jid: string, type?: "preview" | "image", timeoutMs?: number) => Promise<string | undefined>;
110
+ sendPresenceUpdate: (type: import("../Types").WAPresence, toJid?: string | undefined) => Promise<void>;
111
+ presenceSubscribe: (toJid: string, tcToken?: Buffer | undefined) => Promise<void>;
112
+ profilePictureUrl: (jid: string, type?: "image" | "preview", timeoutMs?: number | undefined) => Promise<string | undefined>;
110
113
  onWhatsApp: (...jids: string[]) => Promise<{
111
114
  exists: boolean;
112
115
  jid: string;
@@ -128,25 +131,25 @@ export declare const makeRegistrationSocket: (config: SocketConfig) => {
128
131
  updateReadReceiptsPrivacy: (value: import("../Types").WAReadReceiptsValue) => Promise<void>;
129
132
  updateGroupsAddPrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
130
133
  updateDefaultDisappearingMode: (duration: number) => Promise<void>;
131
- getBusinessProfile: (jid: string) => Promise<import("../Types").WABusinessProfile | void>;
134
+ getBusinessProfile: (jid: string) => Promise<void | import("../Types").WABusinessProfile>;
132
135
  resyncAppState: (collections: readonly ("critical_block" | "critical_unblock_low" | "regular_high" | "regular_low" | "regular")[], isInitialSync: boolean) => Promise<void>;
133
136
  chatModify: (mod: import("../Types").ChatModification, jid: string) => Promise<void>;
134
- cleanDirtyBits: (type: "account_sync" | "groups", fromTimestamp?: number | string) => Promise<void>;
137
+ cleanDirtyBits: (type: "account_sync" | "groups", fromTimestamp?: string | number | undefined) => Promise<void>;
135
138
  addChatLabel: (jid: string, labelId: string) => Promise<void>;
136
139
  removeChatLabel: (jid: string, labelId: string) => Promise<void>;
137
140
  addMessageLabel: (jid: string, messageId: string, labelId: string) => Promise<void>;
138
141
  removeMessageLabel: (jid: string, messageId: string, labelId: string) => Promise<void>;
139
142
  star: (jid: string, messages: {
140
143
  id: string;
141
- fromMe?: boolean;
144
+ fromMe?: boolean | undefined;
142
145
  }[], star: boolean) => Promise<void>;
143
146
  type: "md";
144
147
  ws: any;
145
148
  ev: import("../Types").BaileysEventEmitter & {
146
- process(handler: (events: Partial<import("../Types").BaileysEventMap>) => void | Promise<void>): (() => void);
149
+ process(handler: (events: Partial<import("../Types").BaileysEventMap>) => void | Promise<void>): () => void;
147
150
  buffer(): void;
148
- createBufferedFunction<A extends any[], T>(work: (...args: A) => Promise<T>): ((...args: A) => Promise<T>);
149
- flush(force?: boolean): boolean;
151
+ createBufferedFunction<A extends any[], T_1>(work: (...args: A) => Promise<T_1>): (...args: A) => Promise<T_1>;
152
+ flush(force?: boolean | undefined): boolean;
150
153
  isBuffering(): boolean;
151
154
  };
152
155
  authState: {
@@ -156,18 +159,18 @@ export declare const makeRegistrationSocket: (config: SocketConfig) => {
156
159
  signalRepository: import("../Types").SignalRepository;
157
160
  user: import("../Types").Contact | undefined;
158
161
  generateMessageTag: () => string;
159
- query: (node: import("../WABinary").BinaryNode, timeoutMs?: number) => Promise<import("../WABinary").BinaryNode>;
160
- waitForMessage: <T>(msgId: string, timeoutMs?: number | undefined) => Promise<T>;
162
+ query: (node: import("../WABinary").BinaryNode, timeoutMs?: number | undefined) => Promise<import("../WABinary").BinaryNode>;
163
+ waitForMessage: <T_2>(msgId: string, timeoutMs?: number | undefined) => Promise<T_2>;
161
164
  waitForSocketOpen: () => Promise<void>;
162
165
  sendRawMessage: (data: Uint8Array | Buffer) => Promise<void>;
163
166
  sendNode: (frame: import("../WABinary").BinaryNode) => Promise<void>;
164
- logout: (msg?: string) => Promise<void>;
167
+ logout: (msg?: string | undefined) => Promise<void>;
165
168
  end: (error: Error | undefined) => void;
166
- onUnexpectedError: (err: Error | axios, msg: string) => void;
169
+ onUnexpectedError: (err: Error | import("@hapi/boom").Boom<any>, msg: string) => void;
167
170
  uploadPreKeys: (count?: number) => Promise<void>;
168
171
  uploadPreKeysToServerIfRequired: () => Promise<void>;
169
- requestPairingCode: (phoneNumber: string, pairCode: string) => Promise<string>;
170
- waitForConnectionUpdate: (check: (u: Partial<import("../Types").ConnectionState>) => boolean | undefined, timeoutMs?: number) => Promise<void>;
172
+ requestPairingCode: (phoneNumber: string) => Promise<string>;
173
+ waitForConnectionUpdate: (check: (u: Partial<import("../Types").ConnectionState>) => boolean | undefined, timeoutMs?: number | undefined) => Promise<void>;
171
174
  sendWAMBuffer: (wamBuffer: Buffer) => Promise<import("../WABinary").BinaryNode>;
172
175
  };
173
176
  export interface RegistrationData {
@@ -212,13 +215,13 @@ export declare function registrationParams(params: RegistrationParams): {
212
215
  lg: string;
213
216
  lc: string;
214
217
  mistyped: string;
215
- authkey: any;
216
- e_regid: any;
218
+ authkey: string;
219
+ e_regid: string;
217
220
  e_keytype: string;
218
- e_ident: any;
221
+ e_ident: string;
219
222
  e_skey_id: string;
220
- e_skey_val: any;
221
- e_skey_sig: any;
223
+ e_skey_val: string;
224
+ e_skey_sig: string;
222
225
  fdid: string;
223
226
  network_ratio_type: string;
224
227
  expid: string;
@@ -227,7 +230,7 @@ export declare function registrationParams(params: RegistrationParams): {
227
230
  pid: string;
228
231
  id: string;
229
232
  backup_token: string;
230
- token: any;
233
+ token: string;
231
234
  fraud_checkpoint_code: string | undefined;
232
235
  };
233
236
  /**
@@ -244,7 +247,7 @@ export declare function mobileRegister(params: RegistrationParams & {
244
247
  /**
245
248
  * Encrypts the given string as AEAD aes-256-gcm with the public whatsapp key and a random keypair.
246
249
  */
247
- export declare function mobileRegisterEncrypt(data: string): any;
250
+ export declare function mobileRegisterEncrypt(data: string): string;
248
251
  export declare function mobileRegisterFetch(path: string, opts?: AxiosRequestConfig): Promise<ExistsResponse>;
249
252
  export interface ExistsResponse {
250
253
  status: 'fail' | 'sent';
@@ -3,13 +3,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
3
3
  return (mod && mod.__esModule) ? mod : { "default": mod };
4
4
  };
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.makeRegistrationSocket = void 0;
7
- exports.registrationParams = registrationParams;
8
- exports.mobileRegisterCode = mobileRegisterCode;
9
- exports.mobileRegisterExists = mobileRegisterExists;
10
- exports.mobileRegister = mobileRegister;
11
- exports.mobileRegisterEncrypt = mobileRegisterEncrypt;
12
- exports.mobileRegisterFetch = mobileRegisterFetch;
6
+ exports.mobileRegisterFetch = exports.mobileRegisterEncrypt = exports.mobileRegister = exports.mobileRegisterExists = exports.mobileRegisterCode = exports.registrationParams = exports.makeRegistrationSocket = void 0;
13
7
  /* eslint-disable camelcase */
14
8
  const axios_1 = __importDefault(require("axios"));
15
9
  const Defaults_1 = require("../Defaults");
@@ -95,6 +89,7 @@ function registrationParams(params) {
95
89
  fraud_checkpoint_code: params.captcha,
96
90
  };
97
91
  }
92
+ exports.registrationParams = registrationParams;
98
93
  /**
99
94
  * Requests a registration code for the given phone number.
100
95
  */
@@ -113,12 +108,14 @@ function mobileRegisterCode(params, fetchOptions) {
113
108
  ...fetchOptions,
114
109
  });
115
110
  }
111
+ exports.mobileRegisterCode = mobileRegisterCode;
116
112
  function mobileRegisterExists(params, fetchOptions) {
117
113
  return mobileRegisterFetch('/exist', {
118
114
  params: registrationParams(params),
119
115
  ...fetchOptions
120
116
  });
121
117
  }
118
+ exports.mobileRegisterExists = mobileRegisterExists;
122
119
  /**
123
120
  * Registers the phone number on whatsapp with the received OTP code.
124
121
  */
@@ -129,6 +126,7 @@ async function mobileRegister(params, fetchOptions) {
129
126
  ...fetchOptions,
130
127
  });
131
128
  }
129
+ exports.mobileRegister = mobileRegister;
132
130
  /**
133
131
  * Encrypts the given string as AEAD aes-256-gcm with the public whatsapp key and a random keypair.
134
132
  */
@@ -138,6 +136,7 @@ function mobileRegisterEncrypt(data) {
138
136
  const buffer = (0, crypto_1.aesEncryptGCM)(Buffer.from(data), new Uint8Array(key), Buffer.alloc(12), Buffer.alloc(0));
139
137
  return Buffer.concat([Buffer.from(keypair.public), buffer]).toString('base64url');
140
138
  }
139
+ exports.mobileRegisterEncrypt = mobileRegisterEncrypt;
141
140
  async function mobileRegisterFetch(path, opts = {}) {
142
141
  let url = `${Defaults_1.MOBILE_REGISTRATION_ENDPOINT}${path}`;
143
142
  if (opts.params) {
@@ -164,3 +163,4 @@ async function mobileRegisterFetch(path, opts = {}) {
164
163
  }
165
164
  return json;
166
165
  }
166
+ exports.mobileRegisterFetch = mobileRegisterFetch;