Fetch Logger

Logs fetch requests in a GUI for user viewing

Voor het installeren van scripts heb je een extensie nodig, zoals Tampermonkey, Greasemonkey of Violentmonkey.

Voor het installeren van scripts heb je een extensie nodig, zoals {tampermonkey_link:Tampermonkey}.

Voor het installeren van scripts heb je een extensie nodig, zoals Tampermonkey of Violentmonkey.

Voor het installeren van scripts heb je een extensie nodig, zoals Tampermonkey of Userscripts.

Voor het installeren van scripts heb je een extensie nodig, zoals {tampermonkey_link:Tampermonkey}.

Voor het installeren van scripts heb je een gebruikersscriptbeheerder nodig.

(Ik heb al een user script manager, laat me het downloaden!)

Advertisement:

Voor het installeren van gebruikersstijlen heb je een extensie nodig, zoals {stylus_link:Stylus}.

Voor het installeren van gebruikersstijlen heb je een extensie nodig, zoals {stylus_link:Stylus}.

Voor het installeren van gebruikersstijlen heb je een extensie nodig, zoals {stylus_link:Stylus}.

Voor het installeren van gebruikersstijlen heb je een gebruikersstijlbeheerder nodig.

Voor het installeren van gebruikersstijlen heb je een gebruikersstijlbeheerder nodig.

Voor het installeren van gebruikersstijlen heb je een gebruikersstijlbeheerder nodig.

(Ik heb al een beheerder - laat me doorgaan met de installatie!)

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);
    }
})();