@warriorteam/zalo-personal
Version:
Unofficial Zalo Personal API for JavaScript - A powerful library for interacting with Zalo personal accounts with URL attachment support, auto-reply, product catalog, and business features
39 lines (38 loc) • 1.53 kB
JavaScript
import { ZaloApiError } from "../Errors/ZaloApiError.js";
import { apiFactory } from "../utils.js";
import { AvatarSize } from "../models/index.js";
export const getMultiUsersByPhonesFactory = apiFactory()((api, ctx, utils) => {
const serviceURL = utils.makeURL(`${api.zpwServiceMap.friend[0]}/api/friend/profile/multiget`);
/**
* Get multiple user(s) by their phone numbers.
*
* @param phoneNumbers Phone number(s)
* @param avatarSize Avatar size (default: AvatarSize.Large)
*
* @throws {ZaloApiError}
*/
return async function getMultiUsersByPhones(phoneNumbers, avatarSize = AvatarSize.Large) {
if (!phoneNumbers)
throw new ZaloApiError("Missing phoneNumbers");
if (!Array.isArray(phoneNumbers))
phoneNumbers = [phoneNumbers];
phoneNumbers = phoneNumbers.map((phone) => {
if (phone.startsWith("0") && ctx.language == "vi") {
return "84" + phone.slice(1);
}
return phone;
});
const params = {
phones: phoneNumbers,
avatar_size: avatarSize,
language: ctx.language,
};
const encryptedParams = utils.encodeAES(JSON.stringify(params));
if (!encryptedParams)
throw new ZaloApiError("Failed to encrypt params");
const response = await utils.request(utils.makeURL(serviceURL, { params: encryptedParams }), {
method: "GET",
});
return utils.resolve(response);
};
});