@alannxd/baileys 6.0.5 → 6.0.6

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (234) hide show
  1. package/WAProto/fix-import.js +29 -0
  2. package/WAProto/index.js +160 -201
  3. package/engine-requirements.js +1 -1
  4. package/lib/Defaults/baileys-version.json +3 -0
  5. package/lib/Defaults/index.d.ts +15 -37
  6. package/lib/Defaults/index.js +136 -119
  7. package/lib/Defaults/phonenumber-mcc.json +223 -0
  8. package/lib/Signal/Group/ciphertext-message.d.ts +0 -1
  9. package/lib/Signal/Group/ciphertext-message.js +5 -2
  10. package/lib/Signal/Group/group-session-builder.d.ts +3 -4
  11. package/lib/Signal/Group/group-session-builder.js +41 -7
  12. package/lib/Signal/Group/group_cipher.d.ts +4 -4
  13. package/lib/Signal/Group/group_cipher.js +51 -37
  14. package/lib/Signal/Group/index.d.ts +11 -12
  15. package/lib/Signal/Group/index.js +57 -12
  16. package/lib/Signal/Group/keyhelper.d.ts +1 -2
  17. package/lib/Signal/Group/keyhelper.js +44 -7
  18. package/lib/Signal/Group/queue-job.d.ts +1 -0
  19. package/lib/Signal/Group/queue-job.js +57 -0
  20. package/lib/Signal/Group/sender-chain-key.d.ts +2 -3
  21. package/lib/Signal/Group/sender-chain-key.js +15 -7
  22. package/lib/Signal/Group/sender-key-distribution-message.d.ts +1 -2
  23. package/lib/Signal/Group/sender-key-distribution-message.js +11 -8
  24. package/lib/Signal/Group/sender-key-message.d.ts +1 -2
  25. package/lib/Signal/Group/sender-key-message.js +12 -9
  26. package/lib/Signal/Group/sender-key-name.d.ts +0 -1
  27. package/lib/Signal/Group/sender-key-name.js +5 -2
  28. package/lib/Signal/Group/sender-key-record.d.ts +2 -3
  29. package/lib/Signal/Group/sender-key-record.js +21 -9
  30. package/lib/Signal/Group/sender-key-state.d.ts +6 -7
  31. package/lib/Signal/Group/sender-key-state.js +42 -27
  32. package/lib/Signal/Group/sender-message-key.d.ts +0 -1
  33. package/lib/Signal/Group/sender-message-key.js +7 -4
  34. package/lib/Signal/libsignal.d.ts +3 -5
  35. package/lib/Signal/libsignal.js +90 -347
  36. package/lib/Socket/Client/{types.d.ts → abstract-socket-client.d.ts} +5 -4
  37. package/lib/Socket/Client/abstract-socket-client.js +13 -0
  38. package/lib/Socket/Client/index.d.ts +3 -3
  39. package/lib/Socket/Client/index.js +19 -3
  40. package/lib/Socket/Client/mobile-socket-client.d.ts +13 -0
  41. package/lib/Socket/Client/mobile-socket-client.js +65 -0
  42. package/lib/Socket/Client/{websocket.d.ts → web-socket-client.d.ts} +2 -3
  43. package/lib/Socket/Client/web-socket-client.js +62 -0
  44. package/lib/Socket/business.d.ts +108 -154
  45. package/lib/Socket/business.js +43 -162
  46. package/lib/Socket/chats.d.ts +239 -96
  47. package/lib/Socket/chats.js +427 -627
  48. package/lib/Socket/communities.d.ts +146 -239
  49. package/lib/Socket/communities.js +80 -90
  50. package/lib/Socket/groups.d.ts +57 -104
  51. package/lib/Socket/groups.js +161 -154
  52. package/lib/Socket/index.d.ts +115 -202
  53. package/lib/Socket/index.js +10 -11
  54. package/lib/Socket/luxu.d.ts +266 -22
  55. package/lib/Socket/luxu.js +465 -422
  56. package/lib/Socket/messages-recv.d.ts +84 -136
  57. package/lib/Socket/messages-recv.js +615 -1421
  58. package/lib/Socket/messages-send.d.ts +126 -142
  59. package/lib/Socket/messages-send.js +671 -878
  60. package/lib/Socket/newsletter.d.ts +85 -121
  61. package/lib/Socket/newsletter.js +272 -147
  62. package/lib/Socket/registration.d.ts +267 -0
  63. package/lib/Socket/registration.js +166 -0
  64. package/lib/Socket/socket.d.ts +19 -34
  65. package/lib/Socket/socket.js +313 -544
  66. package/lib/Socket/usync.d.ts +36 -0
  67. package/lib/Socket/usync.js +70 -0
  68. package/lib/Store/index.d.ts +3 -10
  69. package/lib/Store/index.js +10 -10
  70. package/lib/Store/make-cache-manager-store.d.ts +11 -17
  71. package/lib/Store/make-cache-manager-store.js +41 -43
  72. package/lib/Store/make-in-memory-store.d.ts +118 -39
  73. package/lib/Store/make-in-memory-store.js +341 -112
  74. package/lib/Store/make-ordered-dictionary.d.ts +10 -11
  75. package/lib/Store/make-ordered-dictionary.js +20 -14
  76. package/lib/Store/object-repository.d.ts +9 -10
  77. package/lib/Store/object-repository.js +6 -11
  78. package/lib/Types/Auth.d.ts +12 -19
  79. package/lib/Types/Auth.js +2 -2
  80. package/lib/Types/Call.d.ts +1 -3
  81. package/lib/Types/Call.js +2 -2
  82. package/lib/Types/Chat.d.ts +13 -35
  83. package/lib/Types/Chat.js +4 -8
  84. package/lib/Types/Contact.d.ts +1 -8
  85. package/lib/Types/Contact.js +2 -2
  86. package/lib/Types/Events.d.ts +17 -116
  87. package/lib/Types/Events.js +2 -2
  88. package/lib/Types/GroupMetadata.d.ts +5 -21
  89. package/lib/Types/GroupMetadata.js +2 -2
  90. package/lib/Types/Label.d.ts +0 -12
  91. package/lib/Types/Label.js +5 -3
  92. package/lib/Types/LabelAssociation.d.ts +0 -1
  93. package/lib/Types/LabelAssociation.js +5 -3
  94. package/lib/Types/Message.d.ts +58 -105
  95. package/lib/Types/Message.js +9 -11
  96. package/lib/Types/Newsletter.d.ts +103 -0
  97. package/lib/Types/Newsletter.js +38 -0
  98. package/lib/Types/Product.d.ts +1 -2
  99. package/lib/Types/Product.js +2 -2
  100. package/lib/Types/Signal.d.ts +2 -32
  101. package/lib/Types/Signal.js +2 -2
  102. package/lib/Types/Socket.d.ts +25 -50
  103. package/lib/Types/Socket.js +2 -3
  104. package/lib/Types/State.d.ts +2 -72
  105. package/lib/Types/State.js +2 -56
  106. package/lib/Types/USync.d.ts +2 -3
  107. package/lib/Types/USync.js +2 -2
  108. package/lib/Types/index.d.ts +14 -22
  109. package/lib/Types/index.js +31 -15
  110. package/lib/Utils/auth-utils.d.ts +6 -12
  111. package/lib/Utils/auth-utils.js +143 -239
  112. package/lib/Utils/baileys-event-stream.d.ts +16 -0
  113. package/lib/Utils/baileys-event-stream.js +63 -0
  114. package/lib/Utils/business.d.ts +2 -3
  115. package/lib/Utils/business.js +69 -66
  116. package/lib/Utils/chat-utils.d.ts +23 -52
  117. package/lib/Utils/chat-utils.js +253 -396
  118. package/lib/Utils/crypto.d.ts +22 -18
  119. package/lib/Utils/crypto.js +90 -57
  120. package/lib/Utils/decode-wa-message.d.ts +8 -55
  121. package/lib/Utils/decode-wa-message.js +84 -203
  122. package/lib/Utils/event-buffer.d.ts +8 -9
  123. package/lib/Utils/event-buffer.js +77 -185
  124. package/lib/Utils/generics.d.ts +29 -28
  125. package/lib/Utils/generics.js +210 -180
  126. package/lib/Utils/history.d.ts +9 -18
  127. package/lib/Utils/history.js +55 -93
  128. package/lib/Utils/index.d.ts +17 -22
  129. package/lib/Utils/index.js +33 -22
  130. package/lib/Utils/link-preview.d.ts +5 -5
  131. package/lib/Utils/link-preview.js +24 -16
  132. package/lib/Utils/logger.d.ts +3 -11
  133. package/lib/Utils/logger.js +7 -3
  134. package/lib/Utils/lt-hash.d.ts +12 -8
  135. package/lib/Utils/lt-hash.js +46 -3
  136. package/lib/Utils/make-mutex.d.ts +2 -4
  137. package/lib/Utils/make-mutex.js +34 -24
  138. package/lib/Utils/messages-media.d.ts +44 -61
  139. package/lib/Utils/messages-media.js +482 -451
  140. package/lib/Utils/messages.d.ts +18 -32
  141. package/lib/Utils/messages.js +369 -458
  142. package/lib/Utils/noise-handler.d.ts +14 -13
  143. package/lib/Utils/noise-handler.js +99 -145
  144. package/lib/Utils/process-message.d.ts +12 -31
  145. package/lib/Utils/process-message.js +150 -459
  146. package/lib/Utils/signal.d.ts +5 -20
  147. package/lib/Utils/signal.js +72 -120
  148. package/lib/Utils/use-multi-file-auth-state.d.ts +2 -2
  149. package/lib/Utils/use-multi-file-auth-state.js +27 -29
  150. package/lib/Utils/validate-connection.d.ts +7 -7
  151. package/lib/Utils/validate-connection.js +99 -73
  152. package/lib/WABinary/constants.d.ts +27 -25
  153. package/lib/WABinary/constants.js +20 -1281
  154. package/lib/WABinary/decode.d.ts +5 -5
  155. package/lib/WABinary/decode.js +42 -52
  156. package/lib/WABinary/encode.d.ts +3 -3
  157. package/lib/WABinary/encode.js +155 -110
  158. package/lib/WABinary/generic-utils.d.ts +7 -8
  159. package/lib/WABinary/generic-utils.js +49 -48
  160. package/lib/WABinary/index.d.ts +5 -6
  161. package/lib/WABinary/index.js +21 -6
  162. package/lib/WABinary/jid-utils.d.ts +8 -25
  163. package/lib/WABinary/jid-utils.js +40 -74
  164. package/lib/WABinary/types.d.ts +1 -2
  165. package/lib/WABinary/types.js +2 -2
  166. package/lib/WAM/BinaryInfo.d.ts +11 -3
  167. package/lib/WAM/BinaryInfo.js +5 -2
  168. package/lib/WAM/constants.d.ts +3 -5
  169. package/lib/WAM/constants.js +11958 -19461
  170. package/lib/WAM/encode.d.ts +3 -3
  171. package/lib/WAM/encode.js +22 -17
  172. package/lib/WAM/index.d.ts +3 -4
  173. package/lib/WAM/index.js +19 -4
  174. package/lib/WAUSync/Protocols/USyncContactProtocol.d.ts +3 -4
  175. package/lib/WAUSync/Protocols/USyncContactProtocol.js +13 -33
  176. package/lib/WAUSync/Protocols/USyncDeviceProtocol.d.ts +2 -3
  177. package/lib/WAUSync/Protocols/USyncDeviceProtocol.js +14 -11
  178. package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.d.ts +2 -3
  179. package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.js +12 -9
  180. package/lib/WAUSync/Protocols/USyncStatusProtocol.d.ts +2 -3
  181. package/lib/WAUSync/Protocols/USyncStatusProtocol.js +13 -9
  182. package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.d.ts +3 -4
  183. package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.js +22 -20
  184. package/lib/WAUSync/Protocols/UsyncLIDProtocol.d.ts +3 -5
  185. package/lib/WAUSync/Protocols/UsyncLIDProtocol.js +8 -13
  186. package/lib/WAUSync/Protocols/index.d.ts +4 -6
  187. package/lib/WAUSync/Protocols/index.js +20 -6
  188. package/lib/WAUSync/USyncQuery.d.ts +4 -6
  189. package/lib/WAUSync/USyncQuery.js +35 -44
  190. package/lib/WAUSync/USyncUser.d.ts +5 -10
  191. package/lib/WAUSync/USyncUser.js +5 -10
  192. package/lib/WAUSync/index.js +19 -4
  193. package/lib/index.d.ts +9 -10
  194. package/lib/index.js +34 -12
  195. package/package.json +50 -83
  196. package/WAProto/GenerateStatics.sh +0 -3
  197. package/WAProto/WAProto.proto +0 -5479
  198. package/WAProto/fix-imports.js +0 -85
  199. package/WAProto/index.d.ts +0 -14017
  200. package/lib/Signal/lid-mapping.d.ts +0 -23
  201. package/lib/Signal/lid-mapping.js +0 -277
  202. package/lib/Socket/Client/types.js +0 -11
  203. package/lib/Socket/Client/websocket.js +0 -54
  204. package/lib/Socket/mex.d.ts +0 -3
  205. package/lib/Socket/mex.js +0 -42
  206. package/lib/Store/keyed-db.d.ts +0 -22
  207. package/lib/Store/keyed-db.js +0 -108
  208. package/lib/Types/Bussines.d.ts +0 -25
  209. package/lib/Types/Bussines.js +0 -2
  210. package/lib/Types/Mex.d.ts +0 -141
  211. package/lib/Types/Mex.js +0 -37
  212. package/lib/Utils/browser-utils.d.ts +0 -4
  213. package/lib/Utils/browser-utils.js +0 -28
  214. package/lib/Utils/companion-reg-client-utils.d.ts +0 -17
  215. package/lib/Utils/companion-reg-client-utils.js +0 -35
  216. package/lib/Utils/identity-change-handler.d.ts +0 -44
  217. package/lib/Utils/identity-change-handler.js +0 -50
  218. package/lib/Utils/message-retry-manager.d.ts +0 -115
  219. package/lib/Utils/message-retry-manager.js +0 -265
  220. package/lib/Utils/offline-node-processor.d.ts +0 -17
  221. package/lib/Utils/offline-node-processor.js +0 -40
  222. package/lib/Utils/pre-key-manager.d.ts +0 -28
  223. package/lib/Utils/pre-key-manager.js +0 -106
  224. package/lib/Utils/reporting-utils.d.ts +0 -11
  225. package/lib/Utils/reporting-utils.js +0 -258
  226. package/lib/Utils/stanza-ack.d.ts +0 -11
  227. package/lib/Utils/stanza-ack.js +0 -38
  228. package/lib/Utils/sync-action-utils.d.ts +0 -19
  229. package/lib/Utils/sync-action-utils.js +0 -49
  230. package/lib/Utils/tc-token-utils.d.ts +0 -37
  231. package/lib/Utils/tc-token-utils.js +0 -163
  232. package/lib/WAUSync/Protocols/USyncUsernameProtocol.d.ts +0 -10
  233. package/lib/WAUSync/Protocols/USyncUsernameProtocol.js +0 -25
  234. package/lib/WAUSync/index.d.ts +0 -4
