@alannxd/baileys 6.0.5 → 6.0.6

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 (234) hide show
  1. package/WAProto/fix-import.js +29 -0
  2. package/WAProto/index.js +160 -201
  3. package/engine-requirements.js +1 -1
  4. package/lib/Defaults/baileys-version.json +3 -0
  5. package/lib/Defaults/index.d.ts +15 -37
  6. package/lib/Defaults/index.js +136 -119
  7. package/lib/Defaults/phonenumber-mcc.json +223 -0
  8. package/lib/Signal/Group/ciphertext-message.d.ts +0 -1
  9. package/lib/Signal/Group/ciphertext-message.js +5 -2
  10. package/lib/Signal/Group/group-session-builder.d.ts +3 -4
  11. package/lib/Signal/Group/group-session-builder.js +41 -7
  12. package/lib/Signal/Group/group_cipher.d.ts +4 -4
  13. package/lib/Signal/Group/group_cipher.js +51 -37
  14. package/lib/Signal/Group/index.d.ts +11 -12
  15. package/lib/Signal/Group/index.js +57 -12
  16. package/lib/Signal/Group/keyhelper.d.ts +1 -2
  17. package/lib/Signal/Group/keyhelper.js +44 -7
  18. package/lib/Signal/Group/queue-job.d.ts +1 -0
  19. package/lib/Signal/Group/queue-job.js +57 -0
  20. package/lib/Signal/Group/sender-chain-key.d.ts +2 -3
  21. package/lib/Signal/Group/sender-chain-key.js +15 -7
  22. package/lib/Signal/Group/sender-key-distribution-message.d.ts +1 -2
  23. package/lib/Signal/Group/sender-key-distribution-message.js +11 -8
  24. package/lib/Signal/Group/sender-key-message.d.ts +1 -2
  25. package/lib/Signal/Group/sender-key-message.js +12 -9
  26. package/lib/Signal/Group/sender-key-name.d.ts +0 -1
  27. package/lib/Signal/Group/sender-key-name.js +5 -2
  28. package/lib/Signal/Group/sender-key-record.d.ts +2 -3
  29. package/lib/Signal/Group/sender-key-record.js +21 -9
  30. package/lib/Signal/Group/sender-key-state.d.ts +6 -7
  31. package/lib/Signal/Group/sender-key-state.js +42 -27
  32. package/lib/Signal/Group/sender-message-key.d.ts +0 -1
  33. package/lib/Signal/Group/sender-message-key.js +7 -4
  34. package/lib/Signal/libsignal.d.ts +3 -5
  35. package/lib/Signal/libsignal.js +90 -347
  36. package/lib/Socket/Client/{types.d.ts → abstract-socket-client.d.ts} +5 -4
  37. package/lib/Socket/Client/abstract-socket-client.js +13 -0
  38. package/lib/Socket/Client/index.d.ts +3 -3
  39. package/lib/Socket/Client/index.js +19 -3
  40. package/lib/Socket/Client/mobile-socket-client.d.ts +13 -0
  41. package/lib/Socket/Client/mobile-socket-client.js +65 -0
  42. package/lib/Socket/Client/{websocket.d.ts → web-socket-client.d.ts} +2 -3
  43. package/lib/Socket/Client/web-socket-client.js +62 -0
  44. package/lib/Socket/business.d.ts +108 -154
  45. package/lib/Socket/business.js +43 -162
  46. package/lib/Socket/chats.d.ts +239 -96
  47. package/lib/Socket/chats.js +427 -627
  48. package/lib/Socket/communities.d.ts +146 -239
  49. package/lib/Socket/communities.js +80 -90
  50. package/lib/Socket/groups.d.ts +57 -104
  51. package/lib/Socket/groups.js +161 -154
  52. package/lib/Socket/index.d.ts +115 -202
  53. package/lib/Socket/index.js +10 -11
  54. package/lib/Socket/luxu.d.ts +266 -22
  55. package/lib/Socket/luxu.js +465 -422
  56. package/lib/Socket/messages-recv.d.ts +84 -136
  57. package/lib/Socket/messages-recv.js +615 -1421
  58. package/lib/Socket/messages-send.d.ts +126 -142
  59. package/lib/Socket/messages-send.js +671 -878
  60. package/lib/Socket/newsletter.d.ts +85 -121
  61. package/lib/Socket/newsletter.js +272 -147
  62. package/lib/Socket/registration.d.ts +267 -0
  63. package/lib/Socket/registration.js +166 -0
  64. package/lib/Socket/socket.d.ts +19 -34
  65. package/lib/Socket/socket.js +313 -544
  66. package/lib/Socket/usync.d.ts +36 -0
  67. package/lib/Socket/usync.js +70 -0
  68. package/lib/Store/index.d.ts +3 -10
  69. package/lib/Store/index.js +10 -10
  70. package/lib/Store/make-cache-manager-store.d.ts +11 -17
  71. package/lib/Store/make-cache-manager-store.js +41 -43
  72. package/lib/Store/make-in-memory-store.d.ts +118 -39
  73. package/lib/Store/make-in-memory-store.js +341 -112
  74. package/lib/Store/make-ordered-dictionary.d.ts +10 -11
  75. package/lib/Store/make-ordered-dictionary.js +20 -14
  76. package/lib/Store/object-repository.d.ts +9 -10
  77. package/lib/Store/object-repository.js +6 -11
  78. package/lib/Types/Auth.d.ts +12 -19
  79. package/lib/Types/Auth.js +2 -2
  80. package/lib/Types/Call.d.ts +1 -3
  81. package/lib/Types/Call.js +2 -2
  82. package/lib/Types/Chat.d.ts +13 -35
  83. package/lib/Types/Chat.js +4 -8
  84. package/lib/Types/Contact.d.ts +1 -8
  85. package/lib/Types/Contact.js +2 -2
  86. package/lib/Types/Events.d.ts +17 -116
  87. package/lib/Types/Events.js +2 -2
  88. package/lib/Types/GroupMetadata.d.ts +5 -21
  89. package/lib/Types/GroupMetadata.js +2 -2
  90. package/lib/Types/Label.d.ts +0 -12
  91. package/lib/Types/Label.js +5 -3
  92. package/lib/Types/LabelAssociation.d.ts +0 -1
  93. package/lib/Types/LabelAssociation.js +5 -3
  94. package/lib/Types/Message.d.ts +58 -105
  95. package/lib/Types/Message.js +9 -11
  96. package/lib/Types/Newsletter.d.ts +103 -0
  97. package/lib/Types/Newsletter.js +38 -0
  98. package/lib/Types/Product.d.ts +1 -2
  99. package/lib/Types/Product.js +2 -2
  100. package/lib/Types/Signal.d.ts +2 -32
  101. package/lib/Types/Signal.js +2 -2
  102. package/lib/Types/Socket.d.ts +25 -50
  103. package/lib/Types/Socket.js +2 -3
  104. package/lib/Types/State.d.ts +2 -72
  105. package/lib/Types/State.js +2 -56
  106. package/lib/Types/USync.d.ts +2 -3
  107. package/lib/Types/USync.js +2 -2
  108. package/lib/Types/index.d.ts +14 -22
  109. package/lib/Types/index.js +31 -15
  110. package/lib/Utils/auth-utils.d.ts +6 -12
  111. package/lib/Utils/auth-utils.js +143 -239
  112. package/lib/Utils/baileys-event-stream.d.ts +16 -0
  113. package/lib/Utils/baileys-event-stream.js +63 -0
  114. package/lib/Utils/business.d.ts +2 -3
  115. package/lib/Utils/business.js +69 -66
  116. package/lib/Utils/chat-utils.d.ts +23 -52
  117. package/lib/Utils/chat-utils.js +253 -396
  118. package/lib/Utils/crypto.d.ts +22 -18
  119. package/lib/Utils/crypto.js +90 -57
  120. package/lib/Utils/decode-wa-message.d.ts +8 -55
  121. package/lib/Utils/decode-wa-message.js +84 -203
  122. package/lib/Utils/event-buffer.d.ts +8 -9
  123. package/lib/Utils/event-buffer.js +77 -185
  124. package/lib/Utils/generics.d.ts +29 -28
  125. package/lib/Utils/generics.js +210 -180
  126. package/lib/Utils/history.d.ts +9 -18
  127. package/lib/Utils/history.js +55 -93
  128. package/lib/Utils/index.d.ts +17 -22
  129. package/lib/Utils/index.js +33 -22
  130. package/lib/Utils/link-preview.d.ts +5 -5
  131. package/lib/Utils/link-preview.js +24 -16
  132. package/lib/Utils/logger.d.ts +3 -11
  133. package/lib/Utils/logger.js +7 -3
  134. package/lib/Utils/lt-hash.d.ts +12 -8
  135. package/lib/Utils/lt-hash.js +46 -3
  136. package/lib/Utils/make-mutex.d.ts +2 -4
  137. package/lib/Utils/make-mutex.js +34 -24
  138. package/lib/Utils/messages-media.d.ts +44 -61
  139. package/lib/Utils/messages-media.js +482 -451
  140. package/lib/Utils/messages.d.ts +18 -32
  141. package/lib/Utils/messages.js +369 -458
  142. package/lib/Utils/noise-handler.d.ts +14 -13
  143. package/lib/Utils/noise-handler.js +99 -145
  144. package/lib/Utils/process-message.d.ts +12 -31
  145. package/lib/Utils/process-message.js +150 -459
  146. package/lib/Utils/signal.d.ts +5 -20
  147. package/lib/Utils/signal.js +72 -120
  148. package/lib/Utils/use-multi-file-auth-state.d.ts +2 -2
  149. package/lib/Utils/use-multi-file-auth-state.js +27 -29
  150. package/lib/Utils/validate-connection.d.ts +7 -7
  151. package/lib/Utils/validate-connection.js +99 -73
  152. package/lib/WABinary/constants.d.ts +27 -25
  153. package/lib/WABinary/constants.js +20 -1281
  154. package/lib/WABinary/decode.d.ts +5 -5
  155. package/lib/WABinary/decode.js +42 -52
  156. package/lib/WABinary/encode.d.ts +3 -3
  157. package/lib/WABinary/encode.js +155 -110
  158. package/lib/WABinary/generic-utils.d.ts +7 -8
  159. package/lib/WABinary/generic-utils.js +49 -48
  160. package/lib/WABinary/index.d.ts +5 -6
  161. package/lib/WABinary/index.js +21 -6
  162. package/lib/WABinary/jid-utils.d.ts +8 -25
  163. package/lib/WABinary/jid-utils.js +40 -74
  164. package/lib/WABinary/types.d.ts +1 -2
  165. package/lib/WABinary/types.js +2 -2
  166. package/lib/WAM/BinaryInfo.d.ts +11 -3
  167. package/lib/WAM/BinaryInfo.js +5 -2
  168. package/lib/WAM/constants.d.ts +3 -5
  169. package/lib/WAM/constants.js +11958 -19461
  170. package/lib/WAM/encode.d.ts +3 -3
  171. package/lib/WAM/encode.js +22 -17
  172. package/lib/WAM/index.d.ts +3 -4
  173. package/lib/WAM/index.js +19 -4
  174. package/lib/WAUSync/Protocols/USyncContactProtocol.d.ts +3 -4
  175. package/lib/WAUSync/Protocols/USyncContactProtocol.js +13 -33
  176. package/lib/WAUSync/Protocols/USyncDeviceProtocol.d.ts +2 -3
  177. package/lib/WAUSync/Protocols/USyncDeviceProtocol.js +14 -11
  178. package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.d.ts +2 -3
  179. package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.js +12 -9
  180. package/lib/WAUSync/Protocols/USyncStatusProtocol.d.ts +2 -3
  181. package/lib/WAUSync/Protocols/USyncStatusProtocol.js +13 -9
  182. package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.d.ts +3 -4
  183. package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.js +22 -20
  184. package/lib/WAUSync/Protocols/UsyncLIDProtocol.d.ts +3 -5
  185. package/lib/WAUSync/Protocols/UsyncLIDProtocol.js +8 -13
  186. package/lib/WAUSync/Protocols/index.d.ts +4 -6
  187. package/lib/WAUSync/Protocols/index.js +20 -6
  188. package/lib/WAUSync/USyncQuery.d.ts +4 -6
  189. package/lib/WAUSync/USyncQuery.js +35 -44
  190. package/lib/WAUSync/USyncUser.d.ts +5 -10
  191. package/lib/WAUSync/USyncUser.js +5 -10
  192. package/lib/WAUSync/index.js +19 -4
  193. package/lib/index.d.ts +9 -10
  194. package/lib/index.js +34 -12
  195. package/package.json +50 -83
  196. package/WAProto/GenerateStatics.sh +0 -3
  197. package/WAProto/WAProto.proto +0 -5479
  198. package/WAProto/fix-imports.js +0 -85
  199. package/WAProto/index.d.ts +0 -14017
  200. package/lib/Signal/lid-mapping.d.ts +0 -23
  201. package/lib/Signal/lid-mapping.js +0 -277
  202. package/lib/Socket/Client/types.js +0 -11
  203. package/lib/Socket/Client/websocket.js +0 -54
  204. package/lib/Socket/mex.d.ts +0 -3
  205. package/lib/Socket/mex.js +0 -42
  206. package/lib/Store/keyed-db.d.ts +0 -22
  207. package/lib/Store/keyed-db.js +0 -108
  208. package/lib/Types/Bussines.d.ts +0 -25
  209. package/lib/Types/Bussines.js +0 -2
  210. package/lib/Types/Mex.d.ts +0 -141
  211. package/lib/Types/Mex.js +0 -37
  212. package/lib/Utils/browser-utils.d.ts +0 -4
  213. package/lib/Utils/browser-utils.js +0 -28
  214. package/lib/Utils/companion-reg-client-utils.d.ts +0 -17
  215. package/lib/Utils/companion-reg-client-utils.js +0 -35
  216. package/lib/Utils/identity-change-handler.d.ts +0 -44
  217. package/lib/Utils/identity-change-handler.js +0 -50
  218. package/lib/Utils/message-retry-manager.d.ts +0 -115
  219. package/lib/Utils/message-retry-manager.js +0 -265
  220. package/lib/Utils/offline-node-processor.d.ts +0 -17
  221. package/lib/Utils/offline-node-processor.js +0 -40
  222. package/lib/Utils/pre-key-manager.d.ts +0 -28
  223. package/lib/Utils/pre-key-manager.js +0 -106
  224. package/lib/Utils/reporting-utils.d.ts +0 -11
  225. package/lib/Utils/reporting-utils.js +0 -258
  226. package/lib/Utils/stanza-ack.d.ts +0 -11
  227. package/lib/Utils/stanza-ack.js +0 -38
  228. package/lib/Utils/sync-action-utils.d.ts +0 -19
  229. package/lib/Utils/sync-action-utils.js +0 -49
  230. package/lib/Utils/tc-token-utils.d.ts +0 -37
  231. package/lib/Utils/tc-token-utils.js +0 -163
  232. package/lib/WAUSync/Protocols/USyncUsernameProtocol.d.ts +0 -10
  233. package/lib/WAUSync/Protocols/USyncUsernameProtocol.js +0 -25
  234. package/lib/WAUSync/index.d.ts +0 -4
