@rizzkezik/bails 6.1.0
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 +21 -0
- package/README.md +535 -0
- package/WAProto/GenerateStatics.sh +3 -0
- package/WAProto/WAProto.proto +6902 -0
- package/WAProto/fix-imports.js +85 -0
- package/WAProto/index.d.ts +79257 -0
- package/WAProto/index.js +242946 -0
- package/engine-requirements.js +10 -0
- package/lib/Defaults/index.js +130 -0
- package/lib/Signal/Group/ciphertext-message.js +12 -0
- package/lib/Signal/Group/group-session-builder.js +30 -0
- package/lib/Signal/Group/group_cipher.js +82 -0
- package/lib/Signal/Group/index.js +12 -0
- package/lib/Signal/Group/keyhelper.js +18 -0
- package/lib/Signal/Group/sender-chain-key.js +26 -0
- package/lib/Signal/Group/sender-key-distribution-message.js +63 -0
- package/lib/Signal/Group/sender-key-message.js +66 -0
- package/lib/Signal/Group/sender-key-name.js +48 -0
- package/lib/Signal/Group/sender-key-record.js +41 -0
- package/lib/Signal/Group/sender-key-state.js +84 -0
- package/lib/Signal/Group/sender-message-key.js +26 -0
- package/lib/Signal/libsignal.js +431 -0
- package/lib/Signal/lid-mapping.js +277 -0
- package/lib/Socket/Client/index.js +3 -0
- package/lib/Socket/Client/types.js +11 -0
- package/lib/Socket/Client/websocket.js +54 -0
- package/lib/Socket/business.js +379 -0
- package/lib/Socket/chats.js +1193 -0
- package/lib/Socket/communities.js +431 -0
- package/lib/Socket/groups.js +374 -0
- package/lib/Socket/index.js +12 -0
- package/lib/Socket/luxu.js +387 -0
- package/lib/Socket/messages-recv.js +1916 -0
- package/lib/Socket/messages-send.js +1435 -0
- package/lib/Socket/mex.js +42 -0
- package/lib/Socket/newsletter.js +270 -0
- package/lib/Socket/socket.js +967 -0
- package/lib/Store/index.js +10 -0
- package/lib/Store/keyed-db.js +108 -0
- package/lib/Store/make-cache-manager-store.js +85 -0
- package/lib/Store/make-in-memory-store.js +198 -0
- package/lib/Store/make-ordered-dictionary.js +75 -0
- package/lib/Store/object-repository.js +32 -0
- package/lib/Types/Auth.js +2 -0
- package/lib/Types/Bussines.js +2 -0
- package/lib/Types/Call.js +2 -0
- package/lib/Types/Chat.js +8 -0
- package/lib/Types/Contact.js +2 -0
- package/lib/Types/Events.js +2 -0
- package/lib/Types/GroupMetadata.js +2 -0
- package/lib/Types/Label.js +25 -0
- package/lib/Types/LabelAssociation.js +7 -0
- package/lib/Types/Message.js +11 -0
- package/lib/Types/Mex.js +37 -0
- package/lib/Types/Product.js +2 -0
- package/lib/Types/Signal.js +2 -0
- package/lib/Types/Socket.js +3 -0
- package/lib/Types/State.js +56 -0
- package/lib/Types/USync.js +2 -0
- package/lib/Types/index.js +26 -0
- package/lib/Utils/auth-utils.js +302 -0
- package/lib/Utils/browser-utils.js +48 -0
- package/lib/Utils/business.js +231 -0
- package/lib/Utils/chat-utils.js +872 -0
- package/lib/Utils/companion-reg-client-utils.js +35 -0
- package/lib/Utils/crypto.js +118 -0
- package/lib/Utils/decode-wa-message.js +350 -0
- package/lib/Utils/event-buffer.js +622 -0
- package/lib/Utils/generics.js +403 -0
- package/lib/Utils/history.js +134 -0
- package/lib/Utils/identity-change-handler.js +50 -0
- package/lib/Utils/index.js +23 -0
- package/lib/Utils/link-preview.js +85 -0
- package/lib/Utils/logger.js +3 -0
- package/lib/Utils/lt-hash.js +8 -0
- package/lib/Utils/make-mutex.js +33 -0
- package/lib/Utils/message-composer.js +273 -0
- package/lib/Utils/message-retry-manager.js +265 -0
- package/lib/Utils/messages-media.js +788 -0
- package/lib/Utils/messages.js +1253 -0
- package/lib/Utils/noise-handler.js +201 -0
- package/lib/Utils/offline-node-processor.js +40 -0
- package/lib/Utils/pre-key-manager.js +106 -0
- package/lib/Utils/process-message.js +630 -0
- package/lib/Utils/reporting-utils.js +258 -0
- package/lib/Utils/signal.js +201 -0
- package/lib/Utils/stanza-ack.js +38 -0
- package/lib/Utils/sync-action-utils.js +49 -0
- package/lib/Utils/tc-token-utils.js +163 -0
- package/lib/Utils/use-multi-file-auth-state.js +121 -0
- package/lib/Utils/validate-connection.js +203 -0
- package/lib/WABinary/constants.js +1301 -0
- package/lib/WABinary/decode.js +262 -0
- package/lib/WABinary/encode.js +220 -0
- package/lib/WABinary/generic-utils.js +204 -0
- package/lib/WABinary/index.js +6 -0
- package/lib/WABinary/jid-utils.js +98 -0
- package/lib/WABinary/types.js +2 -0
- package/lib/WAM/BinaryInfo.js +10 -0
- package/lib/WAM/constants.js +22853 -0
- package/lib/WAM/encode.js +150 -0
- package/lib/WAM/index.js +4 -0
- package/lib/WAUSync/Protocols/USyncContactProtocol.js +52 -0
- package/lib/WAUSync/Protocols/USyncDeviceProtocol.js +54 -0
- package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.js +27 -0
- package/lib/WAUSync/Protocols/USyncStatusProtocol.js +38 -0
- package/lib/WAUSync/Protocols/USyncUsernameProtocol.js +25 -0
- package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.js +51 -0
- package/lib/WAUSync/Protocols/UsyncLIDProtocol.js +29 -0
- package/lib/WAUSync/Protocols/index.js +6 -0
- package/lib/WAUSync/USyncQuery.js +98 -0
- package/lib/WAUSync/USyncUser.js +31 -0
- package/lib/WAUSync/index.js +4 -0
- package/lib/index.js +31 -0
- package/package.json +143 -0
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
export * from './make-cache-manager-store.js';
|
|
2
|
+
export * from './make-in-memory-store.js';
|
|
3
|
+
export * from './make-ordered-dictionary.js';
|
|
4
|
+
export * from './object-repository.js';
|
|
5
|
+
export * from './keyed-db.js';
|
|
6
|
+
export { default as makeCacheManagerStore } from './make-cache-manager-store.js';
|
|
7
|
+
export { default as makeInMemoryStore } from './make-in-memory-store.js';
|
|
8
|
+
export { default as makeOrderedDictionary } from './make-ordered-dictionary.js';
|
|
9
|
+
export { default as objectRepository } from './object-repository.js';
|
|
10
|
+
export { default as keyedDB } from './keyed-db.js';
|
|
@@ -0,0 +1,108 @@
|
|
|
1
|
+
export default class KeyedDB {
|
|
2
|
+
constructor(compareFn, idGetter) {
|
|
3
|
+
if (typeof compareFn !== "function" || typeof idGetter !== "function") {
|
|
4
|
+
throw new Error("KeyedDB requires compare and idGetter functions");
|
|
5
|
+
}
|
|
6
|
+
this._compare = compareFn;
|
|
7
|
+
this._idGetter = idGetter;
|
|
8
|
+
this._array = [];
|
|
9
|
+
this._dict = {};
|
|
10
|
+
}
|
|
11
|
+
get length() {
|
|
12
|
+
return this._array.length;
|
|
13
|
+
}
|
|
14
|
+
get(id) {
|
|
15
|
+
return this._dict[id];
|
|
16
|
+
}
|
|
17
|
+
insert(entry, mode = "insert") {
|
|
18
|
+
const id = this._idGetter(entry);
|
|
19
|
+
const existing = this._dict[id];
|
|
20
|
+
if (existing && mode === "insert") {
|
|
21
|
+
return false;
|
|
22
|
+
}
|
|
23
|
+
this._dict[id] = entry;
|
|
24
|
+
let inserted = false;
|
|
25
|
+
for (let i = 0; i < this._array.length; i++) {
|
|
26
|
+
const cmp = this._compare(this._idGetter(this._array[i]), id);
|
|
27
|
+
if (cmp < 0) {
|
|
28
|
+
this._array.splice(i, 0, entry);
|
|
29
|
+
inserted = true;
|
|
30
|
+
break;
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
if (!inserted) this._array.push(entry);
|
|
34
|
+
return true;
|
|
35
|
+
}
|
|
36
|
+
insertIfAbsent(...entries) {
|
|
37
|
+
const added = [];
|
|
38
|
+
for (const entry of entries) {
|
|
39
|
+
if (!this._dict[this._idGetter(entry)]) {
|
|
40
|
+
this.insert(entry);
|
|
41
|
+
added.push(entry);
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
return added;
|
|
45
|
+
}
|
|
46
|
+
upsert(...entries) {
|
|
47
|
+
const added = [];
|
|
48
|
+
for (const entry of entries) {
|
|
49
|
+
const id = this._idGetter(entry);
|
|
50
|
+
if (this._dict[id]) {
|
|
51
|
+
const idx = this._array.findIndex(e => this._idGetter(e) === id);
|
|
52
|
+
if (idx >= 0) this._array[idx] = entry;
|
|
53
|
+
this._dict[id] = entry;
|
|
54
|
+
} else {
|
|
55
|
+
this.insert(entry);
|
|
56
|
+
added.push(entry);
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
return added;
|
|
60
|
+
}
|
|
61
|
+
update(id, updater) {
|
|
62
|
+
const item = this._dict[id];
|
|
63
|
+
if (!item) return false;
|
|
64
|
+
updater(item);
|
|
65
|
+
const idx = this._array.findIndex(e => this._idGetter(e) === id);
|
|
66
|
+
if (idx >= 0) this._array[idx] = item;
|
|
67
|
+
return true;
|
|
68
|
+
}
|
|
69
|
+
updateAssign(id, update) {
|
|
70
|
+
const item = this._dict[id];
|
|
71
|
+
if (!item) return false;
|
|
72
|
+
Object.assign(item, update);
|
|
73
|
+
const idx = this._array.findIndex(e => this._idGetter(e) === id);
|
|
74
|
+
if (idx >= 0) this._array[idx] = item;
|
|
75
|
+
return true;
|
|
76
|
+
}
|
|
77
|
+
deleteById(id) {
|
|
78
|
+
if (!this._dict[id]) return false;
|
|
79
|
+
delete this._dict[id];
|
|
80
|
+
const idx = this._array.findIndex(e => this._idGetter(e) === id);
|
|
81
|
+
if (idx >= 0) this._array.splice(idx, 1);
|
|
82
|
+
return true;
|
|
83
|
+
}
|
|
84
|
+
clear() {
|
|
85
|
+
this._array = [];
|
|
86
|
+
this._dict = {};
|
|
87
|
+
}
|
|
88
|
+
all() {
|
|
89
|
+
return [...this._array];
|
|
90
|
+
}
|
|
91
|
+
filter(predicate) {
|
|
92
|
+
this._array = this._array.filter(predicate);
|
|
93
|
+
this._dict = {};
|
|
94
|
+
for (const entry of this._array) {
|
|
95
|
+
this._dict[this._idGetter(entry)] = entry;
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
count() {
|
|
99
|
+
return this._array.length;
|
|
100
|
+
}
|
|
101
|
+
toJSON() {
|
|
102
|
+
return this._array;
|
|
103
|
+
}
|
|
104
|
+
fromJSON(array) {
|
|
105
|
+
this.clear();
|
|
106
|
+
for (const entry of array) this.insert(entry);
|
|
107
|
+
}
|
|
108
|
+
}
|
|
@@ -0,0 +1,85 @@
|
|
|
1
|
+
import { createRequire } from "module";
|
|
2
|
+
const require = createRequire(import.meta.url);
|
|
3
|
+
const cacheManager = require("cache-manager");
|
|
4
|
+
|
|
5
|
+
import * as WAProto_1 from "../../WAProto/index.js";
|
|
6
|
+
import * as Utils_1 from "../Utils/index.js";
|
|
7
|
+
import logger from "../Utils/logger.js";
|
|
8
|
+
|
|
9
|
+
export default async function makeCacheManagerAuthState(store, sessionKey) {
|
|
10
|
+
const defaultKey = (file) => `${sessionKey}:${file}`;
|
|
11
|
+
const databaseConn = await cacheManager.caching(store);
|
|
12
|
+
|
|
13
|
+
const writeData = async (file, data) => {
|
|
14
|
+
let ttl = undefined;
|
|
15
|
+
if (file === "creds") ttl = 63115200; // 2 years
|
|
16
|
+
await databaseConn.set(
|
|
17
|
+
defaultKey(file),
|
|
18
|
+
JSON.stringify(data, Utils_1.BufferJSON.replacer),
|
|
19
|
+
ttl
|
|
20
|
+
);
|
|
21
|
+
};
|
|
22
|
+
|
|
23
|
+
const readData = async (file) => {
|
|
24
|
+
try {
|
|
25
|
+
const data = await databaseConn.get(defaultKey(file));
|
|
26
|
+
if (data) return JSON.parse(data, Utils_1.BufferJSON.reviver);
|
|
27
|
+
return null;
|
|
28
|
+
} catch (error) {
|
|
29
|
+
logger.error(error);
|
|
30
|
+
return null;
|
|
31
|
+
}
|
|
32
|
+
};
|
|
33
|
+
|
|
34
|
+
const removeData = async (file) => {
|
|
35
|
+
try {
|
|
36
|
+
return await databaseConn.del(defaultKey(file));
|
|
37
|
+
} catch {
|
|
38
|
+
logger.error(`Error removing ${file} from session ${sessionKey}`);
|
|
39
|
+
}
|
|
40
|
+
};
|
|
41
|
+
|
|
42
|
+
const clearState = async () => {
|
|
43
|
+
try {
|
|
44
|
+
const result = await databaseConn.store.keys(`${sessionKey}*`);
|
|
45
|
+
await Promise.all(result.map(async (key) => databaseConn.del(key)));
|
|
46
|
+
} catch {}
|
|
47
|
+
};
|
|
48
|
+
|
|
49
|
+
const creds = (await readData("creds")) || Utils_1.initAuthCreds();
|
|
50
|
+
|
|
51
|
+
return {
|
|
52
|
+
clearState,
|
|
53
|
+
saveCreds: () => writeData("creds", creds),
|
|
54
|
+
state: {
|
|
55
|
+
creds,
|
|
56
|
+
keys: {
|
|
57
|
+
get: async (type, ids) => {
|
|
58
|
+
const data = {};
|
|
59
|
+
await Promise.all(
|
|
60
|
+
ids.map(async (id) => {
|
|
61
|
+
let value = await readData(`${type}-${id}`);
|
|
62
|
+
if (type === "app-state-sync-key" && value) {
|
|
63
|
+
value =
|
|
64
|
+
WAProto_1.proto.Message.AppStateSyncKeyData.fromObject(value);
|
|
65
|
+
}
|
|
66
|
+
data[id] = value;
|
|
67
|
+
})
|
|
68
|
+
);
|
|
69
|
+
return data;
|
|
70
|
+
},
|
|
71
|
+
set: async (data) => {
|
|
72
|
+
const tasks = [];
|
|
73
|
+
for (const category in data) {
|
|
74
|
+
for (const id in data[category]) {
|
|
75
|
+
const value = data[category][id];
|
|
76
|
+
const key = `${category}-${id}`;
|
|
77
|
+
tasks.push(value ? writeData(key, value) : removeData(key));
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
await Promise.all(tasks);
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
};
|
|
85
|
+
}
|
|
@@ -0,0 +1,198 @@
|
|
|
1
|
+
import * as WAProto_1 from "../../WAProto/index.js";
|
|
2
|
+
import * as Defaults_1 from "../Defaults/index.js";
|
|
3
|
+
import { LabelAssociationType } from "../Types/LabelAssociation.js";
|
|
4
|
+
import * as Utils_1 from "../Utils/index.js";
|
|
5
|
+
import * as WABinary_1 from "../WABinary/index.js";
|
|
6
|
+
import makeOrderedDictionary from "./make-ordered-dictionary.js";
|
|
7
|
+
import { ObjectRepository } from "./object-repository.js";
|
|
8
|
+
import KeyedDB from "./keyed-db.js";
|
|
9
|
+
|
|
10
|
+
const waChatKey = (pin) => ({
|
|
11
|
+
key: (c) =>
|
|
12
|
+
(pin ? (c.pinned ? "1" : "0") : "") +
|
|
13
|
+
(c.archived ? "0" : "1") +
|
|
14
|
+
(c.conversationTimestamp
|
|
15
|
+
? c.conversationTimestamp.toString(16).padStart(8, "0")
|
|
16
|
+
: "") +
|
|
17
|
+
c.id,
|
|
18
|
+
compare: (k1, k2) => k2.localeCompare(k1)
|
|
19
|
+
});
|
|
20
|
+
|
|
21
|
+
export const waMessageID = (m) => m.key.id || "";
|
|
22
|
+
|
|
23
|
+
export const waLabelAssociationKey = {
|
|
24
|
+
key: (la) =>
|
|
25
|
+
la.type === LabelAssociationType.Chat
|
|
26
|
+
? la.chatId + la.labelId
|
|
27
|
+
: la.chatId + la.messageId + la.labelId,
|
|
28
|
+
compare: (k1, k2) => k2.localeCompare(k1)
|
|
29
|
+
};
|
|
30
|
+
|
|
31
|
+
const makeMessagesDictionary = () => makeOrderedDictionary(waMessageID);
|
|
32
|
+
|
|
33
|
+
export default function makeInMemoryStore(config) {
|
|
34
|
+
const socket = config.socket;
|
|
35
|
+
const chatKey = config.chatKey || waChatKey(true);
|
|
36
|
+
const labelAssociationKey = config.labelAssociationKey || waLabelAssociationKey;
|
|
37
|
+
const logger =
|
|
38
|
+
config.logger ||
|
|
39
|
+
Defaults_1.DEFAULT_CONNECTION_CONFIG.logger.child({
|
|
40
|
+
stream: "in-mem-store"
|
|
41
|
+
});
|
|
42
|
+
|
|
43
|
+
const chats = new KeyedDB(chatKey.compare, chatKey.key);
|
|
44
|
+
const messages = {};
|
|
45
|
+
const contacts = {};
|
|
46
|
+
const groupMetadata = {};
|
|
47
|
+
const presences = {};
|
|
48
|
+
const state = { connection: "close" };
|
|
49
|
+
const labels = new ObjectRepository();
|
|
50
|
+
const labelAssociations = new KeyedDB(labelAssociationKey.compare, labelAssociationKey.key);
|
|
51
|
+
|
|
52
|
+
const assertMessageList = (jid) => {
|
|
53
|
+
if (!messages[jid]) messages[jid] = makeMessagesDictionary();
|
|
54
|
+
return messages[jid];
|
|
55
|
+
};
|
|
56
|
+
|
|
57
|
+
const contactsUpsert = (newContacts) => {
|
|
58
|
+
const oldContacts = new Set(Object.keys(contacts));
|
|
59
|
+
for (const contact of newContacts) {
|
|
60
|
+
oldContacts.delete(contact.id);
|
|
61
|
+
contacts[contact.id] = { ...(contacts[contact.id] || {}), ...contact };
|
|
62
|
+
}
|
|
63
|
+
return oldContacts;
|
|
64
|
+
};
|
|
65
|
+
|
|
66
|
+
const labelsUpsert = (newLabels) => {
|
|
67
|
+
for (const label of newLabels) labels.upsertById(label.id, label);
|
|
68
|
+
};
|
|
69
|
+
|
|
70
|
+
const bind = (ev) => {
|
|
71
|
+
ev.on("connection.update", (update) => Object.assign(state, update));
|
|
72
|
+
|
|
73
|
+
ev.on("messaging-history.set", ({ chats: newChats, contacts: newContacts, messages: newMessages, isLatest, syncType }) => {
|
|
74
|
+
if (syncType === WAProto_1.proto.HistorySync.HistorySyncType.ON_DEMAND) return;
|
|
75
|
+
if (isLatest) {
|
|
76
|
+
chats.clear();
|
|
77
|
+
for (const id in messages) delete messages[id];
|
|
78
|
+
}
|
|
79
|
+
chats.insertIfAbsent(...newChats);
|
|
80
|
+
const oldContacts = contactsUpsert(newContacts);
|
|
81
|
+
if (isLatest) for (const jid of oldContacts) delete contacts[jid];
|
|
82
|
+
for (const msg of newMessages) {
|
|
83
|
+
const jid = msg.key.remoteJid;
|
|
84
|
+
const list = assertMessageList(jid);
|
|
85
|
+
list.upsert(msg, "prepend");
|
|
86
|
+
}
|
|
87
|
+
});
|
|
88
|
+
|
|
89
|
+
ev.on("contacts.upsert", contactsUpsert);
|
|
90
|
+
|
|
91
|
+
ev.on("contacts.update", async (updates) => {
|
|
92
|
+
for (const update of updates) {
|
|
93
|
+
const contact = contacts[update.id];
|
|
94
|
+
if (contact) Object.assign(contact, update);
|
|
95
|
+
}
|
|
96
|
+
});
|
|
97
|
+
|
|
98
|
+
ev.on("chats.upsert", (newChats) => chats.upsert(...newChats));
|
|
99
|
+
|
|
100
|
+
ev.on("chats.update", (updates) => {
|
|
101
|
+
for (let update of updates) {
|
|
102
|
+
chats.update(update.id, (chat) => Object.assign(chat, update));
|
|
103
|
+
}
|
|
104
|
+
});
|
|
105
|
+
|
|
106
|
+
ev.on("labels.edit", (label) => {
|
|
107
|
+
if (label.deleted) return labels.deleteById(label.id);
|
|
108
|
+
if (labels.count() < 20) labels.upsertById(label.id, label);
|
|
109
|
+
});
|
|
110
|
+
|
|
111
|
+
ev.on("labels.association", ({ type, association }) => {
|
|
112
|
+
if (type === "add") labelAssociations.upsert(association);
|
|
113
|
+
if (type === "remove") labelAssociations.delete(association);
|
|
114
|
+
});
|
|
115
|
+
|
|
116
|
+
ev.on("presence.update", ({ id, presences: update }) => {
|
|
117
|
+
presences[id] = presences[id] || {};
|
|
118
|
+
Object.assign(presences[id], update);
|
|
119
|
+
});
|
|
120
|
+
|
|
121
|
+
ev.on("chats.delete", (deletions) => {
|
|
122
|
+
for (const item of deletions) chats.deleteById(item);
|
|
123
|
+
});
|
|
124
|
+
|
|
125
|
+
ev.on("messages.upsert", ({ messages: newMessages, type }) => {
|
|
126
|
+
if (type !== "append" && type !== "notify") return;
|
|
127
|
+
for (const msg of newMessages) {
|
|
128
|
+
const jid = WABinary_1.jidNormalizedUser(msg.key.remoteJid);
|
|
129
|
+
const list = assertMessageList(jid);
|
|
130
|
+
list.upsert(msg, "append");
|
|
131
|
+
if (type === "notify" && !chats.get(jid))
|
|
132
|
+
ev.emit("chats.upsert", [
|
|
133
|
+
{
|
|
134
|
+
id: jid,
|
|
135
|
+
conversationTimestamp: Utils_1.toNumber(msg.messageTimestamp),
|
|
136
|
+
unreadCount: 1
|
|
137
|
+
}
|
|
138
|
+
]);
|
|
139
|
+
}
|
|
140
|
+
});
|
|
141
|
+
|
|
142
|
+
ev.on("messages.update", (updates) => {
|
|
143
|
+
for (const { update, key } of updates) {
|
|
144
|
+
const list = assertMessageList(WABinary_1.jidNormalizedUser(key.remoteJid));
|
|
145
|
+
list.updateAssign(key.id, update);
|
|
146
|
+
}
|
|
147
|
+
});
|
|
148
|
+
|
|
149
|
+
ev.on("messages.delete", (item) => {
|
|
150
|
+
if ("all" in item) messages[item.jid]?.clear();
|
|
151
|
+
else {
|
|
152
|
+
const jid = item.keys[0].remoteJid;
|
|
153
|
+
const list = messages[jid];
|
|
154
|
+
if (list) {
|
|
155
|
+
const idSet = new Set(item.keys.map((k) => k.id));
|
|
156
|
+
list.filter((m) => !idSet.has(m.key.id));
|
|
157
|
+
}
|
|
158
|
+
}
|
|
159
|
+
});
|
|
160
|
+
};
|
|
161
|
+
|
|
162
|
+
const toJSON = () => ({
|
|
163
|
+
chats,
|
|
164
|
+
contacts,
|
|
165
|
+
messages,
|
|
166
|
+
labels,
|
|
167
|
+
labelAssociations
|
|
168
|
+
});
|
|
169
|
+
|
|
170
|
+
const fromJSON = (json) => {
|
|
171
|
+
chats.upsert(...json.chats);
|
|
172
|
+
labelAssociations.upsert(...(json.labelAssociations || []));
|
|
173
|
+
contactsUpsert(Object.values(json.contacts));
|
|
174
|
+
labelsUpsert(Object.values(json.labels || {}));
|
|
175
|
+
for (const jid in json.messages) {
|
|
176
|
+
const list = assertMessageList(jid);
|
|
177
|
+
for (const msg of json.messages[jid])
|
|
178
|
+
list.upsert(WAProto_1.proto.WebMessageInfo.fromObject(msg), "append");
|
|
179
|
+
}
|
|
180
|
+
};
|
|
181
|
+
const loadMessage = async (jid, id) => {
|
|
182
|
+
return messages[jid]?.get(id)
|
|
183
|
+
}
|
|
184
|
+
return {
|
|
185
|
+
chats,
|
|
186
|
+
contacts,
|
|
187
|
+
messages,
|
|
188
|
+
groupMetadata,
|
|
189
|
+
state,
|
|
190
|
+
presences,
|
|
191
|
+
labels,
|
|
192
|
+
labelAssociations,
|
|
193
|
+
bind,
|
|
194
|
+
toJSON,
|
|
195
|
+
fromJSON,
|
|
196
|
+
loadMessage
|
|
197
|
+
};
|
|
198
|
+
}
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
export default function makeOrderedDictionary(idGetter) {
|
|
2
|
+
const array = [];
|
|
3
|
+
const dict = {};
|
|
4
|
+
|
|
5
|
+
const get = (id) => dict[id];
|
|
6
|
+
|
|
7
|
+
const update = (item) => {
|
|
8
|
+
const id = idGetter(item);
|
|
9
|
+
const idx = array.findIndex(i => idGetter(i) === id);
|
|
10
|
+
if (idx >= 0) {
|
|
11
|
+
array[idx] = item;
|
|
12
|
+
dict[id] = item;
|
|
13
|
+
}
|
|
14
|
+
return false;
|
|
15
|
+
};
|
|
16
|
+
|
|
17
|
+
const upsert = (item, mode) => {
|
|
18
|
+
const id = idGetter(item);
|
|
19
|
+
if (get(id)) {
|
|
20
|
+
update(item);
|
|
21
|
+
} else {
|
|
22
|
+
if (mode === 'append') array.push(item);
|
|
23
|
+
else array.unshift(item);
|
|
24
|
+
dict[id] = item;
|
|
25
|
+
}
|
|
26
|
+
};
|
|
27
|
+
|
|
28
|
+
const remove = (item) => {
|
|
29
|
+
const id = idGetter(item);
|
|
30
|
+
const idx = array.findIndex(i => idGetter(i) === id);
|
|
31
|
+
if (idx >= 0) {
|
|
32
|
+
array.splice(idx, 1);
|
|
33
|
+
delete dict[id];
|
|
34
|
+
return true;
|
|
35
|
+
}
|
|
36
|
+
return false;
|
|
37
|
+
};
|
|
38
|
+
|
|
39
|
+
return {
|
|
40
|
+
array,
|
|
41
|
+
get,
|
|
42
|
+
upsert,
|
|
43
|
+
update,
|
|
44
|
+
remove,
|
|
45
|
+
updateAssign: (id, update) => {
|
|
46
|
+
const item = get(id);
|
|
47
|
+
if (item) {
|
|
48
|
+
Object.assign(item, update);
|
|
49
|
+
delete dict[id];
|
|
50
|
+
dict[idGetter(item)] = item;
|
|
51
|
+
return true;
|
|
52
|
+
}
|
|
53
|
+
return false;
|
|
54
|
+
},
|
|
55
|
+
clear: () => {
|
|
56
|
+
array.length = 0;
|
|
57
|
+
for (const key of Object.keys(dict)) delete dict[key];
|
|
58
|
+
},
|
|
59
|
+
filter: (contain) => {
|
|
60
|
+
let i = 0;
|
|
61
|
+
while (i < array.length) {
|
|
62
|
+
if (!contain(array[i])) {
|
|
63
|
+
delete dict[idGetter(array[i])];
|
|
64
|
+
array.splice(i, 1);
|
|
65
|
+
} else {
|
|
66
|
+
i++;
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
},
|
|
70
|
+
toJSON: () => array,
|
|
71
|
+
fromJSON: (newItems) => {
|
|
72
|
+
array.splice(0, array.length, ...newItems);
|
|
73
|
+
}
|
|
74
|
+
};
|
|
75
|
+
}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
export class ObjectRepository {
|
|
2
|
+
constructor(entities = {}) {
|
|
3
|
+
this.entityMap = new Map(Object.entries(entities));
|
|
4
|
+
}
|
|
5
|
+
|
|
6
|
+
findById(id) {
|
|
7
|
+
return this.entityMap.get(id);
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
findAll() {
|
|
11
|
+
return Array.from(this.entityMap.values());
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
upsertById(id, entity) {
|
|
15
|
+
this.entityMap.set(id, { ...entity });
|
|
16
|
+
return this;
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
deleteById(id) {
|
|
20
|
+
return this.entityMap.delete(id);
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
count() {
|
|
24
|
+
return this.entityMap.size;
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
toJSON() {
|
|
28
|
+
return this.findAll();
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
export default ObjectRepository;
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
/** WhatsApp has 20 predefined colors */
|
|
2
|
+
export var LabelColor;
|
|
3
|
+
(function (LabelColor) {
|
|
4
|
+
LabelColor[LabelColor["Color1"] = 0] = "Color1";
|
|
5
|
+
LabelColor[LabelColor["Color2"] = 1] = "Color2";
|
|
6
|
+
LabelColor[LabelColor["Color3"] = 2] = "Color3";
|
|
7
|
+
LabelColor[LabelColor["Color4"] = 3] = "Color4";
|
|
8
|
+
LabelColor[LabelColor["Color5"] = 4] = "Color5";
|
|
9
|
+
LabelColor[LabelColor["Color6"] = 5] = "Color6";
|
|
10
|
+
LabelColor[LabelColor["Color7"] = 6] = "Color7";
|
|
11
|
+
LabelColor[LabelColor["Color8"] = 7] = "Color8";
|
|
12
|
+
LabelColor[LabelColor["Color9"] = 8] = "Color9";
|
|
13
|
+
LabelColor[LabelColor["Color10"] = 9] = "Color10";
|
|
14
|
+
LabelColor[LabelColor["Color11"] = 10] = "Color11";
|
|
15
|
+
LabelColor[LabelColor["Color12"] = 11] = "Color12";
|
|
16
|
+
LabelColor[LabelColor["Color13"] = 12] = "Color13";
|
|
17
|
+
LabelColor[LabelColor["Color14"] = 13] = "Color14";
|
|
18
|
+
LabelColor[LabelColor["Color15"] = 14] = "Color15";
|
|
19
|
+
LabelColor[LabelColor["Color16"] = 15] = "Color16";
|
|
20
|
+
LabelColor[LabelColor["Color17"] = 16] = "Color17";
|
|
21
|
+
LabelColor[LabelColor["Color18"] = 17] = "Color18";
|
|
22
|
+
LabelColor[LabelColor["Color19"] = 18] = "Color19";
|
|
23
|
+
LabelColor[LabelColor["Color20"] = 19] = "Color20";
|
|
24
|
+
})(LabelColor || (LabelColor = {}));
|
|
25
|
+
//# sourceMappingURL=Label.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
/** Association type */
|
|
2
|
+
export var LabelAssociationType;
|
|
3
|
+
(function (LabelAssociationType) {
|
|
4
|
+
LabelAssociationType["Chat"] = "label_jid";
|
|
5
|
+
LabelAssociationType["Message"] = "label_message";
|
|
6
|
+
})(LabelAssociationType || (LabelAssociationType = {}));
|
|
7
|
+
//# sourceMappingURL=LabelAssociation.js.map
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { proto } from '../../WAProto/index.js';
|
|
2
|
+
// export the WAMessage Prototypes
|
|
3
|
+
export { proto as WAProto };
|
|
4
|
+
export const WAMessageStubType = proto.WebMessageInfo.StubType;
|
|
5
|
+
export const WAMessageStatus = proto.WebMessageInfo.Status;
|
|
6
|
+
export var WAMessageAddressingMode;
|
|
7
|
+
(function (WAMessageAddressingMode) {
|
|
8
|
+
WAMessageAddressingMode["PN"] = "pn";
|
|
9
|
+
WAMessageAddressingMode["LID"] = "lid";
|
|
10
|
+
})(WAMessageAddressingMode || (WAMessageAddressingMode = {}));
|
|
11
|
+
//# sourceMappingURL=Message.js.map
|
package/lib/Types/Mex.js
ADDED
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
export var XWAPaths;
|
|
2
|
+
(function (XWAPaths) {
|
|
3
|
+
XWAPaths["xwa2_newsletter_create"] = "xwa2_newsletter_create";
|
|
4
|
+
XWAPaths["xwa2_newsletter_subscribers"] = "xwa2_newsletter_subscribers";
|
|
5
|
+
XWAPaths["xwa2_newsletter_view"] = "xwa2_newsletter_view";
|
|
6
|
+
XWAPaths["xwa2_newsletter_metadata"] = "xwa2_newsletter";
|
|
7
|
+
XWAPaths["xwa2_newsletter_admin_count"] = "xwa2_newsletter_admin";
|
|
8
|
+
XWAPaths["xwa2_newsletter_mute_v2"] = "xwa2_newsletter_mute_v2";
|
|
9
|
+
XWAPaths["xwa2_newsletter_unmute_v2"] = "xwa2_newsletter_unmute_v2";
|
|
10
|
+
XWAPaths["xwa2_newsletter_follow"] = "xwa2_newsletter_follow";
|
|
11
|
+
XWAPaths["xwa2_newsletter_unfollow"] = "xwa2_newsletter_unfollow";
|
|
12
|
+
XWAPaths["xwa2_newsletter_join_v2"] = "xwa2_newsletter_join_v2";
|
|
13
|
+
XWAPaths["xwa2_newsletter_leave_v2"] = "xwa2_newsletter_leave_v2";
|
|
14
|
+
XWAPaths["xwa2_newsletter_change_owner"] = "xwa2_newsletter_change_owner";
|
|
15
|
+
XWAPaths["xwa2_newsletter_demote"] = "xwa2_newsletter_demote";
|
|
16
|
+
XWAPaths["xwa2_newsletter_delete_v2"] = "xwa2_newsletter_delete_v2";
|
|
17
|
+
XWAPaths["xwa2_fetch_account_reachout_timelock"] = "xwa2_fetch_account_reachout_timelock";
|
|
18
|
+
XWAPaths["xwa2_message_capping_info"] = "xwa2_message_capping_info";
|
|
19
|
+
})(XWAPaths || (XWAPaths = {}));
|
|
20
|
+
export var QueryIds;
|
|
21
|
+
(function (QueryIds) {
|
|
22
|
+
QueryIds["CREATE"] = "8823471724422422";
|
|
23
|
+
QueryIds["UPDATE_METADATA"] = "24250201037901610";
|
|
24
|
+
QueryIds["METADATA"] = "6563316087068696";
|
|
25
|
+
QueryIds["SUBSCRIBERS"] = "9783111038412085";
|
|
26
|
+
QueryIds["FOLLOW"] = "24404358912487870";
|
|
27
|
+
QueryIds["UNFOLLOW"] = "9767147403369991";
|
|
28
|
+
QueryIds["MUTE"] = "29766401636284406";
|
|
29
|
+
QueryIds["UNMUTE"] = "9864994326891137";
|
|
30
|
+
QueryIds["ADMIN_COUNT"] = "7130823597031706";
|
|
31
|
+
QueryIds["CHANGE_OWNER"] = "7341777602580933";
|
|
32
|
+
QueryIds["DEMOTE"] = "6551828931592903";
|
|
33
|
+
QueryIds["DELETE"] = "30062808666639665";
|
|
34
|
+
QueryIds["REACHOUT_TIMELOCK"] = "23983697327930364";
|
|
35
|
+
QueryIds["MESSAGE_CAPPING_INFO"] = "24503548349331633";
|
|
36
|
+
})(QueryIds || (QueryIds = {}));
|
|
37
|
+
//# sourceMappingURL=Mex.js.map
|