Skip to content

project-yui/Yui-patch

Repository files navigation

Yui-Patch

适用于Yui的底层模块。

功能

  1. 拦截国内知名聊天软件的文件验证,下文称之为 Telecord (Telegram + Discord)。

逻辑

基本原理

  1. 创建一个默认的 index.default.js,内容为安装时的 index.js 内容; 而 index.js 则为修改的内容。
  2. 拦截CreateFileW
  3. 如果第一次访问 index.js,判定为校验文件,返回 index.default.js 的fd
  4. 否则返回 index.js 的fd

优先级

绝对路径 > 相对路径(当前目录) > 相对路径(系统临时文件目录)

  1. 如果是绝对路径会直接使用绝对路径。
  2. 否则,工作目录能创建文件,会在工作目录创建文件。
  3. 工作目录没有权限会在系统临时文件夹创建文件。
  4. 如果存在文件,不会覆盖文件内容。

使用已有文件 > 创建新文件

  1. 如果文件已经存在,不会进行覆盖写入。
  2. 如果文件不存在会创建并写入 content 数据。

对于二进制文件,阁下可以手动创建文件,写成绝对路径。

使用

  1. 构建生成 dbghelp.dll 文件
  2. 放置于Telecord目录
  3. 创建patch.json文件写入内容:
    {
        "program\\resources\\app\\app_launcher\\index.js": {
            "target": "index.default.js",
            "content": "require('./launcher.node').load('external_index', module);",
            "cur": 0,
            "start": 0,
            "end": 1
        }
    }

注意

如果放置于Telecord官方安装目录,会由于权限问题无法正常使用。

但是Yui项目使用的Telecord程序是直接解压exe的,所以没有权限问题。(将来会变更为使用临时文件目录的方法,以支持官方安装目录)

目前已使用临时文件目录的方法,以支持官方安装目录。

如何看到日志

你可能会发现,项目里面用到了spdlog但是控制台没有日志输出。 那要怎么看到日志呢?

执行以下命令:cmd.exe /C ".\\program\\IM.exe > output.log 2>&1",你就可以在output.log文件里面看到了。

Q: 为什么不显示在控制台呢?

A:我也想,不知道怎么弄。

功能实现

  • 配置化映射
  • 读取配置文件

声明

请勿用于非法用途

参考项目:https://github.com/LiteLoaderQQNT/QQNTFileVerifyPatch