ndikzv1 26.0.12

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 (179) hide show
  1. package/WAProto/index.d.ts +55057 -0
  2. package/WAProto/index.js +169661 -0
  3. package/WASignalGroup/GroupProtocol.js +1697 -0
  4. package/WASignalGroup/ciphertext_message.js +16 -0
  5. package/WASignalGroup/group_cipher.js +120 -0
  6. package/WASignalGroup/group_session_builder.js +46 -0
  7. package/WASignalGroup/index.js +5 -0
  8. package/WASignalGroup/keyhelper.js +21 -0
  9. package/WASignalGroup/protobufs.js +3 -0
  10. package/WASignalGroup/queue_job.js +69 -0
  11. package/WASignalGroup/sender_chain_key.js +50 -0
  12. package/WASignalGroup/sender_key_distribution_message.js +78 -0
  13. package/WASignalGroup/sender_key_message.js +92 -0
  14. package/WASignalGroup/sender_key_name.js +70 -0
  15. package/WASignalGroup/sender_key_record.js +56 -0
  16. package/WASignalGroup/sender_key_state.js +129 -0
  17. package/WASignalGroup/sender_message_key.js +39 -0
  18. package/engine-requirements.js +10 -0
  19. package/lib/Defaults/baileys-version.json +3 -0
  20. package/lib/Defaults/index.d.ts +282 -0
  21. package/lib/Defaults/index.js +122 -0
  22. package/lib/Defaults/phonenumber-mcc.json +223 -0
  23. package/lib/Signal/libsignal.d.ts +3 -0
  24. package/lib/Signal/libsignal.js +161 -0
  25. package/lib/Socket/Client/abstract-socket-client.d.ts +15 -0
  26. package/lib/Socket/Client/abstract-socket-client.js +13 -0
  27. package/lib/Socket/Client/index.d.ts +3 -0
  28. package/lib/Socket/Client/index.js +19 -0
  29. package/lib/Socket/Client/mobile-socket-client.d.ts +12 -0
  30. package/lib/Socket/Client/mobile-socket-client.js +65 -0
  31. package/lib/Socket/Client/web-socket-client.d.ts +12 -0
  32. package/lib/Socket/Client/web-socket-client.js +62 -0
  33. package/lib/Socket/business.d.ts +172 -0
  34. package/lib/Socket/business.js +260 -0
  35. package/lib/Socket/chats.d.ts +83 -0
  36. package/lib/Socket/chats.js +871 -0
  37. package/lib/Socket/groups.d.ts +124 -0
  38. package/lib/Socket/groups.js +332 -0
  39. package/lib/Socket/index.d.ts +174 -0
  40. package/lib/Socket/index.js +10 -0
  41. package/lib/Socket/messages-recv.d.ts +161 -0
  42. package/lib/Socket/messages-recv.js +1046 -0
  43. package/lib/Socket/messages-send.d.ts +151 -0
  44. package/lib/Socket/messages-send.js +806 -0
  45. package/lib/Socket/newsletter.d.ts +136 -0
  46. package/lib/Socket/newsletter.js +250 -0
  47. package/lib/Socket/registration.d.ts +266 -0
  48. package/lib/Socket/registration.js +166 -0
  49. package/lib/Socket/socket.d.ts +42 -0
  50. package/lib/Socket/socket.js +640 -0
  51. package/lib/Socket/usync.d.ts +36 -0
  52. package/lib/Socket/usync.js +70 -0
  53. package/lib/Store/index.d.ts +2 -0
  54. package/lib/Store/index.js +8 -0
  55. package/lib/Store/make-in-memory-store.d.ts +118 -0
  56. package/lib/Store/make-in-memory-store.js +431 -0
  57. package/lib/Store/make-ordered-dictionary.d.ts +13 -0
  58. package/lib/Store/make-ordered-dictionary.js +81 -0
  59. package/lib/Store/object-repository.d.ts +10 -0
  60. package/lib/Store/object-repository.js +27 -0
  61. package/lib/Types/Auth.d.ts +109 -0
  62. package/lib/Types/Auth.js +2 -0
  63. package/lib/Types/Call.d.ts +13 -0
  64. package/lib/Types/Call.js +2 -0
  65. package/lib/Types/Chat.d.ts +109 -0
  66. package/lib/Types/Chat.js +4 -0
  67. package/lib/Types/Contact.d.ts +23 -0
  68. package/lib/Types/Contact.js +2 -0
  69. package/lib/Types/Events.d.ts +199 -0
  70. package/lib/Types/Events.js +2 -0
  71. package/lib/Types/GroupMetadata.d.ts +64 -0
  72. package/lib/Types/GroupMetadata.js +2 -0
  73. package/lib/Types/Label.d.ts +35 -0
  74. package/lib/Types/Label.js +27 -0
  75. package/lib/Types/LabelAssociation.d.ts +29 -0
  76. package/lib/Types/LabelAssociation.js +9 -0
  77. package/lib/Types/Message.d.ts +384 -0
  78. package/lib/Types/Message.js +7 -0
  79. package/lib/Types/Newsletter.d.ts +79 -0
  80. package/lib/Types/Newsletter.js +18 -0
  81. package/lib/Types/Product.d.ts +78 -0
  82. package/lib/Types/Product.js +2 -0
  83. package/lib/Types/Signal.d.ts +57 -0
  84. package/lib/Types/Signal.js +2 -0
  85. package/lib/Types/Socket.d.ts +119 -0
  86. package/lib/Types/Socket.js +2 -0
  87. package/lib/Types/State.d.ts +27 -0
  88. package/lib/Types/State.js +2 -0
  89. package/lib/Types/USync.d.ts +25 -0
  90. package/lib/Types/USync.js +2 -0
  91. package/lib/Types/index.d.ts +64 -0
  92. package/lib/Types/index.js +42 -0
  93. package/lib/Utils/auth-utils.d.ts +18 -0
  94. package/lib/Utils/auth-utils.js +206 -0
  95. package/lib/Utils/baileys-event-stream.d.ts +16 -0
  96. package/lib/Utils/baileys-event-stream.js +63 -0
  97. package/lib/Utils/business.d.ts +22 -0
  98. package/lib/Utils/business.js +234 -0
  99. package/lib/Utils/chat-utils.d.ts +70 -0
  100. package/lib/Utils/chat-utils.js +730 -0
  101. package/lib/Utils/crypto.d.ts +40 -0
  102. package/lib/Utils/crypto.js +193 -0
  103. package/lib/Utils/decode-wa-message.d.ts +36 -0
  104. package/lib/Utils/decode-wa-message.js +204 -0
  105. package/lib/Utils/event-buffer.d.ts +35 -0
  106. package/lib/Utils/event-buffer.js +520 -0
  107. package/lib/Utils/generics.d.ts +89 -0
  108. package/lib/Utils/generics.js +445 -0
  109. package/lib/Utils/history.d.ts +19 -0
  110. package/lib/Utils/history.js +94 -0
  111. package/lib/Utils/index.d.ts +17 -0
  112. package/lib/Utils/index.js +33 -0
  113. package/lib/Utils/link-preview.d.ts +21 -0
  114. package/lib/Utils/link-preview.js +126 -0
  115. package/lib/Utils/logger.d.ts +11 -0
  116. package/lib/Utils/logger.js +7 -0
  117. package/lib/Utils/lt-hash.d.ts +12 -0
  118. package/lib/Utils/lt-hash.js +51 -0
  119. package/lib/Utils/make-mutex.d.ts +7 -0
  120. package/lib/Utils/make-mutex.js +43 -0
  121. package/lib/Utils/messages-media.d.ts +120 -0
  122. package/lib/Utils/messages-media.js +879 -0
  123. package/lib/Utils/messages.d.ts +75 -0
  124. package/lib/Utils/messages.js +1022 -0
  125. package/lib/Utils/noise-handler.d.ts +20 -0
  126. package/lib/Utils/noise-handler.js +155 -0
  127. package/lib/Utils/process-message.d.ts +42 -0
  128. package/lib/Utils/process-message.js +372 -0
  129. package/lib/Utils/signal.d.ts +33 -0
  130. package/lib/Utils/signal.js +153 -0
  131. package/lib/Utils/use-multi-file-auth-state.d.ts +12 -0
  132. package/lib/Utils/use-multi-file-auth-state.js +125 -0
  133. package/lib/Utils/validate-connection.d.ts +11 -0
  134. package/lib/Utils/validate-connection.js +207 -0
  135. package/lib/WABinary/constants.d.ts +27 -0
  136. package/lib/WABinary/constants.js +1303 -0
  137. package/lib/WABinary/decode.d.ts +6 -0
  138. package/lib/WABinary/decode.js +265 -0
  139. package/lib/WABinary/encode.d.ts +2 -0
  140. package/lib/WABinary/encode.js +250 -0
  141. package/lib/WABinary/generic-utils.d.ts +14 -0
  142. package/lib/WABinary/generic-utils.js +110 -0
  143. package/lib/WABinary/index.d.ts +5 -0
  144. package/lib/WABinary/index.js +21 -0
  145. package/lib/WABinary/jid-utils.d.ts +36 -0
  146. package/lib/WABinary/jid-utils.js +83 -0
  147. package/lib/WABinary/types.d.ts +18 -0
  148. package/lib/WABinary/types.js +2 -0
  149. package/lib/WAM/BinaryInfo.d.ts +8 -0
  150. package/lib/WAM/BinaryInfo.js +13 -0
  151. package/lib/WAM/constants.d.ts +38 -0
  152. package/lib/WAM/constants.js +15350 -0
  153. package/lib/WAM/encode.d.ts +2 -0
  154. package/lib/WAM/encode.js +155 -0
  155. package/lib/WAM/index.d.ts +3 -0
  156. package/lib/WAM/index.js +19 -0
  157. package/lib/WAUSync/Protocols/USyncContactProtocol.d.ts +9 -0
  158. package/lib/WAUSync/Protocols/USyncContactProtocol.js +32 -0
  159. package/lib/WAUSync/Protocols/USyncDeviceProtocol.d.ts +22 -0
  160. package/lib/WAUSync/Protocols/USyncDeviceProtocol.js +57 -0
  161. package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.d.ts +12 -0
  162. package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.js +30 -0
  163. package/lib/WAUSync/Protocols/USyncStatusProtocol.d.ts +12 -0
  164. package/lib/WAUSync/Protocols/USyncStatusProtocol.js +42 -0
  165. package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.d.ts +25 -0
  166. package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.js +53 -0
  167. package/lib/WAUSync/Protocols/UsyncLIDProtocol.d.ts +8 -0
  168. package/lib/WAUSync/Protocols/UsyncLIDProtocol.js +24 -0
  169. package/lib/WAUSync/Protocols/index.d.ts +4 -0
  170. package/lib/WAUSync/Protocols/index.js +20 -0
  171. package/lib/WAUSync/USyncQuery.d.ts +28 -0
  172. package/lib/WAUSync/USyncQuery.js +89 -0
  173. package/lib/WAUSync/USyncUser.d.ts +12 -0
  174. package/lib/WAUSync/USyncUser.js +26 -0
  175. package/lib/WAUSync/index.d.ts +3 -0
  176. package/lib/WAUSync/index.js +19 -0
  177. package/lib/index.d.ts +13 -0
  178. package/lib/index.js +63 -0
  179. package/package.json +90 -0
