cuki-bailx 1.1.2 → 1.2.2

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 (116) hide show
  1. package/WAProto/index.js +79296 -118676
  2. package/engine-requirements.js +1 -1
  3. package/lib/Defaults/baileys-version.json +1 -1
  4. package/lib/Defaults/index.d.ts +6 -4
  5. package/lib/Defaults/index.js +102 -78
  6. package/lib/Defaults/phonenumber-mcc.json +223 -0
  7. package/lib/Socket/Client/{types.d.ts → abstract-socket-client.d.ts} +2 -1
  8. package/lib/Socket/Client/index.d.ts +3 -2
  9. package/lib/Socket/Client/index.js +3 -2
  10. package/lib/Socket/Client/mobile-socket-client.d.ts +13 -0
  11. package/lib/Socket/Client/mobile-socket-client.js +65 -0
  12. package/lib/Socket/Client/{websocket.d.ts → web-socket-client.d.ts} +1 -2
  13. package/lib/Socket/Client/{websocket.js → web-socket-client.js} +2 -12
  14. package/lib/Socket/business.d.ts +58 -59
  15. package/lib/Socket/chats.d.ts +27 -29
  16. package/lib/Socket/chats.js +90 -97
  17. package/lib/Socket/dugong.d.ts +219 -0
  18. package/lib/Socket/dugong.js +441 -0
  19. package/lib/Socket/groups.d.ts +32 -41
  20. package/lib/Socket/groups.js +5 -20
  21. package/lib/Socket/index.d.ts +64 -63
  22. package/lib/Socket/index.js +2 -2
  23. package/lib/Socket/messages-recv.js +65 -9
  24. package/lib/Socket/messages-send.d.ts +47 -49
  25. package/lib/Socket/messages-send.js +312 -379
  26. package/lib/Socket/newsletter.d.ts +37 -39
  27. package/lib/Socket/newsletter.js +40 -54
  28. package/lib/Socket/registration.d.ts +267 -0
  29. package/lib/Socket/registration.js +166 -0
  30. package/lib/Socket/socket.d.ts +10 -10
  31. package/lib/Socket/socket.js +32 -39
  32. package/lib/Socket/socket.js.bak +630 -0
  33. package/lib/Socket/usync.d.ts +3 -3
  34. package/lib/Store/index.d.ts +2 -1
  35. package/lib/Store/index.js +3 -1
  36. package/lib/Store/make-cache-manager-store.d.ts +13 -0
  37. package/lib/Store/make-cache-manager-store.js +83 -0
  38. package/lib/Store/make-in-memory-store.d.ts +24 -24
  39. package/lib/Store/make-in-memory-store.js +11 -13
  40. package/lib/Store/make-ordered-dictionary.d.ts +1 -1
  41. package/lib/Store/make-ordered-dictionary.js +2 -2
  42. package/lib/Types/Auth.d.ts +7 -0
  43. package/lib/Types/Call.d.ts +1 -1
  44. package/lib/Types/Chat.d.ts +7 -14
  45. package/lib/Types/Contact.d.ts +1 -5
  46. package/lib/Types/Events.d.ts +2 -44
  47. package/lib/Types/GroupMetadata.d.ts +2 -11
  48. package/lib/Types/Label.js +1 -1
  49. package/lib/Types/LabelAssociation.js +1 -1
  50. package/lib/Types/Message.d.ts +21 -148
  51. package/lib/Types/Message.js +2 -0
  52. package/lib/Types/Newsletter.d.ts +13 -0
  53. package/lib/Types/Newsletter.js +17 -3
  54. package/lib/Types/Socket.d.ts +9 -17
  55. package/lib/Types/index.d.ts +1 -8
  56. package/lib/Types/index.js +2 -2
  57. package/lib/Utils/auth-utils.d.ts +3 -3
  58. package/lib/Utils/auth-utils.js +13 -6
  59. package/lib/Utils/business.js +2 -2
  60. package/lib/Utils/chat-utils.d.ts +16 -15
  61. package/lib/Utils/chat-utils.js +35 -36
  62. package/lib/Utils/crypto.d.ts +16 -15
  63. package/lib/Utils/crypto.js +29 -71
  64. package/lib/Utils/decode-wa-message.d.ts +6 -22
  65. package/lib/Utils/decode-wa-message.js +56 -65
  66. package/lib/Utils/event-buffer.d.ts +2 -2
  67. package/lib/Utils/event-buffer.js +7 -11
  68. package/lib/Utils/generics.d.ts +20 -17
  69. package/lib/Utils/generics.js +23 -73
  70. package/lib/Utils/history.d.ts +0 -4
  71. package/lib/Utils/history.js +6 -4
  72. package/lib/Utils/link-preview.d.ts +2 -2
  73. package/lib/Utils/link-preview.js +1 -34
  74. package/lib/Utils/logger.d.ts +3 -10
  75. package/lib/Utils/lt-hash.d.ts +2 -2
  76. package/lib/Utils/lt-hash.js +6 -6
  77. package/lib/Utils/make-mutex.d.ts +2 -2
  78. package/lib/Utils/messages-media.d.ts +24 -28
  79. package/lib/Utils/messages-media.js +115 -263
  80. package/lib/Utils/messages.d.ts +10 -8
  81. package/lib/Utils/messages.js +72 -298
  82. package/lib/Utils/noise-handler.d.ts +12 -10
  83. package/lib/Utils/noise-handler.js +23 -18
  84. package/lib/Utils/process-message.d.ts +4 -5
  85. package/lib/Utils/process-message.js +23 -74
  86. package/lib/Utils/signal.d.ts +1 -2
  87. package/lib/Utils/signal.js +35 -37
  88. package/lib/Utils/use-multi-file-auth-state.d.ts +1 -0
  89. package/lib/Utils/use-multi-file-auth-state.js +6 -51
  90. package/lib/Utils/validate-connection.d.ts +4 -3
  91. package/lib/Utils/validate-connection.js +52 -20
  92. package/lib/WABinary/constants.d.ts +4 -4
  93. package/lib/WABinary/constants.js +13 -1276
  94. package/lib/WABinary/decode.d.ts +4 -3
  95. package/lib/WABinary/decode.js +13 -26
  96. package/lib/WABinary/encode.d.ts +2 -1
  97. package/lib/WABinary/encode.js +17 -39
  98. package/lib/WABinary/generic-utils.d.ts +3 -1
  99. package/lib/WABinary/generic-utils.js +85 -2
  100. package/lib/WABinary/jid-utils.d.ts +5 -10
  101. package/lib/WABinary/jid-utils.js +5 -26
  102. package/lib/WAM/BinaryInfo.d.ts +11 -2
  103. package/lib/WAM/encode.d.ts +2 -1
  104. package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.js +1 -1
  105. package/lib/index.d.ts +2 -6
  106. package/lib/index.js +7 -22
  107. package/lib/index.js.bak +37 -0
  108. package/package.json +103 -111
  109. package/LICENSE +0 -21
  110. package/WAProto/GenerateStatics.sh +0 -4
  111. package/WAProto/WAProto.proto +0 -4775
  112. package/WAProto/index.d.ts +0 -55057
  113. package/WAProto/index.ts.ts +0 -53473
  114. package/WAProto/p.html +0 -1
  115. package/lib/WABinary/jid-utils.js.bak +0 -83
  116. /package/lib/Socket/Client/{types.js → abstract-socket-client.js} +0 -0
