@skyzopedia/baileys-mod 5.0.8 → 6.0.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 (210) hide show
  1. package/WAProto/index.js +133384 -57814
  2. package/engine-requirements.js +10 -0
  3. package/lib/Defaults/baileys-version.json +3 -0
  4. package/lib/Defaults/index.d.ts +53 -0
  5. package/lib/Defaults/index.js +141 -117
  6. package/lib/Defaults/phonenumber-mcc.json +223 -0
  7. package/lib/Signal/Group/ciphertext-message.d.ts +9 -0
  8. package/lib/Signal/Group/ciphertext-message.js +14 -12
  9. package/lib/Signal/Group/group-session-builder.d.ts +14 -0
  10. package/lib/Signal/Group/group-session-builder.js +42 -10
  11. package/lib/Signal/Group/group_cipher.d.ts +17 -0
  12. package/lib/Signal/Group/group_cipher.js +87 -75
  13. package/lib/Signal/Group/index.d.ts +11 -0
  14. package/lib/Signal/Group/index.js +57 -13
  15. package/lib/Signal/Group/keyhelper.d.ts +10 -0
  16. package/lib/Signal/Group/keyhelper.js +52 -17
  17. package/lib/Signal/Group/queue-job.d.ts +1 -0
  18. package/lib/Signal/Group/queue-job.js +57 -0
  19. package/lib/Signal/Group/sender-chain-key.d.ts +13 -0
  20. package/lib/Signal/Group/sender-chain-key.js +33 -27
  21. package/lib/Signal/Group/sender-key-distribution-message.d.ts +16 -0
  22. package/lib/Signal/Group/sender-key-distribution-message.js +63 -62
  23. package/lib/Signal/Group/sender-key-message.d.ts +18 -0
  24. package/lib/Signal/Group/sender-key-message.js +66 -65
  25. package/lib/Signal/Group/sender-key-name.d.ts +17 -0
  26. package/lib/Signal/Group/sender-key-name.js +44 -45
  27. package/lib/Signal/Group/sender-key-record.d.ts +30 -0
  28. package/lib/Signal/Group/sender-key-record.js +49 -39
  29. package/lib/Signal/Group/sender-key-state.d.ts +38 -0
  30. package/lib/Signal/Group/sender-key-state.js +93 -80
  31. package/lib/Signal/Group/sender-message-key.d.ts +11 -0
  32. package/lib/Signal/Group/sender-message-key.js +28 -27
  33. package/lib/Signal/libsignal.d.ts +3 -0
  34. package/lib/Signal/libsignal.js +163 -313
  35. package/lib/Socket/Client/abstract-socket-client.d.ts +17 -0
  36. package/lib/Socket/Client/abstract-socket-client.js +13 -0
  37. package/lib/Socket/Client/index.d.ts +3 -0
  38. package/lib/Socket/Client/index.js +19 -4
  39. package/lib/Socket/Client/mobile-socket-client.d.ts +13 -0
  40. package/lib/Socket/Client/mobile-socket-client.js +65 -0
  41. package/lib/Socket/Client/web-socket-client.d.ts +12 -0
  42. package/lib/Socket/Client/web-socket-client.js +62 -0
  43. package/lib/Socket/business.d.ts +171 -0
  44. package/lib/Socket/business.js +242 -359
  45. package/lib/Socket/chats.d.ts +267 -0
  46. package/lib/Socket/chats.js +935 -846
  47. package/lib/Socket/dugong.d.ts +254 -0
  48. package/lib/Socket/dugong.js +484 -0
  49. package/lib/Socket/groups.d.ts +115 -0
  50. package/lib/Socket/groups.js +309 -304
  51. package/lib/Socket/index.d.ts +173 -0
  52. package/lib/Socket/index.js +10 -15
  53. package/lib/Socket/messages-recv.d.ts +161 -0
  54. package/lib/Socket/messages-recv.js +1054 -1107
  55. package/lib/Socket/messages-send.d.ts +149 -0
  56. package/lib/Socket/messages-send.js +447 -706
  57. package/lib/Socket/newsletter.d.ts +134 -0
  58. package/lib/Socket/newsletter.js +314 -199
  59. package/lib/Socket/registration.d.ts +267 -0
  60. package/lib/Socket/registration.js +166 -0
  61. package/lib/Socket/socket.d.ts +43 -0
  62. package/lib/Socket/socket.js +650 -777
  63. package/lib/Socket/usync.d.ts +36 -0
  64. package/lib/Socket/usync.js +70 -0
  65. package/lib/Store/index.d.ts +3 -0
  66. package/lib/Store/index.js +10 -6
  67. package/lib/Store/make-cache-manager-store.d.ts +13 -0
  68. package/lib/Store/make-cache-manager-store.js +81 -73
  69. package/lib/Store/make-in-memory-store.d.ts +118 -0
  70. package/lib/Store/make-in-memory-store.js +423 -286
  71. package/lib/Store/make-ordered-dictionary.d.ts +13 -0
  72. package/lib/Store/make-ordered-dictionary.js +79 -77
  73. package/lib/Store/object-repository.d.ts +10 -0
  74. package/lib/Store/object-repository.js +26 -24
  75. package/lib/Types/Auth.d.ts +110 -0
  76. package/lib/Types/Auth.js +2 -3
  77. package/lib/Types/Call.d.ts +13 -0
  78. package/lib/Types/Call.js +2 -3
  79. package/lib/Types/Chat.d.ts +102 -0
  80. package/lib/Types/Chat.js +4 -9
  81. package/lib/Types/Contact.d.ts +19 -0
  82. package/lib/Types/Contact.js +2 -3
  83. package/lib/Types/Events.d.ts +157 -0
  84. package/lib/Types/Events.js +2 -3
  85. package/lib/Types/GroupMetadata.d.ts +55 -0
  86. package/lib/Types/GroupMetadata.js +2 -3
  87. package/lib/Types/Label.d.ts +35 -0
  88. package/lib/Types/Label.js +26 -24
  89. package/lib/Types/LabelAssociation.d.ts +29 -0
  90. package/lib/Types/LabelAssociation.js +8 -6
  91. package/lib/Types/Message.d.ts +273 -0
  92. package/lib/Types/Message.js +9 -12
  93. package/lib/Types/Newsletter.d.ts +103 -0
  94. package/lib/Types/Newsletter.js +38 -33
  95. package/lib/Types/Product.d.ts +78 -0
  96. package/lib/Types/Product.js +2 -3
  97. package/lib/Types/Signal.d.ts +57 -0
  98. package/lib/Types/Signal.js +2 -3
  99. package/lib/Types/Socket.d.ts +111 -0
  100. package/lib/Types/Socket.js +2 -4
  101. package/lib/Types/State.d.ts +27 -0
  102. package/lib/Types/State.js +2 -11
  103. package/lib/Types/USync.d.ts +25 -0
  104. package/lib/Types/USync.js +2 -3
  105. package/lib/Types/index.d.ts +57 -0
  106. package/lib/Types/index.js +41 -27
  107. package/lib/Utils/auth-utils.d.ts +18 -0
  108. package/lib/Utils/auth-utils.js +198 -211
  109. package/lib/Utils/baileys-event-stream.d.ts +16 -0
  110. package/lib/Utils/baileys-event-stream.js +61 -42
  111. package/lib/Utils/business.d.ts +22 -0
  112. package/lib/Utils/business.js +214 -213
  113. package/lib/Utils/chat-utils.d.ts +71 -0
  114. package/lib/Utils/chat-utils.js +687 -710
  115. package/lib/Utils/crypto.d.ts +41 -0
  116. package/lib/Utils/crypto.js +133 -112
  117. package/lib/Utils/decode-wa-message.d.ts +19 -0
  118. package/lib/Utils/decode-wa-message.js +183 -252
  119. package/lib/Utils/event-buffer.d.ts +35 -0
  120. package/lib/Utils/event-buffer.js +496 -510
  121. package/lib/Utils/generics.d.ts +92 -0
  122. package/lib/Utils/generics.js +387 -319
  123. package/lib/Utils/history.d.ts +15 -0
  124. package/lib/Utils/history.js +92 -83
  125. package/lib/Utils/index.d.ts +17 -0
  126. package/lib/Utils/index.js +33 -21
  127. package/lib/Utils/link-preview.d.ts +21 -0
  128. package/lib/Utils/link-preview.js +83 -71
  129. package/lib/Utils/logger.d.ts +4 -0
  130. package/lib/Utils/logger.js +7 -5
  131. package/lib/Utils/lt-hash.d.ts +12 -0
  132. package/lib/Utils/lt-hash.js +46 -40
  133. package/lib/Utils/make-mutex.d.ts +7 -0
  134. package/lib/Utils/make-mutex.js +41 -34
  135. package/lib/Utils/messages-media.d.ts +116 -0
  136. package/lib/Utils/messages-media.js +768 -550
  137. package/lib/Utils/messages.d.ts +77 -0
  138. package/lib/Utils/messages.js +263 -362
  139. package/lib/Utils/noise-handler.d.ts +21 -0
  140. package/lib/Utils/noise-handler.js +149 -138
  141. package/lib/Utils/process-message.d.ts +41 -0
  142. package/lib/Utils/process-message.js +303 -323
  143. package/lib/Utils/signal.d.ts +32 -0
  144. package/lib/Utils/signal.js +141 -149
  145. package/lib/Utils/use-multi-file-auth-state.d.ts +13 -0
  146. package/lib/Utils/use-multi-file-auth-state.js +103 -95
  147. package/lib/Utils/validate-connection.d.ts +11 -0
  148. package/lib/Utils/validate-connection.js +220 -183
  149. package/lib/WABinary/constants.d.ts +30 -0
  150. package/lib/WABinary/constants.js +35 -1298
  151. package/lib/WABinary/decode.d.ts +7 -0
  152. package/lib/WABinary/decode.js +249 -237
  153. package/lib/WABinary/encode.d.ts +3 -0
  154. package/lib/WABinary/encode.js +260 -213
  155. package/lib/WABinary/generic-utils.d.ts +17 -0
  156. package/lib/WABinary/generic-utils.js +65 -56
  157. package/lib/WABinary/index.d.ts +5 -0
  158. package/lib/WABinary/index.js +21 -7
  159. package/lib/WABinary/jid-utils.d.ts +31 -0
  160. package/lib/WABinary/jid-utils.js +58 -89
  161. package/lib/WABinary/types.d.ts +18 -0
  162. package/lib/WABinary/types.js +2 -3
  163. package/lib/WAM/BinaryInfo.d.ts +17 -0
  164. package/lib/WAM/BinaryInfo.js +12 -10
  165. package/lib/WAM/constants.d.ts +38 -0
  166. package/lib/WAM/constants.js +15348 -22851
  167. package/lib/WAM/encode.d.ts +3 -0
  168. package/lib/WAM/encode.js +136 -135
  169. package/lib/WAM/index.d.ts +3 -0
  170. package/lib/WAM/index.js +19 -5
  171. package/lib/WAUSync/Protocols/USyncContactProtocol.d.ts +9 -0
  172. package/lib/WAUSync/Protocols/USyncContactProtocol.js +30 -28
  173. package/lib/WAUSync/Protocols/USyncDeviceProtocol.d.ts +22 -0
  174. package/lib/WAUSync/Protocols/USyncDeviceProtocol.js +53 -49
  175. package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.d.ts +12 -0
  176. package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.js +28 -27
  177. package/lib/WAUSync/Protocols/USyncStatusProtocol.d.ts +12 -0
  178. package/lib/WAUSync/Protocols/USyncStatusProtocol.js +39 -36
  179. package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.d.ts +25 -0
  180. package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.js +50 -50
  181. package/lib/WAUSync/Protocols/UsyncLIDProtocol.d.ts +8 -0
  182. package/lib/WAUSync/Protocols/UsyncLIDProtocol.js +20 -26
  183. package/lib/WAUSync/Protocols/index.d.ts +4 -0
  184. package/lib/WAUSync/Protocols/index.js +20 -6
  185. package/lib/WAUSync/USyncQuery.d.ts +28 -0
  186. package/lib/WAUSync/USyncQuery.js +85 -86
  187. package/lib/WAUSync/USyncUser.d.ts +12 -0
  188. package/lib/WAUSync/USyncUser.js +25 -23
  189. package/lib/WAUSync/index.d.ts +3 -0
  190. package/lib/WAUSync/index.js +19 -5
  191. package/lib/index.d.ts +12 -0
  192. package/lib/index.js +36 -24
  193. package/package.json +106 -98
  194. package/LICENSE +0 -21
  195. package/WAProto/WAProto.proto +0 -5311
  196. package/lib/KeyDB/BinarySearch.js +0 -20
  197. package/lib/KeyDB/KeyedDB.js +0 -167
  198. package/lib/KeyDB/index.js +0 -4
  199. package/lib/Signal/lid-mapping.js +0 -155
  200. package/lib/Socket/Client/types.js +0 -13
  201. package/lib/Socket/Client/websocket.js +0 -52
  202. package/lib/Socket/Client/websocket.js.bak +0 -53
  203. package/lib/Socket/communities.js +0 -413
  204. package/lib/Socket/mex.js +0 -45
  205. package/lib/Types/Bussines.js +0 -3
  206. package/lib/Types/Newsletter.js.bak +0 -33
  207. package/lib/Utils/browser-utils.js +0 -25
  208. package/lib/Utils/message-retry-manager.js +0 -113
  209. package/lib/Utils/messages.js.bak +0 -907
  210. package/lib/Utils/pre-key-manager.js +0 -85
