@queenanya/baileys 7.5.11 → 8.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.
Files changed (157) hide show
  1. package/package.json +13 -97
  2. package/LICENSE +0 -21
  3. package/README.md +0 -931
  4. package/WAProto/GenerateStatics.sh +0 -4
  5. package/WAProto/WAProto.proto +0 -3344
  6. package/WAProto/index.d.ts +0 -37016
  7. package/WAProto/index.js +0 -101044
  8. package/WASignalGroup/GroupProtocol.js +0 -1697
  9. package/WASignalGroup/ciphertext_message.js +0 -16
  10. package/WASignalGroup/group_cipher.js +0 -120
  11. package/WASignalGroup/group_session_builder.js +0 -46
  12. package/WASignalGroup/index.js +0 -5
  13. package/WASignalGroup/keyhelper.js +0 -21
  14. package/WASignalGroup/protobufs.js +0 -3
  15. package/WASignalGroup/queue_job.js +0 -69
  16. package/WASignalGroup/sender_chain_key.js +0 -50
  17. package/WASignalGroup/sender_key_distribution_message.js +0 -78
  18. package/WASignalGroup/sender_key_message.js +0 -92
  19. package/WASignalGroup/sender_key_name.js +0 -70
  20. package/WASignalGroup/sender_key_record.js +0 -56
  21. package/WASignalGroup/sender_key_state.js +0 -129
  22. package/WASignalGroup/sender_message_key.js +0 -39
  23. package/lib/Defaults/baileys-version.json +0 -3
  24. package/lib/Defaults/index.d.ts +0 -53
  25. package/lib/Defaults/index.js +0 -107
  26. package/lib/Signal/libsignal.d.ts +0 -3
  27. package/lib/Signal/libsignal.js +0 -152
  28. package/lib/Socket/Client/index.d.ts +0 -2
  29. package/lib/Socket/Client/index.js +0 -18
  30. package/lib/Socket/Client/types.d.ts +0 -17
  31. package/lib/Socket/Client/types.js +0 -13
  32. package/lib/Socket/Client/websocket.d.ts +0 -12
  33. package/lib/Socket/Client/websocket.js +0 -62
  34. package/lib/Socket/business.d.ts +0 -177
  35. package/lib/Socket/business.js +0 -260
  36. package/lib/Socket/chats.d.ts +0 -91
  37. package/lib/Socket/chats.js +0 -949
  38. package/lib/Socket/groups.d.ts +0 -131
  39. package/lib/Socket/groups.js +0 -314
  40. package/lib/Socket/index.d.ts +0 -177
  41. package/lib/Socket/index.js +0 -10
  42. package/lib/Socket/messages-recv.d.ts +0 -164
  43. package/lib/Socket/messages-recv.js +0 -918
  44. package/lib/Socket/messages-send.d.ts +0 -157
  45. package/lib/Socket/messages-send.js +0 -794
  46. package/lib/Socket/newsletter.d.ts +0 -143
  47. package/lib/Socket/newsletter.js +0 -249
  48. package/lib/Socket/socket.d.ts +0 -45
  49. package/lib/Socket/socket.js +0 -616
  50. package/lib/Store/index.d.ts +0 -3
  51. package/lib/Store/index.js +0 -10
  52. package/lib/Store/make-cache-manager-store.d.ts +0 -14
  53. package/lib/Store/make-cache-manager-store.js +0 -83
  54. package/lib/Store/make-in-memory-store.d.ts +0 -118
  55. package/lib/Store/make-in-memory-store.js +0 -420
  56. package/lib/Store/make-ordered-dictionary.d.ts +0 -13
  57. package/lib/Store/make-ordered-dictionary.js +0 -81
  58. package/lib/Store/object-repository.d.ts +0 -10
  59. package/lib/Store/object-repository.js +0 -27
  60. package/lib/Types/Auth.d.ts +0 -105
  61. package/lib/Types/Auth.js +0 -2
  62. package/lib/Types/Call.d.ts +0 -13
  63. package/lib/Types/Call.js +0 -2
  64. package/lib/Types/Chat.d.ts +0 -107
  65. package/lib/Types/Chat.js +0 -4
  66. package/lib/Types/Contact.d.ts +0 -19
  67. package/lib/Types/Contact.js +0 -2
  68. package/lib/Types/Events.d.ts +0 -199
  69. package/lib/Types/Events.js +0 -2
  70. package/lib/Types/GroupMetadata.d.ts +0 -56
  71. package/lib/Types/GroupMetadata.js +0 -2
  72. package/lib/Types/Label.d.ts +0 -46
  73. package/lib/Types/Label.js +0 -27
  74. package/lib/Types/LabelAssociation.d.ts +0 -29
  75. package/lib/Types/LabelAssociation.js +0 -9
  76. package/lib/Types/Message.d.ts +0 -280
  77. package/lib/Types/Message.js +0 -9
  78. package/lib/Types/Newsletter.d.ts +0 -79
  79. package/lib/Types/Newsletter.js +0 -18
  80. package/lib/Types/Product.d.ts +0 -78
  81. package/lib/Types/Product.js +0 -2
  82. package/lib/Types/Signal.d.ts +0 -57
  83. package/lib/Types/Signal.js +0 -2
  84. package/lib/Types/Socket.d.ts +0 -118
  85. package/lib/Types/Socket.js +0 -2
  86. package/lib/Types/State.d.ts +0 -27
  87. package/lib/Types/State.js +0 -2
  88. package/lib/Types/index.d.ts +0 -65
  89. package/lib/Types/index.js +0 -42
  90. package/lib/Utils/auth-utils.d.ts +0 -18
  91. package/lib/Utils/auth-utils.js +0 -200
  92. package/lib/Utils/baileys-event-stream.d.ts +0 -16
  93. package/lib/Utils/baileys-event-stream.js +0 -63
  94. package/lib/Utils/business.d.ts +0 -22
  95. package/lib/Utils/business.js +0 -234
  96. package/lib/Utils/chat-utils.d.ts +0 -72
  97. package/lib/Utils/chat-utils.js +0 -745
  98. package/lib/Utils/crypto.d.ts +0 -42
  99. package/lib/Utils/crypto.js +0 -153
  100. package/lib/Utils/decode-wa-message.d.ts +0 -20
  101. package/lib/Utils/decode-wa-message.js +0 -218
  102. package/lib/Utils/event-buffer.d.ts +0 -35
  103. package/lib/Utils/event-buffer.js +0 -520
  104. package/lib/Utils/generics.d.ts +0 -119
  105. package/lib/Utils/generics.js +0 -467
  106. package/lib/Utils/history.d.ts +0 -19
  107. package/lib/Utils/history.js +0 -94
  108. package/lib/Utils/index.d.ts +0 -18
  109. package/lib/Utils/index.js +0 -34
  110. package/lib/Utils/link-preview.d.ts +0 -21
  111. package/lib/Utils/link-preview.js +0 -116
  112. package/lib/Utils/logger.d.ts +0 -2
  113. package/lib/Utils/logger.js +0 -7
  114. package/lib/Utils/lt-hash.d.ts +0 -12
  115. package/lib/Utils/lt-hash.js +0 -51
  116. package/lib/Utils/make-mutex.d.ts +0 -7
  117. package/lib/Utils/make-mutex.js +0 -44
  118. package/lib/Utils/messages-media.d.ts +0 -131
  119. package/lib/Utils/messages-media.js +0 -786
  120. package/lib/Utils/messages.d.ts +0 -78
  121. package/lib/Utils/messages.js +0 -767
  122. package/lib/Utils/noise-handler.d.ts +0 -21
  123. package/lib/Utils/noise-handler.js +0 -150
  124. package/lib/Utils/process-message.d.ts +0 -42
  125. package/lib/Utils/process-message.js +0 -355
  126. package/lib/Utils/signal.d.ts +0 -32
  127. package/lib/Utils/signal.js +0 -158
  128. package/lib/Utils/use-multi-file-auth-state.d.ts +0 -12
  129. package/lib/Utils/use-multi-file-auth-state.js +0 -94
  130. package/lib/Utils/use-single-file-auth-state.d.ts +0 -5
  131. package/lib/Utils/use-single-file-auth-state.js +0 -66
  132. package/lib/Utils/validate-connection.d.ts +0 -10
  133. package/lib/Utils/validate-connection.js +0 -171
  134. package/lib/WABinary/constants.d.ts +0 -27
  135. package/lib/WABinary/constants.js +0 -40
  136. package/lib/WABinary/decode.d.ts +0 -8
  137. package/lib/WABinary/decode.js +0 -254
  138. package/lib/WABinary/encode.d.ts +0 -2
  139. package/lib/WABinary/encode.js +0 -230
  140. package/lib/WABinary/generic-utils.d.ts +0 -16
  141. package/lib/WABinary/generic-utils.js +0 -110
  142. package/lib/WABinary/index.d.ts +0 -5
  143. package/lib/WABinary/index.js +0 -21
  144. package/lib/WABinary/jid-utils.d.ts +0 -31
  145. package/lib/WABinary/jid-utils.js +0 -62
  146. package/lib/WABinary/types.d.ts +0 -18
  147. package/lib/WABinary/types.js +0 -2
  148. package/lib/WAM/BinaryInfo.d.ts +0 -18
  149. package/lib/WAM/BinaryInfo.js +0 -13
  150. package/lib/WAM/constants.d.ts +0 -39
  151. package/lib/WAM/constants.js +0 -15350
  152. package/lib/WAM/encode.d.ts +0 -4
  153. package/lib/WAM/encode.js +0 -155
  154. package/lib/WAM/index.d.ts +0 -3
  155. package/lib/WAM/index.js +0 -19
  156. package/lib/index.d.ts +0 -11
  157. package/lib/index.js +0 -30
