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

由于特殊需要,我想 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

  • 思源笔记

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

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

    22023 引用 • 87833 回帖 • 3 关注
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 更新了该帖

相关帖子

欢迎来到这里!

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

注册 关于
请输入回帖内容 ...
  • 88250
    1. 只要遵循 AGPL 开源协议即可
    2. 不影响
    2 回复
  • kuangzeling

    非常期待,我也有这种需求

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

    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 教程,你可以在站内搜索一下。

    1 回复
  • 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 回复
  • 88250

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

    1 回复
  • muxue

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

    1 回复
  • 88250

    需要用到的

    1 回复
  • muxue

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

  • muxue

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

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

  • RenaEmiya

    感谢!

  • muxue

    感觉删除账户登录功能和 S3 同步功能比我想象中的复杂多了,等空下来学学前端三大件再继续吧。现在只出了一个删除了关于页面中联网功能的版本。大家感兴趣可以去下载试用。

请输入回帖内容 ...

推荐标签 标签

  • CSDN

    CSDN (Chinese Software Developer Network) 创立于 1999 年,是中国的 IT 社区和服务平台,为中国的软件开发者和 IT 从业者提供知识传播、职业发展、软件开发等全生命周期服务,满足他们在职业发展中学习及共享知识和信息、建立职业发展社交圈、通过软件开发实现技术商业化等刚性需求。

    14 引用 • 155 回帖 • 1 关注
  • Telegram

    Telegram 是一个非盈利性、基于云端的即时消息服务。它提供了支持各大操作系统平台的开源的客户端,也提供了很多强大的 APIs 给开发者创建自己的客户端和机器人。

    5 引用 • 35 回帖
  • JetBrains

    JetBrains 是一家捷克的软件开发公司,该公司位于捷克的布拉格,并在俄国的圣彼得堡及美国麻州波士顿都设有办公室,该公司最为人所熟知的产品是 Java 编程语言开发撰写时所用的集成开发环境:IntelliJ IDEA

    18 引用 • 54 回帖
  • 宕机

    宕机,多指一些网站、游戏、网络应用等服务器一种区别于正常运行的状态,也叫“Down 机”、“当机”或“死机”。宕机状态不仅仅是指服务器“挂掉了”、“死机了”状态,也包括服务器假死、停用、关闭等一些原因而导致出现的不能够正常运行的状态。

    13 引用 • 82 回帖 • 52 关注
  • OpenResty

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

    17 引用 • 47 关注
  • CSS

    CSS(Cascading Style Sheet)“层叠样式表”是用于控制网页样式并允许将样式信息与网页内容分离的一种标记性语言。

    197 引用 • 547 回帖
  • JVM

    JVM(Java Virtual Machine)Java 虚拟机是一个微型操作系统,有自己的硬件构架体系,还有相应的指令系统。能够识别 Java 独特的 .class 文件(字节码),能够将这些文件中的信息读取出来,使得 Java 程序只需要生成 Java 虚拟机上的字节码后就能在不同操作系统平台上进行运行。

    180 引用 • 120 回帖 • 1 关注
  • C++

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

    107 引用 • 153 回帖 • 3 关注
  • 小说

    小说是以刻画人物形象为中心,通过完整的故事情节和环境描写来反映社会生活的文学体裁。

    28 引用 • 108 回帖
  • etcd

    etcd 是一个分布式、高可用的 key-value 数据存储,专门用于在分布式系统中保存关键数据。

    5 引用 • 26 回帖 • 526 关注
  • 博客

    记录并分享人生的经历。

    273 引用 • 2388 回帖
  • 分享

    有什么新发现就分享给大家吧!

    247 引用 • 1792 回帖 • 7 关注
  • Log4j

    Log4j 是 Apache 开源的一款使用广泛的 Java 日志组件。

    20 引用 • 18 回帖 • 32 关注
  • 友情链接

    确认过眼神后的灵魂连接,站在链在!

    24 引用 • 373 回帖 • 1 关注
  • Google

    Google(Google Inc.,NASDAQ:GOOG)是一家美国上市公司(公有股份公司),于 1998 年 9 月 7 日以私有股份公司的形式创立,设计并管理一个互联网搜索引擎。Google 公司的总部称作“Googleplex”,它位于加利福尼亚山景城。Google 目前被公认为是全球规模最大的搜索引擎,它提供了简单易用的免费服务。不作恶(Don't be evil)是谷歌公司的一项非正式的公司口号。

    49 引用 • 192 回帖
  • LeetCode

    LeetCode(力扣)是一个全球极客挚爱的高质量技术成长平台,想要学习和提升专业能力从这里开始,充足技术干货等你来啃,轻松拿下 Dream Offer!

    209 引用 • 72 回帖 • 1 关注
  • ngrok

    ngrok 是一个反向代理,通过在公共的端点和本地运行的 Web 服务器之间建立一个安全的通道。

    7 引用 • 63 回帖 • 622 关注
  • 微软

    微软是一家美国跨国科技公司,也是世界 PC 软件开发的先导,由比尔·盖茨与保罗·艾伦创办于 1975 年,公司总部设立在华盛顿州的雷德蒙德(Redmond,邻近西雅图)。以研发、制造、授权和提供广泛的电脑软件服务业务为主。

    8 引用 • 44 回帖
  • gRpc
    11 引用 • 9 回帖 • 61 关注
  • Ngui

    Ngui 是一个 GUI 的排版显示引擎和跨平台的 GUI 应用程序开发框架,基于
    Node.js / OpenGL。目标是在此基础上开发 GUI 应用程序可拥有开发 WEB 应用般简单与速度同时兼顾 Native 应用程序的性能与体验。

    7 引用 • 9 回帖 • 388 关注
  • 房星科技

    房星网,我们不和没有钱的程序员谈理想,我们要让程序员又有理想又有钱。我们有雄厚的房地产行业线下资源,遍布昆明全城的 100 家门店、四千地产经纪人是我们坚实的后盾。

    6 引用 • 141 回帖 • 584 关注
  • OpenShift

    红帽提供的 PaaS 云,支持多种编程语言,为开发人员提供了更为灵活的框架、存储选择。

    14 引用 • 20 回帖 • 624 关注
  • 知乎

    知乎是网络问答社区,连接各行各业的用户。用户分享着彼此的知识、经验和见解,为中文互联网源源不断地提供多种多样的信息。

    10 引用 • 66 回帖
  • Flume

    Flume 是一套分布式的、可靠的,可用于有效地收集、聚合和搬运大量日志数据的服务架构。

    9 引用 • 6 回帖 • 621 关注
  • 链书

    链书(Chainbook)是 B3log 开源社区提供的区块链纸质书交易平台,通过 B3T 实现共享激励与价值链。可将你的闲置书籍上架到链书,我们共同构建这个全新的交易平台,让闲置书籍继续发挥它的价值。

    链书社

    链书目前已经下线,也许以后还有计划重制上线。

    14 引用 • 257 回帖
  • Android

    Android 是一种以 Linux 为基础的开放源码操作系统,主要使用于便携设备。2005 年由 Google 收购注资,并拉拢多家制造商组成开放手机联盟开发改良,逐渐扩展到到平板电脑及其他领域上。

    334 引用 • 323 回帖
  • Scala

    Scala 是一门多范式的编程语言,集成面向对象编程和函数式编程的各种特性。

    13 引用 • 11 回帖 • 124 关注