@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.
- package/WAProto/fix-import.js +29 -0
- package/WAProto/index.js +160 -201
- package/engine-requirements.js +1 -1
- package/lib/Defaults/baileys-version.json +3 -0
- package/lib/Defaults/index.d.ts +15 -37
- package/lib/Defaults/index.js +136 -119
- package/lib/Defaults/phonenumber-mcc.json +223 -0
- package/lib/Signal/Group/ciphertext-message.d.ts +0 -1
- package/lib/Signal/Group/ciphertext-message.js +5 -2
- package/lib/Signal/Group/group-session-builder.d.ts +3 -4
- package/lib/Signal/Group/group-session-builder.js +41 -7
- package/lib/Signal/Group/group_cipher.d.ts +4 -4
- package/lib/Signal/Group/group_cipher.js +51 -37
- package/lib/Signal/Group/index.d.ts +11 -12
- package/lib/Signal/Group/index.js +57 -12
- package/lib/Signal/Group/keyhelper.d.ts +1 -2
- package/lib/Signal/Group/keyhelper.js +44 -7
- package/lib/Signal/Group/queue-job.d.ts +1 -0
- package/lib/Signal/Group/queue-job.js +57 -0
- package/lib/Signal/Group/sender-chain-key.d.ts +2 -3
- package/lib/Signal/Group/sender-chain-key.js +15 -7
- package/lib/Signal/Group/sender-key-distribution-message.d.ts +1 -2
- package/lib/Signal/Group/sender-key-distribution-message.js +11 -8
- package/lib/Signal/Group/sender-key-message.d.ts +1 -2
- package/lib/Signal/Group/sender-key-message.js +12 -9
- package/lib/Signal/Group/sender-key-name.d.ts +0 -1
- package/lib/Signal/Group/sender-key-name.js +5 -2
- package/lib/Signal/Group/sender-key-record.d.ts +2 -3
- package/lib/Signal/Group/sender-key-record.js +21 -9
- package/lib/Signal/Group/sender-key-state.d.ts +6 -7
- package/lib/Signal/Group/sender-key-state.js +42 -27
- package/lib/Signal/Group/sender-message-key.d.ts +0 -1
- package/lib/Signal/Group/sender-message-key.js +7 -4
- package/lib/Signal/libsignal.d.ts +3 -5
- package/lib/Signal/libsignal.js +90 -347
- package/lib/Socket/Client/{types.d.ts → abstract-socket-client.d.ts} +5 -4
- package/lib/Socket/Client/abstract-socket-client.js +13 -0
- package/lib/Socket/Client/index.d.ts +3 -3
- package/lib/Socket/Client/index.js +19 -3
- package/lib/Socket/Client/mobile-socket-client.d.ts +13 -0
- package/lib/Socket/Client/mobile-socket-client.js +65 -0
- package/lib/Socket/Client/{websocket.d.ts → web-socket-client.d.ts} +2 -3
- package/lib/Socket/Client/web-socket-client.js +62 -0
- package/lib/Socket/business.d.ts +108 -154
- package/lib/Socket/business.js +43 -162
- package/lib/Socket/chats.d.ts +239 -96
- package/lib/Socket/chats.js +427 -627
- package/lib/Socket/communities.d.ts +146 -239
- package/lib/Socket/communities.js +80 -90
- package/lib/Socket/groups.d.ts +57 -104
- package/lib/Socket/groups.js +161 -154
- package/lib/Socket/index.d.ts +115 -202
- package/lib/Socket/index.js +10 -11
- package/lib/Socket/luxu.d.ts +266 -22
- package/lib/Socket/luxu.js +465 -422
- package/lib/Socket/messages-recv.d.ts +84 -136
- package/lib/Socket/messages-recv.js +615 -1421
- package/lib/Socket/messages-send.d.ts +126 -142
- package/lib/Socket/messages-send.js +671 -878
- package/lib/Socket/newsletter.d.ts +85 -121
- package/lib/Socket/newsletter.js +272 -147
- package/lib/Socket/registration.d.ts +267 -0
- package/lib/Socket/registration.js +166 -0
- package/lib/Socket/socket.d.ts +19 -34
- package/lib/Socket/socket.js +313 -544
- package/lib/Socket/usync.d.ts +36 -0
- package/lib/Socket/usync.js +70 -0
- package/lib/Store/index.d.ts +3 -10
- package/lib/Store/index.js +10 -10
- package/lib/Store/make-cache-manager-store.d.ts +11 -17
- package/lib/Store/make-cache-manager-store.js +41 -43
- package/lib/Store/make-in-memory-store.d.ts +118 -39
- package/lib/Store/make-in-memory-store.js +341 -112
- package/lib/Store/make-ordered-dictionary.d.ts +10 -11
- package/lib/Store/make-ordered-dictionary.js +20 -14
- package/lib/Store/object-repository.d.ts +9 -10
- package/lib/Store/object-repository.js +6 -11
- package/lib/Types/Auth.d.ts +12 -19
- package/lib/Types/Auth.js +2 -2
- package/lib/Types/Call.d.ts +1 -3
- package/lib/Types/Call.js +2 -2
- package/lib/Types/Chat.d.ts +13 -35
- package/lib/Types/Chat.js +4 -8
- package/lib/Types/Contact.d.ts +1 -8
- package/lib/Types/Contact.js +2 -2
- package/lib/Types/Events.d.ts +17 -116
- package/lib/Types/Events.js +2 -2
- package/lib/Types/GroupMetadata.d.ts +5 -21
- package/lib/Types/GroupMetadata.js +2 -2
- package/lib/Types/Label.d.ts +0 -12
- package/lib/Types/Label.js +5 -3
- package/lib/Types/LabelAssociation.d.ts +0 -1
- package/lib/Types/LabelAssociation.js +5 -3
- package/lib/Types/Message.d.ts +58 -105
- package/lib/Types/Message.js +9 -11
- package/lib/Types/Newsletter.d.ts +103 -0
- package/lib/Types/Newsletter.js +38 -0
- package/lib/Types/Product.d.ts +1 -2
- package/lib/Types/Product.js +2 -2
- package/lib/Types/Signal.d.ts +2 -32
- package/lib/Types/Signal.js +2 -2
- package/lib/Types/Socket.d.ts +25 -50
- package/lib/Types/Socket.js +2 -3
- package/lib/Types/State.d.ts +2 -72
- package/lib/Types/State.js +2 -56
- package/lib/Types/USync.d.ts +2 -3
- package/lib/Types/USync.js +2 -2
- package/lib/Types/index.d.ts +14 -22
- package/lib/Types/index.js +31 -15
- package/lib/Utils/auth-utils.d.ts +6 -12
- package/lib/Utils/auth-utils.js +143 -239
- package/lib/Utils/baileys-event-stream.d.ts +16 -0
- package/lib/Utils/baileys-event-stream.js +63 -0
- package/lib/Utils/business.d.ts +2 -3
- package/lib/Utils/business.js +69 -66
- package/lib/Utils/chat-utils.d.ts +23 -52
- package/lib/Utils/chat-utils.js +253 -396
- package/lib/Utils/crypto.d.ts +22 -18
- package/lib/Utils/crypto.js +90 -57
- package/lib/Utils/decode-wa-message.d.ts +8 -55
- package/lib/Utils/decode-wa-message.js +84 -203
- package/lib/Utils/event-buffer.d.ts +8 -9
- package/lib/Utils/event-buffer.js +77 -185
- package/lib/Utils/generics.d.ts +29 -28
- package/lib/Utils/generics.js +210 -180
- package/lib/Utils/history.d.ts +9 -18
- package/lib/Utils/history.js +55 -93
- package/lib/Utils/index.d.ts +17 -22
- package/lib/Utils/index.js +33 -22
- package/lib/Utils/link-preview.d.ts +5 -5
- package/lib/Utils/link-preview.js +24 -16
- package/lib/Utils/logger.d.ts +3 -11
- package/lib/Utils/logger.js +7 -3
- package/lib/Utils/lt-hash.d.ts +12 -8
- package/lib/Utils/lt-hash.js +46 -3
- package/lib/Utils/make-mutex.d.ts +2 -4
- package/lib/Utils/make-mutex.js +34 -24
- package/lib/Utils/messages-media.d.ts +44 -61
- package/lib/Utils/messages-media.js +482 -451
- package/lib/Utils/messages.d.ts +18 -32
- package/lib/Utils/messages.js +369 -458
- package/lib/Utils/noise-handler.d.ts +14 -13
- package/lib/Utils/noise-handler.js +99 -145
- package/lib/Utils/process-message.d.ts +12 -31
- package/lib/Utils/process-message.js +150 -459
- package/lib/Utils/signal.d.ts +5 -20
- package/lib/Utils/signal.js +72 -120
- package/lib/Utils/use-multi-file-auth-state.d.ts +2 -2
- package/lib/Utils/use-multi-file-auth-state.js +27 -29
- package/lib/Utils/validate-connection.d.ts +7 -7
- package/lib/Utils/validate-connection.js +99 -73
- package/lib/WABinary/constants.d.ts +27 -25
- package/lib/WABinary/constants.js +20 -1281
- package/lib/WABinary/decode.d.ts +5 -5
- package/lib/WABinary/decode.js +42 -52
- package/lib/WABinary/encode.d.ts +3 -3
- package/lib/WABinary/encode.js +155 -110
- package/lib/WABinary/generic-utils.d.ts +7 -8
- package/lib/WABinary/generic-utils.js +49 -48
- package/lib/WABinary/index.d.ts +5 -6
- package/lib/WABinary/index.js +21 -6
- package/lib/WABinary/jid-utils.d.ts +8 -25
- package/lib/WABinary/jid-utils.js +40 -74
- package/lib/WABinary/types.d.ts +1 -2
- package/lib/WABinary/types.js +2 -2
- package/lib/WAM/BinaryInfo.d.ts +11 -3
- package/lib/WAM/BinaryInfo.js +5 -2
- package/lib/WAM/constants.d.ts +3 -5
- package/lib/WAM/constants.js +11958 -19461
- package/lib/WAM/encode.d.ts +3 -3
- package/lib/WAM/encode.js +22 -17
- package/lib/WAM/index.d.ts +3 -4
- package/lib/WAM/index.js +19 -4
- package/lib/WAUSync/Protocols/USyncContactProtocol.d.ts +3 -4
- package/lib/WAUSync/Protocols/USyncContactProtocol.js +13 -33
- package/lib/WAUSync/Protocols/USyncDeviceProtocol.d.ts +2 -3
- package/lib/WAUSync/Protocols/USyncDeviceProtocol.js +14 -11
- package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.d.ts +2 -3
- package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.js +12 -9
- package/lib/WAUSync/Protocols/USyncStatusProtocol.d.ts +2 -3
- package/lib/WAUSync/Protocols/USyncStatusProtocol.js +13 -9
- package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.d.ts +3 -4
- package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.js +22 -20
- package/lib/WAUSync/Protocols/UsyncLIDProtocol.d.ts +3 -5
- package/lib/WAUSync/Protocols/UsyncLIDProtocol.js +8 -13
- package/lib/WAUSync/Protocols/index.d.ts +4 -6
- package/lib/WAUSync/Protocols/index.js +20 -6
- package/lib/WAUSync/USyncQuery.d.ts +4 -6
- package/lib/WAUSync/USyncQuery.js +35 -44
- package/lib/WAUSync/USyncUser.d.ts +5 -10
- package/lib/WAUSync/USyncUser.js +5 -10
- package/lib/WAUSync/index.js +19 -4
- package/lib/index.d.ts +9 -10
- package/lib/index.js +34 -12
- package/package.json +50 -83
- package/WAProto/GenerateStatics.sh +0 -3
- package/WAProto/WAProto.proto +0 -5479
- package/WAProto/fix-imports.js +0 -85
- package/WAProto/index.d.ts +0 -14017
- package/lib/Signal/lid-mapping.d.ts +0 -23
- package/lib/Signal/lid-mapping.js +0 -277
- package/lib/Socket/Client/types.js +0 -11
- package/lib/Socket/Client/websocket.js +0 -54
- package/lib/Socket/mex.d.ts +0 -3
- package/lib/Socket/mex.js +0 -42
- package/lib/Store/keyed-db.d.ts +0 -22
- package/lib/Store/keyed-db.js +0 -108
- package/lib/Types/Bussines.d.ts +0 -25
- package/lib/Types/Bussines.js +0 -2
- package/lib/Types/Mex.d.ts +0 -141
- package/lib/Types/Mex.js +0 -37
- package/lib/Utils/browser-utils.d.ts +0 -4
- package/lib/Utils/browser-utils.js +0 -28
- package/lib/Utils/companion-reg-client-utils.d.ts +0 -17
- package/lib/Utils/companion-reg-client-utils.js +0 -35
- package/lib/Utils/identity-change-handler.d.ts +0 -44
- package/lib/Utils/identity-change-handler.js +0 -50
- package/lib/Utils/message-retry-manager.d.ts +0 -115
- package/lib/Utils/message-retry-manager.js +0 -265
- package/lib/Utils/offline-node-processor.d.ts +0 -17
- package/lib/Utils/offline-node-processor.js +0 -40
- package/lib/Utils/pre-key-manager.d.ts +0 -28
- package/lib/Utils/pre-key-manager.js +0 -106
- package/lib/Utils/reporting-utils.d.ts +0 -11
- package/lib/Utils/reporting-utils.js +0 -258
- package/lib/Utils/stanza-ack.d.ts +0 -11
- package/lib/Utils/stanza-ack.js +0 -38
- package/lib/Utils/sync-action-utils.d.ts +0 -19
- package/lib/Utils/sync-action-utils.js +0 -49
- package/lib/Utils/tc-token-utils.d.ts +0 -37
- package/lib/Utils/tc-token-utils.js +0 -163
- package/lib/WAUSync/Protocols/USyncUsernameProtocol.d.ts +0 -10
- package/lib/WAUSync/Protocols/USyncUsernameProtocol.js +0 -25
- package/lib/WAUSync/index.d.ts +0 -4
|
@@ -1,20 +1,21 @@
|
|
|
1
|
-
|
|
2
|
-
import
|
|
3
|
-
import
|
|
4
|
-
import
|
|
5
|
-
|
|
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
|
-
|
|
9
|
+
mobile: boolean;
|
|
10
|
+
logger: Logger;
|
|
9
11
|
routingInfo?: Buffer | undefined;
|
|
10
12
|
}) => {
|
|
11
|
-
encrypt: (plaintext: Uint8Array) =>
|
|
12
|
-
decrypt: (ciphertext: 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: () =>
|
|
16
|
-
processHandshake: ({ serverHello }: proto.HandshakeMessage, noiseKey: KeyPair) =>
|
|
17
|
-
encodeFrame: (data: Buffer | Uint8Array) => Buffer
|
|
18
|
-
decodeFrame: (newData: Buffer | Uint8Array, onFrame: (buff: Uint8Array | BinaryNode) => 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
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
const
|
|
7
|
-
const
|
|
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(
|
|
10
|
+
const iv = new ArrayBuffer(12);
|
|
10
11
|
new DataView(iv).setUint32(8, counter);
|
|
11
12
|
return new Uint8Array(iv);
|
|
12
13
|
};
|
|
13
|
-
|
|
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 (!
|
|
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
|
-
|
|
72
|
-
|
|
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
|
-
|
|
80
|
-
|
|
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.
|
|
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
|
-
|
|
50
|
+
readCounter = 0;
|
|
51
|
+
writeCounter = 0;
|
|
96
52
|
};
|
|
97
|
-
const finishInit =
|
|
98
|
-
isWaitingForTransport = true;
|
|
53
|
+
const finishInit = () => {
|
|
99
54
|
const [write, read] = localHKDF(new Uint8Array(0));
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
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
|
-
|
|
144
|
-
|
|
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
|
-
|
|
162
|
-
|
|
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 (
|
|
170
|
-
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
|
|
173
|
-
const
|
|
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(
|
|
120
|
+
frame.set(header);
|
|
177
121
|
sentIntro = true;
|
|
178
122
|
}
|
|
179
|
-
frame
|
|
180
|
-
frame
|
|
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:
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
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
|
-
|
|
155
|
+
exports.makeNoiseHandler = makeNoiseHandler;
|
|
@@ -1,26 +1,25 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import type {
|
|
3
|
-
import
|
|
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:
|
|
17
|
-
export declare const isRealMessage: (message:
|
|
18
|
-
export declare const shouldIncrementChatUnread: (message:
|
|
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 }:
|
|
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
|