Character.AI Filtered Message Editor

Permanently enables the Edit button on filtered messages by stripping safety flags from all data (JSON.parse intercept).

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!)

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!)

// ==UserScript==
// @name         Character.AI Filtered Message Editor
// @namespace    https://greasyfork.org/users/YOUR_USER_ID
// @version      1.0
// @description  Permanently enables the Edit button on filtered messages by stripping safety flags from all data (JSON.parse intercept).
// @author       You
// @match        https://character.ai/*
// @match        https://neo.character.ai/*
// @grant        none
// @license      MIT
// @run-at       document-start
// ==/UserScript==

(function() {
    'use strict';

    // Inject directly into the page to bypass sandbox limitations
    const inject = function() {
        // Override JSON.parse to catch data from Network, Cache, AND HTML
        const originalParse = JSON.parse;

        JSON.parse = function(text, reviver) {
            const data = originalParse(text, reviver);

            try {
                // Recursive function to find and flip the safety flag
                const clean = (obj) => {
                    if (!obj || typeof obj !== 'object') return;

                    if (obj.safety_truncated === true) {
                        obj.safety_truncated = false;
                    }

                    if (Array.isArray(obj)) {
                        obj.forEach(clean);
                    } else {
                        Object.values(obj).forEach(clean);
                    }
                };

                // Clean the data before the website sees it
                clean(data);

            } catch (e) {
                // Silently fail on errors to keep the site running smoothly
            }

            return data;
        };
    };

    const script = document.createElement('script');
    script.textContent = `(${inject.toString()})();`;
    (document.head || document.documentElement).appendChild(script);
    script.remove();

})();