Skip to content

服务端 API 参考

LX Sync Server 提供了多种 RESTful 风格的 API 接口,用于自动化获取和操控同步服务器数据以及状态。

概述

为了确保安全性,API 要求进行鉴权。目前主要支持以下两种鉴权方式:

  1. 管理员鉴权 (x-frontend-auth): 使用管理终端的全局口令(frontend.password)。用于敏感的服务控制、用户管理及全局数据提取。
  2. 用户 Token 鉴权 (x-user-token): 使用通过登录接口获取的动态 Session Token 或管理面板生成的持久化 API Token。用于操作特定用户的数据(如歌单、设置、缓存等)。

所有接口如无特殊说明均使用 JSON 作为请求体及响应体类型 (Content-Type: application/json)。


1. 认证与账户管理 API

1.1 管理员:服务状态 (GET /api/status)

获取同步服务器整体内存消耗、设备在线情况、运行时间汇总状态。

  • Header Auth: x-frontend-auth: <Admin Password>

1.2 管理员:用户管理 (/api/users)

  • Header Auth: x-frontend-auth: <Admin Password>
  • GET /api/users: 获取所有用户列表及密码。
  • POST /api/users: 创建新用户 ({"name": "...", "password": "..."})。
  • PUT /api/users: 修改用户信息 (重命名或修改密码) ({"name": "原用户名", "newName": "新用户名", "password": "新密码"})。
  • DELETE /api/users: 删除用户 ({"names": ["..."], "deleteData": true})。

1.3 用户:登录获取 Token (POST /api/user/login)

使用用户名密码登录并颁发 Token。

  • Body: {"username": "...", "password": "..."}
  • 响应: {"success": true, "token": "lx_tk_...", "username": "..."}

1.4 用户:登出 (POST /api/user/logout)

注销当前的 Session Token。

  • Header Auth: x-user-token: <Token>

1.5 用户:认证有效性检查 (GET /api/user/auth/verify)

检查当前 Token 是否还有效。

  • Header Auth: x-user-token: <Token>

2. Token 安全管理 API

用于在管理面板或客户端管理持久化的 API Token。要求使用 x-user-token 进行鉴权。

  • GET /api/user/token/config: 获取当前用户的 Token 认证配置(是否开启及列表)。
  • POST /api/user/token/config: 开启或关闭 Token 认证功能 ({"enabled": true/false})。
  • POST /api/user/token/add: 生成新的持久化 API Token ({"name": "名称", "expireDays": 7})。
  • POST /api/user/token/remove: 删除指定 Token ({"token": "..."})。
  • POST /api/user/token/update: 更新 Token 信息(名称、有效期)。
  • POST /api/user/token/toggle: 禁用或启用某个已生成的 Token。
  • GET /api/user/token/logs: 获取特定 Token 的审计/访问日志(需传入 tokenMasked 参数)。

3. 数据与同步 API

此类接口用于管理用户的核心同步数据。

3.1 歌单管理

  • GET /api/user/list: 获取用户当前完整歌单数据。
  • POST /api/user/list: 全量覆盖更新用户歌单数据(会触发同步广播)。
  • POST /api/music/user/list/remove: 批量删除指定歌单中的歌曲 ({"listId": "...", "songIds": [...]})。

3.2 历史快照 (Snapshot)

  • GET /api/data/snapshots: 获取快照列表。
  • GET /api/data/snapshot: 获取特定快照的数据。
  • POST /api/data/restore-snapshot: 恢复到指定快照。
  • POST /api/data/delete-snapshot: 删除特定快照。
  • POST /api/data/upload-snapshot: 手动上传备份快照。

3.3 用户设置与音效

  • GET /api/user/settings: 获取用户应用设置。
  • POST /api/user/settings: 更新用户应用设置。
  • GET /api/user/sound-effects: 获取用户均衡器/音效设置。
  • POST /api/user/sound-effects: 更新用户音效设置。

4. 多媒体核心 API (Web Player 支持)

