@queenanya/baileys 8.3.1 → 8.3.3
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/lib/Defaults/index.d.ts +0 -231
- package/lib/Defaults/index.js +1 -17
- package/lib/Signal/Group/ciphertext-message.d.ts +9 -0
- package/lib/Signal/Group/ciphertext-message.js +15 -0
- package/lib/Signal/Group/group-session-builder.d.ts +14 -0
- package/lib/Signal/Group/group-session-builder.js +64 -0
- package/lib/Signal/Group/group_cipher.d.ts +17 -0
- package/lib/Signal/Group/group_cipher.js +96 -0
- package/lib/Signal/Group/index.d.ts +11 -0
- package/lib/Signal/Group/index.js +57 -0
- package/lib/Signal/Group/keyhelper.d.ts +10 -0
- package/lib/Signal/Group/keyhelper.js +55 -0
- 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 +13 -0
- package/lib/Signal/Group/sender-chain-key.js +34 -0
- package/lib/Signal/Group/sender-key-distribution-message.d.ts +16 -0
- package/lib/Signal/Group/sender-key-distribution-message.js +66 -0
- package/lib/Signal/Group/sender-key-message.d.ts +18 -0
- package/lib/Signal/Group/sender-key-message.js +69 -0
- package/lib/Signal/Group/sender-key-name.d.ts +17 -0
- package/lib/Signal/Group/sender-key-name.js +51 -0
- package/lib/Signal/Group/sender-key-record.d.ts +30 -0
- package/lib/Signal/Group/sender-key-record.js +53 -0
- package/lib/Signal/Group/sender-key-state.d.ts +38 -0
- package/lib/Signal/Group/sender-key-state.js +99 -0
- package/lib/Signal/Group/sender-message-key.d.ts +11 -0
- package/{WASignalGroup/sender_message_key.js → lib/Signal/Group/sender-message-key.js} +6 -16
- package/lib/Signal/libsignal.js +33 -20
- package/lib/Socket/Client/index.d.ts +2 -3
- package/lib/Socket/Client/index.js +2 -3
- package/lib/Socket/Client/{abstract-socket-client.d.ts → types.d.ts} +1 -0
- package/lib/Socket/Client/{web-socket-client.d.ts → websocket.d.ts} +2 -1
- package/lib/Socket/Client/{web-socket-client.js → websocket.js} +12 -2
- package/lib/Socket/business.d.ts +3 -3
- package/lib/Socket/chat-set.d.ts +3 -0
- package/lib/Socket/chat-set.js +63 -0
- package/lib/Socket/chats.d.ts +1 -1
- package/lib/Socket/chats.js +11 -8
- package/lib/Socket/groups.d.ts +1 -1
- package/lib/Socket/index.d.ts +3 -5
- package/lib/Socket/index.js +2 -2
- package/lib/Socket/messages-recv.d.ts +3 -3
- package/lib/Socket/messages-recv.js +16 -8
- package/lib/Socket/messages-send.d.ts +2 -2
- package/lib/Socket/messages-send.js +75 -9
- package/lib/Socket/newsletter.d.ts +1 -1
- package/lib/Socket/socket.d.ts +2 -1
- package/lib/Socket/socket.js +71 -14
- package/lib/Socket/usync.d.ts +1 -1
- package/lib/Store/make-in-memory-store.js +8 -10
- package/lib/Types/Auth.d.ts +0 -6
- package/lib/Types/Message.d.ts +16 -3
- package/lib/Types/Socket.d.ts +3 -3
- package/lib/Utils/auth-utils.js +0 -7
- package/lib/Utils/event-buffer.js +4 -6
- package/lib/Utils/index.d.ts +1 -0
- package/lib/Utils/index.js +1 -0
- package/lib/Utils/messages-media.js +11 -10
- package/lib/Utils/messages.js +10 -2
- package/lib/Utils/midea-msg.d.ts +14 -0
- package/lib/Utils/midea-msg.js +72 -0
- package/lib/Utils/noise-handler.d.ts +1 -2
- package/lib/Utils/noise-handler.js +5 -10
- package/lib/Utils/use-single-file-auth-state.d.ts +5 -0
- package/lib/Utils/use-single-file-auth-state.js +66 -0
- package/lib/Utils/validate-connection.d.ts +0 -1
- package/lib/Utils/validate-connection.js +10 -44
- package/lib/WABinary/jid-utils.d.ts +1 -1
- package/lib/WABinary/jid-utils.js +1 -1
- package/package.json +2 -1
- package/WASignalGroup/GroupProtocol.js +0 -1697
- package/WASignalGroup/ciphertext_message.js +0 -16
- package/WASignalGroup/group_cipher.js +0 -120
- package/WASignalGroup/group_session_builder.js +0 -46
- package/WASignalGroup/index.js +0 -5
- package/WASignalGroup/keyhelper.js +0 -21
- package/WASignalGroup/protobufs.js +0 -3
- package/WASignalGroup/queue_job.js +0 -69
- package/WASignalGroup/sender_chain_key.js +0 -50
- package/WASignalGroup/sender_key_distribution_message.js +0 -78
- package/WASignalGroup/sender_key_message.js +0 -92
- package/WASignalGroup/sender_key_name.js +0 -70
- package/WASignalGroup/sender_key_record.js +0 -56
- package/WASignalGroup/sender_key_state.js +0 -129
- package/lib/Defaults/phonenumber-mcc.json +0 -223
- package/lib/Socket/Client/mobile-socket-client.d.ts +0 -12
- package/lib/Socket/Client/mobile-socket-client.js +0 -65
- package/lib/Socket/registration.d.ts +0 -266
- package/lib/Socket/registration.js +0 -166
- /package/lib/Socket/Client/{abstract-socket-client.js → types.js} +0 -0
package/lib/Defaults/index.d.ts
CHANGED
|
@@ -1,246 +1,15 @@
|
|
|
1
1
|
import { proto } from '../../WAProto';
|
|
2
2
|
import type { MediaType, SocketConfig } from '../Types';
|
|
3
3
|
export declare const UNAUTHORIZED_CODES: number[];
|
|
4
|
-
export declare const PHONENUMBER_MCC: {
|
|
5
|
-
"93": number;
|
|
6
|
-
"355": number;
|
|
7
|
-
"213": number;
|
|
8
|
-
"1-684": number;
|
|
9
|
-
"376": number;
|
|
10
|
-
"244": number;
|
|
11
|
-
"1-264": number;
|
|
12
|
-
"1-268": number;
|
|
13
|
-
"54": number;
|
|
14
|
-
"374": number;
|
|
15
|
-
"297": number;
|
|
16
|
-
"61": number;
|
|
17
|
-
"43": number;
|
|
18
|
-
"994": number;
|
|
19
|
-
"1-242": number;
|
|
20
|
-
"973": number;
|
|
21
|
-
"880": number;
|
|
22
|
-
"1-246": number;
|
|
23
|
-
"375": number;
|
|
24
|
-
"32": number;
|
|
25
|
-
"501": number;
|
|
26
|
-
"229": number;
|
|
27
|
-
"1-441": number;
|
|
28
|
-
"975": number;
|
|
29
|
-
"591": number;
|
|
30
|
-
"387": number;
|
|
31
|
-
"267": number;
|
|
32
|
-
"55": number;
|
|
33
|
-
"1-284": number;
|
|
34
|
-
"673": number;
|
|
35
|
-
"359": number;
|
|
36
|
-
"226": number;
|
|
37
|
-
"257": number;
|
|
38
|
-
"855": number;
|
|
39
|
-
"237": number;
|
|
40
|
-
"238": number;
|
|
41
|
-
"1-345": number;
|
|
42
|
-
"236": number;
|
|
43
|
-
"235": number;
|
|
44
|
-
"56": number;
|
|
45
|
-
"86": number;
|
|
46
|
-
"57": number;
|
|
47
|
-
"269": number;
|
|
48
|
-
"682": number;
|
|
49
|
-
"506": number;
|
|
50
|
-
"385": number;
|
|
51
|
-
"53": number;
|
|
52
|
-
"357": number;
|
|
53
|
-
"420": number;
|
|
54
|
-
"243": number;
|
|
55
|
-
"45": number;
|
|
56
|
-
"253": number;
|
|
57
|
-
"1-767": number;
|
|
58
|
-
"1-809": number;
|
|
59
|
-
"1-849": number;
|
|
60
|
-
"1-829": number;
|
|
61
|
-
"593": number;
|
|
62
|
-
"20": number;
|
|
63
|
-
"503": number;
|
|
64
|
-
"240": number;
|
|
65
|
-
"291": number;
|
|
66
|
-
"372": number;
|
|
67
|
-
"251": number;
|
|
68
|
-
"500": number;
|
|
69
|
-
"298": number;
|
|
70
|
-
"679": number;
|
|
71
|
-
"358": number;
|
|
72
|
-
"33": number;
|
|
73
|
-
"689": number;
|
|
74
|
-
"241": number;
|
|
75
|
-
"220": number;
|
|
76
|
-
"995": number;
|
|
77
|
-
"49": number;
|
|
78
|
-
"233": number;
|
|
79
|
-
"350": number;
|
|
80
|
-
"30": number;
|
|
81
|
-
"299": number;
|
|
82
|
-
"1-473": number;
|
|
83
|
-
"1-671": number;
|
|
84
|
-
"502": number;
|
|
85
|
-
"224": number;
|
|
86
|
-
"592": number;
|
|
87
|
-
"509": number;
|
|
88
|
-
"504": number;
|
|
89
|
-
"852": number;
|
|
90
|
-
"36": number;
|
|
91
|
-
"354": number;
|
|
92
|
-
"91": number;
|
|
93
|
-
"62": number;
|
|
94
|
-
"98": number;
|
|
95
|
-
"964": number;
|
|
96
|
-
"353": number;
|
|
97
|
-
"972": number;
|
|
98
|
-
"39": number;
|
|
99
|
-
"225": number;
|
|
100
|
-
"1-876": number;
|
|
101
|
-
"81": number;
|
|
102
|
-
"962": number;
|
|
103
|
-
"254": number;
|
|
104
|
-
"686": number;
|
|
105
|
-
"383": number;
|
|
106
|
-
"965": number;
|
|
107
|
-
"371": number;
|
|
108
|
-
"961": number;
|
|
109
|
-
"266": number;
|
|
110
|
-
"231": number;
|
|
111
|
-
"218": number;
|
|
112
|
-
"423": number;
|
|
113
|
-
"370": number;
|
|
114
|
-
"352": number;
|
|
115
|
-
"389": number;
|
|
116
|
-
"261": number;
|
|
117
|
-
"265": number;
|
|
118
|
-
"60": number;
|
|
119
|
-
"960": number;
|
|
120
|
-
"223": number;
|
|
121
|
-
"356": number;
|
|
122
|
-
"692": number;
|
|
123
|
-
"222": number;
|
|
124
|
-
"230": number;
|
|
125
|
-
"52": number;
|
|
126
|
-
"691": number;
|
|
127
|
-
"373": number;
|
|
128
|
-
"377": number;
|
|
129
|
-
"976": number;
|
|
130
|
-
"382": number;
|
|
131
|
-
"1-664": number;
|
|
132
|
-
"212": number;
|
|
133
|
-
"258": number;
|
|
134
|
-
"95": number;
|
|
135
|
-
"264": number;
|
|
136
|
-
"674": number;
|
|
137
|
-
"977": number;
|
|
138
|
-
"31": number;
|
|
139
|
-
"687": number;
|
|
140
|
-
"64": number;
|
|
141
|
-
"505": number;
|
|
142
|
-
"227": number;
|
|
143
|
-
"234": number;
|
|
144
|
-
"683": number;
|
|
145
|
-
"1-670": number;
|
|
146
|
-
"47": number;
|
|
147
|
-
"968": number;
|
|
148
|
-
"92": number;
|
|
149
|
-
"680": number;
|
|
150
|
-
"970": number;
|
|
151
|
-
"507": number;
|
|
152
|
-
"675": number;
|
|
153
|
-
"595": number;
|
|
154
|
-
"51": number;
|
|
155
|
-
"63": number;
|
|
156
|
-
"48": number;
|
|
157
|
-
"351": number;
|
|
158
|
-
"1-787, 1-939": number;
|
|
159
|
-
"974": number;
|
|
160
|
-
"242": number;
|
|
161
|
-
"40": number;
|
|
162
|
-
"7": number;
|
|
163
|
-
"250": number;
|
|
164
|
-
"290": number;
|
|
165
|
-
"1-869": number;
|
|
166
|
-
"1-758": number;
|
|
167
|
-
"508": number;
|
|
168
|
-
"1-784": number;
|
|
169
|
-
"685": number;
|
|
170
|
-
"378": number;
|
|
171
|
-
"239": number;
|
|
172
|
-
"966": number;
|
|
173
|
-
"221": number;
|
|
174
|
-
"381": number;
|
|
175
|
-
"248": number;
|
|
176
|
-
"232": number;
|
|
177
|
-
"65": number;
|
|
178
|
-
"386": number;
|
|
179
|
-
"677": number;
|
|
180
|
-
"27": number;
|
|
181
|
-
"211": number;
|
|
182
|
-
"34": number;
|
|
183
|
-
"94": number;
|
|
184
|
-
"249": number;
|
|
185
|
-
"597": number;
|
|
186
|
-
"268": number;
|
|
187
|
-
"46": number;
|
|
188
|
-
"41": number;
|
|
189
|
-
"963": number;
|
|
190
|
-
"886": number;
|
|
191
|
-
"992": number;
|
|
192
|
-
"255": number;
|
|
193
|
-
"66": number;
|
|
194
|
-
"228": number;
|
|
195
|
-
"690": number;
|
|
196
|
-
"676": number;
|
|
197
|
-
"1-868": number;
|
|
198
|
-
"216": number;
|
|
199
|
-
"90": number;
|
|
200
|
-
"993": number;
|
|
201
|
-
"1-649": number;
|
|
202
|
-
"688": number;
|
|
203
|
-
"1-340": number;
|
|
204
|
-
"256": number;
|
|
205
|
-
"380": number;
|
|
206
|
-
"971": number;
|
|
207
|
-
"44": number;
|
|
208
|
-
"1": number;
|
|
209
|
-
"598": number;
|
|
210
|
-
"998": number;
|
|
211
|
-
"678": number;
|
|
212
|
-
"379": number;
|
|
213
|
-
"58": number;
|
|
214
|
-
"681": number;
|
|
215
|
-
"967": number;
|
|
216
|
-
"260": number;
|
|
217
|
-
"263": number;
|
|
218
|
-
"670": number;
|
|
219
|
-
"245": number;
|
|
220
|
-
"856": number;
|
|
221
|
-
"599": number;
|
|
222
|
-
"850": number;
|
|
223
|
-
"262": number;
|
|
224
|
-
"82": number;
|
|
225
|
-
"84": number;
|
|
226
|
-
};
|
|
227
4
|
export declare const DEFAULT_ORIGIN = "https://web.whatsapp.com";
|
|
228
|
-
export declare const MOBILE_ENDPOINT = "g.whatsapp.net";
|
|
229
|
-
export declare const MOBILE_PORT = 443;
|
|
230
5
|
export declare const DEF_CALLBACK_PREFIX = "CB:";
|
|
231
6
|
export declare const DEF_TAG_PREFIX = "TAG:";
|
|
232
7
|
export declare const PHONE_CONNECTION_CB = "CB:Pong";
|
|
233
8
|
export declare const WA_DEFAULT_EPHEMERAL: number;
|
|
234
|
-
export declare const MOBILE_TOKEN: Buffer<ArrayBuffer>;
|
|
235
|
-
export declare const MOBILE_REGISTRATION_ENDPOINT = "https://v.whatsapp.net/v2";
|
|
236
|
-
export declare const MOBILE_USERAGENT = "WhatsApp/2.24.6.77 iOS/15.3.1 Device/Apple-iPhone_7";
|
|
237
|
-
export declare const REGISTRATION_PUBLIC_KEY: Buffer<ArrayBuffer>;
|
|
238
9
|
export declare const NOISE_MODE = "Noise_XX_25519_AESGCM_SHA256\0\0\0\0";
|
|
239
10
|
export declare const DICT_VERSION = 3;
|
|
240
11
|
export declare const KEY_BUNDLE_TYPE: Buffer<ArrayBuffer>;
|
|
241
12
|
export declare const NOISE_WA_HEADER: Buffer<ArrayBuffer>;
|
|
242
|
-
export declare const PROTOCOL_VERSION: number[];
|
|
243
|
-
export declare const MOBILE_NOISE_HEADER: Buffer<ArrayBuffer>;
|
|
244
13
|
/** from: https://stackoverflow.com/questions/3809401/what-is-a-good-regular-expression-to-match-a-url */
|
|
245
14
|
export declare const URL_REGEX: RegExp;
|
|
246
15
|
export declare const WA_CERT_DETAILS: {
|
package/lib/Defaults/index.js
CHANGED
|
@@ -3,38 +3,22 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
3
3
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
4
|
};
|
|
5
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
exports.DEFAULT_CACHE_TTLS = exports.INITIAL_PREKEY_COUNT = exports.MIN_PREKEY_COUNT = exports.MEDIA_KEYS = exports.MEDIA_HKDF_KEY_MAPPING = exports.MEDIA_PATH_MAP = exports.DEFAULT_CONNECTION_CONFIG = exports.PROCESSABLE_HISTORY_TYPES = exports.WA_CERT_DETAILS = exports.URL_REGEX = exports.
|
|
7
|
-
const crypto_1 = require("crypto");
|
|
6
|
+
exports.DEFAULT_CACHE_TTLS = exports.INITIAL_PREKEY_COUNT = exports.MIN_PREKEY_COUNT = exports.MEDIA_KEYS = exports.MEDIA_HKDF_KEY_MAPPING = exports.MEDIA_PATH_MAP = exports.DEFAULT_CONNECTION_CONFIG = exports.PROCESSABLE_HISTORY_TYPES = exports.WA_CERT_DETAILS = exports.URL_REGEX = exports.NOISE_WA_HEADER = exports.KEY_BUNDLE_TYPE = exports.DICT_VERSION = exports.NOISE_MODE = exports.WA_DEFAULT_EPHEMERAL = exports.PHONE_CONNECTION_CB = exports.DEF_TAG_PREFIX = exports.DEF_CALLBACK_PREFIX = exports.DEFAULT_ORIGIN = exports.UNAUTHORIZED_CODES = void 0;
|
|
8
7
|
const WAProto_1 = require("../../WAProto");
|
|
9
8
|
const libsignal_1 = require("../Signal/libsignal");
|
|
10
9
|
const Utils_1 = require("../Utils");
|
|
11
10
|
const logger_1 = __importDefault(require("../Utils/logger"));
|
|
12
11
|
const baileys_version_json_1 = require("./baileys-version.json");
|
|
13
|
-
const phonenumber_mcc_json_1 = __importDefault(require("./phonenumber-mcc.json"));
|
|
14
12
|
exports.UNAUTHORIZED_CODES = [401, 403, 419];
|
|
15
|
-
exports.PHONENUMBER_MCC = phonenumber_mcc_json_1.default;
|
|
16
13
|
exports.DEFAULT_ORIGIN = 'https://web.whatsapp.com';
|
|
17
|
-
exports.MOBILE_ENDPOINT = 'g.whatsapp.net';
|
|
18
|
-
exports.MOBILE_PORT = 443;
|
|
19
14
|
exports.DEF_CALLBACK_PREFIX = 'CB:';
|
|
20
15
|
exports.DEF_TAG_PREFIX = 'TAG:';
|
|
21
16
|
exports.PHONE_CONNECTION_CB = 'CB:Pong';
|
|
22
17
|
exports.WA_DEFAULT_EPHEMERAL = 7 * 24 * 60 * 60;
|
|
23
|
-
const WA_VERSION = '2.24.6.77';
|
|
24
|
-
const WA_VERSION_HASH = (0, crypto_1.createHash)('md5').update(WA_VERSION).digest('hex');
|
|
25
|
-
exports.MOBILE_TOKEN = Buffer.from('0a1mLfGUIBVrMKF1RdvLI5lkRBvof6vn0fD2QRSM' + WA_VERSION_HASH);
|
|
26
|
-
exports.MOBILE_REGISTRATION_ENDPOINT = 'https://v.whatsapp.net/v2';
|
|
27
|
-
exports.MOBILE_USERAGENT = `WhatsApp/${WA_VERSION} iOS/15.3.1 Device/Apple-iPhone_7`;
|
|
28
|
-
exports.REGISTRATION_PUBLIC_KEY = Buffer.from([
|
|
29
|
-
5, 142, 140, 15, 116, 195, 235, 197, 215, 166, 134, 92, 108, 60, 132, 56, 86, 176, 97, 33, 204, 232, 234, 119, 77,
|
|
30
|
-
34, 251, 111, 18, 37, 18, 48, 45,
|
|
31
|
-
]);
|
|
32
18
|
exports.NOISE_MODE = 'Noise_XX_25519_AESGCM_SHA256\0\0\0\0';
|
|
33
19
|
exports.DICT_VERSION = 3;
|
|
34
20
|
exports.KEY_BUNDLE_TYPE = Buffer.from([5]);
|
|
35
21
|
exports.NOISE_WA_HEADER = Buffer.from([87, 65, 6, exports.DICT_VERSION]); // last is "DICT_VERSION"
|
|
36
|
-
exports.PROTOCOL_VERSION = [5, 2];
|
|
37
|
-
exports.MOBILE_NOISE_HEADER = Buffer.concat([Buffer.from('WA'), Buffer.from(exports.PROTOCOL_VERSION)]);
|
|
38
22
|
/** from: https://stackoverflow.com/questions/3809401/what-is-a-good-regular-expression-to-match-a-url */
|
|
39
23
|
exports.URL_REGEX = /https:\/\/(?![^:@\/\s]+:[^:@\/\s]+@)[a-zA-Z0-9.-]+\.[a-zA-Z]{2,}(:\d+)?(\/[^\s]*)?/g;
|
|
40
24
|
exports.WA_CERT_DETAILS = {
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
export declare class CiphertextMessage {
|
|
2
|
+
readonly UNSUPPORTED_VERSION: number;
|
|
3
|
+
readonly CURRENT_VERSION: number;
|
|
4
|
+
readonly WHISPER_TYPE: number;
|
|
5
|
+
readonly PREKEY_TYPE: number;
|
|
6
|
+
readonly SENDERKEY_TYPE: number;
|
|
7
|
+
readonly SENDERKEY_DISTRIBUTION_TYPE: number;
|
|
8
|
+
readonly ENCRYPTED_MESSAGE_OVERHEAD: number;
|
|
9
|
+
}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.CiphertextMessage = void 0;
|
|
4
|
+
class CiphertextMessage {
|
|
5
|
+
constructor() {
|
|
6
|
+
this.UNSUPPORTED_VERSION = 1;
|
|
7
|
+
this.CURRENT_VERSION = 3;
|
|
8
|
+
this.WHISPER_TYPE = 2;
|
|
9
|
+
this.PREKEY_TYPE = 3;
|
|
10
|
+
this.SENDERKEY_TYPE = 4;
|
|
11
|
+
this.SENDERKEY_DISTRIBUTION_TYPE = 5;
|
|
12
|
+
this.ENCRYPTED_MESSAGE_OVERHEAD = 53;
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
exports.CiphertextMessage = CiphertextMessage;
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { SenderKeyDistributionMessage } from './sender-key-distribution-message';
|
|
2
|
+
import { SenderKeyName } from './sender-key-name';
|
|
3
|
+
import { SenderKeyRecord } from './sender-key-record';
|
|
4
|
+
interface SenderKeyStore {
|
|
5
|
+
loadSenderKey(senderKeyName: SenderKeyName): Promise<SenderKeyRecord>;
|
|
6
|
+
storeSenderKey(senderKeyName: SenderKeyName, record: SenderKeyRecord): Promise<void>;
|
|
7
|
+
}
|
|
8
|
+
export declare class GroupSessionBuilder {
|
|
9
|
+
private readonly senderKeyStore;
|
|
10
|
+
constructor(senderKeyStore: SenderKeyStore);
|
|
11
|
+
process(senderKeyName: SenderKeyName, senderKeyDistributionMessage: SenderKeyDistributionMessage): Promise<void>;
|
|
12
|
+
create(senderKeyName: SenderKeyName): Promise<SenderKeyDistributionMessage>;
|
|
13
|
+
}
|
|
14
|
+
export {};
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
+
exports.GroupSessionBuilder = void 0;
|
|
37
|
+
const keyhelper = __importStar(require("./keyhelper"));
|
|
38
|
+
const sender_key_distribution_message_1 = require("./sender-key-distribution-message");
|
|
39
|
+
class GroupSessionBuilder {
|
|
40
|
+
constructor(senderKeyStore) {
|
|
41
|
+
this.senderKeyStore = senderKeyStore;
|
|
42
|
+
}
|
|
43
|
+
async process(senderKeyName, senderKeyDistributionMessage) {
|
|
44
|
+
const senderKeyRecord = await this.senderKeyStore.loadSenderKey(senderKeyName);
|
|
45
|
+
senderKeyRecord.addSenderKeyState(senderKeyDistributionMessage.getId(), senderKeyDistributionMessage.getIteration(), senderKeyDistributionMessage.getChainKey(), senderKeyDistributionMessage.getSignatureKey());
|
|
46
|
+
await this.senderKeyStore.storeSenderKey(senderKeyName, senderKeyRecord);
|
|
47
|
+
}
|
|
48
|
+
async create(senderKeyName) {
|
|
49
|
+
const senderKeyRecord = await this.senderKeyStore.loadSenderKey(senderKeyName);
|
|
50
|
+
if (senderKeyRecord.isEmpty()) {
|
|
51
|
+
const keyId = keyhelper.generateSenderKeyId();
|
|
52
|
+
const senderKey = keyhelper.generateSenderKey();
|
|
53
|
+
const signingKey = keyhelper.generateSenderSigningKey();
|
|
54
|
+
senderKeyRecord.setSenderKeyState(keyId, 0, senderKey, signingKey);
|
|
55
|
+
await this.senderKeyStore.storeSenderKey(senderKeyName, senderKeyRecord);
|
|
56
|
+
}
|
|
57
|
+
const state = senderKeyRecord.getSenderKeyState();
|
|
58
|
+
if (!state) {
|
|
59
|
+
throw new Error('No session state available');
|
|
60
|
+
}
|
|
61
|
+
return new sender_key_distribution_message_1.SenderKeyDistributionMessage(state.getKeyId(), state.getSenderChainKey().getIteration(), state.getSenderChainKey().getSeed(), state.getSigningKeyPublic());
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
exports.GroupSessionBuilder = GroupSessionBuilder;
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { SenderKeyName } from './sender-key-name';
|
|
2
|
+
import { SenderKeyRecord } from './sender-key-record';
|
|
3
|
+
export interface SenderKeyStore {
|
|
4
|
+
loadSenderKey(senderKeyName: SenderKeyName): Promise<SenderKeyRecord>;
|
|
5
|
+
storeSenderKey(senderKeyName: SenderKeyName, record: SenderKeyRecord): Promise<void>;
|
|
6
|
+
}
|
|
7
|
+
export declare class GroupCipher {
|
|
8
|
+
private readonly senderKeyStore;
|
|
9
|
+
private readonly senderKeyName;
|
|
10
|
+
constructor(senderKeyStore: SenderKeyStore, senderKeyName: SenderKeyName);
|
|
11
|
+
private queueJob;
|
|
12
|
+
encrypt(paddedPlaintext: Uint8Array | string): Promise<Uint8Array>;
|
|
13
|
+
decrypt(senderKeyMessageBytes: Uint8Array): Promise<Uint8Array>;
|
|
14
|
+
private getSenderKey;
|
|
15
|
+
private getPlainText;
|
|
16
|
+
private getCipherText;
|
|
17
|
+
}
|
|
@@ -0,0 +1,96 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.GroupCipher = void 0;
|
|
7
|
+
const crypto_1 = require("libsignal/src/crypto");
|
|
8
|
+
const queue_job_1 = __importDefault(require("./queue-job"));
|
|
9
|
+
const sender_key_message_1 = require("./sender-key-message");
|
|
10
|
+
class GroupCipher {
|
|
11
|
+
constructor(senderKeyStore, senderKeyName) {
|
|
12
|
+
this.senderKeyStore = senderKeyStore;
|
|
13
|
+
this.senderKeyName = senderKeyName;
|
|
14
|
+
}
|
|
15
|
+
queueJob(awaitable) {
|
|
16
|
+
return (0, queue_job_1.default)(this.senderKeyName.toString(), awaitable);
|
|
17
|
+
}
|
|
18
|
+
async encrypt(paddedPlaintext) {
|
|
19
|
+
return await this.queueJob(async () => {
|
|
20
|
+
const record = await this.senderKeyStore.loadSenderKey(this.senderKeyName);
|
|
21
|
+
if (!record) {
|
|
22
|
+
throw new Error('No SenderKeyRecord found for encryption');
|
|
23
|
+
}
|
|
24
|
+
const senderKeyState = record.getSenderKeyState();
|
|
25
|
+
if (!senderKeyState) {
|
|
26
|
+
throw new Error('No session to encrypt message');
|
|
27
|
+
}
|
|
28
|
+
const iteration = senderKeyState.getSenderChainKey().getIteration();
|
|
29
|
+
const senderKey = this.getSenderKey(senderKeyState, iteration === 0 ? 0 : iteration + 1);
|
|
30
|
+
const ciphertext = await this.getCipherText(senderKey.getIv(), senderKey.getCipherKey(), paddedPlaintext);
|
|
31
|
+
const senderKeyMessage = new sender_key_message_1.SenderKeyMessage(senderKeyState.getKeyId(), senderKey.getIteration(), ciphertext, senderKeyState.getSigningKeyPrivate());
|
|
32
|
+
await this.senderKeyStore.storeSenderKey(this.senderKeyName, record);
|
|
33
|
+
return senderKeyMessage.serialize();
|
|
34
|
+
});
|
|
35
|
+
}
|
|
36
|
+
async decrypt(senderKeyMessageBytes) {
|
|
37
|
+
return await this.queueJob(async () => {
|
|
38
|
+
const record = await this.senderKeyStore.loadSenderKey(this.senderKeyName);
|
|
39
|
+
if (!record) {
|
|
40
|
+
throw new Error('No SenderKeyRecord found for decryption');
|
|
41
|
+
}
|
|
42
|
+
const senderKeyMessage = new sender_key_message_1.SenderKeyMessage(null, null, null, null, senderKeyMessageBytes);
|
|
43
|
+
const senderKeyState = record.getSenderKeyState(senderKeyMessage.getKeyId());
|
|
44
|
+
if (!senderKeyState) {
|
|
45
|
+
throw new Error('No session found to decrypt message');
|
|
46
|
+
}
|
|
47
|
+
senderKeyMessage.verifySignature(senderKeyState.getSigningKeyPublic());
|
|
48
|
+
const senderKey = this.getSenderKey(senderKeyState, senderKeyMessage.getIteration());
|
|
49
|
+
const plaintext = await this.getPlainText(senderKey.getIv(), senderKey.getCipherKey(), senderKeyMessage.getCipherText());
|
|
50
|
+
await this.senderKeyStore.storeSenderKey(this.senderKeyName, record);
|
|
51
|
+
return plaintext;
|
|
52
|
+
});
|
|
53
|
+
}
|
|
54
|
+
getSenderKey(senderKeyState, iteration) {
|
|
55
|
+
let senderChainKey = senderKeyState.getSenderChainKey();
|
|
56
|
+
if (senderChainKey.getIteration() > iteration) {
|
|
57
|
+
if (senderKeyState.hasSenderMessageKey(iteration)) {
|
|
58
|
+
const messageKey = senderKeyState.removeSenderMessageKey(iteration);
|
|
59
|
+
if (!messageKey) {
|
|
60
|
+
throw new Error('No sender message key found for iteration');
|
|
61
|
+
}
|
|
62
|
+
return messageKey;
|
|
63
|
+
}
|
|
64
|
+
throw new Error(`Received message with old counter: ${senderChainKey.getIteration()}, ${iteration}`);
|
|
65
|
+
}
|
|
66
|
+
if (iteration - senderChainKey.getIteration() > 2000) {
|
|
67
|
+
throw new Error('Over 2000 messages into the future!');
|
|
68
|
+
}
|
|
69
|
+
while (senderChainKey.getIteration() < iteration) {
|
|
70
|
+
senderKeyState.addSenderMessageKey(senderChainKey.getSenderMessageKey());
|
|
71
|
+
senderChainKey = senderChainKey.getNext();
|
|
72
|
+
}
|
|
73
|
+
senderKeyState.setSenderChainKey(senderChainKey.getNext());
|
|
74
|
+
return senderChainKey.getSenderMessageKey();
|
|
75
|
+
}
|
|
76
|
+
async getPlainText(iv, key, ciphertext) {
|
|
77
|
+
try {
|
|
78
|
+
return (0, crypto_1.decrypt)(key, ciphertext, iv);
|
|
79
|
+
}
|
|
80
|
+
catch (e) {
|
|
81
|
+
throw new Error('InvalidMessageException');
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
async getCipherText(iv, key, plaintext) {
|
|
85
|
+
try {
|
|
86
|
+
const ivBuffer = typeof iv === 'string' ? Buffer.from(iv, 'base64') : iv;
|
|
87
|
+
const keyBuffer = typeof key === 'string' ? Buffer.from(key, 'base64') : key;
|
|
88
|
+
const plaintextBuffer = typeof plaintext === 'string' ? Buffer.from(plaintext) : plaintext;
|
|
89
|
+
return (0, crypto_1.encrypt)(keyBuffer, plaintextBuffer, ivBuffer);
|
|
90
|
+
}
|
|
91
|
+
catch (e) {
|
|
92
|
+
throw new Error('InvalidMessageException');
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
exports.GroupCipher = GroupCipher;
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
export { GroupSessionBuilder } from './group-session-builder';
|
|
2
|
+
export { SenderKeyDistributionMessage } from './sender-key-distribution-message';
|
|
3
|
+
export { SenderKeyRecord } from './sender-key-record';
|
|
4
|
+
export { SenderKeyName } from './sender-key-name';
|
|
5
|
+
export { GroupCipher } from './group_cipher';
|
|
6
|
+
export { SenderKeyState } from './sender-key-state';
|
|
7
|
+
export { SenderKeyMessage } from './sender-key-message';
|
|
8
|
+
export { SenderMessageKey } from './sender-message-key';
|
|
9
|
+
export { SenderChainKey } from './sender-chain-key';
|
|
10
|
+
export { CiphertextMessage } from './ciphertext-message';
|
|
11
|
+
export * as keyhelper from './keyhelper';
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
+
exports.keyhelper = exports.CiphertextMessage = exports.SenderChainKey = exports.SenderMessageKey = exports.SenderKeyMessage = exports.SenderKeyState = exports.GroupCipher = exports.SenderKeyName = exports.SenderKeyRecord = exports.SenderKeyDistributionMessage = exports.GroupSessionBuilder = void 0;
|
|
37
|
+
var group_session_builder_1 = require("./group-session-builder");
|
|
38
|
+
Object.defineProperty(exports, "GroupSessionBuilder", { enumerable: true, get: function () { return group_session_builder_1.GroupSessionBuilder; } });
|
|
39
|
+
var sender_key_distribution_message_1 = require("./sender-key-distribution-message");
|
|
40
|
+
Object.defineProperty(exports, "SenderKeyDistributionMessage", { enumerable: true, get: function () { return sender_key_distribution_message_1.SenderKeyDistributionMessage; } });
|
|
41
|
+
var sender_key_record_1 = require("./sender-key-record");
|
|
42
|
+
Object.defineProperty(exports, "SenderKeyRecord", { enumerable: true, get: function () { return sender_key_record_1.SenderKeyRecord; } });
|
|
43
|
+
var sender_key_name_1 = require("./sender-key-name");
|
|
44
|
+
Object.defineProperty(exports, "SenderKeyName", { enumerable: true, get: function () { return sender_key_name_1.SenderKeyName; } });
|
|
45
|
+
var group_cipher_1 = require("./group_cipher");
|
|
46
|
+
Object.defineProperty(exports, "GroupCipher", { enumerable: true, get: function () { return group_cipher_1.GroupCipher; } });
|
|
47
|
+
var sender_key_state_1 = require("./sender-key-state");
|
|
48
|
+
Object.defineProperty(exports, "SenderKeyState", { enumerable: true, get: function () { return sender_key_state_1.SenderKeyState; } });
|
|
49
|
+
var sender_key_message_1 = require("./sender-key-message");
|
|
50
|
+
Object.defineProperty(exports, "SenderKeyMessage", { enumerable: true, get: function () { return sender_key_message_1.SenderKeyMessage; } });
|
|
51
|
+
var sender_message_key_1 = require("./sender-message-key");
|
|
52
|
+
Object.defineProperty(exports, "SenderMessageKey", { enumerable: true, get: function () { return sender_message_key_1.SenderMessageKey; } });
|
|
53
|
+
var sender_chain_key_1 = require("./sender-chain-key");
|
|
54
|
+
Object.defineProperty(exports, "SenderChainKey", { enumerable: true, get: function () { return sender_chain_key_1.SenderChainKey; } });
|
|
55
|
+
var ciphertext_message_1 = require("./ciphertext-message");
|
|
56
|
+
Object.defineProperty(exports, "CiphertextMessage", { enumerable: true, get: function () { return ciphertext_message_1.CiphertextMessage; } });
|
|
57
|
+
exports.keyhelper = __importStar(require("./keyhelper"));
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { generateKeyPair } from 'libsignal/src/curve';
|
|
2
|
+
type KeyPairType = ReturnType<typeof generateKeyPair>;
|
|
3
|
+
export declare function generateSenderKey(): Buffer;
|
|
4
|
+
export declare function generateSenderKeyId(): number;
|
|
5
|
+
export interface SigningKeyPair {
|
|
6
|
+
public: Buffer;
|
|
7
|
+
private: Buffer;
|
|
8
|
+
}
|
|
9
|
+
export declare function generateSenderSigningKey(key?: KeyPairType): SigningKeyPair;
|
|
10
|
+
export {};
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
+
exports.generateSenderKey = generateSenderKey;
|
|
37
|
+
exports.generateSenderKeyId = generateSenderKeyId;
|
|
38
|
+
exports.generateSenderSigningKey = generateSenderSigningKey;
|
|
39
|
+
const nodeCrypto = __importStar(require("crypto"));
|
|
40
|
+
const curve_1 = require("libsignal/src/curve");
|
|
41
|
+
function generateSenderKey() {
|
|
42
|
+
return nodeCrypto.randomBytes(32);
|
|
43
|
+
}
|
|
44
|
+
function generateSenderKeyId() {
|
|
45
|
+
return nodeCrypto.randomInt(2147483647);
|
|
46
|
+
}
|
|
47
|
+
function generateSenderSigningKey(key) {
|
|
48
|
+
if (!key) {
|
|
49
|
+
key = (0, curve_1.generateKeyPair)();
|
|
50
|
+
}
|
|
51
|
+
return {
|
|
52
|
+
public: Buffer.from(key.pubKey),
|
|
53
|
+
private: Buffer.from(key.privKey)
|
|
54
|
+
};
|
|
55
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export default function queueJob<T>(bucket: string | number, awaitable: () => Promise<T>): Promise<T>;
|