Fetch Logger

Logs fetch requests in a GUI for user viewing

ही स्क्रिप्ट इंस्टॉल करण्यासाठी तुम्हाला Tampermonkey, Greasemonkey किंवा Violentmonkey यासारखे एक्स्टेंशन इंस्टॉल करावे लागेल.

You will need to install an extension such as Tampermonkey to install this script.

ही स्क्रिप्ट इंस्टॉल करण्यासाठी तुम्हाला Tampermonkey किंवा Violentmonkey यासारखे एक्स्टेंशन इंस्टॉल करावे लागेल..

You will need to install an extension such as Tampermonkey or Userscripts to install this script.

ही स्क्रिप्ट इंस्टॉल करण्यासाठी तुम्हाला Tampermonkey यासारखे एक्स्टेंशन इंस्टॉल करावे लागेल..

ही स्क्रिप्ट इंस्टॉल करण्यासाठी तुम्हाला एक युझर स्क्रिप्ट व्यवस्थापक एक्स्टेंशन इंस्टॉल करावे लागेल.

(माझ्याकडे आधीच युझर स्क्रिप्ट व्यवस्थापक आहे, मला इंस्टॉल करू द्या!)

Advertisement:

ही स्टाईल इंस्टॉल करण्यासाठी तुम्हाला Stylus सारखे एक्स्टेंशन इंस्टॉल करावे लागेल.

ही स्टाईल इंस्टॉल करण्यासाठी तुम्हाला Stylus सारखे एक्स्टेंशन इंस्टॉल करावे लागेल.

ही स्टाईल इंस्टॉल करण्यासाठी तुम्हाला Stylus सारखे एक्स्टेंशन इंस्टॉल करावे लागेल.

ही स्टाईल इंस्टॉल करण्यासाठी तुम्हाला एक युझर स्टाईल व्यवस्थापक इंस्टॉल करावे लागेल.

ही स्टाईल इंस्टॉल करण्यासाठी तुम्हाला एक युझर स्टाईल व्यवस्थापक इंस्टॉल करावे लागेल.

ही स्टाईल इंस्टॉल करण्यासाठी तुम्हाला एक युझर स्टाईल व्यवस्थापक इंस्टॉल करावे लागेल.

(माझ्याकडे आधीच युझर स्टाईल व्यवस्थापक आहे, मला इंस्टॉल करू द्या!)

Advertisement:

// ==UserScript==
// @name         Fetch Logger
// @namespace    http://tampermonkey.net/
// @version      0.2 
// @description  Logs fetch requests in a GUI for user viewing
// @author       zuxity
// @match        *://*/*
// @grant        none
// ==/UserScript==

(function() {
    'use strict';

    // Create a container for logging fetch requests
    const logContainer = document.createElement('div');
    logContainer.style.position = 'fixed';
    logContainer.style.top = '0';
    logContainer.style.right = '0';
    logContainer.style.background = '#fff';
    logContainer.style.border = '1px solid #ccc';
    logContainer.style.padding = '10px';
    logContainer.style.maxWidth = '300px';
    logContainer.style.overflow = 'auto';
    logContainer.style.zIndex = '9999';
    document.body.appendChild(logContainer);

    // Intercept fetch requests
    const originalFetch = window.fetch;
    window.fetch = function(url, options) {
        return originalFetch(url, options)
            .then(response => {
                // Log the fetch request
                logFetch(url, options, response);
                return response;
            })
            .catch(error => {
                // Log errors
                logError(url, options, error);
                throw error;
            });
    };

    // Function to log fetch requests
    function logFetch(url, options, response) {
        const logEntry = document.createElement('div');
        logEntry.textContent = `URL: ${url}, Method: ${options.method}, Status: ${response.status}`;
        logContainer.appendChild(logEntry);
    }

    // Function to log errors
    function logError(url, options, error) {
        const logEntry = document.createElement('div');
        logEntry.textContent = `Error fetching ${url}: ${error}`;
        logContainer.appendChild(logEntry);
    }
})();