violetics 7.0.1-alpha → 7.0.2-alpha
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 +3 -2
- package/README.md +1001 -232
- package/WAProto/index.js +75379 -142631
- package/engine-requirements.js +11 -8
- package/lib/Defaults/index.js +132 -146
- package/lib/Signal/Group/ciphertext-message.js +2 -6
- package/lib/Signal/Group/group-session-builder.js +7 -42
- package/lib/Signal/Group/group_cipher.js +37 -52
- package/lib/Signal/Group/index.js +11 -57
- package/lib/Signal/Group/keyhelper.js +7 -45
- package/lib/Signal/Group/sender-chain-key.js +7 -16
- package/lib/Signal/Group/sender-key-distribution-message.js +8 -12
- package/lib/Signal/Group/sender-key-message.js +9 -13
- package/lib/Signal/Group/sender-key-name.js +2 -6
- package/lib/Signal/Group/sender-key-record.js +9 -22
- package/lib/Signal/Group/sender-key-state.js +27 -43
- package/lib/Signal/Group/sender-message-key.js +4 -8
- package/lib/Signal/libsignal.js +319 -94
- package/lib/Signal/lid-mapping.js +224 -139
- package/lib/Socket/Client/index.js +2 -19
- package/lib/Socket/Client/types.js +10 -0
- package/lib/Socket/Client/websocket.js +53 -0
- package/lib/Socket/business.js +162 -44
- package/lib/Socket/chats.js +477 -418
- package/lib/Socket/communities.js +430 -0
- package/lib/Socket/groups.js +110 -99
- package/lib/Socket/index.js +10 -10
- package/lib/Socket/messages-recv.js +884 -561
- package/lib/Socket/messages-send.js +859 -428
- package/lib/Socket/mex.js +41 -0
- package/lib/Socket/newsletter.js +195 -390
- package/lib/Socket/socket.js +465 -315
- package/lib/Store/index.js +3 -10
- package/lib/Store/make-in-memory-store.js +73 -79
- package/lib/Store/make-ordered-dictionary.js +4 -7
- package/lib/Store/object-repository.js +2 -6
- package/lib/Types/Auth.js +1 -2
- package/lib/Types/Bussines.js +1 -0
- package/lib/Types/Call.js +1 -2
- package/lib/Types/Chat.js +7 -4
- package/lib/Types/Contact.js +1 -2
- package/lib/Types/Events.js +1 -2
- package/lib/Types/GroupMetadata.js +1 -2
- package/lib/Types/Label.js +2 -5
- package/lib/Types/LabelAssociation.js +2 -5
- package/lib/Types/Message.js +17 -9
- package/lib/Types/Newsletter.js +33 -38
- package/lib/Types/Product.js +1 -2
- package/lib/Types/Signal.js +1 -2
- package/lib/Types/Socket.js +2 -2
- package/lib/Types/State.js +12 -2
- package/lib/Types/USync.js +1 -2
- package/lib/Types/index.js +14 -31
- package/lib/Utils/auth-utils.js +228 -152
- package/lib/Utils/browser-utils.js +28 -0
- package/lib/Utils/business.js +66 -70
- package/lib/Utils/chat-utils.js +331 -249
- package/lib/Utils/crypto.js +57 -91
- package/lib/Utils/decode-wa-message.js +168 -84
- package/lib/Utils/event-buffer.js +138 -80
- package/lib/Utils/generics.js +180 -297
- package/lib/Utils/history.js +83 -49
- package/lib/Utils/identity-change-handler.js +48 -0
- package/lib/Utils/index.js +19 -33
- package/lib/Utils/link-preview.js +14 -23
- package/lib/Utils/logger.js +2 -7
- package/lib/Utils/lt-hash.js +2 -46
- package/lib/Utils/make-mutex.js +24 -47
- package/lib/Utils/message-retry-manager.js +224 -0
- package/lib/Utils/messages-media.js +501 -496
- package/lib/Utils/messages.js +1428 -362
- package/lib/Utils/noise-handler.js +145 -100
- package/lib/Utils/pre-key-manager.js +105 -0
- package/lib/Utils/process-message.js +356 -150
- package/lib/Utils/reporting-utils.js +257 -0
- package/lib/Utils/signal.js +78 -73
- package/lib/Utils/sync-action-utils.js +47 -0
- package/lib/Utils/tc-token-utils.js +17 -0
- package/lib/Utils/use-multi-file-auth-state.js +35 -45
- package/lib/Utils/validate-connection.js +91 -107
- package/lib/WABinary/constants.js +1300 -1304
- package/lib/WABinary/decode.js +26 -48
- package/lib/WABinary/encode.js +109 -155
- package/lib/WABinary/generic-utils.js +161 -149
- package/lib/WABinary/index.js +5 -21
- package/lib/WABinary/jid-utils.js +73 -40
- package/lib/WABinary/types.js +1 -2
- package/lib/WAM/BinaryInfo.js +2 -6
- package/lib/WAM/constants.js +19070 -11568
- package/lib/WAM/encode.js +17 -23
- package/lib/WAM/index.js +3 -19
- package/lib/WAUSync/Protocols/USyncContactProtocol.js +8 -12
- package/lib/WAUSync/Protocols/USyncDeviceProtocol.js +11 -15
- package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.js +9 -13
- package/lib/WAUSync/Protocols/USyncStatusProtocol.js +9 -14
- package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.js +20 -23
- package/lib/WAUSync/Protocols/UsyncLIDProtocol.js +13 -9
- package/lib/WAUSync/Protocols/index.js +4 -20
- package/lib/WAUSync/USyncQuery.js +40 -36
- package/lib/WAUSync/USyncUser.js +2 -6
- package/lib/WAUSync/index.js +3 -19
- package/lib/index.js +11 -44
- package/package.json +74 -107
- package/lib/Defaults/baileys-version.json +0 -3
- package/lib/Defaults/phonenumber-mcc.json +0 -223
- package/lib/Signal/Group/queue-job.js +0 -57
- package/lib/Socket/Client/abstract-socket-client.js +0 -13
- package/lib/Socket/Client/mobile-socket-client.js +0 -65
- package/lib/Socket/Client/web-socket-client.js +0 -118
- package/lib/Socket/groupStatus.js +0 -637
- package/lib/Socket/registration.js +0 -166
- package/lib/Socket/usync.js +0 -70
- package/lib/Store/make-cache-manager-store.js +0 -83
- package/lib/Utils/baileys-event-stream.js +0 -63
|
@@ -1,82 +1,86 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
const boom_1 = require("@hapi/boom");
|
|
5
|
-
const WAProto_1 = require("../../WAProto");
|
|
6
|
-
const Utils_1 = require("../Utils")
|
|
1
|
+
import { Boom } from '@hapi/boom';
|
|
2
|
+
import { proto } from '../../WAProto/index.js';
|
|
3
|
+
import { } from './types.js';
|
|
7
4
|
// some extra useful utilities
|
|
8
|
-
const
|
|
9
|
-
|
|
10
|
-
|
|
5
|
+
const indexCache = new WeakMap();
|
|
6
|
+
export const getBinaryNodeChildren = (node, childTag) => {
|
|
7
|
+
if (!node || !Array.isArray(node.content))
|
|
8
|
+
return [];
|
|
9
|
+
let index = indexCache.get(node);
|
|
10
|
+
// Build the index once per node
|
|
11
|
+
if (!index) {
|
|
12
|
+
index = new Map();
|
|
13
|
+
for (const child of node.content) {
|
|
14
|
+
let arr = index.get(child.tag);
|
|
15
|
+
if (!arr)
|
|
16
|
+
index.set(child.tag, (arr = []));
|
|
17
|
+
arr.push(child);
|
|
18
|
+
}
|
|
19
|
+
indexCache.set(node, index);
|
|
11
20
|
}
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
const
|
|
21
|
+
// Return first matching child
|
|
22
|
+
return index.get(childTag) || [];
|
|
23
|
+
};
|
|
24
|
+
export const getBinaryNodeChild = (node, childTag) => {
|
|
25
|
+
return getBinaryNodeChildren(node, childTag)[0];
|
|
26
|
+
};
|
|
27
|
+
export const getAllBinaryNodeChildren = ({ content }) => {
|
|
16
28
|
if (Array.isArray(content)) {
|
|
17
|
-
return content
|
|
29
|
+
return content;
|
|
18
30
|
}
|
|
19
|
-
return []
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
const
|
|
23
|
-
if (Array.isArray(node?.content)) {
|
|
24
|
-
return node?.content.find(item => item.tag === childTag)
|
|
25
|
-
}
|
|
26
|
-
}
|
|
27
|
-
exports.getBinaryNodeChild = getBinaryNodeChild;
|
|
28
|
-
const getBinaryNodeChildBuffer = (node, childTag) => {
|
|
29
|
-
const child = getBinaryNodeChild(node, childTag)?.content
|
|
31
|
+
return [];
|
|
32
|
+
};
|
|
33
|
+
export const getBinaryNodeChildBuffer = (node, childTag) => {
|
|
34
|
+
const child = getBinaryNodeChild(node, childTag)?.content;
|
|
30
35
|
if (Buffer.isBuffer(child) || child instanceof Uint8Array) {
|
|
31
|
-
return child
|
|
36
|
+
return child;
|
|
32
37
|
}
|
|
33
|
-
}
|
|
34
|
-
|
|
35
|
-
const
|
|
36
|
-
const child = getBinaryNodeChild(node, childTag)?.content
|
|
38
|
+
};
|
|
39
|
+
export const getBinaryNodeChildString = (node, childTag) => {
|
|
40
|
+
const child = getBinaryNodeChild(node, childTag)?.content;
|
|
37
41
|
if (Buffer.isBuffer(child) || child instanceof Uint8Array) {
|
|
38
|
-
return Buffer.from(child).toString('utf-8')
|
|
42
|
+
return Buffer.from(child).toString('utf-8');
|
|
39
43
|
}
|
|
40
44
|
else if (typeof child === 'string') {
|
|
41
|
-
return child
|
|
45
|
+
return child;
|
|
42
46
|
}
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
const
|
|
46
|
-
const buff = getBinaryNodeChildBuffer(node, childTag)
|
|
47
|
+
};
|
|
48
|
+
export const getBinaryNodeChildUInt = (node, childTag, length) => {
|
|
49
|
+
const buff = getBinaryNodeChildBuffer(node, childTag);
|
|
47
50
|
if (buff) {
|
|
48
|
-
return bufferToUInt(buff, length)
|
|
51
|
+
return bufferToUInt(buff, length);
|
|
49
52
|
}
|
|
50
|
-
}
|
|
51
|
-
|
|
52
|
-
const
|
|
53
|
-
const errNode = getBinaryNodeChild(node, 'error')
|
|
53
|
+
};
|
|
54
|
+
export const assertNodeErrorFree = (node) => {
|
|
55
|
+
const errNode = getBinaryNodeChild(node, 'error');
|
|
54
56
|
if (errNode) {
|
|
55
|
-
throw new
|
|
57
|
+
throw new Boom(errNode.attrs.text || 'Unknown error', { data: +errNode.attrs.code });
|
|
56
58
|
}
|
|
57
|
-
}
|
|
58
|
-
|
|
59
|
-
const
|
|
60
|
-
const nodes = getBinaryNodeChildren(node, tag)
|
|
59
|
+
};
|
|
60
|
+
export const reduceBinaryNodeToDictionary = (node, tag) => {
|
|
61
|
+
const nodes = getBinaryNodeChildren(node, tag);
|
|
61
62
|
const dict = nodes.reduce((dict, { attrs }) => {
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
63
|
+
if (typeof attrs.name === 'string') {
|
|
64
|
+
dict[attrs.name] = attrs.value || attrs.config_value;
|
|
65
|
+
}
|
|
66
|
+
else {
|
|
67
|
+
dict[attrs.config_code] = attrs.value || attrs.config_value;
|
|
68
|
+
}
|
|
69
|
+
return dict;
|
|
70
|
+
}, {});
|
|
71
|
+
return dict;
|
|
72
|
+
};
|
|
73
|
+
export const getBinaryNodeMessages = ({ content }) => {
|
|
74
|
+
const msgs = [];
|
|
70
75
|
if (Array.isArray(content)) {
|
|
71
76
|
for (const item of content) {
|
|
72
77
|
if (item.tag === 'message') {
|
|
73
|
-
msgs.push(
|
|
78
|
+
msgs.push(proto.WebMessageInfo.decode(item.content).toJSON());
|
|
74
79
|
}
|
|
75
80
|
}
|
|
76
81
|
}
|
|
77
|
-
return msgs
|
|
78
|
-
}
|
|
79
|
-
exports.getBinaryNodeMessages = getBinaryNodeMessages;
|
|
82
|
+
return msgs;
|
|
83
|
+
};
|
|
80
84
|
function bufferToUInt(e, t) {
|
|
81
85
|
let a = 0;
|
|
82
86
|
for (let i = 0; i < t; i++) {
|
|
@@ -85,7 +89,7 @@ function bufferToUInt(e, t) {
|
|
|
85
89
|
return a;
|
|
86
90
|
}
|
|
87
91
|
const tabs = (n) => '\t'.repeat(n);
|
|
88
|
-
function binaryNodeToString(node, i = 0) {
|
|
92
|
+
export function binaryNodeToString(node, i = 0) {
|
|
89
93
|
if (!node) {
|
|
90
94
|
return node;
|
|
91
95
|
}
|
|
@@ -96,7 +100,7 @@ function binaryNodeToString(node, i = 0) {
|
|
|
96
100
|
return tabs(i) + Buffer.from(node).toString('hex');
|
|
97
101
|
}
|
|
98
102
|
if (Array.isArray(node)) {
|
|
99
|
-
return node.map(
|
|
103
|
+
return node.map(x => tabs(i + 1) + binaryNodeToString(x, i + 1)).join('\n');
|
|
100
104
|
}
|
|
101
105
|
const children = binaryNodeToString(node.content, i + 1);
|
|
102
106
|
const tag = `<${node.tag} ${Object.entries(node.attrs || {})
|
|
@@ -106,93 +110,101 @@ function binaryNodeToString(node, i = 0) {
|
|
|
106
110
|
const content = children ? `>\n${children}\n${tabs(i)}</${node.tag}>` : '/>';
|
|
107
111
|
return tag + content;
|
|
108
112
|
}
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
}
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
content: []
|
|
149
|
-
}]
|
|
150
|
-
} else if (flow_name[name] || name === 'interactive' || name === 'buttons') {
|
|
151
|
-
return [{
|
|
152
|
-
tag: 'biz',
|
|
153
|
-
attrs: {
|
|
154
|
-
actual_actors: '2',
|
|
155
|
-
host_storage: '2',
|
|
156
|
-
privacy_mode_ts: `${ts}`
|
|
157
|
-
},
|
|
158
|
-
content: [{
|
|
159
|
-
tag: 'engagement',
|
|
160
|
-
attrs: {
|
|
161
|
-
customer_service_state: 'open',
|
|
162
|
-
conversation_state: 'open'
|
|
163
|
-
}
|
|
164
|
-
}, {
|
|
165
|
-
tag: 'interactive',
|
|
166
|
-
attrs: {
|
|
167
|
-
type: 'native_flow',
|
|
168
|
-
v: '1'
|
|
169
|
-
},
|
|
170
|
-
content: [{
|
|
171
|
-
tag: 'native_flow',
|
|
172
|
-
attrs: {
|
|
173
|
-
v: '9',
|
|
174
|
-
name: flow_name[name] ?? 'mixed',
|
|
175
|
-
},
|
|
176
|
-
content: []
|
|
177
|
-
}]
|
|
178
|
-
}]
|
|
179
|
-
}]
|
|
180
|
-
} else {
|
|
181
|
-
return [{
|
|
182
|
-
tag: 'biz',
|
|
183
|
-
attrs: {
|
|
184
|
-
actual_actors: '2',
|
|
185
|
-
host_storage: '2',
|
|
186
|
-
privacy_mode_ts: `${ts}`
|
|
187
|
-
},
|
|
188
|
-
content: [{
|
|
189
|
-
tag: 'engagement',
|
|
113
|
+
/**
|
|
114
|
+
* vltcs@changes 30-01-26
|
|
115
|
+
* ---
|
|
116
|
+
* Produce the binary node (WABinary-like JSON shape) required for the specific
|
|
117
|
+
* interactive button / list type.
|
|
118
|
+
* compatible with observed official client traffic.
|
|
119
|
+
*
|
|
120
|
+
* NOTE: Returning different "v" (version) and "name" values influences how
|
|
121
|
+
* WhatsApp renders & validates flows. The constants here are empirically derived.
|
|
122
|
+
*
|
|
123
|
+
* @param {object} message Normalized message content (after Baileys normalization).
|
|
124
|
+
* @returns {object} A node with shape { tag, attrs, [content] } to inject into additionalNodes.
|
|
125
|
+
*/
|
|
126
|
+
const FLOWS_MAP = {
|
|
127
|
+
mpm: 1,
|
|
128
|
+
cta_catalog: 1,
|
|
129
|
+
send_location: 1,
|
|
130
|
+
call_permission_request: 1,
|
|
131
|
+
wa_payment_transaction_details: 1,
|
|
132
|
+
automated_greeting_message_view_catalog: 1
|
|
133
|
+
};
|
|
134
|
+
const qualityAttribute = {
|
|
135
|
+
tag: 'quality_control',
|
|
136
|
+
attrs: { source_type: 'third_party' }
|
|
137
|
+
};
|
|
138
|
+
const defaultContent = [qualityAttribute]
|
|
139
|
+
const listContent = [
|
|
140
|
+
{
|
|
141
|
+
tag: 'list',
|
|
142
|
+
attrs: { v: '2', type: 'product_list' }
|
|
143
|
+
},
|
|
144
|
+
qualityAttribute
|
|
145
|
+
];
|
|
146
|
+
export const getBizBinaryNode = (message) => {
|
|
147
|
+
const flowMsg = message.interactiveMessage?.nativeFlowMessage;
|
|
148
|
+
const buttonName = flowMsg?.buttons?.[0]?.name;
|
|
149
|
+
if (buttonName === 'review_and_pay' || buttonName === 'payment_info') {
|
|
150
|
+
return {
|
|
151
|
+
tag: 'biz',
|
|
190
152
|
attrs: {
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
}
|
|
198
|
-
|
|
153
|
+
native_flow_name: buttonName === 'review_and_pay' ?
|
|
154
|
+
'order_details' :
|
|
155
|
+
buttonName
|
|
156
|
+
},
|
|
157
|
+
content: defaultContent
|
|
158
|
+
};
|
|
159
|
+
}
|
|
160
|
+
else if (buttonName && FLOWS_MAP[buttonName]) {
|
|
161
|
+
return {
|
|
162
|
+
tag: 'biz',
|
|
163
|
+
attrs: {},
|
|
164
|
+
content: [
|
|
165
|
+
{
|
|
166
|
+
tag: 'interactive',
|
|
167
|
+
attrs: { type: 'native_flow', v: '1' },
|
|
168
|
+
content: [
|
|
169
|
+
{
|
|
170
|
+
tag: 'native_flow',
|
|
171
|
+
attrs: { v: '2', name: buttonName }
|
|
172
|
+
}
|
|
173
|
+
]
|
|
174
|
+
},
|
|
175
|
+
qualityAttribute
|
|
176
|
+
]
|
|
177
|
+
};
|
|
178
|
+
}
|
|
179
|
+
if (flowMsg || message.buttonsMessage || message.templateMessage) {
|
|
180
|
+
return {
|
|
181
|
+
tag: 'biz',
|
|
182
|
+
attrs: {},
|
|
183
|
+
content: [
|
|
184
|
+
{
|
|
185
|
+
tag: 'interactive',
|
|
186
|
+
attrs: { type: 'native_flow', v: '1' },
|
|
187
|
+
content: [
|
|
188
|
+
{
|
|
189
|
+
tag: 'native_flow',
|
|
190
|
+
attrs: { v: '9', name: 'mixed' }
|
|
191
|
+
}
|
|
192
|
+
]
|
|
193
|
+
},
|
|
194
|
+
qualityAttribute
|
|
195
|
+
]
|
|
196
|
+
};
|
|
197
|
+
}
|
|
198
|
+
else if (message.listMessage) {
|
|
199
|
+
return {
|
|
200
|
+
tag: 'biz',
|
|
201
|
+
attrs: {},
|
|
202
|
+
content: listContent
|
|
203
|
+
};
|
|
204
|
+
}
|
|
205
|
+
return {
|
|
206
|
+
tag: 'biz',
|
|
207
|
+
attrs: {},
|
|
208
|
+
content: defaultContent
|
|
209
|
+
};
|
|
210
|
+
}
|
package/lib/WABinary/index.js
CHANGED
|
@@ -1,21 +1,5 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
-
}
|
|
8
|
-
Object.defineProperty(o, k2, desc);
|
|
9
|
-
}) : (function(o, m, k, k2) {
|
|
10
|
-
if (k2 === undefined) k2 = k;
|
|
11
|
-
o[k2] = m[k];
|
|
12
|
-
}));
|
|
13
|
-
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
-
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
-
};
|
|
16
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
-
__exportStar(require("./encode"), exports);
|
|
18
|
-
__exportStar(require("./decode"), exports);
|
|
19
|
-
__exportStar(require("./generic-utils"), exports);
|
|
20
|
-
__exportStar(require("./jid-utils"), exports);
|
|
21
|
-
__exportStar(require("./types"), exports);
|
|
1
|
+
export * from './encode.js';
|
|
2
|
+
export * from './decode.js';
|
|
3
|
+
export * from './generic-utils.js';
|
|
4
|
+
export * from './jid-utils.js';
|
|
5
|
+
export * from './types.js';
|
|
@@ -1,16 +1,34 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
1
|
+
export const S_WHATSAPP_NET = '@s.whatsapp.net';
|
|
2
|
+
export const OFFICIAL_BIZ_JID = '16505361212@c.us';
|
|
3
|
+
export const SERVER_JID = 'server@c.us';
|
|
4
|
+
export const PSA_WID = '0@c.us';
|
|
5
|
+
export const STORIES_JID = 'status@broadcast';
|
|
6
|
+
export const META_AI_JID = '13135550002@c.us';
|
|
7
|
+
export var WAJIDDomains;
|
|
8
|
+
(function (WAJIDDomains) {
|
|
9
|
+
WAJIDDomains[WAJIDDomains["WHATSAPP"] = 0] = "WHATSAPP";
|
|
10
|
+
WAJIDDomains[WAJIDDomains["LID"] = 1] = "LID";
|
|
11
|
+
WAJIDDomains[WAJIDDomains["HOSTED"] = 128] = "HOSTED";
|
|
12
|
+
WAJIDDomains[WAJIDDomains["HOSTED_LID"] = 129] = "HOSTED_LID";
|
|
13
|
+
})(WAJIDDomains || (WAJIDDomains = {}));
|
|
14
|
+
export const getServerFromDomainType = (initialServer, domainType) => {
|
|
15
|
+
switch (domainType) {
|
|
16
|
+
case WAJIDDomains.LID:
|
|
17
|
+
return 'lid';
|
|
18
|
+
case WAJIDDomains.HOSTED:
|
|
19
|
+
return 'hosted';
|
|
20
|
+
case WAJIDDomains.HOSTED_LID:
|
|
21
|
+
return 'hosted.lid';
|
|
22
|
+
case WAJIDDomains.WHATSAPP:
|
|
23
|
+
default:
|
|
24
|
+
return initialServer;
|
|
25
|
+
}
|
|
26
|
+
};
|
|
27
|
+
export const jidEncode = (user, server, device, agent) => {
|
|
10
28
|
return `${user || ''}${!!agent ? `_${agent}` : ''}${!!device ? `:${device}` : ''}@${server}`;
|
|
11
29
|
};
|
|
12
|
-
|
|
13
|
-
|
|
30
|
+
export const jidDecode = (jid) => {
|
|
31
|
+
// todo: investigate how to implement hosted ids in this case
|
|
14
32
|
const sepIdx = typeof jid === 'string' ? jid.indexOf('@') : -1;
|
|
15
33
|
if (sepIdx < 0) {
|
|
16
34
|
return undefined;
|
|
@@ -18,45 +36,60 @@ const jidDecode = (jid) => {
|
|
|
18
36
|
const server = jid.slice(sepIdx + 1);
|
|
19
37
|
const userCombined = jid.slice(0, sepIdx);
|
|
20
38
|
const [userAgent, device] = userCombined.split(':');
|
|
21
|
-
const user = userAgent.split('_')
|
|
39
|
+
const [user, agent] = userAgent.split('_');
|
|
40
|
+
let domainType = WAJIDDomains.WHATSAPP;
|
|
41
|
+
if (server === 'lid') {
|
|
42
|
+
domainType = WAJIDDomains.LID;
|
|
43
|
+
}
|
|
44
|
+
else if (server === 'hosted') {
|
|
45
|
+
domainType = WAJIDDomains.HOSTED;
|
|
46
|
+
}
|
|
47
|
+
else if (server === 'hosted.lid') {
|
|
48
|
+
domainType = WAJIDDomains.HOSTED_LID;
|
|
49
|
+
}
|
|
50
|
+
else if (agent) {
|
|
51
|
+
domainType = parseInt(agent);
|
|
52
|
+
}
|
|
22
53
|
return {
|
|
23
|
-
server,
|
|
24
|
-
user,
|
|
25
|
-
domainType
|
|
54
|
+
server: server,
|
|
55
|
+
user: user,
|
|
56
|
+
domainType,
|
|
26
57
|
device: device ? +device : undefined
|
|
27
58
|
};
|
|
28
59
|
};
|
|
29
|
-
exports.jidDecode = jidDecode;
|
|
30
|
-
/** is the jid a user */
|
|
31
|
-
const areJidsSameUser = (jid1, jid2) => {
|
|
32
|
-
var _a, _b;
|
|
33
|
-
return (((_a = (0, exports.jidDecode)(jid1)) === null || _a === void 0 ? void 0 : _a.user) === ((_b = (0, exports.jidDecode)(jid2)) === null || _b === void 0 ? void 0 : _b.user));
|
|
34
|
-
};
|
|
35
|
-
exports.areJidsSameUser = areJidsSameUser;
|
|
36
60
|
/** is the jid a user */
|
|
37
|
-
const
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
61
|
+
export const areJidsSameUser = (jid1, jid2) => jidDecode(jid1)?.user === jidDecode(jid2)?.user;
|
|
62
|
+
/** is the jid Meta AI */
|
|
63
|
+
export const isJidMetaAI = (jid) => jid?.endsWith('@bot');
|
|
64
|
+
/** is the jid a PN user */
|
|
65
|
+
export const isPnUser = (jid) => jid?.endsWith('@s.whatsapp.net');
|
|
66
|
+
/** is the jid a LID */
|
|
67
|
+
export const isLidUser = (jid) => jid?.endsWith('@lid');
|
|
42
68
|
/** is the jid a broadcast */
|
|
43
|
-
const isJidBroadcast = (jid) =>
|
|
44
|
-
exports.isJidBroadcast = isJidBroadcast;
|
|
69
|
+
export const isJidBroadcast = (jid) => jid?.endsWith('@broadcast');
|
|
45
70
|
/** is the jid a group */
|
|
46
|
-
const isJidGroup = (jid) =>
|
|
47
|
-
exports.isJidGroup = isJidGroup;
|
|
71
|
+
export const isJidGroup = (jid) => jid?.endsWith('@g.us');
|
|
48
72
|
/** is the jid the status broadcast */
|
|
49
|
-
const isJidStatusBroadcast = (jid) => jid === 'status@broadcast';
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
73
|
+
export const isJidStatusBroadcast = (jid) => jid === 'status@broadcast';
|
|
74
|
+
/** is the jid a newsletter */
|
|
75
|
+
export const isJidNewsletter = (jid) => jid?.endsWith('@newsletter');
|
|
76
|
+
/** is the jid a hosted PN */
|
|
77
|
+
export const isHostedPnUser = (jid) => jid?.endsWith('@hosted');
|
|
78
|
+
/** is the jid a hosted LID */
|
|
79
|
+
export const isHostedLidUser = (jid) => jid?.endsWith('@hosted.lid');
|
|
80
|
+
const botRegexp = /^1313555\d{4}$|^131655500\d{2}$/;
|
|
81
|
+
export const isJidBot = (jid) => jid && botRegexp.test(jid.split('@')[0]) && jid.endsWith('@c.us');
|
|
82
|
+
export const jidNormalizedUser = (jid) => {
|
|
83
|
+
const result = jidDecode(jid);
|
|
56
84
|
if (!result) {
|
|
57
85
|
return '';
|
|
58
86
|
}
|
|
59
87
|
const { user, server } = result;
|
|
60
|
-
return
|
|
88
|
+
return jidEncode(user, server === 'c.us' ? 's.whatsapp.net' : server);
|
|
61
89
|
};
|
|
62
|
-
|
|
90
|
+
export const transferDevice = (fromJid, toJid) => {
|
|
91
|
+
const fromDecoded = jidDecode(fromJid);
|
|
92
|
+
const deviceId = fromDecoded?.device || 0;
|
|
93
|
+
const { server, user } = jidDecode(toJid);
|
|
94
|
+
return jidEncode(user, server, deviceId);
|
|
95
|
+
};
|
package/lib/WABinary/types.js
CHANGED
|
@@ -1,2 +1 @@
|
|
|
1
|
-
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
1
|
+
import * as constants from './constants.js';
|
package/lib/WAM/BinaryInfo.js
CHANGED
|
@@ -1,7 +1,4 @@
|
|
|
1
|
-
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.BinaryInfo = void 0;
|
|
4
|
-
class BinaryInfo {
|
|
1
|
+
export class BinaryInfo {
|
|
5
2
|
constructor(options = {}) {
|
|
6
3
|
this.protocolVersion = 5;
|
|
7
4
|
this.sequence = 0;
|
|
@@ -9,5 +6,4 @@ class BinaryInfo {
|
|
|
9
6
|
this.buffer = [];
|
|
10
7
|
Object.assign(this, options);
|
|
11
8
|
}
|
|
12
|
-
}
|
|
13
|
-
exports.BinaryInfo = BinaryInfo;
|
|
9
|
+
}
|