chatgpt-alive

Lightweight and effective solution for the ChatGPT disconnection issue requiring page refresh.

이 스크립트를 설치하려면 Tampermonkey, Greasemonkey 또는 Violentmonkey와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 Tampermonkey와 같은 확장 프로그램을 설치해야 합니다.

이 스크립트를 설치하려면 Tampermonkey 또는 Violentmonkey와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 Tampermonkey 또는 Userscripts와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 Tampermonkey와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 유저 스크립트 관리자 확장 프로그램이 필요합니다.

(이미 유저 스크립트 관리자가 설치되어 있습니다. 설치를 진행합니다!)

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

(이미 유저 스타일 관리자가 설치되어 있습니다. 설치를 진행합니다!)

// ==UserScript==
// @name         chatgpt-alive
// @name:zh-CN   chatgpt-alive
// @namespace    https://github.com/scout9ll/chatgpt-alive-extension
// @version      0.1.2
// @description  Lightweight and effective solution for the ChatGPT disconnection issue requiring page refresh.
// @description:zh-cn  轻量有效的解决chatgpt断连需要刷新页面的问题
// @author       scout9ll
// @match        https://chat.openai.com/*
// @icon         https://www.google.com/s2/favicons?sz=64&domain=openai.com
// @grant        none
// @license MIT
// ==/UserScript==

(function() {
    'use strict';
    const iframe = document.createElement("iframe");
    iframe.style.display = "none";
    document.body.appendChild(iframe);
    const heartbeatUrl = "/api/auth/session";
    const gapRange = [50000, 200000];
    function hiChatgpt() {
        setTimeout(() => {
            fetch(heartbeatUrl)
              .then((res) => {
                if (!res.ok) iframe.src = "/404";
              })
              .finally(() => {
                hiChatgpt();
              });
        }, Math.random() * (gapRange[1] - gapRange[0]) + gapRange[0]);
    }
    hiChatgpt();
})();