@neelegirl/baileys 2.0.1 → 2.0.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -5,7 +5,7 @@
5
5
  ### *Die WhatsApp Web API, die alles kann*
6
6
  ### *Smart Queue · QR-Code · Message ID · LID · TypeScript*
7
7
 
8
- [![Version](https://img.shields.io/badge/Version-2.0.0-ff69b4?style=for-the-badge&logo=github)](https://github.com/neelegirl/baileys)
8
+ [![Version](https://img.shields.io/badge/Version-2.0.2-ff69b4?style=for-the-badge&logo=github)](https://github.com/neelegirl/baileys)
9
9
  [![Baileys API](https://img.shields.io/badge/Baileys_API-1.7.2-9b59b6?style=for-the-badge)](https://github.com/WhiskeySockets/Baileys)
10
10
  [![npm](https://img.shields.io/npm/v/@neelegirl/baileys?style=for-the-badge&color=ff69b4&logo=npm)](https://www.npmjs.com/package/@neelegirl/baileys)
11
11
  [![Downloads](https://img.shields.io/npm/dw/@neelegirl/baileys?style=for-the-badge&color=ff69b4&logo=npm)](https://www.npmjs.com/package/@neelegirl/baileys)
@@ -20,9 +20,9 @@
20
20
 
21
21
  | 📦 Paket | 🎯 Baileys API | ✨ Highlights |
22
22
  |----------|----------------|----------------|
23
- | **@neelegirl/baileys v2.0.0** | **1.7.2** | Upstream-Updates · QR-Code · Message ID unverändert |
23
+ | **@neelegirl/baileys v2.0.2** | **1.7.2** | Upstream-Updates · QR-Code · Message ID · Update-Check von npm |
24
24
 
25
- **✨ v2.0.0** · Upstream aus Backup Baileys · Kompatibel mit Baileys **1.7.2** · QR & Message ID bleiben wie gewohnt
25
+ **✨ v2.0.2** · README Glow-Up · Kompatibel mit Baileys **1.7.2** · QR & Message ID unverändert · Update-Prüfung via npm-Registry
26
26
 
27
27
  [**Installation**](#-installation) · [**Quickstart**](#-quickstart-guide) · [**Features**](#-neue-features-in-version-200) · [**Dokumentation**](#-dokumentation) · [**Support**](#-support--community)
28
28
 
@@ -35,7 +35,7 @@
35
35
  - [✨ Warum @neelegirl/baileys?](#-warum-neelegirlbaileys)
36
36
  - [🚀 Installation](#-installation)
37
37
  - [📖 Quickstart Guide](#-quickstart-guide)
38
- - [✨ Neue Features in Version 2.0.0](#-neue-features-in-version-200)
38
+ - [✨ Neue Features in Version 2.0.2](#-neue-features-in-version-202)
39
39
  - [💡 Grundlegende Verwendung](#-grundlegende-verwendung)
40
40
  - [🎯 Erweiterte Features](#-erweiterte-features)
41
41
  - [📚 Dokumentation](#-dokumentation)
@@ -188,10 +188,10 @@ startBot().catch(console.error)
188
188
 
189
189
  ---
190
190
 
191
- ## ✨ Neue Features in Version 2.0.0
191
+ ## ✨ Neue Features in Version 2.0.2
192
192
 
193
193
  ### 🆕 **Was ist neu?**
194
- **Kompatibel mit Baileys API 1.7.2** · Upstream aus **Backup Baileys** integriert · **Message ID & QR-Code unverändert**
194
+ **Kompatibel mit Baileys API 1.7.2** · **Update-Check von npm-Registry** (1× pro Prozess) · **Message ID & QR-Code unverändert**
195
195
 
196
196
  <div align="center">
197
197
 
@@ -860,16 +860,23 @@ const sock = makeWASocket({
860
860
 
861
861
  ## 📝 Changelog
862
862
 
863
- ### Version 2.0.0 (Aktuell) 🎉
863
+ ### Version 2.0.2 (Aktuell) 🎉
864
864
 
865
- - 🔄 **Upstream aus Backup Baileys** – validate-connection, Defaults & Pairing angeglichen
866
- - 🔐 **LID in Pairing** – lid in configureSuccessfulPairing, me.lid, createSignalIdentity(lid)
867
- - 📤 **historySyncConfig** Vollständiges DeviceProps in generateRegistrationNode
868
- - 🌐 **getWebInfo** Desktop-Check für syncFullHistory
869
- - ⚙️ **Defaults** enableAutoSessionRecreation, enableRecentMessageCache, shouldSyncHistoryMessage
870
- - 📖 **README Glow-Up** – Version 2.0.0, schick & aktuell
871
- - 🎨 **QR-Code** & **Message ID** – unverändert (wie gewünscht)
872
- - 🔄 **WhatsApp-Version** [2, 3000, 1032141294]
865
+ - 📖 **README Glow-Up** – Version 2.0.2, Badges & Changelog
866
+ - 🔔 **Update-Check** – Liest Version von **npm-Registry** (registry.npmjs.org), nur 1× pro Prozess
867
+ - Semver-Vergleich für „Update verfügbar“ nur bei wirklich neuerer Version
868
+ - 🎨 **QR-Code** & **Message ID** – unverändert
869
+ - 🔄 Kompatibel mit **Baileys API 1.7.2**
870
+
871
+ ### Version 2.0.1
872
+
873
+ - 🔄 Upstream aus Backup Baileys · LID in Pairing · historySyncConfig · getWebInfo · Defaults
874
+
875
+ ### Version 2.0.0
876
+
877
+ - 🔄 Upstream aus Backup Baileys – validate-connection, Defaults & Pairing angeglichen
878
+ - 🔐 LID in Pairing · 📤 historySyncConfig · 🌐 getWebInfo · ⚙️ Defaults
879
+ - 🎨 QR-Code & Message ID unverändert · WhatsApp-Version [2, 3000, 1032141294]
873
880
 
874
881
  ### Version 1.1.2
875
882
 
@@ -0,0 +1,3 @@
1
+ yarn pbjs -t static-module --no-beautify -w es6 --no-bundle --no-delimited --no-verify --no-comments -o ./index.js ./WAProto.proto;
2
+ yarn pbjs -t static-module --no-beautify -w es6 --no-bundle --no-delimited --no-verify ./WAProto.proto | yarn pbts --no-comments -o ./index.d.ts -;
3
+ node ./fix-imports.js
@@ -0,0 +1,81 @@
1
+ import { readFileSync, writeFileSync } from 'fs';
2
+ import { exit } from 'process';
3
+
4
+ const filePath = './index.js'
5
+
6
+ try {
7
+ let content = readFileSync(filePath, 'utf8')
8
+
9
+ content = content.replace(/import \* as (\$protobuf) from/g, 'import $1 from')
10
+ content = content.replace(/(['"])protobufjs\/minimal(['"])/g, '$1protobufjs/minimal.js$2')
11
+
12
+ const marker = 'const $root = $protobuf.roots["default"] || ($protobuf.roots["default"] = {});\n\n'
13
+ const longToStringHelper =
14
+ 'function longToString(value, unsigned) {\n' +
15
+ '\tif (typeof value === "string") {\n' +
16
+ '\t\treturn value;\n' +
17
+ '\t}\n' +
18
+ '\tif (typeof value === "number") {\n' +
19
+ '\t\treturn String(value);\n' +
20
+ '\t}\n' +
21
+ '\tif (!$util.Long) {\n' +
22
+ '\t\treturn String(value);\n' +
23
+ '\t}\n' +
24
+ '\tconst normalized = $util.Long.fromValue(value);\n' +
25
+ '\tconst prepared = unsigned && normalized && typeof normalized.toUnsigned === "function"\n' +
26
+ '\t\t? normalized.toUnsigned()\n' +
27
+ '\t\t: normalized;\n' +
28
+ '\treturn prepared.toString();\n' +
29
+ '}\n\n'
30
+ const longToNumberHelper =
31
+ 'function longToNumber(value, unsigned) {\n' +
32
+ '\tif (typeof value === "number") {\n' +
33
+ '\t\treturn value;\n' +
34
+ '\t}\n' +
35
+ '\tif (typeof value === "string") {\n' +
36
+ '\t\tconst numeric = Number(value);\n' +
37
+ '\t\treturn numeric;\n' +
38
+ '\t}\n' +
39
+ '\tif (!$util.Long) {\n' +
40
+ '\t\treturn Number(value);\n' +
41
+ '\t}\n' +
42
+ '\tconst normalized = $util.Long.fromValue(value);\n' +
43
+ '\tconst prepared = unsigned && normalized && typeof normalized.toUnsigned === "function"\n' +
44
+ '\t\t? normalized.toUnsigned()\n' +
45
+ '\t\t: typeof normalized.toSigned === "function"\n' +
46
+ '\t\t\t? normalized.toSigned()\n' +
47
+ '\t\t\t: normalized;\n' +
48
+ '\treturn prepared.toNumber();\n' +
49
+ '}\n\n'
50
+
51
+ if (!content.includes('function longToString(')) {
52
+ const markerIndex = content.indexOf(marker)
53
+ if (markerIndex === -1) {
54
+ throw new Error('Unable to inject Long helpers: marker not found in WAProto index output')
55
+ }
56
+
57
+ content = content.replace(marker, `${marker}${longToStringHelper}${longToNumberHelper}`)
58
+ } else {
59
+ const longToStringRegex = /function longToString\(value, unsigned\) {\n[\s\S]*?\n}\n\n/
60
+ const longToNumberRegex = /function longToNumber\(value, unsigned\) {\n[\s\S]*?\n}\n\n/
61
+
62
+ if (!longToStringRegex.test(content) || !longToNumberRegex.test(content)) {
63
+ throw new Error('Unable to update Long helpers: existing definitions not found')
64
+ }
65
+
66
+ content = content.replace(longToStringRegex, longToStringHelper)
67
+ content = content.replace(longToNumberRegex, longToNumberHelper)
68
+ }
69
+
70
+ const longPattern = /([ \t]+d\.(\w+) = )o\.longs === String \? \$util\.Long\.prototype\.toString\.call\(m\.\2\) : o\.longs === Number \? new \$util\.LongBits\(m\.\2\.low >>> 0, m\.\2\.high >>> 0\)\.toNumber\((true)?\) : m\.\2;/g
71
+ content = content.replace(longPattern, (_match, prefix, field, unsignedFlag) => {
72
+ const unsignedArg = unsignedFlag ? ', true' : ''
73
+ return `${prefix}o.longs === String ? longToString(m.${field}${unsignedArg}) : o.longs === Number ? longToNumber(m.${field}${unsignedArg}) : m.${field};`
74
+ })
75
+
76
+ writeFileSync(filePath, content, 'utf8')
77
+ console.log(`✅ Fixed imports in ${filePath}`)
78
+ } catch (error) {
79
+ console.error(`❌ Error fixing imports: ${error.message}`)
80
+ exit(1)
81
+ }
@@ -208,7 +208,7 @@ const uploadingNecessaryImages = async (images, waUploadToServer, timeoutMs = 30
208
208
  }
209
209
  const { stream } = await messages_media_1.getStream(img)
210
210
  const hasher = crypto_1.createHash('sha256')
211
- const filePath = path_1.join(os_1.tmpdir(), 'img' + generics_1.generateMessageID())
211
+ const filePath = path_1.join(process.cwd(), 'tmp', 'img' + generics_1.generateMessageID())
212
212
  const encFileWriteStream = fs_1.createWriteStream(filePath)
213
213
  for await (const block of stream) {
214
214
  hasher.update(block)
@@ -348,7 +348,7 @@ const prepareStream = async (media, mediaType, { logger, saveOriginalFileIfRequi
348
348
  const { stream, type } = await getStream(media, opts)
349
349
  logger?.debug('fetched media stream')
350
350
 
351
- const encFilePath = path_1.join(os_1.tmpdir(), mediaType + generics_1.generateMessageID() + '-plain')
351
+ const encFilePath = path_1.join(process.cwd(), 'tmp', mediaType + generics_1.generateMessageID() + '-plain')
352
352
  const encFileWriteStream = fs_1.createWriteStream(encFilePath)
353
353
 
354
354
  let originalFilePath
@@ -357,7 +357,7 @@ const prepareStream = async (media, mediaType, { logger, saveOriginalFileIfRequi
357
357
  if (type === 'file') {
358
358
  originalFilePath = media.url.toString()
359
359
  } else if (saveOriginalFileIfRequired) {
360
- originalFilePath = path_1.join(os_1.tmpdir(), mediaType + generics_1.generateMessageID() + '-original')
360
+ originalFilePath = path_1.join(process.cwd(), 'tmp', mediaType + generics_1.generateMessageID() + '-original')
361
361
  originalFileStream = fs_1.createWriteStream(originalFilePath)
362
362
  }
363
363
 
@@ -423,12 +423,12 @@ const encryptedStream = async (media, mediaType, { logger, saveOriginalFileIfReq
423
423
  logger?.debug('fetched media stream')
424
424
  const mediaKey = Crypto.randomBytes(32)
425
425
  const { cipherKey, iv, macKey } = await getMediaKeys(mediaKey, mediaType)
426
- const encFilePath = path_1.join(os_1.tmpdir(), mediaType + generics_1.generateMessageID() + '-enc')
426
+ const encFilePath = path_1.join(process.cwd(), 'tmp', mediaType + generics_1.generateMessageID() + '-enc')
427
427
  const encFileWriteStream = fs_1.createWriteStream(encFilePath)
428
428
  let originalFileStream
429
429
  let originalFilePath
430
430
  if (saveOriginalFileIfRequired) {
431
- originalFilePath = path_1.join(os_1.tmpdir(), mediaType + generics_1.generateMessageID() + '-original')
431
+ originalFilePath = path_1.join(process.cwd(), 'tmp', mediaType + generics_1.generateMessageID() + '-original')
432
432
  originalFileStream = fs_1.createWriteStream(originalFilePath)
433
433
  }
434
434
  let fileLength = 0
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@neelegirl/baileys",
3
- "version": "2.0.1",
3
+ "version": "2.0.3",
4
4
  "description": "WhatsApp API for wa-api, a multi-device WhatsApp Web API client",
5
5
  "keywords": [
6
6
  "whatsapp",