gifted-baileys 1.5.4 → 1.5.6
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +1 -1
- package/WAProto/WAProto.proto +88 -969
- package/WAProto/index.d.ts +1256 -13195
- package/WAProto/index.js +74730 -125106
- package/package.json +9 -27
- package/src/Defaults/baileys-version.json +3 -0
- package/{lib → src}/Defaults/index.js +14 -7
- package/src/Defaults/index.ts +131 -0
- package/src/README.md +1 -0
- package/src/Signal/libsignal.js +180 -0
- package/src/Signal/libsignal.ts +141 -0
- package/src/Socket/Client/abstract-socket-client.ts +19 -0
- package/{lib → src}/Socket/Client/index.js +3 -2
- package/src/Socket/Client/index.ts +3 -0
- package/src/Socket/Client/mobile-socket-client.js +78 -0
- package/src/Socket/Client/mobile-socket-client.ts +66 -0
- package/src/Socket/Client/web-socket-client.js +75 -0
- package/src/Socket/Client/web-socket-client.ts +57 -0
- package/{lib → src}/Socket/business.js +33 -28
- package/src/Socket/business.ts +281 -0
- package/{lib → src}/Socket/chats.js +176 -174
- package/src/Socket/chats.ts +1030 -0
- package/{lib → src}/Socket/groups.js +68 -80
- package/src/Socket/groups.ts +356 -0
- package/{lib → src}/Socket/index.js +1 -4
- package/src/Socket/index.ts +13 -0
- package/{lib → src}/Socket/messages-recv.js +211 -378
- package/src/Socket/messages-recv.ts +985 -0
- package/{lib → src}/Socket/messages-send.js +177 -452
- package/src/Socket/messages-send.ts +871 -0
- package/{lib → src}/Socket/newsletter.js +98 -107
- package/src/Socket/newsletter.ts +282 -0
- package/{lib → src}/Socket/registration.js +48 -56
- package/src/Socket/registration.ts +250 -0
- package/{lib → src}/Socket/socket.js +77 -77
- package/src/Socket/socket.ts +777 -0
- package/src/Store/index.ts +3 -0
- package/{lib → src}/Store/make-cache-manager-store.js +34 -25
- package/src/Store/make-cache-manager-store.ts +100 -0
- package/{lib → src}/Store/make-in-memory-store.js +32 -36
- package/src/Store/make-in-memory-store.ts +475 -0
- package/src/Store/make-ordered-dictionary.ts +86 -0
- package/{lib → src}/Store/object-repository.js +1 -1
- package/src/Store/object-repository.ts +32 -0
- package/src/Tests/test.app-state-sync.js +204 -0
- package/src/Tests/test.app-state-sync.ts +207 -0
- package/src/Tests/test.event-buffer.js +270 -0
- package/src/Tests/test.event-buffer.ts +319 -0
- package/src/Tests/test.key-store.js +76 -0
- package/src/Tests/test.key-store.ts +92 -0
- package/src/Tests/test.libsignal.js +141 -0
- package/src/Tests/test.libsignal.ts +186 -0
- package/src/Tests/test.media-download.js +93 -0
- package/src/Tests/test.media-download.ts +76 -0
- package/src/Tests/test.messages.js +33 -0
- package/src/Tests/test.messages.ts +37 -0
- package/src/Tests/utils.js +34 -0
- package/src/Tests/utils.ts +36 -0
- package/src/Types/Auth.ts +113 -0
- package/src/Types/Call.ts +15 -0
- package/src/Types/Chat.ts +106 -0
- package/{lib/Types/Contact.d.ts → src/Types/Contact.ts} +9 -8
- package/src/Types/Events.ts +93 -0
- package/src/Types/GroupMetadata.ts +53 -0
- package/src/Types/Label.ts +36 -0
- package/{lib/Types/LabelAssociation.d.ts → src/Types/LabelAssociation.ts} +22 -16
- package/src/Types/Message.ts +288 -0
- package/src/Types/Newsletter.ts +98 -0
- package/src/Types/Product.ts +85 -0
- package/src/Types/Signal.ts +68 -0
- package/{lib/Types/Socket.d.ts → src/Types/Socket.ts} +68 -61
- package/src/Types/State.ts +29 -0
- package/src/Types/index.ts +59 -0
- package/{lib → src}/Utils/auth-utils.js +90 -73
- package/src/Utils/auth-utils.ts +222 -0
- package/src/Utils/baileys-event-stream.js +92 -0
- package/src/Utils/baileys-event-stream.ts +66 -0
- package/{lib → src}/Utils/business.js +43 -15
- package/src/Utils/business.ts +275 -0
- package/{lib → src}/Utils/chat-utils.js +94 -87
- package/src/Utils/chat-utils.ts +860 -0
- package/{lib → src}/Utils/crypto.js +2 -4
- package/src/Utils/crypto.ts +131 -0
- package/src/Utils/decode-wa-message.js +211 -0
- package/src/Utils/decode-wa-message.ts +228 -0
- package/{lib → src}/Utils/event-buffer.js +13 -4
- package/src/Utils/event-buffer.ts +613 -0
- package/{lib → src}/Utils/generics.js +86 -67
- package/src/Utils/generics.ts +434 -0
- package/{lib → src}/Utils/history.js +39 -13
- package/src/Utils/history.ts +112 -0
- package/src/Utils/index.ts +17 -0
- package/{lib → src}/Utils/link-preview.js +54 -17
- package/src/Utils/link-preview.ts +122 -0
- package/src/Utils/logger.ts +3 -0
- package/src/Utils/lt-hash.ts +61 -0
- package/{lib → src}/Utils/make-mutex.js +13 -4
- package/src/Utils/make-mutex.ts +44 -0
- package/{lib → src}/Utils/messages-media.js +255 -193
- package/src/Utils/messages-media.ts +847 -0
- package/{lib → src}/Utils/messages.js +118 -588
- package/src/Utils/messages.ts +956 -0
- package/src/Utils/noise-handler.ts +197 -0
- package/{lib → src}/Utils/process-message.js +30 -27
- package/src/Utils/process-message.ts +414 -0
- package/{lib → src}/Utils/signal.js +42 -25
- package/src/Utils/signal.ts +177 -0
- package/{lib → src}/Utils/use-multi-file-auth-state.js +28 -27
- package/src/Utils/use-multi-file-auth-state.ts +90 -0
- package/{lib → src}/Utils/validate-connection.js +9 -40
- package/src/Utils/validate-connection.ts +238 -0
- package/src/WABinary/constants.ts +42 -0
- package/src/WABinary/decode.ts +265 -0
- package/{lib → src}/WABinary/encode.js +10 -16
- package/src/WABinary/encode.ts +236 -0
- package/src/WABinary/generic-utils.ts +121 -0
- package/src/WABinary/index.ts +5 -0
- package/src/WABinary/jid-utils.ts +68 -0
- package/src/WABinary/types.ts +17 -0
- package/src/WAM/BinaryInfo.ts +12 -0
- package/src/WAM/constants.ts +15382 -0
- package/src/WAM/encode.ts +174 -0
- package/src/WAM/index.ts +3 -0
- package/{lib → src}/index.js +0 -1
- package/src/index.ts +13 -0
- package/README.md +0 -1645
- package/lib/Defaults/baileys-version.json +0 -3
- package/lib/Defaults/index.d.ts +0 -284
- package/lib/Signal/libsignal.d.ts +0 -3
- package/lib/Signal/libsignal.js +0 -161
- package/lib/Socket/Client/abstract-socket-client.d.ts +0 -15
- package/lib/Socket/Client/index.d.ts +0 -2
- package/lib/Socket/Client/mobile-socket-client.d.ts +0 -12
- package/lib/Socket/Client/mobile-socket-client.js +0 -65
- package/lib/Socket/Client/types.d.ts +0 -17
- package/lib/Socket/Client/types.js +0 -13
- package/lib/Socket/Client/websocket.d.ts +0 -12
- package/lib/Socket/Client/websocket.js +0 -62
- package/lib/Socket/business.d.ts +0 -170
- package/lib/Socket/chats.d.ts +0 -81
- package/lib/Socket/groups.d.ts +0 -115
- package/lib/Socket/index.d.ts +0 -172
- package/lib/Socket/messages-recv.d.ts +0 -158
- package/lib/Socket/messages-send.d.ts +0 -155
- package/lib/Socket/newsletter.d.ts +0 -132
- package/lib/Socket/registration.d.ts +0 -264
- package/lib/Socket/socket.d.ts +0 -44
- package/lib/Socket/usync.d.ts +0 -37
- 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 -14
- 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 -109
- package/lib/Types/Call.d.ts +0 -13
- package/lib/Types/Chat.d.ts +0 -107
- package/lib/Types/Events.d.ts +0 -172
- package/lib/Types/GroupMetadata.d.ts +0 -56
- package/lib/Types/Label.d.ts +0 -46
- package/lib/Types/Message.d.ts +0 -433
- package/lib/Types/Newsletter.d.ts +0 -92
- package/lib/Types/Product.d.ts +0 -78
- package/lib/Types/Signal.d.ts +0 -57
- package/lib/Types/State.d.ts +0 -27
- package/lib/Types/USync.d.ts +0 -25
- package/lib/Types/USync.js +0 -2
- package/lib/Types/index.d.ts +0 -66
- package/lib/Utils/auth-utils.d.ts +0 -18
- package/lib/Utils/baileys-event-stream.d.ts +0 -16
- package/lib/Utils/baileys-event-stream.js +0 -63
- package/lib/Utils/business.d.ts +0 -22
- package/lib/Utils/chat-utils.d.ts +0 -70
- package/lib/Utils/crypto.d.ts +0 -40
- package/lib/Utils/decode-wa-message.d.ts +0 -36
- package/lib/Utils/decode-wa-message.js +0 -226
- package/lib/Utils/event-buffer.d.ts +0 -35
- package/lib/Utils/generics.d.ts +0 -88
- package/lib/Utils/history.d.ts +0 -19
- package/lib/Utils/index.d.ts +0 -17
- package/lib/Utils/link-preview.d.ts +0 -21
- package/lib/Utils/logger.d.ts +0 -2
- 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 -113
- package/lib/Utils/messages.d.ts +0 -77
- package/lib/Utils/noise-handler.d.ts +0 -20
- package/lib/Utils/process-message.d.ts +0 -41
- package/lib/Utils/signal.d.ts +0 -33
- package/lib/Utils/use-multi-file-auth-state.d.ts +0 -12
- package/lib/Utils/validate-connection.d.ts +0 -11
- package/lib/WABinary/constants.d.ts +0 -27
- package/lib/WABinary/decode.d.ts +0 -6
- package/lib/WABinary/encode.d.ts +0 -2
- package/lib/WABinary/generic-utils.d.ts +0 -14
- 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 -8
- package/lib/WAM/constants.d.ts +0 -38
- package/lib/WAM/encode.d.ts +0 -2
- package/lib/WAM/index.d.ts +0 -3
- package/lib/WAUSync/Protocols/USyncContactProtocol.d.ts +0 -9
- package/lib/WAUSync/Protocols/USyncContactProtocol.js +0 -32
- package/lib/WAUSync/Protocols/USyncDeviceProtocol.d.ts +0 -22
- package/lib/WAUSync/Protocols/USyncDeviceProtocol.js +0 -57
- package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.d.ts +0 -12
- package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.js +0 -30
- package/lib/WAUSync/Protocols/USyncStatusProtocol.d.ts +0 -12
- package/lib/WAUSync/Protocols/USyncStatusProtocol.js +0 -42
- package/lib/WAUSync/Protocols/index.d.ts +0 -4
- package/lib/WAUSync/Protocols/index.js +0 -20
- package/lib/WAUSync/USyncQuery.d.ts +0 -26
- package/lib/WAUSync/USyncQuery.js +0 -79
- package/lib/WAUSync/USyncUser.d.ts +0 -10
- package/lib/WAUSync/USyncUser.js +0 -22
- package/lib/WAUSync/index.d.ts +0 -3
- package/lib/WAUSync/index.js +0 -19
- /package/{lib → src}/Defaults/phonenumber-mcc.json +0 -0
- /package/{lib → src}/Socket/Client/abstract-socket-client.js +0 -0
- /package/{lib → src}/Store/index.js +0 -0
- /package/{lib → src}/Store/make-ordered-dictionary.js +0 -0
- /package/{lib → src}/Types/Auth.js +0 -0
- /package/{lib → src}/Types/Call.js +0 -0
- /package/{lib → src}/Types/Chat.js +0 -0
- /package/{lib → src}/Types/Contact.js +0 -0
- /package/{lib → src}/Types/Events.js +0 -0
- /package/{lib → src}/Types/GroupMetadata.js +0 -0
- /package/{lib → src}/Types/Label.js +0 -0
- /package/{lib → src}/Types/LabelAssociation.js +0 -0
- /package/{lib → src}/Types/Message.js +0 -0
- /package/{lib → src}/Types/Newsletter.js +0 -0
- /package/{lib → src}/Types/Product.js +0 -0
- /package/{lib → src}/Types/Signal.js +0 -0
- /package/{lib → src}/Types/Socket.js +0 -0
- /package/{lib → src}/Types/State.js +0 -0
- /package/{lib → src}/Types/index.js +0 -0
- /package/{lib → src}/Utils/index.js +0 -0
- /package/{lib → src}/Utils/logger.js +0 -0
- /package/{lib → src}/Utils/lt-hash.js +0 -0
- /package/{lib → src}/Utils/noise-handler.js +0 -0
- /package/{lib → src}/WABinary/constants.js +0 -0
- /package/{lib → src}/WABinary/decode.js +0 -0
- /package/{lib → src}/WABinary/generic-utils.js +0 -0
- /package/{lib → src}/WABinary/index.js +0 -0
- /package/{lib → src}/WABinary/jid-utils.js +0 -0
- /package/{lib → src}/WABinary/types.js +0 -0
- /package/{lib → src}/WAM/BinaryInfo.js +0 -0
- /package/{lib → src}/WAM/constants.js +0 -0
- /package/{lib → src}/WAM/encode.js +0 -0
- /package/{lib → src}/WAM/index.js +0 -0
- /package/{lib → src}/gifted +0 -0
|
@@ -1,4 +1,13 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
+
});
|
|
10
|
+
};
|
|
2
11
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
12
|
exports.extractNewsletterMetadata = exports.makeNewsletterSocket = void 0;
|
|
4
13
|
const Types_1 = require("../Types");
|
|
@@ -9,38 +18,39 @@ const makeNewsletterSocket = (config) => {
|
|
|
9
18
|
const sock = (0, groups_1.makeGroupsSocket)(config);
|
|
10
19
|
const { authState, signalRepository, query, generateMessageTag } = sock;
|
|
11
20
|
const encoder = new TextEncoder();
|
|
12
|
-
const newsletterQuery =
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
21
|
+
const newsletterQuery = (jid, type, content) => __awaiter(void 0, void 0, void 0, function* () {
|
|
22
|
+
return (query({
|
|
23
|
+
tag: 'iq',
|
|
24
|
+
attrs: {
|
|
25
|
+
id: generateMessageTag(),
|
|
26
|
+
type,
|
|
27
|
+
xmlns: 'newsletter',
|
|
28
|
+
to: jid,
|
|
29
|
+
},
|
|
30
|
+
content
|
|
31
|
+
}));
|
|
32
|
+
});
|
|
33
|
+
const newsletterWMexQuery = (jid, queryId, content) => __awaiter(void 0, void 0, void 0, function* () {
|
|
34
|
+
return (query({
|
|
35
|
+
tag: 'iq',
|
|
36
|
+
attrs: {
|
|
37
|
+
id: generateMessageTag(),
|
|
38
|
+
type: 'get',
|
|
39
|
+
xmlns: 'w:mex',
|
|
40
|
+
to: WABinary_1.S_WHATSAPP_NET,
|
|
41
|
+
},
|
|
42
|
+
content: [
|
|
43
|
+
{
|
|
44
|
+
tag: 'query',
|
|
45
|
+
attrs: { 'query_id': queryId },
|
|
46
|
+
content: encoder.encode(JSON.stringify({
|
|
47
|
+
variables: Object.assign({ 'newsletter_id': jid }, content)
|
|
48
|
+
}))
|
|
49
|
+
}
|
|
50
|
+
]
|
|
51
|
+
}));
|
|
52
|
+
});
|
|
53
|
+
const parseFetchedUpdates = (node, type) => __awaiter(void 0, void 0, void 0, function* () {
|
|
44
54
|
let child;
|
|
45
55
|
if (type === 'messages') {
|
|
46
56
|
child = (0, WABinary_1.getBinaryNodeChild)(node, 'messages');
|
|
@@ -49,7 +59,7 @@ const makeNewsletterSocket = (config) => {
|
|
|
49
59
|
const parent = (0, WABinary_1.getBinaryNodeChild)(node, 'message_updates');
|
|
50
60
|
child = (0, WABinary_1.getBinaryNodeChild)(parent, 'messages');
|
|
51
61
|
}
|
|
52
|
-
return
|
|
62
|
+
return yield Promise.all((0, WABinary_1.getAllBinaryNodeChildren)(child).map((messageNode) => __awaiter(void 0, void 0, void 0, function* () {
|
|
53
63
|
var _a, _b;
|
|
54
64
|
messageNode.attrs.from = child === null || child === void 0 ? void 0 : child.attrs.jid;
|
|
55
65
|
const views = parseInt(((_b = (_a = (0, WABinary_1.getBinaryNodeChild)(messageNode, 'views_count')) === null || _a === void 0 ? void 0 : _a.attrs) === null || _b === void 0 ? void 0 : _b.count) || '0');
|
|
@@ -62,65 +72,52 @@ const makeNewsletterSocket = (config) => {
|
|
|
62
72
|
reactions
|
|
63
73
|
};
|
|
64
74
|
if (type === 'messages') {
|
|
65
|
-
const { fullMessage: message, decrypt } =
|
|
66
|
-
|
|
75
|
+
const { fullMessage: message, decrypt } = yield (0, Utils_1.decryptMessageNode)(messageNode, authState.creds.me.id, authState.creds.me.lid || '', signalRepository, config.logger);
|
|
76
|
+
yield decrypt();
|
|
67
77
|
data.message = message;
|
|
68
78
|
}
|
|
69
79
|
return data;
|
|
70
|
-
}));
|
|
71
|
-
};
|
|
72
|
-
return {
|
|
73
|
-
...sock,
|
|
74
|
-
subscribeNewsletterUpdates: async (jid) => {
|
|
80
|
+
})));
|
|
81
|
+
});
|
|
82
|
+
return Object.assign(Object.assign({}, sock), { subscribeNewsletterUpdates: (jid) => __awaiter(void 0, void 0, void 0, function* () {
|
|
75
83
|
var _a;
|
|
76
|
-
const result =
|
|
84
|
+
const result = yield newsletterQuery(jid, 'set', [{ tag: 'live_updates', attrs: {}, content: [] }]);
|
|
77
85
|
return (_a = (0, WABinary_1.getBinaryNodeChild)(result, 'live_updates')) === null || _a === void 0 ? void 0 : _a.attrs;
|
|
78
|
-
},
|
|
79
|
-
|
|
80
|
-
await newsletterWMexQuery(jid, Types_1.QueryIds.JOB_MUTATION, {
|
|
86
|
+
}), newsletterReactionMode: (jid, mode) => __awaiter(void 0, void 0, void 0, function* () {
|
|
87
|
+
yield newsletterWMexQuery(jid, Types_1.QueryIds.JOB_MUTATION, {
|
|
81
88
|
updates: { settings: { 'reaction_codes': { value: mode } } }
|
|
82
89
|
});
|
|
83
|
-
},
|
|
84
|
-
|
|
85
|
-
await newsletterWMexQuery(jid, Types_1.QueryIds.JOB_MUTATION, {
|
|
90
|
+
}), newsletterUpdateDescription: (jid, description) => __awaiter(void 0, void 0, void 0, function* () {
|
|
91
|
+
yield newsletterWMexQuery(jid, Types_1.QueryIds.JOB_MUTATION, {
|
|
86
92
|
updates: { description: description || '', settings: null }
|
|
87
93
|
});
|
|
88
|
-
},
|
|
89
|
-
|
|
90
|
-
await newsletterWMexQuery(jid, Types_1.QueryIds.JOB_MUTATION, {
|
|
94
|
+
}), newsletterUpdateName: (jid, name) => __awaiter(void 0, void 0, void 0, function* () {
|
|
95
|
+
yield newsletterWMexQuery(jid, Types_1.QueryIds.JOB_MUTATION, {
|
|
91
96
|
updates: { name, settings: null }
|
|
92
97
|
});
|
|
93
|
-
},
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
await newsletterWMexQuery(jid, Types_1.QueryIds.JOB_MUTATION, {
|
|
98
|
+
}), newsletterUpdatePicture: (jid, content) => __awaiter(void 0, void 0, void 0, function* () {
|
|
99
|
+
const { img } = yield (0, Utils_1.generateProfilePicture)(content);
|
|
100
|
+
yield newsletterWMexQuery(jid, Types_1.QueryIds.JOB_MUTATION, {
|
|
97
101
|
updates: { picture: img.toString('base64'), settings: null }
|
|
98
102
|
});
|
|
99
|
-
},
|
|
100
|
-
|
|
101
|
-
await newsletterWMexQuery(jid, Types_1.QueryIds.JOB_MUTATION, {
|
|
103
|
+
}), newsletterRemovePicture: (jid) => __awaiter(void 0, void 0, void 0, function* () {
|
|
104
|
+
yield newsletterWMexQuery(jid, Types_1.QueryIds.JOB_MUTATION, {
|
|
102
105
|
updates: { picture: '', settings: null }
|
|
103
106
|
});
|
|
104
|
-
},
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
},
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
await newsletterWMexQuery(jid, Types_1.QueryIds.MUTE);
|
|
116
|
-
},
|
|
117
|
-
newsletterAction: async (jid, type) => {
|
|
118
|
-
await newsletterWMexQuery(jid, Types_1.QueryIds[type.toUpperCase()]);
|
|
119
|
-
},
|
|
120
|
-
newsletterCreate: async (name, description) => {
|
|
107
|
+
}), newsletterUnfollow: (jid) => __awaiter(void 0, void 0, void 0, function* () {
|
|
108
|
+
yield newsletterWMexQuery(jid, Types_1.QueryIds.UNFOLLOW);
|
|
109
|
+
}), newsletterFollow: (jid) => __awaiter(void 0, void 0, void 0, function* () {
|
|
110
|
+
yield newsletterWMexQuery(jid, Types_1.QueryIds.FOLLOW);
|
|
111
|
+
}), newsletterUnmute: (jid) => __awaiter(void 0, void 0, void 0, function* () {
|
|
112
|
+
yield newsletterWMexQuery(jid, Types_1.QueryIds.UNMUTE);
|
|
113
|
+
}), newsletterMute: (jid) => __awaiter(void 0, void 0, void 0, function* () {
|
|
114
|
+
yield newsletterWMexQuery(jid, Types_1.QueryIds.MUTE);
|
|
115
|
+
}), newsletterAction: (jid, type) => __awaiter(void 0, void 0, void 0, function* () {
|
|
116
|
+
yield newsletterWMexQuery(jid, type.toUpperCase());
|
|
117
|
+
}), newsletterCreate: (name, description, reaction_codes) => __awaiter(void 0, void 0, void 0, function* () {
|
|
121
118
|
//TODO: Implement TOS system wide for Meta AI, communities, and here etc.
|
|
122
119
|
/**tos query */
|
|
123
|
-
|
|
120
|
+
yield query({
|
|
124
121
|
tag: 'iq',
|
|
125
122
|
attrs: {
|
|
126
123
|
to: WABinary_1.S_WHATSAPP_NET,
|
|
@@ -139,13 +136,12 @@ const makeNewsletterSocket = (config) => {
|
|
|
139
136
|
}
|
|
140
137
|
]
|
|
141
138
|
});
|
|
142
|
-
const result =
|
|
143
|
-
input: { name, description, settings:
|
|
139
|
+
const result = yield newsletterWMexQuery(undefined, Types_1.QueryIds.CREATE, {
|
|
140
|
+
input: { name, description, settings: { 'reaction_codes': { value: reaction_codes.toUpperCase() } } }
|
|
144
141
|
});
|
|
145
142
|
return (0, exports.extractNewsletterMetadata)(result, true);
|
|
146
|
-
},
|
|
147
|
-
|
|
148
|
-
const result = await newsletterWMexQuery(undefined, Types_1.QueryIds.METADATA, {
|
|
143
|
+
}), newsletterMetadata: (type, key, role) => __awaiter(void 0, void 0, void 0, function* () {
|
|
144
|
+
const result = yield newsletterWMexQuery(undefined, Types_1.QueryIds.METADATA, {
|
|
149
145
|
input: {
|
|
150
146
|
key,
|
|
151
147
|
type: type.toUpperCase(),
|
|
@@ -156,58 +152,53 @@ const makeNewsletterSocket = (config) => {
|
|
|
156
152
|
'fetch_creation_time': true
|
|
157
153
|
});
|
|
158
154
|
return (0, exports.extractNewsletterMetadata)(result);
|
|
159
|
-
},
|
|
160
|
-
newsletterAdminCount: async (jid) => {
|
|
155
|
+
}), newsletterAdminCount: (jid) => __awaiter(void 0, void 0, void 0, function* () {
|
|
161
156
|
var _a, _b;
|
|
162
|
-
const result =
|
|
157
|
+
const result = yield newsletterWMexQuery(jid, Types_1.QueryIds.ADMIN_COUNT);
|
|
163
158
|
const buff = (_b = (_a = (0, WABinary_1.getBinaryNodeChild)(result, 'result')) === null || _a === void 0 ? void 0 : _a.content) === null || _b === void 0 ? void 0 : _b.toString();
|
|
164
159
|
return JSON.parse(buff).data[Types_1.XWAPaths.ADMIN_COUNT].admin_count;
|
|
165
|
-
},
|
|
160
|
+
}),
|
|
166
161
|
/**user is Lid, not Jid */
|
|
167
|
-
newsletterChangeOwner:
|
|
168
|
-
|
|
162
|
+
newsletterChangeOwner: (jid, user) => __awaiter(void 0, void 0, void 0, function* () {
|
|
163
|
+
yield newsletterWMexQuery(jid, Types_1.QueryIds.CHANGE_OWNER, {
|
|
169
164
|
'user_id': user
|
|
170
165
|
});
|
|
171
|
-
},
|
|
166
|
+
}),
|
|
172
167
|
/**user is Lid, not Jid */
|
|
173
|
-
newsletterDemote:
|
|
174
|
-
|
|
168
|
+
newsletterDemote: (jid, user) => __awaiter(void 0, void 0, void 0, function* () {
|
|
169
|
+
yield newsletterWMexQuery(jid, Types_1.QueryIds.DEMOTE, {
|
|
175
170
|
'user_id': user
|
|
176
171
|
});
|
|
177
|
-
},
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
},
|
|
172
|
+
}), newsletterDelete: (jid) => __awaiter(void 0, void 0, void 0, function* () {
|
|
173
|
+
yield newsletterWMexQuery(jid, Types_1.QueryIds.DELETE);
|
|
174
|
+
}),
|
|
181
175
|
/**if code wasn't passed, the reaction will be removed (if is reacted) */
|
|
182
|
-
newsletterReactMessage:
|
|
183
|
-
|
|
176
|
+
newsletterReactMessage: (jid, serverId, code) => __awaiter(void 0, void 0, void 0, function* () {
|
|
177
|
+
yield query({
|
|
184
178
|
tag: 'message',
|
|
185
|
-
attrs: { to: jid,
|
|
179
|
+
attrs: Object.assign(Object.assign({ to: jid }, (!code ? { edit: '7' } : {})), { type: 'reaction', 'server_id': serverId, id: (0, Utils_1.generateMessageID)() }),
|
|
186
180
|
content: [{
|
|
187
181
|
tag: 'reaction',
|
|
188
182
|
attrs: code ? { code } : {}
|
|
189
183
|
}]
|
|
190
184
|
});
|
|
191
|
-
},
|
|
192
|
-
|
|
193
|
-
const result = await newsletterQuery(WABinary_1.S_WHATSAPP_NET, 'get', [
|
|
185
|
+
}), newsletterFetchMessages: (type, key, count, after) => __awaiter(void 0, void 0, void 0, function* () {
|
|
186
|
+
const result = yield newsletterQuery(WABinary_1.S_WHATSAPP_NET, 'get', [
|
|
194
187
|
{
|
|
195
188
|
tag: 'messages',
|
|
196
|
-
attrs: { type,
|
|
189
|
+
attrs: Object.assign(Object.assign({ type }, (type === 'invite' ? { key } : { jid: key })), { count: count.toString(), after: (after === null || after === void 0 ? void 0 : after.toString()) || '100' })
|
|
197
190
|
}
|
|
198
191
|
]);
|
|
199
|
-
return
|
|
200
|
-
},
|
|
201
|
-
|
|
202
|
-
const result = await newsletterQuery(jid, 'get', [
|
|
192
|
+
return yield parseFetchedUpdates(result, 'messages');
|
|
193
|
+
}), newsletterFetchUpdates: (jid, count, after, since) => __awaiter(void 0, void 0, void 0, function* () {
|
|
194
|
+
const result = yield newsletterQuery(jid, 'get', [
|
|
203
195
|
{
|
|
204
196
|
tag: 'message_updates',
|
|
205
197
|
attrs: { count: count.toString(), after: (after === null || after === void 0 ? void 0 : after.toString()) || '100', since: (since === null || since === void 0 ? void 0 : since.toString()) || '0' }
|
|
206
198
|
}
|
|
207
199
|
]);
|
|
208
|
-
return
|
|
209
|
-
}
|
|
210
|
-
};
|
|
200
|
+
return yield parseFetchedUpdates(result, 'updates');
|
|
201
|
+
}) });
|
|
211
202
|
};
|
|
212
203
|
exports.makeNewsletterSocket = makeNewsletterSocket;
|
|
213
204
|
const extractNewsletterMetadata = (node, isCreate) => {
|
|
@@ -0,0 +1,282 @@
|
|
|
1
|
+
import { NewsletterFetchedUpdate, NewsletterMetadata, NewsletterReaction, NewsletterReactionMode, NewsletterViewRole, QueryIds, SocketConfig, WAMediaUpload, XWAPaths } from '../Types'
|
|
2
|
+
import { decryptMessageNode, generateMessageID, generateProfilePicture } from '../Utils'
|
|
3
|
+
import { BinaryNode, getAllBinaryNodeChildren, getBinaryNodeChild, getBinaryNodeChildren, S_WHATSAPP_NET } from '../WABinary'
|
|
4
|
+
import { makeGroupsSocket } from './groups'
|
|
5
|
+
|
|
6
|
+
export const makeNewsletterSocket = (config: SocketConfig) => {
|
|
7
|
+
const sock = makeGroupsSocket(config)
|
|
8
|
+
const { authState, signalRepository, query, generateMessageTag } = sock
|
|
9
|
+
|
|
10
|
+
const encoder = new TextEncoder()
|
|
11
|
+
|
|
12
|
+
const newsletterQuery = async(jid: string, type: 'get' | 'set', content: BinaryNode[]) => (
|
|
13
|
+
query({
|
|
14
|
+
tag: 'iq',
|
|
15
|
+
attrs: {
|
|
16
|
+
id: generateMessageTag(),
|
|
17
|
+
type,
|
|
18
|
+
xmlns: 'newsletter',
|
|
19
|
+
to: jid,
|
|
20
|
+
},
|
|
21
|
+
content
|
|
22
|
+
})
|
|
23
|
+
)
|
|
24
|
+
|
|
25
|
+
const newsletterWMexQuery = async(jid: string | undefined, queryId: QueryIds, content?: object) => (
|
|
26
|
+
query({
|
|
27
|
+
tag: 'iq',
|
|
28
|
+
attrs: {
|
|
29
|
+
id: generateMessageTag(),
|
|
30
|
+
type: 'get',
|
|
31
|
+
xmlns: 'w:mex',
|
|
32
|
+
to: S_WHATSAPP_NET,
|
|
33
|
+
},
|
|
34
|
+
content: [
|
|
35
|
+
{
|
|
36
|
+
tag: 'query',
|
|
37
|
+
attrs: { 'query_id': queryId },
|
|
38
|
+
content: encoder.encode(
|
|
39
|
+
JSON.stringify({
|
|
40
|
+
variables: {
|
|
41
|
+
'newsletter_id': jid,
|
|
42
|
+
...content
|
|
43
|
+
}
|
|
44
|
+
})
|
|
45
|
+
)
|
|
46
|
+
}
|
|
47
|
+
]
|
|
48
|
+
})
|
|
49
|
+
)
|
|
50
|
+
|
|
51
|
+
const parseFetchedUpdates = async(node: BinaryNode, type: 'messages' | 'updates') => {
|
|
52
|
+
let child
|
|
53
|
+
|
|
54
|
+
if(type === 'messages') {
|
|
55
|
+
child = getBinaryNodeChild(node, 'messages')
|
|
56
|
+
} else {
|
|
57
|
+
const parent = getBinaryNodeChild(node, 'message_updates')
|
|
58
|
+
child = getBinaryNodeChild(parent, 'messages')
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
return await Promise.all(getAllBinaryNodeChildren(child).map(async messageNode => {
|
|
62
|
+
messageNode.attrs.from = child?.attrs.jid as string
|
|
63
|
+
|
|
64
|
+
const views = parseInt(getBinaryNodeChild(messageNode, 'views_count')?.attrs?.count || '0')
|
|
65
|
+
const reactionNode = getBinaryNodeChild(messageNode, 'reactions')
|
|
66
|
+
const reactions = getBinaryNodeChildren(reactionNode, 'reaction')
|
|
67
|
+
.map(({ attrs }) => ({ count: +attrs.count, code: attrs.code } as NewsletterReaction))
|
|
68
|
+
|
|
69
|
+
const data: NewsletterFetchedUpdate = {
|
|
70
|
+
'server_id': messageNode.attrs.server_id,
|
|
71
|
+
views,
|
|
72
|
+
reactions
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
if(type === 'messages') {
|
|
76
|
+
const { fullMessage: message, decrypt } = await decryptMessageNode(
|
|
77
|
+
messageNode,
|
|
78
|
+
authState.creds.me!.id,
|
|
79
|
+
authState.creds.me!.lid || '',
|
|
80
|
+
signalRepository,
|
|
81
|
+
config.logger
|
|
82
|
+
)
|
|
83
|
+
|
|
84
|
+
await decrypt()
|
|
85
|
+
|
|
86
|
+
data.message = message
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
return data
|
|
90
|
+
}))
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
return {
|
|
94
|
+
...sock,
|
|
95
|
+
subscribeNewsletterUpdates: async(jid: string) => {
|
|
96
|
+
const result = await newsletterQuery(jid, 'set', [{ tag: 'live_updates', attrs: {}, content: [] }])
|
|
97
|
+
|
|
98
|
+
return getBinaryNodeChild(result, 'live_updates')?.attrs as {duration: string}
|
|
99
|
+
},
|
|
100
|
+
|
|
101
|
+
newsletterReactionMode: async(jid: string, mode: NewsletterReactionMode) => {
|
|
102
|
+
await newsletterWMexQuery(jid, QueryIds.JOB_MUTATION, {
|
|
103
|
+
updates: { settings: { 'reaction_codes': { value: mode } } }
|
|
104
|
+
})
|
|
105
|
+
},
|
|
106
|
+
|
|
107
|
+
newsletterUpdateDescription: async(jid: string, description?: string) => {
|
|
108
|
+
await newsletterWMexQuery(jid, QueryIds.JOB_MUTATION, {
|
|
109
|
+
updates: { description: description || '', settings: null }
|
|
110
|
+
})
|
|
111
|
+
},
|
|
112
|
+
|
|
113
|
+
newsletterUpdateName: async(jid: string, name: string) => {
|
|
114
|
+
await newsletterWMexQuery(jid, QueryIds.JOB_MUTATION, {
|
|
115
|
+
updates: { name, settings: null }
|
|
116
|
+
})
|
|
117
|
+
},
|
|
118
|
+
|
|
119
|
+
newsletterUpdatePicture: async(jid: string, content: WAMediaUpload) => {
|
|
120
|
+
const { img } = await generateProfilePicture(content)
|
|
121
|
+
|
|
122
|
+
await newsletterWMexQuery(jid, QueryIds.JOB_MUTATION, {
|
|
123
|
+
updates: { picture: img.toString('base64'), settings: null }
|
|
124
|
+
})
|
|
125
|
+
},
|
|
126
|
+
|
|
127
|
+
newsletterRemovePicture: async(jid: string) => {
|
|
128
|
+
await newsletterWMexQuery(jid, QueryIds.JOB_MUTATION, {
|
|
129
|
+
updates: { picture: '', settings: null }
|
|
130
|
+
})
|
|
131
|
+
},
|
|
132
|
+
|
|
133
|
+
newsletterUnfollow: async(jid: string) => {
|
|
134
|
+
await newsletterWMexQuery(jid, QueryIds.UNFOLLOW)
|
|
135
|
+
},
|
|
136
|
+
|
|
137
|
+
newsletterFollow: async(jid: string) => {
|
|
138
|
+
await newsletterWMexQuery(jid, QueryIds.FOLLOW)
|
|
139
|
+
},
|
|
140
|
+
|
|
141
|
+
newsletterUnmute: async(jid: string) => {
|
|
142
|
+
await newsletterWMexQuery(jid, QueryIds.UNMUTE)
|
|
143
|
+
},
|
|
144
|
+
|
|
145
|
+
newsletterMute: async(jid: string) => {
|
|
146
|
+
await newsletterWMexQuery(jid, QueryIds.MUTE)
|
|
147
|
+
},
|
|
148
|
+
|
|
149
|
+
newsletterAction: async(jid: string, type: 'follow' | 'unfollow' | 'mute' | 'unmute') => {
|
|
150
|
+
await newsletterWMexQuery(jid, type.toUpperCase() as QueryIds)
|
|
151
|
+
},
|
|
152
|
+
|
|
153
|
+
newsletterCreate: async(name: string, description: string, reaction_codes: string) => {
|
|
154
|
+
//TODO: Implement TOS system wide for Meta AI, communities, and here etc.
|
|
155
|
+
/**tos query */
|
|
156
|
+
await query({
|
|
157
|
+
tag: 'iq',
|
|
158
|
+
attrs: {
|
|
159
|
+
to: S_WHATSAPP_NET,
|
|
160
|
+
xmlns: 'tos',
|
|
161
|
+
id: generateMessageTag(),
|
|
162
|
+
type: 'set'
|
|
163
|
+
},
|
|
164
|
+
content: [
|
|
165
|
+
{
|
|
166
|
+
tag: 'notice',
|
|
167
|
+
attrs: {
|
|
168
|
+
id: '20601218',
|
|
169
|
+
stage: '5'
|
|
170
|
+
},
|
|
171
|
+
content: []
|
|
172
|
+
}
|
|
173
|
+
]
|
|
174
|
+
})
|
|
175
|
+
const result = await newsletterWMexQuery(undefined, QueryIds.CREATE, {
|
|
176
|
+
input: { name, description, settings: { 'reaction_codes': { value: reaction_codes.toUpperCase() } } }
|
|
177
|
+
})
|
|
178
|
+
|
|
179
|
+
return extractNewsletterMetadata(result, true)
|
|
180
|
+
},
|
|
181
|
+
|
|
182
|
+
newsletterMetadata: async(type: 'invite' | 'jid', key: string, role?: NewsletterViewRole) => {
|
|
183
|
+
const result = await newsletterWMexQuery(undefined, QueryIds.METADATA, {
|
|
184
|
+
input: {
|
|
185
|
+
key,
|
|
186
|
+
type: type.toUpperCase(),
|
|
187
|
+
'view_role': role || 'GUEST'
|
|
188
|
+
},
|
|
189
|
+
'fetch_viewer_metadata': true,
|
|
190
|
+
'fetch_full_image': true,
|
|
191
|
+
'fetch_creation_time': true
|
|
192
|
+
})
|
|
193
|
+
|
|
194
|
+
return extractNewsletterMetadata(result)
|
|
195
|
+
},
|
|
196
|
+
|
|
197
|
+
newsletterAdminCount: async(jid: string) => {
|
|
198
|
+
const result = await newsletterWMexQuery(jid, QueryIds.ADMIN_COUNT)
|
|
199
|
+
|
|
200
|
+
const buff = getBinaryNodeChild(result, 'result')?.content?.toString()
|
|
201
|
+
|
|
202
|
+
return JSON.parse(buff!).data[XWAPaths.ADMIN_COUNT].admin_count as number
|
|
203
|
+
},
|
|
204
|
+
|
|
205
|
+
/**user is Lid, not Jid */
|
|
206
|
+
newsletterChangeOwner: async(jid: string, user: string) => {
|
|
207
|
+
await newsletterWMexQuery(jid, QueryIds.CHANGE_OWNER, {
|
|
208
|
+
'user_id': user
|
|
209
|
+
})
|
|
210
|
+
},
|
|
211
|
+
|
|
212
|
+
/**user is Lid, not Jid */
|
|
213
|
+
newsletterDemote: async(jid: string, user: string) => {
|
|
214
|
+
await newsletterWMexQuery(jid, QueryIds.DEMOTE, {
|
|
215
|
+
'user_id': user
|
|
216
|
+
})
|
|
217
|
+
},
|
|
218
|
+
|
|
219
|
+
newsletterDelete: async(jid: string) => {
|
|
220
|
+
await newsletterWMexQuery(jid, QueryIds.DELETE)
|
|
221
|
+
},
|
|
222
|
+
|
|
223
|
+
/**if code wasn't passed, the reaction will be removed (if is reacted) */
|
|
224
|
+
newsletterReactMessage: async(jid: string, serverId: string, code?: string) => {
|
|
225
|
+
await query({
|
|
226
|
+
tag: 'message',
|
|
227
|
+
attrs: { to: jid, ...(!code ? { edit: '7' } : {}), type: 'reaction', 'server_id': serverId, id: generateMessageID() },
|
|
228
|
+
content: [{
|
|
229
|
+
tag: 'reaction',
|
|
230
|
+
attrs: code ? { code } : {}
|
|
231
|
+
}]
|
|
232
|
+
})
|
|
233
|
+
},
|
|
234
|
+
|
|
235
|
+
newsletterFetchMessages: async(type: 'invite' | 'jid', key: string, count: number, after?: number) => {
|
|
236
|
+
const result = await newsletterQuery(S_WHATSAPP_NET, 'get', [
|
|
237
|
+
{
|
|
238
|
+
tag: 'messages',
|
|
239
|
+
attrs: { type, ...(type === 'invite' ? { key } : { jid: key }), count: count.toString(), after: after?.toString() || '100' }
|
|
240
|
+
}
|
|
241
|
+
])
|
|
242
|
+
|
|
243
|
+
return await parseFetchedUpdates(result, 'messages')
|
|
244
|
+
},
|
|
245
|
+
|
|
246
|
+
newsletterFetchUpdates: async(jid: string, count: number, after?: number, since?: number) => {
|
|
247
|
+
const result = await newsletterQuery(jid, 'get', [
|
|
248
|
+
{
|
|
249
|
+
tag: 'message_updates',
|
|
250
|
+
attrs: { count: count.toString(), after: after?.toString() || '100', since: since?.toString() || '0' }
|
|
251
|
+
}
|
|
252
|
+
])
|
|
253
|
+
|
|
254
|
+
return await parseFetchedUpdates(result, 'updates')
|
|
255
|
+
}
|
|
256
|
+
}
|
|
257
|
+
}
|
|
258
|
+
|
|
259
|
+
export const extractNewsletterMetadata = (node: BinaryNode, isCreate?: boolean) => {
|
|
260
|
+
const result = getBinaryNodeChild(node, 'result')?.content?.toString()
|
|
261
|
+
const metadataPath = JSON.parse(result!).data[isCreate ? XWAPaths.CREATE : XWAPaths.NEWSLETTER]
|
|
262
|
+
|
|
263
|
+
const metadata: NewsletterMetadata = {
|
|
264
|
+
id: metadataPath.id,
|
|
265
|
+
state: metadataPath.state.type,
|
|
266
|
+
'creation_time': +metadataPath.thread_metadata.creation_time,
|
|
267
|
+
name: metadataPath.thread_metadata.name.text,
|
|
268
|
+
nameTime: +metadataPath.thread_metadata.name.update_time,
|
|
269
|
+
description: metadataPath.thread_metadata.description.text,
|
|
270
|
+
descriptionTime: +metadataPath.thread_metadata.description.update_time,
|
|
271
|
+
invite: metadataPath.thread_metadata.invite,
|
|
272
|
+
handle: metadataPath.thread_metadata.handle,
|
|
273
|
+
picture: metadataPath.thread_metadata.picture?.direct_path || null,
|
|
274
|
+
preview: metadataPath.thread_metadata.preview?.direct_path || null,
|
|
275
|
+
'reaction_codes': metadataPath.thread_metadata?.settings?.reaction_codes?.value,
|
|
276
|
+
subscribers: +metadataPath.thread_metadata.subscribers_count,
|
|
277
|
+
verification: metadataPath.thread_metadata.verification,
|
|
278
|
+
'viewer_metadata': metadataPath.viewer_metadata
|
|
279
|
+
}
|
|
280
|
+
|
|
281
|
+
return metadata
|
|
282
|
+
}
|