Skip to content

wps365-open/cli

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

7 Commits
 
 
 
 
 
 
 
 

Repository files navigation

WPS365 CLI

License: MIT Go Version

中文 | English

WPS 365 官方 CLI 工具 — 面向开发者与 AI Agent 的命令行入口。覆盖日历、协作、通讯录、邮箱、云文档、多维表、会议等 7 大业务域,未覆盖的接口通过 api get|post 直接访问。

安装 · 命令体系 · 认证 · 进阶用法 · 安全 · 开发 · 贡献

功能

类别 能力
📅 日历 查询日历列表、创建/更新/删除日程、管理参会人与会议室、忙闲查询、请假日程、批量操作
💬 即时通讯 发送/回复/撤回消息、群聊增删改查、成员管理、消息列表、加急、书签
👤 通讯录 查询当前用户、用户列表、按姓名/邮箱/手机号搜索、批量查询、部门与离职人员管理
📧 邮箱 邮箱管理、文件夹浏览、邮件列表/详情/搜索、发送与草稿、邮件组与通讯录管理
📁 云文档 驱动器管理、文件列表/上传/下载/搜索、批量操作、权限管理、版本管理、分享链接
📋 多维表 数据表/字段/视图管理、记录增删改查与搜索、仪表盘、Webhook、附件
🎥 会议 在线会议管理、参会人管理、预约会议、会议纪要与录制、会议室与层级管理

安装与快速开始

安装

macOS / Linux

curl -fsSL https://raw.githubusercontent.com/wps365-open/cli/main/install.sh | bash

Windows(PowerShell)

irm https://raw.githubusercontent.com/wps365-open/cli/main/install.ps1 | iex

Windows(Git Bash)

curl -fsSL https://raw.githubusercontent.com/wps365-open/cli/main/install.sh | bash

可通过环境变量自定义:

# 安装指定版本
curl -fsSL https://raw.githubusercontent.com/wps365-open/cli/main/install.sh | WPS365_VERSION=v0.0.2 bash

# 自定义安装目录
curl -fsSL https://raw.githubusercontent.com/wps365-open/cli/main/install.sh | WPS365_INSTALL_DIR=~/.local/bin bash
# PowerShell: 安装指定版本
$env:WPS365_VERSION="v0.0.2"; irm https://raw.githubusercontent.com/wps365-open/cli/main/install.ps1 | iex

# PowerShell: 自定义安装目录
$env:WPS365_INSTALL_DIR="C:\tools"; irm https://raw.githubusercontent.com/wps365-open/cli/main/install.ps1 | iex

手动下载

Release 页面

三步开始

# 1. 配置 OAuth 客户端凭证(仅需一次,交互式引导)
wps365-cli auth setup

# 2. 登录授权
wps365-cli auth login --scopes "kso.user_base.read,kso.calendar.read"

# 3. 开始使用
wps365-cli user me

双轨命令体系

CLI 提供两种粒度的调用方式,精装命令覆盖高频场景,api 命令兜底全量 API:

1. 精装命令

语义化参数、智能默认值、auth 约束自动校验,对人类与脚本友好。

wps365-cli user me
wps365-cli calendar events create primary \
  --name "周会" --from "2024-01-15T14:00:00+08:00" --to "2024-01-15T15:00:00+08:00"
wps365-cli im messages send --to u1 --to u2 --text "hello"

运行 wps365-cli <resource> --help 查看所有子命令。

2. 通用 API 调用

直接调用任意 WPS 365 开放平台端点,覆盖全部 API。

wps365-cli api get "/v7/users/current"
wps365-cli api post "/v7/calendars/create" \
  --data '{"summary": "项目日历"}'

认证

常用命令