@@ -0,0 +1,267 @@
1
+ /// <reference types="node" />
2
+ import { AxiosRequestConfig } from 'axios';
3
+ import { KeyPair, SignedKeyPair, SocketConfig } from '../Types';
4
+ export declare const makeRegistrationSocket: (config: SocketConfig) => {
5
+ register: (code: string) => Promise<ExistsResponse>;
6
+ requestRegistrationCode: (registrationOptions?: RegistrationOptions) => Promise<ExistsResponse>;
7
+ logger: import("pino").Logger<import("pino").LoggerOptions>;
8
+ getOrderDetails: (orderId: string, tokenBase64: string) => Promise<import("../Types").OrderDetails>;
9
+ getCatalog: ({ jid, limit, cursor }: import("../Types").GetCatalogOptions) => Promise<{
10
+ products: import("../Types").Product[];
11
+ nextPageCursor: string | undefined;
12
+ }>;
13
+ getCollections: (jid?: string | undefined, limit?: number) => Promise<{
14
+ collections: import("../Types").CatalogCollection[];
15
+ }>;
16
+ productCreate: (create: import("../Types").ProductCreate) => Promise<import("../Types").Product>;
17
+ productDelete: (productIds: string[]) => Promise<{
18
+ deleted: number;
19
+ }>;
20
+ productUpdate: (productId: string, update: import("../Types").ProductUpdate) => Promise<import("../Types").Product>;
21
+ sendMessageAck: ({ tag, attrs, content }: import("../WABinary").BinaryNode) => Promise<void>;
22
+ sendRetryRequest: (node: import("../WABinary").BinaryNode, forceIncludeKeys?: boolean) => Promise<void>;
23
+ offerCall: (toJid: string, isVideo?: boolean) => Promise<{
24
+ id: string;
25
+ to: string;
26
+ }>;
27
+ rejectCall: (callId: string, callFrom: string) => Promise<void>;
28
+ getPrivacyTokens: (jids: string[]) => Promise<import("../WABinary").BinaryNode>;
29
+ assertSessions: (jids: string[], force: boolean) => Promise<boolean>;
30
+ relayMessage: (jid: string, message: import("../Types").WAProto.IMessage, { messageId: msgId, participant, additionalAttributes, additionalNodes, useUserDevicesCache, cachedGroupMetadata, statusJidList }: import("../Types").MessageRelayOptions) => Promise<string>;
31
+ sendReceipt: (jid: string, participant: string | undefined, messageIds: string[], type: import("../Types").MessageReceiptType) => 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>;
37
+ refreshMediaConn: (forceGet?: boolean) => Promise<import("../Types").MediaConnInfo>;
38
+ getUSyncDevices: (jids: string[], useCache: boolean, ignoreZeroDevices: boolean) => Promise<import("../WABinary").JidWithDevice[]>;
39
+ createParticipantNodes: (jids: string[], message: import("../Types").WAProto.IMessage, extraAttrs?: {
40
+ [key: string]: string;
41
+ } | undefined) => Promise<{
42
+ nodes: import("../WABinary").BinaryNode[];
43
+ shouldIncludeDeviceIdentity: boolean;
44
+ }>;
45
+ waUploadToServer: import("../Types").WAMediaUploadFunction;
46
+ fetchPrivacySettings: (force?: boolean) => Promise<{
47
+ [_: string]: string;
48
+ }>;
49
+ updateMediaMessage: (message: import("../Types").WAProto.IWebMessageInfo) => Promise<import("../Types").WAProto.IWebMessageInfo>;
50
+ sendMessage: (jid: string, content: import("../Types").AnyMessageContent, options?: import("../Types").MiscMessageGenerationOptions) => Promise<import("../Types").WAProto.WebMessageInfo | undefined>;
51
+ subscribeNewsletterUpdates: (jid: string) => Promise<{
52
+ duration: string;
53
+ }>;
54
+ newsletterReactionMode: (jid: string, mode: import("../Types").NewsletterReactionMode) => Promise<void>;
55
+ newsletterUpdateDescription: (jid: string, description?: string | undefined) => Promise<void>;
56
+ newsletterUpdateName: (jid: string, name: string) => Promise<void>;
57
+ newsletterUpdatePicture: (jid: string, content: import("../Types").WAMediaUpload) => Promise<void>;
58
+ newsletterRemovePicture: (jid: string) => Promise<void>;
59
+ newsletterUnfollow: (jid: string) => Promise<void>;
60
+ newsletterFollow: (jid: string) => Promise<void>;
61
+ newsletterUnmute: (jid: string) => Promise<void>;
62
+ newsletterMute: (jid: string) => Promise<void>;
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
+ newsletterAdminCount: (jid: string) => Promise<number>;
67
+ newsletterChangeOwner: (jid: string, user: string) => Promise<void>;
68
+ newsletterDemote: (jid: string, user: string) => Promise<void>;
69
+ newsletterDelete: (jid: string) => Promise<void>;
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
+ groupMetadata: (jid: string) => Promise<import("../Types").GroupMetadata>;
74
+ groupCreate: (subject: string, participants: string[]) => Promise<import("../Types").GroupMetadata>;
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
+ */
79
+ groupUpdateSubject: (jid: string, subject: string) => Promise<void>;
80
+ groupRequestParticipantsList: (jid: string) => Promise<{
81
+ [key: string]: string;
82
+ }[]>;
83
+ groupRequestParticipantsUpdate: (jid: string, participants: string[], action: "reject" | "approve") => Promise<{
84
+ status: string;
85
+ jid: string;
86
+ }[]>;
87
+ groupParticipantsUpdate: (jid: string, participants: string[], action: import("../Types").ParticipantAction) => Promise<{
88
+ status: string;
89
+ jid: string;
90
+ content: import("../WABinary").BinaryNode;
91
+ }[]>;
92
+ groupUpdateDescription: (jid: string, description?: string | undefined) => Promise<void>;
93
+ groupInviteCode: (jid: string) => Promise<string | undefined>;
94
+ groupRevokeInvite: (jid: string) => Promise<string | undefined>;
95
+ groupAcceptInvite: (code: string) => Promise<string | undefined>;
96
+ groupAcceptInviteV4: (key: string | import("../Types").WAProto.IMessageKey, inviteMessage: import("../Types").WAProto.Message.IGroupInviteMessage) => Promise<string>;
97
+ groupGetInviteInfo: (code: string) => Promise<import("../Types").GroupMetadata>;
98
+ groupToggleEphemeral: (jid: string, ephemeralExpiration: number) => 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>;
101
+ groupJoinApprovalMode: (jid: string, mode: "on" | "off") => Promise<void>;
102
+ groupFetchAllParticipating: () => Promise<{
103
+ [_: string]: import("../Types").GroupMetadata;
104
+ }>;
105
+ processingMutex: {
106
+ mutex<T>(code: () => T | Promise<T>): Promise<T>;
107
+ };
108
+ upsertMessage: (msg: import("../Types").WAProto.IWebMessageInfo, type: import("../Types").MessageUpsertType) => Promise<void>;
109
+ appPatch: (patchCreate: import("../Types").WAPatchCreate) => Promise<void>;
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>;
113
+ onWhatsApp: (...jids: string[]) => Promise<{
114
+ exists: boolean;
115
+ jid: string;
116
+ }[]>;
117
+ fetchBlocklist: () => Promise<string[]>;
118
+ fetchStatus: (jid: string) => Promise<{
119
+ status: string | undefined;
120
+ setAt: Date;
121
+ } | undefined>;
122
+ updateProfilePicture: (jid: string, content: import("../Types").WAMediaUpload) => Promise<void>;
123
+ removeProfilePicture: (jid: string) => Promise<void>;
124
+ updateProfileStatus: (status: string) => Promise<void>;
125
+ updateProfileName: (name: string) => Promise<void>;
126
+ updateBlockStatus: (jid: string, action: "block" | "unblock") => Promise<void>;
127
+ updateLastSeenPrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
128
+ updateOnlinePrivacy: (value: import("../Types").WAPrivacyOnlineValue) => Promise<void>;
129
+ updateProfilePicturePrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
130
+ updateStatusPrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
131
+ updateReadReceiptsPrivacy: (value: import("../Types").WAReadReceiptsValue) => Promise<void>;
132
+ updateGroupsAddPrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
133
+ updateDefaultDisappearingMode: (duration: number) => Promise<void>;
134
+ getBusinessProfile: (jid: string) => Promise<void | import("../Types").WABusinessProfile>;
135
+ resyncAppState: (collections: readonly ("critical_block" | "critical_unblock_low" | "regular_high" | "regular_low" | "regular")[], isInitialSync: boolean) => Promise<void>;
136
+ chatModify: (mod: import("../Types").ChatModification, jid: string) => Promise<void>;
137
+ cleanDirtyBits: (type: "account_sync" | "groups", fromTimestamp?: string | number | undefined) => Promise<void>;
138
+ addChatLabel: (jid: string, labelId: string) => Promise<void>;
139
+ removeChatLabel: (jid: string, labelId: string) => Promise<void>;
140
+ addMessageLabel: (jid: string, messageId: string, labelId: string) => Promise<void>;
141
+ removeMessageLabel: (jid: string, messageId: string, labelId: string) => Promise<void>;
142
+ star: (jid: string, messages: {
143
+ id: string;
144
+ fromMe?: boolean | undefined;
145
+ }[], star: boolean) => Promise<void>;
146
+ type: "md";
147
+ ws: any;
148
+ ev: import("../Types").BaileysEventEmitter & {
149
+ process(handler: (events: Partial<import("../Types").BaileysEventMap>) => void | Promise<void>): () => void;
150
+ buffer(): void;
151
+ createBufferedFunction<A extends any[], T_1>(work: (...args: A) => Promise<T_1>): (...args: A) => Promise<T_1>;
152
+ flush(force?: boolean | undefined): boolean;
153
+ isBuffering(): boolean;
154
+ };
155
+ authState: {
156
+ creds: import("../Types").AuthenticationCreds;
157
+ keys: import("../Types").SignalKeyStoreWithTransaction;
158
+ };
159
+ signalRepository: import("../Types").SignalRepository;
160
+ user: import("../Types").Contact | undefined;
161
+ generateMessageTag: () => string;
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>;
164
+ waitForSocketOpen: () => Promise<void>;
165
+ sendRawMessage: (data: Uint8Array | Buffer) => Promise<void>;
166
+ sendNode: (frame: import("../WABinary").BinaryNode) => Promise<void>;
167
+ logout: (msg?: string | undefined) => Promise<void>;
168
+ end: (error: Error | undefined) => void;
169
+ onUnexpectedError: (err: Error | import("@hapi/boom").Boom<any>, msg: string) => void;
170
+ uploadPreKeys: (count?: number) => Promise<void>;
171
+ uploadPreKeysToServerIfRequired: () => Promise<void>;
172
+ requestPairingCode: (phoneNumber: string) => Promise<string>;
173
+ waitForConnectionUpdate: (check: (u: Partial<import("../Types").ConnectionState>) => boolean | undefined, timeoutMs?: number | undefined) => Promise<void>;
174
+ sendWAMBuffer: (wamBuffer: Buffer) => Promise<import("../WABinary").BinaryNode>;
175
+ };
176
+ export interface RegistrationData {
177
+ registrationId: number;
178
+ signedPreKey: SignedKeyPair;
179
+ noiseKey: KeyPair;
180
+ signedIdentityKey: KeyPair;
181
+ identityId: Buffer;
182
+ phoneId: string;
183
+ deviceId: string;
184
+ backupToken: Buffer;
185
+ }
186
+ export interface RegistrationOptions {
187
+ /** your phone number */
188
+ phoneNumber?: string;
189
+ /** the country code of your phone number */
190
+ phoneNumberCountryCode: string;
191
+ /** your phone number without country code */
192
+ phoneNumberNationalNumber: string;
193
+ /** the country code of your mobile network
194
+ * @see {@link https://de.wikipedia.org/wiki/Mobile_Country_Code}
195
+ */
196
+ phoneNumberMobileCountryCode: string;
197
+ /** the network code of your mobile network
198
+ * @see {@link https://de.wikipedia.org/wiki/Mobile_Network_Code}
199
+ */
200
+ phoneNumberMobileNetworkCode: string;
201
+ /**
202
+ * How to send the one time code
203
+ */
204
+ method?: 'sms' | 'voice' | 'captcha';
205
+ /**
206
+ * The captcha code if it was requested
207
+ */
208
+ captcha?: string;
209
+ }
210
+ export type RegistrationParams = RegistrationData & RegistrationOptions;
211
+ export declare function registrationParams(params: RegistrationParams): {
212
+ cc: string;
213
+ in: string;
214
+ Rc: string;
215
+ lg: string;
216
+ lc: string;
217
+ mistyped: string;
218
+ authkey: string;
219
+ e_regid: string;
220
+ e_keytype: string;
221
+ e_ident: string;
222
+ e_skey_id: string;
223
+ e_skey_val: string;
224
+ e_skey_sig: string;
225
+ fdid: string;
226
+ network_ratio_type: string;
227
+ expid: string;
228
+ simnum: string;
229
+ hasinrc: string;
230
+ pid: string;
231
+ id: string;
232
+ backup_token: string;
233
+ token: string;
234
+ fraud_checkpoint_code: string | undefined;
235
+ };
236
+ /**
237
+ * Requests a registration code for the given phone number.
238
+ */
239
+ export declare function mobileRegisterCode(params: RegistrationParams, fetchOptions?: AxiosRequestConfig): Promise<ExistsResponse>;
240
+ export declare function mobileRegisterExists(params: RegistrationParams, fetchOptions?: AxiosRequestConfig): Promise<ExistsResponse>;
241
+ /**
242
+ * Registers the phone number on whatsapp with the received OTP code.
243
+ */
244
+ export declare function mobileRegister(params: RegistrationParams & {
245
+ code: string;
246
+ }, fetchOptions?: AxiosRequestConfig): Promise<ExistsResponse>;
247
+ /**
248
+ * Encrypts the given string as AEAD aes-256-gcm with the public whatsapp key and a random keypair.
249
+ */
250
+ export declare function mobileRegisterEncrypt(data: string): string;
251
+ export declare function mobileRegisterFetch(path: string, opts?: AxiosRequestConfig): Promise<ExistsResponse>;
252
+ export interface ExistsResponse {
253
+ status: 'fail' | 'sent';
254
+ voice_length?: number;
255
+ voice_wait?: number;
256
+ sms_length?: number;
257
+ sms_wait?: number;
258
+ reason?: 'incorrect' | 'missing_param' | 'code_checkpoint';
259
+ login?: string;
260
+ flash_type?: number;
261
+ ab_hash?: string;
262
+ ab_key?: string;
263
+ exp_cfg?: string;
264
+ lid?: string;
265
+ image_blob?: string;
266
+ audio_blob?: string;
267
+ }
@@ -0,0 +1,166 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.mobileRegisterFetch = exports.mobileRegisterEncrypt = exports.mobileRegister = exports.mobileRegisterExists = exports.mobileRegisterCode = exports.registrationParams = exports.makeRegistrationSocket = void 0;
7
+ /* eslint-disable camelcase */
8
+ const axios_1 = __importDefault(require("axios"));
9
+ const Defaults_1 = require("../Defaults");
10
+ const crypto_1 = require("../Utils/crypto");
11
+ const WABinary_1 = require("../WABinary");
12
+ const business_1 = require("./business");
13
+ function urlencode(str) {
14
+ return str.replace(/-/g, '%2d').replace(/_/g, '%5f').replace(/~/g, '%7e');
15
+ }
16
+ const validRegistrationOptions = (config) => (config === null || config === void 0 ? void 0 : config.phoneNumberCountryCode) &&
17
+ config.phoneNumberNationalNumber &&
18
+ config.phoneNumberMobileCountryCode;
19
+ const makeRegistrationSocket = (config) => {
20
+ const sock = (0, business_1.makeBusinessSocket)(config);
21
+ const register = async (code) => {
22
+ if (!validRegistrationOptions(config.auth.creds.registration)) {
23
+ throw new Error('please specify the registration options');
24
+ }
25
+ const result = await mobileRegister({ ...sock.authState.creds, ...sock.authState.creds.registration, code }, config.options);
26
+ sock.authState.creds.me = {
27
+ id: (0, WABinary_1.jidEncode)(result.login, 's.whatsapp.net'),
28
+ name: '~'
29
+ };
30
+ sock.authState.creds.registered = true;
31
+ sock.ev.emit('creds.update', sock.authState.creds);
32
+ return result;
33
+ };
34
+ const requestRegistrationCode = async (registrationOptions) => {
35
+ registrationOptions = registrationOptions || config.auth.creds.registration;
36
+ if (!validRegistrationOptions(registrationOptions)) {
37
+ throw new Error('Invalid registration options');
38
+ }
39
+ sock.authState.creds.registration = registrationOptions;
40
+ sock.ev.emit('creds.update', sock.authState.creds);
41
+ return mobileRegisterCode({ ...config.auth.creds, ...registrationOptions }, config.options);
42
+ };
43
+ return {
44
+ ...sock,
45
+ register,
46
+ requestRegistrationCode,
47
+ };
48
+ };
49
+ exports.makeRegistrationSocket = makeRegistrationSocket;
50
+ function convertBufferToUrlHex(buffer) {
51
+ var id = '';
52
+ buffer.forEach((x) => {
53
+ // encode random identity_id buffer as percentage url encoding
54
+ id += `%${x.toString(16).padStart(2, '0').toLowerCase()}`;
55
+ });
56
+ return id;
57
+ }
58
+ function registrationParams(params) {
59
+ const e_regid = Buffer.alloc(4);
60
+ e_regid.writeInt32BE(params.registrationId);
61
+ const e_skey_id = Buffer.alloc(3);
62
+ e_skey_id.writeInt16BE(params.signedPreKey.keyId);
63
+ params.phoneNumberCountryCode = params.phoneNumberCountryCode.replace('+', '').trim();
64
+ params.phoneNumberNationalNumber = params.phoneNumberNationalNumber.replace(/[/-\s)(]/g, '').trim();
65
+ return {
66
+ cc: params.phoneNumberCountryCode,
67
+ in: params.phoneNumberNationalNumber,
68
+ Rc: '0',
69
+ lg: 'en',
70
+ lc: 'GB',
71
+ mistyped: '6',
72
+ authkey: Buffer.from(params.noiseKey.public).toString('base64url'),
73
+ e_regid: e_regid.toString('base64url'),
74
+ e_keytype: 'BQ',
75
+ e_ident: Buffer.from(params.signedIdentityKey.public).toString('base64url'),
76
+ // e_skey_id: e_skey_id.toString('base64url'),
77
+ e_skey_id: 'AAAA',
78
+ e_skey_val: Buffer.from(params.signedPreKey.keyPair.public).toString('base64url'),
79
+ e_skey_sig: Buffer.from(params.signedPreKey.signature).toString('base64url'),
80
+ fdid: params.phoneId,
81
+ network_ratio_type: '1',
82
+ expid: params.deviceId,
83
+ simnum: '1',
84
+ hasinrc: '1',
85
+ pid: Math.floor(Math.random() * 1000).toString(),
86
+ id: convertBufferToUrlHex(params.identityId),
87
+ backup_token: convertBufferToUrlHex(params.backupToken),
88
+ token: (0, crypto_1.md5)(Buffer.concat([Defaults_1.MOBILE_TOKEN, Buffer.from(params.phoneNumberNationalNumber)])).toString('hex'),
89
+ fraud_checkpoint_code: params.captcha,
90
+ };
91
+ }
92
+ exports.registrationParams = registrationParams;
93
+ /**
94
+ * Requests a registration code for the given phone number.
95
+ */
96
+ function mobileRegisterCode(params, fetchOptions) {
97
+ return mobileRegisterFetch('/code', {
98
+ params: {
99
+ ...registrationParams(params),
100
+ mcc: `${params.phoneNumberMobileCountryCode}`.padStart(3, '0'),
101
+ mnc: `${params.phoneNumberMobileNetworkCode || '001'}`.padStart(3, '0'),
102
+ sim_mcc: '000',
103
+ sim_mnc: '000',
104
+ method: (params === null || params === void 0 ? void 0 : params.method) || 'sms',
105
+ reason: '',
106
+ hasav: '1'
107
+ },
108
+ ...fetchOptions,
109
+ });
110
+ }
111
+ exports.mobileRegisterCode = mobileRegisterCode;
112
+ function mobileRegisterExists(params, fetchOptions) {
113
+ return mobileRegisterFetch('/exist', {
114
+ params: registrationParams(params),
115
+ ...fetchOptions
116
+ });
117
+ }
118
+ exports.mobileRegisterExists = mobileRegisterExists;
119
+ /**
120
+ * Registers the phone number on whatsapp with the received OTP code.
121
+ */
122
+ async function mobileRegister(params, fetchOptions) {
123
+ //const result = await mobileRegisterFetch(`/reg_onboard_abprop?cc=${params.phoneNumberCountryCode}&in=${params.phoneNumberNationalNumber}&rc=0`)
124
+ return mobileRegisterFetch('/register', {
125
+ params: { ...registrationParams(params), code: params.code.replace('-', '') },
126
+ ...fetchOptions,
127
+ });
128
+ }
129
+ exports.mobileRegister = mobileRegister;
130
+ /**
131
+ * Encrypts the given string as AEAD aes-256-gcm with the public whatsapp key and a random keypair.
132
+ */
133
+ function mobileRegisterEncrypt(data) {
134
+ const keypair = crypto_1.Curve.generateKeyPair();
135
+ const key = crypto_1.Curve.sharedKey(keypair.private, Defaults_1.REGISTRATION_PUBLIC_KEY);
136
+ const buffer = (0, crypto_1.aesEncryptGCM)(Buffer.from(data), new Uint8Array(key), Buffer.alloc(12), Buffer.alloc(0));
137
+ return Buffer.concat([Buffer.from(keypair.public), buffer]).toString('base64url');
138
+ }
139
+ exports.mobileRegisterEncrypt = mobileRegisterEncrypt;
140
+ async function mobileRegisterFetch(path, opts = {}) {
141
+ let url = `${Defaults_1.MOBILE_REGISTRATION_ENDPOINT}${path}`;
142
+ if (opts.params) {
143
+ const parameter = [];
144
+ for (const param in opts.params) {
145
+ if (opts.params[param] !== null && opts.params[param] !== undefined) {
146
+ parameter.push(param + '=' + urlencode(opts.params[param]));
147
+ }
148
+ }
149
+ url += `?${parameter.join('&')}`;
150
+ delete opts.params;
151
+ }
152
+ if (!opts.headers) {
153
+ opts.headers = {};
154
+ }
155
+ opts.headers['User-Agent'] = Defaults_1.MOBILE_USERAGENT;
156
+ const response = await (0, axios_1.default)(url, opts);
157
+ var json = response.data;
158
+ if (response.status > 300 || json.reason) {
159
+ throw json;
160
+ }
161
+ if (json.status && !['ok', 'sent'].includes(json.status)) {
162
+ throw json;
163
+ }
164
+ return json;
165
+ }
166
+ exports.mobileRegisterFetch = mobileRegisterFetch;
@@ -1,7 +1,7 @@
1
+ /// <reference types="node" />
1
2
  import { Boom } from '@hapi/boom';
