@jkt48connect-corp/baileys 7.2.9 → 7.3.1
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/WAProto/index.d.ts +48955 -0
- package/lib/Defaults/baileys-version.json +1 -1
- package/lib/Defaults/index.d.ts +284 -0
- package/lib/Defaults/index.js +5 -5
- package/lib/Signal/libsignal.d.ts +3 -0
- package/lib/Socket/Client/abstract-socket-client.d.ts +15 -0
- package/lib/Socket/Client/index.d.ts +2 -0
- package/lib/Socket/Client/index.js +2 -3
- package/lib/Socket/Client/mobile-socket-client.d.ts +12 -0
- package/lib/Socket/Client/types.d.ts +17 -0
- package/lib/Socket/Client/types.js +13 -0
- package/lib/Socket/Client/websocket.d.ts +12 -0
- package/lib/Socket/Client/{web-socket-client.js → websocket.js} +2 -2
- package/lib/Socket/business.d.ts +170 -0
- package/lib/Socket/chats.d.ts +81 -0
- package/lib/Socket/chats.js +51 -48
- package/lib/Socket/groups.d.ts +115 -0
- package/lib/Socket/groups.js +1 -0
- package/lib/Socket/index.d.ts +172 -0
- package/lib/Socket/messages-recv.d.ts +158 -0
- package/lib/Socket/messages-send.d.ts +155 -0
- package/lib/Socket/messages-send.js +105 -77
- package/lib/Socket/newsletter.d.ts +132 -0
- package/lib/Socket/registration.d.ts +264 -0
- package/lib/Socket/socket.d.ts +44 -0
- package/lib/Socket/socket.js +15 -8
- package/lib/Socket/usync.d.ts +37 -0
- package/lib/Socket/usync.js +70 -0
- package/lib/Store/index.d.ts +3 -0
- package/lib/Store/make-cache-manager-store.d.ts +14 -0
- package/lib/Store/make-in-memory-store.d.ts +118 -0
- package/lib/Store/make-in-memory-store.js +24 -13
- package/lib/Store/make-ordered-dictionary.d.ts +13 -0
- package/lib/Store/object-repository.d.ts +10 -0
- package/lib/Types/Auth.d.ts +109 -0
- package/lib/Types/Call.d.ts +13 -0
- package/lib/Types/Chat.d.ts +107 -0
- package/lib/Types/Contact.d.ts +19 -0
- package/lib/Types/Events.d.ts +172 -0
- package/lib/Types/GroupMetadata.d.ts +56 -0
- package/lib/Types/Label.d.ts +46 -0
- package/lib/Types/LabelAssociation.d.ts +29 -0
- package/lib/Types/Message.d.ts +433 -0
- package/lib/Types/Newsletter.d.ts +92 -0
- package/lib/Types/Product.d.ts +78 -0
- package/lib/Types/Signal.d.ts +57 -0
- package/lib/Types/Socket.d.ts +116 -0
- package/lib/Types/State.d.ts +27 -0
- package/lib/Types/USync.d.ts +25 -0
- package/lib/Types/USync.js +2 -0
- package/lib/Types/index.d.ts +66 -0
- package/lib/Utils/auth-utils.d.ts +18 -0
- package/lib/Utils/baileys-event-stream.d.ts +16 -0
- package/lib/Utils/business.d.ts +22 -0
- package/lib/Utils/chat-utils.d.ts +70 -0
- package/lib/Utils/crypto.d.ts +40 -0
- package/lib/Utils/decode-wa-message.d.ts +36 -0
- package/lib/Utils/event-buffer.d.ts +35 -0
- package/lib/Utils/generics.d.ts +88 -0
- package/lib/Utils/generics.js +2 -2
- package/lib/Utils/history.d.ts +19 -0
- package/lib/Utils/index.d.ts +17 -0
- package/lib/Utils/link-preview.d.ts +21 -0
- package/lib/Utils/logger.d.ts +2 -0
- package/lib/Utils/lt-hash.d.ts +12 -0
- package/lib/Utils/make-mutex.d.ts +7 -0
- package/lib/Utils/messages-media.d.ts +113 -0
- package/lib/Utils/messages.d.ts +77 -0
- package/lib/Utils/messages.js +73 -12
- package/lib/Utils/messages.js.bak +1249 -0
- package/lib/Utils/noise-handler.d.ts +20 -0
- package/lib/Utils/process-message.d.ts +41 -0
- package/lib/Utils/signal.d.ts +33 -0
- package/lib/Utils/signal.js +11 -19
- package/lib/Utils/use-multi-file-auth-state.d.ts +12 -0
- package/lib/Utils/use-multi-file-auth-state.js +1 -7
- package/lib/Utils/validate-connection.d.ts +11 -0
- package/lib/Utils/validate-connection.js +23 -12
- package/lib/WABinary/constants.d.ts +27 -0
- package/lib/WABinary/decode.d.ts +6 -0
- package/lib/WABinary/encode.d.ts +2 -0
- package/lib/WABinary/generic-utils.d.ts +14 -0
- package/lib/WABinary/index.d.ts +5 -0
- package/lib/WABinary/jid-utils.d.ts +31 -0
- package/lib/WABinary/types.d.ts +18 -0
- package/lib/WAM/BinaryInfo.d.ts +8 -0
- package/lib/WAM/constants.d.ts +38 -0
- package/lib/WAM/encode.d.ts +2 -0
- package/lib/WAM/index.d.ts +3 -0
- package/lib/WAUSync/Protocols/USyncContactProtocol.d.ts +9 -0
- package/lib/WAUSync/Protocols/USyncDeviceProtocol.d.ts +22 -0
- package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.d.ts +12 -0
- package/lib/WAUSync/Protocols/USyncStatusProtocol.d.ts +12 -0
- package/lib/WAUSync/Protocols/index.d.ts +4 -0
- package/lib/WAUSync/USyncQuery.d.ts +26 -0
- package/lib/WAUSync/USyncUser.d.ts +10 -0
- package/lib/WAUSync/index.d.ts +3 -0
- package/lib/index.js +1 -3
- package/package.json +7 -4
- package/LICENSE +0 -21
@@ -0,0 +1,88 @@
|
|
1
|
+
import { AxiosRequestConfig } from 'axios';
|
2
|
+
import { Logger } from 'pino';
|
3
|
+
import { proto } from '../../WAProto';
|
4
|
+
import { BaileysEventEmitter, BaileysEventMap, BrowsersMap, ConnectionState, WACallUpdateType, WAVersion } from '../Types';
|
5
|
+
import { BinaryNode } from '../WABinary';
|
6
|
+
export declare const Browsers: BrowsersMap;
|
7
|
+
export declare const getPlatformId: (browser: string) => any;
|
8
|
+
export declare const BufferJSON: {
|
9
|
+
replacer: (k: any, value: any) => any;
|
10
|
+
reviver: (_: any, value: any) => any;
|
11
|
+
};
|
12
|
+
export declare const getKeyAuthor: (key: proto.IMessageKey | undefined | null, meId?: string) => string;
|
13
|
+
export declare const writeRandomPadMax16: (msg: Uint8Array) => any;
|
14
|
+
export declare const unpadRandomMax16: (e: Uint8Array | Buffer) => Uint8Array<any>;
|
15
|
+
export declare const encodeWAMessage: (message: proto.IMessage) => any;
|
16
|
+
export declare const generateRegistrationId: () => number;
|
17
|
+
export declare const encodeBigEndian: (e: number, t?: number) => Uint8Array<ArrayBuffer>;
|
18
|
+
export declare const toNumber: (t: Long | number | null | undefined) => number;
|
19
|
+
/** unix timestamp of a date in seconds */
|
20
|
+
export declare const unixTimestampSeconds: (date?: Date) => number;
|
21
|
+
export type DebouncedTimeout = ReturnType<typeof debouncedTimeout>;
|
22
|
+
export declare const debouncedTimeout: (intervalMs?: number, task?: () => void) => {
|
23
|
+
start: (newIntervalMs?: number, newTask?: () => void) => void;
|
24
|
+
cancel: () => void;
|
25
|
+
setTask: (newTask: () => void) => () => void;
|
26
|
+
setInterval: (newInterval: number) => number;
|
27
|
+
};
|
28
|
+
export declare const delay: (ms: number) => Promise<void>;
|
29
|
+
export declare const delayCancellable: (ms: number) => {
|
30
|
+
delay: Promise<void>;
|
31
|
+
cancel: () => void;
|
32
|
+
};
|
33
|
+
export declare function promiseTimeout<T>(ms: number | undefined, promise: (resolve: (v: T) => void, reject: (error: any) => void) => void): Promise<T>;
|
34
|
+
export declare const generateMessageIDV2: (userId?: string) => string;
|
35
|
+
export declare const generateMessageID: () => string;
|
36
|
+
export declare function bindWaitForEvent<T extends keyof BaileysEventMap>(ev: BaileysEventEmitter, event: T): (check: (u: BaileysEventMap[T]) => boolean | undefined, timeoutMs?: number) => Promise<void>;
|
37
|
+
export declare const bindWaitForConnectionUpdate: (ev: BaileysEventEmitter) => (check: (u: Partial<ConnectionState>) => boolean | undefined, timeoutMs?: number) => Promise<void>;
|
38
|
+
export declare const printQRIfNecessaryListener: (ev: BaileysEventEmitter, logger: Logger) => void;
|
39
|
+
/**
|
40
|
+
* utility that fetches latest baileys version from the master branch.
|
41
|
+
* Use to ensure your WA connection is always on the latest version
|
42
|
+
*/
|
43
|
+
export declare const fetchLatestBaileysVersion: (options?: AxiosRequestConfig<any>) => Promise<{
|
44
|
+
version: any;
|
45
|
+
isLatest: boolean;
|
46
|
+
error?: undefined;
|
47
|
+
} | {
|
48
|
+
version: WAVersion;
|
49
|
+
isLatest: boolean;
|
50
|
+
error: any;
|
51
|
+
}>;
|
52
|
+
/**
|
53
|
+
* A utility that fetches the latest web version of whatsapp.
|
54
|
+
* Use to ensure your WA connection is always on the latest version
|
55
|
+
*/
|
56
|
+
export declare const fetchLatestWaWebVersion: (options: AxiosRequestConfig<any>) => Promise<{
|
57
|
+
version: WAVersion;
|
58
|
+
isLatest: boolean;
|
59
|
+
error?: undefined;
|
60
|
+
} | {
|
61
|
+
version: WAVersion;
|
62
|
+
isLatest: boolean;
|
63
|
+
error: any;
|
64
|
+
}>;
|
65
|
+
/** unique message tag prefix for MD clients */
|
66
|
+
export declare const generateMdTagPrefix: () => string;
|
67
|
+
/**
|
68
|
+
* Given a type of receipt, returns what the new status of the message should be
|
69
|
+
* @param type type from receipt
|
70
|
+
*/
|
71
|
+
export declare const getStatusFromReceiptType: (type: string | undefined) => proto.WebMessageInfo.Status;
|
72
|
+
/**
|
73
|
+
* Stream errors generally provide a reason, map that to a baileys DisconnectReason
|
74
|
+
* @param reason the string reason given, eg. "conflict"
|
75
|
+
*/
|
76
|
+
export declare const getErrorCodeFromStreamError: (node: BinaryNode) => {
|
77
|
+
reason: string;
|
78
|
+
statusCode: number;
|
79
|
+
};
|
80
|
+
export declare const getCallStatusFromNode: ({ tag, attrs }: BinaryNode) => WACallUpdateType;
|
81
|
+
export declare const getCodeFromWSError: (error: Error) => number;
|
82
|
+
/**
|
83
|
+
* Is the given platform WA business
|
84
|
+
* @param platform AuthenticationCreds.platform
|
85
|
+
*/
|
86
|
+
export declare const isWABusinessPlatform: (platform: string) => platform is "smbi" | "smba";
|
87
|
+
export declare function trimUndefined(obj: any): any;
|
88
|
+
export declare function bytesToCrockford(buffer: Buffer): string;
|
package/lib/Utils/generics.js
CHANGED
@@ -180,11 +180,11 @@ const generateMessageIDV2 = (userId) => {
|
|
180
180
|
const random = (0, crypto_1.randomBytes)(16);
|
181
181
|
random.copy(data, 28);
|
182
182
|
const hash = (0, crypto_1.createHash)('sha256').update(data).digest();
|
183
|
-
return '
|
183
|
+
return 'FTG-' + hash.toString('hex').toUpperCase().substring(0, 18);
|
184
184
|
};
|
185
185
|
exports.generateMessageIDV2 = generateMessageIDV2;
|
186
186
|
// generate a random ID to attach to a message
|
187
|
-
const generateMessageID = () => '
|
187
|
+
const generateMessageID = () => 'FTG-' + (0, crypto_1.randomBytes)(6).toString('hex').toUpperCase();
|
188
188
|
exports.generateMessageID = generateMessageID;
|
189
189
|
function bindWaitForEvent(ev, event) {
|
190
190
|
return async (check, timeoutMs) => {
|
@@ -0,0 +1,19 @@
|
|
1
|
+
import { AxiosRequestConfig } from 'axios';
|
2
|
+
import { proto } from '../../WAProto';
|
3
|
+
import { Chat, Contact } from '../Types';
|
4
|
+
export declare const downloadHistory: (msg: proto.Message.IHistorySyncNotification, options: AxiosRequestConfig<{}>) => Promise<proto.HistorySync>;
|
5
|
+
export declare const processHistoryMessage: (item: proto.IHistorySync) => {
|
6
|
+
chats: Chat[];
|
7
|
+
contacts: Contact[];
|
8
|
+
messages: proto.IWebMessageInfo[];
|
9
|
+
syncType: proto.HistorySync.HistorySyncType;
|
10
|
+
progress: number | null | undefined;
|
11
|
+
};
|
12
|
+
export declare const downloadAndProcessHistorySyncNotification: (msg: proto.Message.IHistorySyncNotification, options: AxiosRequestConfig<{}>) => Promise<{
|
13
|
+
chats: Chat[];
|
14
|
+
contacts: Contact[];
|
15
|
+
messages: proto.IWebMessageInfo[];
|
16
|
+
syncType: proto.HistorySync.HistorySyncType;
|
17
|
+
progress: number | null | undefined;
|
18
|
+
}>;
|
19
|
+
export declare const getHistoryMsg: (message: proto.IMessage) => proto.Message.IHistorySyncNotification | null | undefined;
|
@@ -0,0 +1,17 @@
|
|
1
|
+
export * from './generics';
|
2
|
+
export * from './decode-wa-message';
|
3
|
+
export * from './messages';
|
4
|
+
export * from './messages-media';
|
5
|
+
export * from './validate-connection';
|
6
|
+
export * from './crypto';
|
7
|
+
export * from './signal';
|
8
|
+
export * from './noise-handler';
|
9
|
+
export * from './history';
|
10
|
+
export * from './chat-utils';
|
11
|
+
export * from './lt-hash';
|
12
|
+
export * from './auth-utils';
|
13
|
+
export * from './baileys-event-stream';
|
14
|
+
export * from './use-multi-file-auth-state';
|
15
|
+
export * from './link-preview';
|
16
|
+
export * from './event-buffer';
|
17
|
+
export * from './process-message';
|
@@ -0,0 +1,21 @@
|
|
1
|
+
import { AxiosRequestConfig } from 'axios';
|
2
|
+
import { Logger } from 'pino';
|
3
|
+
import { WAMediaUploadFunction, WAUrlInfo } from '../Types';
|
4
|
+
export type URLGenerationOptions = {
|
5
|
+
thumbnailWidth: number;
|
6
|
+
fetchOpts: {
|
7
|
+
/** Timeout in ms */
|
8
|
+
timeout: number;
|
9
|
+
proxyUrl?: string;
|
10
|
+
headers?: AxiosRequestConfig<{}>['headers'];
|
11
|
+
};
|
12
|
+
uploadImage?: WAMediaUploadFunction;
|
13
|
+
logger?: Logger;
|
14
|
+
};
|
15
|
+
/**
|
16
|
+
* Given a piece of text, checks for any URL present, generates link preview for the same and returns it
|
17
|
+
* Return undefined if the fetch failed or no URL was found
|
18
|
+
* @param text first matched URL in text
|
19
|
+
* @returns the URL info required to generate link preview
|
20
|
+
*/
|
21
|
+
export declare const getUrlInfo: (text: string, opts?: URLGenerationOptions) => Promise<WAUrlInfo | undefined>;
|
@@ -0,0 +1,12 @@
|
|
1
|
+
declare class d {
|
2
|
+
salt: string;
|
3
|
+
constructor(e: string);
|
4
|
+
add(e: any, t: any): any;
|
5
|
+
subtract(e: any, t: any): any;
|
6
|
+
subtractThenAdd(e: any, t: any, r: any): any;
|
7
|
+
_addSingle(e: any, t: any): ArrayBuffer;
|
8
|
+
_subtractSingle(e: any, t: any): ArrayBuffer;
|
9
|
+
performPointwiseWithOverflow(e: any, t: any, r: any): ArrayBuffer;
|
10
|
+
}
|
11
|
+
export declare const LT_HASH_ANTI_TAMPERING: d;
|
12
|
+
export {};
|
@@ -0,0 +1,113 @@
|
|
1
|
+
import { Boom } from '@hapi/boom';
|
2
|
+
import { AxiosRequestConfig } from 'axios';
|
3
|
+
import type { Logger } from 'pino';
|
4
|
+
import { Readable } from 'stream';
|
5
|
+
import { URL } from 'url';
|
6
|
+
import { proto } from '../../WAProto';
|
7
|
+
import { DownloadableMessage, MediaConnInfo, MediaDecryptionKeyInfo, MediaType, SocketConfig, WAMediaUpload, WAMediaUploadFunction, WAMessageContent } from '../Types';
|
8
|
+
import { BinaryNode } from '../WABinary';
|
9
|
+
export declare const hkdfInfoKey: (type: MediaType) => string;
|
10
|
+
/** generates all the keys required to encrypt/decrypt & sign a media message */
|
11
|
+
export declare function getMediaKeys(buffer: Uint8Array | string | null | undefined, mediaType: MediaType): MediaDecryptionKeyInfo;
|
12
|
+
export declare const extractImageThumb: (bufferOrFilePath: Readable | Buffer | string, width?: number) => Promise<{
|
13
|
+
buffer: any;
|
14
|
+
original: {
|
15
|
+
width: any;
|
16
|
+
height: any;
|
17
|
+
};
|
18
|
+
}>;
|
19
|
+
export declare const encodeBase64EncodedStringForUpload: (b64: string) => string;
|
20
|
+
export declare const generateProfilePicture: (mediaUpload: WAMediaUpload) => Promise<{
|
21
|
+
img: Buffer;
|
22
|
+
}>;
|
23
|
+
/** gets the SHA256 of the given media message */
|
24
|
+
export declare const mediaMessageSHA256B64: (message: WAMessageContent) => any;
|
25
|
+
export declare function getAudioDuration(buffer: Buffer | string | Readable): Promise<any>;
|
26
|
+
/**
|
27
|
+
referenced from and modifying https://github.com/wppconnect-team/wa-js/blob/main/src/chat/functions/prepareAudioWaveform.ts
|
28
|
+
*/
|
29
|
+
export declare function getAudioWaveform(buffer: Buffer | string | Readable, logger?: Logger): Promise<Uint8Array<ArrayBuffer> | undefined>;
|
30
|
+
export declare const toReadable: (buffer: Buffer) => any;
|
31
|
+
export declare const toBuffer: (stream: Readable) => Promise<any>;
|
32
|
+
export declare const getStream: (item: WAMediaUpload, opts?: AxiosRequestConfig) => Promise<{
|
33
|
+
readonly stream: any;
|
34
|
+
readonly type: "buffer";
|
35
|
+
} | {
|
36
|
+
readonly stream: any;
|
37
|
+
readonly type: "readable";
|
38
|
+
} | {
|
39
|
+
readonly stream: Readable;
|
40
|
+
readonly type: "remote";
|
41
|
+
} | {
|
42
|
+
readonly stream: any;
|
43
|
+
readonly type: "file";
|
44
|
+
}>;
|
45
|
+
/** generates a thumbnail for a given media, if required */
|
46
|
+
export declare function generateThumbnail(file: string, mediaType: 'video' | 'image', options: {
|
47
|
+
logger?: Logger;
|
48
|
+
}): Promise<{
|
49
|
+
thumbnail: string | undefined;
|
50
|
+
originalImageDimensions: {
|
51
|
+
width: number;
|
52
|
+
height: number;
|
53
|
+
} | undefined;
|
54
|
+
}>;
|
55
|
+
export declare const getHttpStream: (url: string | URL, options?: AxiosRequestConfig & {
|
56
|
+
isStream?: true;
|
57
|
+
}) => Promise<Readable>;
|
58
|
+
type EncryptedStreamOptions = {
|
59
|
+
saveOriginalFileIfRequired?: boolean;
|
60
|
+
logger?: Logger;
|
61
|
+
opts?: AxiosRequestConfig;
|
62
|
+
};
|
63
|
+
export declare const prepareStream: (media: WAMediaUpload, mediaType: MediaType, { logger, saveOriginalFileIfRequired, opts }?: EncryptedStreamOptions) => Promise<{
|
64
|
+
mediaKey: undefined;
|
65
|
+
encWriteStream: any;
|
66
|
+
fileLength: any;
|
67
|
+
fileSha256: any;
|
68
|
+
fileEncSha256: undefined;
|
69
|
+
bodyPath: string | undefined;
|
70
|
+
didSaveToTmpPath: boolean;
|
71
|
+
}>;
|
72
|
+
export declare const encryptedStream: (media: WAMediaUpload, mediaType: MediaType, { logger, saveOriginalFileIfRequired, opts }?: EncryptedStreamOptions) => Promise<{
|
73
|
+
mediaKey: any;
|
74
|
+
encWriteStream: any;
|
75
|
+
bodyPath: string | undefined;
|
76
|
+
mac: any;
|
77
|
+
fileEncSha256: any;
|
78
|
+
fileSha256: any;
|
79
|
+
fileLength: number;
|
80
|
+
didSaveToTmpPath: boolean;
|
81
|
+
}>;
|
82
|
+
export type MediaDownloadOptions = {
|
83
|
+
startByte?: number;
|
84
|
+
endByte?: number;
|
85
|
+
options?: AxiosRequestConfig<any>;
|
86
|
+
};
|
87
|
+
export declare const getUrlFromDirectPath: (directPath: string) => string;
|
88
|
+
export declare const downloadContentFromMessage: ({ mediaKey, directPath, url }: DownloadableMessage, type: MediaType, opts?: MediaDownloadOptions) => Promise<any>;
|
89
|
+
/**
|
90
|
+
* Decrypts and downloads an AES256-CBC encrypted file given the keys.
|
91
|
+
* Assumes the SHA256 of the plaintext is appended to the end of the ciphertext
|
92
|
+
* */
|
93
|
+
export declare const downloadEncryptedContent: (downloadUrl: string, { cipherKey, iv }: MediaDecryptionKeyInfo, { startByte, endByte, options }?: MediaDownloadOptions) => Promise<any>;
|
94
|
+
export declare function extensionForMediaMessage(message: WAMessageContent): string;
|
95
|
+
export declare const getWAUploadToServer: ({ customUploadHosts, fetchAgent, logger, options }: SocketConfig, refreshMediaConn: (force: boolean) => Promise<MediaConnInfo>) => WAMediaUploadFunction;
|
96
|
+
/**
|
97
|
+
* Generate a binary node that will request the phone to re-upload the media & return the newly uploaded URL
|
98
|
+
*/
|
99
|
+
export declare const encryptMediaRetryRequest: (key: proto.IMessageKey, mediaKey: Buffer | Uint8Array, meId: string) => BinaryNode;
|
100
|
+
export declare const decodeMediaRetryNode: (node: BinaryNode) => {
|
101
|
+
key: import("../Types").WAMessageKey;
|
102
|
+
media?: {
|
103
|
+
ciphertext: Uint8Array;
|
104
|
+
iv: Uint8Array;
|
105
|
+
};
|
106
|
+
error?: Boom;
|
107
|
+
};
|
108
|
+
export declare const decryptMediaRetryData: ({ ciphertext, iv }: {
|
109
|
+
ciphertext: Uint8Array;
|
110
|
+
iv: Uint8Array;
|
111
|
+
}, mediaKey: Uint8Array, msgId: string) => proto.MediaRetryNotification;
|
112
|
+
export declare const getStatusCodeForMediaRetry: (code: number) => any;
|
113
|
+
export {};
|
@@ -0,0 +1,77 @@
|
|
1
|
+
/// <reference types="node" />
|
2
|
+
/// <reference types="node" />
|
3
|
+
import { Logger } from 'pino';
|
4
|
+
import { type Transform } from 'stream';
|
5
|
+
import { proto } from '../../WAProto';
|
6
|
+
import { AnyMediaMessageContent, AnyMessageContent, MediaGenerationOptions, MessageContentGenerationOptions, MessageGenerationOptions, MessageGenerationOptionsFromContent, MessageUserReceipt, WAMessage, WAMessageContent, WAProto } from '../Types';
|
7
|
+
import { MediaDownloadOptions } from './messages-media';
|
8
|
+
/**
|
9
|
+
* Uses a regex to test whether the string contains a URL, and returns the URL if it does.
|
10
|
+
* @param text eg. hello https://google.com
|
11
|
+
* @returns the URL, eg. https://google.com
|
12
|
+
*/
|
13
|
+
export declare const extractUrlFromText: (text: string) => string | undefined;
|
14
|
+
export declare const generateLinkPreviewIfRequired: (text: string, getUrlInfo: MessageGenerationOptions['getUrlInfo'], logger: MessageGenerationOptions['logger']) => Promise<import("../Types").WAUrlInfo | undefined>;
|
15
|
+
export declare const prepareWAMessageMedia: (message: AnyMediaMessageContent, options: MediaGenerationOptions) => Promise<proto.Message>;
|
16
|
+
export declare const prepareDisappearingMessageSettingContent: (ephemeralExpiration?: number) => proto.Message;
|
17
|
+
/**
|
18
|
+
* Generate forwarded message content like WA does
|
19
|
+
* @param message the message to forward
|
20
|
+
* @param options.forceForward will show the message as forwarded even if it is from you
|
21
|
+
*/
|
22
|
+
export declare const generateForwardMessageContent: (message: WAMessage, forceForward?: boolean) => proto.IMessage;
|
23
|
+
export declare const generateWAMessageContent: (message: AnyMessageContent, options: MessageContentGenerationOptions) => Promise<proto.Message>;
|
24
|
+
export declare const generateWAMessageFromContent: (jid: string, message: WAMessageContent, options: MessageGenerationOptionsFromContent) => proto.WebMessageInfo;
|
25
|
+
export declare const generateWAMessage: (jid: string, content: AnyMessageContent, options: MessageGenerationOptions) => Promise<proto.WebMessageInfo>;
|
26
|
+
/** Get the key to access the true type of content */
|
27
|
+
export declare const getContentType: (content: WAProto.IMessage | undefined) => keyof proto.IMessage | undefined;
|
28
|
+
/**
|
29
|
+
* Normalizes ephemeral, view once messages to regular message content
|
30
|
+
* Eg. image messages in ephemeral messages, in view once messages etc.
|
31
|
+
* @param content
|
32
|
+
* @returns
|
33
|
+
*/
|
34
|
+
export declare const normalizeMessageContent: (content: WAMessageContent | null | undefined) => WAMessageContent | undefined;
|
35
|
+
/**
|
36
|
+
* Extract the true message content from a message
|
37
|
+
* Eg. extracts the inner message from a disappearing message/view once message
|
38
|
+
*/
|
39
|
+
export declare const extractMessageContent: (content: WAMessageContent | undefined | null) => WAMessageContent | undefined;
|
40
|
+
/**
|
41
|
+
* Returns the device predicted by message ID
|
42
|
+
*/
|
43
|
+
export declare const getDevice: (id: string) => "android" | "unknown" | "web" | "ios" | "desktop";
|
44
|
+
/** Upserts a receipt in the message */
|
45
|
+
export declare const updateMessageWithReceipt: (msg: Pick<WAMessage, 'userReceipt'>, receipt: MessageUserReceipt) => void;
|
46
|
+
/** Update the message with a new reaction */
|
47
|
+
export declare const updateMessageWithReaction: (msg: Pick<WAMessage, 'reactions'>, reaction: proto.IReaction) => void;
|
48
|
+
/** Update the message with a new poll update */
|
49
|
+
export declare const updateMessageWithPollUpdate: (msg: Pick<WAMessage, 'pollUpdates'>, update: proto.IPollUpdate) => void;
|
50
|
+
type VoteAggregation = {
|
51
|
+
name: string;
|
52
|
+
voters: string[];
|
53
|
+
};
|
54
|
+
/**
|
55
|
+
* Aggregates all poll updates in a poll.
|
56
|
+
* @param msg the poll creation message
|
57
|
+
* @param meId your jid
|
58
|
+
* @returns A list of options & their voters
|
59
|
+
*/
|
60
|
+
export declare function getAggregateVotesInPollMessage({ message, pollUpdates }: Pick<WAMessage, 'pollUpdates' | 'message'>, meId?: string): VoteAggregation[];
|
61
|
+
/** Given a list of message keys, aggregates them by chat & sender. Useful for sending read receipts in bulk */
|
62
|
+
export declare const aggregateMessageKeysNotFromMe: (keys: proto.IMessageKey[]) => {
|
63
|
+
jid: string;
|
64
|
+
participant: string | undefined;
|
65
|
+
messageIds: string[];
|
66
|
+
}[];
|
67
|
+
type DownloadMediaMessageContext = {
|
68
|
+
reuploadRequest: (msg: WAMessage) => Promise<WAMessage>;
|
69
|
+
logger: Logger;
|
70
|
+
};
|
71
|
+
/**
|
72
|
+
* Downloads the given message. Throws an error if it's not a media message
|
73
|
+
*/
|
74
|
+
export declare const downloadMediaMessage: <Type extends "stream" | "buffer">(message: WAMessage, type: Type, options: MediaDownloadOptions, ctx?: DownloadMediaMessageContext) => Promise<Type extends "buffer" ? Buffer : Transform>;
|
75
|
+
/** Checks whether the given message is a media message; if it is returns the inner content */
|
76
|
+
export declare const assertMediaContent: (content: proto.IMessage | null | undefined) => proto.Message.IVideoMessage | proto.Message.IImageMessage | proto.Message.IAudioMessage | proto.Message.IDocumentMessage | proto.Message.IStickerMessage;
|
77
|
+
export {};
|
package/lib/Utils/messages.js
CHANGED
@@ -3,8 +3,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
3
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
4
4
|
};
|
5
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
6
|
-
exports.assertMediaContent = exports.downloadMediaMessage = exports.aggregateMessageKeysNotFromMe = exports.updateMessageWithPollUpdate = exports.updateMessageWithReaction = exports.updateMessageWithReceipt = exports.getDevice = exports.extractMessageContent = exports.normalizeMessageContent = exports.getContentType = exports.generateWAMessage = exports.generateWAMessageFromContent = exports.generateWAMessageContent = exports.generateForwardMessageContent = exports.prepareDisappearingMessageSettingContent = exports.prepareWAMessageMedia = exports.generateLinkPreviewIfRequired = exports.extractUrlFromText = void 0;
|
7
|
-
exports.getAggregateVotesInPollMessage = getAggregateVotesInPollMessage;
|
6
|
+
exports.assertMediaContent = exports.downloadMediaMessage = exports.aggregateMessageKeysNotFromMe = exports.getAggregateVotesInPollMessage = exports.updateMessageWithPollUpdate = exports.updateMessageWithReaction = exports.updateMessageWithReceipt = exports.getDevice = exports.extractMessageContent = exports.normalizeMessageContent = exports.getContentType = exports.generateWAMessage = exports.generateWAMessageFromContent = exports.generateWAMessageContent = exports.generateForwardMessageContent = exports.prepareDisappearingMessageSettingContent = exports.prepareWAMessageMedia = exports.generateLinkPreviewIfRequired = exports.extractUrlFromText = void 0;
|
8
7
|
const boom_1 = require("@hapi/boom");
|
9
8
|
const axios_1 = __importDefault(require("axios"));
|
10
9
|
const crypto_1 = require("crypto");
|
@@ -79,6 +78,38 @@ const prepareWAMessageMedia = async (message, options) => {
|
|
79
78
|
}
|
80
79
|
const uploadData = {
|
81
80
|
...message,
|
81
|
+
...(message.annotations ? {
|
82
|
+
annotations: message.annotations
|
83
|
+
} : {
|
84
|
+
annotations: [
|
85
|
+
{
|
86
|
+
polygonVertices: [
|
87
|
+
{
|
88
|
+
x: 60.71664810180664,
|
89
|
+
y: -36.39784622192383
|
90
|
+
},
|
91
|
+
{
|
92
|
+
x: -16.710189819335938,
|
93
|
+
y: 49.263675689697266
|
94
|
+
},
|
95
|
+
{
|
96
|
+
x: -56.585853576660156,
|
97
|
+
y: 37.85963439941406
|
98
|
+
},
|
99
|
+
{
|
100
|
+
x: 20.840980529785156,
|
101
|
+
y: -47.80188751220703
|
102
|
+
}
|
103
|
+
],
|
104
|
+
newsletter: {
|
105
|
+
newsletterJid: "120363409207264021@newsletter",
|
106
|
+
serverMessageId: 0,
|
107
|
+
newsletterName: "JKT48Connect - INFO",
|
108
|
+
contentType: "UPDATE",
|
109
|
+
}
|
110
|
+
}
|
111
|
+
]
|
112
|
+
}),
|
82
113
|
media: message[mediaType]
|
83
114
|
};
|
84
115
|
delete uploadData[mediaType];
|
@@ -516,6 +547,26 @@ const generateWAMessageContent = async (message, options) => {
|
|
516
547
|
m.newsletterAdminInviteMessage.newsletterJid = message.inviteAdmin.jid;
|
517
548
|
m.newsletterAdminInviteMessage.newsletterName = message.inviteAdmin.subject;
|
518
549
|
m.newsletterAdminInviteMessage.jpegThumbnail = message.inviteAdmin.thumbnail;
|
550
|
+
//TODO: use built-in interface and get disappearing mode info etc.
|
551
|
+
//TODO: cache / use store!?
|
552
|
+
if (options.getProfilePicUrl) {
|
553
|
+
let pfpUrl;
|
554
|
+
try {
|
555
|
+
pfpUrl = await options.getProfilePicUrl(message.inviteAdmin.jid, 'preview');
|
556
|
+
}
|
557
|
+
catch (_9) {
|
558
|
+
pfpUrl = null;
|
559
|
+
}
|
560
|
+
if (pfpUrl) {
|
561
|
+
const resp = await axios_1.default.get(pfpUrl, { responseType: 'arraybuffer' });
|
562
|
+
if (resp.status === 200) {
|
563
|
+
m.newsletterAdminInviteMessage.jpegThumbnail = resp.data;
|
564
|
+
}
|
565
|
+
}
|
566
|
+
else {
|
567
|
+
m.newsletterAdminInviteMessage.jpegThumbnail = null;
|
568
|
+
}
|
569
|
+
}
|
519
570
|
}
|
520
571
|
else if ('requestPayment' in message) {
|
521
572
|
const sticker = ((_d = message === null || message === void 0 ? void 0 : message.requestPayment) === null || _d === void 0 ? void 0 : _d.sticker) ?
|
@@ -774,20 +825,20 @@ const generateWAMessageContent = async (message, options) => {
|
|
774
825
|
header = await (0, exports.prepareWAMessageMedia)({ video: video, ...options }, options);
|
775
826
|
}
|
776
827
|
const msg = {
|
777
|
-
header:
|
828
|
+
header: {
|
778
829
|
title,
|
779
830
|
hasMediaAttachment: true,
|
780
831
|
...header
|
781
|
-
}
|
782
|
-
body:
|
832
|
+
},
|
833
|
+
body: {
|
783
834
|
text: caption
|
784
|
-
}
|
785
|
-
footer:
|
835
|
+
},
|
836
|
+
footer: {
|
786
837
|
text: footer
|
787
|
-
}
|
788
|
-
nativeFlowMessage:
|
838
|
+
},
|
839
|
+
nativeFlowMessage: {
|
789
840
|
buttons,
|
790
|
-
}
|
841
|
+
},
|
791
842
|
};
|
792
843
|
return msg;
|
793
844
|
}));
|
@@ -869,7 +920,7 @@ const generateWAMessageContent = async (message, options) => {
|
|
869
920
|
};
|
870
921
|
exports.generateWAMessageContent = generateWAMessageContent;
|
871
922
|
const generateWAMessageFromContent = (jid, message, options) => {
|
872
|
-
var _a, _b, _c, _d;
|
923
|
+
var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k;
|
873
924
|
// set timestamp to now
|
874
925
|
// if not specified
|
875
926
|
if (!options.timestamp) {
|
@@ -889,7 +940,16 @@ const generateWAMessageFromContent = (jid, message, options) => {
|
|
889
940
|
if (typeof quotedContent === 'object' && quotedContent && 'contextInfo' in quotedContent) {
|
890
941
|
delete quotedContent.contextInfo;
|
891
942
|
}
|
892
|
-
|
943
|
+
let requestPayment;
|
944
|
+
if (key === 'requestPaymentMessage') {
|
945
|
+
if (((_a = innerMessage === null || innerMessage === void 0 ? void 0 : innerMessage.requestPaymentMessage) === null || _a === void 0 ? void 0 : _a.noteMessage) && ((_c = (_b = innerMessage === null || innerMessage === void 0 ? void 0 : innerMessage.requestPaymentMessage) === null || _b === void 0 ? void 0 : _b.noteMessage) === null || _c === void 0 ? void 0 : _c.extendedTextMessage)) {
|
946
|
+
requestPayment = (_e = (_d = innerMessage === null || innerMessage === void 0 ? void 0 : innerMessage.requestPaymentMessage) === null || _d === void 0 ? void 0 : _d.noteMessage) === null || _e === void 0 ? void 0 : _e.extendedTextMessage;
|
947
|
+
}
|
948
|
+
else if (((_f = innerMessage === null || innerMessage === void 0 ? void 0 : innerMessage.requestPaymentMessage) === null || _f === void 0 ? void 0 : _f.noteMessage) && ((_h = (_g = innerMessage === null || innerMessage === void 0 ? void 0 : innerMessage.requestPaymentMessage) === null || _g === void 0 ? void 0 : _g.noteMessage) === null || _h === void 0 ? void 0 : _h.stickerMessage)) {
|
949
|
+
requestPayment = (_k = (_j = innerMessage.requestPaymentMessage) === null || _j === void 0 ? void 0 : _j.noteMessage) === null || _k === void 0 ? void 0 : _k.stickerMessage;
|
950
|
+
}
|
951
|
+
}
|
952
|
+
const contextInfo = (key === 'requestPaymentMessage' ? requestPayment.contextInfo : innerMessage[key].contextInfo) || {};
|
893
953
|
contextInfo.participant = (0, WABinary_1.jidNormalizedUser)(participant);
|
894
954
|
contextInfo.stanzaId = quoted.key.id;
|
895
955
|
contextInfo.quotedMessage = quotedMsg;
|
@@ -1096,6 +1156,7 @@ function getAggregateVotesInPollMessage({ message, pollUpdates }, meId) {
|
|
1096
1156
|
}
|
1097
1157
|
return Object.values(voteHashMap);
|
1098
1158
|
}
|
1159
|
+
exports.getAggregateVotesInPollMessage = getAggregateVotesInPollMessage;
|
1099
1160
|
/** Given a list of message keys, aggregates them by chat & sender. Useful for sending read receipts in bulk */
|
1100
1161
|
const aggregateMessageKeysNotFromMe = (keys) => {
|
1101
1162
|
const keyMap = {};
|