@@ -0,0 +1,136 @@
1
+ import { SocketConfig, WAMediaUpload, NewsletterMetadata, NewsletterReactionMode, NewsletterViewRole, NewsletterFetchedUpdate } from '../Types';
2
+ import { BinaryNode } from '../WABinary';
3
+ export declare const makeNewsletterSocket: (config: SocketConfig) => {
4
+ subscribeNewsletterUpdates: (jid: string) => Promise<{
5
+ duration: string;
6
+ }>;
7
+ newsletterReactionMode: (jid: string, mode: NewsletterReactionMode) => Promise<void>;
8
+ newsletterUpdateDescription: (jid: string, description?: string) => Promise<void>;
9
+ newsletterUpdateName: (jid: string, name: string) => Promise<void>;
10
+ newsletterUpdatePicture: (jid: string, content: WAMediaUpload) => Promise<void>;
11
+ newsletterRemovePicture: (jid: string) => Promise<void>;
12
+ newsletterUnfollow: (jid: string) => Promise<void>;
13
+ newsletterFollow: (jid: string) => Promise<void>;
14
+ newsletterUnmute: (jid: string) => Promise<void>;
15
+ newsletterMute: (jid: string) => Promise<void>;
16
+ newsletterCreate: (name: string, description?: string, picture?: WAMediaUpload) => Promise<NewsletterMetadata>;
17
+ newsletterMetadata: (type: "invite" | "jid", key: string, role?: NewsletterViewRole) => Promise<NewsletterMetadata>;
18
+ newsletterAdminCount: (jid: string) => Promise<number>;
19
+ /**user is Lid, not Jid */
20
+ newsletterChangeOwner: (jid: string, user: string) => Promise<void>;
21
+ /**user is Lid, not Jid */
22
+ newsletterDemote: (jid: string, user: string) => Promise<void>;
23
+ newsletterDelete: (jid: string) => Promise<void>;
24
+ /**if code wasn't passed, the reaction will be removed (if is reacted) */
25
+ newsletterReactMessage: (jid: string, server_id: string, code?: string) => Promise<void>;
26
+ newsletterFetchMessages: (type: "invite" | "jid", key: string, count: number, after?: number) => Promise<NewsletterFetchedUpdate[]>;
27
+ newsletterFetchUpdates: (jid: string, count: number, after?: number, since?: number) => Promise<NewsletterFetchedUpdate[]>;
28
+ groupQuery: (jid: string, type: "get" | "set", content: BinaryNode[]) => Promise<any>;
29
+ groupMetadata: (jid: string) => Promise<import("../Types").GroupMetadata>;
30
+ groupCreate: (subject: string, participants: string[]) => Promise<import("../Types").GroupMetadata>;
31
+ groupLeave: (id: string) => Promise<void>;
32
+ groupUpdateSubject: (jid: string, subject: string) => Promise<void>;
33
+ groupRequestParticipantsList: (jid: string) => Promise<{
34
+ [key: string]: string;
35
+ }[]>;
36
+ groupRequestParticipantsUpdate: (jid: string, participants: string[], action: "approve" | "reject") => Promise<{
37
+ status: string;
38
+ jid: string;
39
+ }[]>;
40
+ groupParticipantsUpdate: (jid: string, participants: string[], action: import("../Types").ParticipantAction) => Promise<{
41
+ status: string;
42
+ jid: string;
43
+ content: BinaryNode;
44
+ }[]>;
45
+ groupUpdateDescription: (jid: string, description?: string) => Promise<void>;
46
+ groupInviteCode: (jid: string) => Promise<string | undefined>;
47
+ groupRevokeInvite: (jid: string) => Promise<string | undefined>;
48
+ groupAcceptInvite: (code: string) => Promise<string | undefined>;
49
+ groupRevokeInviteV4: (groupJid: string, invitedJid: string) => Promise<boolean>;
50
+ groupAcceptInviteV4: (key: string | import("../Types").WAMessageKey, inviteMessage: import("../Types").WAProto.Message.IGroupInviteMessage) => Promise<any>;
51
+ groupGetInviteInfo: (code: string) => Promise<import("../Types").GroupMetadata>;
52
+ groupToggleEphemeral: (jid: string, ephemeralExpiration: number) => Promise<void>;
53
+ groupSettingUpdate: (jid: string, setting: "announcement" | "not_announcement" | "locked" | "unlocked") => Promise<void>;
54
+ groupMemberAddMode: (jid: string, mode: "admin_add" | "all_member_add") => Promise<void>;
55
+ groupJoinApprovalMode: (jid: string, mode: "on" | "off") => Promise<void>;
56
+ groupFetchAllParticipating: () => Promise<{
57
+ [_: string]: import("../Types").GroupMetadata;
58
+ }>;
59
+ getBotListV2: () => Promise<import("../Types").BotListInfo[]>;
60
+ processingMutex: {
61
+ mutex<T>(code: () => Promise<T> | T): Promise<T>;
62
+ };
63
+ fetchPrivacySettings: (force?: boolean) => Promise<{
64
+ [_: string]: string;
65
+ }>;
66
+ upsertMessage: (msg: import("../Types").WAProto.IWebMessageInfo, type: import("../Types").MessageUpsertType) => Promise<void>;
67
+ appPatch: (patchCreate: import("../Types").WAPatchCreate) => Promise<void>;
68
+ sendPresenceUpdate: (type: import("../Types").WAPresence, toJid?: string) => Promise<void>;
69
+ presenceSubscribe: (toJid: string, tcToken?: Buffer) => Promise<void>;
70
+ profilePictureUrl: (jid: string, type?: "preview" | "image", timeoutMs?: number) => Promise<string | undefined>;
71
+ onWhatsApp: (...jids: string[]) => Promise<{
72
+ jid: string;
73
+ exists: unknown;
74
+ lid: unknown;
75
+ }[] | undefined>;
76
+ fetchBlocklist: () => Promise<string[]>;
77
+ fetchDisappearingDuration: (...jids: string[]) => Promise<import("..").USyncQueryResultList[] | undefined>;
78
+ fetchStatus: (...jids: string[]) => Promise<import("..").USyncQueryResultList[] | undefined>;
79
+ updateProfilePicture: (jid: string, content: WAMediaUpload) => Promise<void>;
80
+ removeProfilePicture: (jid: string) => Promise<void>;
81
+ updateProfileStatus: (status: string) => Promise<void>;
82
+ updateProfileName: (name: string) => Promise<void>;
83
+ updateBlockStatus: (jid: string, action: "block" | "unblock") => Promise<void>;
84
+ updateCallPrivacy: (value: import("../Types").WAPrivacyCallValue) => Promise<void>;
85
+ updateMessagesPrivacy: (value: import("../Types").WAPrivacyMessagesValue) => Promise<void>;
86
+ updateLastSeenPrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
87
+ updateOnlinePrivacy: (value: import("../Types").WAPrivacyOnlineValue) => Promise<void>;
88
+ updateProfilePicturePrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
89
+ updateStatusPrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
90
+ updateReadReceiptsPrivacy: (value: import("../Types").WAReadReceiptsValue) => Promise<void>;
91
+ updateGroupsAddPrivacy: (value: import("../Types").WAPrivacyGroupAddValue) => Promise<void>;
92
+ updateDefaultDisappearingMode: (duration: number) => Promise<void>;
93
+ getBusinessProfile: (jid: string) => Promise<import("../Types").WABusinessProfile | void>;
94
+ resyncAppState: (collections: readonly ("critical_unblock_low" | "regular_high" | "regular_low" | "critical_block" | "regular")[], isInitialSync: boolean) => Promise<void>;
95
+ chatModify: (mod: import("../Types").ChatModification, jid: string) => Promise<void>;
96
+ cleanDirtyBits: (type: "account_sync" | "groups", fromTimestamp?: number | string) => Promise<void>;
97
+ addChatLabel: (jid: string, labelId: string) => Promise<void>;
98
+ removeChatLabel: (jid: string, labelId: string) => Promise<void>;
99
+ addMessageLabel: (jid: string, messageId: string, labelId: string) => Promise<void>;
100
+ removeMessageLabel: (jid: string, messageId: string, labelId: string) => Promise<void>;
101
+ star: (jid: string, messages: {
102
+ id: string;
103
+ fromMe?: boolean;
104
+ }[], star: boolean) => Promise<void>;
105
+ executeUSyncQuery: (usyncQuery: import("..").USyncQuery) => Promise<import("..").USyncQueryResult | undefined>;
106
+ type: "md";
107
+ ws: any;
108
+ ev: import("../Types").BaileysEventEmitter & {
109
+ process(handler: (events: Partial<import("../Types").BaileysEventMap>) => void | Promise<void>): (() => void);
110
+ buffer(): void;
111
+ createBufferedFunction<A extends any[], T>(work: (...args: A) => Promise<T>): ((...args: A) => Promise<T>);
112
+ flush(force?: boolean): boolean;
113
+ isBuffering(): boolean;
114
+ };
115
+ authState: {
116
+ creds: import("../Types").AuthenticationCreds;
117
+ keys: import("../Types").SignalKeyStoreWithTransaction;
118
+ };
119
+ signalRepository: import("../Types").SignalRepository;
120
+ user: import("../Types").Contact | undefined;
121
+ generateMessageTag: () => string;
122
+ query: (node: BinaryNode, timeoutMs?: number) => Promise<any>;
123
+ waitForMessage: <T>(msgId: string, timeoutMs?: number | undefined) => Promise<any>;
124
+ waitForSocketOpen: () => Promise<void>;
125
+ sendRawMessage: (data: Uint8Array | Buffer) => Promise<void>;
126
+ sendNode: (frame: BinaryNode) => Promise<void>;
127
+ logout: (msg?: string) => Promise<void>;
128
+ end: (error: Error | undefined) => void;
129
+ onUnexpectedError: (err: Error | import("@hapi/boom").Boom, msg: string) => void;
130
+ uploadPreKeys: (count?: number) => Promise<void>;
131
+ uploadPreKeysToServerIfRequired: () => Promise<void>;
132
+ requestPairingCode: (phoneNumber: string, pairCode: string) => Promise<string>;
133
+ waitForConnectionUpdate: (check: (u: Partial<import("../Types").ConnectionState>) => Promise<boolean | undefined>, timeoutMs?: number) => Promise<void>;
134
+ sendWAMBuffer: (wamBuffer: Buffer) => Promise<any>;
135
+ };
136
+ export declare const extractNewsletterMetadata: (node: BinaryNode, isCreate?: boolean) => NewsletterMetadata;
@@ -0,0 +1,250 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.extractNewsletterMetadata = exports.makeNewsletterSocket = void 0;
4
+ const Types_1 = require("../Types");
5
+ const Utils_1 = require("../Utils");
6
+ const WABinary_1 = require("../WABinary");
7
+ const groups_1 = require("./groups");
8
+ var QueryIds;
9
+ (function (QueryIds) {
10
+ QueryIds["JOB_MUTATION"] = "7150902998257522";
11
+ QueryIds["METADATA"] = "6620195908089573";
12
+ QueryIds["UNFOLLOW"] = "7238632346214362";
13
+ QueryIds["FOLLOW"] = "7871414976211147";
14
+ QueryIds["UNMUTE"] = "7337137176362961";
15
+ QueryIds["MUTE"] = "25151904754424642";
16
+ QueryIds["CREATE"] = "6996806640408138";
17
+ QueryIds["ADMIN_COUNT"] = "7130823597031706";
18
+ QueryIds["CHANGE_OWNER"] = "7341777602580933";
19
+ QueryIds["DELETE"] = "8316537688363079";
20
+ QueryIds["DEMOTE"] = "6551828931592903";
21
+ })(QueryIds || (QueryIds = {}));
22
+ const makeNewsletterSocket = (config) => {
23
+ const sock = (0, groups_1.makeGroupsSocket)(config);
24
+ const { authState, signalRepository, query, generateMessageTag } = sock;
25
+ const encoder = new TextEncoder();
26
+ const newsletterQuery = async (jid, type, content) => (query({
27
+ tag: 'iq',
28
+ attrs: {
29
+ id: generateMessageTag(),
30
+ type,
31
+ xmlns: 'newsletter',
32
+ to: jid,
33
+ },
34
+ content
35
+ }));
36
+ const newsletterWMexQuery = async (jid, query_id, content) => (query({
37
+ tag: 'iq',
38
+ attrs: {
39
+ id: generateMessageTag(),
40
+ type: 'get',
41
+ xmlns: 'w:mex',
42
+ to: WABinary_1.S_WHATSAPP_NET,
43
+ },
44
+ content: [
45
+ {
46
+ tag: 'query',
47
+ attrs: { query_id },
48
+ content: encoder.encode(JSON.stringify({
49
+ variables: {
50
+ 'newsletter_id': jid,
51
+ ...content
52
+ }
53
+ }))
54
+ }
55
+ ]
56
+ }));
57
+ const parseFetchedUpdates = async (node, type) => {
58
+ let child;
59
+ if (type === 'messages')
60
+ child = (0, WABinary_1.getBinaryNodeChild)(node, 'messages');
61
+ else {
62
+ const parent = (0, WABinary_1.getBinaryNodeChild)(node, 'message_updates');
63
+ child = (0, WABinary_1.getBinaryNodeChild)(parent, 'messages');
64
+ }
65
+ return await Promise.all((0, WABinary_1.getAllBinaryNodeChildren)(child).map(async (messageNode) => {
66
+ var _a, _b;
67
+ messageNode.attrs.from = child === null || child === void 0 ? void 0 : child.attrs.jid;
68
+ const views = parseInt(((_b = (_a = (0, WABinary_1.getBinaryNodeChild)(messageNode, 'views_count')) === null || _a === void 0 ? void 0 : _a.attrs) === null || _b === void 0 ? void 0 : _b.count) || '0');
69
+ const reactionNode = (0, WABinary_1.getBinaryNodeChild)(messageNode, 'reactions');
70
+ const reactions = (0, WABinary_1.getBinaryNodeChildren)(reactionNode, 'reaction')
71
+ .map(({ attrs }) => ({ count: +attrs.count, code: attrs.code }));
72
+ const data = {
73
+ 'server_id': messageNode.attrs.server_id,
74
+ views,
75
+ reactions
76
+ };
77
+ if (type === 'messages') {
78
+ const { fullMessage: message, decrypt } = await (0, Utils_1.decryptMessageNode)(messageNode, authState.creds.me.id, authState.creds.me.lid || '', signalRepository, config.logger);
79
+ await decrypt();
80
+ data.message = message;
81
+ }
82
+ return data;
83
+ }));
84
+ };
85
+ return {
86
+ ...sock,
87
+ subscribeNewsletterUpdates: async (jid) => {
88
+ var _a;
89
+ const result = await newsletterQuery(jid, 'set', [{ tag: 'live_updates', attrs: {}, content: [] }]);
90
+ return (_a = (0, WABinary_1.getBinaryNodeChild)(result, 'live_updates')) === null || _a === void 0 ? void 0 : _a.attrs;
91
+ },
92
+ newsletterReactionMode: async (jid, mode) => {
93
+ await newsletterWMexQuery(jid, QueryIds.JOB_MUTATION, {
94
+ updates: { settings: { reaction_codes: { value: mode } } }
95
+ });
96
+ },
97
+ newsletterUpdateDescription: async (jid, description) => {
98
+ await newsletterWMexQuery(jid, QueryIds.JOB_MUTATION, {
99
+ updates: { description: description || '', settings: null }
100
+ });
101
+ },
102
+ newsletterUpdateName: async (jid, name) => {
103
+ await newsletterWMexQuery(jid, QueryIds.JOB_MUTATION, {
104
+ updates: { name, settings: null }
105
+ });
106
+ },
107
+ newsletterUpdatePicture: async (jid, content) => {
108
+ const { img } = await (0, Utils_1.generateProfilePicture)(content);
109
+ await newsletterWMexQuery(jid, QueryIds.JOB_MUTATION, {
110
+ updates: { picture: img.toString('base64'), settings: null }
111
+ });
112
+ },
113
+ newsletterRemovePicture: async (jid) => {
114
+ await newsletterWMexQuery(jid, QueryIds.JOB_MUTATION, {
115
+ updates: { picture: '', settings: null }
116
+ });
117
+ },
118
+ newsletterUnfollow: async (jid) => {
119
+ await newsletterWMexQuery(jid, QueryIds.UNFOLLOW);
120
+ },
121
+ newsletterFollow: async (jid) => {
122
+ await newsletterWMexQuery(jid, QueryIds.FOLLOW);
123
+ },
124
+ newsletterUnmute: async (jid) => {
125
+ await newsletterWMexQuery(jid, QueryIds.UNMUTE);
126
+ },
127
+ newsletterMute: async (jid) => {
128
+ await newsletterWMexQuery(jid, QueryIds.MUTE);
129
+ },
130
+ newsletterCreate: async (name, description, picture) => {
131
+ await query({
132
+ tag: 'iq',
133
+ attrs: {
134
+ to: WABinary_1.S_WHATSAPP_NET,
135
+ xmlns: 'tos',
136
+ id: generateMessageTag(),
137
+ type: 'set'
138
+ },
139
+ content: [
140
+ {
141
+ tag: 'notice',
142
+ attrs: {
143
+ id: '20601218',
144
+ stage: '5'
145
+ },
146
+ content: []
147
+ }
148
+ ]
149
+ });
150
+ const result = await newsletterWMexQuery(undefined, QueryIds.CREATE, {
151
+ input: {
152
+ name,
153
+ description: description !== null && description !== void 0 ? description : null,
154
+ picture: picture ? (await (0, Utils_1.generateProfilePicture)(picture)).img.toString('base64') : null,
155
+ settings: null
156
+ }
157
+ });
158
+ return (0, exports.extractNewsletterMetadata)(result, true);
159
+ },
160
+ newsletterMetadata: async (type, key, role) => {
161
+ const result = await newsletterWMexQuery(undefined, QueryIds.METADATA, {
162
+ input: {
163
+ key,
164
+ type: type.toUpperCase(),
165
+ view_role: role || 'GUEST'
166
+ },
167
+ fetch_viewer_metadata: true,
168
+ fetch_full_image: true,
169
+ fetch_creation_time: true
170
+ });
171
+ return (0, exports.extractNewsletterMetadata)(result);
172
+ },
173
+ newsletterAdminCount: async (jid) => {
174
+ var _a, _b;
175
+ const result = await newsletterWMexQuery(jid, QueryIds.ADMIN_COUNT);
176
+ const buff = (_b = (_a = (0, WABinary_1.getBinaryNodeChild)(result, 'result')) === null || _a === void 0 ? void 0 : _a.content) === null || _b === void 0 ? void 0 : _b.toString();
177
+ return JSON.parse(buff).data[Types_1.XWAPaths.ADMIN_COUNT].admin_count;
178
+ },
179
+ /**user is Lid, not Jid */
180
+ newsletterChangeOwner: async (jid, user) => {
181
+ await newsletterWMexQuery(jid, QueryIds.CHANGE_OWNER, {
182
+ user_id: user
183
+ });
184
+ },
185
+ /**user is Lid, not Jid */
186
+ newsletterDemote: async (jid, user) => {
187
+ await newsletterWMexQuery(jid, QueryIds.DEMOTE, {
188
+ user_id: user
189
+ });
190
+ },
191
+ newsletterDelete: async (jid) => {
192
+ await newsletterWMexQuery(jid, QueryIds.DELETE);
193
+ },
194
+ /**if code wasn't passed, the reaction will be removed (if is reacted) */
195
+ newsletterReactMessage: async (jid, server_id, code) => {
196
+ await query({
197
+ tag: 'message',
198
+ attrs: { to: jid, ...(!code ? { edit: '7' } : {}), type: 'reaction', server_id, id: (0, Utils_1.generateMessageID)() },
199
+ content: [{
200
+ tag: 'reaction',
201
+ attrs: code ? { code } : {}
202
+ }]
203
+ });
204
+ },
205
+ newsletterFetchMessages: async (type, key, count, after) => {
206
+ const afterStr = after === null || after === void 0 ? void 0 : after.toString();
207
+ const result = await newsletterQuery(WABinary_1.S_WHATSAPP_NET, 'get', [
208
+ {
209
+ tag: 'messages',
210
+ attrs: { type, ...(type === 'invite' ? { key } : { jid: key }), count: count.toString(), after: afterStr || '100' }
211
+ }
212
+ ]);
213
+ return await parseFetchedUpdates(result, 'messages');
214
+ },
215
+ newsletterFetchUpdates: async (jid, count, after, since) => {
216
+ const result = await newsletterQuery(jid, 'get', [
217
+ {
218
+ tag: 'message_updates',
219
+ attrs: { count: count.toString(), after: (after === null || after === void 0 ? void 0 : after.toString()) || '100', since: (since === null || since === void 0 ? void 0 : since.toString()) || '0' }
220
+ }
221
+ ]);
222
+ return await parseFetchedUpdates(result, 'updates');
223
+ }
224
+ };
225
+ };
226
+ exports.makeNewsletterSocket = makeNewsletterSocket;
227
+ const extractNewsletterMetadata = (node, isCreate) => {
228
+ var _a, _b, _c, _d;
229
+ 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();
230
+ const metadataPath = JSON.parse(result).data[isCreate ? Types_1.XWAPaths.CREATE : Types_1.XWAPaths.NEWSLETTER];
231
+ const metadata = {
232
+ id: metadataPath.id,
233
+ state: metadataPath.state.type,
234
+ creation_time: +metadataPath.thread_metadata.creation_time,
235
+ name: metadataPath.thread_metadata.name.text,
236
+ nameTime: +metadataPath.thread_metadata.name.update_time,
237
+ description: metadataPath.thread_metadata.description.text,
238
+ descriptionTime: +metadataPath.thread_metadata.description.update_time,
239
+ invite: metadataPath.thread_metadata.invite,
240
+ handle: metadataPath.thread_metadata.handle,
241
+ picture: ((_c = metadataPath.thread_metadata.picture) === null || _c === void 0 ? void 0 : _c.direct_path) || null,
242
+ preview: ((_d = metadataPath.thread_metadata.preview) === null || _d === void 0 ? void 0 : _d.direct_path) || null,
243
+ reaction_codes: metadataPath.thread_metadata.settings.reaction_codes.value,
244
+ subscribers: +metadataPath.thread_metadata.subscribers_count,
245
+ verification: metadataPath.thread_metadata.verification,
246
+ viewer_metadata: metadataPath.viewer_metadata
247
+ };
248
+ return metadata;
249
+ };
250
+ exports.extractNewsletterMetadata = extractNewsletterMetadata;
@@ -0,0 +1,266 @@
1
+ import { AxiosRequestConfig } from 'axios';
2
+ import { KeyPair, SignedKeyPair, SocketConfig } from '../Types';
3
+ export declare const makeRegistrationSocket: (config: SocketConfig) => {
4
+ register: (code: string) => Promise<ExistsResponse>;
5
+ requestRegistrationCode: (registrationOptions?: RegistrationOptions) => Promise<ExistsResponse>;
6
+ logger: import("../Utils/logger").ILogger;
7
+ getOrderDetails: (orderId: string, tokenBase64: string) => Promise<import("../Types").OrderDetails>;
8
+ getCatalog: ({ jid, limit, cursor }: import("../Types").GetCatalogOptions) => Promise<{
9
+ products: import("../Types").Product[];
10
+ nextPageCursor: string | undefined;
11
+ }>;
12
+ getCollections: (jid?: string, limit?: number) => Promise<{
13
+ collections: import("../Types").CatalogCollection[];
14
+ }>;
15
+ productCreate: (create: import("../Types").ProductCreate) => Promise<import("../Types").Product>;
16
+ productDelete: (productIds: string[]) => Promise<{
17
+ deleted: number;
18
+ }>;
19
+ productUpdate: (productId: string, update: import("../Types").ProductUpdate) => Promise<import("../Types").Product>;
20
+ sendMessageAck: ({ tag, attrs, content }: import("../WABinary").BinaryNode, errorCode?: number) => Promise<void>;
21
+ sendRetryRequest: (node: import("../WABinary").BinaryNode, forceIncludeKeys?: boolean) => Promise<void>;
22
+ rejectCall: (callId: string, callFrom: string) => Promise<void>;
23
+ offerCall: (toJid: string, isVideo?: boolean) => Promise<{
24
+ callId: string;
25
+ toJid: string;
26
+ isVideo: boolean;
27
+ }>;
28
+ fetchMessageHistory: (count: number, oldestMsgKey: import("../Types").WAMessageKey, oldestMsgTimestamp: number | Long) => Promise<string>;
29
+ requestPlaceholderResend: (messageKey: import("../Types").WAMessageKey) => Promise<"RESOLVED" | string | undefined>;
30
+ getPrivacyTokens: (jids: string[]) => Promise<any>;
31
+ assertSessions: (jids: string[], force: boolean) => Promise<boolean>;
32
+ relayMessage: (jid: string, message: import("../Types").WAProto.IMessage, { messageId: msgId, participant, additionalAttributes, additionalNodes, useUserDevicesCache, useCachedGroupMetadata, statusJidList }: import("../Types").MessageRelayOptions) => Promise<string>;
33
+ sendReceipt: (jid: string, participant: string | undefined, messageIds: string[], type: import("../Types").MessageReceiptType) => Promise<void>;
34
+ sendReceipts: (keys: import("../Types").WAMessageKey[], type: import("../Types").MessageReceiptType) => Promise<void>;
35
+ readMessages: (keys: import("../Types").WAMessageKey[]) => Promise<void>;
36
+ refreshMediaConn: (forceGet?: boolean) => Promise<import("../Types").MediaConnInfo>;
37
+ waUploadToServer: import("../Types").WAMediaUploadFunction;
38
+ fetchPrivacySettings: (force?: boolean) => Promise<{
39
+ [_: string]: string;
40
+ }>;
41
+ getUSyncDevices: (jids: string[], useCache: boolean, ignoreZeroDevices: boolean) => Promise<import("../WABinary").JidWithDevice[]>;
42
+ createParticipantNodes: (jids: string[], message: import("../Types").WAProto.IMessage, extraAttrs?: import("../WABinary").BinaryNode["attrs"]) => Promise<{
43
+ nodes: import("../WABinary").BinaryNode[];
44
+ shouldIncludeDeviceIdentity: boolean;
45
+ }>;
46
+ sendPeerDataOperationMessage: (pdoMessage: import("../Types").WAProto.Message.IPeerDataOperationRequestMessage) => Promise<string>;
47
+ updateMediaMessage: (message: import("../Types").WAProto.IWebMessageInfo) => Promise<import("../Types").WAProto.IWebMessageInfo>;
48
+ sendMessage: (jid: string, content: import("../Types").AnyMessageContent, options?: import("../Types").MiscMessageGenerationOptions) => Promise<import("../Types").WAProto.WebMessageInfo | undefined>;
49
+ subscribeNewsletterUpdates: (jid: string) => Promise<{
50
+ duration: string;
51
+ }>;
52
+ newsletterReactionMode: (jid: string, mode: import("../Types").NewsletterReactionMode) => Promise<void>;
53
+ newsletterUpdateDescription: (jid: string, description?: string) => Promise<void>;
54
+ newsletterUpdateName: (jid: string, name: string) => Promise<void>;
55
+ newsletterUpdatePicture: (jid: string, content: import("../Types").WAMediaUpload) => Promise<void>;
56
+ newsletterRemovePicture: (jid: string) => Promise<void>;
57
+ newsletterUnfollow: (jid: string) => Promise<void>;
58
+ newsletterFollow: (jid: string) => Promise<void>;
59
+ newsletterUnmute: (jid: string) => Promise<void>;
60
+ newsletterMute: (jid: string) => Promise<void>;
61
+ newsletterCreate: (name: string, description?: string, picture?: import("../Types").WAMediaUpload) => Promise<import("../Types").NewsletterMetadata>;
62
+ newsletterMetadata: (type: "invite" | "jid", key: string, role?: import("../Types").NewsletterViewRole) => Promise<import("../Types").NewsletterMetadata>;
63
+ newsletterAdminCount: (jid: string) => Promise<number>;
64
+ newsletterChangeOwner: (jid: string, user: string) => Promise<void>;
65
+ newsletterDemote: (jid: string, user: string) => Promise<void>;
66
+ newsletterDelete: (jid: string) => Promise<void>;
67
+ newsletterReactMessage: (jid: string, server_id: string, code?: string) => Promise<void>;
68
+ newsletterFetchMessages: (type: "invite" | "jid", key: string, count: number, after?: number) => Promise<import("../Types").NewsletterFetchedUpdate[]>;
69
+ newsletterFetchUpdates: (jid: string, count: number, after?: number, since?: number) => Promise<import("../Types").NewsletterFetchedUpdate[]>;
70
+ groupQuery: (jid: string, type: "get" | "set", content: import("../WABinary").BinaryNode[]) => Promise<any>;
71
+ groupMetadata: (jid: string) => Promise<import("../Types").GroupMetadata>;
72
+ groupCreate: (subject: string, participants: string[]) => Promise<import("../Types").GroupMetadata>;
73
+ groupLeave: (id: string) => Promise<void>;
74
+ groupUpdateSubject: (jid: string, subject: string) => Promise<void>;
75
+ groupRequestParticipantsList: (jid: string) => Promise<{
76
+ [key: string]: string;
77
+ }[]>;
78
+ groupRequestParticipantsUpdate: (jid: string, participants: string[], action: "approve" | "reject") => Promise<{
79
+ status: string;
80
+ jid: string;
81
+ }[]>;
82
+ groupParticipantsUpdate: (jid: string, participants: string[], action: import("../Types").ParticipantAction) => Promise<{
83
+ status: string;
84
+ jid: string;
85
+ content: import("../WABinary").BinaryNode;
86
+ }[]>;
87
+ groupUpdateDescription: (jid: string, description?: string) => Promise<void>;
88
+ groupInviteCode: (jid: string) => Promise<string | undefined>;
89
+ groupRevokeInvite: (jid: string) => Promise<string | undefined>;
90
+ groupAcceptInvite: (code: string) => Promise<string | undefined>;
91
+ groupRevokeInviteV4: (groupJid: string, invitedJid: string) => Promise<boolean>;
92
+ groupAcceptInviteV4: (key: string | import("../Types").WAMessageKey, inviteMessage: import("../Types").WAProto.Message.IGroupInviteMessage) => Promise<any>;
93
+ groupGetInviteInfo: (code: string) => Promise<import("../Types").GroupMetadata>;
94
+ groupToggleEphemeral: (jid: string, ephemeralExpiration: number) => Promise<void>;
95
+ groupSettingUpdate: (jid: string, setting: "announcement" | "not_announcement" | "locked" | "unlocked") => Promise<void>;
96
+ groupMemberAddMode: (jid: string, mode: "admin_add" | "all_member_add") => Promise<void>;
97
+ groupJoinApprovalMode: (jid: string, mode: "on" | "off") => Promise<void>;
98
+ groupFetchAllParticipating: () => Promise<{
99
+ [_: string]: import("../Types").GroupMetadata;
100
+ }>;
101
+ getBotListV2: () => Promise<import("../Types").BotListInfo[]>;
102
+ processingMutex: {
103
+ mutex<T>(code: () => Promise<T> | T): Promise<T>;
104
+ };
105
+ upsertMessage: (msg: import("../Types").WAProto.IWebMessageInfo, type: import("../Types").MessageUpsertType) => Promise<void>;
106
+ 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
+ onWhatsApp: (...jids: string[]) => Promise<{
111
+ jid: string;
112
+ exists: unknown;
113
+ lid: unknown;
114
+ }[] | undefined>;
115
+ fetchBlocklist: () => Promise<string[]>;
116
+ fetchDisappearingDuration: (...jids: string[]) => Promise<import("..").USyncQueryResultList[] | undefined>;
117
+ fetchStatus: (...jids: string[]) => Promise<import("..").USyncQueryResultList[] | undefined>;
118
+ updateProfilePicture: (jid: string, content: import("../Types").WAMediaUpload) => Promise<void>;
119
+ removeProfilePicture: (jid: string) => Promise<void>;
120
+ updateProfileStatus: (status: string) => Promise<void>;
121
+ updateProfileName: (name: string) => Promise<void>;
122
+ updateBlockStatus: (jid: string, action: "block" | "unblock") => Promise<void>;
123
+ updateCallPrivacy: (value: import("../Types").WAPrivacyCallValue) => Promise<void>;
124
+ updateMessagesPrivacy: (value: import("../Types").WAPrivacyMessagesValue) => Promise<void>;
125
+ updateLastSeenPrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
126
+ updateOnlinePrivacy: (value: import("../Types").WAPrivacyOnlineValue) => Promise<void>;
127
+ updateProfilePicturePrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
128
+ updateStatusPrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
129
+ updateReadReceiptsPrivacy: (value: import("../Types").WAReadReceiptsValue) => Promise<void>;
130
+ updateGroupsAddPrivacy: (value: import("../Types").WAPrivacyGroupAddValue) => Promise<void>;
131
+ updateDefaultDisappearingMode: (duration: number) => Promise<void>;
132
+ getBusinessProfile: (jid: string) => Promise<import("../Types").WABusinessProfile | void>;
133
+ resyncAppState: (collections: readonly ("critical_unblock_low" | "regular_high" | "regular_low" | "critical_block" | "regular")[], isInitialSync: boolean) => Promise<void>;
134
+ chatModify: (mod: import("../Types").ChatModification, jid: string) => Promise<void>;
135
+ cleanDirtyBits: (type: "account_sync" | "groups", fromTimestamp?: number | string) => Promise<void>;
136
+ addChatLabel: (jid: string, labelId: string) => Promise<void>;
137
+ removeChatLabel: (jid: string, labelId: string) => Promise<void>;
138
+ addMessageLabel: (jid: string, messageId: string, labelId: string) => Promise<void>;
139
+ removeMessageLabel: (jid: string, messageId: string, labelId: string) => Promise<void>;
140
+ star: (jid: string, messages: {
141
+ id: string;
142
+ fromMe?: boolean;
143
+ }[], star: boolean) => Promise<void>;
144
+ executeUSyncQuery: (usyncQuery: import("..").USyncQuery) => Promise<import("..").USyncQueryResult | undefined>;
145
+ type: "md";
146
+ ws: any;
147
+ ev: import("../Types").BaileysEventEmitter & {
148
+ process(handler: (events: Partial<import("../Types").BaileysEventMap>) => void | Promise<void>): (() => void);
149
+ buffer(): void;
150
+ createBufferedFunction<A extends any[], T>(work: (...args: A) => Promise<T>): ((...args: A) => Promise<T>);
151
+ flush(force?: boolean): boolean;
152
+ isBuffering(): boolean;
153
+ };
154
+ authState: {
155
+ creds: import("../Types").AuthenticationCreds;
156
+ keys: import("../Types").SignalKeyStoreWithTransaction;
157
+ };
158
+ signalRepository: import("../Types").SignalRepository;
159
+ user: import("../Types").Contact | undefined;
160
+ generateMessageTag: () => string;
161
+ query: (node: import("../WABinary").BinaryNode, timeoutMs?: number) => Promise<any>;
162
+ waitForMessage: <T>(msgId: string, timeoutMs?: number | undefined) => Promise<any>;
163
+ waitForSocketOpen: () => Promise<void>;
164
+ sendRawMessage: (data: Uint8Array | Buffer) => Promise<void>;
165
+ sendNode: (frame: import("../WABinary").BinaryNode) => Promise<void>;
166
+ logout: (msg?: string) => Promise<void>;
167
+ end: (error: Error | undefined) => void;
168
+ onUnexpectedError: (err: Error | import("@hapi/boom").Boom, msg: string) => void;
169
+ uploadPreKeys: (count?: number) => Promise<void>;
170
+ uploadPreKeysToServerIfRequired: () => Promise<void>;
171
+ requestPairingCode: (phoneNumber: string, pairCode: string) => Promise<string>;
172
+ waitForConnectionUpdate: (check: (u: Partial<import("../Types").ConnectionState>) => Promise<boolean | undefined>, timeoutMs?: number) => Promise<void>;
173
+ sendWAMBuffer: (wamBuffer: Buffer) => Promise<any>;
174
+ };
175
+ export interface RegistrationData {
176
+ registrationId: number;
177
+ signedPreKey: SignedKeyPair;
178
+ noiseKey: KeyPair;
179
+ signedIdentityKey: KeyPair;
180
+ identityId: Buffer;
181
+ phoneId: string;
182
+ deviceId: string;
183
+ backupToken: Buffer;
184
+ }
185
+ export interface RegistrationOptions {
186
+ /** your phone number */
187
+ phoneNumber?: string;
188
+ /** the country code of your phone number */
189
+ phoneNumberCountryCode: string;
190
+ /** your phone number without country code */
191
+ phoneNumberNationalNumber: string;
192
+ /** the country code of your mobile network
193
+ * @see {@link https://de.wikipedia.org/wiki/Mobile_Country_Code}
194
+ */
195
+ phoneNumberMobileCountryCode: string;
196
+ /** the network code of your mobile network
197
+ * @see {@link https://de.wikipedia.org/wiki/Mobile_Network_Code}
198
+ */
199
+ phoneNumberMobileNetworkCode: string;
200
+ /**
201
+ * How to send the one time code
202
+ */
203
+ method?: 'sms' | 'voice' | 'captcha';
204
+ /**
205
+ * The captcha code if it was requested
206
+ */
207
+ captcha?: string;
208
+ }
209
+ export type RegistrationParams = RegistrationData & RegistrationOptions;
210
+ export declare function registrationParams(params: RegistrationParams): {
211
+ cc: string;
212
+ in: string;
213
+ Rc: string;
214
+ lg: string;
215
+ lc: string;
216
+ mistyped: string;
217
+ authkey: string;
218
+ e_regid: string;
219
+ e_keytype: string;
220
+ e_ident: string;
221
+ e_skey_id: string;
222
+ e_skey_val: string;
223
+ e_skey_sig: string;
224
+ fdid: string;
225
+ network_ratio_type: string;
226
+ expid: string;
227
+ simnum: string;
228
+ hasinrc: string;
229
+ pid: string;
230
+ id: string;
231
+ backup_token: string;
232
+ token: string;
233
+ fraud_checkpoint_code: string | undefined;
234
+ };
235
+ /**
236
+ * Requests a registration code for the given phone number.
237
+ */
238
+ export declare function mobileRegisterCode(params: RegistrationParams, fetchOptions?: AxiosRequestConfig): Promise<ExistsResponse>;
239
+ export declare function mobileRegisterExists(params: RegistrationParams, fetchOptions?: AxiosRequestConfig): Promise<ExistsResponse>;
240
+ /**
241
+ * Registers the phone number on whatsapp with the received OTP code.
242
+ */
243
+ export declare function mobileRegister(params: RegistrationParams & {
244
+ code: string;
245
+ }, fetchOptions?: AxiosRequestConfig): Promise<ExistsResponse>;
246
+ /**
247
+ * Encrypts the given string as AEAD aes-256-gcm with the public whatsapp key and a random keypair.
248
+ */
249
+ export declare function mobileRegisterEncrypt(data: string): string;
250
+ export declare function mobileRegisterFetch(path: string, opts?: AxiosRequestConfig): Promise<ExistsResponse>;
251
+ export interface ExistsResponse {
252
+ status: 'fail' | 'sent';
253
+ voice_length?: number;
254
+ voice_wait?: number;
255
+ sms_length?: number;
256
+ sms_wait?: number;
257
+ reason?: 'incorrect' | 'missing_param' | 'code_checkpoint';
258
+ login?: string;
259
+ flash_type?: number;
260
+ ab_hash?: string;
261
+ ab_key?: string;
262
+ exp_cfg?: string;
263
+ lid?: string;
264
+ image_blob?: string;
265
+ audio_blob?: string;
266
+ }