Software: Apache. PHP/8.1.30 uname -a: Linux server1.tuhinhossain.com 5.15.0-163-generic #173-Ubuntu SMP Tue Oct 14 17:51:00 UTC uid=1002(picotech) gid=1003(picotech) groups=1003(picotech),0(root) Safe-mode: OFF (not secure) /home/picotech/domains/wa.picotech.app/public_html/node_modules/@whiskeysockets/baileys/lib/Utils/ drwxr-xr-x | |
| Viewing file: Select action/file-type: "use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.decryptMessageNode = exports.decodeMessageNode = void 0;
const boom_1 = require("@hapi/boom");
const WAProto_1 = require("../../WAProto");
const WABinary_1 = require("../WABinary");
const generics_1 = require("./generics");
const NO_MESSAGE_FOUND_ERROR_TEXT = 'Message absent from node';
/**
* Decode the received node as a message.
* @note this will only parse the message, not decrypt it
*/
function decodeMessageNode(stanza, meId) {
let msgType;
let chatId;
let author;
const msgId = stanza.attrs.id;
const from = stanza.attrs.from;
const participant = stanza.attrs.participant;
const recipient = stanza.attrs.recipient;
const isMe = (jid) => (0, WABinary_1.areJidsSameUser)(jid, meId);
if ((0, WABinary_1.isJidUser)(from)) {
if (recipient) {
if (!isMe(from)) {
throw new boom_1.Boom('receipient present, but msg not from me', { data: stanza });
}
chatId = recipient;
}
else {
chatId = from;
}
msgType = 'chat';
author = from;
}
else if ((0, WABinary_1.isJidGroup)(from)) {
if (!participant) {
throw new boom_1.Boom('No participant in group message');
}
msgType = 'group';
author = participant;
chatId = from;
}
else if ((0, WABinary_1.isJidBroadcast)(from)) {
if (!participant) {
throw new boom_1.Boom('No participant in group message');
}
const isParticipantMe = isMe(participant);
if ((0, WABinary_1.isJidStatusBroadcast)(from)) {
msgType = isParticipantMe ? 'direct_peer_status' : 'other_status';
}
else {
msgType = isParticipantMe ? 'peer_broadcast' : 'other_broadcast';
}
chatId = from;
author = participant;
}
else {
throw new boom_1.Boom('Unknown message type', { data: stanza });
}
const fromMe = isMe(stanza.attrs.participant || stanza.attrs.from);
const pushname = stanza.attrs.notify;
const key = {
remoteJid: chatId,
fromMe,
id: msgId,
participant
};
const fullMessage = {
key,
messageTimestamp: +stanza.attrs.t,
pushName: pushname,
broadcast: (0, WABinary_1.isJidBroadcast)(from)
};
if (key.fromMe) {
fullMessage.status = WAProto_1.proto.WebMessageInfo.Status.SERVER_ACK;
}
return {
fullMessage,
author,
sender: msgType === 'chat' ? author : chatId
};
}
exports.decodeMessageNode = decodeMessageNode;
const decryptMessageNode = (stanza, meId, repository, logger) => {
const { fullMessage, author, sender } = decodeMessageNode(stanza, meId);
return {
fullMessage,
category: stanza.attrs.category,
author,
async decrypt() {
var _a;
let decryptables = 0;
if (Array.isArray(stanza.content)) {
for (const { tag, attrs, content } of stanza.content) {
if (tag === 'verified_name' && content instanceof Uint8Array) {
const cert = WAProto_1.proto.VerifiedNameCertificate.decode(content);
const details = WAProto_1.proto.VerifiedNameCertificate.Details.decode(cert.details);
fullMessage.verifiedBizName = details.verifiedName;
}
if (tag !== 'enc') {
continue;
}
if (!(content instanceof Uint8Array)) {
continue;
}
decryptables += 1;
let msgBuffer;
try {
const e2eType = attrs.type;
switch (e2eType) {
case 'skmsg':
msgBuffer = await repository.decryptGroupMessage({
group: sender,
authorJid: author,
msg: content
});
break;
case 'pkmsg':
case 'msg':
const user = (0, WABinary_1.isJidUser)(sender) ? sender : author;
msgBuffer = await repository.decryptMessage({
jid: user,
type: e2eType,
ciphertext: content
});
break;
default:
throw new Error(`Unknown e2e type: ${e2eType}`);
}
let msg = WAProto_1.proto.Message.decode((0, generics_1.unpadRandomMax16)(msgBuffer));
msg = ((_a = msg.deviceSentMessage) === null || _a === void 0 ? void 0 : _a.message) || msg;
if (msg.senderKeyDistributionMessage) {
await repository.processSenderKeyDistributionMessage({
authorJid: author,
item: msg.senderKeyDistributionMessage
});
}
if (fullMessage.message) {
Object.assign(fullMessage.message, msg);
}
else {
fullMessage.message = msg;
}
}
catch (err) {
logger.error({ key: fullMessage.key, err }, 'failed to decrypt message');
fullMessage.messageStubType = WAProto_1.proto.WebMessageInfo.StubType.CIPHERTEXT;
fullMessage.messageStubParameters = [err.message];
}
}
}
// if nothing was found to decrypt
if (!decryptables) {
fullMessage.messageStubType = WAProto_1.proto.WebMessageInfo.StubType.CIPHERTEXT;
fullMessage.messageStubParameters = [NO_MESSAGE_FOUND_ERROR_TEXT];
}
}
};
};
exports.decryptMessageNode = decryptMessageNode;
|
:: Command execute :: | |
--[ c99shell v. 2.5 [PHP 8 Update] [24.05.2025] | Generation time: 0.0034 ]-- |