@@ -1,219 +1,206 @@
1
- //=======================================================//
2
- import { delay, generateRegistrationId } from "./generics.js";
3
- import { DEFAULT_CACHE_TTLS } from "../Defaults/index.js";
4
- import { PreKeyManager } from "./pre-key-manager.js";
5
- import { Curve, signedKeyPair } from "./crypto.js";
6
- import { AsyncLocalStorage } from "async_hooks";
7
- import NodeCache from "@cacheable/node-cache";
8
- import { randomBytes } from "crypto";
9
- import { Mutex } from "async-mutex";
10
- import PQueue from "p-queue";
11
- //=======================================================//
12
- export function makeCacheableSignalKeyStore(store, logger, _cache) {
13
- const cache = _cache ||
14
- new NodeCache({
15
- stdTTL: DEFAULT_CACHE_TTLS.SIGNAL_STORE,
16
- useClones: false,
17
- deleteOnExpire: true
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");
13
+ /**
14
+ * Adds caching capability to a SignalKeyStore
15
+ * @param store the store to add caching to
16
+ * @param logger to log trace events
17
+ * @param _cache cache store to use
18
+ */
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,
18
24
  });
19
- const cacheMutex = new Mutex();
20
- function getUniqueId(type, id) {
21
- return `${type}.${id}`;
22
- }
23
- return {
24
- async get(type, ids) {
25
- return cacheMutex.runExclusive(async () => {
26
- const data = {};
27
- const idsToFetch = [];
28
- for (const id of ids) {
29
- const item = (await cache.get(getUniqueId(type, id)));
30
- if (typeof item !== "undefined") {
31
- data[id] = item;
32
- }
33
- else {
34
- idsToFetch.push(id);
35
- }
36
- }
37
- if (idsToFetch.length) {
38
- logger?.trace({ items: idsToFetch.length }, "loading from store");
39
- const fetched = await store.get(type, idsToFetch);
40
- for (const id of idsToFetch) {
41
- const item = fetched[id];
42
- if (item) {
43
- data[id] = item;
44
- cache.set(getUniqueId(type, id), item);
25
+ function getUniqueId(type, id) {
26
+ return `${type}.${id}`;
27
+ }
28
+ return {
29
+ async get(type, ids) {
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;
36
+ }
37
+ else {
38
+ idsToFetch.push(id);
39
+ }
45
40
  }
46
- }
47
- }
48
- return data;
49
- });
50
- },
51
- async set(data) {
52
- return cacheMutex.runExclusive(async () => {
53
- let keys = 0;
54
- for (const type in data) {
55
- for (const id in data[type]) {
56
- await cache.set(getUniqueId(type, id), data[type][id]);
57
- keys += 1;
58
- }
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);
49
+ }
50
+ }
51
+ }
52
+ return data;
53
+ },
54
+ async set(data) {
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;
60
+ }
61
+ }
62
+ logger.trace({ keys }, 'updated cache');
63
+ await store.set(data);
64
+ },
65
+ async clear() {
66
+ var _a;
67
+ cache.flushAll();
68
+ await ((_a = store.clear) === null || _a === void 0 ? void 0 : _a.call(store));
59
69
  }
