@neelegirly/baileys 2.2.16

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 (206) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +108 -0
  3. package/WAProto/WAProto.proto +5007 -0
  4. package/WAProto/index.d.ts +57712 -0
  5. package/WAProto/index.js +178969 -0
  6. package/lib/Defaults/baileys-version.json +1 -0
  7. package/lib/Defaults/index.d.ts +68 -0
  8. package/lib/Defaults/index.js +155 -0
  9. package/lib/Defaults/phonenumber-mcc.json +223 -0
  10. package/lib/Signal/WASignalGroup/GroupProtocol.js +1909 -0
  11. package/lib/Signal/WASignalGroup/ciphertext_message.js +16 -0
  12. package/lib/Signal/WASignalGroup/generate-proto.sh +1 -0
  13. package/lib/Signal/WASignalGroup/group.proto +42 -0
  14. package/lib/Signal/WASignalGroup/group_cipher.js +120 -0
  15. package/lib/Signal/WASignalGroup/group_session_builder.js +46 -0
  16. package/lib/Signal/WASignalGroup/index.js +6 -0
  17. package/lib/Signal/WASignalGroup/keyhelper.js +22 -0
  18. package/lib/Signal/WASignalGroup/protobufs.js +3 -0
  19. package/lib/Signal/WASignalGroup/queue_job.js +69 -0
  20. package/lib/Signal/WASignalGroup/readme.md +6 -0
  21. package/lib/Signal/WASignalGroup/sender_chain_key.js +50 -0
  22. package/lib/Signal/WASignalGroup/sender_key_distribution_message.js +78 -0
  23. package/lib/Signal/WASignalGroup/sender_key_message.js +92 -0
  24. package/lib/Signal/WASignalGroup/sender_key_name.js +70 -0
  25. package/lib/Signal/WASignalGroup/sender_key_record.js +56 -0
  26. package/lib/Signal/WASignalGroup/sender_key_state.js +129 -0
  27. package/lib/Signal/WASignalGroup/sender_message_key.js +39 -0
  28. package/lib/Signal/libsignal.d.ts +4 -0
  29. package/lib/Signal/libsignal.js +427 -0
  30. package/lib/Socket/Client/abstract-socket-client.d.ts +15 -0
  31. package/lib/Socket/Client/abstract-socket-client.js +13 -0
  32. package/lib/Socket/Client/index.d.ts +2 -0
  33. package/lib/Socket/Client/index.js +22 -0
  34. package/lib/Socket/Client/mobile-socket-client.d.ts +12 -0
  35. package/lib/Socket/Client/mobile-socket-client.js +65 -0
  36. package/lib/Socket/Client/types.d.ts +16 -0
  37. package/lib/Socket/Client/types.js +18 -0
  38. package/lib/Socket/Client/websocket.d.ts +13 -0
  39. package/lib/Socket/Client/websocket.js +62 -0
  40. package/lib/Socket/business.d.ts +187 -0
  41. package/lib/Socket/business.js +268 -0
  42. package/lib/Socket/chats.d.ts +98 -0
  43. package/lib/Socket/chats.js +1133 -0
  44. package/lib/Socket/communities.d.ts +223 -0
  45. package/lib/Socket/communities.js +433 -0
  46. package/lib/Socket/groups.d.ts +131 -0
  47. package/lib/Socket/groups.js +352 -0
  48. package/lib/Socket/index.d.ts +191 -0
  49. package/lib/Socket/index.js +23 -0
  50. package/lib/Socket/messages-recv.d.ts +177 -0
  51. package/lib/Socket/messages-recv.js +1826 -0
  52. package/lib/Socket/messages-send.d.ts +168 -0
  53. package/lib/Socket/messages-send.js +1537 -0
  54. package/lib/Socket/mex.d.ts +2 -0
  55. package/lib/Socket/mex.js +47 -0
  56. package/lib/Socket/newsletter.d.ts +147 -0
  57. package/lib/Socket/newsletter.js +286 -0
  58. package/lib/Socket/registration.d.ts +266 -0
  59. package/lib/Socket/registration.js +166 -0
  60. package/lib/Socket/socket.d.ts +45 -0
  61. package/lib/Socket/socket.js +928 -0
  62. package/lib/Socket/usync.d.ts +37 -0
  63. package/lib/Socket/usync.js +83 -0
  64. package/lib/Store/index.d.ts +4 -0
  65. package/lib/Store/index.js +24 -0
  66. package/lib/Store/make-cache-manager-store.d.ts +14 -0
  67. package/lib/Store/make-cache-manager-store.js +90 -0
  68. package/lib/Store/make-in-memory-store.d.ts +123 -0
  69. package/lib/Store/make-in-memory-store.js +429 -0
  70. package/lib/Store/make-ordered-dictionary.d.ts +12 -0
  71. package/lib/Store/make-ordered-dictionary.js +86 -0
  72. package/lib/Store/object-repository.d.ts +10 -0
  73. package/lib/Store/object-repository.js +31 -0
  74. package/lib/Types/Auth.d.ts +120 -0
  75. package/lib/Types/Auth.js +3 -0
  76. package/lib/Types/Bussines.d.ts +20 -0
  77. package/lib/Types/Bussines.js +2 -0
  78. package/lib/Types/Call.d.ts +14 -0
  79. package/lib/Types/Call.js +3 -0
  80. package/lib/Types/Chat.d.ts +141 -0
  81. package/lib/Types/Chat.js +9 -0
  82. package/lib/Types/Contact.d.ts +20 -0
  83. package/lib/Types/Contact.js +3 -0
  84. package/lib/Types/Events.d.ts +237 -0
  85. package/lib/Types/Events.js +3 -0
  86. package/lib/Types/GroupMetadata.d.ts +66 -0
  87. package/lib/Types/GroupMetadata.js +3 -0
  88. package/lib/Types/Label.d.ts +48 -0
  89. package/lib/Types/Label.js +31 -0
  90. package/lib/Types/LabelAssociation.d.ts +35 -0
  91. package/lib/Types/LabelAssociation.js +13 -0
  92. package/lib/Types/Message.d.ts +473 -0
  93. package/lib/Types/Message.js +13 -0
  94. package/lib/Types/MexUpdates.d.ts +9 -0
  95. package/lib/Types/MexUpdates.js +18 -0
  96. package/lib/Types/Newsletter.d.ts +109 -0
  97. package/lib/Types/Newsletter.js +40 -0
  98. package/lib/Types/Product.d.ts +92 -0
  99. package/lib/Types/Product.js +3 -0
  100. package/lib/Types/Signal.d.ts +68 -0
  101. package/lib/Types/Signal.js +3 -0
  102. package/lib/Types/Socket.d.ts +122 -0
  103. package/lib/Types/Socket.js +3 -0
  104. package/lib/Types/State.d.ts +41 -0
  105. package/lib/Types/State.js +14 -0
  106. package/lib/Types/USync.d.ts +26 -0
  107. package/lib/Types/USync.js +3 -0
  108. package/lib/Types/index.d.ts +80 -0
  109. package/lib/Types/index.js +48 -0
  110. package/lib/Utils/auth-utils.d.ts +21 -0
  111. package/lib/Utils/auth-utils.js +205 -0
  112. package/lib/Utils/baileys-event-stream.d.ts +18 -0
  113. package/lib/Utils/baileys-event-stream.js +70 -0
  114. package/lib/Utils/branding.d.ts +24 -0
  115. package/lib/Utils/branding.js +209 -0
  116. package/lib/Utils/business.d.ts +29 -0
  117. package/lib/Utils/business.js +255 -0
  118. package/lib/Utils/chat-utils.d.ts +82 -0
  119. package/lib/Utils/chat-utils.js +798 -0
  120. package/lib/Utils/check-npm-version.d.ts +18 -0
  121. package/lib/Utils/check-npm-version.js +130 -0
  122. package/lib/Utils/crypto.d.ts +56 -0
  123. package/lib/Utils/crypto.js +179 -0
  124. package/lib/Utils/decode-wa-message.d.ts +41 -0
  125. package/lib/Utils/decode-wa-message.js +288 -0
  126. package/lib/Utils/event-buffer.d.ts +39 -0
  127. package/lib/Utils/event-buffer.js +565 -0
  128. package/lib/Utils/generics.d.ts +129 -0
  129. package/lib/Utils/generics.js +630 -0
  130. package/lib/Utils/history.d.ts +23 -0
  131. package/lib/Utils/history.js +110 -0
  132. package/lib/Utils/index.d.ts +22 -0
  133. package/lib/Utils/index.js +42 -0
  134. package/lib/Utils/link-preview.d.ts +23 -0
  135. package/lib/Utils/link-preview.js +120 -0
  136. package/lib/Utils/logger.d.ts +13 -0
  137. package/lib/Utils/logger.js +7 -0
  138. package/lib/Utils/lt-hash.d.ts +14 -0
  139. package/lib/Utils/lt-hash.js +58 -0
  140. package/lib/Utils/make-mutex.d.ts +9 -0
  141. package/lib/Utils/make-mutex.js +49 -0
  142. package/lib/Utils/message-retry-manager.d.ts +84 -0
  143. package/lib/Utils/message-retry-manager.js +179 -0
  144. package/lib/Utils/messages-media.d.ts +129 -0
  145. package/lib/Utils/messages-media.js +806 -0
  146. package/lib/Utils/messages.d.ts +103 -0
  147. package/lib/Utils/messages.js +1579 -0
  148. package/lib/Utils/noise-handler.d.ts +20 -0
  149. package/lib/Utils/noise-handler.js +155 -0
  150. package/lib/Utils/process-message.d.ts +49 -0
  151. package/lib/Utils/process-message.js +443 -0
  152. package/lib/Utils/signal.d.ts +42 -0
  153. package/lib/Utils/signal.js +168 -0
  154. package/lib/Utils/use-mongo-file-auth-state.d.ts +6 -0
  155. package/lib/Utils/use-mongo-file-auth-state.js +84 -0
  156. package/lib/Utils/use-multi-file-auth-state.d.ts +18 -0
  157. package/lib/Utils/use-multi-file-auth-state.js +249 -0
  158. package/lib/Utils/use-single-file-auth-state.d.ts +13 -0
  159. package/lib/Utils/use-single-file-auth-state.js +80 -0
  160. package/lib/Utils/validate-connection.d.ts +13 -0
  161. package/lib/Utils/validate-connection.js +218 -0
  162. package/lib/WABinary/constants.d.ts +30 -0
  163. package/lib/WABinary/constants.js +1316 -0
  164. package/lib/WABinary/decode.d.ts +9 -0
  165. package/lib/WABinary/decode.js +288 -0
  166. package/lib/WABinary/encode.d.ts +3 -0
  167. package/lib/WABinary/encode.js +265 -0
  168. package/lib/WABinary/generic-utils.d.ts +28 -0
  169. package/lib/WABinary/generic-utils.js +142 -0
  170. package/lib/WABinary/index.d.ts +5 -0
  171. package/lib/WABinary/index.js +25 -0
  172. package/lib/WABinary/jid-utils.d.ts +59 -0
  173. package/lib/WABinary/jid-utils.js +105 -0
  174. package/lib/WABinary/types.d.ts +22 -0
  175. package/lib/WABinary/types.js +3 -0
  176. package/lib/WAM/BinaryInfo.d.ts +16 -0
  177. package/lib/WAM/BinaryInfo.js +17 -0
  178. package/lib/WAM/constants.d.ts +47 -0
  179. package/lib/WAM/constants.js +15371 -0
  180. package/lib/WAM/encode.d.ts +3 -0
  181. package/lib/WAM/encode.js +165 -0
  182. package/lib/WAM/index.d.ts +3 -0
  183. package/lib/WAM/index.js +23 -0
  184. package/lib/WAUSync/Protocols/USyncBotProfileProtocol.d.ts +28 -0
  185. package/lib/WAUSync/Protocols/USyncBotProfileProtocol.js +69 -0
  186. package/lib/WAUSync/Protocols/USyncContactProtocol.d.ts +10 -0
  187. package/lib/WAUSync/Protocols/USyncContactProtocol.js +36 -0
  188. package/lib/WAUSync/Protocols/USyncDeviceProtocol.d.ts +26 -0
  189. package/lib/WAUSync/Protocols/USyncDeviceProtocol.js +62 -0
  190. package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.d.ts +14 -0
  191. package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.js +35 -0
  192. package/lib/WAUSync/Protocols/USyncLIDProtocol.d.ts +9 -0
  193. package/lib/WAUSync/Protocols/USyncLIDProtocol.js +30 -0
  194. package/lib/WAUSync/Protocols/USyncStatusProtocol.d.ts +14 -0
  195. package/lib/WAUSync/Protocols/USyncStatusProtocol.js +46 -0
  196. package/lib/WAUSync/Protocols/index.d.ts +6 -0
  197. package/lib/WAUSync/Protocols/index.js +26 -0
  198. package/lib/WAUSync/USyncQuery.d.ts +31 -0
  199. package/lib/WAUSync/USyncQuery.js +82 -0
  200. package/lib/WAUSync/USyncUser.d.ts +12 -0
  201. package/lib/WAUSync/USyncUser.js +30 -0
  202. package/lib/WAUSync/index.d.ts +3 -0
  203. package/lib/WAUSync/index.js +23 -0
  204. package/lib/index.d.ts +13 -0
  205. package/lib/index.js +33 -0
  206. package/package.json +120 -0
