gifted-baileys 1.5.0 → 1.5.5
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 +1429 -684
- package/package.json +11 -26
- package/src/Defaults/baileys-version.json +3 -0
- package/{lib → src}/Defaults/index.js +16 -8
- package/src/Defaults/index.ts +131 -0
- package/src/Defaults/phonenumber-mcc.json +223 -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/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 -27
- package/src/Socket/business.ts +281 -0
- package/{lib → src}/Socket/chats.js +197 -178
- package/src/Socket/chats.ts +1030 -0
- package/{lib → src}/Socket/groups.js +69 -79
- 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 +160 -108
- package/src/Socket/messages-recv.ts +985 -0
- package/{lib → src}/Socket/messages-send.js +183 -100
- package/src/Socket/messages-send.ts +871 -0
- package/src/Socket/newsletter.js +227 -0
- package/src/Socket/newsletter.ts +282 -0
- package/{lib → src}/Socket/registration.js +55 -63
- package/src/Socket/registration.ts +250 -0
- package/{lib → src}/Socket/socket.js +107 -66
- 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 +51 -61
- 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/{lib → src}/Types/Label.js +1 -1
- package/src/Types/Label.ts +36 -0
- package/{lib → src}/Types/LabelAssociation.js +1 -1
- package/{lib/Types/LabelAssociation.d.ts → src/Types/LabelAssociation.ts} +22 -16
- package/src/Types/Message.ts +288 -0
- package/src/Types/Newsletter.js +32 -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 -56
- package/src/Types/State.ts +29 -0
- package/{lib → src}/Types/index.js +2 -1
- package/src/Types/index.ts +59 -0
- package/{lib → src}/Utils/auth-utils.js +95 -76
- 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 +45 -17
- package/src/Utils/business.ts +275 -0
- package/{lib → src}/Utils/chat-utils.js +74 -46
- package/src/Utils/chat-utils.ts +860 -0
- package/{lib → src}/Utils/crypto.js +31 -21
- 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 +98 -45
- package/src/Utils/generics.ts +434 -0
- package/{lib → src}/Utils/history.js +39 -10
- 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 +296 -192
- package/src/Utils/messages-media.ts +847 -0
- package/{lib → src}/Utils/messages.js +124 -113
- package/src/Utils/messages.ts +956 -0
- package/{lib → src}/Utils/noise-handler.js +16 -3
- package/src/Utils/noise-handler.ts +197 -0
- package/{lib → src}/Utils/process-message.js +33 -29
- package/src/Utils/process-message.ts +414 -0
- package/{lib → src}/Utils/signal.js +23 -14
- package/src/Utils/signal.ts +177 -0
- package/{lib → src}/Utils/use-multi-file-auth-state.js +28 -19
- package/src/Utils/use-multi-file-auth-state.ts +90 -0
- package/{lib → src}/Utils/validate-connection.js +25 -42
- package/src/Utils/validate-connection.ts +238 -0
- package/src/WABinary/constants.ts +42 -0
- package/{lib → src}/WABinary/decode.js +17 -7
- package/src/WABinary/decode.ts +265 -0
- package/{lib → src}/WABinary/encode.js +17 -7
- package/src/WABinary/encode.ts +236 -0
- package/{lib → src}/WABinary/generic-utils.js +2 -2
- package/src/WABinary/generic-utils.ts +121 -0
- package/src/WABinary/index.ts +5 -0
- package/{lib → src}/WABinary/jid-utils.js +4 -1
- package/src/WABinary/jid-utils.ts +68 -0
- package/src/WABinary/types.ts +17 -0
- package/src/WAM/BinaryInfo.js +13 -0
- package/src/WAM/BinaryInfo.ts +12 -0
- package/src/WAM/constants.js +15350 -0
- package/src/WAM/constants.ts +15382 -0
- package/src/WAM/encode.js +155 -0
- package/src/WAM/encode.ts +174 -0
- package/src/WAM/index.js +19 -0
- package/src/WAM/index.ts +3 -0
- package/src/gifted +1 -0
- package/{lib → src}/index.js +1 -0
- package/src/index.ts +13 -0
- package/lib/Defaults/baileys-version.json +0 -3
- package/lib/Defaults/index.d.ts +0 -284
- package/lib/Defaults/phonenumber-mcc.json +0 -223
- package/lib/Signal/libsignal.d.ts +0 -3
- package/lib/Signal/libsignal.js +0 -152
- package/lib/Socket/Client/abstract-socket-client.d.ts +0 -17
- 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 -135
- package/lib/Socket/chats.d.ts +0 -79
- package/lib/Socket/groups.d.ts +0 -113
- package/lib/Socket/index.d.ts +0 -137
- package/lib/Socket/messages-recv.d.ts +0 -124
- package/lib/Socket/messages-send.d.ts +0 -119
- package/lib/Socket/registration.d.ts +0 -232
- package/lib/Socket/socket.d.ts +0 -42
- 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 -117
- 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 -108
- package/lib/Types/Call.d.ts +0 -13
- package/lib/Types/Chat.d.ts +0 -102
- package/lib/Types/Events.d.ts +0 -157
- package/lib/Types/GroupMetadata.d.ts +0 -52
- package/lib/Types/Label.d.ts +0 -35
- package/lib/Types/Message.d.ts +0 -261
- 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/index.d.ts +0 -56
- 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 -71
- package/lib/Utils/crypto.d.ts +0 -41
- package/lib/Utils/decode-wa-message.d.ts +0 -19
- package/lib/Utils/decode-wa-message.js +0 -174
- package/lib/Utils/event-buffer.d.ts +0 -35
- package/lib/Utils/generics.d.ts +0 -94
- 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 -107
- package/lib/Utils/messages.d.ts +0 -76
- 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 -32
- 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 -7
- package/lib/WABinary/encode.d.ts +0 -3
- package/lib/WABinary/generic-utils.d.ts +0 -15
- package/lib/WABinary/index.d.ts +0 -5
- package/lib/WABinary/jid-utils.d.ts +0 -29
- package/lib/WABinary/types.d.ts +0 -18
- package/lib/index.d.ts +0 -10
- /package/{lib → src}/Socket/Client/abstract-socket-client.js +0 -0
- /package/{lib → src}/Socket/Client/index.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/Message.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}/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}/WABinary/constants.js +0 -0
- /package/{lib → src}/WABinary/index.js +0 -0
- /package/{lib → src}/WABinary/types.js +0 -0
|
@@ -0,0 +1,227 @@
|
|
|
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
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.extractNewsletterMetadata = exports.makeNewsletterSocket = void 0;
|
|
13
|
+
const Types_1 = require("../Types");
|
|
14
|
+
const Utils_1 = require("../Utils");
|
|
15
|
+
const WABinary_1 = require("../WABinary");
|
|
16
|
+
const groups_1 = require("./groups");
|
|
17
|
+
const makeNewsletterSocket = (config) => {
|
|
18
|
+
const sock = (0, groups_1.makeGroupsSocket)(config);
|
|
19
|
+
const { authState, signalRepository, query, generateMessageTag } = sock;
|
|
20
|
+
const encoder = new TextEncoder();
|
|
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* () {
|
|
54
|
+
let child;
|
|
55
|
+
if (type === 'messages') {
|
|
56
|
+
child = (0, WABinary_1.getBinaryNodeChild)(node, 'messages');
|
|
57
|
+
}
|
|
58
|
+
else {
|
|
59
|
+
const parent = (0, WABinary_1.getBinaryNodeChild)(node, 'message_updates');
|
|
60
|
+
child = (0, WABinary_1.getBinaryNodeChild)(parent, 'messages');
|
|
61
|
+
}
|
|
62
|
+
return yield Promise.all((0, WABinary_1.getAllBinaryNodeChildren)(child).map((messageNode) => __awaiter(void 0, void 0, void 0, function* () {
|
|
63
|
+
var _a, _b;
|
|
64
|
+
messageNode.attrs.from = child === null || child === void 0 ? void 0 : child.attrs.jid;
|
|
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');
|
|
66
|
+
const reactionNode = (0, WABinary_1.getBinaryNodeChild)(messageNode, 'reactions');
|
|
67
|
+
const reactions = (0, WABinary_1.getBinaryNodeChildren)(reactionNode, 'reaction')
|
|
68
|
+
.map(({ attrs }) => ({ count: +attrs.count, code: attrs.code }));
|
|
69
|
+
const data = {
|
|
70
|
+
'server_id': messageNode.attrs.server_id,
|
|
71
|
+
views,
|
|
72
|
+
reactions
|
|
73
|
+
};
|
|
74
|
+
if (type === 'messages') {
|
|
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();
|
|
77
|
+
data.message = message;
|
|
78
|
+
}
|
|
79
|
+
return data;
|
|
80
|
+
})));
|
|
81
|
+
});
|
|
82
|
+
return Object.assign(Object.assign({}, sock), { subscribeNewsletterUpdates: (jid) => __awaiter(void 0, void 0, void 0, function* () {
|
|
83
|
+
var _a;
|
|
84
|
+
const result = yield newsletterQuery(jid, 'set', [{ tag: 'live_updates', attrs: {}, content: [] }]);
|
|
85
|
+
return (_a = (0, WABinary_1.getBinaryNodeChild)(result, 'live_updates')) === null || _a === void 0 ? void 0 : _a.attrs;
|
|
86
|
+
}), newsletterReactionMode: (jid, mode) => __awaiter(void 0, void 0, void 0, function* () {
|
|
87
|
+
yield newsletterWMexQuery(jid, Types_1.QueryIds.JOB_MUTATION, {
|
|
88
|
+
updates: { settings: { 'reaction_codes': { value: mode } } }
|
|
89
|
+
});
|
|
90
|
+
}), newsletterUpdateDescription: (jid, description) => __awaiter(void 0, void 0, void 0, function* () {
|
|
91
|
+
yield newsletterWMexQuery(jid, Types_1.QueryIds.JOB_MUTATION, {
|
|
92
|
+
updates: { description: description || '', settings: null }
|
|
93
|
+
});
|
|
94
|
+
}), newsletterUpdateName: (jid, name) => __awaiter(void 0, void 0, void 0, function* () {
|
|
95
|
+
yield newsletterWMexQuery(jid, Types_1.QueryIds.JOB_MUTATION, {
|
|
96
|
+
updates: { name, settings: null }
|
|
97
|
+
});
|
|
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, {
|
|
101
|
+
updates: { picture: img.toString('base64'), settings: null }
|
|
102
|
+
});
|
|
103
|
+
}), newsletterRemovePicture: (jid) => __awaiter(void 0, void 0, void 0, function* () {
|
|
104
|
+
yield newsletterWMexQuery(jid, Types_1.QueryIds.JOB_MUTATION, {
|
|
105
|
+
updates: { picture: '', settings: null }
|
|
106
|
+
});
|
|
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* () {
|
|
118
|
+
//TODO: Implement TOS system wide for Meta AI, communities, and here etc.
|
|
119
|
+
/**tos query */
|
|
120
|
+
yield query({
|
|
121
|
+
tag: 'iq',
|
|
122
|
+
attrs: {
|
|
123
|
+
to: WABinary_1.S_WHATSAPP_NET,
|
|
124
|
+
xmlns: 'tos',
|
|
125
|
+
id: generateMessageTag(),
|
|
126
|
+
type: 'set'
|
|
127
|
+
},
|
|
128
|
+
content: [
|
|
129
|
+
{
|
|
130
|
+
tag: 'notice',
|
|
131
|
+
attrs: {
|
|
132
|
+
id: '20601218',
|
|
133
|
+
stage: '5'
|
|
134
|
+
},
|
|
135
|
+
content: []
|
|
136
|
+
}
|
|
137
|
+
]
|
|
138
|
+
});
|
|
139
|
+
const result = yield newsletterWMexQuery(undefined, Types_1.QueryIds.CREATE, {
|
|
140
|
+
input: { name, description, settings: { 'reaction_codes': { value: reaction_codes.toUpperCase() } } }
|
|
141
|
+
});
|
|
142
|
+
return (0, exports.extractNewsletterMetadata)(result, true);
|
|
143
|
+
}), newsletterMetadata: (type, key, role) => __awaiter(void 0, void 0, void 0, function* () {
|
|
144
|
+
const result = yield newsletterWMexQuery(undefined, Types_1.QueryIds.METADATA, {
|
|
145
|
+
input: {
|
|
146
|
+
key,
|
|
147
|
+
type: type.toUpperCase(),
|
|
148
|
+
'view_role': role || 'GUEST'
|
|
149
|
+
},
|
|
150
|
+
'fetch_viewer_metadata': true,
|
|
151
|
+
'fetch_full_image': true,
|
|
152
|
+
'fetch_creation_time': true
|
|
153
|
+
});
|
|
154
|
+
return (0, exports.extractNewsletterMetadata)(result);
|
|
155
|
+
}), newsletterAdminCount: (jid) => __awaiter(void 0, void 0, void 0, function* () {
|
|
156
|
+
var _a, _b;
|
|
157
|
+
const result = yield newsletterWMexQuery(jid, Types_1.QueryIds.ADMIN_COUNT);
|
|
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();
|
|
159
|
+
return JSON.parse(buff).data[Types_1.XWAPaths.ADMIN_COUNT].admin_count;
|
|
160
|
+
}),
|
|
161
|
+
/**user is Lid, not Jid */
|
|
162
|
+
newsletterChangeOwner: (jid, user) => __awaiter(void 0, void 0, void 0, function* () {
|
|
163
|
+
yield newsletterWMexQuery(jid, Types_1.QueryIds.CHANGE_OWNER, {
|
|
164
|
+
'user_id': user
|
|
165
|
+
});
|
|
166
|
+
}),
|
|
167
|
+
/**user is Lid, not Jid */
|
|
168
|
+
newsletterDemote: (jid, user) => __awaiter(void 0, void 0, void 0, function* () {
|
|
169
|
+
yield newsletterWMexQuery(jid, Types_1.QueryIds.DEMOTE, {
|
|
170
|
+
'user_id': user
|
|
171
|
+
});
|
|
172
|
+
}), newsletterDelete: (jid) => __awaiter(void 0, void 0, void 0, function* () {
|
|
173
|
+
yield newsletterWMexQuery(jid, Types_1.QueryIds.DELETE);
|
|
174
|
+
}),
|
|
175
|
+
/**if code wasn't passed, the reaction will be removed (if is reacted) */
|
|
176
|
+
newsletterReactMessage: (jid, serverId, code) => __awaiter(void 0, void 0, void 0, function* () {
|
|
177
|
+
yield query({
|
|
178
|
+
tag: 'message',
|
|
179
|
+
attrs: Object.assign(Object.assign({ to: jid }, (!code ? { edit: '7' } : {})), { type: 'reaction', 'server_id': serverId, id: (0, Utils_1.generateMessageID)() }),
|
|
180
|
+
content: [{
|
|
181
|
+
tag: 'reaction',
|
|
182
|
+
attrs: code ? { code } : {}
|
|
183
|
+
}]
|
|
184
|
+
});
|
|
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', [
|
|
187
|
+
{
|
|
188
|
+
tag: 'messages',
|
|
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' })
|
|
190
|
+
}
|
|
191
|
+
]);
|
|
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', [
|
|
195
|
+
{
|
|
196
|
+
tag: 'message_updates',
|
|
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' }
|
|
198
|
+
}
|
|
199
|
+
]);
|
|
200
|
+
return yield parseFetchedUpdates(result, 'updates');
|
|
201
|
+
}) });
|
|
202
|
+
};
|
|
203
|
+
exports.makeNewsletterSocket = makeNewsletterSocket;
|
|
204
|
+
const extractNewsletterMetadata = (node, isCreate) => {
|
|
205
|
+
var _a, _b, _c, _d, _e, _f, _g;
|
|
206
|
+
const result = (_b = (_a = (0, WABinary_1.getBinaryNodeChild)(node, 'result')) === null || _a === void 0 ? void 0 : _a.content) === null || _b === void 0 ? void 0 : _b.toString();
|
|
207
|
+
const metadataPath = JSON.parse(result).data[isCreate ? Types_1.XWAPaths.CREATE : Types_1.XWAPaths.NEWSLETTER];
|
|
208
|
+
const metadata = {
|
|
209
|
+
id: metadataPath.id,
|
|
210
|
+
state: metadataPath.state.type,
|
|
211
|
+
'creation_time': +metadataPath.thread_metadata.creation_time,
|
|
212
|
+
name: metadataPath.thread_metadata.name.text,
|
|
213
|
+
nameTime: +metadataPath.thread_metadata.name.update_time,
|
|
214
|
+
description: metadataPath.thread_metadata.description.text,
|
|
215
|
+
descriptionTime: +metadataPath.thread_metadata.description.update_time,
|
|
216
|
+
invite: metadataPath.thread_metadata.invite,
|
|
217
|
+
handle: metadataPath.thread_metadata.handle,
|
|
218
|
+
picture: ((_c = metadataPath.thread_metadata.picture) === null || _c === void 0 ? void 0 : _c.direct_path) || null,
|
|
219
|
+
preview: ((_d = metadataPath.thread_metadata.preview) === null || _d === void 0 ? void 0 : _d.direct_path) || null,
|
|
220
|
+
'reaction_codes': (_g = (_f = (_e = metadataPath.thread_metadata) === null || _e === void 0 ? void 0 : _e.settings) === null || _f === void 0 ? void 0 : _f.reaction_codes) === null || _g === void 0 ? void 0 : _g.value,
|
|
221
|
+
subscribers: +metadataPath.thread_metadata.subscribers_count,
|
|
222
|
+
verification: metadataPath.thread_metadata.verification,
|
|
223
|
+
'viewer_metadata': metadataPath.viewer_metadata
|
|
224
|
+
};
|
|
225
|
+
return metadata;
|
|
226
|
+
};
|
|
227
|
+
exports.extractNewsletterMetadata = extractNewsletterMetadata;
|
|
@@ -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
|
+
}
|
|
@@ -1,9 +1,24 @@
|
|
|
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
|
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
12
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
13
|
};
|
|
5
14
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
exports.
|
|
15
|
+
exports.makeRegistrationSocket = void 0;
|
|
16
|
+
exports.registrationParams = registrationParams;
|
|
17
|
+
exports.mobileRegisterCode = mobileRegisterCode;
|
|
18
|
+
exports.mobileRegisterExists = mobileRegisterExists;
|
|
19
|
+
exports.mobileRegister = mobileRegister;
|
|
20
|
+
exports.mobileRegisterEncrypt = mobileRegisterEncrypt;
|
|
21
|
+
exports.mobileRegisterFetch = mobileRegisterFetch;
|
|
7
22
|
/* eslint-disable camelcase */
|
|
8
23
|
const axios_1 = __importDefault(require("axios"));
|
|
9
24
|
const Defaults_1 = require("../Defaults");
|
|
@@ -18,11 +33,11 @@ const validRegistrationOptions = (config) => (config === null || config === void
|
|
|
18
33
|
config.phoneNumberMobileCountryCode;
|
|
19
34
|
const makeRegistrationSocket = (config) => {
|
|
20
35
|
const sock = (0, business_1.makeBusinessSocket)(config);
|
|
21
|
-
const register =
|
|
36
|
+
const register = (code) => __awaiter(void 0, void 0, void 0, function* () {
|
|
22
37
|
if (!validRegistrationOptions(config.auth.creds.registration)) {
|
|
23
38
|
throw new Error('please specify the registration options');
|
|
24
39
|
}
|
|
25
|
-
const result =
|
|
40
|
+
const result = yield mobileRegister(Object.assign(Object.assign(Object.assign({}, sock.authState.creds), sock.authState.creds.registration), { code }), config.options);
|
|
26
41
|
sock.authState.creds.me = {
|
|
27
42
|
id: (0, WABinary_1.jidEncode)(result.login, 's.whatsapp.net'),
|
|
28
43
|
name: '~'
|
|
@@ -30,21 +45,18 @@ const makeRegistrationSocket = (config) => {
|
|
|
30
45
|
sock.authState.creds.registered = true;
|
|
31
46
|
sock.ev.emit('creds.update', sock.authState.creds);
|
|
32
47
|
return result;
|
|
33
|
-
};
|
|
34
|
-
const requestRegistrationCode =
|
|
48
|
+
});
|
|
49
|
+
const requestRegistrationCode = (registrationOptions) => __awaiter(void 0, void 0, void 0, function* () {
|
|
35
50
|
registrationOptions = registrationOptions || config.auth.creds.registration;
|
|
36
51
|
if (!validRegistrationOptions(registrationOptions)) {
|
|
37
52
|
throw new Error('Invalid registration options');
|
|
38
53
|
}
|
|
39
54
|
sock.authState.creds.registration = registrationOptions;
|
|
40
55
|
sock.ev.emit('creds.update', sock.authState.creds);
|
|
41
|
-
return mobileRegisterCode({
|
|
42
|
-
};
|
|
43
|
-
return {
|
|
44
|
-
|
|
45
|
-
register,
|
|
46
|
-
requestRegistrationCode,
|
|
47
|
-
};
|
|
56
|
+
return mobileRegisterCode(Object.assign(Object.assign({}, config.auth.creds), registrationOptions), config.options);
|
|
57
|
+
});
|
|
58
|
+
return Object.assign(Object.assign({}, sock), { register,
|
|
59
|
+
requestRegistrationCode });
|
|
48
60
|
};
|
|
49
61
|
exports.makeRegistrationSocket = makeRegistrationSocket;
|
|
50
62
|
function convertBufferToUrlHex(buffer) {
|
|
@@ -89,44 +101,24 @@ function registrationParams(params) {
|
|
|
89
101
|
fraud_checkpoint_code: params.captcha,
|
|
90
102
|
};
|
|
91
103
|
}
|
|
92
|
-
exports.registrationParams = registrationParams;
|
|
93
104
|
/**
|
|
94
105
|
* Requests a registration code for the given phone number.
|
|
95
106
|
*/
|
|
96
107
|
function mobileRegisterCode(params, fetchOptions) {
|
|
97
|
-
return mobileRegisterFetch('/code', {
|
|
98
|
-
params: {
|
|
99
|
-
...registrationParams(params),
|
|
100
|
-
mcc: `${params.phoneNumberMobileCountryCode}`.padStart(3, '0'),
|
|
101
|
-
mnc: `${params.phoneNumberMobileNetworkCode || '001'}`.padStart(3, '0'),
|
|
102
|
-
sim_mcc: '000',
|
|
103
|
-
sim_mnc: '000',
|
|
104
|
-
method: (params === null || params === void 0 ? void 0 : params.method) || 'sms',
|
|
105
|
-
reason: '',
|
|
106
|
-
hasav: '1'
|
|
107
|
-
},
|
|
108
|
-
...fetchOptions,
|
|
109
|
-
});
|
|
108
|
+
return mobileRegisterFetch('/code', Object.assign({ params: Object.assign(Object.assign({}, registrationParams(params)), { mcc: `${params.phoneNumberMobileCountryCode}`.padStart(3, '0'), mnc: `${params.phoneNumberMobileNetworkCode || '001'}`.padStart(3, '0'), sim_mcc: '000', sim_mnc: '000', method: (params === null || params === void 0 ? void 0 : params.method) || 'sms', reason: '', hasav: '1' }) }, fetchOptions));
|
|
110
109
|
}
|
|
111
|
-
exports.mobileRegisterCode = mobileRegisterCode;
|
|
112
110
|
function mobileRegisterExists(params, fetchOptions) {
|
|
113
|
-
return mobileRegisterFetch('/exist', {
|
|
114
|
-
params: registrationParams(params),
|
|
115
|
-
...fetchOptions
|
|
116
|
-
});
|
|
111
|
+
return mobileRegisterFetch('/exist', Object.assign({ params: registrationParams(params) }, fetchOptions));
|
|
117
112
|
}
|
|
118
|
-
exports.mobileRegisterExists = mobileRegisterExists;
|
|
119
113
|
/**
|
|
120
114
|
* Registers the phone number on whatsapp with the received OTP code.
|
|
121
115
|
*/
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
params: {
|
|
126
|
-
...fetchOptions,
|
|
116
|
+
function mobileRegister(params, fetchOptions) {
|
|
117
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
118
|
+
//const result = await mobileRegisterFetch(`/reg_onboard_abprop?cc=${params.phoneNumberCountryCode}&in=${params.phoneNumberNationalNumber}&rc=0`)
|
|
119
|
+
return mobileRegisterFetch('/register', Object.assign({ params: Object.assign(Object.assign({}, registrationParams(params)), { code: params.code.replace('-', '') }) }, fetchOptions));
|
|
127
120
|
});
|
|
128
121
|
}
|
|
129
|
-
exports.mobileRegister = mobileRegister;
|
|
130
122
|
/**
|
|
131
123
|
* Encrypts the given string as AEAD aes-256-gcm with the public whatsapp key and a random keypair.
|
|
132
124
|
*/
|
|
@@ -136,31 +128,31 @@ function mobileRegisterEncrypt(data) {
|
|
|
136
128
|
const buffer = (0, crypto_1.aesEncryptGCM)(Buffer.from(data), new Uint8Array(key), Buffer.alloc(12), Buffer.alloc(0));
|
|
137
129
|
return Buffer.concat([Buffer.from(keypair.public), buffer]).toString('base64url');
|
|
138
130
|
}
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
131
|
+
function mobileRegisterFetch(path_1) {
|
|
132
|
+
return __awaiter(this, arguments, void 0, function* (path, opts = {}) {
|
|
133
|
+
let url = `${Defaults_1.MOBILE_REGISTRATION_ENDPOINT}${path}`;
|
|
134
|
+
if (opts.params) {
|
|
135
|
+
const parameter = [];
|
|
136
|
+
for (const param in opts.params) {
|
|
137
|
+
if (opts.params[param] !== null && opts.params[param] !== undefined) {
|
|
138
|
+
parameter.push(param + '=' + urlencode(opts.params[param]));
|
|
139
|
+
}
|
|
147
140
|
}
|
|
141
|
+
url += `?${parameter.join('&')}`;
|
|
142
|
+
delete opts.params;
|
|
143
|
+
}
|
|
144
|
+
if (!opts.headers) {
|
|
145
|
+
opts.headers = {};
|
|
146
|
+
}
|
|
147
|
+
opts.headers['User-Agent'] = Defaults_1.MOBILE_USERAGENT;
|
|
148
|
+
const response = yield (0, axios_1.default)(url, opts);
|
|
149
|
+
var json = response.data;
|
|
150
|
+
if (response.status > 300 || json.reason) {
|
|
151
|
+
throw json;
|
|
148
152
|
}
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
}
|
|
155
|
-
opts.headers['User-Agent'] = Defaults_1.MOBILE_USERAGENT;
|
|
156
|
-
const response = await (0, axios_1.default)(url, opts);
|
|
157
|
-
var json = response.data;
|
|
158
|
-
if (response.status > 300 || json.reason) {
|
|
159
|
-
throw json;
|
|
160
|
-
}
|
|
161
|
-
if (json.status && !['ok', 'sent'].includes(json.status)) {
|
|
162
|
-
throw json;
|
|
163
|
-
}
|
|
164
|
-
return json;
|
|
153
|
+
if (json.status && !['ok', 'sent'].includes(json.status)) {
|
|
154
|
+
throw json;
|
|
155
|
+
}
|
|
156
|
+
return json;
|
|
157
|
+
});
|
|
165
158
|
}
|
|
166
|
-
exports.mobileRegisterFetch = mobileRegisterFetch;
|