60
- logger?.trace({ keys }, "updated cache");
61
- await store.set(data);
62
- });
63
- },
64
- async clear() {
65
- await cache.flushAll();
66
- await store.clear?.();
67
- }
68
- };
70
+ };
69
71
  }
70
- //=======================================================//
71
- export const addTransactionCapability = (state, logger, { maxCommitRetries, delayBetweenTriesMs }) => {
72
- const txStorage = new AsyncLocalStorage();
73
- const keyQueues = new Map();
74
- const txMutexes = new Map();
75
- const preKeyManager = new PreKeyManager(state, logger);
76
- function getQueue(key) {
77
- if (!keyQueues.has(key)) {
78
- keyQueues.set(key, new PQueue({ concurrency: 1 }));
79
- }
80
- return keyQueues.get(key);
81
- }
82
- function getTxMutex(key) {
83
- if (!txMutexes.has(key)) {
84
- txMutexes.set(key, new Mutex());
85
- }
86
- return txMutexes.get(key);
87
- }
88
- function isInTransaction() {
89
- return !!txStorage.getStore();
90
- }
91
- async function commitWithRetry(mutations) {
92
- if (Object.keys(mutations).length === 0) {
93
- logger.trace("no mutations in transaction");
94
- return;
95
- }
96
- logger.trace("committing transaction");
97
- for (let attempt = 0; attempt < maxCommitRetries; attempt++) {
98
- try {
99
- await state.set(mutations);
100
- logger.trace({ mutationCount: Object.keys(mutations).length }, "committed transaction");
101
- return;
102
- }
103
- catch (error) {
104
- const retriesLeft = maxCommitRetries - attempt - 1;
105
- logger.warn(`failed to commit mutations, retries left=${retriesLeft}`);
106
- if (retriesLeft === 0) {
107
- throw error;
108
- }
109
- await delay(delayBetweenTriesMs);
110
- }
111
- }
112
- }
113
- return {
114
- get: async (type, ids) => {
115
- const ctx = txStorage.getStore();
116
- if (!ctx) {
117
- return state.get(type, ids);
118
- }
119
- const cached = ctx.cache[type] || {};
120
- const missing = ids.filter(id => !(id in cached));
121
- if (missing.length > 0) {
122
- ctx.dbQueries++;
123
- logger.trace({ type, count: missing.length }, "fetching missing keys in transaction");
124
- const fetched = await getTxMutex(type).runExclusive(() => state.get(type, missing));
125
- ctx.cache[type] = ctx.cache[type] || {};
126
- Object.assign(ctx.cache[type], fetched);
127
- }
128
- const result = {};
129
- for (const id of ids) {
130
- const value = ctx.cache[type]?.[id];
131
- if (value !== undefined && value !== null) {
132
- result[id] = value;
133
- }
134
- }
135
- return result;
136
- },
137
- set: async (data) => {
138
- const ctx = txStorage.getStore();
139
- if (!ctx) {
140
- const types = Object.keys(data);
141
- for (const type_ of types) {
142
- const type = type_;
143
- if (type === "pre-key") {
144
- await preKeyManager.validateDeletions(data, type);
145
- }
146
- }
147
- await Promise.all(types.map(type => getQueue(type).add(async () => {
148
- const typeData = { [type]: data[type] };
149
- await state.set(typeData);
150
- })));
151
- return;
152
- }
153
- logger.trace({ types: Object.keys(data) }, "caching in transaction");
154
- for (const key_ in data) {
155
- const key = key_;
156
- ctx.cache[key] = ctx.cache[key] || {};
157
- ctx.mutations[key] = ctx.mutations[key] || {};
158
- if (key === "pre-key") {
159
- await preKeyManager.processOperations(data, key, ctx.cache, ctx.mutations, true);
160
- }
161
- else {
162
- Object.assign(ctx.cache[key], data[key]);
163
- Object.assign(ctx.mutations[key], data[key]);
164
- }
165
- }
166
- },
167
- isInTransaction,
168
- transaction: async (work, key) => {
169
- const existing = txStorage.getStore();
170
- if (existing) {
171
- logger.trace("reusing existing transaction context");
172
- return work();
173
- }
174
- return getTxMutex(key).runExclusive(async () => {
175
- const ctx = {
176
- cache: {},
177
- mutations: {},
178
- dbQueries: 0
179
- };
180
- logger.trace("entering transaction");
181
- try {
182
- const result = await txStorage.run(ctx, work);
183
- await commitWithRetry(ctx.mutations);
184
- logger.trace({ dbQueries: ctx.dbQueries }, "transaction completed");
185
- return result;
186
- }
187
- catch (error) {
188
- logger.error({ error }, "transaction failed, rolling back");
189
- throw error;
72
+ exports.makeCacheableSignalKeyStore = makeCacheableSignalKeyStore;
73
+ /**
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
76
+ * @param state the key store to apply this capability to
77
+ * @param logger logger to log events
78
+ * @returns SignalKeyStore with transaction capability
79
+ */
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;
87
+ return {
88
+ get: async (type, ids) => {
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);
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);
112
+ }
113
+ },
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]);
122
+ }
123
+ }
124
+ else {
125
+ return state.set(data);
126
+ }
127
+ },
128
+ isInTransaction,
129
+ async transaction(work) {
130
+ let result;
131
+ transactionsInProgress += 1;
132
+ if (transactionsInProgress === 1) {
133
+ logger.trace('entering transaction');
134
+ }
135
+ try {
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
+ }
156
+ }
157
+ else {
158
+ logger.trace('no mutations in transaction');
159
+ }
160
+ }
161
+ }
162
+ finally {
163
+ transactionsInProgress -= 1;
164
+ if (transactionsInProgress === 0) {
165
+ transactionCache = {};
166
+ mutations = {};
167
+ dbQueriesInTransaction = 0;
168
+ }
169
+ }
170
+ return result;
190
171
  }
