UNPKG

@solufy/evolution-sdk

Version:

Unofficial SDK for the Evolution Whatsapp API v2

173 lines (164 loc) 4.92 kB
// src/api/routes.ts var Routes = { Message: { SendText: "message/sendText", SendMedia: "message/sendMedia", SendVoice: "message/sendWhatsAppAudio", SendSticker: "message/sendSticker", SendLocation: "message/sendLocation", SendContact: "message/sendContact", SendPoll: "message/sendPoll" }, Chats: { Check: "chat/whatsappNumbers", FindAll: "chat/findChats", SendPresence: "chat/sendPresence" }, Groups: { FindAll: "group/fetchAllGroups", FindByJid: "group/findGroupInfos", FindByInviteCode: "group/inviteInfo" } }; // src/modules/chats/schemas/check.ts import { parsePhoneNumber as parsePhoneNumber2 } from "libphonenumber-js"; import { z as z2 } from "zod"; // src/schemas/common.ts import { isValidPhoneNumber, parsePhoneNumber } from "libphonenumber-js"; import { z } from "zod"; var PhoneNumberSchema = z.custom((value) => isValidPhoneNumber(value), "Invalid phone number").transform((phoneNumber) => parsePhoneNumber(phoneNumber).number); var JidSchema = z.string().endsWith( "@s.whatsapp.net", "Invalid remote JID, should end with @s.whatsapp.net" ); var GroupJidSchema = z.string().endsWith( "@g.us", "Invalid group JID, should end with @g.us" ); var GroupInviteCodeSchema = z.string().length(22).regex( /^[a-zA-Z0-9]{22}$/, "Invalid group invite code" ); var ApiNumberSchema = z.union([ PhoneNumberSchema, JidSchema, GroupJidSchema ]); var mediaSchema = z.union([z.string().url(), z.string().base64()]); // src/types/tags.ts var Jid = (jid) => jid; var GroupJid = (jid) => jid; var ChatId = (id) => id; // src/modules/chats/schemas/check.ts var CheckOptionsSchema = z2.array(PhoneNumberSchema); var CheckBodySchema = CheckOptionsSchema.transform((data) => ({ numbers: Array.isArray(data) ? data : [data] })); var CheckResponseSchema = z2.array( z2.object({ exists: z2.boolean(), jid: z2.string(), number: z2.string() }) ).transform( (numbers) => numbers.map((number) => ({ exists: number.exists, jid: Jid(number.jid), number: parsePhoneNumber2(number.number).number })) ); // src/modules/chats/schemas/find-all.ts import { z as z3 } from "zod"; // src/utils/phone-numer-from-jid.ts import { parsePhoneNumber as parsePhoneNumber3 } from "libphonenumber-js"; function phoneNumberFromJid(jid) { return parsePhoneNumber3(`+${jid.split("@")[0]}`).number; } // src/modules/chats/schemas/find-all.ts var FindAllChatsResponseSchema = z3.array( z3.object({ id: z3.string(), remoteJid: z3.string(), name: z3.string().nullish(), labels: z3.array(z3.string()).nullish(), createdAt: z3.coerce.date(), updatedAt: z3.coerce.date(), pushName: z3.string().nullish(), profilePicUrl: z3.string().url().nullish() }) ).transform( (chats) => chats.map((chat) => ({ id: ChatId(chat.id), jid: chat.remoteJid.endsWith("@g.us") ? GroupJid(chat.remoteJid) : Jid(chat.remoteJid), phoneNumber: phoneNumberFromJid(chat.remoteJid), name: chat.name || void 0, labels: chat.labels || void 0, createdAt: chat.createdAt, updatedAt: chat.updatedAt, pushName: chat.pushName || void 0, pictureUrl: chat.profilePicUrl || void 0 })) ); // src/modules/chats/schemas/presence.ts import { z as z4 } from "zod"; var PresenceOptionsSchema = z4.object({ /** * Chat number or JID to receve the presence */ number: ApiNumberSchema, /** * Duration of the presence in millisseconds */ duration: z4.number(), /** * Presence state * - `composing`: typing a message * - `recording`: recording an audio */ presence: z4.enum(["composing", "recording"]), /** * Whether to wait until the presence is finished (duration) */ waitUntilFinish: z4.boolean().optional() }); var PresenceBodySchema = PresenceOptionsSchema.transform( ({ waitUntilFinish, duration, ...data }) => ({ ...data, delay: duration }) ); // src/modules/chats/index.ts var ChatsModule = class { constructor(api) { this.api = api; } /** * Checks if a number has WhatsApp * @param numbers - Number(s) (with country code) to check */ async check(...numbers) { const body = CheckBodySchema.parse(numbers.flat()); const response = await this.api.post(Routes.Chats.Check, { body }); return CheckResponseSchema.parse(response); } /** * Gets all chats */ async findAll() { const response = await this.api.post(Routes.Chats.FindAll); return FindAllChatsResponseSchema.parse(response); } /** * Sends a presence to a certain chat * @param options - Presence options */ async sendPresence(options) { const body = PresenceBodySchema.parse(options); if (options.waitUntilFinish) { await this.api.post(Routes.Chats.SendPresence, { body }); } else { this.api.post(Routes.Chats.SendPresence, { body }); } } }; export { ChatsModule }; //# sourceMappingURL=index.mjs.map