Path: blob/master/node_modules/@adiwajshing/baileys/lib/Utils/messages.d.ts
1129 views
/// <reference types="node" />1/// <reference types="node" />2import { Logger } from 'pino';3import { proto } from '../../WAProto';4import { AnyMediaMessageContent, AnyMessageContent, MediaGenerationOptions, MessageContentGenerationOptions, MessageGenerationOptions, MessageGenerationOptionsFromContent, MessageUserReceipt, WAMessage, WAMessageContent, WAProto } from '../Types';5import { MediaDownloadOptions } from './messages-media';6/**7* Uses a regex to test whether the string contains a URL, and returns the URL if it does.8* @param text eg. hello https://google.com9* @returns the URL, eg. https://google.com10*/11export declare const extractUrlFromText: (text: string) => string | undefined;12export declare const generateLinkPreviewIfRequired: (text: string, getUrlInfo: MessageGenerationOptions['getUrlInfo'], logger: MessageGenerationOptions['logger']) => Promise<import("../Types").WAUrlInfo | undefined>;13export declare const prepareWAMessageMedia: (message: AnyMediaMessageContent, options: MediaGenerationOptions) => Promise<proto.Message>;14export declare const prepareDisappearingMessageSettingContent: (ephemeralExpiration?: number) => proto.Message;15/**16* Generate forwarded message content like WA does17* @param message the message to forward18* @param options.forceForward will show the message as forwarded even if it is from you19*/20export declare const generateForwardMessageContent: (message: WAMessage, forceForward?: boolean) => proto.IMessage;21export declare const generateWAMessageContent: (message: AnyMessageContent, options: MessageContentGenerationOptions) => Promise<proto.Message>;22export declare const generateWAMessageFromContent: (jid: string, message: WAMessageContent, options: MessageGenerationOptionsFromContent) => proto.WebMessageInfo;23export declare const generateWAMessage: (jid: string, content: AnyMessageContent, options: MessageGenerationOptions) => Promise<proto.WebMessageInfo>;24/** Get the key to access the true type of content */25export declare const getContentType: (content: WAProto.IMessage | undefined) => keyof proto.IMessage | undefined;26/**27* Normalizes ephemeral, view once messages to regular message content28* Eg. image messages in ephemeral messages, in view once messages etc.29* @param content30* @returns31*/32export declare const normalizeMessageContent: (content: WAMessageContent | null | undefined) => WAMessageContent | undefined;33/**34* Extract the true message content from a message35* Eg. extracts the inner message from a disappearing message/view once message36*/37export declare const extractMessageContent: (content: WAMessageContent | undefined | null) => WAMessageContent | undefined;38/**39* Returns the device predicted by message ID40*/41export declare const getDevice: (id: string) => "android" | "web" | "ios";42/** Upserts a receipt in the message */43export declare const updateMessageWithReceipt: (msg: Pick<WAMessage, 'userReceipt'>, receipt: MessageUserReceipt) => void;44/** Update the message with a new reaction */45export declare const updateMessageWithReaction: (msg: Pick<WAMessage, 'reactions'>, reaction: proto.IReaction) => void;46/** Given a list of message keys, aggregates them by chat & sender. Useful for sending read receipts in bulk */47export declare const aggregateMessageKeysNotFromMe: (keys: proto.IMessageKey[]) => {48jid: string;49participant: string | undefined;50messageIds: string[];51}[];52declare type DownloadMediaMessageContext = {53reuploadRequest: (msg: WAMessage) => Promise<WAMessage>;54logger: Logger;55};56/**57* Downloads the given message. Throws an error if it's not a media message58*/59export declare const downloadMediaMessage: (message: WAMessage, type: 'buffer' | 'stream', options: MediaDownloadOptions, ctx?: DownloadMediaMessageContext) => Promise<Buffer | import("stream").Transform>;60/** Checks whether the given message is a media message; if it is returns the inner content */61export declare const assertMediaContent: (content: proto.IMessage | null | undefined) => proto.Message.IVideoMessage | proto.Message.IImageMessage | proto.Message.IAudioMessage | proto.Message.IDocumentMessage | proto.Message.IStickerMessage;62/**63* this is an experimental patch to make buttons work64* Don't know how it works, but it does for now65*/66export declare const patchMessageForMdIfRequired: (message: proto.IMessage) => proto.IMessage;67export {};686970