191
- });
172
+ };
173
+ function isInTransaction() {
174
+ return transactionsInProgress > 0;
192
175
  }
193
- };
194
176
  };
195
- //=======================================================//
196
- export const initAuthCreds = () => {
197
- const identityKey = Curve.generateKeyPair();
198
- return {
199
- "noiseKey": Curve.generateKeyPair(),
200
- "pairingEphemeralKeyPair": Curve.generateKeyPair(),
201
- "signedIdentityKey": identityKey,
202
- "signedPreKey": signedKeyPair(identityKey, 1),
203
- "registrationId": generateRegistrationId(),
204
- "advSecretKey": randomBytes(32).toString("base64"),
205
- "processedHistoryMessages": [],
206
- "nextPreKeyId": 1,
207
- "firstUnuploadedPreKeyId": 1,
208
- "accountSyncCounter": 0,
209
- "accountSettings": {
210
- "unarchiveChats": false
211
- },
212
- "registered": false,
213
- "pairingCode": undefined,
214
- "lastPropHash": undefined,
215
- "routingInfo": undefined,
216
- "additionalData": undefined
217
- };
177
+ exports.addTransactionCapability = addTransactionCapability;
178
+ const initAuthCreds = () => {
179
+ const identityKey = crypto_2.Curve.generateKeyPair();
180
+ return {
181
+ noiseKey: crypto_2.Curve.generateKeyPair(),
182
+ pairingEphemeralKeyPair: crypto_2.Curve.generateKeyPair(),
183
+ signedIdentityKey: identityKey,
184
+ signedPreKey: (0, crypto_2.signedKeyPair)(identityKey, 1),
185
+ registrationId: (0, generics_1.generateRegistrationId)(),
186
+ advSecretKey: (0, crypto_1.randomBytes)(32).toString('base64'),
187
+ processedHistoryMessages: [],
188
+ nextPreKeyId: 1,
189
+ firstUnuploadedPreKeyId: 1,
190
+ accountSyncCounter: 0,
191
+ accountSettings: {
192
+ unarchiveChats: false
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),
198
+ registered: false,
199
+ backupToken: (0, crypto_1.randomBytes)(20),
200
+ registration: {},
201
+ pairingCode: undefined,
202
+ lastPropHash: undefined,
203
+ routingInfo: undefined,
204
+ };
218
205
  };
219
- //=======================================================//
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
+ };
@@ -1,44 +1,63 @@
1
- //=======================================================//
2
- import { makeMutex } from "./make-mutex.js";
3
- import { createInterface } from "readline";
4
- import { writeFile } from "fs/promises";
5
- import { delay } from "./generics.js";
6
- import { createReadStream } from "fs";
7
- import EventEmitter from "events";
8
- //=======================================================//
9
- export const captureEventStream = (ev, filename) => {
10
- const oldEmit = ev.emit;
11
- const writeMutex = makeMutex();
12
- ev.emit = function (...args) {
13
- const content = JSON.stringify({ timestamp: Date.now(), event: args[0], data: args[1] }) + "\n";
14
- const result = oldEmit.apply(ev, args);
15
- writeMutex.mutex(async () => {
16
- await writeFile(filename, content, { flag: "a" });
17
- });
18
- return result;
19
- };
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
20
4
  };
