数据全在本地。无后端、无中间服务器,只有你的 Mac。
- 采集 —— URL 正文提取 + 封面、RSS / Atom / JSON 订阅(去重、条件请求、并发同步)、本地 PDF/图片导入。
- 阅读 —— 三栏布局、划词高亮与笔记、双语对照、衬线/排版调节、阅读进度与位置记忆。
- 整理 —— 标签、树形目录、收藏、SQLite FTS5 全文搜索(中英文)、条目删除、键盘导航。
- AI(自带 Key) —— 摘要(结构化)、翻译(逐段保 id)、对话与二次创作(流式输出);结果回流落库,离线可读。
- 本地优先 —— 库 / 高亮 / 笔记 / 阅读位置全部本地持久化;AI 默认关闭、显式开启、绝不自动发送。
-
从 Releases 下载
Reader.dmg。 -
打开 DMG,把 Reader 拖进 Applications。
-
首次打开 —— 当前版本未做 Apple 公证,需放行一次 Gatekeeper:在「应用程序」里右键 Reader → 打开,或在终端执行:
xattr -dr com.apple.quarantine /Applications/Reader.app
App 菜单 Reader → 检查更新… 即可。更新由 Sparkle 分发,经 EdDSA 签名校验,不必再去网站手动下载。
在应用内「设置」选择 Provider 并填入 Key(只存 Keychain):
- Anthropic 官方 —— 默认
api.anthropic.com。 - Anthropic 兼容网关 / 自定义端点 —— 填 Base URL + 鉴权方式(API Key 或 Auth Token)+ 模型;模型支持
xxx[1m]写法(自动转 1M 上下文)。可直接粘贴连接配置(形如{"env":{"ANTHROPIC_BASE_URL":...,"ANTHROPIC_AUTH_TOKEN":...},"model":...})一键导入。 - OpenAI / OpenAI 兼容 —— 填 Base URL(可指向本地 Ollama / LM Studio)+ 模型。
AI 处理会把所选内容发送到你配置的端点;其余数据始终只在本地。
- 数据库:
~/Library/Application Support/ReaderMacApp/reader.sqlite - API Key:macOS Keychain(按 Provider 隔离,不写入磁盘明文)
- 不收集、不上传任何遥测;唯一的对外请求是你主动触发的 AI 调用与订阅抓取。
swift build # 编译
swift test # 全部单测
./script/build_and_run.sh # 开发期:拼最小 .app 并运行
./script/package_app.sh # 打包成品:dist/Reader.app + dist/Reader.dmgSwift 5.9 / SwiftUI / macOS 13+,SwiftPM 单工程,原生 URLSession(AI 与抓取均无第三方 SDK)。依赖 GRDB(SQLite/FTS5)、SwiftSoup(正文提取)、FeedKit(订阅解析)、Sparkle(自更新)。
Sources/
ReaderCore/ # 纯逻辑,与 UI 解耦,可单测
AI/ # AIService 协议 + Anthropic / OpenAI 兼容 + Prompts + Keychain
Capture/ # HTTPClient / 正文提取 / RSS 同步 / 附件导入
Persistence/ # Repository 协议 + GRDB 实现 + 迁移(含 FTS5)
ReaderMacApp/ # SwiftUI 界面(App / Views / Support)
Tests/ # 91 个单测(零真实网络,mock 传输 + fixture)
以本地优先为原则构建 · 数据归你所有