@jkt48connect-corp/baileys 7.2.7 → 7.2.9

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 (118) hide show
  1. package/LICENSE +1 -1
  2. package/README.md +838 -94
  3. package/WAProto/WAProto.proto +969 -88
  4. package/WAProto/index.js +124901 -74525
  5. package/lib/Defaults/baileys-version.json +1 -1
  6. package/lib/Defaults/index.js +5 -3
  7. package/lib/Defaults/phonenumber-mcc.json +221 -221
  8. package/lib/Signal/libsignal.js +18 -9
  9. package/lib/Socket/groups.js +1 -1
  10. package/lib/Socket/messages-recv.js +310 -151
  11. package/lib/Socket/messages-send.js +269 -36
  12. package/lib/Socket/newsletter.js +3 -3
  13. package/lib/Socket/registration.js +7 -7
  14. package/lib/Socket/socket.js +7 -3
  15. package/lib/Store/make-in-memory-store.js +13 -11
  16. package/lib/Types/Label.js +1 -1
  17. package/lib/Types/LabelAssociation.js +1 -1
  18. package/lib/Types/Newsletter.js +3 -3
  19. package/lib/Types/index.js +1 -1
  20. package/lib/Utils/auth-utils.js +3 -3
  21. package/lib/Utils/business.js +2 -2
  22. package/lib/Utils/chat-utils.js +41 -20
  23. package/lib/Utils/crypto.js +35 -23
  24. package/lib/Utils/decode-wa-message.js +43 -15
  25. package/lib/Utils/generics.js +32 -16
  26. package/lib/Utils/history.js +3 -0
  27. package/lib/Utils/index.js +0 -1
  28. package/lib/Utils/messages-media.js +38 -47
  29. package/lib/Utils/messages.js +430 -12
  30. package/lib/Utils/process-message.js +2 -2
  31. package/lib/Utils/use-multi-file-auth-state.js +17 -3
  32. package/lib/Utils/validate-connection.js +12 -23
  33. package/lib/WABinary/decode.js +17 -7
  34. package/lib/WABinary/encode.js +33 -17
  35. package/lib/WABinary/generic-utils.js +2 -2
  36. package/lib/WAUSync/Protocols/USyncContactProtocol.js +32 -0
  37. package/lib/WAUSync/Protocols/USyncDeviceProtocol.js +57 -0
  38. package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.js +30 -0
  39. package/lib/WAUSync/Protocols/USyncStatusProtocol.js +42 -0
  40. package/lib/WAUSync/Protocols/index.js +20 -0
  41. package/lib/WAUSync/USyncQuery.js +79 -0
  42. package/lib/WAUSync/USyncUser.js +22 -0
  43. package/lib/WAUSync/index.js +19 -0
  44. package/lib/index.js +4 -1
  45. package/package.json +15 -10
  46. package/WAProto/index.d.ts +0 -37016
  47. package/lib/Defaults/index.d.ts +0 -283
  48. package/lib/Signal/libsignal.d.ts +0 -3
  49. package/lib/Socket/Client/abstract-socket-client.d.ts +0 -17
  50. package/lib/Socket/Client/index.d.ts +0 -3
  51. package/lib/Socket/Client/mobile-socket-client.d.ts +0 -13
  52. package/lib/Socket/Client/web-socket-client.d.ts +0 -12
  53. package/lib/Socket/business.d.ts +0 -170
  54. package/lib/Socket/chats.d.ts +0 -80
  55. package/lib/Socket/community.d.ts +0 -219
  56. package/lib/Socket/community.js +0 -354
  57. package/lib/Socket/groups.d.ts +0 -114
  58. package/lib/Socket/index.d.ts +0 -172
  59. package/lib/Socket/messages-recv.d.ts +0 -158
  60. package/lib/Socket/messages-send.d.ts +0 -147
  61. package/lib/Socket/newsletter.d.ts +0 -133
  62. package/lib/Socket/registration.d.ts +0 -267
  63. package/lib/Socket/socket.d.ts +0 -43
  64. package/lib/Store/index.d.ts +0 -3
  65. package/lib/Store/make-cache-manager-store.d.ts +0 -13
  66. package/lib/Store/make-in-memory-store.d.ts +0 -118
  67. package/lib/Store/make-ordered-dictionary.d.ts +0 -13
  68. package/lib/Store/object-repository.d.ts +0 -10
  69. package/lib/Types/Auth.d.ts +0 -110
  70. package/lib/Types/Call.d.ts +0 -13
  71. package/lib/Types/Chat.d.ts +0 -102
  72. package/lib/Types/Contact.d.ts +0 -19
  73. package/lib/Types/Events.d.ts +0 -157
  74. package/lib/Types/GroupMetadata.d.ts +0 -54
  75. package/lib/Types/Label.d.ts +0 -35
  76. package/lib/Types/LabelAssociation.d.ts +0 -29
  77. package/lib/Types/Message.d.ts +0 -273
  78. package/lib/Types/Newsletter.d.ts +0 -92
  79. package/lib/Types/Product.d.ts +0 -78
  80. package/lib/Types/Signal.d.ts +0 -57
  81. package/lib/Types/Socket.d.ts +0 -111
  82. package/lib/Types/State.d.ts +0 -27
  83. package/lib/Types/index.d.ts +0 -57
  84. package/lib/Utils/auth-utils.d.ts +0 -18
  85. package/lib/Utils/baileys-event-stream.d.ts +0 -16
  86. package/lib/Utils/business.d.ts +0 -22
  87. package/lib/Utils/chat-utils.d.ts +0 -71
  88. package/lib/Utils/crypto.d.ts +0 -41
  89. package/lib/Utils/decode-wa-message.d.ts +0 -19
  90. package/lib/Utils/event-buffer.d.ts +0 -35
  91. package/lib/Utils/generics.d.ts +0 -97
  92. package/lib/Utils/history.d.ts +0 -15
  93. package/lib/Utils/index.d.ts +0 -18
  94. package/lib/Utils/link-preview.d.ts +0 -21
  95. package/lib/Utils/logger.d.ts +0 -4
  96. package/lib/Utils/lt-hash.d.ts +0 -12
  97. package/lib/Utils/make-mutex.d.ts +0 -7
  98. package/lib/Utils/messages-media.d.ts +0 -116
  99. package/lib/Utils/messages.d.ts +0 -77
  100. package/lib/Utils/noise-handler.d.ts +0 -21
  101. package/lib/Utils/process-message.d.ts +0 -41
  102. package/lib/Utils/signal.d.ts +0 -32
  103. package/lib/Utils/use-multi-file-auth-state.d.ts +0 -12
  104. package/lib/Utils/use-single-file-auth-statev2.d.ts +0 -12
  105. package/lib/Utils/use-single-file-auth-statev2.js +0 -75
  106. package/lib/Utils/validate-connection.d.ts +0 -11
  107. package/lib/WABinary/constants.d.ts +0 -27
  108. package/lib/WABinary/decode.d.ts +0 -7
  109. package/lib/WABinary/encode.d.ts +0 -3
  110. package/lib/WABinary/generic-utils.d.ts +0 -15
  111. package/lib/WABinary/index.d.ts +0 -5
  112. package/lib/WABinary/jid-utils.d.ts +0 -31
  113. package/lib/WABinary/types.d.ts +0 -18
  114. package/lib/WAM/BinaryInfo.d.ts +0 -17
  115. package/lib/WAM/constants.d.ts +0 -38
  116. package/lib/WAM/encode.d.ts +0 -3
  117. package/lib/WAM/index.d.ts +0 -3
  118. package/lib/index.d.ts +0 -11
