Monitor de Tráfego de Dados ↓↑

Exibe em tempo real a quantidade de dados recebidos e enviados no site. No entanto possui limitações na detecção de upload de arquivos.

// ==UserScript==
// @namespace    http://linkme.bio/jhonpergon/?userscript=redemonitor
// @version      0.2
// @author       Jhon Pérgon

// @name         Monitor de Tráfego de Dados ↓↑
// @name:pt         Monitor de Tráfego de Dados ↓↑
// @name:pt-BR         Monitor de Tráfego de Dados ↓↑
// @name:pt-PT         Monitor de Tráfego de Dados ↓↑
// @name:es         Monitor de Tráfico de Datos ↓↑
// @name:en         Monitor de Tráfego de Dados ↓↑
// @name:fr         Monitor de Trafic de Données ↓↑
// @name:ru         Мониторинг Трафика Данных ↓↑
// @name:ja         データトラフィックモニター ↓↑
// @name:ko         데이터 트래픽 모니터 ↓↑
// @name:zh-TW         數據流量監控 ↓↑
// @name:zh-CN         数据流量监控 ↓↑
// @name:id         Monitor Lalu Lintas Data ↓↑
// @name:ug         داتا ترافىك كونتروللىغۇچ ↓↑
// @name:ar         جهاز مراقبة حركة البيانات ↓↑
// @name:he         מוניטור תנועת נתונים ↓↑
// @name:hi         डेटा ट्रैफिक मॉनिटर ↓↑
// @name:th         ตัวเฝ้าระวังการจราจรข้อมูล ↓↑
// @name:bg         Монитор на Трафика на Данни ↓↑
// @name:ro         Monitor de Trafic de Date ↓↑
// @name:fi         Tietoliikenteen Monitori ↓↑
// @name:it         Monitor del Traffico Dati ↓↑
// @name:el         Παρακολούθηση της Κίνησης Δεδομένων ↓↑
// @name:eo         Datentrafikomonitoro ↓↑
// @name:hu         Adatforgalom Figyelő ↓↑
// @name:nb         Data Trafikkovervåker ↓↑
// @name:sk         Monitor Dátového Toku ↓↑
// @name:sv         Data Trafikövervakare ↓↑
// @name:sr         Монитор Саобраћаја Података ↓↑
// @name:pl         Monitor Ruchu Danych ↓↑
// @name:nl         Data Verkeer Monitor ↓↑
// @name:de         Datenverkehrsmonitor ↓↑
// @name:da         Data Trafikovervågning ↓↑
// @name:cs         Monitor Datového Toku ↓↑
// @name:uk         Монітор Трафіку Даних ↓↑
// @name:tr         Veri Trafik İzleyici ↓↑
// @name:vi         Giám Sát Lưu Lượng Dữ Liệu ↓↑
// @name:fr-CA         Monitor de Trafic de Données ↓↑

