关于魔改离线版本思源的可行性咨询(持续更新进度)

由于特殊需要,我想 fork 并魔改一个完全离线的思源笔记,剔除所有登录、云同步功能以及外网请求功能(比如设置里面的谷歌统计),现在我有一些问题

  1. 思源是否允许这种魔改后的版本在商业环境使用?需要做特殊申请或版权声明吗?
  2. 删除所有外网访问相关功能是否会影响思源的本地处理?

希望 d 大能解答一下,感激不尽!

PS:现在我还没有动手,只是有这个想法而已,欢迎讨论!


更新:感谢 d 大的回复!

image.png

提前说明,本人是 C++ 选手,没有学过 go 和前端,但是我接触过一部分这方面的知识,go 的代码还是比较好看懂的,前端得再琢磨一下。也欢迎其他感兴趣的开发者与我联系,一起研究怎么删除这些功能。目前打算基于 3.15.0 版本进行魔改,简单汇总了一下可以修改的点:

  • 最快的方式是只修改前端代码,把前台页面中这些功能给删除掉,并把有开关的功能都设置为默认关闭;
  • 后端修改最快的方式是直接删除 kernel\api\router.go 中相关 API 的路由注册,这样这些函数的 API 入口没了,也就没有办法被调用了,然后再找到具体的函数,将这个函数其他调用点也剔除;

项目风险:

  • 目前还不了解怎么对思源笔记进行打包,研究中……
  • 我是一个三分钟热度的人,可能遇到困难就摆烂了,希望能有老哥时不时踢我一脚让我动起来 😂 ;
  • 后续需要从官方版本中合并 bug 修复 pr,目前暂时不考虑实时更新到最新版本的情况;

最后,我的每一步修改都会写详细的 diff 日志和修改原因,方便使用者一眼看懂到底修改了什么内容。

另外,如果这个项目真的能成,我打算基于 2.8.7(没记错的话这个版本是最后一个支持 win7 的版本)也执行一次魔改操作,这样能让这个被魔改的思源笔记能被更多的设备使用。

开整:https://github.com/musnows/siyuan-local/tree/local

  • 思源笔记

    思源笔记是一款隐私优先的个人知识管理系统,支持完全离线使用,同时也支持端到端加密同步。

    融合块、大纲和双向链接,重构你的思维。

    20928 引用 • 82119 回帖
