@elrayyxml/baileys 1.0.6 → 1.0.7

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 (100) hide show
  1. package/README.md +58 -26
  2. package/lib/Defaults/baileys-version.json +1 -1
  3. package/lib/Defaults/index.d.ts +51 -0
  4. package/lib/Defaults/index.js +4 -0
  5. package/lib/Signal/Group/ciphertext-message.d.ts +9 -0
  6. package/lib/Signal/Group/group-session-builder.d.ts +14 -0
  7. package/lib/Signal/Group/group_cipher.d.ts +17 -0
  8. package/lib/Signal/Group/index.d.ts +11 -0
  9. package/lib/Signal/Group/keyhelper.d.ts +10 -0
  10. package/lib/Signal/Group/queue-job.d.ts +1 -0
  11. package/lib/Signal/Group/sender-chain-key.d.ts +13 -0
  12. package/lib/Signal/Group/sender-key-distribution-message.d.ts +16 -0
  13. package/lib/Signal/Group/sender-key-message.d.ts +18 -0
  14. package/lib/Signal/Group/sender-key-name.d.ts +17 -0
  15. package/lib/Signal/Group/sender-key-record.d.ts +30 -0
  16. package/lib/Signal/Group/sender-key-state.d.ts +38 -0
  17. package/lib/Signal/Group/sender-message-key.d.ts +11 -0
  18. package/lib/Signal/libsignal.d.ts +3 -0
  19. package/lib/Socket/Client/index.d.ts +2 -0
  20. package/lib/Socket/Client/types.d.ts +16 -0
  21. package/lib/Socket/Client/websocket.d.ts +13 -0
  22. package/lib/Socket/business.d.ts +172 -0
  23. package/lib/Socket/chats.d.ts +82 -0
  24. package/lib/Socket/groups.d.ts +124 -0
  25. package/lib/Socket/index.d.ts +172 -0
  26. package/lib/Socket/messages-recv.d.ts +161 -0
  27. package/lib/Socket/messages-send.d.ts +151 -0
  28. package/lib/Socket/messages-send.js +8 -36
  29. package/lib/Socket/newsletter.d.ts +136 -0
  30. package/lib/Socket/newsletter.js +5 -1
  31. package/lib/Socket/socket.d.ts +43 -0
  32. package/lib/Socket/usync.d.ts +36 -0
  33. package/lib/Store/index.d.ts +2 -0
  34. package/lib/Store/make-in-memory-store.d.ts +118 -0
  35. package/lib/Store/make-ordered-dictionary.d.ts +13 -0
  36. package/lib/Store/object-repository.d.ts +10 -0
  37. package/lib/Types/Auth.d.ts +103 -0
  38. package/lib/Types/Call.d.ts +13 -0
  39. package/lib/Types/Chat.d.ts +109 -0
  40. package/lib/Types/Contact.d.ts +23 -0
  41. package/lib/Types/Events.d.ts +199 -0
  42. package/lib/Types/GroupMetadata.d.ts +64 -0
  43. package/lib/Types/Label.d.ts +35 -0
  44. package/lib/Types/LabelAssociation.d.ts +29 -0
  45. package/lib/Types/Message.d.ts +400 -0
  46. package/lib/Types/Newsletter.d.ts +79 -0
  47. package/lib/Types/Product.d.ts +78 -0
  48. package/lib/Types/Signal.d.ts +57 -0
  49. package/lib/Types/Socket.d.ts +119 -0
  50. package/lib/Types/State.d.ts +27 -0
  51. package/lib/Types/USync.d.ts +25 -0
  52. package/lib/Types/index.d.ts +64 -0
  53. package/lib/Utils/auth-utils.d.ts +18 -0
  54. package/lib/Utils/baileys-event-stream.d.ts +16 -0
  55. package/lib/Utils/business.d.ts +22 -0
  56. package/lib/Utils/chat-utils.d.ts +70 -0
  57. package/lib/Utils/crypto.d.ts +40 -0
  58. package/lib/Utils/decode-wa-message.d.ts +35 -0
  59. package/lib/Utils/event-buffer.d.ts +35 -0
  60. package/lib/Utils/generics.d.ts +89 -0
  61. package/lib/Utils/generics.js +0 -1
  62. package/lib/Utils/history.d.ts +19 -0
  63. package/lib/Utils/index.d.ts +17 -0
  64. package/lib/Utils/link-preview.d.ts +21 -0
  65. package/lib/Utils/logger.d.ts +11 -0
  66. package/lib/Utils/lt-hash.d.ts +12 -0
  67. package/lib/Utils/make-mutex.d.ts +7 -0
  68. package/lib/Utils/messages-media.d.ts +120 -0
  69. package/lib/Utils/messages.d.ts +75 -0
  70. package/lib/Utils/messages.js +305 -35
  71. package/lib/Utils/noise-handler.d.ts +19 -0
  72. package/lib/Utils/process-message.d.ts +42 -0
  73. package/lib/Utils/signal.d.ts +33 -0
  74. package/lib/Utils/use-multi-file-auth-state.d.ts +12 -0
  75. package/lib/Utils/validate-connection.d.ts +10 -0
  76. package/lib/WABinary/constants.d.ts +27 -0
  77. package/lib/WABinary/decode.d.ts +6 -0
  78. package/lib/WABinary/encode.d.ts +2 -0
  79. package/lib/WABinary/generic-utils.d.ts +14 -0
  80. package/lib/WABinary/generic-utils.js +1 -9
  81. package/lib/WABinary/index.d.ts +5 -0
  82. package/lib/WABinary/jid-utils.d.ts +36 -0
  83. package/lib/WABinary/types.d.ts +18 -0
  84. package/lib/WAM/BinaryInfo.d.ts +8 -0
  85. package/lib/WAM/constants.d.ts +38 -0
  86. package/lib/WAM/encode.d.ts +2 -0
  87. package/lib/WAM/index.d.ts +3 -0
  88. package/lib/WAUSync/Protocols/USyncContactProtocol.d.ts +9 -0
  89. package/lib/WAUSync/Protocols/USyncDeviceProtocol.d.ts +22 -0
  90. package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.d.ts +12 -0
  91. package/lib/WAUSync/Protocols/USyncStatusProtocol.d.ts +12 -0
  92. package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.d.ts +25 -0
  93. package/lib/WAUSync/Protocols/UsyncLIDProtocol.d.ts +8 -0
  94. package/lib/WAUSync/Protocols/index.d.ts +4 -0
  95. package/lib/WAUSync/USyncQuery.d.ts +28 -0
  96. package/lib/WAUSync/USyncUser.d.ts +12 -0
  97. package/lib/WAUSync/index.d.ts +3 -0
  98. package/lib/index.d.ts +13 -0
  99. package/lib/index.js +4 -1
  100. package/package.json +14 -13