// @description         Exibe em tempo real a quantidade de dados recebidos e enviados no site. No entanto possui limitações na detecção de upload de arquivos.
// @description:pt         Mostra em tempo real a quantidade de dados recebidos e enviados no site. No entanto, tem limitações na detecção de upload de arquivos.
// @description:pt-BR         Exibe em tempo real a quantidade de dados recebidos e enviados no site. No entanto, tem limitações na detecção de upload de arquivos.
// @description:pt-PT         Mostra em tempo real a quantidade de dados recebidos e enviados no site. No entanto, tem limitações na detecção de upload de arquivos.
// @description:en         Displays in real time the amount of data received and sent on the website. However, it has limitations in detecting file uploads.
// @description:es         Muestra en tiempo real la cantidad de datos recibidos y enviados en el sitio. Sin embargo, tiene limitaciones en la detección de la carga de archivos.
// @description:fr         Affiche en temps réel la quantité de données reçues et envoyées sur le site. Cependant, il présente des limitations dans la détection du téléchargement de fichiers.
// @description:ru         Показывает в реальном времени количество данных, полученных и отправленных на сайте. Однако есть ограничения в обнаружении загрузки файлов.
// @description:ja         サイトで受信および送信されたデータの量をリアルタイムで表示します。ただし、ファイルのアップロードの検出に制限があります。
// @description:ko         사이트에서 수신 및 송신된 데이터 양을 실시간으로 표시합니다. 그러나 파일 업로드 감지에는 제한 사항이 있습니다.
// @description:zh-TW         實時顯示網站接收和發送的數據量。但是,在檔案上傳檢測方面存在限制。
// @description:zh-CN         实时显示网站接收和发送的数据量。但是,在文件上传检测方面存在限制。
// @description:id         Menampilkan jumlah data yang diterima dan dikirim secara real-time di situs web. Namun, memiliki keterbatasan dalam mendeteksi unggahan berkas.
// @description:ug         ئاپتا سىتادا يوللىنىپ كېتىپ بولغان ئۇچۇر سانىنى تەھرىرلىۋاتىدۇ. بىراق، ھۆججەت يۈكلەشنى تەكشۈرۈش ۋەجۇدىيەتلەرى بار.
// @description:ar         يعرض في الوقت الحقيقي كمية البيانات التي تم استلامها وإرسالها على الموقع. ومع ذلك، يوجد قيود في الكشف عن تحميل الملفات.
// @description:he         מציג בזמן אמת כמות של נתונים שנשלחו והתקבלו באתר. אך יש לו הגבלות בזיהוי העלאת קבצים.
// @description:hi         साइट पर प्राप्त और भेजे गए डेटा की मात्रा को वास्तविक समय में प्रदर्शित करता है। हालांकि, फ़ाइल अपलोड की पहचान में कुछ सीमाएं हैं.
// @description:th         แสดงปริมาณข้อมูลที่รับและส่งในเวลาจริงบนเว็บไซต์ แต่มีข้อจำกัดในการตรวจจับการอัปโหลดไฟล์.
// @description:bg         Показва в реално време количеството данни, получавани и изпращани на сайта. Въпреки това има ограничения при откриването на качването на файлове.
// @description:ro         Afișează în timp real cantitatea de date primite și trimise pe site. Cu toate acestea, există limitări în detectarea încărcării de fișiere.
// @description:fi         Näyttää reaaliajassa sivustolle saapuneen ja lähetetyn datan määrän. Huomaa kuitenkin, että se on rajoitettu tiedoston lataamisen havaitsemisessa.
// @description:it         Mostra in tempo reale la quantità di dati ricevuti e inviati sul sito. Tuttavia, presenta limitazioni nella rilevazione dell'upload dei file.
// @description:el         Εμφανίζει σε πραγματικό χρόνο τον όγκο των δεδομένων που λαμβάνονται και αποστέλλονται στον ιστότοπο. Ωστόσο, υπάρχουν περιορισμοί στην ανίχνευση της μεταφόρτωσης αρχείων.
// @description:eo         Montras en tempo realan la kvanton de datumoj ricevitaj kaj senditaj sur la retejo. Tamen, ĝi havas limigojn en la detekto de alŝuto de dosieroj.
// @description:hu         Valós időben mutatja be az oldalon kapott és elküldött adatok mennyiségét. Azonban korlátozásokkal jár a fájlfeltöltés érzékelésében.
// @description:nb         Viser i sanntid mengden data som mottas og sendes på nettstedet. Det har imidlertid begrensninger i deteksjonen av opplasting av filer.
// @description:sk         Zobrazuje v reálnom čase množstvo dát prijatých a odoslaných na webovej stránke. Má však obmedzenia pri detekcii nahrávania súborov.
// @description:sv         Visar i realtid mängden data som tas emot och skickas på webbplatsen. Det har dock begränsningar i upptäckten av filuppladdning.
// @description:sr         Приказује у реалном времену количину података који су примљени и послати на веб-сајту. Међутим, постоје ограничења у откривању учитавања фајлова.
// @description:pl         Wyświetla w czasie rzeczywistym ilość danych otrzymanych i wysłanych na stronie internetowej. Jednak ma ograniczenia w wykrywaniu przesyłania plików.
// @description:nl         Toont in realtime de hoeveelheid ontvangen en verzonden gegevens op de website. Het heeft echter beperkingen bij het detecteren van het uploaden van bestanden.
// @description:de         Zeigt in Echtzeit die Menge der auf der Website empfangenen und gesendeten Daten an. Es gibt jedoch Einschränkungen bei der Erkennung von Datei-Uploads.
// @description:da         Viser i realtid mængden af data, der er modtaget og sendt på webstedet. Det har dog begrænsninger i opdagelsen af filoverførsel.
// @description:cs         Zobrazuje v reálném čase množství dat přijatých a odeslaných na webu. Má však omezení ve sledování nahrávání souborů.
// @description:uk         Показує в реальному часі кількість даних, отриманих і відправлених на сайті. Проте є обмеження в виявленні завантаження файлів.
// @description:tr         Sitede alınan ve gönderilen veri miktarını gerçek zamanlı olarak gösterir. Ancak dosya yükleme tespitinde sınırlamaları vardır.
// @description:vi         Hiển thị số lượng dữ liệu nhận và gửi trên trang web trong thời gian thực. Tuy nhiên, có hạn chế trong việc phát hiện tải lên tệp.
// @description:fr-CA         Affiche en temps réel la quantité de données reçues et envoyées sur le site. Cependant, il présente des limites dans la détection du téléchargement de fichiers.