5 操作
muxue 在 2024-09-07 12:36:30 更新了该帖
muxue 在 2024-09-07 09:05:44 更新了该帖
muxue 在 2024-09-07 09:05:23 置顶了该帖
muxue 在 2024-09-05 08:10:31 更新了该帖 muxue 在 2024-09-05 08:06:04 更新了该帖

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...
    1. 只要遵循 AGPL 开源协议即可
    2. 不影响
    2 回复
  • 非常期待,我也有这种需求

  • 好像其他人已经开发了去除登录的版本了

    1 回复
  • pakeh2866 1 赞同

    去登陆那个还是有联网功能吧

  • zhangjh

    大概知道你要干嘛了,哈哈

    1 回复
  • xnyshu

    是什么?

  • muxue

    收到,感谢!

  • sky2023 1 评论

    个人不希望搞这些东西,完全免费的东西会分流官方版本的用户,进而降低原作者的开发积极性

    1 回复
    开源就是能最大化满足不同用户的需求,这是合理的
    JeffreyChen 1 赞同
  • sky2023

    你能不能直说你的特殊需求是啥

  • daloo

    完全离线、免登录的思源笔记,理论上在非使用状态下可以通过百度云盘等网盘同步所有内容?说实话这样很理想,不过应该会影响思源笔记的商业化和发展壮大

    1 回复
  • xurdy

    就是保存为独立 markdown 文件一样呗,类似 typora 一样的吧?

    我倒是蛮期待的

    1 回复
  • muxue

    完全离线是为了满足信息安全要求,而不是和思源笔记本体抢市场。即便是思源本体也能通过你说的百度网盘进行同步,只不过需要把思源笔记给关闭后再启动同步操作。而且思源本身是不建议这样同步的。

  • muxue 1 2 赞同

    完全离线是为了满足信息安全要求,而不是和思源笔记本体抢市场。更何况我只是剔除了所有外网访问功能,理论上官方的版本在不登陆的时候和我这个版本完全一致,不存在抢用户的情况。

    我感觉老哥可能误解了,我是要把所有涉及外网访问功能去除,而不是破解 VIP 登录才能使用云同步功能的限制。包括 S3\WEBDAV 同步在内的功能也会被我删掉。

    这个版本又没有官网,只有一个 github 页面,除非经常上链滴论坛,不然压根不会知道这个版本的存在。而经常上链滴论坛的老哥基本都是思源的老用户了,本身就不是能被分流走的新用户。

    我认为肯定有喜欢思源笔记的朋友也因为公司的信息安全要求无法在公司内部使用思源。所以我想制作一个没有任何外网访问功能的思源笔记,这样它更有可能通过公司的信息安全审查,允许在内部使用。而现在的思源有第三方登录、同步、谷歌统计、自动上传日志这类外网访问的请求,即便这些功能在不使用的时候也不会发出外网请求,但只要这些功能存在,思源笔记就不太能轻易的通过信息安全审查。

    2 操作
    muxue 在 2024-09-05 08:16:37 更新了该回帖
    muxue 在 2024-09-05 07:55:42 更新了该回帖
  • muxue

    并不是,我这里要做的工作只是把思源的登录、云端同步功能全部删掉,让它变成彻彻底底的只能本地使用的笔记软件。思源本身的编辑处理操作不会有任何变化,和 typora 这类 md 编辑器还是会有区别的。

  • muxue 1 赞同

    进度更新:目前已经成功在 windows 下构建了 3.15.0 版本的 exe 并成功安装,走通了构建的这个步骤的全流程。

    PS:考虑到 arm windows 压根没啥用户,本项目可能不会去构建 arm 版本的 exe。而且由于慕雪没有 mac 机器,也不会去打包 mac 下的版本。有需要的用户可以在本项目魔改完毕后自行尝试打包。

    第一个删除的元素是谷歌统计,用来练手。

    • 前台的 about.ts 里面的 html 页面、按钮事件注册,谷歌统计发送 app\src\util\assets.ts,搜索里面关于谷歌的设置 app\src\config\search.ts 这三个文件里面的内容都删除了。
    • 后台 kernel\api\router.go 的 API 接口注册删除,配置文件 kernel\api\system.go 中的谷歌统计不再从配置文件里面获取,而是直接复制为 true 来默认 disable(其实这个赋值没啥意义,因为已经没有人读这个 config 条目了)。

    效果如下,原本的谷歌统计按钮已经消失。看来修改没有问题,并没有我想的那么复杂。

    image.png

    修改比较复杂的点应该是删除账户登录和云端同步这两个功能。由于 AI 功能必须要配置 api key 才能生效,而且大陆也没办法裸连,所以暂时不剔除 AI 功能。

    继续修改ing,欢迎大家持续关注本贴。

  • RenaEmiya

    想请教一波,如果要编译一个 win7 下能使用的 3.15,难度高么 ~

    1 回复
  • muxue

    由于我很久没有使用过 win7 了,不确定当前最新版本思源笔记的依赖项是否能在 win7 上安装。我记得站内有构建 3.10.0 版本的 win7 教程,你可以在站内搜索一下。

  • EROMIU

    windows on arm 用户落泪

    1 回复
  • 补充一下,打开集市会联网

    1 回复
  • muxue

    其实主要是没有找到构建脚本里面那个给 arm64 打包的 exe 要去哪里下。等我搞定了再问问 d 大吧。

    咳咳,找到了,https://github.com/mstorsjo/llvm-mingw/releases?q=20240518&expanded=true

    试了试,能一起打包 windows arm64 的版本,但是我不确定打包的能不能用,因为没有测试环境(理论上没问题)

    image.png

    1 操作
    muxue 在 2024-09-07 12:29:32 更新了该回帖
  • muxue 1 评论

    集市功能感觉不好删除,删掉了是不是就没办法通过本地下载插件并导入了?

    或者把本地插件列表保留,删掉云端列表?

    把需要联网的部分删掉就可以了,比如插件的获取、下载和自动检测更新
    JeffreyChen
  • muxue

    请问 D 大,在删除了云端同步功能后,本地的数据库密钥是不是也没有意义了?

    1 回复
  • 有意义的,数据仓库可以手动打快照用于备份。

    1 回复
  • muxue

    不不,我说的是数据仓库密钥(就是端到端加密的那个),不是数据库本体。打快照应该用不上密钥吧?

    1 回复
  • 需要用到的

    1 回复
  • muxue

    好的,明白了。👌 感谢解答

  • muxue

    现在出了一个删除了设置-关于页面中自动上传错误日志、下载新安装包、谷歌统计等功能的版本,欢迎大家下载体验

    https://github.com/musnows/siyuan-local/releases/tag/v3.1.5-dev1

