@whiskeysockets/baileys
Version:
A WebSockets library for interacting with WhatsApp Web
125 lines (124 loc) • 7.51 kB
TypeScript
import { proto } from '../../WAProto';
import { GroupMetadata, ParticipantAction, SocketConfig } from '../Types';
import { BinaryNode } from '../WABinary';
export declare const makeGroupsSocket: (config: SocketConfig) => {
groupMetadata: (jid: string) => Promise<GroupMetadata>;
groupCreate: (subject: string, participants: string[]) => Promise<GroupMetadata>;
groupLeave: (id: string) => Promise<void>;
groupUpdateSubject: (jid: string, subject: string) => Promise<void>;
groupRequestParticipantsList: (jid: string) => Promise<{
[key: string]: string;
}[]>;
groupRequestParticipantsUpdate: (jid: string, participants: string[], action: "approve" | "reject") => Promise<{
status: string;
jid: string;
}[]>;
groupParticipantsUpdate: (jid: string, participants: string[], action: ParticipantAction) => Promise<{
status: string;
jid: string;
content: BinaryNode;
}[]>;
groupUpdateDescription: (jid: string, description?: string) => Promise<void>;
groupInviteCode: (jid: string) => Promise<string | undefined>;
groupRevokeInvite: (jid: string) => Promise<string | undefined>;
groupAcceptInvite: (code: string) => Promise<string | undefined>;
/**
* revoke a v4 invite for someone
* @param groupJid group jid
* @param invitedJid jid of person you invited
* @returns true if successful
*/
groupRevokeInviteV4: (groupJid: string, invitedJid: string) => Promise<boolean>;
/**
* accept a GroupInviteMessage
* @param key the key of the invite message, or optionally only provide the jid of the person who sent the invite
* @param inviteMessage the message to accept
*/
groupAcceptInviteV4: (key: string | proto.IMessageKey, inviteMessage: proto.Message.IGroupInviteMessage) => Promise<any>;
groupGetInviteInfo: (code: string) => Promise<GroupMetadata>;
groupToggleEphemeral: (jid: string, ephemeralExpiration: number) => Promise<void>;
groupSettingUpdate: (jid: string, setting: "announcement" | "not_announcement" | "locked" | "unlocked") => Promise<void>;
groupMemberAddMode: (jid: string, mode: "admin_add" | "all_member_add") => Promise<void>;
groupJoinApprovalMode: (jid: string, mode: "on" | "off") => Promise<void>;
groupFetchAllParticipating: () => Promise<{
[_: string]: GroupMetadata;
}>;
getBotListV2: () => Promise<import("../Types").BotListInfo[]>;
processingMutex: {
mutex<T>(code: () => Promise<T> | T): Promise<T>;
};
fetchPrivacySettings: (force?: boolean) => Promise<{
[_: string]: string;
}>;
upsertMessage: (msg: proto.IWebMessageInfo, type: import("../Types").MessageUpsertType) => Promise<void>;
appPatch: (patchCreate: import("../Types").WAPatchCreate) => Promise<void>;
sendPresenceUpdate: (type: import("../Types").WAPresence, toJid?: string) => Promise<void>;
presenceSubscribe: (toJid: string, tcToken?: Buffer) => Promise<void>;
profilePictureUrl: (jid: string, type?: "preview" | "image", timeoutMs?: number) => Promise<string | undefined>;
onWhatsApp: (...jids: string[]) => Promise<{
jid: string;
exists: unknown;
lid: unknown;
}[] | undefined>;
fetchBlocklist: () => Promise<string[]>;
fetchStatus: (...jids: string[]) => Promise<import("..").USyncQueryResultList[] | undefined>;
fetchDisappearingDuration: (...jids: string[]) => Promise<import("..").USyncQueryResultList[] | undefined>;
updateProfilePicture: (jid: string, content: import("../Types").WAMediaUpload) => Promise<void>;
removeProfilePicture: (jid: string) => Promise<void>;
updateProfileStatus: (status: string) => Promise<void>;
updateProfileName: (name: string) => Promise<void>;
updateBlockStatus: (jid: string, action: "block" | "unblock") => Promise<void>;
updateCallPrivacy: (value: import("../Types").WAPrivacyCallValue) => Promise<void>;
updateMessagesPrivacy: (value: import("../Types").WAPrivacyMessagesValue) => Promise<void>;
updateLastSeenPrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
updateOnlinePrivacy: (value: import("../Types").WAPrivacyOnlineValue) => Promise<void>;
updateProfilePicturePrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
updateStatusPrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
updateReadReceiptsPrivacy: (value: import("../Types").WAReadReceiptsValue) => Promise<void>;
updateGroupsAddPrivacy: (value: import("../Types").WAPrivacyGroupAddValue) => Promise<void>;
updateDefaultDisappearingMode: (duration: number) => Promise<void>;
getBusinessProfile: (jid: string) => Promise<import("../Types").WABusinessProfile | void>;
resyncAppState: (collections: readonly ("critical_block" | "critical_unblock_low" | "regular_high" | "regular_low" | "regular")[], isInitialSync: boolean) => Promise<void>;
chatModify: (mod: import("../Types").ChatModification, jid: string) => Promise<void>;
cleanDirtyBits: (type: "account_sync" | "groups", fromTimestamp?: number | string) => Promise<void>;
addLabel: (jid: string, labels: import("../Types/Label").LabelActionBody) => Promise<void>;
addChatLabel: (jid: string, labelId: string) => Promise<void>;
removeChatLabel: (jid: string, labelId: string) => Promise<void>;
addMessageLabel: (jid: string, messageId: string, labelId: string) => Promise<void>;
removeMessageLabel: (jid: string, messageId: string, labelId: string) => Promise<void>;
star: (jid: string, messages: {
id: string;
fromMe?: boolean;
}[], star: boolean) => Promise<void>;
executeUSyncQuery: (usyncQuery: import("..").USyncQuery) => Promise<import("..").USyncQueryResult | undefined>;
type: "md";
ws: import("./Client").WebSocketClient;
ev: import("../Types").BaileysEventEmitter & {
process(handler: (events: Partial<import("../Types").BaileysEventMap>) => void | Promise<void>): (() => void);
buffer(): void;
createBufferedFunction<A extends any[], T>(work: (...args: A) => Promise<T>): ((...args: A) => Promise<T>);
flush(force?: boolean): boolean;
isBuffering(): boolean;
};
authState: {
creds: import("../Types").AuthenticationCreds;
keys: import("../Types").SignalKeyStoreWithTransaction;
};
signalRepository: import("../Types").SignalRepository;
user: import("../Types").Contact | undefined;
generateMessageTag: () => string;
query: (node: BinaryNode, timeoutMs?: number) => Promise<any>;
waitForMessage: <T>(msgId: string, timeoutMs?: number | undefined) => Promise<any>;
waitForSocketOpen: () => Promise<void>;
sendRawMessage: (data: Uint8Array | Buffer) => Promise<void>;
sendNode: (frame: BinaryNode) => Promise<void>;
logout: (msg?: string) => Promise<void>;
end: (error: Error | undefined) => void;
onUnexpectedError: (err: Error | import("@hapi/boom").Boom, msg: string) => void;
uploadPreKeys: (count?: number) => Promise<void>;
uploadPreKeysToServerIfRequired: () => Promise<void>;
requestPairingCode: (phoneNumber: string) => Promise<string>;
waitForConnectionUpdate: (check: (u: Partial<import("../Types").ConnectionState>) => Promise<boolean | undefined>, timeoutMs?: number) => Promise<void>;
sendWAMBuffer: (wamBuffer: Buffer) => Promise<any>;
};
export declare const extractGroupMetadata: (result: BinaryNode) => GroupMetadata;