UNPKG

@whiskeysockets/baileys

Version:
315 lines (314 loc) 13.7 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.extractGroupMetadata = exports.makeGroupsSocket = void 0; const WAProto_1 = require("../../WAProto"); const Types_1 = require("../Types"); const Utils_1 = require("../Utils"); const WABinary_1 = require("../WABinary"); const chats_1 = require("./chats"); const makeGroupsSocket = (config) => { const sock = (0, chats_1.makeChatsSocket)(config); const { authState, ev, query, upsertMessage } = sock; const groupQuery = async (jid, type, content) => (query({ tag: 'iq', attrs: { type, xmlns: 'w:g2', to: jid, }, content })); const groupMetadata = async (jid) => { const result = await groupQuery(jid, 'get', [{ tag: 'query', attrs: { request: 'interactive' } }]); return (0, exports.extractGroupMetadata)(result); }; const groupFetchAllParticipating = async () => { const result = await query({ tag: 'iq', attrs: { to: '@g.us', xmlns: 'w:g2', type: 'get', }, content: [ { tag: 'participating', attrs: {}, content: [ { tag: 'participants', attrs: {} }, { tag: 'description', attrs: {} } ] } ] }); const data = {}; const groupsChild = (0, WABinary_1.getBinaryNodeChild)(result, 'groups'); if (groupsChild) { const groups = (0, WABinary_1.getBinaryNodeChildren)(groupsChild, 'group'); for (const groupNode of groups) { const meta = (0, exports.extractGroupMetadata)({ tag: 'result', attrs: {}, content: [groupNode] }); data[meta.id] = meta; } } sock.ev.emit('groups.update', Object.values(data)); return data; }; sock.ws.on('CB:ib,,dirty', async (node) => { const { attrs } = (0, WABinary_1.getBinaryNodeChild)(node, 'dirty'); if (attrs.type !== 'groups') { return; } await groupFetchAllParticipating(); await sock.cleanDirtyBits('groups'); }); return { ...sock, groupMetadata, groupCreate: async (subject, participants) => { const key = (0, Utils_1.generateMessageID)(); const result = await groupQuery('@g.us', 'set', [ { tag: 'create', attrs: { subject, key }, content: participants.map(jid => ({ tag: 'participant', attrs: { jid } })) } ]); return (0, exports.extractGroupMetadata)(result); }, groupLeave: async (id) => { await groupQuery('@g.us', 'set', [ { tag: 'leave', attrs: {}, content: [ { tag: 'group', attrs: { id } } ] } ]); }, groupUpdateSubject: async (jid, subject) => { await groupQuery(jid, 'set', [ { tag: 'subject', attrs: {}, content: Buffer.from(subject, 'utf-8') } ]); }, groupRequestParticipantsList: async (jid) => { const result = await groupQuery(jid, 'get', [ { tag: 'membership_approval_requests', attrs: {} } ]); const node = (0, WABinary_1.getBinaryNodeChild)(result, 'membership_approval_requests'); const participants = (0, WABinary_1.getBinaryNodeChildren)(node, 'membership_approval_request'); return participants.map(v => v.attrs); }, groupRequestParticipantsUpdate: async (jid, participants, action) => { const result = await groupQuery(jid, 'set', [{ tag: 'membership_requests_action', attrs: {}, content: [ { tag: action, attrs: {}, content: participants.map(jid => ({ tag: 'participant', attrs: { jid } })) } ] }]); const node = (0, WABinary_1.getBinaryNodeChild)(result, 'membership_requests_action'); const nodeAction = (0, WABinary_1.getBinaryNodeChild)(node, action); const participantsAffected = (0, WABinary_1.getBinaryNodeChildren)(nodeAction, 'participant'); return participantsAffected.map(p => { return { status: p.attrs.error || '200', jid: p.attrs.jid }; }); }, groupParticipantsUpdate: async (jid, participants, action) => { const result = await groupQuery(jid, 'set', [ { tag: action, attrs: {}, content: participants.map(jid => ({ tag: 'participant', attrs: { jid } })) } ]); const node = (0, WABinary_1.getBinaryNodeChild)(result, action); const participantsAffected = (0, WABinary_1.getBinaryNodeChildren)(node, 'participant'); return participantsAffected.map(p => { return { status: p.attrs.error || '200', jid: p.attrs.jid, content: p }; }); }, groupUpdateDescription: async (jid, description) => { var _a; const metadata = await groupMetadata(jid); const prev = (_a = metadata.descId) !== null && _a !== void 0 ? _a : null; await groupQuery(jid, 'set', [ { tag: 'description', attrs: { ...(description ? { id: (0, Utils_1.generateMessageID)() } : { delete: 'true' }), ...(prev ? { prev } : {}) }, content: description ? [ { tag: 'body', attrs: {}, content: Buffer.from(description, 'utf-8') } ] : undefined } ]); }, groupInviteCode: async (jid) => { const result = await groupQuery(jid, 'get', [{ tag: 'invite', attrs: {} }]); const inviteNode = (0, WABinary_1.getBinaryNodeChild)(result, 'invite'); return inviteNode === null || inviteNode === void 0 ? void 0 : inviteNode.attrs.code; }, groupRevokeInvite: async (jid) => { const result = await groupQuery(jid, 'set', [{ tag: 'invite', attrs: {} }]); const inviteNode = (0, WABinary_1.getBinaryNodeChild)(result, 'invite'); return inviteNode === null || inviteNode === void 0 ? void 0 : inviteNode.attrs.code; }, groupAcceptInvite: async (code) => { const results = await groupQuery('@g.us', 'set', [{ tag: 'invite', attrs: { code } }]); const result = (0, WABinary_1.getBinaryNodeChild)(results, 'group'); return result === null || result === void 0 ? void 0 : result.attrs.jid; }, /** * revoke a v4 invite for someone * @param groupJid group jid * @param invitedJid jid of person you invited * @returns true if successful */ groupRevokeInviteV4: async (groupJid, invitedJid) => { const result = await groupQuery(groupJid, 'set', [{ tag: 'revoke', attrs: {}, content: [{ tag: 'participant', attrs: { jid: invitedJid } }] }]); return !!result; }, /** * 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: ev.createBufferedFunction(async (key, inviteMessage) => { var _a; key = typeof key === 'string' ? { remoteJid: key } : key; const results = await groupQuery(inviteMessage.groupJid, 'set', [{ tag: 'accept', attrs: { code: inviteMessage.inviteCode, expiration: inviteMessage.inviteExpiration.toString(), admin: key.remoteJid } }]); // if we have the full message key // update the invite message to be expired if (key.id) { // create new invite message that is expired inviteMessage = WAProto_1.proto.Message.GroupInviteMessage.fromObject(inviteMessage); inviteMessage.inviteExpiration = 0; inviteMessage.inviteCode = ''; ev.emit('messages.update', [ { key, update: { message: { groupInviteMessage: inviteMessage } } } ]); } // generate the group add message await upsertMessage({ key: { remoteJid: inviteMessage.groupJid, id: (0, Utils_1.generateMessageIDV2)((_a = sock.user) === null || _a === void 0 ? void 0 : _a.id), fromMe: false, participant: key.remoteJid, }, messageStubType: Types_1.WAMessageStubType.GROUP_PARTICIPANT_ADD, messageStubParameters: [ authState.creds.me.id ], participant: key.remoteJid, messageTimestamp: (0, Utils_1.unixTimestampSeconds)() }, 'notify'); return results.attrs.from; }), groupGetInviteInfo: async (code) => { const results = await groupQuery('@g.us', 'get', [{ tag: 'invite', attrs: { code } }]); return (0, exports.extractGroupMetadata)(results); }, groupToggleEphemeral: async (jid, ephemeralExpiration) => { const content = ephemeralExpiration ? { tag: 'ephemeral', attrs: { expiration: ephemeralExpiration.toString() } } : { tag: 'not_ephemeral', attrs: {} }; await groupQuery(jid, 'set', [content]); }, groupSettingUpdate: async (jid, setting) => { await groupQuery(jid, 'set', [{ tag: setting, attrs: {} }]); }, groupMemberAddMode: async (jid, mode) => { await groupQuery(jid, 'set', [{ tag: 'member_add_mode', attrs: {}, content: mode }]); }, groupJoinApprovalMode: async (jid, mode) => { await groupQuery(jid, 'set', [{ tag: 'membership_approval_mode', attrs: {}, content: [{ tag: 'group_join', attrs: { state: mode } }] }]); }, groupFetchAllParticipating }; }; exports.makeGroupsSocket = makeGroupsSocket; const extractGroupMetadata = (result) => { var _a, _b; const group = (0, WABinary_1.getBinaryNodeChild)(result, 'group'); const descChild = (0, WABinary_1.getBinaryNodeChild)(group, 'description'); let desc; let descId; if (descChild) { desc = (0, WABinary_1.getBinaryNodeChildString)(descChild, 'body'); descId = descChild.attrs.id; } const groupId = group.attrs.id.includes('@') ? group.attrs.id : (0, WABinary_1.jidEncode)(group.attrs.id, 'g.us'); const eph = (_a = (0, WABinary_1.getBinaryNodeChild)(group, 'ephemeral')) === null || _a === void 0 ? void 0 : _a.attrs.expiration; const memberAddMode = (0, WABinary_1.getBinaryNodeChildString)(group, 'member_add_mode') === 'all_member_add'; const metadata = { id: groupId, subject: group.attrs.subject, subjectOwner: group.attrs.s_o, subjectTime: +group.attrs.s_t, size: (0, WABinary_1.getBinaryNodeChildren)(group, 'participant').length, creation: +group.attrs.creation, owner: group.attrs.creator ? (0, WABinary_1.jidNormalizedUser)(group.attrs.creator) : undefined, desc, descId, linkedParent: ((_b = (0, WABinary_1.getBinaryNodeChild)(group, 'linked_parent')) === null || _b === void 0 ? void 0 : _b.attrs.jid) || undefined, restrict: !!(0, WABinary_1.getBinaryNodeChild)(group, 'locked'), announce: !!(0, WABinary_1.getBinaryNodeChild)(group, 'announcement'), isCommunity: !!(0, WABinary_1.getBinaryNodeChild)(group, 'parent'), isCommunityAnnounce: !!(0, WABinary_1.getBinaryNodeChild)(group, 'default_sub_group'), joinApprovalMode: !!(0, WABinary_1.getBinaryNodeChild)(group, 'membership_approval_mode'), memberAddMode, participants: (0, WABinary_1.getBinaryNodeChildren)(group, 'participant').map(({ attrs }) => { return { id: attrs.jid, admin: (attrs.type || null), }; }), ephemeralDuration: eph ? +eph : undefined }; return metadata; }; exports.extractGroupMetadata = extractGroupMetadata;