@@ -1,20 +1,21 @@
1
- import { proto } from '../../WAProto/index.js';
2
- import type { KeyPair } from '../Types/index.js';
3
- import type { BinaryNode } from '../WABinary/index.js';
4
- import type { ILogger } from './logger.js';
5
- export declare const makeNoiseHandler: ({ keyPair: { private: privateKey, public: publicKey }, NOISE_HEADER, logger, routingInfo }: {
1
+ /// <reference types="node" />
2
+ import { Logger } from 'pino';
3
+ import { proto } from '../../WAProto';
4
+ import { KeyPair } from '../Types';
5
+ import { BinaryNode } from '../WABinary';
6
+ export declare const makeNoiseHandler: ({ keyPair: { private: privateKey, public: publicKey }, NOISE_HEADER, mobile, logger, routingInfo }: {
6
7
  keyPair: KeyPair;
7
8
  NOISE_HEADER: Uint8Array;
8
- logger: ILogger;
9
+ mobile: boolean;
10
+ logger: Logger;
9
11
  routingInfo?: Buffer | undefined;
10
12
  }) => {
11
- encrypt: (plaintext: Uint8Array) => Uint8Array;
12
- decrypt: (ciphertext: Uint8Array) => Uint8Array;
13
+ encrypt: (plaintext: Uint8Array) => Buffer;
14
+ decrypt: (ciphertext: Uint8Array) => Buffer;
13
15
  authenticate: (data: Uint8Array) => void;
14
16
  mixIntoKey: (data: Uint8Array) => void;
15
- finishInit: () => Promise<void>;
16
- processHandshake: ({ serverHello }: proto.HandshakeMessage, noiseKey: KeyPair) => Uint8Array<ArrayBufferLike>;
17
- encodeFrame: (data: Buffer | Uint8Array) => Buffer<ArrayBuffer>;
18
- decodeFrame: (newData: Buffer | Uint8Array, onFrame: (buff: Uint8Array | BinaryNode) => void) => Promise<void>;
17
+ finishInit: () => void;
18
+ processHandshake: ({ serverHello }: proto.HandshakeMessage, noiseKey: KeyPair) => Buffer;
19
+ encodeFrame: (data: Buffer | Uint8Array) => Buffer;
20
+ decodeFrame: (newData: Buffer | Uint8Array, onFrame: (buff: Uint8Array | BinaryNode) => void) => void;
19
21
  };
20
- //# sourceMappingURL=noise-handler.d.ts.map
@@ -1,131 +1,74 @@
1
- import { Boom } from '@hapi/boom';
2
- import { proto } from '../../WAProto/index.js';
3
- import { NOISE_MODE, WA_CERT_DETAILS } from '../Defaults/index.js';
4
- import { decodeBinaryNode } from '../WABinary/index.js';
5
- import { aesDecryptGCM, aesEncryptGCM, Curve, hkdf, sha256 } from './crypto.js';
6
- const IV_LENGTH = 12;
7
- const EMPTY_BUFFER = Buffer.alloc(0);
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.makeNoiseHandler = void 0;
4
+ const boom_1 = require("@hapi/boom");
5
+ const WAProto_1 = require("../../WAProto");
6
+ const Defaults_1 = require("../Defaults");
7
+ const WABinary_1 = require("../WABinary");
8
+ const crypto_1 = require("./crypto");
8
9
  const generateIV = (counter) => {
9
- const iv = new ArrayBuffer(IV_LENGTH);
10
+ const iv = new ArrayBuffer(12);
10
11
  new DataView(iv).setUint32(8, counter);
11
12
  return new Uint8Array(iv);
12
13
  };
13
- class TransportState {
14
- constructor(encKey, decKey) {
15
- this.encKey = encKey;
16
- this.decKey = decKey;
17
- this.readCounter = 0;
18
- this.writeCounter = 0;
19
- this.iv = new Uint8Array(IV_LENGTH);
20
- }
21
- encrypt(plaintext) {
22
- const c = this.writeCounter++;
23
- this.iv[8] = (c >>> 24) & 0xff;
24
- this.iv[9] = (c >>> 16) & 0xff;
25
- this.iv[10] = (c >>> 8) & 0xff;
26
- this.iv[11] = c & 0xff;
27
- return aesEncryptGCM(plaintext, this.encKey, this.iv, EMPTY_BUFFER);
28
- }
29
- decrypt(ciphertext) {
30
- const c = this.readCounter++;
31
- this.iv[8] = (c >>> 24) & 0xff;
32
- this.iv[9] = (c >>> 16) & 0xff;
33
- this.iv[10] = (c >>> 8) & 0xff;
34
- this.iv[11] = c & 0xff;
35
- return aesDecryptGCM(ciphertext, this.decKey, this.iv, EMPTY_BUFFER);
36
- }
37
- }
38
- export const makeNoiseHandler = ({ keyPair: { private: privateKey, public: publicKey }, NOISE_HEADER, logger, routingInfo }) => {
14
+ const makeNoiseHandler = ({ keyPair: { private: privateKey, public: publicKey }, NOISE_HEADER, mobile, logger, routingInfo }) => {
39
15
  logger = logger.child({ class: 'ns' });
40
- const data = Buffer.from(NOISE_MODE);
41
- let hash = data.byteLength === 32 ? data : sha256(data);
42
- let salt = hash;
43
- let encKey = hash;
44
- let decKey = hash;
45
- let counter = 0;
46
- let sentIntro = false;
47
- let inBytes = Buffer.alloc(0);
48
- let transport = null;
49
- let isWaitingForTransport = false;
50
- let pendingOnFrame = null;
51
- let introHeader;
52
- if (routingInfo) {
53
- introHeader = Buffer.alloc(7 + routingInfo.byteLength + NOISE_HEADER.length);
54
- introHeader.write('ED', 0, 'utf8');
55
- introHeader.writeUint8(0, 2);
56
- introHeader.writeUint8(1, 3);
57
- introHeader.writeUint8(routingInfo.byteLength >> 16, 4);
58
- introHeader.writeUint16BE(routingInfo.byteLength & 65535, 5);
59
- introHeader.set(routingInfo, 7);
60
- introHeader.set(NOISE_HEADER, 7 + routingInfo.byteLength);
61
- }
62
- else {
63
- introHeader = Buffer.from(NOISE_HEADER);
64
- }
65
16
  const authenticate = (data) => {
66
- if (!transport) {
67
- hash = sha256(Buffer.concat([hash, data]));
17
+ if (!isFinished) {
18
+ hash = (0, crypto_1.sha256)(Buffer.concat([hash, data]));
68
19
  }
69
20
  };
70
21
  const encrypt = (plaintext) => {
71
- if (transport) {
72
- return transport.encrypt(plaintext);
73
- }
74
- const result = aesEncryptGCM(plaintext, encKey, generateIV(counter++), hash);
22
+ const result = (0, crypto_1.aesEncryptGCM)(plaintext, encKey, generateIV(writeCounter), hash);
23
+ writeCounter += 1;
75
24
  authenticate(result);
76
25
  return result;
77
26
  };
78
27
  const decrypt = (ciphertext) => {
79
- if (transport) {
80
- return transport.decrypt(ciphertext);
28
+ // before the handshake is finished, we use the same counter
29
+ // after handshake, the counters are different
30
+ const iv = generateIV(isFinished ? readCounter : writeCounter);
31
+ const result = (0, crypto_1.aesDecryptGCM)(ciphertext, decKey, iv, hash);
32
+ if (isFinished) {
33
+ readCounter += 1;
34
+ }
35
+ else {
36
+ writeCounter += 1;
81
37
  }
82
- const result = aesDecryptGCM(ciphertext, decKey, generateIV(counter++), hash);
83
38
  authenticate(ciphertext);
84
39
  return result;
85
40
  };
86
41
  const localHKDF = (data) => {
87
- const key = hkdf(Buffer.from(data), 64, { salt, info: '' });
88
- return [key.subarray(0, 32), key.subarray(32)];
42
+ const key = (0, crypto_1.hkdf)(Buffer.from(data), 64, { salt, info: '' });
43
+ return [key.slice(0, 32), key.slice(32)];
89
44
  };
90
45
  const mixIntoKey = (data) => {
91
46
  const [write, read] = localHKDF(data);
92
47
  salt = write;
93
48
  encKey = read;
94
49
  decKey = read;
95
- counter = 0;
50
+ readCounter = 0;
51
+ writeCounter = 0;
96
52
  };
97
- const finishInit = async () => {
98
- isWaitingForTransport = true;
53
+ const finishInit = () => {
99
54
  const [write, read] = localHKDF(new Uint8Array(0));
100
- transport = new TransportState(write, read);
101
- isWaitingForTransport = false;
102
- logger.trace('Noise handler transitioned to Transport state');
103
- if (pendingOnFrame) {
104
- logger.trace({ length: inBytes.length }, 'Flushing buffered frames after transport ready');
105
- await processData(pendingOnFrame);
106
- pendingOnFrame = null;
107
- }
108
- };
109
- const processData = async (onFrame) => {
110
- let size;
111
- while (true) {
112
- if (inBytes.length < 3)
113
- return;
114
- size = (inBytes[0] << 16) | (inBytes[1] << 8) | inBytes[2];
115
- if (inBytes.length < size + 3)
116
- return;
117
- let frame = inBytes.subarray(3, size + 3);
118
- inBytes = inBytes.subarray(size + 3);
119
- if (transport) {
120
- const result = transport.decrypt(frame);
121
- frame = await decodeBinaryNode(result);
122
- }
123
- if (logger.level === 'trace') {
124
- logger.trace({ msg: frame?.attrs?.id }, 'recv frame');
125
- }
126
- onFrame(frame);
127
- }
55
+ encKey = write;
56
+ decKey = read;
57
+ hash = Buffer.from([]);
58
+ readCounter = 0;
59
+ writeCounter = 0;
60
+ isFinished = true;
128
61
  };
62
+ const data = Buffer.from(Defaults_1.NOISE_MODE);
63
+ let hash = Buffer.from(data.byteLength === 32 ? data : (0, crypto_1.sha256)(data));
64
+ let salt = hash;
65
+ let encKey = hash;
66
+ let decKey = hash;
67
+ let readCounter = 0;
68
+ let writeCounter = 0;
69
+ let isFinished = false;
70
+ let sentIntro = false;
71
+ let inBytes = Buffer.alloc(0);
129
72
  authenticate(NOISE_HEADER);
130
73
  authenticate(publicKey);
131
74
  return {
@@ -136,66 +79,77 @@ export const makeNoiseHandler = ({ keyPair: { private: privateKey, public: publi
136
79
  finishInit,
137
80
  processHandshake: ({ serverHello }, noiseKey) => {
138
81
  authenticate(serverHello.ephemeral);
139
- mixIntoKey(Curve.sharedKey(privateKey, serverHello.ephemeral));
82
+ mixIntoKey(crypto_1.Curve.sharedKey(privateKey, serverHello.ephemeral));
140
83
  const decStaticContent = decrypt(serverHello.static);
141
- mixIntoKey(Curve.sharedKey(privateKey, decStaticContent));
84
+ mixIntoKey(crypto_1.Curve.sharedKey(privateKey, decStaticContent));
142
85
  const certDecoded = decrypt(serverHello.payload);
143
- const { intermediate: certIntermediate, leaf } = proto.CertChain.decode(certDecoded);
144
- // leaf
145
- if (!leaf?.details || !leaf?.signature) {
146
- throw new Boom('invalid noise leaf certificate', { statusCode: 400 });
147
- }
148
- if (!certIntermediate?.details || !certIntermediate?.signature) {
149
- throw new Boom('invalid noise intermediate certificate', { statusCode: 400 });
150
- }
151
- const details = proto.CertChain.NoiseCertificate.Details.decode(certIntermediate.details);
152
- const { issuerSerial } = details;
153
- const verify = Curve.verify(details.key, leaf.details, leaf.signature);
154
- const verifyIntermediate = Curve.verify(WA_CERT_DETAILS.PUBLIC_KEY, certIntermediate.details, certIntermediate.signature);
155
- if (!verify) {
156
- throw new Boom('noise certificate signature invalid', { statusCode: 400 });
157
- }
158
- if (!verifyIntermediate) {
159
- throw new Boom('noise intermediate certificate signature invalid', { statusCode: 400 });
86
+ if (mobile) {
87
+ WAProto_1.proto.CertChain.NoiseCertificate.decode(certDecoded);
160
88
  }
161
- if (issuerSerial !== WA_CERT_DETAILS.SERIAL) {
162
- throw new Boom('certification match failed', { statusCode: 400 });
89
+ else {
90
+ const { intermediate: certIntermediate } = WAProto_1.proto.CertChain.decode(certDecoded);
91
+ const { issuerSerial } = WAProto_1.proto.CertChain.NoiseCertificate.Details.decode(certIntermediate.details);
92
+ if (issuerSerial !== Defaults_1.WA_CERT_DETAILS.SERIAL) {
93
+ throw new boom_1.Boom('certification match failed', { statusCode: 400 });
94
+ }
163
95
  }
164
96
  const keyEnc = encrypt(noiseKey.public);
165
- mixIntoKey(Curve.sharedKey(noiseKey.private, serverHello.ephemeral));
97
+ mixIntoKey(crypto_1.Curve.sharedKey(noiseKey.private, serverHello.ephemeral));
166
98
  return keyEnc;
167
99
  },
168
100
  encodeFrame: (data) => {
169
- if (transport) {
170
- data = transport.encrypt(data);
101
+ if (isFinished) {
102
+ data = encrypt(data);
103
+ }
104
+ let header;
105
+ if (routingInfo) {
106
+ header = Buffer.alloc(7);
107
+ header.write('ED', 0, 'utf8');
108
+ header.writeUint8(0, 2);
109
+ header.writeUint8(1, 3);
110
+ header.writeUint8(routingInfo.byteLength >> 16, 4);
111
+ header.writeUint16BE(routingInfo.byteLength & 65535, 5);
112
+ header = Buffer.concat([header, routingInfo, NOISE_HEADER]);
113
+ }
114
+ else {
115
+ header = Buffer.from(NOISE_HEADER);
171
116
  }
172
- const dataLen = data.byteLength;
173
- const introSize = sentIntro ? 0 : introHeader.length;
174
- const frame = Buffer.allocUnsafe(introSize + 3 + dataLen);
117
+ const introSize = sentIntro ? 0 : header.length;
118
+ const frame = Buffer.alloc(introSize + 3 + data.byteLength);
175
119
  if (!sentIntro) {
176
- frame.set(introHeader);
120
+ frame.set(header);
177
121
  sentIntro = true;
178
122
  }
179
- frame[introSize] = (dataLen >>> 16) & 0xff;
180
- frame[introSize + 1] = (dataLen >>> 8) & 0xff;
181
- frame[introSize + 2] = dataLen & 0xff;
123
+ frame.writeUInt8(data.byteLength >> 16, introSize);
124
+ frame.writeUInt16BE(65535 & data.byteLength, introSize + 1);
182
125
  frame.set(data, introSize + 3);
183
126
  return frame;
184
127
  },
185
- decodeFrame: async (newData, onFrame) => {
186
- if (isWaitingForTransport) {
187
- inBytes = Buffer.concat([inBytes, newData]);
188
- pendingOnFrame = onFrame;
189
- return;
190
- }
191
- if (inBytes.length === 0) {
192
- inBytes = Buffer.from(newData);
193
- }
194
- else {
195
- inBytes = Buffer.concat([inBytes, newData]);
128
+ decodeFrame: (newData, onFrame) => {
129
+ var _a;
130
+ // the binary protocol uses its own framing mechanism
131
+ // on top of the WS frames
132
+ // so we get this data and separate out the frames
133
+ const getBytesSize = () => {
134
+ if (inBytes.length >= 3) {
135
+ return (inBytes.readUInt8() << 16) | inBytes.readUInt16BE(1);
136
+ }
137
+ };
138
+ inBytes = Buffer.concat([inBytes, newData]);
139
+ logger.trace(`recv ${newData.length} bytes, total recv ${inBytes.length} bytes`);
140
+ let size = getBytesSize();
141
+ while (size && inBytes.length >= size + 3) {
142
+ let frame = inBytes.slice(3, size + 3);
143
+ inBytes = inBytes.slice(size + 3);
144
+ if (isFinished) {
145
+ const result = decrypt(frame);
146
+ frame = (0, WABinary_1.decodeBinaryNode)(result);
147
+ }
148
+ logger.trace({ msg: (_a = frame === null || frame === void 0 ? void 0 : frame.attrs) === null || _a === void 0 ? void 0 : _a.id }, 'recv frame');
149
+ onFrame(frame);
150
+ size = getBytesSize();
196
151
  }
197
- await processData(onFrame);
198
152
  }
199
153
  };
200
154
  };
201
- //# sourceMappingURL=noise-handler.js.map
155
+ exports.makeNoiseHandler = makeNoiseHandler;
@@ -1,26 +1,25 @@
1
- import { proto } from '../../WAProto/index.js';
2
- import type { AuthenticationCreds, BaileysEventEmitter, CacheStore, SignalKeyStoreWithTransaction, SignalRepositoryWithLIDStore, SocketConfig, WAMessage, WAMessageKey } from '../Types/index.js';
3
- import type { ILogger } from './logger.js';
1
+ import { AxiosRequestConfig } from 'axios';
2
+ import type { Logger } from 'pino';
3
+ import { proto } from '../../WAProto';
4
+ import { AuthenticationCreds, BaileysEventEmitter, SignalKeyStoreWithTransaction, SocketConfig } from '../Types';
4
5
  type ProcessMessageContext = {
5
6
  shouldProcessHistoryMsg: boolean;
6
- placeholderResendCache?: CacheStore;
7
7
  creds: AuthenticationCreds;
8
8
  keyStore: SignalKeyStoreWithTransaction;
9
9
  ev: BaileysEventEmitter;
10
- logger?: ILogger;
11
- options: RequestInit;
12
- signalRepository: SignalRepositoryWithLIDStore;
13
10
  getMessage: SocketConfig['getMessage'];
11
+ logger?: Logger;
12
+ options: AxiosRequestConfig<{}>;
14
13
  };
15
14
  /** Cleans a received message to further processing */
16
- export declare const cleanMessage: (message: WAMessage, meId: string, meLid: string) => void;
17
- export declare const isRealMessage: (message: WAMessage) => boolean;
18
- export declare const shouldIncrementChatUnread: (message: WAMessage) => boolean;
15
+ export declare const cleanMessage: (message: proto.IWebMessageInfo, meId: string) => void;
16
+ export declare const isRealMessage: (message: proto.IWebMessageInfo, meId: string) => boolean | undefined;
17
+ export declare const shouldIncrementChatUnread: (message: proto.IWebMessageInfo) => boolean;
19
18
  /**
20
19
  * Get the ID of the chat from the given key.
21
20
  * Typically -- that'll be the remoteJid, but for broadcasts, it'll be the participant
22
21
  */
23
- export declare const getChatId: ({ remoteJid, participant, fromMe }: WAMessageKey) => string;
22
+ export declare const getChatId: ({ remoteJid, participant, fromMe }: proto.IMessageKey) => string;
24
23
  type PollContext = {
25
24
  /** normalised jid of the person that created the poll */
26
25
  pollCreatorJid: string;
@@ -31,30 +30,12 @@ type PollContext = {
31
30
  /** jid of the person that voted */
32
31
  voterJid: string;
33
32
  };
34
- type EventContext = {
35
- /** normalised jid of the person that created the event */
36
- eventCreatorJid: string;
37
- /** ID of the event creation message */
38
- eventMsgId: string;
39
- /** event creation message enc key */
40
- eventEncKey: Uint8Array;
41
- /** jid of the person that responded */
42
- responderJid: string;
43
- };
44
33
  /**
45
34
  * Decrypt a poll vote
46
35
  * @param vote encrypted vote
47
36
  * @param ctx additional info about the poll required for decryption
48
37
  * @returns list of SHA256 options
49
38
  */
50
- export declare function decryptPollVote({ encPayload, encIv }: proto.Message.IPollEncValue, { pollCreatorJid, pollMsgId, pollEncKey, voterJid }: PollContext): proto.Message.PollVoteMessage;
51
- /**
52
- * Decrypt an event response
53
- * @param response encrypted event response
54
- * @param ctx additional info about the event required for decryption
55
- * @returns event response message
56
- */
57
- export declare function decryptEventResponse({ encPayload, encIv }: proto.Message.IPollEncValue, { eventCreatorJid, eventMsgId, eventEncKey, responderJid }: EventContext): proto.Message.EventResponseMessage;
58
- declare const processMessage: (message: WAMessage, { shouldProcessHistoryMsg, placeholderResendCache, ev, creds, signalRepository, keyStore, logger, options, getMessage }: ProcessMessageContext) => Promise<void>;
39
+ export declare function decryptPollVote({ encPayload, encIv }: proto.Message.IPollEncValue, { pollCreatorJid, pollMsgId, pollEncKey, voterJid, }: PollContext): proto.Message.PollVoteMessage;
40
+ declare const processMessage: (message: proto.IWebMessageInfo, { shouldProcessHistoryMsg, ev, creds, keyStore, logger, options, getMessage }: ProcessMessageContext) => Promise<void>;
59
41
  export default processMessage;
60
- //# sourceMappingURL=process-message.d.ts.map