Source: Functions/Verifiers/Antilinks/index.js

/* eslint-disable max-len */

/* Requires */
const fs = require('fs');
const path = require('path');
const Indexer = require('../../../index');

/* JSON's | Utilidades */
const envInfo = JSON.parse(fs.readFileSync(`${__dirname}/utils.json`));
let ongoingChecks = [];

/**
 * 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;
}

/* Configura o antispam */
async function filterLinks(
    kill = envInfo.functions.spam.arguments.kill.value,
    env = envInfo.functions.spam.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') {
            /* Importa os valores */
            const {
                urlData,
                isInvite,
                user,
                userFormated,
                isGroup,
                isOwner,
                messageKey,
                isBotGroupAdmins,
                groupMembersId,
                isModerator,
                isGroupAdmins,
                groupAdmins,
                chatId,
                isGroupCreator,
                functions,
            } = env.value;

            /* Só inicia em condições corretas */
            if (isGroup && !isGroupAdmins && !isGroupCreator && !isOwner && !isModerator && isBotGroupAdmins) {
                /* Define as condições */
                let conditions = functions.antilinks.enable === true && (
                    /* É um link com block de todos os links */
                    (urlData.isURL && functions.antilinks.type === 1)

                    /* É um convite com block de todos os links */
                    || (isInvite && functions.antilinks.type === 1)

                    /* É um convite com block apenas de convites */
                    || (isInvite && functions.antilinks.type === 2)
                );

                /* Reajuste da condição */
                if (conditions === false && functions.antilinks.type === 3 && functions.antilinks.enable === true) {
                    /* Faz um for para verificar cada link */
                    for (let i = 0; i < urlData.hostnames.length; i += 1) {
                        /* Define a execução no arquivo de hosts */
                        const isBadURL = Indexer('bash').bash(`bash "${path.normalize(`${irisPath}/lib/Scripts/Others/Hosts.sh`)}" "${urlData.hostnames[i]}" "${path.normalize(`${irisPath}/lib/Databases/Utilities/hosts.txt`)}"`).value;

                        /* Se o link existir no arquivo de hosts */
                        if (/1/gi.test(isBadURL)) {
                            /* Determina para banir */
                            conditions = true;
                        }
                    }
                }

                /* Se for condição true e um link de convite */
                if (conditions && isInvite) {
                    /* Adquire o link do grupo */
                    const groupInvite = await kill.groupInviteCode(chatId);

                    /* Se o link recebido é apenas um e é o convite do grupo atual */
                    if (urlData.allURLs.length === 1) {
                        /* Verifica se é o link do grupo atual */
                        if (urlData.allURLs[0].includes(groupInvite) || urlData.matchedURL.includes(groupInvite)) {
                            /* Cancela o ban */
                            conditions = false;
                        }
                    }
                }

                /* Se as condições de ban forem true */
                if (conditions) {
                    /* Se ainda estiver no grupo, como casos de spam ou adm remover antes da Íris */
                    /* Também ajuda a evitar SPAM da mensagem de ban ou tentativas de banir já removidos */
                    if (groupMembersId.includes(user) && !ongoingChecks.includes(user)) {
                        /* Adiciona no sistema de evitar spam */
                        ongoingChecks.push(user);

                        /* Bloqueia o grupo para apenas adms */
                        await kill.groupSettingUpdate(chatId, 'announcement');

                        /* Remove do grupo */
                        await kill.groupParticipantsUpdate(chatId, [user], 'remove');

                        /* Define a mentions */
                        const mentioning = (config.tagAdmins.value === true
                            ? [...groupAdmins, user, ...config.owner.value]
                            : [user]
                        );

                        /* Avisa da URL e do banimento */
                        await kill.sendMessage(chatId, { text: Indexer('sql').languages(region, 'Security', 'Notice', true, true, { userFormated, notice: 'URL' }).value, mentions: mentioning });

                        /* Tira do modo só admins */
                        await kill.groupSettingUpdate(chatId, 'not_announcement');

                        /* Tira do sistema de evitar spam */
                        ongoingChecks = ongoingChecks.filter((d) => d !== user);
                    }

                    /* Deleta a mensagem */
                    await kill.sendMessage(chatId, { delete: messageKey });
                }
            }
        }

        /* Define o sucesso, se seu comando der erro isso jamais será chamado */
        envInfo.results.success = true;

        /* Caso de algum erro */
    } catch (error) {
        /* Insere tudo na envInfo */
        logging.echoError(error, envInfo, __dirname);
    }

    /* Retorna os resultados */
    return logging.postResults(envInfo);
}

/* Reset profundo para evitar circular */
/**
 * 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.poswork]: { value: logging.postResults },
        [envInfo.exports.env]: { value: ambientDetails },
        [envInfo.exports.messedup]: { value: logging.echoError },
        [envInfo.exports.reset]: { value: resetLocal },
        [envInfo.exports.filter]: { value: filterLinks },
    },
    parameters: {
        location: { value: __filename },
    },
}, envFile, changeKey, dirname);
resetLocal();