supunmd-bail 2.0.2 → 2.1.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/LICENSE +1 -1
- package/README.md +2 -2
- package/WAProto/index.js +130529 -45236
- package/engine-requirements.js +1 -1
- package/lib/Defaults/baileys-version.json +1 -1
- package/lib/Defaults/index.d.ts +9 -18
- package/lib/Defaults/index.js +136 -104
- 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 +0 -1
- package/lib/Signal/Group/queue-job.js +5 -2
- 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 -258
- package/lib/Socket/Client/{types.d.ts → abstract-socket-client.d.ts} +3 -2
- 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} +1 -2
- package/lib/Socket/Client/web-socket-client.js +62 -0
- package/lib/Socket/business.d.ts +108 -125
- package/lib/Socket/business.js +43 -159
- package/lib/Socket/chats.d.ts +239 -70
- package/lib/Socket/chats.js +384 -363
- package/lib/Socket/dugong.d.ts +254 -0
- package/lib/Socket/dugong.js +484 -0
- package/lib/Socket/groups.d.ts +56 -78
- package/lib/Socket/groups.js +96 -106
- package/lib/Socket/index.d.ts +115 -173
- package/lib/Socket/index.js +10 -17
- package/lib/Socket/messages-recv.d.ts +79 -91
- package/lib/Socket/messages-recv.js +521 -639
- package/lib/Socket/messages-send.d.ts +91 -111
- package/lib/Socket/messages-send.js +438 -599
- package/lib/Socket/newsletter.d.ts +84 -97
- package/lib/Socket/newsletter.js +1 -181
- package/lib/Socket/registration.d.ts +267 -0
- package/lib/Socket/registration.js +166 -0
- package/lib/Socket/socket.d.ts +18 -26
- package/lib/Socket/socket.js +230 -448
- package/lib/Socket/usync.d.ts +16 -17
- package/lib/Socket/usync.js +26 -19
- package/lib/Store/index.d.ts +3 -0
- package/lib/Store/index.js +10 -0
- package/lib/Store/make-cache-manager-store.d.ts +13 -0
- package/lib/Store/make-cache-manager-store.js +83 -0
- package/lib/Store/make-in-memory-store.d.ts +118 -0
- package/lib/Store/make-in-memory-store.js +427 -0
- package/lib/Store/make-ordered-dictionary.d.ts +13 -0
- package/lib/Store/make-ordered-dictionary.js +81 -0
- package/lib/Store/object-repository.d.ts +10 -0
- package/lib/Store/object-repository.js +27 -0
- package/lib/Types/Auth.d.ts +12 -13
- package/lib/Types/Auth.js +2 -2
- package/lib/Types/Call.d.ts +1 -2
- package/lib/Types/Call.js +2 -2
- package/lib/Types/Chat.d.ts +13 -34
- package/lib/Types/Chat.js +4 -8
- package/lib/Types/Contact.d.ts +1 -6
- package/lib/Types/Contact.js +2 -2
- package/lib/Types/Events.d.ts +15 -60
- package/lib/Types/Events.js +2 -2
- package/lib/Types/GroupMetadata.d.ts +5 -17
- 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 +54 -84
- package/lib/Types/Message.js +9 -11
- package/lib/Types/Newsletter.d.ts +98 -130
- package/lib/Types/Newsletter.js +38 -31
- package/lib/Types/Product.d.ts +1 -2
- package/lib/Types/Product.js +2 -2
- package/lib/Types/Signal.d.ts +1 -20
- package/lib/Types/Signal.js +2 -2
- package/lib/Types/Socket.d.ts +25 -47
- package/lib/Types/Socket.js +2 -3
- package/lib/Types/State.d.ts +2 -14
- package/lib/Types/State.js +2 -13
- 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 -7
- package/lib/Utils/auth-utils.js +148 -199
- package/lib/Utils/baileys-event-stream.d.ts +1 -2
- package/lib/Utils/baileys-event-stream.js +22 -15
- package/lib/Utils/business.d.ts +2 -3
- package/lib/Utils/business.js +69 -66
- package/lib/Utils/chat-utils.d.ts +22 -21
- package/lib/Utils/chat-utils.js +226 -260
- package/lib/Utils/crypto.d.ts +19 -19
- package/lib/Utils/crypto.js +86 -77
- package/lib/Utils/decode-wa-message.d.ts +8 -37
- package/lib/Utils/decode-wa-message.js +83 -164
- package/lib/Utils/event-buffer.d.ts +8 -7
- package/lib/Utils/event-buffer.js +76 -110
- package/lib/Utils/generics.d.ts +29 -27
- package/lib/Utils/generics.js +210 -168
- package/lib/Utils/history.d.ts +8 -12
- package/lib/Utils/history.js +46 -34
- package/lib/Utils/index.d.ts +17 -20
- package/lib/Utils/index.js +33 -20
- package/lib/Utils/link-preview.d.ts +5 -5
- package/lib/Utils/link-preview.js +22 -14
- package/lib/Utils/logger.d.ts +3 -11
- package/lib/Utils/logger.js +7 -3
- package/lib/Utils/lt-hash.d.ts +8 -9
- package/lib/Utils/lt-hash.js +28 -25
- package/lib/Utils/make-mutex.d.ts +2 -3
- package/lib/Utils/make-mutex.js +10 -7
- package/lib/Utils/messages-media.d.ts +44 -42
- package/lib/Utils/messages-media.js +475 -319
- package/lib/Utils/messages.d.ts +18 -17
- package/lib/Utils/messages.js +259 -383
- package/lib/Utils/noise-handler.d.ts +15 -14
- package/lib/Utils/noise-handler.js +38 -30
- package/lib/Utils/process-message.d.ts +13 -14
- package/lib/Utils/process-message.js +147 -239
- package/lib/Utils/signal.d.ts +5 -7
- package/lib/Utils/signal.js +72 -78
- 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 +106 -72
- 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 -28
- package/lib/WABinary/encode.d.ts +3 -3
- package/lib/WABinary/encode.js +154 -105
- package/lib/WABinary/generic-utils.d.ts +7 -5
- package/lib/WABinary/generic-utils.js +63 -56
- 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 +11 -8
- 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 -5
- package/lib/WAUSync/Protocols/index.js +20 -5
- package/lib/WAUSync/USyncQuery.d.ts +4 -5
- package/lib/WAUSync/USyncQuery.js +35 -40
- package/lib/WAUSync/USyncUser.d.ts +5 -6
- package/lib/WAUSync/USyncUser.js +5 -2
- package/lib/WAUSync/index.d.ts +3 -4
- package/lib/WAUSync/index.js +19 -4
- package/lib/index.d.ts +9 -19
- package/lib/index.js +1 -36
- package/package.json +109 -103
- package/WAProto/GenerateStatics.sh +0 -3
- package/WAProto/WAProto.proto +0 -5519
- package/WAProto/fix-imports.js +0 -29
- package/WAProto/index.d.ts +0 -11969
- package/lib/Signal/lid-mapping.d.ts +0 -23
- package/lib/Signal/lid-mapping.js +0 -171
- package/lib/Socket/Client/types.js +0 -11
- package/lib/Socket/Client/websocket.js +0 -50
- package/lib/Socket/communities.d.ts +0 -244
- package/lib/Socket/communities.js +0 -431
- package/lib/Socket/mex.d.ts +0 -3
- package/lib/Socket/mex.js +0 -42
- package/lib/Types/Bussines.d.ts +0 -25
- package/lib/Types/Bussines.js +0 -2
- package/lib/Utils/browser-utils.d.ts +0 -4
- package/lib/Utils/browser-utils.js +0 -28
- package/lib/Utils/message-retry-manager.d.ts +0 -82
- package/lib/Utils/message-retry-manager.js +0 -149
- package/lib/Utils/pre-key-manager.d.ts +0 -28
- package/lib/Utils/pre-key-manager.js +0 -106
- /package/lib/{supun → supunmd} +0 -0
package/lib/Utils/history.js
CHANGED
|
@@ -1,13 +1,17 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
const
|
|
9
|
-
|
|
10
|
-
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.getHistoryMsg = exports.downloadAndProcessHistorySyncNotification = exports.processHistoryMessage = exports.downloadHistory = void 0;
|
|
4
|
+
const util_1 = require("util");
|
|
5
|
+
const zlib_1 = require("zlib");
|
|
6
|
+
const WAProto_1 = require("../../WAProto");
|
|
7
|
+
const Types_1 = require("../Types");
|
|
8
|
+
const WABinary_1 = require("../WABinary");
|
|
9
|
+
const generics_1 = require("./generics");
|
|
10
|
+
const messages_1 = require("./messages");
|
|
11
|
+
const messages_media_1 = require("./messages-media");
|
|
12
|
+
const inflatePromise = (0, util_1.promisify)(zlib_1.inflate);
|
|
13
|
+
const downloadHistory = async (msg, options) => {
|
|
14
|
+
const stream = await (0, messages_media_1.downloadContentFromMessage)(msg, 'md-msg-hist', { options });
|
|
11
15
|
const bufferArray = [];
|
|
12
16
|
for await (const chunk of stream) {
|
|
13
17
|
bufferArray.push(chunk);
|
|
@@ -15,50 +19,57 @@ export const downloadHistory = async (msg, options) => {
|
|
|
15
19
|
let buffer = Buffer.concat(bufferArray);
|
|
16
20
|
// decompress buffer
|
|
17
21
|
buffer = await inflatePromise(buffer);
|
|
18
|
-
const syncData = proto.HistorySync.decode(buffer);
|
|
22
|
+
const syncData = WAProto_1.proto.HistorySync.decode(buffer);
|
|
19
23
|
return syncData;
|
|
20
24
|
};
|
|
21
|
-
|
|
25
|
+
exports.downloadHistory = downloadHistory;
|
|
26
|
+
const processHistoryMessage = (item) => {
|
|
27
|
+
var _a, _b, _c;
|
|
22
28
|
const messages = [];
|
|
23
29
|
const contacts = [];
|
|
24
30
|
const chats = [];
|
|
25
31
|
switch (item.syncType) {
|
|
26
|
-
case proto.HistorySync.HistorySyncType.INITIAL_BOOTSTRAP:
|
|
27
|
-
case proto.HistorySync.HistorySyncType.RECENT:
|
|
28
|
-
case proto.HistorySync.HistorySyncType.FULL:
|
|
29
|
-
case proto.HistorySync.HistorySyncType.ON_DEMAND:
|
|
32
|
+
case WAProto_1.proto.HistorySync.HistorySyncType.INITIAL_BOOTSTRAP:
|
|
33
|
+
case WAProto_1.proto.HistorySync.HistorySyncType.RECENT:
|
|
34
|
+
case WAProto_1.proto.HistorySync.HistorySyncType.FULL:
|
|
30
35
|
for (const chat of item.conversations) {
|
|
31
|
-
contacts.push({
|
|
36
|
+
contacts.push({
|
|
32
37
|
id: chat.id,
|
|
33
38
|
name: chat.name || undefined,
|
|
34
39
|
lid: chat.lidJid || undefined,
|
|
35
|
-
|
|
40
|
+
jid: (0, WABinary_1.isJidUser)(chat.id) ? chat.id : undefined
|
|
36
41
|
});
|
|
37
42
|
const msgs = chat.messages || [];
|
|
38
43
|
delete chat.messages;
|
|
44
|
+
delete chat.archived;
|
|
45
|
+
delete chat.muteEndTime;
|
|
46
|
+
delete chat.pinned;
|
|
39
47
|
for (const item of msgs) {
|
|
40
48
|
const message = item.message;
|
|
41
49
|
messages.push(message);
|
|
42
|
-
if (!chat.messages
|
|
50
|
+
if (!((_a = chat.messages) === null || _a === void 0 ? void 0 : _a.length)) {
|
|
43
51
|
// keep only the most recent message in the chat array
|
|
44
52
|
chat.messages = [{ message }];
|
|
45
53
|
}
|
|
46
54
|
if (!message.key.fromMe && !chat.lastMessageRecvTimestamp) {
|
|
47
|
-
chat.lastMessageRecvTimestamp = toNumber(message.messageTimestamp);
|
|
55
|
+
chat.lastMessageRecvTimestamp = (0, generics_1.toNumber)(message.messageTimestamp);
|
|
48
56
|
}
|
|
49
|
-
if ((message.messageStubType === WAMessageStubType.BIZ_PRIVACY_MODE_TO_BSP
|
|
50
|
-
message.messageStubType === WAMessageStubType.BIZ_PRIVACY_MODE_TO_FB)
|
|
51
|
-
message.messageStubParameters
|
|
57
|
+
if ((message.messageStubType === Types_1.WAMessageStubType.BIZ_PRIVACY_MODE_TO_BSP
|
|
58
|
+
|| message.messageStubType === Types_1.WAMessageStubType.BIZ_PRIVACY_MODE_TO_FB)
|
|
59
|
+
&& ((_b = message.messageStubParameters) === null || _b === void 0 ? void 0 : _b[0])) {
|
|
52
60
|
contacts.push({
|
|
53
61
|
id: message.key.participant || message.key.remoteJid,
|
|
54
|
-
verifiedName: message.messageStubParameters
|
|
62
|
+
verifiedName: (_c = message.messageStubParameters) === null || _c === void 0 ? void 0 : _c[0],
|
|
55
63
|
});
|
|
56
64
|
}
|
|
57
65
|
}
|
|
66
|
+
if ((0, WABinary_1.isJidUser)(chat.id) && chat.readOnly && chat.archived) {
|
|
67
|
+
delete chat.readOnly;
|
|
68
|
+
}
|
|
58
69
|
chats.push({ ...chat });
|
|
59
70
|
}
|
|
60
71
|
break;
|
|
61
|
-
case proto.HistorySync.HistorySyncType.PUSH_NAME:
|
|
72
|
+
case WAProto_1.proto.HistorySync.HistorySyncType.PUSH_NAME:
|
|
62
73
|
for (const c of item.pushnames) {
|
|
63
74
|
contacts.push({ id: c.id, notify: c.pushname });
|
|
64
75
|
}
|
|
@@ -68,17 +79,18 @@ export const processHistoryMessage = (item) => {
|
|
|
68
79
|
chats,
|
|
69
80
|
contacts,
|
|
70
81
|
messages,
|
|
71
|
-
syncType: item.syncType,
|
|
72
|
-
progress: item.progress
|
|
73
82
|
};
|
|
74
83
|
};
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
84
|
+
exports.processHistoryMessage = processHistoryMessage;
|
|
85
|
+
const downloadAndProcessHistorySyncNotification = async (msg, options) => {
|
|
86
|
+
const historyMsg = await (0, exports.downloadHistory)(msg, options);
|
|
87
|
+
return (0, exports.processHistoryMessage)(historyMsg);
|
|
78
88
|
};
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
89
|
+
exports.downloadAndProcessHistorySyncNotification = downloadAndProcessHistorySyncNotification;
|
|
90
|
+
const getHistoryMsg = (message) => {
|
|
91
|
+
var _a;
|
|
92
|
+
const normalizedContent = !!message ? (0, messages_1.normalizeMessageContent)(message) : undefined;
|
|
93
|
+
const anyHistoryMsg = (_a = normalizedContent === null || normalizedContent === void 0 ? void 0 : normalizedContent.protocolMessage) === null || _a === void 0 ? void 0 : _a.historySyncNotification;
|
|
82
94
|
return anyHistoryMsg;
|
|
83
95
|
};
|
|
84
|
-
|
|
96
|
+
exports.getHistoryMsg = getHistoryMsg;
|
package/lib/Utils/index.d.ts
CHANGED
|
@@ -1,20 +1,17 @@
|
|
|
1
|
-
export * from './generics
|
|
2
|
-
export * from './decode-wa-message
|
|
3
|
-
export * from './messages
|
|
4
|
-
export * from './messages-media
|
|
5
|
-
export * from './validate-connection
|
|
6
|
-
export * from './crypto
|
|
7
|
-
export * from './signal
|
|
8
|
-
export * from './noise-handler
|
|
9
|
-
export * from './history
|
|
10
|
-
export * from './chat-utils
|
|
11
|
-
export * from './lt-hash
|
|
12
|
-
export * from './auth-utils
|
|
13
|
-
export * from './baileys-event-stream
|
|
14
|
-
export * from './use-multi-file-auth-state
|
|
15
|
-
export * from './link-preview
|
|
16
|
-
export * from './event-buffer
|
|
17
|
-
export * from './process-message
|
|
18
|
-
export * from './message-retry-manager.js';
|
|
19
|
-
export * from './browser-utils.js';
|
|
20
|
-
//# sourceMappingURL=index.d.ts.map
|
|
1
|
+
export * from './generics';
|
|
2
|
+
export * from './decode-wa-message';
|
|
3
|
+
export * from './messages';
|
|
4
|
+
export * from './messages-media';
|
|
5
|
+
export * from './validate-connection';
|
|
6
|
+
export * from './crypto';
|
|
7
|
+
export * from './signal';
|
|
8
|
+
export * from './noise-handler';
|
|
9
|
+
export * from './history';
|
|
10
|
+
export * from './chat-utils';
|
|
11
|
+
export * from './lt-hash';
|
|
12
|
+
export * from './auth-utils';
|
|
13
|
+
export * from './baileys-event-stream';
|
|
14
|
+
export * from './use-multi-file-auth-state';
|
|
15
|
+
export * from './link-preview';
|
|
16
|
+
export * from './event-buffer';
|
|
17
|
+
export * from './process-message';
|
package/lib/Utils/index.js
CHANGED
|
@@ -1,20 +1,33 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
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 __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./generics"), exports);
|
|
18
|
+
__exportStar(require("./decode-wa-message"), exports);
|
|
19
|
+
__exportStar(require("./messages"), exports);
|
|
20
|
+
__exportStar(require("./messages-media"), exports);
|
|
21
|
+
__exportStar(require("./validate-connection"), exports);
|
|
22
|
+
__exportStar(require("./crypto"), exports);
|
|
23
|
+
__exportStar(require("./signal"), exports);
|
|
24
|
+
__exportStar(require("./noise-handler"), exports);
|
|
25
|
+
__exportStar(require("./history"), exports);
|
|
26
|
+
__exportStar(require("./chat-utils"), exports);
|
|
27
|
+
__exportStar(require("./lt-hash"), exports);
|
|
28
|
+
__exportStar(require("./auth-utils"), exports);
|
|
29
|
+
__exportStar(require("./baileys-event-stream"), exports);
|
|
30
|
+
__exportStar(require("./use-multi-file-auth-state"), exports);
|
|
31
|
+
__exportStar(require("./link-preview"), exports);
|
|
32
|
+
__exportStar(require("./event-buffer"), exports);
|
|
33
|
+
__exportStar(require("./process-message"), exports);
|
|
@@ -1,15 +1,16 @@
|
|
|
1
|
-
import
|
|
2
|
-
import
|
|
1
|
+
import { AxiosRequestConfig } from 'axios';
|
|
2
|
+
import { Logger } from 'pino';
|
|
3
|
+
import { WAMediaUploadFunction, WAUrlInfo } from '../Types';
|
|
3
4
|
export type URLGenerationOptions = {
|
|
4
5
|
thumbnailWidth: number;
|
|
5
6
|
fetchOpts: {
|
|
6
7
|
/** Timeout in ms */
|
|
7
8
|
timeout: number;
|
|
8
9
|
proxyUrl?: string;
|
|
9
|
-
headers?:
|
|
10
|
+
headers?: AxiosRequestConfig<{}>['headers'];
|
|
10
11
|
};
|
|
11
12
|
uploadImage?: WAMediaUploadFunction;
|
|
12
|
-
logger?:
|
|
13
|
+
logger?: Logger;
|
|
13
14
|
};
|
|
14
15
|
/**
|
|
15
16
|
* Given a piece of text, checks for any URL present, generates link preview for the same and returns it
|
|
@@ -18,4 +19,3 @@ export type URLGenerationOptions = {
|
|
|
18
19
|
* @returns the URL info required to generate link preview
|
|
19
20
|
*/
|
|
20
21
|
export declare const getUrlInfo: (text: string, opts?: URLGenerationOptions) => Promise<WAUrlInfo | undefined>;
|
|
21
|
-
//# sourceMappingURL=link-preview.d.ts.map
|
|
@@ -1,10 +1,13 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.getUrlInfo = void 0;
|
|
4
|
+
const messages_1 = require("./messages");
|
|
5
|
+
const messages_media_1 = require("./messages-media");
|
|
3
6
|
const THUMBNAIL_WIDTH_PX = 192;
|
|
4
7
|
/** Fetches an image and generates a thumbnail for it */
|
|
5
8
|
const getCompressedJpegThumbnail = async (url, { thumbnailWidth, fetchOpts }) => {
|
|
6
|
-
const stream = await getHttpStream(url, fetchOpts);
|
|
7
|
-
const result = await extractImageThumb(stream, thumbnailWidth);
|
|
9
|
+
const stream = await (0, messages_media_1.getHttpStream)(url, fetchOpts);
|
|
10
|
+
const result = await (0, messages_media_1.extractImageThumb)(stream, thumbnailWidth);
|
|
8
11
|
return result;
|
|
9
12
|
};
|
|
10
13
|
/**
|
|
@@ -13,10 +16,11 @@ const getCompressedJpegThumbnail = async (url, { thumbnailWidth, fetchOpts }) =>
|
|
|
13
16
|
* @param text first matched URL in text
|
|
14
17
|
* @returns the URL info required to generate link preview
|
|
15
18
|
*/
|
|
16
|
-
|
|
19
|
+
const getUrlInfo = async (text, opts = {
|
|
17
20
|
thumbnailWidth: THUMBNAIL_WIDTH_PX,
|
|
18
21
|
fetchOpts: { timeout: 3000 }
|
|
19
22
|
}) => {
|
|
23
|
+
var _a;
|
|
20
24
|
try {
|
|
21
25
|
// retries
|
|
22
26
|
const retries = 0;
|
|
@@ -35,9 +39,9 @@ export const getUrlInfo = async (text, opts = {
|
|
|
35
39
|
if (retries >= maxRetry) {
|
|
36
40
|
return false;
|
|
37
41
|
}
|
|
38
|
-
if (forwardedURLObj.hostname === urlObj.hostname
|
|
39
|
-
forwardedURLObj.hostname === 'www.' + urlObj.hostname
|
|
40
|
-
'www.' + forwardedURLObj.hostname === urlObj.hostname) {
|
|
42
|
+
if (forwardedURLObj.hostname === urlObj.hostname
|
|
43
|
+
|| forwardedURLObj.hostname === 'www.' + urlObj.hostname
|
|
44
|
+
|| 'www.' + forwardedURLObj.hostname === urlObj.hostname) {
|
|
41
45
|
retries + 1;
|
|
42
46
|
return true;
|
|
43
47
|
}
|
|
@@ -45,7 +49,7 @@ export const getUrlInfo = async (text, opts = {
|
|
|
45
49
|
return false;
|
|
46
50
|
}
|
|
47
51
|
},
|
|
48
|
-
headers: opts.fetchOpts
|
|
52
|
+
headers: opts.fetchOpts
|
|
49
53
|
});
|
|
50
54
|
if (info && 'title' in info && info.title) {
|
|
51
55
|
const [image] = info.images;
|
|
@@ -57,20 +61,24 @@ export const getUrlInfo = async (text, opts = {
|
|
|
57
61
|
originalThumbnailUrl: image
|
|
58
62
|
};
|
|
59
63
|
if (opts.uploadImage) {
|
|
60
|
-
const { imageMessage } = await prepareWAMessageMedia({ image: { url: image } }, {
|
|
64
|
+
const { imageMessage } = await (0, messages_1.prepareWAMessageMedia)({ image: { url: image } }, {
|
|
61
65
|
upload: opts.uploadImage,
|
|
62
66
|
mediaTypeOverride: 'thumbnail-link',
|
|
63
67
|
options: opts.fetchOpts
|
|
64
68
|
});
|
|
65
|
-
urlInfo.jpegThumbnail = imageMessage
|
|
69
|
+
urlInfo.jpegThumbnail = (imageMessage === null || imageMessage === void 0 ? void 0 : imageMessage.jpegThumbnail)
|
|
70
|
+
? Buffer.from(imageMessage.jpegThumbnail)
|
|
71
|
+
: undefined;
|
|
66
72
|
urlInfo.highQualityThumbnail = imageMessage || undefined;
|
|
67
73
|
}
|
|
68
74
|
else {
|
|
69
75
|
try {
|
|
70
|
-
urlInfo.jpegThumbnail = image
|
|
76
|
+
urlInfo.jpegThumbnail = image
|
|
77
|
+
? (await getCompressedJpegThumbnail(image, opts)).buffer
|
|
78
|
+
: undefined;
|
|
71
79
|
}
|
|
72
80
|
catch (error) {
|
|
73
|
-
opts.logger
|
|
81
|
+
(_a = opts.logger) === null || _a === void 0 ? void 0 : _a.debug({ err: error.stack, url: previewLink }, 'error in generating thumbnail');
|
|
74
82
|
}
|
|
75
83
|
}
|
|
76
84
|
return urlInfo;
|
|
@@ -82,4 +90,4 @@ export const getUrlInfo = async (text, opts = {
|
|
|
82
90
|
}
|
|
83
91
|
}
|
|
84
92
|
};
|
|
85
|
-
|
|
93
|
+
exports.getUrlInfo = getUrlInfo;
|
package/lib/Utils/logger.d.ts
CHANGED
|
@@ -1,12 +1,4 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
trace(obj: unknown, msg?: string): void;
|
|
5
|
-
debug(obj: unknown, msg?: string): void;
|
|
6
|
-
info(obj: unknown, msg?: string): void;
|
|
7
|
-
warn(obj: unknown, msg?: string): void;
|
|
8
|
-
error(obj: unknown, msg?: string): void;
|
|
9
|
-
}
|
|
10
|
-
declare const _default: import("pino").Logger<never, boolean>;
|
|
1
|
+
declare const _default: import("pino").Logger<{
|
|
2
|
+
timestamp: () => string;
|
|
3
|
+
}>;
|
|
11
4
|
export default _default;
|
|
12
|
-
//# sourceMappingURL=logger.d.ts.map
|
package/lib/Utils/logger.js
CHANGED
|
@@ -1,3 +1,7 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
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
|
+
const pino_1 = __importDefault(require("pino"));
|
|
7
|
+
exports.default = (0, pino_1.default)({ timestamp: () => `,"time":"${new Date().toJSON()}"` });
|
package/lib/Utils/lt-hash.d.ts
CHANGED
|
@@ -1,13 +1,12 @@
|
|
|
1
|
-
declare class
|
|
1
|
+
declare class d {
|
|
2
2
|
salt: string;
|
|
3
3
|
constructor(e: string);
|
|
4
|
-
add(e:
|
|
5
|
-
subtract(e:
|
|
6
|
-
subtractThenAdd(e:
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
4
|
+
add(e: any, t: any): any;
|
|
5
|
+
subtract(e: any, t: any): any;
|
|
6
|
+
subtractThenAdd(e: any, t: any, r: any): any;
|
|
7
|
+
_addSingle(e: any, t: any): ArrayBuffer;
|
|
8
|
+
_subtractSingle(e: any, t: any): ArrayBuffer;
|
|
9
|
+
performPointwiseWithOverflow(e: any, t: any, r: any): ArrayBuffer;
|
|
10
10
|
}
|
|
11
|
-
export declare const LT_HASH_ANTI_TAMPERING:
|
|
11
|
+
export declare const LT_HASH_ANTI_TAMPERING: d;
|
|
12
12
|
export {};
|
|
13
|
-
//# sourceMappingURL=lt-hash.d.ts.map
|
package/lib/Utils/lt-hash.js
CHANGED
|
@@ -1,48 +1,51 @@
|
|
|
1
|
-
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.LT_HASH_ANTI_TAMPERING = void 0;
|
|
4
|
+
const crypto_1 = require("./crypto");
|
|
2
5
|
/**
|
|
3
6
|
* LT Hash is a summation based hash algorithm that maintains the integrity of a piece of data
|
|
4
7
|
* over a series of mutations. You can add/remove mutations and it'll return a hash equal to
|
|
5
8
|
* if the same series of mutations was made sequentially.
|
|
6
9
|
*/
|
|
7
10
|
const o = 128;
|
|
8
|
-
class
|
|
11
|
+
class d {
|
|
9
12
|
constructor(e) {
|
|
10
13
|
this.salt = e;
|
|
11
14
|
}
|
|
12
|
-
|
|
15
|
+
add(e, t) {
|
|
16
|
+
var r = this;
|
|
13
17
|
for (const item of t) {
|
|
14
|
-
e =
|
|
18
|
+
e = r._addSingle(e, item);
|
|
15
19
|
}
|
|
16
20
|
return e;
|
|
17
21
|
}
|
|
18
|
-
|
|
22
|
+
subtract(e, t) {
|
|
23
|
+
var r = this;
|
|
19
24
|
for (const item of t) {
|
|
20
|
-
e =
|
|
25
|
+
e = r._subtractSingle(e, item);
|
|
21
26
|
}
|
|
22
27
|
return e;
|
|
23
28
|
}
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
return
|
|
29
|
+
subtractThenAdd(e, t, r) {
|
|
30
|
+
var n = this;
|
|
31
|
+
return n.add(n.subtract(e, r), t);
|
|
27
32
|
}
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
33
|
+
_addSingle(e, t) {
|
|
34
|
+
var r = this;
|
|
35
|
+
const n = new Uint8Array((0, crypto_1.hkdf)(Buffer.from(t), o, { info: r.salt })).buffer;
|
|
36
|
+
return r.performPointwiseWithOverflow(e, n, ((e, t) => e + t));
|
|
31
37
|
}
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
38
|
+
_subtractSingle(e, t) {
|
|
39
|
+
var r = this;
|
|
40
|
+
const n = new Uint8Array((0, crypto_1.hkdf)(Buffer.from(t), o, { info: r.salt })).buffer;
|
|
41
|
+
return r.performPointwiseWithOverflow(e, n, ((e, t) => e - t));
|
|
35
42
|
}
|
|
36
|
-
performPointwiseWithOverflow(e, t,
|
|
37
|
-
const n = new DataView(e);
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
const s = new DataView(out);
|
|
41
|
-
for (let offset = 0; offset < n.byteLength; offset += 2) {
|
|
42
|
-
s.setUint16(offset, op(n.getUint16(offset, true), i.getUint16(offset, true)), true);
|
|
43
|
+
performPointwiseWithOverflow(e, t, r) {
|
|
44
|
+
const n = new DataView(e), i = new DataView(t), a = new ArrayBuffer(n.byteLength), s = new DataView(a);
|
|
45
|
+
for (let e = 0; e < n.byteLength; e += 2) {
|
|
46
|
+
s.setUint16(e, r(n.getUint16(e, !0), i.getUint16(e, !0)), !0);
|
|
43
47
|
}
|
|
44
|
-
return
|
|
48
|
+
return a;
|
|
45
49
|
}
|
|
46
50
|
}
|
|
47
|
-
|
|
48
|
-
//# sourceMappingURL=lt-hash.js.map
|
|
51
|
+
exports.LT_HASH_ANTI_TAMPERING = new d('WhatsApp Patch Integrity');
|
|
@@ -1,8 +1,7 @@
|
|
|
1
1
|
export declare const makeMutex: () => {
|
|
2
|
-
mutex<T>(code: () =>
|
|
2
|
+
mutex<T>(code: () => T | Promise<T>): Promise<T>;
|
|
3
3
|
};
|
|
4
4
|
export type Mutex = ReturnType<typeof makeMutex>;
|
|
5
5
|
export declare const makeKeyedMutex: () => {
|
|
6
|
-
mutex<T>(key: string, task: () =>
|
|
6
|
+
mutex<T>(key: string, task: () => T | Promise<T>): Promise<T>;
|
|
7
7
|
};
|
|
8
|
-
//# sourceMappingURL=make-mutex.d.ts.map
|
package/lib/Utils/make-mutex.js
CHANGED
|
@@ -1,5 +1,7 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.makeKeyedMutex = exports.makeMutex = void 0;
|
|
4
|
+
const makeMutex = () => {
|
|
3
5
|
let task = Promise.resolve();
|
|
4
6
|
let taskTimeout;
|
|
5
7
|
return {
|
|
@@ -10,7 +12,7 @@ export const makeMutex = () => {
|
|
|
10
12
|
try {
|
|
11
13
|
await task;
|
|
12
14
|
}
|
|
13
|
-
catch { }
|
|
15
|
+
catch (_a) { }
|
|
14
16
|
try {
|
|
15
17
|
// execute the current task
|
|
16
18
|
const result = await code();
|
|
@@ -23,18 +25,19 @@ export const makeMutex = () => {
|
|
|
23
25
|
// we replace the existing task, appending the new piece of execution to it
|
|
24
26
|
// so the next task will have to wait for this one to finish
|
|
25
27
|
return task;
|
|
26
|
-
}
|
|
28
|
+
},
|
|
27
29
|
};
|
|
28
30
|
};
|
|
29
|
-
|
|
31
|
+
exports.makeMutex = makeMutex;
|
|
32
|
+
const makeKeyedMutex = () => {
|
|
30
33
|
const map = {};
|
|
31
34
|
return {
|
|
32
35
|
mutex(key, task) {
|
|
33
36
|
if (!map[key]) {
|
|
34
|
-
map[key] = makeMutex();
|
|
37
|
+
map[key] = (0, exports.makeMutex)();
|
|
35
38
|
}
|
|
36
39
|
return map[key].mutex(task);
|
|
37
40
|
}
|
|
38
41
|
};
|
|
39
42
|
};
|
|
40
|
-
|
|
43
|
+
exports.makeKeyedMutex = makeKeyedMutex;
|