21
- //=======================================================//
22
- export const readAndEmitEventStream = (filename, delayIntervalMs = 0) => {
23
- const ev = new EventEmitter();
24
- const fireEvents = async () => {
25
- const fileStream = createReadStream(filename);
26
- const rl = createInterface({
27
- input: fileStream,
28
- crlfDelay: Infinity
29
- });
30
- for await (const line of rl) {
31
- if (line) {
32
- const { event, data } = JSON.parse(line);
33
- ev.emit(event, data);
34
- delayIntervalMs && (await delay(delayIntervalMs));
35
- }
36
- }
37
- fileStream.close();
38
- };
39
- return {
40
- ev,
41
- task: fireEvents()
42
- };
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
+ };
43
31
  };
44
- //=======================================================//
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;
@@ -0,0 +1,22 @@
1
+ import { CatalogCollection, OrderDetails, Product, ProductCreate, ProductUpdate, WAMediaUpload, WAMediaUploadFunction } from '../Types';
2
+ import { BinaryNode } from '../WABinary';
3
+ export declare const parseCatalogNode: (node: BinaryNode) => {
4
+ products: Product[];
5
+ nextPageCursor: string | undefined;
6
+ };
7
+ export declare const parseCollectionsNode: (node: BinaryNode) => {
8
+ collections: CatalogCollection[];
9
+ };
10
+ export declare const parseOrderDetailsNode: (node: BinaryNode) => OrderDetails;
11
+ export declare const toProductNode: (productId: string | undefined, product: ProductCreate | ProductUpdate) => BinaryNode;
12
+ export declare const parseProductNode: (productNode: BinaryNode) => Product;
13
+ /**
14
+ * Uploads images not already uploaded to WA's servers
15
+ */
16
+ export declare function uploadingNecessaryImagesOfProduct<T extends ProductUpdate | ProductCreate>(product: T, waUploadToServer: WAMediaUploadFunction, timeoutMs?: number): Promise<T>;
17
+ /**
18
+ * Uploads images not already uploaded to WA's servers
19
+ */
20
+ export declare const uploadingNecessaryImages: (images: WAMediaUpload[], waUploadToServer: WAMediaUploadFunction, timeoutMs?: number) => Promise<{
21
+ url: string;
22
+ }[]>;