4.1 搜索与提示

  • GET /api/music/search: 音乐搜索(支持 kw, kg, tx, wy, mg)。
  • GET /api/music/tipSearch: 搜索关键词联想提示。
  • GET /api/music/hotSearch: 各平台实时热搜榜单。

4.2 广场与榜单

  • GET /api/music/songList/tags: 获取歌单分类标签。
  • GET /api/music/songList/list: 获取指定标签的精选歌单列表。
  • GET /api/music/songList/detail: 获取歌单详情(完整歌曲列表)。
  • GET /api/music/leaderboard/boards: 获取排行榜分类。
  • GET /api/music/leaderboard/list: 获取排行榜内的歌曲。

4.3 播放与歌词

  • POST /api/music/url: 获取音乐播放直链。
    • Header Support: 可选 x-req-id 用于 SSE 进度追踪。
    • Progress: 可通过 GET /api/music/progress?reqId=xxx 订阅 SSE 获取自定义源解析进度。
  • POST /api/music/lyric: 获取歌词。
  • POST /api/music/comment: 获取歌曲评论(支持 hot/new 类型)。

4.4 下载与转发 (GET /api/music/download)

代理下载音乐文件,支持自动注入 ID3 标签。

  • Params: url, filename, tag=1 (注入标签), name, singer, album, pic

5. 服务端文件缓存 API

用户可以通过接口管理缓存在服务器上的音乐文件和歌词。

  • GET /api/music/cache/stats: 获取当前用户的缓存统计(文件数、占用空间)。
  • GET /api/music/cache/list: 获取详细的缓存文件列表。
  • POST /api/music/cache/download: 触发服务器后台下载歌曲并缓存。
  • POST /api/music/cache/remove: 删除指定的缓存文件。
  • POST /api/music/cache/clear: 清理所有音乐缓存。
  • POST /api/music/cache/lyric: 保存或读取歌词缓存。

6. 自定义源管理 API

  • GET /api/custom-source/list: 获取已导入的自定义源列表。
  • POST /api/custom-source/import: 在线导入自定义源脚本。
  • POST /api/custom-source/upload: 上传本地脚本文件。
  • POST /api/custom-source/toggle: 启用或禁用某个源。
  • POST /api/custom-source/delete: 删除自定义源。
  • POST /api/custom-source/reorder: 对自定义源进行排序。

7. 全局系统配置 API (管理员权限)

用于管理后台对服务器核心行为的实时调整。要求 x-frontend-auth 鉴权。

  • GET /api/config: 获取服务器当前的所有可配置项(含环境变量覆盖后的最终值)。
  • POST /api/config: 增量更新全局配置。
    • 参数示例: {"singer.sourcePriority": ["tx", "wy"], "user.enablePublicRestriction": true}
    • 验证: 某些字段(如 singer.sourcePriority)会进行合法性校验。

8. Web 播放器专属 API

专为 Web 播放器前端逻辑设计的接口,支持基于 Session 的访问。

8.1 基础配置与认证

  • GET /api/music/config: 公开接口,获取 Web 播放器的运行状态配置。
    • 响应: {"player.enableAuth": boolean, "user.enablePublicRestriction": boolean}
  • POST /api/music/auth: 校验访问密码,成功后下发 lx_player_session HttpOnly Cookie。
  • POST /api/music/auth/logout: 彻底注销当前的 Session 会话。
  • GET /api/music/auth/verify: 检查当前 Session 是否依然有效。

8.2 增强元数据详情

  • GET /api/music/artistDetail: 获取歌手精美详情。
    • Params: source (tx/wy), id (歌手Mid/ID)。
    • Return: 含 name, desc, avatar, fans 等。
  • GET /api/music/artistAlbums: 分页获取歌手的专辑列表。
  • GET /api/music/artistSongs: 分页获取歌手的全部歌曲。
  • GET /api/music/albumSongs: 获取指定专辑内的所有音轨详情。

8.3 实时进度 (SSE)

  • GET /api/music/progress?reqId=xxx: 通过 Server-Sent Events (SSE) 实时订阅外链解析、缓存进度等流式信息。

Released under the Apache-2.0 License.