root d12668201f
Some checks failed
CI / lint-and-compile (push) Has been cancelled
CI / lint-and-compile (pull_request) Has been cancelled
fix: capture login API via response event listener
2026-04-17 15:40:25 +08:00

Lingma OpenAI Gateway

把本地 Lingma 能力封装为 OpenAI 兼容接口,支持:

  • GET /v1/models
  • POST /v1/chat/completions
  • stream=trueSSE
  • Bearer API Key 鉴权

1. 准备目录

mkdir -p runtime-bin

说明:

  • 启动时会自动获取最新插件并提取 Lingmaruntime-bin
  • 默认通过 VSCode Marketplace 查询最新版本,再下载对应 VSIX。

2. 配置环境变量

cp .env.example .env

至少修改:

  • API_KEYS
  • LINGMA_USERNAME
  • LINGMA_PASSWORD

如果你的 Lingma 路径不同,修改:

  • LINGMA_BIN

可选(企业专属域):

  • DEDICATED_DOMAIN_URL

.env 字段说明(简版)

  • HOST:网关监听地址(通常 0.0.0.0
  • PORT:网关监听端口(外部调用端口)
  • API_KEYSBearer Key多个用逗号分隔
  • LINGMA_BIN:容器内 Lingma 路径
  • LINGMA_SOURCE_TYPE:二进制来源(marketplace/vsix
  • LINGMA_MARKETPLACE_PUBLISHERMarketplace 发布者
  • LINGMA_MARKETPLACE_EXTENSIONMarketplace 扩展名
  • LINGMA_VSIX_URLVSIX 下载地址(最新优先)
  • LINGMA_BOOTSTRAP_ALWAYS:启动时是否总尝试刷新 Lingma
  • LINGMA_FORCE_REFRESH:是否强制刷新(忽略本地缓存)
  • LINGMA_WORK_DIRLingma 工作目录(登录与会话数据)
  • LINGMA_SOCKET_PORTLingma 本地 WS 端口
  • LINGMA_STARTUP_TIMEOUTLingma 启动等待秒数
  • LINGMA_RPC_TIMEOUT:单次 RPC 超时秒数
  • DEFAULT_MODEL:默认模型(无法映射时兜底)
  • DEFAULT_ASK_MODE:默认模式(chat/agent
  • DEDICATED_DOMAIN_URL:企业专属域(可留空)
  • AUTO_LOGIN_ENABLED:未登录时自动登录开关
  • AUTO_LOGIN_HEADLESS:自动登录是否无头浏览器
  • AUTO_LOGIN_TIMEOUT:自动登录超时秒数
  • AUTO_LOGIN_MAX_RETRY:自动登录重试次数
  • LINGMA_USERNAMELingma 登录用户名
  • LINGMA_PASSWORDLingma 登录密码

.env 最小必填示例

PORT=8317
API_KEYS=sk-your-api-key
LINGMA_USERNAME=your-username
LINGMA_PASSWORD=your-password
LINGMA_SOURCE_TYPE=marketplace
LINGMA_MARKETPLACE_PUBLISHER=Alibaba-Cloud
LINGMA_MARKETPLACE_EXTENSION=tongyi-lingma
LINGMA_VSIX_URL=https://tongyi-code.oss-cn-hangzhou.aliyuncs.com/vscode/tongyi-lingma-latest.vsix
DEDICATED_DOMAIN_URL=

3. Docker 运行

docker compose up -d --build

查看日志:

docker compose logs -f

4. 调用示例

模型列表

curl -s http://127.0.0.1:8317/v1/models \
  -H "Authorization: Bearer sk-your-api-key"

说明:

  • id 保持 Lingma 原始模型 key兼容 OpenAI 客户端)
  • name 提供可读名称(如 qwen3.6-plus
  • 调用 /v1/chat/completions 时,model 既可传 id,也可直接传 name

非流式聊天

curl -s http://127.0.0.1:8317/v1/chat/completions \
  -H "Authorization: Bearer sk-your-api-key" \
  -H "Content-Type: application/json" \
  -d '{
    "model": "dashscope_qmodel",
    "messages": [
      {"role": "user", "content": "写一个 python hello world"}
    ]
  }'

流式聊天

curl -N http://127.0.0.1:8317/v1/chat/completions \
  -H "Authorization: Bearer sk-your-api-key" \
  -H "Content-Type: application/json" \
  -d '{
    "model": "dashscope_qmodel",
    "stream": true,
    "messages": [
      {"role": "user", "content": "介绍一下你自己"}
    ]
  }'

5. 统计与监控

支持调用次数与 token估算值统计

  • GET /internal/stats(需 Bearer
  • GET /metricsPrometheus 文本格式)

示例:

curl -s http://127.0.0.1:8317/internal/stats \
  -H "Authorization: Bearer sk-xxx"
curl -s http://127.0.0.1:8317/metrics

说明:

  • usage.prompt_tokens/completion_tokens 为估算值(按字节近似换算)。
  • 非流式响应里会附带 usage 字段。

6. 容器内自动登录

已内置自动登录能力Playwright + Chromium

你可以主动触发:

curl -s -X POST http://127.0.0.1:8317/internal/auto-login/start \
  -H "Authorization: Bearer sk-your-api-key"

查看状态:

curl -s http://127.0.0.1:8317/internal/auto-login/status \
  -H "Authorization: Bearer sk-your-api-key"

说明:

  • 若未登录,/v1/models/v1/chat/completions 也会尝试自动登录。
  • 账号密码来自 .envLINGMA_USERNAME / LINGMA_PASSWORD)。
  • 建议仅在受控环境使用,并妥善保护 .env

7. agent 模式

在 v1 中,若 modelagentlingma-agent,会走 agent 模式。

curl -s http://127.0.0.1:8317/v1/chat/completions \
  -H "Authorization: Bearer sk-xxx" \
  -H "Content-Type: application/json" \
  -d '{
    "model": "agent",
    "messages": [
      {"role": "user", "content": "分析这个项目目录结构"}
    ]
  }'
Description
No description provided
Readme 1.3 MiB
Languages
Python 98.8%
Shell 0.9%
Dockerfile 0.3%