// @icon         
// @match        *://*/*
// @grant        none
// @license      MIT
// @grant        GM_addStyle
// ==/UserScript==

(function() {
    'use strict';

    GM_addStyle('@import url("https://cdn.jsdelivr.net/npm/bootstrap-icons@1.8.3/font/bootstrap-icons.css");');

    let addOne = false;
    // Crie um elemento de div para exibir o tráfego de rede
    const trafficDiv = document.createElement('div');
    trafficDiv.style.position = 'fixed';
    trafficDiv.style.zIndex = '999999';
    trafficDiv.style.left = '0';
    trafficDiv.style.bottom = '0';
    trafficDiv.style.fontSize = '11px';
    trafficDiv.style.backgroundColor = 'rgba(0, 0, 0, 0.7)';
    trafficDiv.style.color = 'white';
    trafficDiv.style.padding = '5px';

    if(addOne == false){
      document.body.appendChild(trafficDiv);
      addOne = true;
    }

    // Variável para rastrear o tamanho total dos recursos recebidos no último segundo
    let totalReceivedSize = 0;
    let receivedLastSecond = 0;
    let totalUploadedSize = 0;
    let uploadedLastSecond = 0;

    // Função para formatar bytes em KB ou MB
    function formatBytes(bytes) {
        if (bytes < 1024) {
            return bytes.toFixed(2) + ' Kb';
        } else if (bytes < 1024 * 1024) {
            return (bytes / 1024).toFixed(1) + ' Kb';
        } else {
            return (bytes / (1024 * 1024)).toFixed(1) + ' Mb';
        }
    }

    // Função para atualizar o tráfego de rede
    function updateTraffic() {
        // Obtenha os dados de tráfego de rede
        const resources = window.performance.getEntriesByType('resource');

        // Calcule o tamanho dos recursos recebidos nos últimos segundos
        const now = performance.now();
        const receivedThisSecond = resources.reduce((acc, entry) => {
            if (now - entry.responseEnd < 1000) { // dentro do último segundo
                return acc + entry.transferSize;
            } else {
                return acc;
            }
        }, 0);

        // Calcule a velocidade de download no último segundo
        const downloadSpeed = (receivedThisSecond - receivedLastSecond) / 1024; // em KB/s
        receivedLastSecond = receivedThisSecond;
        totalReceivedSize += receivedThisSecond;

        // Calcule a velocidade de upload no último segundo
        const uploadedThisSecond = totalUploadedSize - uploadedLastSecond;
        const uploadSpeed = uploadedThisSecond / 1024; // em KB/s
        uploadedLastSecond = totalUploadedSize;

        // Atualize o conteúdo da div com os dados de tráfego formatados
        trafficDiv.innerHTML = `<b><i class="bi bi-arrow-down"></i> ${formatBytes(totalReceivedSize)} • <i class="bi bi-speedometer"></i> ${formatBytes(receivedThisSecond)} | <i class="bi bi-arrow-up"></i> ${formatBytes(uploadedThisSecond)}</b>`;
    }

    // Adicione um ouvinte de eventos para elementos de input type=file para rastrear o tamanho dos arquivos enviados
    document.body.addEventListener('change', function(event) {
        if (event.target && event.target.tagName === 'INPUT' && event.target.type === 'file') {
            const files = event.target.files;
            for (let i = 0; i < files.length; i++) {
                totalUploadedSize += files[i].size;
            }
            updateTraffic();
        }
    });

    // Chame a função de atualização a cada segundo
    setInterval(updateTraffic, 1000);
})();