@@ -0,0 +1,205 @@
1
+ "use strict"
2
+
3
+ var __importDefault = (this && this.__importDefault) || function (mod) {
4
+ return (mod && mod.__esModule) ? mod : { "default": mod }
5
+ }
6
+
7
+ Object.defineProperty(exports, "__esModule", { value: true })
8
+
9
+ const crypto_1 = require("crypto")
10
+ const node_cache_1 = __importDefault(require("@cacheable/node-cache"))
11
+ const Defaults_1 = require("../Defaults")
12
+ const crypto_2 = require("./crypto")
13
+ const generics_1 = require("./generics")
14
+
15
+ /**
16
+ * Adds caching capability to a SignalKeyStore
17
+ * @param store the store to add caching to
18
+ * @param logger to log trace events
19
+ * @param _cache cache store to use
20
+ */
21
+ function makeCacheableSignalKeyStore(store, logger, _cache) {
22
+ const cache = _cache || new node_cache_1.default({
23
+ stdTTL: Defaults_1.DEFAULT_CACHE_TTLS.SIGNAL_STORE,
24
+ useClones: false,
25
+ deleteOnExpire: true,
26
+ })
27
+ function getUniqueId(type, id) {
28
+ return `${type}.${id}`
29
+ }
30
+ return {
31
+ async get(type, ids) {
32
+ const data = {}
33
+ const idsToFetch = []
34
+ for (const id of ids) {
35
+ const item = cache.get(getUniqueId(type, id))
36
+ if (typeof item !== 'undefined') {
37
+ data[id] = item
38
+ }
39
+ else {
40
+ idsToFetch.push(id)
41
+ }
42
+ }
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
+ cache.set(getUniqueId(type, id), item)
51
+ }
52
+ }
53
+ }
54
+ return data
55
+ },
56
+ async set(data) {
57
+ let keys = 0
58
+ for (const type in data) {
59
+ for (const id in data[type]) {
60
+ cache.set(getUniqueId(type, id), data[type][id])
61
+ keys += 1
62
+ }
63
+ }
64
+ logger?.trace({ keys }, 'updated cache')
65
+ await store.set(data)
66
+ },
67
+ async clear() {
68
+ cache.flushAll()
69
+ await store.clear?.call(store)
70
+ }
71
+ }
72
+ }
73
+
74
+ /**
75
+ * Adds DB like transaction capability (https://en.wikipedia.org/wiki/Database_transaction) to the SignalKeyStore,
76
+ * this allows batch read & write operations & improves the performance of the lib
77
+ * @param state the key store to apply this capability to
78
+ * @param logger logger to log events
79
+ * @returns SignalKeyStore with transaction capability
80
+ */
81
+ const addTransactionCapability = (state, logger, { maxCommitRetries, delayBetweenTriesMs }) => {
82
+ // number of queries made to the DB during the transaction
83
+ // only there for logging purposes
84
+ let dbQueriesInTransaction = 0
85
+ let transactionCache = {}
86
+ let mutations = {}
87
+ let transactionsInProgress = 0
88
+ return {
89
+ get: async (type, ids) => {
90
+ if (isInTransaction()) {
91
+ const dict = transactionCache[type]
92
+ const idsRequiringFetch = dict
93
+ ? ids.filter(item => typeof dict[item] === 'undefined')
94
+ : ids
95
+ // only fetch if there are any items to fetch
96
+ if (idsRequiringFetch.length) {
97
+ dbQueriesInTransaction += 1
98
+ const result = await state.get(type, idsRequiringFetch)
99
+ transactionCache[type] || (transactionCache[type] = {})
100
+ Object.assign(transactionCache[type], result)
101
+ }
102
+ return ids.reduce((dict, id) => {
103
+ const value = transactionCache[type]?.[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 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
171
+ }
172
+ }
173
+ function isInTransaction() {
174
+ return transactionsInProgress > 0
175
+ }
176
+ }
177
+
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: crypto_2.signedKeyPair(identityKey, 1),
185
+ registrationId: generics_1.generateRegistrationId(),
186
+ advSecretKey: crypto_1.randomBytes(32).toString('base64'),
187
+ processedHistoryMessages: [],
188
+ nextPreKeyId: 1,
189
+ firstUnuploadedPreKeyId: 1,
190
+ accountSyncCounter: 0,
191
+ accountSettings: {
192
+ unarchiveChats: false
193
+ },
194
+ registered: false,
195
+ pairingCode: undefined,
196
+ lastPropHash: undefined,
197
+ routingInfo: undefined
198
+ }
199
+ }
200
+
201
+ module.exports = {
202
+ makeCacheableSignalKeyStore,
203
+ addTransactionCapability,
204
+ initAuthCreds
205
+ }
@@ -0,0 +1,18 @@
1
+ import type { BaileysEventEmitter } from '../Types'
2
+
3
+ /**
4
+ * Captures events from a baileys event emitter & stores them in a file
5
+ * @param ev The event emitter to read events from
6
+ * @param filename File to save to
7
+ */
8
+ export declare const captureEventStream: (ev: BaileysEventEmitter, filename: string) => void
9
+
10
+ /**
11
+ * Read event file and emit events from there
12
+ * @param filename filename containing event data
13
+ * @param delayIntervalMs delay between each event emit
14
+ */
15
+ export declare const readAndEmitEventStream: (filename: string, delayIntervalMs?: number) => {
16
+ ev: BaileysEventEmitter
17
+ task: Promise<void>
18
+ }
@@ -0,0 +1,70 @@
1
+ "use strict"
2
+
3
+ var __importDefault = (this && this.__importDefault) || function (mod) {
4
+ return (mod && mod.__esModule) ? mod : { "default": mod }
5
+ }
6
+
7
+ Object.defineProperty(exports, "__esModule", { value: true })
8
+
9
+ const events_1 = __importDefault(require("events"))
10
+ const fs_1 = require("fs")
11
+ const promises_1 = require("fs/promises")
12
+ const readline_1 = require("readline")
13
+ const generics_1 = require("./generics")
14
+ const make_mutex_1 = require("./make-mutex")
15
+
16
+ /**
17
+ * Captures events from a baileys event emitter & stores them in a file
18
+ * @param ev The event emitter to read events from
19
+ * @param filename File to save to
20
+ */
21
+ const captureEventStream = (ev, filename) => {
22
+ const oldEmit = ev.emit
23
+ // write mutex so data is appended in order
24
+ const writeMutex = make_mutex_1.makeMutex()
25
+ // monkey patch eventemitter to capture all events
26
+ ev.emit = function (...args) {
27
+ const content = JSON.stringify({ timestamp: Date.now(), event: args[0], data: args[1] }) + '\n'
28
+ const result = oldEmit.apply(ev, args)
29
+ writeMutex.mutex(async () => {
30
+ await promises_1.writeFile(filename, content, { flag: 'a' })
31
+ })
32
+ return result
33
+ }
34
+ }
35
+
36
+ /**
37
+ * Read event file and emit events from there
38
+ * @param filename filename containing event data
39
+ * @param delayIntervalMs delay between each event emit
40
+ */
41
+ const readAndEmitEventStream = (filename, delayIntervalMs = 0) => {
42
+ const ev = new events_1.default()
43
+ const fireEvents = async () => {
44
+ // from: https://stackoverflow.com/questions/6156501/read-a-file-one-line-at-a-time-in-node-js
45
+ const fileStream = fs_1.createReadStream(filename)
46
+ const rl = readline_1.createInterface({
47
+ input: fileStream,
48
+ crlfDelay: Infinity
49
+ })
50
+ // Note: we use the crlfDelay option to recognize all instances of CR LF
51
+ // ('\r\n') in input.txt as a single line break.
52
+ for await (const line of rl) {
53
+ if (line) {
54
+ const { event, data } = JSON.parse(line)
55
+ ev.emit(event, data)
56
+ delayIntervalMs && await generics_1.delay(delayIntervalMs)
57
+ }
58
+ }
59
+ fileStream.close()
60
+ }
61
+ return {
62
+ ev,
63
+ task: fireEvents()
64
+ }
65
+ }
66
+
67
+ module.exports = {
68
+ captureEventStream,
69
+ readAndEmitEventStream
70
+ }
@@ -0,0 +1,24 @@
1
+ export interface ResolvedVersions {
2
+ baileysPackage: string;
3
+ baileysVersion: string;
4
+ wrapperPackage: string | null;
5
+ wrapperVersion: string | null;
6
+ wrapperLatest: string | null;
7
+ libsignalVersion: string | null;
8
+ }
9
+ export interface VersionUpdateInfo {
10
+ current: string;
11
+ latest: string;
12
+ hasUpdate: boolean;
13
+ source?: "npm" | "github";
14
+ }
15
+ export interface QrBrandingResult {
16
+ headerLines: string[];
17
+ footerLines: string[];
18
+ versions: ResolvedVersions;
19
+ update: VersionUpdateInfo | null;
20
+ }
21
+ export declare const getResolvedVersions: () => ResolvedVersions;
22
+ export declare const getBaileysUpdateInfo: () => Promise<VersionUpdateInfo | null>;
23
+ export declare const getQrBranding: () => Promise<QrBrandingResult>;
24
+ export declare const writeBrandingLines: (lines: string[], logger?: any) => void;
@@ -0,0 +1,209 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.writeBrandingLines = exports.getQrBranding = exports.getBaileysUpdateInfo = exports.getResolvedVersions = void 0;
5
+
6
+ const fs = require("fs");
7
+ const path = require("path");
8
+ const { checkNpmVersion } = require("./check-npm-version");
9
+
10
+ const BRAND = Object.freeze({
11
+ name: "Neelegirly 💖",
12
+ headerClaim: "Girly Glow-Up fuer WhatsApp Web",
13
+ footerClaim: "QR Love · Stable Sessions · Update Glow",
14
+ footerTagline: "Powered by Neelegirly for the cutest WhatsApp Web flow"
15
+ });
16
+
17
+ const ANSI = Object.freeze({
18
+ reset: "\x1b[0m",
19
+ bold: "\x1b[1m",
20
+ cyan: "\x1b[36m",
21
+ magenta: "\x1b[35m",
22
+ yellow: "\x1b[33m",
23
+ gray: "\x1b[90m"
24
+ });
25
+
26
+ const color = (value, ansiColor) => `${ansiColor}${value}${ANSI.reset}`;
27
+
28
+ let packageMetaCache = null;
29
+ let updateCheckPromise = null;
30
+ let updateInfoCache = null;
31
+ let hasShownBaileysUpdateHint = false;
32
+ let hasShownWrapperUpdateHint = false;
33
+
34
+ const readJson = (filePath) => {
35
+ try {
36
+ const content = fs.readFileSync(filePath, "utf8");
37
+ return JSON.parse(content);
38
+ } catch (_error) {
39
+ return null;
40
+ }
41
+ };
42
+
43
+ const readBaileysMeta = () => {
44
+ if (packageMetaCache) {
45
+ return packageMetaCache;
46
+ }
47
+
48
+ const filePath = path.join(__dirname, "..", "..", "package.json");
49
+ const parsed = readJson(filePath) || {};
50
+
51
+ packageMetaCache = {
52
+ name: parsed.name || "@neelegirly/baileys",
53
+ version: parsed.version || process.env.npm_package_version || "0.0.0"
54
+ };
55
+
56
+ return packageMetaCache;
57
+ };
58
+
59
+ const safeRequireVersion = (pkg) => {
60
+ try {
61
+ const resolved = require.resolve(`${pkg}/package.json`, { paths: [process.cwd(), __dirname] });
62
+ const parsed = readJson(resolved);
63
+ return parsed?.version ? String(parsed.version) : null;
64
+ } catch (_error) {
65
+ return null;
66
+ }
67
+ };
68
+
69
+ const getResolvedVersions = () => {
70
+ const meta = readBaileysMeta();
71
+ const wrapperPackage = process.env.NEELEGIRLY_WRAPPER_PACKAGE || "";
72
+ const wrapperVersion = process.env.NEELEGIRLY_WRAPPER_VERSION || "";
73
+ const libsignalVersion = safeRequireVersion("@neelegirly/libsignal") || "";
74
+
75
+ return {
76
+ baileysPackage: meta.name,
77
+ baileysVersion: meta.version,
78
+ wrapperPackage: wrapperPackage || null,
79
+ wrapperVersion: wrapperVersion || null,
80
+ wrapperLatest: process.env.NEELEGIRLY_WRAPPER_UPDATE || null,
81
+ libsignalVersion: libsignalVersion || null
82
+ };
83
+ };
84
+
85
+ exports.getResolvedVersions = getResolvedVersions;
86
+
87
+ const getBaileysUpdateInfo = async () => {
88
+ if (updateInfoCache) {
89
+ return updateInfoCache;
90
+ }
91
+
92
+ if (!updateCheckPromise) {
93
+ const { baileysPackage, baileysVersion } = getResolvedVersions();
94
+ updateCheckPromise = checkNpmVersion(baileysPackage, baileysVersion, {
95
+ githubRepo: "neelegirly/baileys",
96
+ timeoutMs: 5000
97
+ }).catch(() => null);
98
+ }
99
+
100
+ updateInfoCache = await updateCheckPromise;
101
+ return updateInfoCache;
102
+ };
103
+
104
+ exports.getBaileysUpdateInfo = getBaileysUpdateInfo;
105
+
106
+ const buildDivider = () => color("============================================================", ANSI.gray);
107
+
108
+ const getQrBranding = async () => {
109
+ const versions = getResolvedVersions();
110
+ const update = await getBaileysUpdateInfo();
111
+ const shouldShowBaileysUpdateHint = Boolean(update?.hasUpdate) && !hasShownBaileysUpdateHint;
112
+ const shouldShowWrapperUpdateHint =
113
+ Boolean(versions.wrapperPackage && versions.wrapperLatest) && !hasShownWrapperUpdateHint;
114
+
115
+ const headerLines = [
116
+ buildDivider(),
117
+ color(`${ANSI.bold}${BRAND.name}${ANSI.reset} | ${BRAND.headerClaim}`, ANSI.magenta),
118
+ color(`Neelegirly Glow Version: ${versions.baileysVersion}`, ANSI.cyan),
119
+ color(`Paket: ${versions.baileysPackage} v${versions.baileysVersion}`, ANSI.cyan)
120
+ ];
121
+
122
+ if (versions.wrapperPackage && versions.wrapperVersion) {
123
+ headerLines.push(
124
+ color(`Wrapper: ${versions.wrapperPackage} v${versions.wrapperVersion}`, ANSI.cyan)
125
+ );
126
+ }
127
+
128
+ if (versions.libsignalVersion) {
129
+ headerLines.push(color(`Signal-Core: @neelegirly/libsignal v${versions.libsignalVersion}`, ANSI.cyan));
130
+ }
131
+
132
+ if (shouldShowBaileysUpdateHint) {
133
+ const source = update.source || "npm";
134
+ headerLines.push(
135
+ color(
136
+ `Update verfuegbar (${versions.baileysPackage}): ${update.latest} | Quelle: ${source}`,
137
+ ANSI.yellow
138
+ )
139
+ );
140
+ }
141
+
142
+ if (shouldShowWrapperUpdateHint) {
143
+ headerLines.push(
144
+ color(
145
+ `Update verfuegbar (${versions.wrapperPackage}): ${versions.wrapperLatest}`,
146
+ ANSI.yellow
147
+ )
148
+ );
149
+ }
150
+
151
+ const footerLines = [
152
+ color(`💖 ${BRAND.footerClaim}`, ANSI.magenta),
153
+ color(`Powered by ${BRAND.name}`, ANSI.cyan),
154
+ color(BRAND.footerTagline, ANSI.cyan),
155
+ color(`Aktive Basis: ${versions.baileysPackage} v${versions.baileysVersion}`, ANSI.gray)
156
+ ];
157
+
158
+ if (shouldShowBaileysUpdateHint) {
159
+ footerLines.push(
160
+ color(`Du nutzt ${update.current}, neu ist ${update.latest}.`, ANSI.yellow)
161
+ );
162
+ }
163
+
164
+ if (shouldShowWrapperUpdateHint) {
165
+ footerLines.push(
166
+ color(
167
+ `Du nutzt ${versions.wrapperVersion} (${versions.wrapperPackage}), neu ist ${versions.wrapperLatest}.`,
168
+ ANSI.yellow
169
+ )
170
+ );
171
+ }
172
+
173
+ if (shouldShowBaileysUpdateHint) {
174
+ hasShownBaileysUpdateHint = true;
175
+ }
176
+ if (shouldShowWrapperUpdateHint) {
177
+ hasShownWrapperUpdateHint = true;
178
+ }
179
+
180
+ footerLines.push(buildDivider());
181
+
182
+ return {
183
+ headerLines,
184
+ footerLines,
185
+ versions,
186
+ update
187
+ };
188
+ };
189
+
190
+ exports.getQrBranding = getQrBranding;
191
+
192
+ const writeBrandingLines = (lines, logger) => {
193
+ if (!Array.isArray(lines) || !lines.length) {
194
+ return;
195
+ }
196
+
197
+ for (const line of lines) {
198
+ if (!line) continue;
199
+
200
+ if (logger && typeof logger.info === "function" && logger.level && logger.level !== "silent") {
201
+ logger.info(line);
202
+ continue;
203
+ }
204
+
205
+ console.log(line);
206
+ }
207
+ };
208
+
209
+ exports.writeBrandingLines = writeBrandingLines;
@@ -0,0 +1,29 @@
1
+ import { CatalogCollection, OrderDetails, Product, ProductCreate, ProductUpdate, WAMediaUpload, WAMediaUploadFunction } from '../Types'
2
+ import { BinaryNode } from '../WABinary'
3
+
4
+ export declare const parseCatalogNode: (node: BinaryNode) => {
5
+ products: Product[]
6
+ nextPageCursor: string | undefined
7
+ }
8
+
9
+ export declare const parseCollectionsNode: (node: BinaryNode) => {
10
+ collections: CatalogCollection[]
11
+ }
12
+
13
+ export declare const parseOrderDetailsNode: (node: BinaryNode) => OrderDetails
14
+
15
+ export declare const toProductNode: (productId: string | undefined, product: ProductCreate | ProductUpdate) => BinaryNode
16
+
17
+ export declare const parseProductNode: (productNode: BinaryNode) => Product
18
+
19
+ /**
20
+ * Uploads images not already uploaded to WA's servers
21
+ */
22
+ export declare function uploadingNecessaryImagesOfProduct<T extends ProductUpdate | ProductCreate>(product: T, waUploadToServer: WAMediaUploadFunction, timeoutMs?: number): Promise<T>
23
+
24
+ /**
25
+ * Uploads images not already uploaded to WA's servers
26
+ */
27
+ export declare const uploadingNecessaryImages: (images: WAMediaUpload[], waUploadToServer: WAMediaUploadFunction, timeoutMs?: number) => Promise<{
28
+ url: string
29
+ }[]>