@@ -1,133 +0,0 @@
1
- /// <reference types="node" />
2
- import { NewsletterFetchedUpdate, NewsletterMetadata, NewsletterReactionMode, NewsletterViewRole, SocketConfig, WAMediaUpload } from '../Types';
3
- import { BinaryNode } from '../WABinary';
4
- export declare const makeNewsletterSocket: (config: SocketConfig) => {
5
- subscribeNewsletterUpdates: (jid: string) => Promise<{
6
- duration: string;
7
- }>;
8
- newsletterReactionMode: (jid: string, mode: NewsletterReactionMode) => Promise<void>;
9
- newsletterUpdateDescription: (jid: string, description?: string) => Promise<void>;
10
- newsletterUpdateName: (jid: string, name: string) => Promise<void>;
11
- newsletterUpdatePicture: (jid: string, content: WAMediaUpload) => Promise<void>;
12
- newsletterRemovePicture: (jid: string) => Promise<void>;
13
- newsletterUnfollow: (jid: string) => Promise<void>;
14
- newsletterFollow: (jid: string) => Promise<void>;
15
- newsletterUnmute: (jid: string) => Promise<void>;
16
- newsletterMute: (jid: string) => Promise<void>;
17
- newsletterAction: (jid: string, type: 'follow' | 'unfollow' | 'mute' | 'unmute') => Promise<void>;
18
- newsletterCreate: (name: string, description: string, reaction_codes: string) => Promise<NewsletterMetadata>;
19
- newsletterMetadata: (type: 'invite' | 'jid', key: string, role?: NewsletterViewRole) => Promise<NewsletterMetadata>;
20
- newsletterAdminCount: (jid: string) => Promise<number>;
21
- /**user is Lid, not Jid */
22
- newsletterChangeOwner: (jid: string, user: string) => Promise<void>;
23
- /**user is Lid, not Jid */
24
- newsletterDemote: (jid: string, user: string) => Promise<void>;
25
- newsletterDelete: (jid: string) => Promise<void>;
26
- /**if code wasn't passed, the reaction will be removed (if is reacted) */
27
- newsletterReactMessage: (jid: string, serverId: string, code?: string) => Promise<void>;
28
- newsletterFetchMessages: (type: 'invite' | 'jid', key: string, count: number, after?: number) => Promise<NewsletterFetchedUpdate[]>;
29
- newsletterFetchUpdates: (jid: string, count: number, after?: number, since?: number) => Promise<NewsletterFetchedUpdate[]>;
30
- groupMetadata: (jid: string) => Promise<import("../Types").GroupMetadata>;
31
- groupCreate: (subject: string, participants: string[]) => Promise<import("../Types").GroupMetadata>;
32
- groupLeave: (id: string) => Promise<void>;
33
- groupUpdateSubject: (jid: string, subject: string) => Promise<void>;
34
- groupRequestParticipantsList: (jid: string) => Promise<{
35
- [key: string]: string;
36
- }[]>;
37
- groupRequestParticipantsUpdate: (jid: string, participants: string[], action: "reject" | "approve") => Promise<{
38
- status: string;
39
- jid: string;
40
- }[]>;
41
- groupParticipantsUpdate: (jid: string, participants: string[], action: import("../Types").ParticipantAction) => Promise<{
42
- status: string;
43
- jid: string;
44
- content: BinaryNode;
45
- }[]>;
46
- groupUpdateDescription: (jid: string, description?: string | undefined) => Promise<void>;
47
- groupInviteCode: (jid: string) => Promise<string | undefined>;
48
- groupRevokeInvite: (jid: string) => Promise<string | undefined>;
49
- groupAcceptInvite: (code: string) => Promise<string | undefined>;
50
- groupAcceptInviteV4: (key: string | import("../Types").WAProto.IMessageKey, inviteMessage: import("../Types").WAProto.Message.IGroupInviteMessage) => Promise<string>;
51
- groupGetInviteInfo: (code: string) => Promise<import("../Types").GroupMetadata>;
52
- groupToggleEphemeral: (jid: string, ephemeralExpiration: number) => Promise<void>;
53
- groupSettingUpdate: (jid: string, setting: "announcement" | "locked" | "not_announcement" | "unlocked") => Promise<void>;
54
- groupMemberAddMode: (jid: string, mode: "all_member_add" | "admin_add") => Promise<void>;
55
- groupJoinApprovalMode: (jid: string, mode: "on" | "off") => Promise<void>;
56
- groupFetchAllParticipating: () => Promise<{
57
- [_: string]: import("../Types").GroupMetadata;
58
- }>;
59
- processingMutex: {
60
- mutex<T>(code: () => T | Promise<T>): Promise<T>;
61
- };
62
- fetchPrivacySettings: (force?: boolean) => Promise<{
63
- [_: string]: string;
64
- }>;
65
- upsertMessage: (msg: import("../Types").WAProto.IWebMessageInfo, type: import("../Types").MessageUpsertType) => Promise<void>;
66
- appPatch: (patchCreate: import("../Types").WAPatchCreate) => Promise<void>;
67
- sendPresenceUpdate: (type: import("../Types").WAPresence, toJid?: string | undefined) => Promise<void>;
68
- presenceSubscribe: (toJid: string, tcToken?: Buffer | undefined) => Promise<void>;
69
- profilePictureUrl: (jid: string, type?: "image" | "preview", timeoutMs?: number | undefined) => Promise<string | undefined>;
70
- onWhatsApp: (...jids: string[]) => Promise<{
71
- exists: boolean;
72
- jid: string;
73
- }[]>;
74
- fetchBlocklist: () => Promise<string[]>;
75
- fetchStatus: (jid: string) => Promise<{
76
- status: string | undefined;
77
- setAt: Date;
78
- } | undefined>;
79
- updateProfilePicture: (jid: string, content: WAMediaUpload) => Promise<void>;
80
- removeProfilePicture: (jid: string) => Promise<void>;
81
- updateProfileStatus: (status: string) => Promise<void>;
82
- updateProfileName: (name: string) => Promise<void>;
83
- updateBlockStatus: (jid: string, action: "block" | "unblock") => Promise<void>;
84
- updateLastSeenPrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
85
- updateOnlinePrivacy: (value: import("../Types").WAPrivacyOnlineValue) => Promise<void>;
86
- updateProfilePicturePrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
87
- updateStatusPrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
88
- updateReadReceiptsPrivacy: (value: import("../Types").WAReadReceiptsValue) => Promise<void>;
89
- updateGroupsAddPrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
90
- updateDefaultDisappearingMode: (duration: number) => Promise<void>;
91
- getBusinessProfile: (jid: string) => Promise<void | import("../Types").WABusinessProfile>;
92
- resyncAppState: (collections: readonly ("critical_block" | "critical_unblock_low" | "regular_high" | "regular_low" | "regular")[], isInitialSync: boolean) => Promise<void>;
93
- chatModify: (mod: import("../Types").ChatModification, jid: string) => Promise<void>;
94
- cleanDirtyBits: (type: "account_sync" | "groups", fromTimestamp?: string | number | undefined) => Promise<void>;
95
- addChatLabel: (jid: string, labelId: string) => Promise<void>;
96
- removeChatLabel: (jid: string, labelId: string) => Promise<void>;
97
- addMessageLabel: (jid: string, messageId: string, labelId: string) => Promise<void>;
98
- removeMessageLabel: (jid: string, messageId: string, labelId: string) => Promise<void>;
99
- star: (jid: string, messages: {
100
- id: string;
101
- fromMe?: boolean | undefined;
102
- }[], star: boolean) => Promise<void>;
103
- type: "md";
104
- ws: any;
105
- ev: import("../Types").BaileysEventEmitter & {
106
- process(handler: (events: Partial<import("../Types").BaileysEventMap>) => void | Promise<void>): () => void;
107
- buffer(): void;
108
- createBufferedFunction<A extends any[], T_1>(work: (...args: A) => Promise<T_1>): (...args: A) => Promise<T_1>;
109
- flush(force?: boolean | undefined): boolean;
110
- isBuffering(): boolean;
111
- };
112
- authState: {
113
- creds: import("../Types").AuthenticationCreds;
114
- keys: import("../Types").SignalKeyStoreWithTransaction;
115
- };
116
- signalRepository: import("../Types").SignalRepository;
117
- user: import("../Types").Contact | undefined;
118
- generateMessageTag: () => string;
119
- query: (node: BinaryNode, timeoutMs?: number | undefined) => Promise<BinaryNode>;
120
- waitForMessage: <T_2>(msgId: string, timeoutMs?: number | undefined) => Promise<T_2>;
121
- waitForSocketOpen: () => Promise<void>;
122
- sendRawMessage: (data: Uint8Array | Buffer) => Promise<void>;
123
- sendNode: (frame: BinaryNode) => Promise<void>;
124
- logout: (msg?: string | undefined) => Promise<void>;
125
- end: (error: Error | undefined) => void;
126
- onUnexpectedError: (err: Error | import("@hapi/boom").Boom<any>, msg: string) => void;
127
- uploadPreKeys: (count?: number) => Promise<void>;
128
- uploadPreKeysToServerIfRequired: () => Promise<void>;
129
- requestPairingCode: (phoneNumber: string) => Promise<string>;
130
- waitForConnectionUpdate: (check: (u: Partial<import("../Types").ConnectionState>) => boolean | undefined, timeoutMs?: number | undefined) => Promise<void>;
131
- sendWAMBuffer: (wamBuffer: Buffer) => Promise<BinaryNode>;
132
- };
133
- export declare const extractNewsletterMetadata: (node: BinaryNode, isCreate?: boolean) => NewsletterMetadata;
@@ -1,267 +0,0 @@
1
- /// <reference types="node" />
2
- import { AxiosRequestConfig } from 'axios';
3
- import { KeyPair, SignedKeyPair, SocketConfig } from '../Types';
4
- export declare const makeRegistrationSocket: (config: SocketConfig) => {
5
- register: (code: string) => Promise<ExistsResponse>;
6
- requestRegistrationCode: (registrationOptions?: RegistrationOptions) => Promise<ExistsResponse>;
7
- logger: import("pino").Logger<import("pino").LoggerOptions>;
8
- getOrderDetails: (orderId: string, tokenBase64: string) => Promise<import("../Types").OrderDetails>;
9
- getCatalog: ({ jid, limit, cursor }: import("../Types").GetCatalogOptions) => Promise<{
10
- products: import("../Types").Product[];
11
- nextPageCursor: string | undefined;
12
- }>;
13
- getCollections: (jid?: string | undefined, limit?: number) => Promise<{
14
- collections: import("../Types").CatalogCollection[];
15
- }>;
16
- productCreate: (create: import("../Types").ProductCreate) => Promise<import("../Types").Product>;
17
- productDelete: (productIds: string[]) => Promise<{
18
- deleted: number;
19
- }>;
20
- productUpdate: (productId: string, update: import("../Types").ProductUpdate) => Promise<import("../Types").Product>;
21
- sendMessageAck: ({ tag, attrs, content }: import("../WABinary").BinaryNode) => Promise<void>;
22
- sendRetryRequest: (node: import("../WABinary").BinaryNode, forceIncludeKeys?: boolean) => Promise<void>;
23
- offerCall: (toJid: string, isVideo?: boolean) => Promise<{
24
- id: string;
25
- to: string;
26
- }>;
27
- rejectCall: (callId: string, callFrom: string) => Promise<void>;
28
- getPrivacyTokens: (jids: string[]) => Promise<import("../WABinary").BinaryNode>;
29
- assertSessions: (jids: string[], force: boolean) => Promise<boolean>;
30
- relayMessage: (jid: string, message: import("../Types").WAProto.IMessage, { messageId: msgId, participant, additionalAttributes, additionalNodes, useUserDevicesCache, cachedGroupMetadata, 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").WAProto.IMessageKey[], type: import("../Types").MessageReceiptType) => Promise<void>;
33
- getButtonArgs: (message: import("../Types").WAProto.IMessage) => {
34
- [key: string]: string;
35
- };
36
- readMessages: (keys: import("../Types").WAProto.IMessageKey[]) => Promise<void>;
37
- refreshMediaConn: (forceGet?: boolean) => Promise<import("../Types").MediaConnInfo>;
38
- getUSyncDevices: (jids: string[], useCache: boolean, ignoreZeroDevices: boolean) => Promise<import("../WABinary").JidWithDevice[]>;
39
- createParticipantNodes: (jids: string[], message: import("../Types").WAProto.IMessage, extraAttrs?: {
40
- [key: string]: string;
41
- } | undefined) => Promise<{
42
- nodes: import("../WABinary").BinaryNode[];
43
- shouldIncludeDeviceIdentity: boolean;
44
- }>;
45
- waUploadToServer: import("../Types").WAMediaUploadFunction;
46
- fetchPrivacySettings: (force?: boolean) => Promise<{
47
- [_: string]: string;
48
- }>;
49
- updateMediaMessage: (message: import("../Types").WAProto.IWebMessageInfo) => Promise<import("../Types").WAProto.IWebMessageInfo>;
50
- sendMessage: (jid: string, content: import("../Types").AnyMessageContent, options?: import("../Types").MiscMessageGenerationOptions) => Promise<import("../Types").WAProto.WebMessageInfo | undefined>;
51
- subscribeNewsletterUpdates: (jid: string) => Promise<{
52
- duration: string;
53
- }>;
54
- newsletterReactionMode: (jid: string, mode: import("../Types").NewsletterReactionMode) => Promise<void>;
55
- newsletterUpdateDescription: (jid: string, description?: string | undefined) => Promise<void>;
56
- newsletterUpdateName: (jid: string, name: string) => Promise<void>;
57
- newsletterUpdatePicture: (jid: string, content: import("../Types").WAMediaUpload) => Promise<void>;
58
- newsletterRemovePicture: (jid: string) => Promise<void>;
59
- newsletterUnfollow: (jid: string) => Promise<void>;
60
- newsletterFollow: (jid: string) => Promise<void>;
61
- newsletterUnmute: (jid: string) => Promise<void>;
62
- newsletterMute: (jid: string) => Promise<void>;
63
- newsletterAction: (jid: string, type: "mute" | "follow" | "unfollow" | "unmute") => Promise<void>;
64
- newsletterCreate: (name: string, description: string, reaction_codes: string) => Promise<import("../Types").NewsletterMetadata>;
65
- newsletterMetadata: (type: "invite" | "jid", key: string, role?: import("../Types").NewsletterViewRole | undefined) => Promise<import("../Types").NewsletterMetadata>;
66
- newsletterAdminCount: (jid: string) => Promise<number>;
67
- newsletterChangeOwner: (jid: string, user: string) => Promise<void>;
68
- newsletterDemote: (jid: string, user: string) => Promise<void>;
69
- newsletterDelete: (jid: string) => Promise<void>;
70
- newsletterReactMessage: (jid: string, serverId: string, code?: string | undefined) => Promise<void>;
71
- newsletterFetchMessages: (type: "invite" | "jid", key: string, count: number, after?: number | undefined) => Promise<import("../Types").NewsletterFetchedUpdate[]>;
72
- newsletterFetchUpdates: (jid: string, count: number, after?: number | undefined, since?: number | undefined) => Promise<import("../Types").NewsletterFetchedUpdate[]>;
73
- groupMetadata: (jid: string) => Promise<import("../Types").GroupMetadata>;
74
- groupCreate: (subject: string, participants: string[]) => Promise<import("../Types").GroupMetadata>;
75
- groupLeave: (id: string) => Promise<void>;
76
- /** the network code of your mobile network
77
- * @see {@link https://de.wikipedia.org/wiki/Mobile_Network_Code}
78
- */
79
- groupUpdateSubject: (jid: string, subject: string) => Promise<void>;
80
- groupRequestParticipantsList: (jid: string) => Promise<{
81
- [key: string]: string;
82
- }[]>;
83
- groupRequestParticipantsUpdate: (jid: string, participants: string[], action: "reject" | "approve") => Promise<{
84
- status: string;
85
- jid: string;
86
- }[]>;
87
- groupParticipantsUpdate: (jid: string, participants: string[], action: import("../Types").ParticipantAction) => Promise<{
88
- status: string;
89
- jid: string;
90
- content: import("../WABinary").BinaryNode;
91
- }[]>;
92
- groupUpdateDescription: (jid: string, description?: string | undefined) => Promise<void>;
93
- groupInviteCode: (jid: string) => Promise<string | undefined>;
94
- groupRevokeInvite: (jid: string) => Promise<string | undefined>;
95
- groupAcceptInvite: (code: string) => Promise<string | undefined>;
96
- groupAcceptInviteV4: (key: string | import("../Types").WAProto.IMessageKey, inviteMessage: import("../Types").WAProto.Message.IGroupInviteMessage) => Promise<string>;
97
- groupGetInviteInfo: (code: string) => Promise<import("../Types").GroupMetadata>;
98
- groupToggleEphemeral: (jid: string, ephemeralExpiration: number) => Promise<void>;
99
- groupSettingUpdate: (jid: string, setting: "announcement" | "locked" | "not_announcement" | "unlocked") => Promise<void>;
100
- groupMemberAddMode: (jid: string, mode: "all_member_add" | "admin_add") => Promise<void>;
101
- groupJoinApprovalMode: (jid: string, mode: "on" | "off") => Promise<void>;
102
- groupFetchAllParticipating: () => Promise<{
103
- [_: string]: import("../Types").GroupMetadata;
104
- }>;
105
- processingMutex: {
106
- mutex<T>(code: () => T | Promise<T>): Promise<T>;
107
- };
108
- upsertMessage: (msg: import("../Types").WAProto.IWebMessageInfo, type: import("../Types").MessageUpsertType) => Promise<void>;
109
- appPatch: (patchCreate: import("../Types").WAPatchCreate) => Promise<void>;
110
- sendPresenceUpdate: (type: import("../Types").WAPresence, toJid?: string | undefined) => Promise<void>;
111
- presenceSubscribe: (toJid: string, tcToken?: Buffer | undefined) => Promise<void>;
112
- profilePictureUrl: (jid: string, type?: "image" | "preview", timeoutMs?: number | undefined) => Promise<string | undefined>;
113
- onWhatsApp: (...jids: string[]) => Promise<{
114
- exists: boolean;
115
- jid: string;
116
- }[]>;
117
- fetchBlocklist: () => Promise<string[]>;
118
- fetchStatus: (jid: string) => Promise<{
119
- status: string | undefined;
120
- setAt: Date;
121
- } | undefined>;
122
- updateProfilePicture: (jid: string, content: import("../Types").WAMediaUpload) => Promise<void>;
123
- removeProfilePicture: (jid: string) => Promise<void>;
124
- updateProfileStatus: (status: string) => Promise<void>;
125
- updateProfileName: (name: string) => Promise<void>;
126
- updateBlockStatus: (jid: string, action: "block" | "unblock") => Promise<void>;
127
- updateLastSeenPrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
128
- updateOnlinePrivacy: (value: import("../Types").WAPrivacyOnlineValue) => Promise<void>;
129
- updateProfilePicturePrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
130
- updateStatusPrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
131
- updateReadReceiptsPrivacy: (value: import("../Types").WAReadReceiptsValue) => Promise<void>;
132
- updateGroupsAddPrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
133
- updateDefaultDisappearingMode: (duration: number) => Promise<void>;
134
- getBusinessProfile: (jid: string) => Promise<void | import("../Types").WABusinessProfile>;
135
- resyncAppState: (collections: readonly ("critical_block" | "critical_unblock_low" | "regular_high" | "regular_low" | "regular")[], isInitialSync: boolean) => Promise<void>;
136
- chatModify: (mod: import("../Types").ChatModification, jid: string) => Promise<void>;
137
- cleanDirtyBits: (type: "account_sync" | "groups", fromTimestamp?: string | number | undefined) => Promise<void>;
138
- addChatLabel: (jid: string, labelId: string) => Promise<void>;
139
- removeChatLabel: (jid: string, labelId: string) => Promise<void>;
140
- addMessageLabel: (jid: string, messageId: string, labelId: string) => Promise<void>;
141
- removeMessageLabel: (jid: string, messageId: string, labelId: string) => Promise<void>;
142
- star: (jid: string, messages: {
143
- id: string;
144
- fromMe?: boolean | undefined;
145
- }[], star: boolean) => Promise<void>;
146
- type: "md";
147
- ws: any;
148
- ev: import("../Types").BaileysEventEmitter & {
149
- process(handler: (events: Partial<import("../Types").BaileysEventMap>) => void | Promise<void>): () => void;
150
- buffer(): void;
151
- createBufferedFunction<A extends any[], T_1>(work: (...args: A) => Promise<T_1>): (...args: A) => Promise<T_1>;
152
- flush(force?: boolean | undefined): boolean;
153
- isBuffering(): boolean;
154
- };
155
- authState: {
156
- creds: import("../Types").AuthenticationCreds;
157
- keys: import("../Types").SignalKeyStoreWithTransaction;
158
- };
159
- signalRepository: import("../Types").SignalRepository;
160
- user: import("../Types").Contact | undefined;
161
- generateMessageTag: () => string;
162
- query: (node: import("../WABinary").BinaryNode, timeoutMs?: number | undefined) => Promise<import("../WABinary").BinaryNode>;
163
- waitForMessage: <T_2>(msgId: string, timeoutMs?: number | undefined) => Promise<T_2>;
164
- waitForSocketOpen: () => Promise<void>;
165
- sendRawMessage: (data: Uint8Array | Buffer) => Promise<void>;
166
- sendNode: (frame: import("../WABinary").BinaryNode) => Promise<void>;
167
- logout: (msg?: string | undefined) => Promise<void>;
168
- end: (error: Error | undefined) => void;
169
- onUnexpectedError: (err: Error | import("@hapi/boom").Boom<any>, msg: string) => void;
170
- uploadPreKeys: (count?: number) => Promise<void>;
171
- uploadPreKeysToServerIfRequired: () => Promise<void>;
172
- requestPairingCode: (phoneNumber: string) => Promise<string>;
173
- waitForConnectionUpdate: (check: (u: Partial<import("../Types").ConnectionState>) => boolean | undefined, timeoutMs?: number | undefined) => Promise<void>;
174
- sendWAMBuffer: (wamBuffer: Buffer) => Promise<import("../WABinary").BinaryNode>;
175
- };
176
- export interface RegistrationData {
177
- registrationId: number;
178
- signedPreKey: SignedKeyPair;
179
- noiseKey: KeyPair;
180
- signedIdentityKey: KeyPair;
181
- identityId: Buffer;
182
- phoneId: string;
183
- deviceId: string;
184
- backupToken: Buffer;
185
- }
186
- export interface RegistrationOptions {
187
- /** your phone number */
188
- phoneNumber?: string;
189
- /** the country code of your phone number */
190
- phoneNumberCountryCode: string;
191
- /** your phone number without country code */
192
- phoneNumberNationalNumber: string;
193
- /** the country code of your mobile network
194
- * @see {@link https://de.wikipedia.org/wiki/Mobile_Country_Code}
195
- */
196
- phoneNumberMobileCountryCode: string;
197
- /** the network code of your mobile network
198
- * @see {@link https://de.wikipedia.org/wiki/Mobile_Network_Code}
199
- */
200
- phoneNumberMobileNetworkCode: string;
201
- /**
202
- * How to send the one time code
203
- */
204
- method?: 'sms' | 'voice' | 'captcha';
205
- /**
206
- * The captcha code if it was requested
207
- */
208
- captcha?: string;
209
- }
210
- export type RegistrationParams = RegistrationData & RegistrationOptions;
211
- export declare function registrationParams(params: RegistrationParams): {
212
- cc: string;
213
- in: string;
214
- Rc: string;
215
- lg: string;
216
- lc: string;
217
- mistyped: string;
218
- authkey: string;
219
- e_regid: string;
220
- e_keytype: string;
221
- e_ident: string;
222
- e_skey_id: string;
223
- e_skey_val: string;
224
- e_skey_sig: string;
225
- fdid: string;
226
- network_ratio_type: string;
227
- expid: string;
228
- simnum: string;
229
- hasinrc: string;
230
- pid: string;
231
- id: string;
232
- backup_token: string;
233
- token: string;
234
- fraud_checkpoint_code: string | undefined;
235
- };
236
- /**
237
- * Requests a registration code for the given phone number.
238
- */
239
- export declare function mobileRegisterCode(params: RegistrationParams, fetchOptions?: AxiosRequestConfig): Promise<ExistsResponse>;
240
- export declare function mobileRegisterExists(params: RegistrationParams, fetchOptions?: AxiosRequestConfig): Promise<ExistsResponse>;
241
- /**
242
- * Registers the phone number on whatsapp with the received OTP code.
243
- */
244
- export declare function mobileRegister(params: RegistrationParams & {
245
- code: string;
246
- }, fetchOptions?: AxiosRequestConfig): Promise<ExistsResponse>;
247
- /**
248
- * Encrypts the given string as AEAD aes-256-gcm with the public whatsapp key and a random keypair.
249
- */
250
- export declare function mobileRegisterEncrypt(data: string): string;
251
- export declare function mobileRegisterFetch(path: string, opts?: AxiosRequestConfig): Promise<ExistsResponse>;
252
- export interface ExistsResponse {
253
- status: 'fail' | 'sent';
254
- voice_length?: number;
255
- voice_wait?: number;
256
- sms_length?: number;
257
- sms_wait?: number;
258
- reason?: 'incorrect' | 'missing_param' | 'code_checkpoint';
259
- login?: string;
260
- flash_type?: number;
261
- ab_hash?: string;
262
- ab_key?: string;
263
- exp_cfg?: string;
264
- lid?: string;
265
- image_blob?: string;
266
- audio_blob?: string;
267
- }
@@ -1,43 +0,0 @@
1
- /// <reference types="node" />
2
- import { Boom } from '@hapi/boom';
3
- import { SocketConfig } from '../Types';
4
- import { BinaryNode } from '../WABinary';
5
- /**
6
- * Connects to WA servers and performs:
7
- * - simple queries (no retry mechanism, wait for connection establishment)
8
- * - listen to messages and emit events
9
- * - query phone connection
10
- */
11
- export declare const makeSocket: (config: SocketConfig) => {
12
- type: "md";
13
- ws: any;
14
- ev: import("../Types").BaileysEventEmitter & {
15
- process(handler: (events: Partial<import("../Types").BaileysEventMap>) => void | Promise<void>): () => void;
16
- buffer(): void;
17
- createBufferedFunction<A extends any[], T>(work: (...args: A) => Promise<T>): (...args: A) => Promise<T>;
18
- flush(force?: boolean | undefined): boolean;
19
- isBuffering(): boolean;
20
- };
21
- authState: {
22
- creds: import("../Types").AuthenticationCreds;
23
- keys: import("../Types").SignalKeyStoreWithTransaction;
24
- };
25
- signalRepository: import("../Types").SignalRepository;
26
- readonly user: import("../Types").Contact | undefined;
27
- generateMessageTag: () => string;
28
- query: (node: BinaryNode, timeoutMs?: number) => Promise<BinaryNode>;
29
- waitForMessage: <T_1>(msgId: string, timeoutMs?: number | undefined) => Promise<T_1>;
30
- waitForSocketOpen: () => Promise<void>;
31
- sendRawMessage: (data: Uint8Array | Buffer) => Promise<void>;
32
- sendNode: (frame: BinaryNode) => Promise<void>;
33
- logout: (msg?: string) => Promise<void>;
34
- end: (error: Error | undefined) => void;
35
- onUnexpectedError: (err: Error | Boom, msg: string) => void;
36
- uploadPreKeys: (count?: number) => Promise<void>;
37
- uploadPreKeysToServerIfRequired: () => Promise<void>;
38
- requestPairingCode: (phoneNumber: string) => Promise<string>;
39
- /** Waits for the connection to WA to reach a state */
40
- waitForConnectionUpdate: (check: (u: Partial<import("../Types").ConnectionState>) => boolean | undefined, timeoutMs?: number | undefined) => Promise<void>;
41
- sendWAMBuffer: (wamBuffer: Buffer) => Promise<BinaryNode>;
42
- };
43
- export type Socket = ReturnType<typeof makeSocket>;
@@ -1,3 +0,0 @@
1
- import makeCacheManagerAuthState from './make-cache-manager-store';
2
- import makeInMemoryStore from './make-in-memory-store';
3
- export { makeInMemoryStore, makeCacheManagerAuthState };
@@ -1,13 +0,0 @@
1
- import { AuthenticationCreds } from '../Types';
2
- declare const makeCacheManagerAuthState: (store: Storage, sessionKey: string) => Promise<{
3
- clearState: () => Promise<void>;
4
- saveCreds: () => Promise<void>;
5
- state: {
6
- creds: AuthenticationCreds;
7
- keys: {
8
- get: (type: string, ids: string[]) => Promise<{}>;
9
- set: (data: any) => Promise<void>;
10
- };
11
- };
12
- }>;
13
- export default makeCacheManagerAuthState;
@@ -1,118 +0,0 @@
1
- import type KeyedDB from '@adiwajshing/keyed-db';
2
- import type { Comparable } from '@adiwajshing/keyed-db/lib/Types';
3
- import type { Logger } from 'pino';
4
- import { proto } from '../../WAProto';
5
- import type makeMDSocket from '../Socket';
6
- import type { BaileysEventEmitter, Chat, ConnectionState, Contact, GroupMetadata, PresenceData, WAMessage, WAMessageCursor, WAMessageKey } from '../Types';
7
- import { Label } from '../Types/Label';
8
- import { LabelAssociation } from '../Types/LabelAssociation';
9
- import { ObjectRepository } from './object-repository';
10
- type WASocket = ReturnType<typeof makeMDSocket>;
11
- export declare const waChatKey: (pin: boolean) => {
12
- key: (c: Chat) => string;
13
- compare: (k1: string, k2: string) => number;
14
- };
15
- export declare const waMessageID: (m: WAMessage) => string;
16
- export declare const waLabelAssociationKey: Comparable<LabelAssociation, string>;
17
- export type BaileysInMemoryStoreConfig = {
18
- chatKey?: Comparable<Chat, string>;
19
- labelAssociationKey?: Comparable<LabelAssociation, string>;
20
- logger?: Logger;
21
- socket?: WASocket;
22
- };
23
- declare const _default: (config: BaileysInMemoryStoreConfig) => {
24
- chats: KeyedDB<Chat, string>;
25
- contacts: {
26
- [_: string]: Contact;
27
- };
28
- messages: {
29
- [_: string]: {
30
- array: proto.IWebMessageInfo[];
31
- get: (id: string) => proto.IWebMessageInfo | undefined;
32
- upsert: (item: proto.IWebMessageInfo, mode: "append" | "prepend") => void;
33
- update: (item: proto.IWebMessageInfo) => boolean;
34
- remove: (item: proto.IWebMessageInfo) => boolean;
35
- updateAssign: (id: string, update: Partial<proto.IWebMessageInfo>) => boolean;
36
- clear: () => void;
37
- filter: (contain: (item: proto.IWebMessageInfo) => boolean) => void;
38
- toJSON: () => proto.IWebMessageInfo[];
39
- fromJSON: (newItems: proto.IWebMessageInfo[]) => void;
40
- };
41
- };
42
- groupMetadata: {
43
- [_: string]: GroupMetadata;
44
- };
45
- state: ConnectionState;
46
- presences: {
47
- [id: string]: {
48
- [participant: string]: PresenceData;
49
- };
50
- };
51
- labels: ObjectRepository<Label>;
52
- labelAssociations: KeyedDB<LabelAssociation, string>;
53
- bind: (ev: BaileysEventEmitter) => void;
54
- /** loads messages from the store, if not found -- uses the legacy connection */
55
- loadMessages: (jid: string, count: number, cursor: WAMessageCursor) => Promise<proto.IWebMessageInfo[]>;
56
- /**
57
- * Get all available labels for profile
58
- *
59
- * Keep in mind that the list is formed from predefined tags and tags
60
- * that were "caught" during their editing.
61
- */
62
- getLabels: () => ObjectRepository<Label>;
63
- /**
64
- * Get labels for chat
65
- *
66
- * @returns Label IDs
67
- **/
68
- getChatLabels: (chatId: string) => LabelAssociation[];
69
- /**
70
- * Get labels for message
71
- *
72
- * @returns Label IDs
73
- **/
74
- getMessageLabels: (messageId: string) => string[];
75
- loadMessage: (jid: string, id: string) => Promise<proto.IWebMessageInfo | undefined>;
76
- mostRecentMessage: (jid: string) => Promise<proto.IWebMessageInfo>;
77
- fetchImageUrl: (jid: string, sock: WASocket | undefined) => Promise<string | null | undefined>;
78
- fetchGroupMetadata: (jid: string, sock: WASocket | undefined) => Promise<GroupMetadata>;
79
- fetchMessageReceipts: ({ remoteJid, id }: WAMessageKey) => Promise<proto.IUserReceipt[] | null | undefined>;
80
- toJSON: () => {
81
- chats: KeyedDB<Chat, string>;
82
- contacts: {
83
- [_: string]: Contact;
84
- };
85
- messages: {
86
- [_: string]: {
87
- array: proto.IWebMessageInfo[];
88
- get: (id: string) => proto.IWebMessageInfo | undefined;
89
- upsert: (item: proto.IWebMessageInfo, mode: "append" | "prepend") => void;
90
- update: (item: proto.IWebMessageInfo) => boolean;
91
- remove: (item: proto.IWebMessageInfo) => boolean;
92
- updateAssign: (id: string, update: Partial<proto.IWebMessageInfo>) => boolean;
93
- clear: () => void;
94
- filter: (contain: (item: proto.IWebMessageInfo) => boolean) => void;
95
- toJSON: () => proto.IWebMessageInfo[];
96
- fromJSON: (newItems: proto.IWebMessageInfo[]) => void;
97
- };
98
- };
99
- labels: ObjectRepository<Label>;
100
- labelAssociations: KeyedDB<LabelAssociation, string>;
101
- };
102
- fromJSON: (json: {
103
- chats: Chat[];
104
- contacts: {
105
- [id: string]: Contact;
106
- };
107
- messages: {
108
- [id: string]: proto.IWebMessageInfo[];
109
- };
110
- labels: {
111
- [labelId: string]: Label;
112
- };
113
- labelAssociations: LabelAssociation[];
114
- }) => void;
115
- writeToFile: (path: string) => void;
116
- readFromFile: (path: string) => void;
117
- };
118
- export default _default;
@@ -1,13 +0,0 @@
1
- declare function makeOrderedDictionary<T>(idGetter: (item: T) => string): {
2
- array: T[];
3
- get: (id: string) => T | undefined;
4
- upsert: (item: T, mode: 'append' | 'prepend') => void;
5
- update: (item: T) => boolean;
6
- remove: (item: T) => boolean;
7
- updateAssign: (id: string, update: Partial<T>) => boolean;
8
- clear: () => void;
9
- filter: (contain: (item: T) => boolean) => void;
10
- toJSON: () => T[];
11
- fromJSON: (newItems: T[]) => void;
12
- };
13
- export default makeOrderedDictionary;
@@ -1,10 +0,0 @@
1
- export declare class ObjectRepository<T extends object> {
2
- readonly entityMap: Map<string, T>;
3
- constructor(entities?: Record<string, T>);
4
- findById(id: string): T | undefined;
5
- findAll(): T[];
6
- upsertById(id: string, entity: T): Map<string, T>;
7
- deleteById(id: string): boolean;
8
- count(): number;
9
- toJSON(): T[];
10
- }