multica/docs/auth/desktop-integration.md
Naiyuan Qing bef3a5b3cb docs: add desktop auth integration guide
Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
2026-02-13 12:25:08 +08:00

1.5 KiB
Raw Blame History

Desktop 登录集成

登录流程

Desktop 点击登录
    ↓
启动本地 HTTP 服务器 (随机端口,如 54321)
    ↓
打开浏览器 → http://localhost:3000/api/desktop/session?port=54321&platform=web
    ↓
Web 重定向 → /login?next=...
    ↓
用户登录,调用 /api/v1/auth/login (代理到 api-dev.copilothub.ai)
    ↓
登录成功,回调 → http://127.0.0.1:54321/callback?sid=xxx&user=xxx
    ↓
Desktop 保存到 ~/.super-multica/auth.json

前端逻辑

Web 端

  • 端口:3000
  • 登录 API/api/v1/auth/login(通过 Next.js rewrites 代理到后端)
  • 登录成功后回调:http://127.0.0.1:{port}/callback?sid=xxx&user=xxx

Desktop 端

  • 点击登录 → 启动本地服务器 → 打开浏览器
  • 收到回调 → 保存到本地文件

存储

~/.super-multica/auth.json
{
  "sid": "xxx",
  "user": {
    "uid": "xxx",
    "name": "xxx",
    "email": "xxx"
  }
}

退出登录

后端只需要返回错误,前端会自动处理退出。

前端收到认证错误后:

  1. 调用 auth:clear 清除本地数据
  2. 跳转到登录页

本地调试

# 1. 启动代理 (devd)
devd -l /=http://127.0.0.1:3000 /api/=https://api-dev.copilothub.ai/api

# 2. 启动 Web
pnpm dev:web

# 3. 启动 Desktop
pnpm dev:desktop

本地调试时,通过 devd 将 /api/ 请求代理到 api-dev.copilothub.ai

参考