@@ -1,290 +1,189 @@
1
- import NodeCache from '@cacheable/node-cache';
2
- import { Boom } from '@hapi/boom';
3
- import { AsyncLocalStorage } from 'async_hooks';
4
- import { Mutex } from 'async-mutex';
5
- import { randomBytes } from 'crypto';
6
- import PQueue from 'p-queue';
7
- import { DEFAULT_CACHE_TTLS } from '../Defaults/index.js';
8
- import { Curve, signedKeyPair } from './crypto.js';
9
- import { delay, generateRegistrationId } from './generics.js';
10
- import { PreKeyManager } from './pre-key-manager.js';
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.initAuthCreds = exports.addTransactionCapability = exports.makeCacheableSignalKeyStore = void 0;
7
+ const crypto_1 = require("crypto");
8
+ const node_cache_1 = __importDefault(require("node-cache"));
9
+ const uuid_1 = require("uuid");
10
+ const Defaults_1 = require("../Defaults");
11
+ const crypto_2 = require("./crypto");
12
+ const generics_1 = require("./generics");
11
13
  /**
12
14
  * Adds caching capability to a SignalKeyStore
13
15
  * @param store the store to add caching to
14
16
  * @param logger to log trace events
15
17
  * @param _cache cache store to use
16
18
  */