package/README.md CHANGED
@@ -2,7 +2,7 @@
2
2
 
3
3
  <div align="center">
4
4
 
5
- ### @elrayyxml/baileys
5
+ ## @elrayyxml/baileys
6
6
 
7
7
  </div>
8
8
 
@@ -12,7 +12,7 @@
12
12
 
13
13
  <p><em>Baileys Modified</em></p>
14
14
 
15
- <img src="https://files.catbox.moe/7m4cuw.jpg" width="300" alt="Cover Banner" />
15
+ <img src="https://files.catbox.moe/ehdrm3.jpg" width="300" alt="Cover Banner" />
16
16
 
17
17
  </div>
18
18
 
@@ -24,28 +24,12 @@
24
24
  [![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://opensource.org/licenses/MIT)
25
25
  [![WhatsApp](https://img.shields.io/badge/WhatsApp-API-green.svg?logo=whatsapp)](https://whatsapp.com)
26
26
  [![Node.js](https://img.shields.io/badge/Node.js-20%2B-green.svg)](https://nodejs.org)
27
- [![npm downloads](https://img.shields.io/npm/dt/@elrayyxml/baileys.svg?color=blueviolet&label=Downloads&logo=npm)](https://www.npmjs.com/package/@elrayyxml/baileys)
28
- [![REST API](https://img.shields.io/badge/REST_API-green.svg)](https://api.elrayyxml.web.id)
27
+ [![npm downloads](https://img.shields.io/npm/dt/@elrayyxml/baileys.svg?color=blueviolet&label=downloads&logo=npm)](https://www.npmjs.com/package/@elrayyxml/baileys)
28
+ [![REST API](https://img.shields.io/badge/REST_API-green.svg)](https://api.nexray.web.id)
29
29
 
30
30
  </div>
31
31
 
32
- ### Installation
33
-
34
- ```bash
35
- npm install @elrayyxml/baileys
36
- # or
37
- yarn add @elrayyxml/baileys
38
- ```
39
-
40
- ### `package.json` Fork Baileys
41
-
42
- ```json
43
- "dependencies": {
44
- "baileys": "npm:@elrayyxml/baileys"
45
- }
46
- ```
47
-
48
- ### Contact
32
+ ## Contact
49
33
 
50
34
  <div align="center">
51
35
 
@@ -56,7 +40,7 @@ yarn add @elrayyxml/baileys
56
40
 
57
41
  </div>
58
42
 
59
- ### Official Channel
43
+ ## Official Channel
60
44
 
61
45
  <div align="center">
62
46
  <a href="https://whatsapp.com/channel/0029Vb69z8n1dAvztHQTDu3r">
@@ -66,15 +50,24 @@ yarn add @elrayyxml/baileys
66
50
  </div>
67
51
 
68
52
 
69
- ## Example
70
53
 
71
- ## Install
54
+ ## Installation
72
55
 
73
56
  Use the stable version:
74
- ```
57
+ ```bash
58
+ npm install @elrayyxml/baileys
59
+ # or
75
60
  yarn add @elrayyxml/baileys
76
61
  ```
77
62
 
63
+ ### `package.json` Fork Baileys
64
+
65
+ ```json
66
+ "dependencies": {
67
+ "baileys": "npm:@elrayyxml/baileys"
68
+ }
69
+ ```
70
+
78
71
  Then import your code using:
79
72
  ```ts
80
73
  import makeWASocket from '@elrayyxml/baileys'
@@ -751,7 +744,7 @@ await sock.sendMessage(
751
744
  name: 'Hiii',
752
745
  publisher: 'By Itsockchann',
753
746
  description: 'Hello',
754
- cover: Buffer, // Image buffer
747
+ cover: { url: 'https://example.com/cover.webp' }, // Buffer
755
748
  stickers: [{
756
749
  sticker: { url: 'https://example.com/1234kjd.webp' },
757
750
  emojis: ['❤'], // optional
@@ -1400,6 +1393,45 @@ await sock.sendMessage(
1400
1393
  }
1401
1394
  )
1402
1395
  ```
1396
+
1397
+ ### Group Status Message
1398
+ ```ts
1399
+ // Text
1400
+ await sock.groupStatusMessage(jid,
1401
+ {
1402
+ text: 'Hello Everyone :3',
1403
+ font: 2, // optional
1404
+ textColor: 'FF0000', // optional
1405
+ backgroundColor: '#000000' // optional
1406
+ }
1407
+ )
1408
+
1409
+ // Image
1410
+ await sock.groupStatusMessage(jid,
1411
+ {
1412
+ Image: { url: 'https://example.com/ruriooe.jpg' }, or image buffer
1413
+ caption: 'Hello Everyone :3' // optional
1414
+ }
1415
+ )
1416
+
1417
+ // Video
1418
+ await sock.groupStatusMessage(jid,
1419
+ {
1420
+ video: { url: 'https://example.com/ruriooe.mp4' }, or video buffer
1421
+ caption: 'Hello Everyone :3' // optional
1422
+ }
1423
+ )
1424
+
1425
+ // Audio
1426
+ await sock.groupStatusMessage(jid,
1427
+ {
1428
+ audio: { url: 'https://example.com/ruriooe.mp3' }, or audio buffer
1429
+ backgroundColor: '#000000', // optional
1430
+ mimetype: 'audio/mp4',
1431
+ ppt: true
1432
+ },
1433
+ )
1434
+ ```
1403
1435
 
1404
1436
  ### Status Mentions Message
1405
1437
  ```ts
@@ -1,3 +1,3 @@
1
1
  {
2
- "version": [2, 3000, 1027934701]
2
+ "version": [2, 3000, 1035194821]
3
3
  }
@@ -0,0 +1,51 @@
1
+ import { proto } from '../../WAProto';
2
+ import type { MediaType, SocketConfig } from '../Types';
3
+ export declare const UNAUTHORIZED_CODES: number[];
4
+ export declare const DEFAULT_ORIGIN = "https://web.whatsapp.com";
5
+ export declare const DEF_CALLBACK_PREFIX = "CB:";
6
+ export declare const DEF_TAG_PREFIX = "TAG:";
7
+ export declare const PHONE_CONNECTION_CB = "CB:Pong";
8
+ export declare const WA_DEFAULT_EPHEMERAL: number;
9
+ export declare const NOISE_MODE = "Noise_XX_25519_AESGCM_SHA256\0\0\0\0";
10
+ export declare const DICT_VERSION = 3;
11
+ export declare const KEY_BUNDLE_TYPE: Buffer<ArrayBuffer>;
12
+ export declare const NOISE_WA_HEADER: Buffer<ArrayBuffer>;
13
+ /** from: https://stackoverflow.com/questions/3809401/what-is-a-good-regular-expression-to-match-a-url */
14
+ export declare const URL_REGEX: RegExp;
15
+ export declare const WA_CERT_DETAILS: {
16
+ SERIAL: number;
17
+ };
18
+ export declare const PROCESSABLE_HISTORY_TYPES: proto.Message.HistorySyncNotification.HistorySyncType[];
19
+ export declare const DEFAULT_CONNECTION_CONFIG: SocketConfig;
20
+ export declare const MEDIA_PATH_MAP: {
21
+ [T in MediaType]?: string;
22
+ };
23
+ export declare const MEDIA_HKDF_KEY_MAPPING: {
24
+ audio: string;
25
+ document: string;
26
+ gif: string;
27
+ image: string;
28
+ ppic: string;
29
+ product: string;
30
+ ptt: string;
31
+ sticker: string;
32
+ video: string;
33
+ 'thumbnail-document': string;
34
+ 'thumbnail-image': string;
35
+ 'thumbnail-video': string;
36
+ 'thumbnail-link': string;
37
+ 'md-msg-hist': string;
38
+ 'md-app-state': string;
39
+ 'product-catalog-image': string;
40
+ 'payment-bg-image': string;
41
+ ptv: string;
42
+ };
43
+ export declare const MEDIA_KEYS: MediaType[];
44
+ export declare const MIN_PREKEY_COUNT = 5;
45
+ export declare const INITIAL_PREKEY_COUNT = 30;
46
+ export declare const DEFAULT_CACHE_TTLS: {
47
+ SIGNAL_STORE: number;
48
+ MSG_RETRY: number;
49
+ CALL_OFFER: number;
50
+ USER_DEVICES: number;
51
+ };
@@ -76,6 +76,8 @@ exports.MEDIA_PATH_MAP = {
76
76
  document: '/mms/document',
77
77
  audio: '/mms/audio',
78
78
  sticker: '/mms/image',
79
+ 'sticker-pack': '/mms/sticker-pack',
80
+ 'thumbnail-sticker-pack': '/mms/thumbnail-sticker-pack',
79
81
  'thumbnail-link': '/mms/image',
80
82
  'product-catalog-image': '/product/image',
81
83
  'md-app-state': '',
@@ -91,6 +93,8 @@ exports.MEDIA_HKDF_KEY_MAPPING = {
91
93
  'ptt': 'Audio',
92
94
  'sticker': 'Image',
93
95
  'video': 'Video',
96
+ 'sticker-pack': 'Sticker Pack',
97
+ 'thumbnail-sticker-pack': 'Sticker Pack Thumbnail',
94
98
  'thumbnail-document': 'Document Thumbnail',
95
99
  'thumbnail-image': 'Image Thumbnail',
96
100
  'thumbnail-video': 'Video Thumbnail',
@@ -0,0 +1,9 @@
1
+ export declare class CiphertextMessage {
2
+ readonly UNSUPPORTED_VERSION: number;
3
+ readonly CURRENT_VERSION: number;
4
+ readonly WHISPER_TYPE: number;
5
+ readonly PREKEY_TYPE: number;
6
+ readonly SENDERKEY_TYPE: number;
7
+ readonly SENDERKEY_DISTRIBUTION_TYPE: number;
8
+ readonly ENCRYPTED_MESSAGE_OVERHEAD: number;
9
+ }
@@ -0,0 +1,14 @@
1
+ import { SenderKeyDistributionMessage } from './sender-key-distribution-message';
2
+ import { SenderKeyName } from './sender-key-name';
3
+ import { SenderKeyRecord } from './sender-key-record';
4
+ interface SenderKeyStore {
5
+ loadSenderKey(senderKeyName: SenderKeyName): Promise<SenderKeyRecord>;
6
+ storeSenderKey(senderKeyName: SenderKeyName, record: SenderKeyRecord): Promise<void>;
7
+ }
8
+ export declare class GroupSessionBuilder {
9
+ private readonly senderKeyStore;
10
+ constructor(senderKeyStore: SenderKeyStore);
11
+ process(senderKeyName: SenderKeyName, senderKeyDistributionMessage: SenderKeyDistributionMessage): Promise<void>;
12
+ create(senderKeyName: SenderKeyName): Promise<SenderKeyDistributionMessage>;
13
+ }
14
+ export {};
@@ -0,0 +1,17 @@
1
+ import { SenderKeyName } from './sender-key-name';
2
+ import { SenderKeyRecord } from './sender-key-record';
3
+ export interface SenderKeyStore {
4
+ loadSenderKey(senderKeyName: SenderKeyName): Promise<SenderKeyRecord>;
5
+ storeSenderKey(senderKeyName: SenderKeyName, record: SenderKeyRecord): Promise<void>;
6
+ }
7
+ export declare class GroupCipher {
8
+ private readonly senderKeyStore;
9
+ private readonly senderKeyName;
10
+ constructor(senderKeyStore: SenderKeyStore, senderKeyName: SenderKeyName);
11
+ private queueJob;
12
+ encrypt(paddedPlaintext: Uint8Array | string): Promise<Uint8Array>;
13
+ decrypt(senderKeyMessageBytes: Uint8Array): Promise<Uint8Array>;
14
+ private getSenderKey;
15
+ private getPlainText;
16
+ private getCipherText;
17
+ }
@@ -0,0 +1,11 @@
1
+ export { GroupSessionBuilder } from './group-session-builder';
2
+ export { SenderKeyDistributionMessage } from './sender-key-distribution-message';
3
+ export { SenderKeyRecord } from './sender-key-record';
4
+ export { SenderKeyName } from './sender-key-name';
5
+ export { GroupCipher } from './group_cipher';
6
+ export { SenderKeyState } from './sender-key-state';
7
+ export { SenderKeyMessage } from './sender-key-message';
8
+ export { SenderMessageKey } from './sender-message-key';
9
+ export { SenderChainKey } from './sender-chain-key';
10
+ export { CiphertextMessage } from './ciphertext-message';
11
+ export * as keyhelper from './keyhelper';
@@ -0,0 +1,10 @@
1
+ import { generateKeyPair } from 'libsignal/src/curve';
2
+ type KeyPairType = ReturnType<typeof generateKeyPair>;
3
+ export declare function generateSenderKey(): Buffer;
4
+ export declare function generateSenderKeyId(): number;
5
+ export interface SigningKeyPair {
6
+ public: Buffer;
7
+ private: Buffer;
8
+ }
9
+ export declare function generateSenderSigningKey(key?: KeyPairType): SigningKeyPair;
10
+ export {};
@@ -0,0 +1 @@
1
+ export default function queueJob<T>(bucket: string | number, awaitable: () => Promise<T>): Promise<T>;
@@ -0,0 +1,13 @@
1
+ import { SenderMessageKey } from './sender-message-key';
2
+ export declare class SenderChainKey {
3
+ private readonly MESSAGE_KEY_SEED;
4
+ private readonly CHAIN_KEY_SEED;
5
+ private readonly iteration;
6
+ private readonly chainKey;
7
+ constructor(iteration: number, chainKey: any);
8
+ getIteration(): number;
9
+ getSenderMessageKey(): SenderMessageKey;
10
+ getNext(): SenderChainKey;
11
+ getSeed(): Uint8Array;
12
+ private getDerivative;
13
+ }
@@ -0,0 +1,16 @@
1
+ import { CiphertextMessage } from './ciphertext-message';
2
+ export declare class SenderKeyDistributionMessage extends CiphertextMessage {
3
+ private readonly id;
4
+ private readonly iteration;
5
+ private readonly chainKey;
6
+ private readonly signatureKey;
7
+ private readonly serialized;
8
+ constructor(id?: number | null, iteration?: number | null, chainKey?: Uint8Array | null, signatureKey?: Uint8Array | null, serialized?: Uint8Array | null);
9
+ private intsToByteHighAndLow;
10
+ serialize(): Uint8Array;
11
+ getType(): number;
12
+ getIteration(): number;
13
+ getChainKey(): Uint8Array;
14
+ getSignatureKey(): Uint8Array;
15
+ getId(): number;
16
+ }
@@ -0,0 +1,18 @@
1
+ import { CiphertextMessage } from './ciphertext-message';
2
+ export declare class SenderKeyMessage extends CiphertextMessage {
3
+ private readonly SIGNATURE_LENGTH;
4
+ private readonly messageVersion;
5
+ private readonly keyId;
6
+ private readonly iteration;
7
+ private readonly ciphertext;
8
+ private readonly signature;
9
+ private readonly serialized;
10
+ constructor(keyId?: number | null, iteration?: number | null, ciphertext?: Uint8Array | null, signatureKey?: Uint8Array | null, serialized?: Uint8Array | null);
11
+ getKeyId(): number;
12
+ getIteration(): number;
13
+ getCipherText(): Uint8Array;
14
+ verifySignature(signatureKey: Uint8Array): void;
15
+ private getSignature;
16
+ serialize(): Uint8Array;
17
+ getType(): number;
18
+ }
@@ -0,0 +1,17 @@
1
+ interface Sender {
2
+ id: string;
3
+ deviceId: number;
4
+ toString(): string;
5
+ }
6
+ export declare class SenderKeyName {
7
+ private readonly groupId;
8
+ private readonly sender;
9
+ constructor(groupId: string, sender: Sender);
10
+ getGroupId(): string;
11
+ getSender(): Sender;
12
+ serialize(): string;
13
+ toString(): string;
14
+ equals(other: SenderKeyName | null): boolean;
15
+ hashCode(): number;
16
+ }
17
+ export {};
@@ -0,0 +1,30 @@
1
+ import { SenderKeyState } from './sender-key-state';
2
+ export interface SenderKeyStateStructure {
3
+ senderKeyId: number;
4
+ senderChainKey: {
5
+ iteration: number;
6
+ seed: Uint8Array;
7
+ };
8
+ senderSigningKey: {
9
+ public: Uint8Array;
10
+ private?: Uint8Array;
11
+ };
12
+ senderMessageKeys: Array<{
13
+ iteration: number;
14
+ seed: Uint8Array;
15
+ }>;
16
+ }
17
+ export declare class SenderKeyRecord {
18
+ private readonly MAX_STATES;
19
+ private readonly senderKeyStates;
20
+ constructor(serialized?: SenderKeyStateStructure[]);
21
+ isEmpty(): boolean;
22
+ getSenderKeyState(keyId?: number): SenderKeyState | undefined;
23
+ addSenderKeyState(id: number, iteration: number, chainKey: Uint8Array, signatureKey: Uint8Array): void;
24
+ setSenderKeyState(id: number, iteration: number, chainKey: Uint8Array, keyPair: {
25
+ public: Uint8Array;
26
+ private: Uint8Array;
27
+ }): void;
28
+ serialize(): SenderKeyStateStructure[];
29
+ static deserialize(data: Uint8Array | string | SenderKeyStateStructure[]): SenderKeyRecord;
30
+ }
@@ -0,0 +1,38 @@
1
+ import { SenderChainKey } from './sender-chain-key';
2
+ import { SenderMessageKey } from './sender-message-key';
3
+ interface SenderChainKeyStructure {
4
+ iteration: number;
5
+ seed: Uint8Array;
6
+ }
7
+ interface SenderSigningKeyStructure {
8
+ public: Uint8Array;
9
+ private?: Uint8Array;
10
+ }
11
+ interface SenderMessageKeyStructure {
12
+ iteration: number;
13
+ seed: Uint8Array;
14
+ }
15
+ interface SenderKeyStateStructure {
16
+ senderKeyId: number;
17
+ senderChainKey: SenderChainKeyStructure;
18
+ senderSigningKey: SenderSigningKeyStructure;
19
+ senderMessageKeys: SenderMessageKeyStructure[];
20
+ }
21
+ export declare class SenderKeyState {
22
+ private readonly MAX_MESSAGE_KEYS;
23
+ private readonly senderKeyStateStructure;
24
+ constructor(id?: number | null, iteration?: number | null, chainKey?: Uint8Array | null, signatureKeyPair?: {
25
+ public: Uint8Array;
26
+ private: Uint8Array;
27
+ } | null, signatureKeyPublic?: Uint8Array | null, signatureKeyPrivate?: Uint8Array | null, senderKeyStateStructure?: SenderKeyStateStructure | null);
28
+ getKeyId(): number;
29
+ getSenderChainKey(): SenderChainKey;
30
+ setSenderChainKey(chainKey: SenderChainKey): void;
31
+ getSigningKeyPublic(): Buffer;
32
+ getSigningKeyPrivate(): Buffer | undefined;
33
+ hasSenderMessageKey(iteration: number): boolean;
34
+ addSenderMessageKey(senderMessageKey: SenderMessageKey): void;
35
+ removeSenderMessageKey(iteration: number): SenderMessageKey | null;
36
+ getStructure(): SenderKeyStateStructure;
37
+ }
38
+ export {};
@@ -0,0 +1,11 @@
1
+ export declare class SenderMessageKey {
2
+ private readonly iteration;
3
+ private readonly iv;
4
+ private readonly cipherKey;
5
+ private readonly seed;
6
+ constructor(iteration: number, seed: Uint8Array);
7
+ getIteration(): number;
8
+ getIv(): Uint8Array;
9
+ getCipherKey(): Uint8Array;
10
+ getSeed(): Uint8Array;
11
+ }
@@ -0,0 +1,3 @@
1
+ import { SignalAuthState } from '../Types';
2
+ import { SignalRepository } from '../Types/Signal';
3
+ export declare function makeLibSignalRepository(auth: SignalAuthState): SignalRepository;
@@ -0,0 +1,2 @@
1
+ export * from './types';
2
+ export * from './websocket';
@@ -0,0 +1,16 @@
1
+ import { EventEmitter } from 'events';
2
+ import { URL } from 'url';
3
+ import { SocketConfig } from '../../Types';
4
+ export declare abstract class AbstractSocketClient extends EventEmitter {
5
+ url: URL;
6
+ config: SocketConfig;
7
+ abstract get isOpen(): boolean;
8
+ abstract get isClosed(): boolean;
9
+ abstract get isClosing(): boolean;
10
+ abstract get isConnecting(): boolean;
11
+ constructor(url: URL, config: SocketConfig);
12
+ abstract connect(): Promise<void>;
13
+ abstract close(): Promise<void>;
14
+ abstract restart(): Promise<void>;
15
+ abstract send(str: Uint8Array | string, cb?: (err?: Error) => void): boolean;
16
+ }
@@ -0,0 +1,13 @@
1
+ import WebSocket from 'ws';
2
+ import { AbstractSocketClient } from './types';
3
+ export declare class WebSocketClient extends AbstractSocketClient {
4
+ protected socket: WebSocket | null;
5
+ get isOpen(): boolean;
6
+ get isClosed(): boolean;
7
+ get isClosing(): boolean;
8
+ get isConnecting(): boolean;
9
+ connect(): Promise<void>;
10
+ close(): Promise<void>;
11
+ restart(): Promise<void>;
12
+ send(str: string | Uint8Array, cb?: (err?: Error) => void): boolean;
13
+ }
@@ -0,0 +1,172 @@
1
+ import { GetCatalogOptions, ProductCreate, ProductUpdate, SocketConfig } from '../Types';
2
+ import { BinaryNode } from '../WABinary';
3
+ export declare const makeBusinessSocket: (config: SocketConfig) => {
4
+ logger: import("../Utils/logger").ILogger;
5
+ getOrderDetails: (orderId: string, tokenBase64: string) => Promise<import("../Types").OrderDetails>;
6
+ getCatalog: ({ jid, limit, cursor }: GetCatalogOptions) => Promise<{
7
+ products: import("../Types").Product[];
8
+ nextPageCursor: string | undefined;
9
+ }>;
10
+ getCollections: (jid?: string, limit?: number) => Promise<{
11
+ collections: import("../Types").CatalogCollection[];
12
+ }>;
13
+ productCreate: (create: ProductCreate) => Promise<import("../Types").Product>;
14
+ productDelete: (productIds: string[]) => Promise<{
15
+ deleted: number;
16
+ }>;
17
+ productUpdate: (productId: string, update: ProductUpdate) => Promise<import("../Types").Product>;
18
+ sendMessageAck: ({ tag, attrs, content }: BinaryNode, errorCode?: number) => Promise<void>;
19
+ sendRetryRequest: (node: BinaryNode, forceIncludeKeys?: boolean) => Promise<void>;
20
+ rejectCall: (callId: string, callFrom: string) => Promise<void>;
21
+ offerCall: (toJid: string, isVideo?: boolean) => Promise<{
22
+ callId: string;
23
+ toJid: string;
24
+ isVideo: boolean;
25
+ }>;
26
+ fetchMessageHistory: (count: number, oldestMsgKey: import("../Types").WAMessageKey, oldestMsgTimestamp: number | Long) => Promise<string>;
27
+ requestPlaceholderResend: (messageKey: import("../Types").WAMessageKey) => Promise<string | undefined>;
28
+ getPrivacyTokens: (jids: string[]) => Promise<any>;
29
+ assertSessions: (jids: string[], force: boolean) => Promise<boolean>;
30
+ relayMessage: (jid: string, message: import("../Types").WAProto.IMessage, { messageId: msgId, participant, additionalAttributes, additionalNodes, useUserDevicesCache, useCachedGroupMetadata, statusJidList }: import("../Types").MessageRelayOptions) => Promise<string>;
31
+ sendReceipt: (jid: string, participant: string | undefined, messageIds: string[], type: import("../Types").MessageReceiptType) => Promise<void>;
32
+ sendReceipts: (keys: import("../Types").WAMessageKey[], type: import("../Types").MessageReceiptType) => Promise<void>;
33
+ readMessages: (keys: import("../Types").WAMessageKey[]) => Promise<void>;
34
+ refreshMediaConn: (forceGet?: boolean) => Promise<import("../Types").MediaConnInfo>;
35
+ waUploadToServer: import("../Types").WAMediaUploadFunction;
36
+ fetchPrivacySettings: (force?: boolean) => Promise<{
37
+ [_: string]: string;
38
+ }>;
39
+ getUSyncDevices: (jids: string[], useCache: boolean, ignoreZeroDevices: boolean) => Promise<import("../WABinary").JidWithDevice[]>;
40
+ createParticipantNodes: (jids: string[], message: import("../Types").WAProto.IMessage, extraAttrs?: BinaryNode["attrs"]) => Promise<{
41
+ nodes: any[];
42
+ shouldIncludeDeviceIdentity: boolean;
43
+ }>;
44
+ sendPeerDataOperationMessage: (pdoMessage: import("../Types").WAProto.Message.IPeerDataOperationRequestMessage) => Promise<string>;
45
+ updateMediaMessage: (message: import("../Types").WAProto.IWebMessageInfo) => Promise<import("../Types").WAProto.IWebMessageInfo>;
46
+ sendMessage: (jid: string, content: import("../Types").AnyMessageContent, options?: import("../Types").MiscMessageGenerationOptions) => Promise<import("../Types").WAProto.WebMessageInfo>;
47
+ subscribeNewsletterUpdates: (jid: string) => Promise<{
48
+ duration: string;
49
+ }>;
50
+ newsletterReactionMode: (jid: string, mode: import("../Types").NewsletterReactionMode) => Promise<void>;
51
+ newsletterUpdateDescription: (jid: string, description?: string) => Promise<void>;
52
+ newsletterUpdateName: (jid: string, name: string) => Promise<void>;
53
+ newsletterUpdatePicture: (jid: string, content: import("../Types").WAMediaUpload) => Promise<void>;
54
+ newsletterRemovePicture: (jid: string) => Promise<void>;
55
+ newsletterUnfollow: (jid: string) => Promise<void>;
56
+ newsletterFollow: (jid: string) => Promise<void>;
57
+ newsletterUnmute: (jid: string) => Promise<void>;
58
+ newsletterMute: (jid: string) => Promise<void>;
59
+ newsletterCreate: (name: string, description?: string, picture?: import("../Types").WAMediaUpload) => Promise<import("../Types").NewsletterMetadata>;
60
+ newsletterMetadata: (type: "invite" | "jid", key: string, role?: import("../Types").NewsletterViewRole) => Promise<import("../Types").NewsletterMetadata>;
61
+ newsletterAdminCount: (jid: string) => Promise<number>;
62
+ newsletterChangeOwner: (jid: string, user: string) => Promise<void>;
63
+ newsletterDemote: (jid: string, user: string) => Promise<void>;
64
+ newsletterDelete: (jid: string) => Promise<void>;
65
+ newsletterReactMessage: (jid: string, server_id: string, code?: string) => Promise<void>;
66
+ newsletterFetchMessages: (type: "invite" | "jid", key: string, count: number, after?: number) => Promise<import("../Types").NewsletterFetchedUpdate[]>;
67
+ newsletterFetchUpdates: (jid: string, count: number, after?: number, since?: number) => Promise<import("../Types").NewsletterFetchedUpdate[]>;
68
+ groupQuery: (jid: string, type: "get" | "set", content: BinaryNode[]) => Promise<any>;
69
+ groupMetadata: (jid: string) => Promise<import("../Types").GroupMetadata>;
70
+ groupCreate: (subject: string, participants: string[]) => Promise<import("../Types").GroupMetadata>;
71
+ groupLeave: (id: string) => Promise<void>;
72
+ groupUpdateSubject: (jid: string, subject: string) => Promise<void>;
73
+ groupRequestParticipantsList: (jid: string) => Promise<{
74
+ [key: string]: string;
75
+ }[]>;
76
+ groupRequestParticipantsUpdate: (jid: string, participants: string[], action: "approve" | "reject") => Promise<{
77
+ status: string;
78
+ jid: string;
79
+ }[]>;
80
+ groupParticipantsUpdate: (jid: string, participants: string[], action: import("../Types").ParticipantAction) => Promise<{
81
+ status: string;
82
+ jid: string;
83
+ content: BinaryNode;
84
+ }[]>;
85
+ groupUpdateDescription: (jid: string, description?: string) => Promise<void>;
86
+ groupInviteCode: (jid: string) => Promise<string | undefined>;
87
+ groupRevokeInvite: (jid: string) => Promise<string | undefined>;
88
+ groupAcceptInvite: (code: string) => Promise<string | undefined>;
89
+ groupRevokeInviteV4: (groupJid: string, invitedJid: string) => Promise<boolean>;
90
+ groupAcceptInviteV4: (key: string | import("../Types").WAMessageKey, inviteMessage: import("../Types").WAProto.Message.IGroupInviteMessage) => Promise<any>;
91
+ groupGetInviteInfo: (code: string) => Promise<import("../Types").GroupMetadata>;
92
+ groupToggleEphemeral: (jid: string, ephemeralExpiration: number) => Promise<void>;
93
+ groupSettingUpdate: (jid: string, setting: "announcement" | "not_announcement" | "locked" | "unlocked") => Promise<void>;
94
+ groupMemberAddMode: (jid: string, mode: "admin_add" | "all_member_add") => Promise<void>;
95
+ groupJoinApprovalMode: (jid: string, mode: "on" | "off") => Promise<void>;
96
+ groupFetchAllParticipating: () => Promise<{
97
+ [_: string]: import("../Types").GroupMetadata;
98
+ }>;
99
+ getBotListV2: () => Promise<import("../Types").BotListInfo[]>;
100
+ processingMutex: {
101
+ mutex<T>(code: () => Promise<T> | T): Promise<T>;
102
+ };
103
+ upsertMessage: (msg: import("../Types").WAMessage, type: import("../Types").MessageUpsertType) => Promise<void>;
104
+ appPatch: (patchCreate: import("../Types").WAPatchCreate) => Promise<void>;
105
+ sendPresenceUpdate: (type: import("../Types").WAPresence, toJid?: string) => Promise<void>;
106
+ presenceSubscribe: (toJid: string, tcToken?: Buffer) => Promise<void>;
107
+ profilePictureUrl: (jid: string, type?: "preview" | "image", timeoutMs?: number) => Promise<string | undefined>;
108
+ onWhatsApp: (...jids: string[]) => Promise<{
109
+ jid: string;
110
+ exists: unknown;
111
+ lid: unknown;
112
+ }[] | undefined>;
113
+ fetchBlocklist: () => Promise<string[]>;
114
+ fetchDisappearingDuration: (...jids: string[]) => Promise<import("..").USyncQueryResultList[] | undefined>;
115
+ fetchStatus: (...jids: string[]) => Promise<import("..").USyncQueryResultList[] | undefined>;
116
+ updateProfilePicture: (jid: string, content: import("../Types").WAMediaUpload) => Promise<void>;
117
+ removeProfilePicture: (jid: string) => Promise<void>;
118
+ updateProfileStatus: (status: string) => Promise<void>;
119
+ updateProfileName: (name: string) => Promise<void>;
120
+ updateBlockStatus: (jid: string, action: "block" | "unblock") => Promise<void>;
121
+ updateCallPrivacy: (value: import("../Types").WAPrivacyCallValue) => Promise<void>;
122
+ updateMessagesPrivacy: (value: import("../Types").WAPrivacyMessagesValue) => Promise<void>;
123
+ updateLastSeenPrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
124
+ updateOnlinePrivacy: (value: import("../Types").WAPrivacyOnlineValue) => Promise<void>;
125
+ updateProfilePicturePrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
126
+ updateStatusPrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
127
+ updateReadReceiptsPrivacy: (value: import("../Types").WAReadReceiptsValue) => Promise<void>;
128
+ updateGroupsAddPrivacy: (value: import("../Types").WAPrivacyGroupAddValue) => Promise<void>;
129
+ updateDefaultDisappearingMode: (duration: number) => Promise<void>;
130
+ getBusinessProfile: (jid: string) => Promise<import("../Types").WABusinessProfile | void>;
131
+ resyncAppState: (collections: readonly ("critical_unblock_low" | "regular_high" | "regular_low" | "critical_block" | "regular")[], isInitialSync: boolean) => Promise<void>;
132
+ chatModify: (mod: import("../Types").ChatModification, jid: string) => Promise<void>;
133
+ cleanDirtyBits: (type: "account_sync" | "groups", fromTimestamp?: number | string) => Promise<void>;
134
+ addChatLabel: (jid: string, labelId: string) => Promise<void>;
135
+ removeChatLabel: (jid: string, labelId: string) => Promise<void>;
136
+ addMessageLabel: (jid: string, messageId: string, labelId: string) => Promise<void>;
137
+ removeMessageLabel: (jid: string, messageId: string, labelId: string) => Promise<void>;
138
+ star: (jid: string, messages: {
139
+ id: string;
140
+ fromMe?: boolean;
141
+ }[], star: boolean) => Promise<void>;
142
+ executeUSyncQuery: (usyncQuery: import("..").USyncQuery) => Promise<import("..").USyncQueryResult | undefined>;
143
+ type: "md";
144
+ ws: import("./Client").WebSocketClient;
145
+ ev: import("../Types").BaileysEventEmitter & {
146
+ process(handler: (events: Partial<import("../Types").BaileysEventMap>) => void | Promise<void>): (() => void);
147
+ buffer(): void;
148
+ createBufferedFunction<A extends any[], T>(work: (...args: A) => Promise<T>): ((...args: A) => Promise<T>);
149
+ flush(force?: boolean): boolean;
150
+ isBuffering(): boolean;
151
+ };
152
+ authState: {
153
+ creds: import("../Types").AuthenticationCreds;
154
+ keys: import("../Types").SignalKeyStoreWithTransaction;
155
+ };
156
+ signalRepository: import("../Types").SignalRepository;
157
+ user: import("../Types").Contact | undefined;
158
+ generateMessageTag: () => string;
159
+ query: (node: BinaryNode, timeoutMs?: number) => Promise<any>;
160
+ waitForMessage: <T>(msgId: string, timeoutMs?: number | undefined) => Promise<any>;
161
+ waitForSocketOpen: () => Promise<void>;
162
+ sendRawMessage: (data: Uint8Array | Buffer) => Promise<void>;
163
+ sendNode: (frame: BinaryNode) => Promise<void>;
164
+ logout: (msg?: string) => Promise<void>;
165
+ end: (error: Error | undefined) => void;
166
+ onUnexpectedError: (err: Error | import("@hapi/boom").Boom, msg: string) => void;
167
+ uploadPreKeys: (count?: number) => Promise<void>;
168
+ uploadPreKeysToServerIfRequired: () => Promise<void>;
169
+ requestPairingCode: (phoneNumber: string, pairCode: string) => Promise<string>;
170
+ waitForConnectionUpdate: (check: (u: Partial<import("../Types").ConnectionState>) => Promise<boolean | undefined>, timeoutMs?: number) => Promise<void>;
171
+ sendWAMBuffer: (wamBuffer: Buffer) => Promise<any>;
172
+ };