Webpack

Expose webpack modules to userscripts

目前为 2023-08-26 提交的版本。查看 最新版本

此脚本不应直接安装,它是一个供其他脚本使用的外部库。如果您需要使用该库,请在脚本元属性加入:// @require https://update.gf.qytechs.cn/scripts/473902/1240908/Webpack.js

// ==UserScript==
// @name         Webpack
// @namespace    osu
// @version      1.0.5
// @description  Expose webpack modules to userscripts
// @author       Magnus Cosmos
// ==/UserScript==

function isNonEmptyObj(obj) {
    if (obj === null || (typeof obj !== "function" && typeof obj !== "object")) {
        return false;
    }
    for (const key in obj) {
        return true;
    }
    return false;
}

// Based on `Webpack-module-crack` and `moduleRaid`
class Webpack {
    constructor(options) {
        const { moduleId, chunkId, entryPoint } = options || {};
        this.moduleId = moduleId || Math.random().toString(36).substring(2, 6);
        this.chunkId = chunkId || Math.floor(101 + Math.random() * 899);
        this.modules = {};
        this.data = [
            [this.chunkId],
            {
                [this.moduleId]: (module, exports, require) => {
                    const installedModules = require.c;
                    for (const id in installedModules) {
                        const exports = installedModules[id].exports;
                        if (isNonEmptyObj(exports)) {
                            this.modules[id] = exports;
                        }
                    }
                },
            },
            [[this.moduleId]],
        ];
        if (entryPoint) {
            this.inject(entryPoint);
        } else {
            this.inject("webpackJsonp");
        }
    }

    inject(entryPoint) {
        try {
            if (unsafeWindow) {
                unsafeWindow[entryPoint].push(this.data);
            } else {
                window[entryPoint].push(this.data);
            }
        } catch (err) {
            throw new Error(`Injection failed: ${err.message}`);
        }
    }
}

QingJ © 2025

镜像随时可能失效,请加Q群300939539或关注我们的公众号极客氢云获取最新地址