命令 说明 使用场景
auth setup 配置 OAuth 客户端凭证 首次使用,交互式引导保存 client_idclient_secret
auth login 登录授权 --scopes 指定权限进行用户授权;--app 切换为应用身份
auth status 查看认证状态 检查当前 token 是否有效、过期时间、认证模式等
auth token 输出当前 access token 将 token 传递给其他工具或脚本,如 curl -H "Authorization: Bearer $(wps365-cli auth token)"
auth refresh 手动刷新 token 主动刷新即将过期的 token,需指定 --delegated--app
auth logout 删除本地 token 退出登录,支持 --app / --delegated 选择性删除;凭证保留,可直接重新 login
auth clean 清理所有认证数据 凭证损坏、密钥不匹配或需要完全重置时使用;清除后需从 setup 重新开始。--force 跳过确认
# 1. 首次配置(交互式引导)
wps365-cli auth setup

# 2. 用户身份登录(浏览器 OAuth 授权)
wps365-cli auth login --scopes "kso.user_base.read,kso.calendar.read"

# 3. 应用身份登录(client credentials 授权)
wps365-cli auth login --app

# 4. 非交互式(CI/CD 场景)
export WPS365_CLIENT_ID="<client-id>"
export WPS365_CLIENT_SECRET="<client-secret>"
wps365-cli auth login --app

# 5. 查看当前认证状态
wps365-cli auth status

# 6. 将 token 传给其他工具
curl -H "Authorization: Bearer $(wps365-cli auth token)" https://open.wps.cn/v7/users/current

# 7. 退出登录(保留凭证,下次可直接 login)
wps365-cli auth logout

# 8. 完全重置(清除所有 token、凭证和自动密钥)
wps365-cli auth clean --force

认证模式

模式 说明 获取方式
delegated 用户授权身份,适用于当前用户、个人待办等用户态接口 auth login --scopes "..."
app 应用身份,适用于服务端调用或应用态接口 auth login --app

命令根据底层 OpenAPI security 自动选择认证模式,--token-type 可显式覆盖。不兼容时直接报错,不静默切换。

进阶用法

输出格式

-o json      # JSON(默认)
-o yaml      # YAML
-o table     # 易读表格
-o tsv       # Tab 分隔(适合管道处理)
wps365-cli -o yaml user me
wps365-cli -o table calendar list

Dry Run

预览请求而不实际发送,方便调试和脚本验证:

wps365-cli --dry-run user me
wps365-cli --dry-run api get "/v7/users/current"
wps365-cli --dry-run -o json im messages send --to u1 --text "hello"

环境变量

变量 用途
WPS365_CLIENT_ID OAuth 客户端 ID
WPS365_CLIENT_SECRET OAuth 客户端密钥
WPS365_AUTH 默认认证模式(app / delegated
WPS365_ACCESS_TOKEN 直接注入 access token(跳过存储和刷新)
WPS365_API_BASE API 基础地址
WPS365_AUTH_URL 自定义 OAuth 授权端点
WPS365_TOKEN_URL 自定义 OAuth token 端点
WPS365_REDIRECT_URI OAuth 回调地址
WPS365_CONFIG_DIR 配置文件目录
WPS365_KEYRING_BACKEND 凭证存储后端(keychain / file
WPS365_KEYRING_PASSWORD 文件后端加密密码(可选,未设置时自动生成)
WPS365_OUTPUT 默认输出格式
WPS365_QUIET 静默 stderr 信息输出

凭证与安全

client_secret 和 token 存储在安全后端,明文永远不落盘:

  • 钥匙串(macOS/Windows 默认):使用系统 Keychain / Credential Manager
  • 加密文件(Linux 默认):AES-256-GCM 加密。未设置 WPS365_KEYRING_PASSWORD 时自动生成随机密钥并持久化到本地,无需额外配置

Token 生命周期完全自动管理:

  • access token 过期前 10 秒主动刷新
  • 401 响应时透明刷新并重试
  • delegated token 通过 refresh_token 刷新;refresh token 过期时提示重新 auth login
  • app token 过期时自动通过 client_credentials 重新获取

贡献

欢迎社区贡献!如果你发现 bug 或有功能建议,请提交 Issue 或 Pull Request。

对于较大的改动,建议先通过 Issue 讨论。

许可证

本项目基于 MIT 许可证 开源。

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Packages

 
 
 

Contributors