/* eslint-disable indent */
/* eslint-disable max-len */
/* Requires */
const fs = require('fs');
const { Sticker } = require('wa-sticker-formatter');
const Indexer = require('../../index');
/* JSON's | Utilidades */
const envInfo = JSON.parse(fs.readFileSync(`${__dirname}/utils.json`));
/**
* Retorna todos os detalhes do ambiente (`envInfo`).
*
* @returns {Object} O objeto `envInfo`, que contém os detalhes do ambiente da execução.
*/
function ambientDetails() {
/* Retorna a envData */
return envInfo;
}
/* Cria a função de comando */
async function tagEveryone(
kill = envInfo.functions.exec.arguments.kill.value,
env = envInfo.functions.exec.arguments.env.value,
) {
/* Define um resultado padrão */
envInfo.results.value = false;
/* Define o sucesso */
envInfo.results.success = false;
/* Try-Catch para casos de erro */
try {
/* Se recebeu tudo corretamente, se der ruim, não fará nada */
if (typeof kill === 'object' && typeof env === 'object') {
/* Define os dados necessarios */
const {
reply,
chatId,
quotedMsgObj,
isOwner,
isGroupMsg,
isQuotedMsg,
body,
prefix,
typeFormatted,
functions,
isAllowed,
decryptedMedia,
mimetype,
groupMembersIdFormated,
groupMembersId,
userFormated,
stickerConfig,
quotedTypeFormated,
command,
user,
arks,
} = env.value;
/* Tira quem está no Anti-Everyone */
const noEveryFormatted = groupMembersIdFormated?.filter((usr) => !functions?.dnd?.values?.some((ir) => ir?.replace(/@s.whatsapp.net/gi, '') === usr)) || [userFormated];
const noEveryone = groupMembersId?.filter((usr) => !functions?.dnd?.values?.includes(usr)) || [user];
/* Define o placeholder do body, caso não tenha */
const insertContext = `By: @${userFormated}`;
/* Define o RegExp de remover o comando da Object */
const replaceCmd = new RegExp(`\\${prefix}${command}\\s`, 'gi');
/* Define o alias na envInfo */
envInfo.alias = env.value.alias;
/* Se não for grupo */
if (!isGroupMsg) {
/* Manda a mensagem só de grupos */
envInfo.results.value = await kill.sendMessage(chatId, { text: Indexer('sql').languages(region, 'Extras', 'OnlyGroups', true, true, envInfo).value }, reply);
/* Define o menu de ajuda */
} else if (arks.includes('--help-dev') && isOwner === true) {
/* Manda a mensagem de ajuda de dev */
envInfo.results.value = await kill.sendMessage(chatId, { text: Indexer('sql').languages(region, 'Helper', 'Developer', true, true, envInfo).value }, reply);
/* Menu de ajuda normal */
} else if (arks.includes('--help')) {
/* Não inclui informações secretas */
envInfo.results.value = await kill.sendMessage(chatId, { text: Indexer('sql').languages(region, 'Helper', 'User', true, true, envInfo).value }, reply);
/* Se dono, admin, mod ou pode rodar */
} else if (isAllowed && isGroupMsg) {
/* Define a Object inicial */
let baileysMessage = { mentions: noEveryone };
/* Define como buscar */
const switchTypeFt = isQuotedMsg ? quotedTypeFormated : typeFormatted;
/* Define os dados da mensagem por meio do seu tipo */
switch (switchTypeFt) {
/* Imagem */
case 'image':
baileysMessage.image = decryptedMedia;
baileysMessage.caption = (body || quotedMsgObj.caption || insertContext).replace(/--show/gi, `\n\n@${noEveryFormatted.join(' @')}`).replace(replaceCmd, '');
baileysMessage.mimetype = mimetype;
break;
/* audio */
case 'audio':
baileysMessage.audio = decryptedMedia;
baileysMessage.mimetype = mimetype;
baileysMessage.ptt = quotedMsgObj.ptt || true;
break;
/* contact */
case 'contact':
case 'contactsArray':
baileysMessage.contacts = { displayName: quotedMsgObj.displayName, contacts: quotedMsgObj.contacts };
break;
/* Documento */
case 'document':
case 'documentWithCaption':
baileysMessage.document = decryptedMedia;
baileysMessage.mimetype = mimetype;
baileysMessage.fileName = quotedMsgObj.fileName;
baileysMessage.caption = (body || quotedMsgObj.caption || insertContext).replace(/--show/gi, `\n\n@${noEveryFormatted.join(' @')}`).replace(replaceCmd, '');
break;
/* Stickers */
case 'sticker':
/* Constrói o sticker, se deixar em 100% nos videos pode travar o sticker */
baileysMessage = await new Sticker(decryptedMedia, {
...stickerConfig,
type: 'default',
}).toMessage();
break;
/* Localização */
case 'location':
case 'liveLocation':
baileysMessage.location = { degreesLatitude: quotedMsgObj.degreesLatitude, degreesLongitude: quotedMsgObj.degreesLongitude };
break;
/* Video */
case 'video':
baileysMessage.video = decryptedMedia;
baileysMessage.caption = (body || quotedMsgObj.caption || insertContext).replace(/--show/gi, `\n\n@${noEveryFormatted.join(' @')}`).replace(replaceCmd, '');
baileysMessage.mimetype = mimetype;
break;
/* Conversation, URL e outros */
default:
baileysMessage.text = body || quotedMsgObj.matchedText || quotedMsgObj.text || quotedMsgObj.caption || quotedMsgObj.conversation || quotedMsgObj;
baileysMessage.text = typeof baileysMessage.text === 'object' ? insertContext : baileysMessage.text;
baileysMessage.text = baileysMessage.text.replace(/--show/gi, `\n\n@${noEveryFormatted.join(' @')}`).replace(replaceCmd, '');
break;
}
/* Reencaminha a mensagem da pessoa */
envInfo.results.value = await kill.sendMessage(chatId, baileysMessage, reply);
/* Se caso não for permitido */
} else {
/* Avisa que 'só adm' pode usar */
envInfo.results.value = await kill.sendMessage(chatId, { text: Indexer('sql').languages(region, 'Helper', 'Restrict', true, true, env.value).value }, reply);
}
}
/* Define o sucesso, se seu comando der erro isso jamais será chamado, então o success automaticamente será false em falhas */
envInfo.results.success = true;
/* Caso de algum erro */
} catch (error) {
/* Insere tudo na envInfo */
logging.echoError(error, envInfo, __dirname);
/* Avisa que deu erro enviando o comando e data atual pro sistema S.E.R (Send Error Report) */
await kill.sendMessage(env.value.chatId, {
text: Indexer('sql').languages(region, 'S.E.R', error, true, true, {
command: 'EVERYONE',
time: (new Date()).toLocaleString(),
}).value,
}, env.value.reply);
}
/* Retorna os resultados */
return logging.postResults(envInfo);
}
/**
* Restaura o ambiente e atualiza as exportações do módulo com a funcionalidade principal
* @param {Object} [changeKey={}] - Chaves personalizadas para atualizar o envInfo
* @param {Object} [envFile=envInfo] - Objeto com informações do ambiente
* @param {string} [dirname=__dirname] - Caminho do diretório atual
* @returns {Object} Exportações do módulo com todas as funções configuradas
*/
/* eslint-disable-next-line no-return-assign */
const resetLocal = (
changeKey = {},
envFile = envInfo,
dirname = __dirname,
) => module.exports = logging.resetAmbient({
functions: {
[envInfo.exports.env]: { value: ambientDetails },
[envInfo.exports.messedup]: { value: logging.echoError },
[envInfo.exports.poswork]: { value: logging.postResults },
[envInfo.exports.reset]: { value: resetLocal },
[envInfo.exports.exec]: { value: tagEveryone },
},
parameters: {
location: { value: __filename },
},
}, envFile, changeKey, dirname);
resetLocal();