socketon 1.31.2-rc → 1.51.16
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/README.md +313 -159
- package/WAProto/WAProto.proto +5311 -0
- package/WAProto/index.js +65801 -141371
- package/lib/Defaults/index.js +117 -141
- package/lib/KeyDB/BinarySearch.js +20 -0
- package/lib/KeyDB/KeyedDB.js +167 -0
- package/lib/KeyDB/index.js +4 -0
- package/lib/Signal/Group/ciphertext-message.js +12 -14
- package/lib/Signal/Group/group-session-builder.js +10 -42
- package/lib/Signal/Group/group_cipher.js +75 -87
- package/lib/Signal/Group/index.js +13 -57
- package/lib/Signal/Group/keyhelper.js +17 -52
- package/lib/Signal/Group/sender-chain-key.js +27 -33
- package/lib/Signal/Group/sender-key-distribution-message.js +62 -63
- package/lib/Signal/Group/sender-key-message.js +65 -66
- package/lib/Signal/Group/sender-key-name.js +45 -44
- package/lib/Signal/Group/sender-key-record.js +39 -49
- package/lib/Signal/Group/sender-key-state.js +80 -93
- package/lib/Signal/Group/sender-message-key.js +27 -28
- package/lib/Signal/libsignal.js +313 -163
- package/lib/Signal/lid-mapping.js +155 -0
- package/lib/Socket/Client/index.js +4 -19
- package/lib/Socket/Client/types.js +13 -0
- package/lib/Socket/Client/websocket.js +52 -0
- package/lib/Socket/Client/websocket.js.bak +53 -0
- package/lib/Socket/business.js +359 -242
- package/lib/Socket/chats.js +846 -935
- package/lib/Socket/communities.js +413 -0
- package/lib/Socket/groups.js +304 -309
- package/lib/Socket/index.js +15 -10
- package/lib/Socket/messages-recv.js +1107 -1054
- package/lib/Socket/messages-send.js +639 -448
- package/lib/Socket/mex.js +45 -0
- package/lib/Socket/newsletter.js +240 -324
- package/lib/Socket/socket.js +794 -651
- package/lib/Socket/socketon.js +402 -0
- package/lib/Store/index.js +6 -10
- package/lib/Store/make-cache-manager-store.js +73 -81
- package/lib/Store/make-in-memory-store.js +286 -423
- package/lib/Store/make-ordered-dictionary.js +77 -79
- package/lib/Store/object-repository.js +24 -26
- package/lib/Types/Auth.js +3 -2
- package/lib/Types/Bussines.js +3 -0
- package/lib/Types/Call.js +3 -2
- package/lib/Types/Chat.js +9 -4
- package/lib/Types/Contact.js +3 -2
- package/lib/Types/Events.js +3 -2
- package/lib/Types/GroupMetadata.js +3 -2
- package/lib/Types/Label.js +24 -26
- package/lib/Types/LabelAssociation.js +6 -8
- package/lib/Types/Message.js +12 -9
- package/lib/Types/Newsletter.js +33 -38
- package/lib/Types/Newsletter.js.bak +33 -0
- package/lib/Types/Product.js +3 -2
- package/lib/Types/Signal.js +3 -2
- package/lib/Types/Socket.js +4 -2
- package/lib/Types/State.js +11 -2
- package/lib/Types/USync.js +3 -2
- package/lib/Types/index.js +27 -41
- package/lib/Utils/auth-utils.js +211 -198
- package/lib/Utils/baileys-event-stream.js +42 -61
- package/lib/Utils/browser-utils.js +25 -0
- package/lib/Utils/business.js +213 -214
- package/lib/Utils/chat-utils.js +710 -687
- package/lib/Utils/crypto.js +112 -133
- package/lib/Utils/decode-wa-message.js +252 -183
- package/lib/Utils/decode-wa-message.js.bak +267 -0
- package/lib/Utils/event-buffer.js +510 -496
- package/lib/Utils/generics.js +319 -392
- package/lib/Utils/history.js +83 -92
- package/lib/Utils/index.js +21 -33
- package/lib/Utils/link-preview.js +71 -83
- package/lib/Utils/logger.js +5 -7
- package/lib/Utils/lt-hash.js +40 -46
- package/lib/Utils/make-mutex.js +34 -41
- package/lib/Utils/message-retry-manager.js +113 -0
- package/lib/Utils/messages-media.js +550 -768
- package/lib/Utils/messages.js +354 -263
- package/lib/Utils/noise-handler.js +138 -149
- package/lib/Utils/pre-key-manager.js +85 -0
- package/lib/Utils/process-message.js +323 -303
- package/lib/Utils/signal.js +149 -141
- package/lib/Utils/use-multi-file-auth-state.js +95 -103
- package/lib/Utils/validate-connection.js +183 -214
- package/lib/WABinary/constants.js +1298 -35
- package/lib/WABinary/decode.js +237 -249
- package/lib/WABinary/encode.js +213 -260
- package/lib/WABinary/generic-utils.js +56 -65
- package/lib/WABinary/index.js +7 -21
- package/lib/WABinary/jid-utils.js +89 -58
- package/lib/WABinary/types.js +3 -2
- package/lib/WAM/BinaryInfo.js +10 -12
- package/lib/WAM/constants.js +22851 -15348
- package/lib/WAM/encode.js +135 -136
- package/lib/WAM/index.js +5 -19
- package/lib/WAUSync/Protocols/USyncContactProtocol.js +28 -30
- package/lib/WAUSync/Protocols/USyncDeviceProtocol.js +49 -53
- package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.js +27 -28
- package/lib/WAUSync/Protocols/USyncStatusProtocol.js +36 -39
- package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.js +50 -50
- package/lib/WAUSync/Protocols/UsyncLIDProtocol.js +26 -20
- package/lib/WAUSync/Protocols/index.js +6 -20
- package/lib/WAUSync/USyncQuery.js +86 -85
- package/lib/WAUSync/USyncUser.js +23 -25
- package/lib/WAUSync/index.js +5 -19
- package/lib/index.js +27 -35
- package/package.json +85 -95
- package/engine-requirements.js +0 -10
- package/lib/Defaults/baileys-version.json +0 -3
- package/lib/Defaults/index.d.ts +0 -53
- package/lib/Defaults/phonenumber-mcc.json +0 -223
- package/lib/Signal/Group/ciphertext-message.d.ts +0 -9
- package/lib/Signal/Group/group-session-builder.d.ts +0 -14
- package/lib/Signal/Group/group_cipher.d.ts +0 -17
- package/lib/Signal/Group/index.d.ts +0 -11
- package/lib/Signal/Group/keyhelper.d.ts +0 -10
- package/lib/Signal/Group/queue-job.d.ts +0 -1
- package/lib/Signal/Group/queue-job.js +0 -57
- package/lib/Signal/Group/sender-chain-key.d.ts +0 -13
- package/lib/Signal/Group/sender-key-distribution-message.d.ts +0 -16
- package/lib/Signal/Group/sender-key-message.d.ts +0 -18
- package/lib/Signal/Group/sender-key-name.d.ts +0 -17
- package/lib/Signal/Group/sender-key-record.d.ts +0 -30
- package/lib/Signal/Group/sender-key-state.d.ts +0 -38
- package/lib/Signal/Group/sender-message-key.d.ts +0 -11
- package/lib/Signal/libsignal.d.ts +0 -3
- package/lib/Socket/Client/abstract-socket-client.d.ts +0 -17
- package/lib/Socket/Client/abstract-socket-client.js +0 -13
- package/lib/Socket/Client/index.d.ts +0 -3
- package/lib/Socket/Client/mobile-socket-client.d.ts +0 -13
- package/lib/Socket/Client/mobile-socket-client.js +0 -65
- package/lib/Socket/Client/web-socket-client.d.ts +0 -12
- package/lib/Socket/Client/web-socket-client.js +0 -62
- package/lib/Socket/business.d.ts +0 -171
- package/lib/Socket/chats.d.ts +0 -267
- package/lib/Socket/dugong.d.ts +0 -254
- package/lib/Socket/dugong.js +0 -484
- package/lib/Socket/groups.d.ts +0 -115
- package/lib/Socket/index.d.ts +0 -173
- package/lib/Socket/messages-recv.d.ts +0 -161
- package/lib/Socket/messages-send.d.ts +0 -149
- package/lib/Socket/newsletter.d.ts +0 -134
- package/lib/Socket/registration.d.ts +0 -267
- package/lib/Socket/registration.js +0 -166
- package/lib/Socket/socket.d.ts +0 -43
- package/lib/Socket/usync.d.ts +0 -36
- package/lib/Socket/usync.js +0 -70
- package/lib/Store/index.d.ts +0 -3
- package/lib/Store/make-cache-manager-store.d.ts +0 -13
- package/lib/Store/make-in-memory-store.d.ts +0 -118
- package/lib/Store/make-ordered-dictionary.d.ts +0 -13
- package/lib/Store/object-repository.d.ts +0 -10
- package/lib/Types/Auth.d.ts +0 -110
- package/lib/Types/Call.d.ts +0 -13
- package/lib/Types/Chat.d.ts +0 -102
- package/lib/Types/Contact.d.ts +0 -19
- package/lib/Types/Events.d.ts +0 -157
- package/lib/Types/GroupMetadata.d.ts +0 -55
- package/lib/Types/Label.d.ts +0 -35
- package/lib/Types/LabelAssociation.d.ts +0 -29
- package/lib/Types/Message.d.ts +0 -273
- package/lib/Types/Newsletter.d.ts +0 -103
- package/lib/Types/Product.d.ts +0 -78
- package/lib/Types/Signal.d.ts +0 -57
- package/lib/Types/Socket.d.ts +0 -111
- package/lib/Types/State.d.ts +0 -27
- package/lib/Types/USync.d.ts +0 -25
- package/lib/Types/index.d.ts +0 -57
- package/lib/Utils/auth-utils.d.ts +0 -18
- package/lib/Utils/baileys-event-stream.d.ts +0 -16
- package/lib/Utils/business.d.ts +0 -22
- package/lib/Utils/chat-utils.d.ts +0 -71
- package/lib/Utils/crypto.d.ts +0 -41
- package/lib/Utils/decode-wa-message.d.ts +0 -19
- package/lib/Utils/event-buffer.d.ts +0 -35
- package/lib/Utils/generics.d.ts +0 -92
- package/lib/Utils/generics.js.bak +0 -433
- package/lib/Utils/history.d.ts +0 -15
- package/lib/Utils/index.d.ts +0 -17
- package/lib/Utils/link-preview.d.ts +0 -21
- package/lib/Utils/logger.d.ts +0 -4
- package/lib/Utils/lt-hash.d.ts +0 -12
- package/lib/Utils/make-mutex.d.ts +0 -7
- package/lib/Utils/messages-media.d.ts +0 -116
- package/lib/Utils/messages.d.ts +0 -77
- package/lib/Utils/noise-handler.d.ts +0 -21
- package/lib/Utils/process-message.d.ts +0 -41
- package/lib/Utils/signal.d.ts +0 -32
- package/lib/Utils/use-multi-file-auth-state.d.ts +0 -13
- package/lib/Utils/validate-connection.d.ts +0 -11
- package/lib/Utils/validate-connection.js.bak +0 -237
- package/lib/WABinary/constants.d.ts +0 -30
- package/lib/WABinary/decode.d.ts +0 -7
- package/lib/WABinary/encode.d.ts +0 -3
- package/lib/WABinary/generic-utils.d.ts +0 -17
- package/lib/WABinary/index.d.ts +0 -5
- package/lib/WABinary/jid-utils.d.ts +0 -31
- package/lib/WABinary/types.d.ts +0 -18
- package/lib/WAM/BinaryInfo.d.ts +0 -17
- package/lib/WAM/constants.d.ts +0 -38
- package/lib/WAM/encode.d.ts +0 -3
- package/lib/WAM/index.d.ts +0 -3
- package/lib/WAUSync/Protocols/USyncContactProtocol.d.ts +0 -9
- package/lib/WAUSync/Protocols/USyncDeviceProtocol.d.ts +0 -22
- package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.d.ts +0 -12
- package/lib/WAUSync/Protocols/USyncStatusProtocol.d.ts +0 -12
- package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.d.ts +0 -25
- package/lib/WAUSync/Protocols/UsyncLIDProtocol.d.ts +0 -8
- package/lib/WAUSync/Protocols/index.d.ts +0 -4
- package/lib/WAUSync/USyncQuery.d.ts +0 -28
- package/lib/WAUSync/USyncUser.d.ts +0 -12
- package/lib/WAUSync/index.d.ts +0 -3
- package/lib/index.d.ts +0 -12
package/lib/Utils/history.js
CHANGED
|
@@ -1,96 +1,87 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
const
|
|
11
|
-
const
|
|
12
|
-
const
|
|
13
|
-
const
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
buffer = await inflatePromise(buffer);
|
|
22
|
-
const syncData = WAProto_1.proto.HistorySync.decode(buffer);
|
|
23
|
-
return syncData;
|
|
1
|
+
//=======================================================//
|
|
2
|
+
import { downloadContentFromMessage } from "./messages-media.js";
|
|
3
|
+
import { normalizeMessageContent } from "./messages.js";
|
|
4
|
+
import { WAMessageStubType } from "../Types/index.js";
|
|
5
|
+
import { proto } from "../../WAProto/index.js";
|
|
6
|
+
import { toNumber } from "./generics.js";
|
|
7
|
+
import { promisify } from "util";
|
|
8
|
+
import { inflate } from "zlib";
|
|
9
|
+
//=======================================================//
|
|
10
|
+
const inflatePromise = promisify(inflate);
|
|
11
|
+
export const downloadHistory = async (msg, options) => {
|
|
12
|
+
const stream = await downloadContentFromMessage(msg, "md-msg-hist", { options });
|
|
13
|
+
const bufferArray = [];
|
|
14
|
+
for await (const chunk of stream) {
|
|
15
|
+
bufferArray.push(chunk);
|
|
16
|
+
}
|
|
17
|
+
let buffer = Buffer.concat(bufferArray);
|
|
18
|
+
buffer = await inflatePromise(buffer);
|
|
19
|
+
const syncData = proto.HistorySync.decode(buffer);
|
|
20
|
+
return syncData;
|
|
24
21
|
};
|
|
25
|
-
|
|
26
|
-
const processHistoryMessage = (item) => {
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
return {
|
|
79
|
-
chats,
|
|
80
|
-
contacts,
|
|
81
|
-
messages,
|
|
82
|
-
};
|
|
22
|
+
//=======================================================//
|
|
23
|
+
export const processHistoryMessage = (item) => {
|
|
24
|
+
const messages = [];
|
|
25
|
+
const contacts = [];
|
|
26
|
+
const chats = [];
|
|
27
|
+
switch (item.syncType) {
|
|
28
|
+
case proto.HistorySync.HistorySyncType.INITIAL_BOOTSTRAP:
|
|
29
|
+
case proto.HistorySync.HistorySyncType.RECENT:
|
|
30
|
+
case proto.HistorySync.HistorySyncType.FULL:
|
|
31
|
+
case proto.HistorySync.HistorySyncType.ON_DEMAND:
|
|
32
|
+
for (const chat of item.conversations) {
|
|
33
|
+
contacts.push({
|
|
34
|
+
id: chat.id,
|
|
35
|
+
name: chat.name || undefined,
|
|
36
|
+
lid: chat.lidJid || undefined,
|
|
37
|
+
phoneNumber: chat.pnJid || undefined
|
|
38
|
+
});
|
|
39
|
+
const msgs = chat.messages || [];
|
|
40
|
+
delete chat.messages;
|
|
41
|
+
for (const item of msgs) {
|
|
42
|
+
const message = item.message;
|
|
43
|
+
messages.push(message);
|
|
44
|
+
if (!chat.messages?.length) {
|
|
45
|
+
chat.messages = [{ message }];
|
|
46
|
+
}
|
|
47
|
+
if (!message.key.fromMe && !chat.lastMessageRecvTimestamp) {
|
|
48
|
+
chat.lastMessageRecvTimestamp = toNumber(message.messageTimestamp);
|
|
49
|
+
}
|
|
50
|
+
if ((message.messageStubType === WAMessageStubType.BIZ_PRIVACY_MODE_TO_BSP ||
|
|
51
|
+
message.messageStubType === WAMessageStubType.BIZ_PRIVACY_MODE_TO_FB) &&
|
|
52
|
+
message.messageStubParameters?.[0]) {
|
|
53
|
+
contacts.push({
|
|
54
|
+
id: message.key.participant || message.key.remoteJid,
|
|
55
|
+
verifiedName: message.messageStubParameters?.[0]
|
|
56
|
+
});
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
chats.push({ ...chat });
|
|
60
|
+
}
|
|
61
|
+
break;
|
|
62
|
+
case proto.HistorySync.HistorySyncType.PUSH_NAME:
|
|
63
|
+
for (const c of item.pushnames) {
|
|
64
|
+
contacts.push({ id: c.id, notify: c.pushname });
|
|
65
|
+
}
|
|
66
|
+
break;
|
|
67
|
+
}
|
|
68
|
+
return {
|
|
69
|
+
chats,
|
|
70
|
+
contacts,
|
|
71
|
+
messages,
|
|
72
|
+
syncType: item.syncType,
|
|
73
|
+
progress: item.progress
|
|
74
|
+
};
|
|
83
75
|
};
|
|
84
|
-
|
|
85
|
-
const downloadAndProcessHistorySyncNotification = async (msg, options) => {
|
|
86
|
-
|
|
87
|
-
|
|
76
|
+
//=======================================================//
|
|
77
|
+
export const downloadAndProcessHistorySyncNotification = async (msg, options) => {
|
|
78
|
+
const historyMsg = await downloadHistory(msg, options);
|
|
79
|
+
return processHistoryMessage(historyMsg);
|
|
88
80
|
};
|
|
89
|
-
|
|
90
|
-
const getHistoryMsg = (message) => {
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
return anyHistoryMsg;
|
|
81
|
+
//=======================================================//
|
|
82
|
+
export const getHistoryMsg = (message) => {
|
|
83
|
+
const normalizedContent = !!message ? normalizeMessageContent(message) : undefined;
|
|
84
|
+
const anyHistoryMsg = normalizedContent?.protocolMessage?.historySyncNotification;
|
|
85
|
+
return anyHistoryMsg;
|
|
95
86
|
};
|
|
96
|
-
|
|
87
|
+
//=======================================================//
|
package/lib/Utils/index.js
CHANGED
|
@@ -1,33 +1,21 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
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
|
+
//=======================================================//
|
|
2
|
+
export * from "./use-multi-file-auth-state.js";
|
|
3
|
+
export * from "./message-retry-manager.js";
|
|
4
|
+
export * from "./baileys-event-stream.js";
|
|
5
|
+
export * from "./validate-connection.js";
|
|
6
|
+
export * from "./decode-wa-message.js";
|
|
7
|
+
export * from "./process-message.js";
|
|
8
|
+
export * from "./messages-media.js";
|
|
9
|
+
export * from "./noise-handler.js";
|
|
10
|
+
export * from "./browser-utils.js";
|
|
11
|
+
export * from "./link-preview.js";
|
|
12
|
+
export * from "./event-buffer.js";
|
|
13
|
+
export * from "./auth-utils.js";
|
|
14
|
+
export * from "./chat-utils.js";
|
|
15
|
+
export * from "./generics.js";
|
|
16
|
+
export * from "./messages.js";
|
|
17
|
+
export * from "./history.js";
|
|
18
|
+
export * from "./lt-hash.js";
|
|
19
|
+
export * from "./crypto.js";
|
|
20
|
+
export * from "./signal.js";
|
|
21
|
+
//=======================================================//
|
|
@@ -1,93 +1,81 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
const messages_media_1 = require("./messages-media");
|
|
1
|
+
//=======================================================//
|
|
2
|
+
import { extractImageThumb, getHttpStream } from "./messages-media.js";
|
|
3
|
+
import { prepareWAMessageMedia } from "./messages.js";
|
|
4
|
+
//=======================================================//
|
|
6
5
|
const THUMBNAIL_WIDTH_PX = 192;
|
|
7
|
-
|
|
6
|
+
//=======================================================//
|
|
8
7
|
const getCompressedJpegThumbnail = async (url, { thumbnailWidth, fetchOpts }) => {
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
8
|
+
const stream = await getHttpStream(url, fetchOpts);
|
|
9
|
+
const result = await extractImageThumb(stream, thumbnailWidth);
|
|
10
|
+
return result;
|
|
12
11
|
};
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
* @returns the URL info required to generate link preview
|
|
18
|
-
*/
|
|
19
|
-
const getUrlInfo = async (text, opts = {
|
|
20
|
-
thumbnailWidth: THUMBNAIL_WIDTH_PX,
|
|
21
|
-
fetchOpts: { timeout: 3000 }
|
|
12
|
+
//=======================================================//
|
|
13
|
+
export const getUrlInfo = async (text, opts = {
|
|
14
|
+
thumbnailWidth: THUMBNAIL_WIDTH_PX,
|
|
15
|
+
fetchOpts: { timeout: 3000 }
|
|
22
16
|
}) => {
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
17
|
+
try {
|
|
18
|
+
const retries = 0;
|
|
19
|
+
const maxRetry = 5;
|
|
20
|
+
const { getLinkPreview } = await import("link-preview-js");
|
|
21
|
+
let previewLink = text;
|
|
22
|
+
if (!text.startsWith("https://") && !text.startsWith("http://")) {
|
|
23
|
+
previewLink = "https://" + previewLink;
|
|
24
|
+
}
|
|
25
|
+
const info = await getLinkPreview(previewLink, {
|
|
26
|
+
...opts.fetchOpts,
|
|
27
|
+
followRedirects: "follow",
|
|
28
|
+
handleRedirects: (baseURL, forwardedURL) => {
|
|
29
|
+
const urlObj = new URL(baseURL);
|
|
30
|
+
const forwardedURLObj = new URL(forwardedURL);
|
|
31
|
+
if (retries >= maxRetry) {
|
|
32
|
+
return false;
|
|
33
|
+
}
|
|
34
|
+
if (forwardedURLObj.hostname === urlObj.hostname ||
|
|
35
|
+
forwardedURLObj.hostname === "www." + urlObj.hostname ||
|
|
36
|
+
"www." + forwardedURLObj.hostname === urlObj.hostname) {
|
|
37
|
+
retries + 1;
|
|
38
|
+
return true;
|
|
39
|
+
}
|
|
40
|
+
else {
|
|
41
|
+
return false;
|
|
32
42
|
}
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
}
|
|
51
|
-
},
|
|
52
|
-
headers: opts.fetchOpts
|
|
43
|
+
},
|
|
44
|
+
headers: opts.fetchOpts?.headers
|
|
45
|
+
});
|
|
46
|
+
if (info && "title" in info && info.title) {
|
|
47
|
+
const [image] = info.images;
|
|
48
|
+
const urlInfo = {
|
|
49
|
+
"canonical-url": info.url,
|
|
50
|
+
"matched-text": text,
|
|
51
|
+
title: info.title,
|
|
52
|
+
description: info.description,
|
|
53
|
+
originalThumbnailUrl: image
|
|
54
|
+
};
|
|
55
|
+
if (opts.uploadImage) {
|
|
56
|
+
const { imageMessage } = await prepareWAMessageMedia({ image: { url: image } }, {
|
|
57
|
+
upload: opts.uploadImage,
|
|
58
|
+
mediaTypeOverride: "thumbnail-link",
|
|
59
|
+
options: opts.fetchOpts
|
|
53
60
|
});
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
description: info.description,
|
|
61
|
-
originalThumbnailUrl: image
|
|
62
|
-
};
|
|
63
|
-
if (opts.uploadImage) {
|
|
64
|
-
const { imageMessage } = await (0, messages_1.prepareWAMessageMedia)({ image: { url: image } }, {
|
|
65
|
-
upload: opts.uploadImage,
|
|
66
|
-
mediaTypeOverride: 'thumbnail-link',
|
|
67
|
-
options: opts.fetchOpts
|
|
68
|
-
});
|
|
69
|
-
urlInfo.jpegThumbnail = (imageMessage === null || imageMessage === void 0 ? void 0 : imageMessage.jpegThumbnail)
|
|
70
|
-
? Buffer.from(imageMessage.jpegThumbnail)
|
|
71
|
-
: undefined;
|
|
72
|
-
urlInfo.highQualityThumbnail = imageMessage || undefined;
|
|
73
|
-
}
|
|
74
|
-
else {
|
|
75
|
-
try {
|
|
76
|
-
urlInfo.jpegThumbnail = image
|
|
77
|
-
? (await getCompressedJpegThumbnail(image, opts)).buffer
|
|
78
|
-
: undefined;
|
|
79
|
-
}
|
|
80
|
-
catch (error) {
|
|
81
|
-
(_a = opts.logger) === null || _a === void 0 ? void 0 : _a.debug({ err: error.stack, url: previewLink }, 'error in generating thumbnail');
|
|
82
|
-
}
|
|
83
|
-
}
|
|
84
|
-
return urlInfo;
|
|
61
|
+
urlInfo.jpegThumbnail = imageMessage?.jpegThumbnail ? Buffer.from(imageMessage.jpegThumbnail) : undefined;
|
|
62
|
+
urlInfo.highQualityThumbnail = imageMessage || undefined;
|
|
63
|
+
}
|
|
64
|
+
else {
|
|
65
|
+
try {
|
|
66
|
+
urlInfo.jpegThumbnail = image ? (await getCompressedJpegThumbnail(image, opts)).buffer : undefined;
|
|
85
67
|
}
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
if (!error.message.includes('receive a valid')) {
|
|
89
|
-
throw error;
|
|
68
|
+
catch (error) {
|
|
69
|
+
opts.logger?.debug({ err: error.stack, url: previewLink }, "error in generating thumbnail");
|
|
90
70
|
}
|
|
71
|
+
}
|
|
72
|
+
return urlInfo;
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
catch (error) {
|
|
76
|
+
if (!error.message.includes("receive a valid")) {
|
|
77
|
+
throw error;
|
|
91
78
|
}
|
|
79
|
+
}
|
|
92
80
|
};
|
|
93
|
-
|
|
81
|
+
//=======================================================//
|
package/lib/Utils/logger.js
CHANGED
|
@@ -1,7 +1,5 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
};
|
|
5
|
-
|
|
6
|
-
const pino_1 = __importDefault(require("pino"));
|
|
7
|
-
exports.default = (0, pino_1.default)({ timestamp: () => `,"time":"${new Date().toJSON()}"` });
|
|
1
|
+
//=======================================================//
|
|
2
|
+
import P from "pino";
|
|
3
|
+
//=======================================================//
|
|
4
|
+
export default P({ timestamp: () => `,"time":"${new Date().toJSON()}"` });
|
|
5
|
+
//=======================================================//
|
package/lib/Utils/lt-hash.js
CHANGED
|
@@ -1,51 +1,45 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
const crypto_1 = require("./crypto");
|
|
5
|
-
/**
|
|
6
|
-
* LT Hash is a summation based hash algorithm that maintains the integrity of a piece of data
|
|
7
|
-
* over a series of mutations. You can add/remove mutations and it'll return a hash equal to
|
|
8
|
-
* if the same series of mutations was made sequentially.
|
|
9
|
-
*/
|
|
1
|
+
//=======================================================//
|
|
2
|
+
import { hkdf } from "./crypto.js";
|
|
3
|
+
//=======================================================//
|
|
10
4
|
const o = 128;
|
|
11
|
-
class
|
|
12
|
-
|
|
13
|
-
|
|
5
|
+
class LTHash {
|
|
6
|
+
constructor(e) {
|
|
7
|
+
this.salt = e;
|
|
8
|
+
}
|
|
9
|
+
async add(e, t) {
|
|
10
|
+
for (const item of t) {
|
|
11
|
+
e = await this._addSingle(e, item);
|
|
14
12
|
}
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
return e;
|
|
13
|
+
return e;
|
|
14
|
+
}
|
|
15
|
+
async subtract(e, t) {
|
|
16
|
+
for (const item of t) {
|
|
17
|
+
e = await this._subtractSingle(e, item);
|
|
21
18
|
}
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
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);
|
|
47
|
-
}
|
|
48
|
-
return a;
|
|
19
|
+
return e;
|
|
20
|
+
}
|
|
21
|
+
async subtractThenAdd(e, addList, subtractList) {
|
|
22
|
+
const subtracted = await this.subtract(e, subtractList);
|
|
23
|
+
return this.add(subtracted, addList);
|
|
24
|
+
}
|
|
25
|
+
async _addSingle(e, t) {
|
|
26
|
+
const derived = new Uint8Array(await hkdf(Buffer.from(t), o, { info: this.salt })).buffer;
|
|
27
|
+
return this.performPointwiseWithOverflow(e, derived, (a, b) => a + b);
|
|
28
|
+
}
|
|
29
|
+
async _subtractSingle(e, t) {
|
|
30
|
+
const derived = new Uint8Array(await hkdf(Buffer.from(t), o, { info: this.salt })).buffer;
|
|
31
|
+
return this.performPointwiseWithOverflow(e, derived, (a, b) => a - b);
|
|
32
|
+
}
|
|
33
|
+
performPointwiseWithOverflow(e, t, op) {
|
|
34
|
+
const n = new DataView(e);
|
|
35
|
+
const i = new DataView(t);
|
|
36
|
+
const out = new ArrayBuffer(n.byteLength);
|
|
37
|
+
const s = new DataView(out);
|
|
38
|
+
for (let offset = 0; offset < n.byteLength; offset += 2) {
|
|
39
|
+
s.setUint16(offset, op(n.getUint16(offset, true), i.getUint16(offset, true)), true);
|
|
49
40
|
}
|
|
41
|
+
return out;
|
|
42
|
+
}
|
|
50
43
|
}
|
|
51
|
-
|
|
44
|
+
export const LT_HASH_ANTI_TAMPERING = new LTHash("WhatsApp Patch Integrity");
|
|
45
|
+
//=======================================================//
|
package/lib/Utils/make-mutex.js
CHANGED
|
@@ -1,43 +1,36 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
catch (_a) { }
|
|
16
|
-
try {
|
|
17
|
-
// execute the current task
|
|
18
|
-
const result = await code();
|
|
19
|
-
return result;
|
|
20
|
-
}
|
|
21
|
-
finally {
|
|
22
|
-
clearTimeout(taskTimeout);
|
|
23
|
-
}
|
|
24
|
-
})();
|
|
25
|
-
// we replace the existing task, appending the new piece of execution to it
|
|
26
|
-
// so the next task will have to wait for this one to finish
|
|
27
|
-
return task;
|
|
28
|
-
},
|
|
29
|
-
};
|
|
30
|
-
};
|
|
31
|
-
exports.makeMutex = makeMutex;
|
|
32
|
-
const makeKeyedMutex = () => {
|
|
33
|
-
const map = {};
|
|
34
|
-
return {
|
|
35
|
-
mutex(key, task) {
|
|
36
|
-
if (!map[key]) {
|
|
37
|
-
map[key] = (0, exports.makeMutex)();
|
|
38
|
-
}
|
|
39
|
-
return map[key].mutex(task);
|
|
1
|
+
//=======================================================//
|
|
2
|
+
export const makeMutex = () => {
|
|
3
|
+
let task = Promise.resolve();
|
|
4
|
+
let taskTimeout;
|
|
5
|
+
return {
|
|
6
|
+
mutex(code) {
|
|
7
|
+
task = (async () => {
|
|
8
|
+
try {
|
|
9
|
+
await task;
|
|
10
|
+
}
|
|
11
|
+
catch { }
|
|
12
|
+
try {
|
|
13
|
+
const result = await code();
|
|
14
|
+
return result;
|
|
40
15
|
}
|
|
41
|
-
|
|
16
|
+
finally {
|
|
17
|
+
clearTimeout(taskTimeout);
|
|
18
|
+
}
|
|
19
|
+
})();
|
|
20
|
+
return task;
|
|
21
|
+
}
|
|
22
|
+
};
|
|
23
|
+
};
|
|
24
|
+
//=======================================================//
|
|
25
|
+
export const makeKeyedMutex = () => {
|
|
26
|
+
const map = {};
|
|
27
|
+
return {
|
|
28
|
+
mutex(key, task) {
|
|
29
|
+
if (!map[key]) {
|
|
30
|
+
map[key] = makeMutex();
|
|
31
|
+
}
|
|
32
|
+
return map[key].mutex(task);
|
|
33
|
+
}
|
|
34
|
+
};
|
|
42
35
|
};
|
|
43
|
-
|
|
36
|
+
//=======================================================//
|