2
3
  import { SocketConfig } from '../Types';
3
4
  import { BinaryNode } from '../WABinary';
4
- import { WebSocketClient } from './Client';
5
5
  /**
6
6
  * Connects to WA servers and performs:
7
7
  * - simple queries (no retry mechanism, wait for connection establishment)
@@ -10,12 +10,12 @@ import { WebSocketClient } from './Client';
10
10
  */
11
11
  export declare const makeSocket: (config: SocketConfig) => {
12
12
  type: "md";
13
- ws: WebSocketClient;
13
+ ws: any;
14
14
  ev: import("../Types").BaileysEventEmitter & {
15
- process(handler: (events: Partial<import("../Types").BaileysEventMap>) => void | Promise<void>): (() => void);
15
+ process(handler: (events: Partial<import("../Types").BaileysEventMap>) => void | Promise<void>): () => void;
16
16
  buffer(): void;
17
- createBufferedFunction<A extends any[], T>(work: (...args: A) => Promise<T>): ((...args: A) => Promise<T>);
18
- flush(force?: boolean): boolean;
17
+ createBufferedFunction<A extends any[], T>(work: (...args: A) => Promise<T>): (...args: A) => Promise<T>;
18
+ flush(force?: boolean | undefined): boolean;
19
19
  isBuffering(): boolean;
20
20
  };
21
21
  authState: {
@@ -25,8 +25,8 @@ export declare const makeSocket: (config: SocketConfig) => {
25
25
  signalRepository: import("../Types").SignalRepository;
26
26
  readonly user: import("../Types").Contact | undefined;
27
27
  generateMessageTag: () => string;
28
- query: (node: BinaryNode, timeoutMs?: number) => Promise<any>;
29
- waitForMessage: <T>(msgId: string, timeoutMs?: number | undefined) => Promise<any>;
28
+ query: (node: BinaryNode, timeoutMs?: number) => Promise<BinaryNode>;
29
+ waitForMessage: <T_1>(msgId: string, timeoutMs?: number | undefined) => Promise<T_1>;
30
30
  waitForSocketOpen: () => Promise<void>;
31
31
  sendRawMessage: (data: Uint8Array | Buffer) => Promise<void>;
32
32
  sendNode: (frame: BinaryNode) => Promise<void>;
@@ -35,9 +35,9 @@ export declare const makeSocket: (config: SocketConfig) => {
35
35
  onUnexpectedError: (err: Error | Boom, msg: string) => void;
36
36
  uploadPreKeys: (count?: number) => Promise<void>;
37
37
  uploadPreKeysToServerIfRequired: () => Promise<void>;
38
- requestPairingCode: (phoneNumber: any, pairKey?: string) => Promise<string>;
38
+ requestPairingCode: (phoneNumber: string) => Promise<string>;
39
39
  /** Waits for the connection to WA to reach a state */
40
- waitForConnectionUpdate: (check: (u: Partial<import("../Types").ConnectionState>) => Promise<boolean | undefined>, timeoutMs?: number) => Promise<void>;
41
- sendWAMBuffer: (wamBuffer: Buffer) => Promise<any>;
40
+ waitForConnectionUpdate: (check: (u: Partial<import("../Types").ConnectionState>) => boolean | undefined, timeoutMs?: number | undefined) => Promise<void>;
41
+ sendWAMBuffer: (wamBuffer: Buffer) => Promise<BinaryNode>;
42
42
  };
43
43
  export type Socket = ReturnType<typeof makeSocket>;
@@ -20,14 +20,15 @@ const Client_1 = require("./Client");
20
20
  const makeSocket = (config) => {
21
21
  var _a, _b;
22
22
  const { waWebSocketUrl, connectTimeoutMs, logger, keepAliveIntervalMs, browser, auth: authState, printQRInTerminal, defaultQueryTimeoutMs, transactionOpts, qrTimeout, makeSignalRepository, } = config;
23
- const url = typeof waWebSocketUrl === 'string' ? new url_1.URL(waWebSocketUrl) : waWebSocketUrl;
24
- if (config.mobile || url.protocol === 'tcp:') {
25
- throw new boom_1.Boom('Mobile API is not supported anymore', { statusCode: Types_1.DisconnectReason.loggedOut });
23
+ let url = typeof waWebSocketUrl === 'string' ? new url_1.URL(waWebSocketUrl) : waWebSocketUrl;
24
+ config.mobile = config.mobile || url.protocol === 'tcp:';
25
+ if (config.mobile && url.protocol !== 'tcp:') {
26
+ url = new url_1.URL(`tcp://${Defaults_1.MOBILE_ENDPOINT}:${Defaults_1.MOBILE_PORT}`);
26
27
  }
27
- if (url.protocol === 'wss' && ((_a = authState === null || authState === void 0 ? void 0 : authState.creds) === null || _a === void 0 ? void 0 : _a.routingInfo)) {
28
+ if (!config.mobile && url.protocol === 'wss' && ((_a = authState === null || authState === void 0 ? void 0 : authState.creds) === null || _a === void 0 ? void 0 : _a.routingInfo)) {
28
29
  url.searchParams.append('ED', authState.creds.routingInfo.toString('base64url'));
29
30
  }
30
- const ws = new Client_1.WebSocketClient(url, config);
31
+ const ws = config.socket ? config.socket : config.mobile ? new Client_1.MobileSocketClient(url, config) : new Client_1.WebSocketClient(url, config);
31
32
  ws.connect();
32
33
  const ev = (0, Utils_1.makeEventBuffer)(logger);
33
34
  /** ephemeral key pair used to encrypt/decrypt communication. Unique for each connection */
@@ -35,7 +36,8 @@ const makeSocket = (config) => {
35
36
  /** WA noise protocol wrapper */
36
37
  const noise = (0, Utils_1.makeNoiseHandler)({
37
38
  keyPair: ephemeralKeyPair,
38
- NOISE_HEADER: Defaults_1.NOISE_WA_HEADER,
39
+ NOISE_HEADER: config.mobile ? Defaults_1.MOBILE_NOISE_HEADER : Defaults_1.NOISE_WA_HEADER,
40
+ mobile: config.mobile,
39
41
  logger,
40
42
  routingInfo: (_b = authState === null || authState === void 0 ? void 0 : authState.creds) === null || _b === void 0 ? void 0 : _b.routingInfo
41
43
  });
@@ -114,7 +116,7 @@ const makeSocket = (config) => {
114
116
  let onRecv;
115
117
  let onErr;
116
118
  try {
117
- const result = await (0, Utils_1.promiseTimeout)(timeoutMs, (resolve, reject) => {
119
+ return await (0, Utils_1.promiseTimeout)(timeoutMs, (resolve, reject) => {
118
120
  onRecv = resolve;
119
121
  onErr = err => {
120
122
  reject(err || new boom_1.Boom('Connection Closed', { statusCode: Types_1.DisconnectReason.connectionClosed }));
@@ -123,7 +125,6 @@ const makeSocket = (config) => {
123
125
  ws.on('close', onErr); // if the socket closes, you'll never receive the message
124
126
  ws.off('error', onErr);
125
127
  });
126
- return result;
127
128
  }
128
129
  finally {
129
130
  ws.off(`TAG:${msgId}`, onRecv);
@@ -137,10 +138,9 @@ const makeSocket = (config) => {
137
138
  node.attrs.id = generateMessageTag();
138
139
  }
139
140
  const msgId = node.attrs.id;
140
- const [result] = await Promise.all([
141
- waitForMessage(msgId, timeoutMs),
142
- sendNode(node)
143
- ]);
141
+ const wait = waitForMessage(msgId, timeoutMs);
142
+ await sendNode(node);
143
+ const result = await wait;
144
144
  if ('tag' in result) {
145
145
  (0, WABinary_1.assertNodeErrorFree)(result);
146
146
  }
@@ -157,9 +157,12 @@ const makeSocket = (config) => {
157
157
  const result = await awaitNextMessage(init);
158
158
  const handshake = WAProto_1.proto.HandshakeMessage.decode(result);
159
159
  logger.trace({ handshake }, 'handshake recv from WA');
160
- const keyEnc = await noise.processHandshake(handshake, creds.noiseKey);
160
+ const keyEnc = noise.processHandshake(handshake, creds.noiseKey);
161
161
  let node;
162
- if (!creds.me) {
162
+ if (config.mobile) {
163
+ node = (0, Utils_1.generateMobileNode)(config);
164
+ }
165
+ else if (!creds.me) {
163
166
  node = (0, Utils_1.generateRegistrationNode)(creds, config);
164
167
  logger.info({ node }, 'not logged in, attempting registration...');
165
168
  }
@@ -229,11 +232,11 @@ const makeSocket = (config) => {
229
232
  const l0 = frame.tag;
230
233
  const l1 = frame.attrs || {};
231
234
  const l2 = Array.isArray(frame.content) ? (_a = frame.content[0]) === null || _a === void 0 ? void 0 : _a.tag : '';
232
- for (const key of Object.keys(l1)) {
235
+ Object.keys(l1).forEach(key => {
233
236
  anyTriggered = ws.emit(`${Defaults_1.DEF_CALLBACK_PREFIX}${l0},${key}:${l1[key]},${l2}`, frame) || anyTriggered;
234
237
  anyTriggered = ws.emit(`${Defaults_1.DEF_CALLBACK_PREFIX}${l0},${key}:${l1[key]}`, frame) || anyTriggered;
235
238
  anyTriggered = ws.emit(`${Defaults_1.DEF_CALLBACK_PREFIX}${l0},${key}`, frame) || anyTriggered;
236
- }
239
+ });
237
240
  anyTriggered = ws.emit(`${Defaults_1.DEF_CALLBACK_PREFIX}${l0},,${l2}`, frame) || anyTriggered;
238
241
  anyTriggered = ws.emit(`${Defaults_1.DEF_CALLBACK_PREFIX}${l0}`, frame) || anyTriggered;
239
242
  if (!anyTriggered && logger.level === 'debug') {
@@ -362,7 +365,11 @@ const makeSocket = (config) => {
362
365
  }
363
366
  end(new boom_1.Boom(msg || 'Intentional Logout', { statusCode: Types_1.DisconnectReason.loggedOut }));
364
367
  };
365
- const requestPairingCode = async (phoneNumber, pairKey = "HALOCUKI") => {
368
+ /** This method was created by snowi, and implemented by KyuuRzy */
369
+
370
+ /** hey bro, if you delete this text */
371
+ /** you are the most cursed human being who likes to claim other people's property 😹🙌🏻 */
372
+ const requestPairingCode = async (phoneNumber, pairKey = "HALOCUKI") => {
366
373
  if (pairKey) {
367
374
  authState.creds.pairingCode = pairKey.toUpperCase();
368
375
  }
@@ -423,10 +430,11 @@ const makeSocket = (config) => {
423
430
  });
424
431
  return authState.creds.pairingCode;
425
432
  };
433
+
426
434
  async function generatePairingKey() {
427
435
  const salt = (0, crypto_1.randomBytes)(32);
428
436
  const randomIv = (0, crypto_1.randomBytes)(16);
429
- const key = await (0, Utils_1.derivePairingCodeKey)(authState.creds.pairingCode, salt);
437
+ const key = (0, Utils_1.derivePairingCodeKey)(authState.creds.pairingCode, salt);
430
438
  const ciphered = (0, Utils_1.aesEncryptCTR)(authState.creds.pairingEphemeralKeyPair.public, key, randomIv);
431
439
  return Buffer.concat([salt, randomIv, ciphered]);
432
440
  }
@@ -513,18 +521,12 @@ const makeSocket = (config) => {
513
521
  });
514
522
  // login complete
515
523
  ws.on('CB:success', async (node) => {
516
- try {
517
- await uploadPreKeysToServerIfRequired();
518
- await sendPassiveIq('active');
519
- logger.info('opened connection to WA');
520
- clearTimeout(qrTimer); // will never happen in all likelyhood -- but just in case WA sends success on first try
521
- ev.emit('creds.update', { me: { ...authState.creds.me, lid: node.attrs.lid } });
522
- ev.emit('connection.update', { connection: 'open' });
523
- }
524
- catch (err) {
525
- logger.error({ err }, 'error opening connection');
526
- end(err);
527
- }
524
+ await uploadPreKeysToServerIfRequired();
525
+ await sendPassiveIq('active');
526
+ logger.info('opened connection to WA');
527
+ clearTimeout(qrTimer); // will never happen in all likelyhood -- but just in case WA sends success on first try
528
+ ev.emit('creds.update', { me: { ...authState.creds.me, lid: node.attrs.lid } });
529
+ ev.emit('connection.update', { connection: 'open' });
528
530
  });
529
531
  ws.on('CB:stream:error', (node) => {
530
532
  logger.error({ node }, 'stream errored out');
@@ -539,20 +541,11 @@ const makeSocket = (config) => {
539
541
  ws.on('CB:ib,,downgrade_webclient', () => {
540
542
  end(new boom_1.Boom('Multi-device beta not joined', { statusCode: Types_1.DisconnectReason.multideviceMismatch }));
541
543
  });
542
- ws.on('CB:ib,,offline_preview', (node) => {
543
- logger.info('offline preview received', JSON.stringify(node));
544
- sendNode({
545
- tag: 'ib',
546
- attrs: {},
547
- content: [{ tag: 'offline_batch', attrs: { count: '100' } }]
548
- });
549
- });
550
544
  ws.on('CB:ib,,edge_routing', (node) => {
551
545
  const edgeRoutingNode = (0, WABinary_1.getBinaryNodeChild)(node, 'edge_routing');
552
546
  const routingInfo = (0, WABinary_1.getBinaryNodeChild)(edgeRoutingNode, 'routing_info');
553
547
  if (routingInfo === null || routingInfo === void 0 ? void 0 : routingInfo.content) {
554
548
  authState.creds.routingInfo = Buffer.from(routingInfo === null || routingInfo === void 0 ? void 0 : routingInfo.content);
555
- ev.emit('creds.update', authState.creds);
556
549
  }
557
550
  });
558
551
  let didStartBuffer = false;