17
- export function makeCacheableSignalKeyStore(store, logger, _cache) {
18
- const cache = _cache ||
19
- new NodeCache({
20
- stdTTL: DEFAULT_CACHE_TTLS.SIGNAL_STORE, // 5 minutes
21
- useClones: false,
22
- deleteOnExpire: true
23
- });
24
- // Mutex for protecting cache operations
25
- const cacheMutex = new Mutex();
19
+ function makeCacheableSignalKeyStore(store, logger, _cache) {
20
+ const cache = _cache || new node_cache_1.default({
21
+ stdTTL: Defaults_1.DEFAULT_CACHE_TTLS.SIGNAL_STORE,
22
+ useClones: false,
23
+ deleteOnExpire: true,
24
+ });
26
25
  function getUniqueId(type, id) {
27
26
  return `${type}.${id}`;
28
27
  }
29
28
  return {
30
29
  async get(type, ids) {
31
- return cacheMutex.runExclusive(async () => {
32
- const data = {};
33
- const idsToFetch = [];
34
- for (const id of ids) {
35
- const item = (await cache.get(getUniqueId(type, id)));
36
- if (typeof item !== 'undefined') {
37
- data[id] = item;
38
- }
39
- else {
40
- idsToFetch.push(id);
41
- }
30
+ const data = {};
31
+ const idsToFetch = [];
32
+ for (const id of ids) {
33
+ const item = cache.get(getUniqueId(type, id));
34
+ if (typeof item !== 'undefined') {
35
+ data[id] = item;
42
36
  }
43
- if (idsToFetch.length) {
44
- logger?.trace({ items: idsToFetch.length }, 'loading from store');
45
- const fetched = await store.get(type, idsToFetch);
46
- for (const id of idsToFetch) {
47
- const item = fetched[id];
48
- if (item) {
49
- data[id] = item;
50
- // eslint-disable-next-line @typescript-eslint/no-unnecessary-type-assertion
51
- await cache.set(getUniqueId(type, id), item);
52
- }
37
+ else {
38
+ idsToFetch.push(id);
39
+ }
40
+ }
41
+ if (idsToFetch.length) {
42
+ logger.trace({ items: idsToFetch.length }, 'loading from store');
43
+ const fetched = await store.get(type, idsToFetch);
44
+ for (const id of idsToFetch) {
45
+ const item = fetched[id];
46
+ if (item) {
47
+ data[id] = item;
48
+ cache.set(getUniqueId(type, id), item);
53
49
  }
54
50
  }
55
- return data;
56
- });
51
+ }
52
+ return data;
57
53
  },
58
54
  async set(data) {
59
- return cacheMutex.runExclusive(async () => {
60
- let keys = 0;
61
- for (const type in data) {
62
- for (const id in data[type]) {
63
- await cache.set(getUniqueId(type, id), data[type][id]);
64
- keys += 1;
65
- }
55
+ let keys = 0;
56
+ for (const type in data) {
57
+ for (const id in data[type]) {
58
+ cache.set(getUniqueId(type, id), data[type][id]);
59
+ keys += 1;
66
60
  }
67
- logger?.trace({ keys }, 'updated cache');
68
- await store.set(data);
69
- });
61
+ }
62
+ logger.trace({ keys }, 'updated cache');
63
+ await store.set(data);
70
64
  },
71
65
  async clear() {
72
- await cache.flushAll();
73
- await store.clear?.();
66
+ var _a;
67
+ cache.flushAll();
68
+ await ((_a = store.clear) === null || _a === void 0 ? void 0 : _a.call(store));
74
69
  }
75
70
  };
76
71
  }
72
+ exports.makeCacheableSignalKeyStore = makeCacheableSignalKeyStore;
77
73
  /**
78
- * Adds DB-like transaction capability to the SignalKeyStore
79
- * Uses AsyncLocalStorage for automatic context management
74
+ * Adds DB like transaction capability (https://en.wikipedia.org/wiki/Database_transaction) to the SignalKeyStore,
75
+ * this allows batch read & write operations & improves the performance of the lib
80
76
  * @param state the key store to apply this capability to
81
77
  * @param logger logger to log events
82
78
  * @returns SignalKeyStore with transaction capability
83
79
  */
84
- export const addTransactionCapability = (state, logger, { maxCommitRetries, delayBetweenTriesMs }) => {
85
- const txStorage = new AsyncLocalStorage();
86
- // Queues for concurrency control (keyed by signal data type - bounded set)
87
- const keyQueues = new Map();
88
- // Transaction mutexes with reference counting for cleanup
89
- const txMutexes = new Map();
90
- const txMutexRefCounts = new Map();
91
- // Pre-key manager for specialized operations
92
- const preKeyManager = new PreKeyManager(state, logger);
93
- /**
94
- * Get or create a queue for a specific key type
95
- */
96
- function getQueue(key) {
97
- if (!keyQueues.has(key)) {
98
- keyQueues.set(key, new PQueue({ concurrency: 1 }));
99
- }
100
- return keyQueues.get(key);
101
- }
102
- /**
103
- * Get or create a transaction mutex
104
- */
105
- function getTxMutex(key) {
106
- if (!txMutexes.has(key)) {
107
- txMutexes.set(key, new Mutex());
108
- txMutexRefCounts.set(key, 0);
109
- }
110
- return txMutexes.get(key);
111
- }
112
- /**
113
- * Acquire a reference to a transaction mutex
114
- */
115
- function acquireTxMutexRef(key) {
116
- const count = txMutexRefCounts.get(key) ?? 0;
117
- txMutexRefCounts.set(key, count + 1);
118
- }
119
- /**
120
- * Release a reference to a transaction mutex and cleanup if no longer needed
121
- */
122
- function releaseTxMutexRef(key) {
123
- const count = (txMutexRefCounts.get(key) ?? 1) - 1;
124
- txMutexRefCounts.set(key, count);
125
- // Cleanup if no more references and mutex is not locked
126
- if (count <= 0) {
127
- const mutex = txMutexes.get(key);
128
- if (mutex && !mutex.isLocked()) {
129
- txMutexes.delete(key);
130
- txMutexRefCounts.delete(key);
131
- }
132
- }
133
- }
134
- /**
135
- * Check if currently in a transaction
136
- */
137
- function isInTransaction() {
138
- return !!txStorage.getStore();
139
- }
140
- /**
141
- * Commit transaction with retries
142
- */
143
- async function commitWithRetry(mutations) {
144
- if (Object.keys(mutations).length === 0) {
145
- logger.trace('no mutations in transaction');
146
- return;
147
- }
148
- logger.trace('committing transaction');
149
- for (let attempt = 0; attempt < maxCommitRetries; attempt++) {
150
- try {
151
- await state.set(mutations);
152
- logger.trace({ mutationCount: Object.keys(mutations).length }, 'committed transaction');
153
- return;
154
- }
155
- catch (error) {
156
- const retriesLeft = maxCommitRetries - attempt - 1;
157
- logger.warn(`failed to commit mutations, retries left=${retriesLeft}`);
158
- if (retriesLeft === 0) {
159
- throw error;
160
- }
161
- await delay(delayBetweenTriesMs);
162
- }
163
- }
164
- }
80
+ const addTransactionCapability = (state, logger, { maxCommitRetries, delayBetweenTriesMs }) => {
81
+ // number of queries made to the DB during the transaction
82
+ // only there for logging purposes
83
+ let dbQueriesInTransaction = 0;
84
+ let transactionCache = {};
85
+ let mutations = {};
86
+ let transactionsInProgress = 0;
165
87
  return {
166
88
  get: async (type, ids) => {
167
- const ctx = txStorage.getStore();
168
- if (!ctx) {
169
- // No transaction - direct read without exclusive lock for concurrency
170
- return state.get(type, ids);
171
- }
172
- // In transaction - check cache first
173
- const cached = ctx.cache[type] || {};
174
- const missing = ids.filter(id => !(id in cached));
175
- if (missing.length > 0) {
176
- ctx.dbQueries++;
177
- logger.trace({ type, count: missing.length }, 'fetching missing keys in transaction');
178
- const fetched = await getTxMutex(type).runExclusive(() => state.get(type, missing));
179
- // Update cache
180
- ctx.cache[type] = ctx.cache[type] || {};
181
- Object.assign(ctx.cache[type], fetched);
182
- }
183
- // Return requested ids from cache
184
- const result = {};
185
- for (const id of ids) {
186
- const value = ctx.cache[type]?.[id];
187
- if (value !== undefined && value !== null) {
188
- result[id] = value;
89
+ if (isInTransaction()) {
90
+ const dict = transactionCache[type];
91
+ const idsRequiringFetch = dict
92
+ ? ids.filter(item => typeof dict[item] === 'undefined')
93
+ : ids;
94
+ // only fetch if there are any items to fetch
95
+ if (idsRequiringFetch.length) {
96
+ dbQueriesInTransaction += 1;
97
+ const result = await state.get(type, idsRequiringFetch);
98
+ transactionCache[type] || (transactionCache[type] = {});
99
+ Object.assign(transactionCache[type], result);
189
100
  }
101
+ return ids.reduce((dict, id) => {
102
+ var _a;
103
+ const value = (_a = transactionCache[type]) === null || _a === void 0 ? void 0 : _a[id];
104
+ if (value) {
105
+ dict[id] = value;
106
+ }
107
+ return dict;
108
+ }, {});
109
+ }
110
+ else {
111
+ return state.get(type, ids);
190
112
  }
191
- return result;
192
113
  },
193
- set: async (data) => {
194
- const ctx = txStorage.getStore();
195
- if (!ctx) {
196
- // No transaction - direct write with queue protection
197
- const types = Object.keys(data);
198
- // Process pre-keys with validation
199
- for (const type_ of types) {
200
- const type = type_;
201
- if (type === 'pre-key') {
202
- await preKeyManager.validateDeletions(data, type);
203
- }
114
+ set: data => {
115
+ if (isInTransaction()) {
116
+ logger.trace({ types: Object.keys(data) }, 'caching in transaction');
117
+ for (const key in data) {
118
+ transactionCache[key] = transactionCache[key] || {};
119
+ Object.assign(transactionCache[key], data[key]);
120
+ mutations[key] = mutations[key] || {};
121
+ Object.assign(mutations[key], data[key]);
204
122
  }
205
- // Write all data in parallel
206
- await Promise.all(types.map(type => getQueue(type).add(async () => {
207
- const typeData = { [type]: data[type] };
208
- await state.set(typeData);
209
- })));
210
- return;
211
123
  }
212
- // In transaction - update cache and mutations
213
- logger.trace({ types: Object.keys(data) }, 'caching in transaction');
214
- for (const key_ in data) {
215
- const key = key_;
216
- // Ensure structures exist
217
- ctx.cache[key] = ctx.cache[key] || {};
218
- ctx.mutations[key] = ctx.mutations[key] || {};
219
- // Special handling for pre-keys
220
- if (key === 'pre-key') {
221
- await preKeyManager.processOperations(data, key, ctx.cache, ctx.mutations, true);
222
- }
223
- else {
224
- // Normal key types
225
- Object.assign(ctx.cache[key], data[key]);
226
- Object.assign(ctx.mutations[key], data[key]);
227
- }
124
+ else {
125
+ return state.set(data);
228
126
  }
229
127
  },
230
128
  isInTransaction,
231
- transaction: async (work, key) => {
232
- const existing = txStorage.getStore();
233
- // Nested transaction - reuse existing context
234
- if (existing) {
235
- logger.trace('reusing existing transaction context');
236
- return work();
129
+ async transaction(work) {
130
+ let result;
131
+ transactionsInProgress += 1;
132
+ if (transactionsInProgress === 1) {
133
+ logger.trace('entering transaction');
237
134
  }
238
- // New transaction - acquire mutex and create context
239
- const mutex = getTxMutex(key);
240
- acquireTxMutexRef(key);
241
135
  try {
242
- return await mutex.runExclusive(async () => {
243
- const ctx = {
244
- cache: {},
245
- mutations: {},
246
- dbQueries: 0
247
- };
248
- logger.trace('entering transaction');
249
- try {
250
- const result = await txStorage.run(ctx, work);
251
- // Commit mutations
252
- await commitWithRetry(ctx.mutations);
253
- logger.trace({ dbQueries: ctx.dbQueries }, 'transaction completed');
254
- return result;
136
+ result = await work();
137
+ // commit if this is the outermost transaction
138
+ if (transactionsInProgress === 1) {
139
+ if (Object.keys(mutations).length) {
140
+ logger.trace('committing transaction');
141
+ // retry mechanism to ensure we've some recovery
142
+ // in case a transaction fails in the first attempt
143
+ let tries = maxCommitRetries;
144
+ while (tries) {
145
+ tries -= 1;
146
+ try {
147
+ await state.set(mutations);
148
+ logger.trace({ dbQueriesInTransaction }, 'committed transaction');
149
+ break;
150
+ }
151
+ catch (error) {
152
+ logger.warn(`failed to commit ${Object.keys(mutations).length} mutations, tries left=${tries}`);
153
+ await (0, generics_1.delay)(delayBetweenTriesMs);
154
+ }
155
+ }
255
156
  }
256
- catch (error) {
257
- logger.error({ error }, 'transaction failed, rolling back');
258
- throw error;
157
+ else {
158
+ logger.trace('no mutations in transaction');
259
159
  }
260
- });
160
+ }
261
161
  }
262
162
  finally {
263
- releaseTxMutexRef(key);
163
+ transactionsInProgress -= 1;
164
+ if (transactionsInProgress === 0) {
165
+ transactionCache = {};
166
+ mutations = {};
167
+ dbQueriesInTransaction = 0;
168
+ }
264
169
  }
170
+ return result;
265
171
  }
266
172
  };
267
- };
268
- /**
269
- * Returns the authenticated user's JID, or throws a Boom-401 if creds are not yet authenticated.
270
- * Use this anywhere we'd otherwise reach for `creds.me!.id` to fail fast with a descriptive error.
271
- */
272
- export const assertMeId = (creds) => {
273
- const id = creds.me?.id;
274
- if (!id) {
275
- throw new Boom('Cannot proceed: socket is not authenticated yet (creds.me.id is missing)', { statusCode: 401 });
173
+ function isInTransaction() {
174
+ return transactionsInProgress > 0;
276
175
  }
277
- return id;
278
176
  };
279
- export const initAuthCreds = () => {
280
- const identityKey = Curve.generateKeyPair();
177
+ exports.addTransactionCapability = addTransactionCapability;
178
+ const initAuthCreds = () => {
179
+ const identityKey = crypto_2.Curve.generateKeyPair();
281
180
  return {
282
- noiseKey: Curve.generateKeyPair(),
283
- pairingEphemeralKeyPair: Curve.generateKeyPair(),
181
+ noiseKey: crypto_2.Curve.generateKeyPair(),
182
+ pairingEphemeralKeyPair: crypto_2.Curve.generateKeyPair(),
284
183
  signedIdentityKey: identityKey,
285
- signedPreKey: signedKeyPair(identityKey, 1),
286
- registrationId: generateRegistrationId(),
287
- advSecretKey: randomBytes(32).toString('base64'),
184
+ signedPreKey: (0, crypto_2.signedKeyPair)(identityKey, 1),
185
+ registrationId: (0, generics_1.generateRegistrationId)(),
186
+ advSecretKey: (0, crypto_1.randomBytes)(32).toString('base64'),
288
187
  processedHistoryMessages: [],
289
188
  nextPreKeyId: 1,
290
189
  firstUnuploadedPreKeyId: 1,
@@ -292,11 +191,16 @@ export const initAuthCreds = () => {
292
191
  accountSettings: {
293
192
  unarchiveChats: false
294
193
  },
194
+ // mobile creds
195
+ deviceId: Buffer.from((0, uuid_1.v4)().replace(/-/g, ''), 'hex').toString('base64url'),
196
+ phoneId: (0, uuid_1.v4)(),
197
+ identityId: (0, crypto_1.randomBytes)(20),
295
198
  registered: false,
199
+ backupToken: (0, crypto_1.randomBytes)(20),
200
+ registration: {},
296
201
  pairingCode: undefined,
297
202
  lastPropHash: undefined,
298
203
  routingInfo: undefined,
299
- additionalData: undefined
300
204
  };
301
205
  };
302
- //# sourceMappingURL=auth-utils.js.map
206
+ exports.initAuthCreds = initAuthCreds;
@@ -0,0 +1,16 @@
1
+ import type { BaileysEventEmitter } from '../Types';
2
+ /**
3
+ * Captures events from a baileys event emitter & stores them in a file
4
+ * @param ev The event emitter to read events from
5
+ * @param filename File to save to
6
+ */
7
+ export declare const captureEventStream: (ev: BaileysEventEmitter, filename: string) => void;
8
+ /**
9
+ * Read event file and emit events from there
10
+ * @param filename filename containing event data
11
+ * @param delayIntervalMs delay between each event emit
12
+ */
13
+ export declare const readAndEmitEventStream: (filename: string, delayIntervalMs?: number) => {
14
+ ev: BaileysEventEmitter;
15
+ task: Promise<void>;
16
+ };
@@ -0,0 +1,63 @@
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.readAndEmitEventStream = exports.captureEventStream = void 0;
7
+ const events_1 = __importDefault(require("events"));
8
+ const fs_1 = require("fs");
9
+ const promises_1 = require("fs/promises");
10
+ const readline_1 = require("readline");
11
+ const generics_1 = require("./generics");
12
+ const make_mutex_1 = require("./make-mutex");
13
+ /**
14
+ * Captures events from a baileys event emitter & stores them in a file
15
+ * @param ev The event emitter to read events from
16
+ * @param filename File to save to
17
+ */
18
+ const captureEventStream = (ev, filename) => {
19
+ const oldEmit = ev.emit;
20
+ // write mutex so data is appended in order
21
+ const writeMutex = (0, make_mutex_1.makeMutex)();
22
+ // monkey patch eventemitter to capture all events
23
+ ev.emit = function (...args) {
24
+ const content = JSON.stringify({ timestamp: Date.now(), event: args[0], data: args[1] }) + '\n';
25
+ const result = oldEmit.apply(ev, args);
26
+ writeMutex.mutex(async () => {
27
+ await (0, promises_1.writeFile)(filename, content, { flag: 'a' });
28
+ });
29
+ return result;
30
+ };
31
+ };
32
+ exports.captureEventStream = captureEventStream;
33
+ /**
34
+ * Read event file and emit events from there
35
+ * @param filename filename containing event data
36
+ * @param delayIntervalMs delay between each event emit
37
+ */
38
+ const readAndEmitEventStream = (filename, delayIntervalMs = 0) => {
39
+ const ev = new events_1.default();
40
+ const fireEvents = async () => {
41
+ // from: https://stackoverflow.com/questions/6156501/read-a-file-one-line-at-a-time-in-node-js
42
+ const fileStream = (0, fs_1.createReadStream)(filename);
43
+ const rl = (0, readline_1.createInterface)({
44
+ input: fileStream,
45
+ crlfDelay: Infinity
46
+ });
47
+ // Note: we use the crlfDelay option to recognize all instances of CR LF
48
+ // ('\r\n') in input.txt as a single line break.
49
+ for await (const line of rl) {
50
+ if (line) {
51
+ const { event, data } = JSON.parse(line);
52
+ ev.emit(event, data);
53
+ delayIntervalMs && await (0, generics_1.delay)(delayIntervalMs);
54
+ }
55
+ }
56
+ fileStream.close();
57
+ };
58
+ return {
59
+ ev,
60
+ task: fireEvents()
61
+ };
62
+ };
63
+ exports.readAndEmitEventStream = readAndEmitEventStream;
@@ -1,5 +1,5 @@
1
- import type { CatalogCollection, OrderDetails, Product, ProductCreate, ProductUpdate, WAMediaUpload, WAMediaUploadFunction } from '../Types/index.js';
2
- import { type BinaryNode } from '../WABinary/index.js';
1
+ import { CatalogCollection, OrderDetails, Product, ProductCreate, ProductUpdate, WAMediaUpload, WAMediaUploadFunction } from '../Types';
2
+ import { BinaryNode } from '../WABinary';
3
3
  export declare const parseCatalogNode: (node: BinaryNode) => {
4
4
  products: Product[];
5
5
  nextPageCursor: string | undefined;
@@ -20,4 +20,3 @@ export declare function uploadingNecessaryImagesOfProduct<T extends ProductUpdat
20
20
  export declare const uploadingNecessaryImages: (images: WAMediaUpload[], waUploadToServer: WAMediaUploadFunction, timeoutMs?: number) => Promise<{
21
21
  url: string;
22
22
  }[]>;
23
- //# sourceMappingURL=business.d.ts.map