请输入回帖内容 ...

推荐标签 标签

  • React

    React 是 Facebook 开源的一个用于构建 UI 的 JavaScript 库。

    192 引用 • 291 回帖 • 417 关注
  • C++

    C++ 是在 C 语言的基础上开发的一种通用编程语言,应用广泛。C++ 支持多种编程范式,面向对象编程、泛型编程和过程化编程。

    107 引用 • 152 回帖 • 1 关注
  • JSON

    JSON (JavaScript Object Notation)是一种轻量级的数据交换格式。易于人类阅读和编写。同时也易于机器解析和生成。

    52 引用 • 190 回帖
  • GitHub

    GitHub 于 2008 年上线,目前,除了 Git 代码仓库托管及基本的 Web 管理界面以外,还提供了订阅、讨论组、文本渲染、在线文件编辑器、协作图谱(报表)、代码片段分享(Gist)等功能。正因为这些功能所提供的便利,又经过长期的积累,GitHub 的用户活跃度很高,在开源世界里享有深远的声望,并形成了社交化编程文化(Social Coding)。

    209 引用 • 2031 回帖
  • B3log

    B3log 是一个开源组织,名字来源于“Bulletin Board Blog”缩写,目标是将独立博客与论坛结合,形成一种新的网络社区体验,详细请看 B3log 构思。目前 B3log 已经开源了多款产品:SymSoloVditor思源笔记

    1081 引用 • 3459 回帖 • 233 关注
  • Markdown

    Markdown 是一种轻量级标记语言,用户可使用纯文本编辑器来排版文档,最终通过 Markdown 引擎将文档转换为所需格式(比如 HTML、PDF 等)。

    167 引用 • 1489 回帖 • 1 关注
  • jQuery

    jQuery 是一套跨浏览器的 JavaScript 库,强化 HTML 与 JavaScript 之间的操作。由 John Resig 在 2006 年 1 月的 BarCamp NYC 上释出第一个版本。全球约有 28% 的网站使用 jQuery,是非常受欢迎的 JavaScript 库。

    63 引用 • 134 回帖 • 727 关注
  • jsoup

    jsoup 是一款 Java 的 HTML 解析器,可直接解析某个 URL 地址、HTML 文本内容。它提供了一套非常省力的 API,可通过 DOM,CSS 以及类似于 jQuery 的操作方法来取出和操作数据。

    6 引用 • 1 回帖 • 469 关注
  • 思源笔记

    思源笔记是一款隐私优先的个人知识管理系统,支持完全离线使用,同时也支持端到端加密同步。

    融合块、大纲和双向链接,重构你的思维。

    20928 引用 • 82119 回帖
  • Quicker

    Quicker 您的指尖工具箱!操作更少,收获更多!

    28 引用 • 101 回帖
  • danl
    102 关注
  • Hprose

    Hprose 是一款先进的轻量级、跨语言、跨平台、无侵入式、高性能动态远程对象调用引擎库。它不仅简单易用,而且功能强大。你无需专门学习,只需看上几眼,就能用它轻松构建分布式应用系统。

    9 引用 • 17 回帖 • 610 关注
  • Facebook

    Facebook 是一个联系朋友的社交工具。大家可以通过它和朋友、同事、同学以及周围的人保持互动交流,分享无限上传的图片,发布链接和视频,更可以增进对朋友的了解。

    4 引用 • 15 回帖 • 461 关注
  • CAP

    CAP 指的是在一个分布式系统中, Consistency(一致性)、 Availability(可用性)、Partition tolerance(分区容错性),三者不可兼得。

    11 引用 • 5 回帖 • 599 关注
  • Windows

    Microsoft Windows 是美国微软公司研发的一套操作系统,它问世于 1985 年,起初仅仅是 Microsoft-DOS 模拟环境,后续的系统版本由于微软不断的更新升级,不但易用,也慢慢的成为家家户户人们最喜爱的操作系统。

    220 引用 • 472 回帖
  • 音乐

    你听到信仰的声音了么?

    60 引用 • 511 回帖
  • 尊园地产

    昆明尊园房地产经纪有限公司,即:Kunming Zunyuan Property Agency Company Limited(简称“尊园地产”)于 2007 年 6 月开始筹备,2007 年 8 月 18 日正式成立,注册资本 200 万元,公司性质为股份经纪有限公司,主营业务为:代租、代售、代办产权过户、办理银行按揭、担保、抵押、评估等。

    1 引用 • 22 回帖 • 724 关注
  • SpaceVim

    SpaceVim 是一个社区驱动的模块化 vim/neovim 配置集合,以模块的方式组织管理插件以
    及相关配置,为不同的语言开发量身定制了相关的开发模块,该模块提供代码自动补全,
    语法检查、格式化、调试、REPL 等特性。用户仅需载入相关语言的模块即可得到一个开箱
    即用的 Vim-IDE。

    3 引用 • 31 回帖 • 93 关注
  • frp

    frp 是一个可用于内网穿透的高性能的反向代理应用,支持 TCP、UDP、 HTTP 和 HTTPS 协议。

    19 引用 • 7 回帖 • 1 关注
  • GAE

    Google App Engine(GAE)是 Google 管理的数据中心中用于 WEB 应用程序的开发和托管的平台。2008 年 4 月 发布第一个测试版本。目前支持 Python、Java 和 Go 开发部署。全球已有数十万的开发者在其上开发了众多的应用。

    14 引用 • 42 回帖 • 723 关注
  • Thymeleaf

    Thymeleaf 是一款用于渲染 XML/XHTML/HTML5 内容的模板引擎。类似 Velocity、 FreeMarker 等,它也可以轻易的与 Spring 等 Web 框架进行集成作为 Web 应用的模板引擎。与其它模板引擎相比,Thymeleaf 最大的特点是能够直接在浏览器中打开并正确显示模板页面,而不需要启动整个 Web 应用。

    11 引用 • 19 回帖 • 335 关注
  • OkHttp

    OkHttp 是一款 HTTP & HTTP/2 客户端库,专为 Android 和 Java 应用打造。

    16 引用 • 6 回帖 • 55 关注
  • Node.js

    Node.js 是一个基于 Chrome JavaScript 运行时建立的平台, 用于方便地搭建响应速度快、易于扩展的网络应用。Node.js 使用事件驱动, 非阻塞 I/O 模型而得以轻量和高效。

    139 引用 • 268 回帖 • 85 关注
  • 以太坊

    以太坊(Ethereum)并不是一个机构,而是一款能够在区块链上实现智能合约、开源的底层系统。以太坊是一个平台和一种编程语言 Solidity,使开发人员能够建立和发布下一代去中心化应用。 以太坊可以用来编程、分散、担保和交易任何事物:投票、域名、金融交易所、众筹、公司管理、合同和知识产权等等。

    34 引用 • 367 回帖 • 2 关注
  • Maven

    Maven 是基于项目对象模型(POM)、通过一小段描述信息来管理项目的构建、报告和文档的软件项目管理工具。

    186 引用 • 318 回帖 • 327 关注
  • OpenResty

    OpenResty 是一个基于 NGINX 与 Lua 的高性能 Web 平台,其内部集成了大量精良的 Lua 库、第三方模块以及大多数的依赖项。用于方便地搭建能够处理超高并发、扩展性极高的动态 Web 应用、Web 服务和动态网关。

    17 引用 • 46 关注
  • Netty

    Netty 是一个基于 NIO 的客户端-服务器编程框架,使用 Netty 可以让你快速、简单地开发出一个可维护、高性能的网络应用,例如实现了某种协议的客户、服务端应用。

    49 引用 • 33 回帖 • 26 关注