@@ -1,83 +0,0 @@
1
- "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
- Object.defineProperty(exports, "__esModule", { value: true });
6
- const cache_manager_1 = require("cache-manager");
7
- const WAProto_1 = require("../../WAProto");
8
- const Utils_1 = require("../Utils");
9
- const logger_1 = __importDefault(require("../Utils/logger"));
10
- const makeCacheManagerAuthState = async (store, sessionKey) => {
11
- const defaultKey = (file) => `${sessionKey}:${file}`;
12
- const databaseConn = await (0, cache_manager_1.caching)(store);
13
- const writeData = async (file, data) => {
14
- let ttl = undefined;
15
- if (file === 'creds') {
16
- ttl = 63115200; // 2 years
17
- }
18
- await databaseConn.set(defaultKey(file), JSON.stringify(data, Utils_1.BufferJSON.replacer), ttl);
19
- };
20
- const readData = async (file) => {
21
- try {
22
- const data = await databaseConn.get(defaultKey(file));
23
- if (data) {
24
- return JSON.parse(data, Utils_1.BufferJSON.reviver);
25
- }
26
- return null;
27
- }
28
- catch (error) {
29
- logger_1.default.error(error);
30
- return null;
31
- }
32
- };
33
- const removeData = async (file) => {
34
- try {
35
- return await databaseConn.del(defaultKey(file));
36
- }
37
- catch (_a) {
38
- logger_1.default.error(`Error removing ${file} from session ${sessionKey}`);
39
- }
40
- };
41
- const clearState = async () => {
42
- try {
43
- const result = await databaseConn.store.keys(`${sessionKey}*`);
44
- await Promise.all(result.map(async (key) => await databaseConn.del(key)));
45
- }
46
- catch (err) {
47
- }
48
- };
49
- const creds = (await readData('creds')) || (0, Utils_1.initAuthCreds)();
50
- return {
51
- clearState,
52
- saveCreds: () => writeData('creds', creds),
53
- state: {
54
- creds,
55
- keys: {
56
- get: async (type, ids) => {
57
- const data = {};
58
- await Promise.all(ids.map(async (id) => {
59
- let value = await readData(`${type}-${id}`);
60
- if (type === 'app-state-sync-key' && value) {
61
- value = WAProto_1.proto.Message.AppStateSyncKeyData.fromObject(value);
62
- }
63
- data[id] = value;
64
- }));
65
- return data;
66
- },
67
- set: async (data) => {
68
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
69
- const tasks = [];
70
- for (const category in data) {
71
- for (const id in data[category]) {
72
- const value = data[category][id];
73
- const key = `${category}-${id}`;
74
- tasks.push(value ? writeData(key, value) : removeData(key));
75
- }
76
- }
77
- await Promise.all(tasks);
78
- },
79
- }
80
- }
81
- };
82
- };
83
- exports.default = makeCacheManagerAuthState;
@@ -1,118 +0,0 @@
1
- import type KeyedDB from '@adiwajshing/keyed-db';
2
- import type { Comparable } from '@adiwajshing/keyed-db/lib/Types';
3
- import type { Logger } from 'pino';
4
- import { proto } from '../../WAProto';
5
- import type makeMDSocket from '../Socket';
6
- import type { BaileysEventEmitter, Chat, ConnectionState, Contact, GroupMetadata, PresenceData, WAMessage, WAMessageCursor, WAMessageKey } from '../Types';
7
- import { Label } from '../Types/Label';
8
- import { LabelAssociation } from '../Types/LabelAssociation';
9
- import { ObjectRepository } from './object-repository';
10
- type WASocket = ReturnType<typeof makeMDSocket>;
11
- export declare const waChatKey: (pin: boolean) => {
12
- key: (c: Chat) => string;
13
- compare: (k1: string, k2: string) => number;
14
- };
15
- export declare const waMessageID: (m: WAMessage) => string;
16
- export declare const waLabelAssociationKey: Comparable<LabelAssociation, string>;
17
- export type BaileysInMemoryStoreConfig = {
18
- chatKey?: Comparable<Chat, string>;
19
- labelAssociationKey?: Comparable<LabelAssociation, string>;
20
- logger?: Logger;
21
- socket?: WASocket;
22
- };
23
- declare const _default: (config: BaileysInMemoryStoreConfig) => {
24
- chats: KeyedDB<Chat, string>;
25
- contacts: {
26
- [_: string]: Contact;
27
- };
28
- messages: {
29
- [_: string]: {
30
- array: proto.IWebMessageInfo[];
31
- get: (id: string) => proto.IWebMessageInfo | undefined;
32
- upsert: (item: proto.IWebMessageInfo, mode: "append" | "prepend") => void;
33
- update: (item: proto.IWebMessageInfo) => boolean;
34
- remove: (item: proto.IWebMessageInfo) => boolean;
35
- updateAssign: (id: string, update: Partial<proto.IWebMessageInfo>) => boolean;
36
- clear: () => void;
37
- filter: (contain: (item: proto.IWebMessageInfo) => boolean) => void;
38
- toJSON: () => proto.IWebMessageInfo[];
39
- fromJSON: (newItems: proto.IWebMessageInfo[]) => void;
40
- };
41
- };
42
- groupMetadata: {
43
- [_: string]: GroupMetadata;
44
- };
45
- state: ConnectionState;
46
- presences: {
47
- [id: string]: {
48
- [participant: string]: PresenceData;
49
- };
50
- };
51
- labels: ObjectRepository<Label>;
52
- labelAssociations: KeyedDB<LabelAssociation, string>;
53
- bind: (ev: BaileysEventEmitter) => void;
54
- /** loads messages from the store, if not found -- uses the legacy connection */
55
- loadMessages: (jid: string, count: number, cursor: WAMessageCursor) => Promise<proto.IWebMessageInfo[]>;
56
- /**
57
- * Get all available labels for profile
58
- *
59
- * Keep in mind that the list is formed from predefined tags and tags
60
- * that were "caught" during their editing.
61
- */
62
- getLabels: () => ObjectRepository<Label>;
63
- /**
64
- * Get labels for chat
65
- *
66
- * @returns Label IDs
67
- **/
68
- getChatLabels: (chatId: string) => LabelAssociation[];
69
- /**
70
- * Get labels for message
71
- *
72
- * @returns Label IDs
73
- **/
74
- getMessageLabels: (messageId: string) => string[];
75
- loadMessage: (jid: string, id: string) => Promise<proto.IWebMessageInfo | undefined>;
76
- mostRecentMessage: (jid: string) => Promise<proto.IWebMessageInfo>;
77
- fetchImageUrl: (jid: string, sock: WASocket | undefined) => Promise<string | null | undefined>;
78
- fetchGroupMetadata: (jid: string, sock: WASocket | undefined) => Promise<GroupMetadata>;
79
- fetchMessageReceipts: ({ remoteJid, id }: WAMessageKey) => Promise<proto.IUserReceipt[] | null | undefined>;
80
- toJSON: () => {
81
- chats: KeyedDB<Chat, string>;
82
- contacts: {
83
- [_: string]: Contact;
84
- };
85
- messages: {
86
- [_: string]: {
87
- array: proto.IWebMessageInfo[];
88
- get: (id: string) => proto.IWebMessageInfo | undefined;
89
- upsert: (item: proto.IWebMessageInfo, mode: "append" | "prepend") => void;
90
- update: (item: proto.IWebMessageInfo) => boolean;
91
- remove: (item: proto.IWebMessageInfo) => boolean;
92
- updateAssign: (id: string, update: Partial<proto.IWebMessageInfo>) => boolean;
93
- clear: () => void;
94
- filter: (contain: (item: proto.IWebMessageInfo) => boolean) => void;
95
- toJSON: () => proto.IWebMessageInfo[];
96
- fromJSON: (newItems: proto.IWebMessageInfo[]) => void;
97
- };
98
- };
99
- labels: ObjectRepository<Label>;
100
- labelAssociations: KeyedDB<LabelAssociation, string>;
101
- };
102
- fromJSON: (json: {
103
- chats: Chat[];
104
- contacts: {
105
- [id: string]: Contact;
106
- };
107
- messages: {
108
- [id: string]: proto.IWebMessageInfo[];
109
- };
110
- labels: {
111
- [labelId: string]: Label;
112
- };
113
- labelAssociations: LabelAssociation[];
114
- }) => void;
115
- writeToFile: (path: string) => void;
116
- readFromFile: (path: string) => void;
117
- };
118
- export default _default;
@@ -1,420 +0,0 @@
1
- "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
- Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.waLabelAssociationKey = exports.waMessageID = exports.waChatKey = void 0;
7
- const WAProto_1 = require("../../WAProto");
8
- const Defaults_1 = require("../Defaults");
9
- const LabelAssociation_1 = require("../Types/LabelAssociation");
10
- const Utils_1 = require("../Utils");
11
- const WABinary_1 = require("../WABinary");
12
- const make_ordered_dictionary_1 = __importDefault(require("./make-ordered-dictionary"));
13
- const object_repository_1 = require("./object-repository");
14
- const waChatKey = (pin) => ({
15
- key: (c) => (pin ? (c.pinned ? '1' : '0') : '') + (c.archived ? '0' : '1') + (c.conversationTimestamp ? c.conversationTimestamp.toString(16).padStart(8, '0') : '') + c.id,
16
- compare: (k1, k2) => k2.localeCompare(k1)
17
- });
18
- exports.waChatKey = waChatKey;
19
- const waMessageID = (m) => m.key.id || '';
20
- exports.waMessageID = waMessageID;
21
- exports.waLabelAssociationKey = {
22
- key: (la) => (la.type === LabelAssociation_1.LabelAssociationType.Chat ? la.chatId + la.labelId : la.chatId + la.messageId + la.labelId),
23
- compare: (k1, k2) => k2.localeCompare(k1)
24
- };
25
- const makeMessagesDictionary = () => (0, make_ordered_dictionary_1.default)(exports.waMessageID);
26
- exports.default = (config) => {
27
- const socket = config.socket;
28
- const chatKey = config.chatKey || (0, exports.waChatKey)(true);
29
- const labelAssociationKey = config.labelAssociationKey || exports.waLabelAssociationKey;
30
- const logger = config.logger || Defaults_1.DEFAULT_CONNECTION_CONFIG.logger.child({ stream: 'in-mem-store' });
31
- const KeyedDB = require('@adiwajshing/keyed-db').default;
32
- const chats = new KeyedDB(chatKey, c => c.id);
33
- const messages = {};
34
- const contacts = {};
35
- const groupMetadata = {};
36
- const presences = {};
37
- const state = { connection: 'close' };
38
- const labels = new object_repository_1.ObjectRepository();
39
- const labelAssociations = new KeyedDB(labelAssociationKey, labelAssociationKey.key);
40
- const assertMessageList = (jid) => {
41
- if (!messages[jid]) {
42
- messages[jid] = makeMessagesDictionary();
43
- }
44
- return messages[jid];
45
- };
46
- const contactsUpsert = (newContacts) => {
47
- const oldContacts = new Set(Object.keys(contacts));
48
- for (const contact of newContacts) {
49
- oldContacts.delete(contact.id);
50
- contacts[contact.id] = Object.assign(contacts[contact.id] || {}, contact);
51
- }
52
- return oldContacts;
53
- };
54
- const labelsUpsert = (newLabels) => {
55
- for (const label of newLabels) {
56
- labels.upsertById(label.id, label);
57
- }
58
- };
59
- /**
60
- * binds to a BaileysEventEmitter.
61
- * It listens to all events and constructs a state that you can query accurate data from.
62
- * Eg. can use the store to fetch chats, contacts, messages etc.
63
- * @param ev typically the event emitter from the socket connection
64
- */
65
- const bind = (ev) => {
66
- ev.on('connection.update', update => {
67
- Object.assign(state, update);
68
- });
69
- ev.on('messaging-history.set', ({ chats: newChats, contacts: newContacts, messages: newMessages, isLatest, syncType }) => {
70
- if (syncType === WAProto_1.proto.HistorySync.HistorySyncType.ON_DEMAND) {
71
- return; // FOR NOW,
72
- //TODO: HANDLE
73
- }
74
- if (isLatest) {
75
- chats.clear();
76
- for (const id in messages) {
77
- delete messages[id];
78
- }
79
- }
80
- const chatsAdded = chats.insertIfAbsent(...newChats).length;
81
- logger.debug({ chatsAdded }, 'synced chats');
82
- const oldContacts = contactsUpsert(newContacts);
83
- if (isLatest) {
84
- for (const jid of oldContacts) {
85
- delete contacts[jid];
86
- }
87
- }
88
- logger.debug({ deletedContacts: isLatest ? oldContacts.size : 0, newContacts }, 'synced contacts');
89
- for (const msg of newMessages) {
90
- const jid = msg.key.remoteJid;
91
- const list = assertMessageList(jid);
92
- list.upsert(msg, 'prepend');
93
- }
94
- logger.debug({ messages: newMessages.length }, 'synced messages');
95
- });
96
- ev.on('contacts.upsert', contacts => {
97
- contactsUpsert(contacts);
98
- });
99
- ev.on('contacts.update', async (updates) => {
100
- var _a;
101
- for (const update of updates) {
102
- let contact;
103
- if (contacts[update.id]) {
104
- contact = contacts[update.id];
105
- }
106
- else {
107
- const contactHashes = await Promise.all(Object.keys(contacts).map(async (contactId) => {
108
- const { user } = (0, WABinary_1.jidDecode)(contactId);
109
- return [contactId, (await (0, Utils_1.md5)(Buffer.from(user + 'WA_ADD_NOTIF', 'utf8'))).toString('base64').slice(0, 3)];
110
- }));
111
- contact = contacts[((_a = contactHashes.find(([, b]) => b === update.id)) === null || _a === void 0 ? void 0 : _a[0]) || '']; // find contact by attrs.hash, when user is not saved as a contact
112
- }
113
- if (contact) {
114
- if (update.imgUrl === 'changed') {
115
- contact.imgUrl = socket ? await (socket === null || socket === void 0 ? void 0 : socket.profilePictureUrl(contact.id)) : undefined;
116
- }
117
- else if (update.imgUrl === 'removed') {
118
- delete contact.imgUrl;
119
- }
120
- }
121
- else {
122
- return logger.debug({ update }, 'got update for non-existant contact');
123
- }
124
- Object.assign(contacts[contact.id], contact);
125
- }
126
- });
127
- ev.on('chats.upsert', newChats => {
128
- chats.upsert(...newChats);
129
- });
130
- ev.on('chats.update', updates => {
131
- for (let update of updates) {
132
- const result = chats.update(update.id, chat => {
133
- if (update.unreadCount > 0) {
134
- update = { ...update };
135
- update.unreadCount = (chat.unreadCount || 0) + update.unreadCount;
136
- }
137
- Object.assign(chat, update);
138
- });
139
- if (!result) {
140
- logger.debug({ update }, 'got update for non-existant chat');
141
- }
142
- }
143
- });
144
- ev.on('labels.edit', (label) => {
145
- if (label.deleted) {
146
- return labels.deleteById(label.id);
147
- }
148
- // WhatsApp can store only up to 20 labels
149
- if (labels.count() < 20) {
150
- return labels.upsertById(label.id, label);
151
- }
152
- logger.error('Labels count exceed');
153
- });
154
- ev.on('labels.association', ({ type, association }) => {
155
- switch (type) {
156
- case 'add':
157
- labelAssociations.upsert(association);
158
- break;
159
- case 'remove':
160
- labelAssociations.delete(association);
161
- break;
162
- default:
163
- console.error(`unknown operation type [${type}]`);
164
- }
165
- });
166
- ev.on('presence.update', ({ id, presences: update }) => {
167
- presences[id] = presences[id] || {};
168
- Object.assign(presences[id], update);
169
- });
170
- ev.on('chats.delete', deletions => {
171
- for (const item of deletions) {
172
- if (chats.get(item)) {
173
- chats.deleteById(item);
174
- }
175
- }
176
- });
177
- ev.on('messages.upsert', ({ messages: newMessages, type }) => {
178
- switch (type) {
179
- case 'append':
180
- case 'notify':
181
- for (const msg of newMessages) {
182
- const jid = (0, WABinary_1.jidNormalizedUser)(msg.key.remoteJid);
183
- const list = assertMessageList(jid);
184
- list.upsert(msg, 'append');
185
- if (type === 'notify' && !chats.get(jid)) {
186
- ev.emit('chats.upsert', [
187
- {
188
- id: jid,
189
- conversationTimestamp: (0, Utils_1.toNumber)(msg.messageTimestamp),
190
- unreadCount: 1
191
- }
192
- ]);
193
- }
194
- }
195
- break;
196
- }
197
- });
198
- ev.on('messages.update', updates => {
199
- var _a;
200
- for (const { update, key } of updates) {
201
- const list = assertMessageList((0, WABinary_1.jidNormalizedUser)(key.remoteJid));
202
- if (update === null || update === void 0 ? void 0 : update.status) {
203
- const listStatus = (_a = list.get(key.id)) === null || _a === void 0 ? void 0 : _a.status;
204
- if (listStatus && (update === null || update === void 0 ? void 0 : update.status) <= listStatus) {
205
- logger.debug({ update, storedStatus: listStatus }, 'status stored newer then update');
206
- delete update.status;
207
- logger.debug({ update }, 'new update object');
208
- }
209
- }
210
- const result = list.updateAssign(key.id, update);
211
- if (!result) {
212
- logger.debug({ update }, 'got update for non-existent message');
213
- }
214
- }
215
- });
216
- ev.on('messages.delete', item => {
217
- if ('all' in item) {
218
- const list = messages[item.jid];
219
- list === null || list === void 0 ? void 0 : list.clear();
220
- }
221
- else {
222
- const jid = item.keys[0].remoteJid;
223
- const list = messages[jid];
224
- if (list) {
225
- const idSet = new Set(item.keys.map(k => k.id));
226
- list.filter(m => !idSet.has(m.key.id));
227
- }
228
- }
229
- });
230
- ev.on('groups.update', updates => {
231
- for (const update of updates) {
232
- const id = update.id;
233
- if (groupMetadata[id]) {
234
- Object.assign(groupMetadata[id], update);
235
- }
236
- else {
237
- logger.debug({ update }, 'got update for non-existant group metadata');
238
- }
239
- }
240
- });
241
- ev.on('group-participants.update', ({ id, participants, action }) => {
242
- const metadata = groupMetadata[id];
243
- if (metadata) {
244
- switch (action) {
245
- case 'add':
246
- metadata.participants.push(...participants.map(id => ({ id, isAdmin: false, isSuperAdmin: false })));
247
- break;
248
- case 'demote':
249
- case 'promote':
250
- for (const participant of metadata.participants) {
251
- if (participants.includes(participant.id)) {
252
- participant.isAdmin = action === 'promote';
253
- }
254
- }
255
- break;
256
- case 'remove':
257
- metadata.participants = metadata.participants.filter(p => !participants.includes(p.id));
258
- break;
259
- }
260
- }
261
- });
262
- ev.on('message-receipt.update', updates => {
263
- for (const { key, receipt } of updates) {
264
- const obj = messages[key.remoteJid];
265
- const msg = obj === null || obj === void 0 ? void 0 : obj.get(key.id);
266
- if (msg) {
267
- (0, Utils_1.updateMessageWithReceipt)(msg, receipt);
268
- }
269
- }
270
- });
271
- ev.on('messages.reaction', (reactions) => {
272
- for (const { key, reaction } of reactions) {
273
- const obj = messages[key.remoteJid];
274
- const msg = obj === null || obj === void 0 ? void 0 : obj.get(key.id);
275
- if (msg) {
276
- (0, Utils_1.updateMessageWithReaction)(msg, reaction);
277
- }
278
- }
279
- });
280
- };
281
- const toJSON = () => ({
282
- chats,
283
- contacts,
284
- messages,
285
- labels,
286
- labelAssociations
287
- });
288
- const fromJSON = (json) => {
289
- chats.upsert(...json.chats);
290
- labelAssociations.upsert(...json.labelAssociations || []);
291
- contactsUpsert(Object.values(json.contacts));
292
- labelsUpsert(Object.values(json.labels || {}));
293
- for (const jid in json.messages) {
294
- const list = assertMessageList(jid);
295
- for (const msg of json.messages[jid]) {
296
- list.upsert(WAProto_1.proto.WebMessageInfo.fromObject(msg), 'append');
297
- }
298
- }
299
- };
300
- return {
301
- chats,
302
- contacts,
303
- messages,
304
- groupMetadata,
305
- state,
306
- presences,
307
- labels,
308
- labelAssociations,
309
- bind,
310
- /** loads messages from the store, if not found -- uses the legacy connection */
311
- loadMessages: async (jid, count, cursor) => {
312
- const list = assertMessageList(jid);
313
- const mode = !cursor || 'before' in cursor ? 'before' : 'after';
314
- const cursorKey = !!cursor ? ('before' in cursor ? cursor.before : cursor.after) : undefined;
315
- const cursorValue = cursorKey ? list.get(cursorKey.id) : undefined;
316
- let messages;
317
- if (list && mode === 'before' && (!cursorKey || cursorValue)) {
318
- if (cursorValue) {
319
- const msgIdx = list.array.findIndex(m => m.key.id === (cursorKey === null || cursorKey === void 0 ? void 0 : cursorKey.id));
320
- messages = list.array.slice(0, msgIdx);
321
- }
322
- else {
323
- messages = list.array;
324
- }
325
- const diff = count - messages.length;
326
- if (diff < 0) {
327
- messages = messages.slice(-count); // get the last X messages
328
- }
329
- }
330
- else {
331
- messages = [];
332
- }
333
- return messages;
334
- },
335
- /**
336
- * Get all available labels for profile
337
- *
338
- * Keep in mind that the list is formed from predefined tags and tags
339
- * that were "caught" during their editing.
340
- */
341
- getLabels: () => {
342
- return labels;
343
- },
344
- /**
345
- * Get labels for chat
346
- *
347
- * @returns Label IDs
348
- **/
349
- getChatLabels: (chatId) => {
350
- return labelAssociations.filter((la) => la.chatId === chatId).all();
351
- },
352
- /**
353
- * Get labels for message
354
- *
355
- * @returns Label IDs
356
- **/
357
- getMessageLabels: (messageId) => {
358
- const associations = labelAssociations
359
- .filter((la) => la.messageId === messageId)
360
- .all();
361
- return associations.map(({ labelId }) => labelId);
362
- },
363
- loadMessage: async (jid, id) => { var _a; return (_a = messages[jid]) === null || _a === void 0 ? void 0 : _a.get(id); },
364
- mostRecentMessage: async (jid) => {
365
- var _a;
366
- const message = (_a = messages[jid]) === null || _a === void 0 ? void 0 : _a.array.slice(-1)[0];
367
- return message;
368
- },
369
- fetchImageUrl: async (jid, sock) => {
370
- const contact = contacts[jid];
371
- if (!contact) {
372
- return sock === null || sock === void 0 ? void 0 : sock.profilePictureUrl(jid);
373
- }
374
- if (typeof contact.imgUrl === 'undefined') {
375
- contact.imgUrl = await (sock === null || sock === void 0 ? void 0 : sock.profilePictureUrl(jid));
376
- }
377
- return contact.imgUrl;
378
- },
379
- fetchGroupMetadata: async (jid, sock) => {
380
- if (!groupMetadata[jid]) {
381
- const metadata = await (sock === null || sock === void 0 ? void 0 : sock.groupMetadata(jid));
382
- if (metadata) {
383
- groupMetadata[jid] = metadata;
384
- }
385
- }
386
- return groupMetadata[jid];
387
- },
388
- // fetchBroadcastListInfo: async(jid: string, sock: WASocket | undefined) => {
389
- // if(!groupMetadata[jid]) {
390
- // const metadata = await sock?.getBroadcastListInfo(jid)
391
- // if(metadata) {
392
- // groupMetadata[jid] = metadata
393
- // }
394
- // }
395
- // return groupMetadata[jid]
396
- // },
397
- fetchMessageReceipts: async ({ remoteJid, id }) => {
398
- const list = messages[remoteJid];
399
- const msg = list === null || list === void 0 ? void 0 : list.get(id);
400
- return msg === null || msg === void 0 ? void 0 : msg.userReceipt;
401
- },
402
- toJSON,
403
- fromJSON,
404
- writeToFile: (path) => {
405
- // require fs here so that in case "fs" is not available -- the app does not crash
406
- const { writeFileSync } = require('fs');
407
- writeFileSync(path, JSON.stringify(toJSON()));
408
- },
409
- readFromFile: (path) => {
410
- // require fs here so that in case "fs" is not available -- the app does not crash
411
- const { readFileSync, existsSync } = require('fs');
412
- if (existsSync(path)) {
413
- logger.debug({ path }, 'reading from file');
414
- const jsonStr = readFileSync(path, { encoding: 'utf-8' });
415
- const json = JSON.parse(jsonStr);
416
- fromJSON(json);
417
- }
418
- }
419
- };
420
- };
@@ -1,13 +0,0 @@
1
- declare function makeOrderedDictionary<T>(idGetter: (item: T) => string): {
2
- array: T[];
3
- get: (id: string) => T | undefined;
4
- upsert: (item: T, mode: 'append' | 'prepend') => void;
5
- update: (item: T) => boolean;
6
- remove: (item: T) => boolean;
7
- updateAssign: (id: string, update: Partial<T>) => boolean;
8
- clear: () => void;
9
- filter: (contain: (item: T) => boolean) => void;
10
- toJSON: () => T[];
11
- fromJSON: (newItems: T[]) => void;
12
- };
13
- export default makeOrderedDictionary;