本项目使用 Go 实现了 RustDesk 的 API,并包含了 Web Admin 和 Web 客户端。RustDesk 是一个远程桌面软件,提供了自托管的解决方案。
- PC端API
- 个人版API
- 登录
- 地址簿
- 群组
- 授权登录,支持
github
,google
和OIDC
登录,支持web后台
授权登录 - i18n
- Web Admin
- 用户管理
- 设备管理
- 地址簿管理
- 标签管理
- 群组管理
- Oauth 管理
- 登录日志
- 链接日志
- 文件传输日志
- 快速使用web client
- i18n
- 通过 web client 分享给游客
- Web Client
- 自动获取API server
- 自动获取ID服务器和KEY
- 自动获取地址簿
- 游客通过临时分享链接直接远程到设备
- v2 Preview
- CLI
- 重置管理员密码
因为server端相对于客户端落后版本,server不会响应客户端的secure_tcp
请求,所以客户端超时。
相关代码代码位置在https://github.com/rustdesk/rustdesk/blob/master/src/client.rs#L322
if !key.is_empty() && !token.is_empty() {
// mainly for the security of token
allow_err!(secure_tcp(&mut socket, key).await);
}
可看到当key
和token
都不为空时,会调用secure_tcp
,但是server端不会响应,所以客户端超时
secure_tcp
代码位置在 https://github.com/rustdesk/rustdesk/blob/master/src/common.rs#L1203
- server端指定key。
- 优点:简单
- 缺点:链接不是加密的
比如
hbbs -r <relay-server-ip[:port]> -k <key> hbbr -k <key>
hbbs -r <relay-server-ip[:port]> -k abc1234567 hbbr -k abc1234567
- server端使用系统生成的key,或者自定义的密钥对,但如果client已登录,链接时容易超时或者链接不上,可以退出登录后再链接就可以了,webclient可以不用退出登录
- 优点:链接加密
- 缺点:操作麻烦
- server端使用系统生成的key,或者自定义的密钥对,fork官方客户端的代码将
secure_tcp
修改成直接返回,然后通过Github Actions
编译,下载编译后的客户端。 参考官方文档- 优点:链接加密,可以自定义客户端一些功能,编译后直接可用
- 缺点:需要自己fork代码,编译,有点难度
- 使用我fork的代码,已经修改了
secure_tcp
,可以直接下载使用,下载地址- 优点:代码改动可查看,
Github Actions
编译,链接加密,直接下载使用 - 缺点:可能跟不上官方版本更新
- 优点:代码改动可查看,
对链接加密要求不高的可以使用1
,对链接加密要求高的可以使用3
或4
基本实现了PC端基础的接口。支持Personal版本接口,可以通过配置文件rustdesk.personal
或环境变量RUSTDESK_API_RUSTDESK_PERSONAL
来控制是否启用
- 添加了
github
,google
以及OIDC
授权登录,需要在后台配置好就可以用了,具体可看后台OAuth配置 - 添加了web后台授权登录,点击后直接登录后台就自动登录客户端了
群组分为共享组
和普通组
,共享组中所有人都能看到小组成员的设备,普通组只有管理员能看到所有小组成员的设备
-
使用前后端分离,提供用户友好的管理界面,主要用来管理和展示。前端代码在rustdesk-api-web
-
后台访问地址是
http://<your server>[:port]/_admin/
初次安装管理员为用户名密码为admin
admin
,请即时更改密码
-
可以直接打开webclient,方便使用;也可以分享给游客,游客可以直接通过webclient远程到设备
-
Oauth,支持了
Github
,Google
以及OIDC
, 需要创建一个OAuth App
,然后配置到后台- 对于
Google
和Github
,Issuer
和Scopes
不需要填写. - 对于
OIDC
,Issuer
是必须的。Scopes
是可选的,默认为openid,profile,email
. 确保可以获取sub
,email
和preferred_username
github oauth app
在Settings
->Developer settings
->OAuth Apps
->New OAuth App
中创建,地址 https://github.com/settings/developersAuthorization callback URL
填写http://<your server[:port]>/api/oauth/callback
,比如http://127.0.0.1:21114/api/oauth/callback
- 对于
- 如果已经登录了后台,web client将自动直接登录
- 如果没登录后台,点击右上角登录即可,api server已经自动配置好了
- 登录后,会自动同步ID服务器和KEY
- 登录后,会将地址簿自动保存到web client中,方便使用
- 现已支持
v2 Preview
,访问路径是/webclient2
v2 preview
部署,参考WIKI
# 查看帮助
./apimain -h
./apimain reset-admin-pwd <pwd>
- 参考
conf/config.yaml
配置文件,修改相关配置。 - 如果
gorm.type
是sqlite
,则不需要配置mysql相关配置。 - 语言如果不设置默认为
zh-CN
lang: "en"
app:
web-client: 1 # 1:启用 0:禁用
register: false #是否开启注册
show-swagger: 0 #是否显示swagger文档
gin:
api-addr: "0.0.0.0:21114"
mode: "release"
resources-path: 'resources'
trust-proxy: ""
gorm:
type: "sqlite"
max-idle-conns: 10
max-open-conns: 100
mysql:
username: "root"
password: "111111"
addr: "192.168.1.66:3308"
dbname: "rustdesk"
rustdesk:
id-server: "192.168.1.66:21116"
relay-server: "192.168.1.66:21117"
api-server: "http://192.168.1.66:21114"
key: "123456789"
personal: 1
logger:
path: "./runtime/log.txt"
level: "warn" #trace,debug,info,warn,error,fatal
report-caller: true
proxy:
enable: false
host: ""
变量名前缀是RUSTDESK_API
,环境变量如果存在将覆盖配置文件中的配置
变量名 | 说明 | 示例 |
---|---|---|
TZ | 时区 | Asia/Shanghai |
RUSTDESK_API_LANG | 语言 | en ,zh-CN |
RUSTDESK_API_APP_WEB_CLIENT | 是否启用web-client; 1:启用,0:不启用; 默认启用 | 1 |
RUSTDESK_API_APP_REGISTER | 是否开启注册; true , false 默认false |
false |
RUSTDESK_API_APP_SHOW_SWAGGER | 是否可见swagger文档;1 显示,0 不显示,默认0 不显示 |
1 |
-----ADMIN配置----- | ---------- | ---------- |
RUSTDESK_API_ADMIN_TITLE | 后台标题 | RustDesk Api Admin |
RUSTDESK_API_ADMIN_HELLO | 后台欢迎语,可以使用html |
|
RUSTDESK_API_ADMIN_HELLO_FILE | 后台欢迎语文件,如果内容多,使用文件更方便。 会覆盖 RUSTDESK_API_ADMIN_HELLO |
./conf/admin/hello.html |
-----GIN配置----- | ---------- | ---------- |
RUSTDESK_API_GIN_TRUST_PROXY | 信任的代理IP列表,以, 分割,默认信任所有 |
192.168.1.2,192.168.1.3 |
-----------GORM配置---------------- | ------------------------------------ | --------------------------- |
RUSTDESK_API_GORM_TYPE | 数据库类型sqlite或者mysql,默认sqlite | sqlite |
RUSTDESK_API_GORM_MAX_IDLE_CONNS | 数据库最大空闲连接数 | 10 |
RUSTDESK_API_GORM_MAX_OPEN_CONNS | 数据库最大打开连接数 | 100 |
RUSTDESK_API_RUSTDESK_PERSONAL | 是否启用个人版API, 1:启用,0:不启用; 默认启用 | 1 |
-----MYSQL配置----- | ---------- | ---------- |
RUSTDESK_API_MYSQL_USERNAME | mysql用户名 | root |
RUSTDESK_API_MYSQL_PASSWORD | mysql密码 | 111111 |
RUSTDESK_API_MYSQL_ADDR | mysql地址 | 192.168.1.66:3306 |
RUSTDESK_API_MYSQL_DBNAME | mysql数据库名 | rustdesk |
-----RUSTDESK配置----- | --------------- | ---------- |
RUSTDESK_API_RUSTDESK_ID_SERVER | Rustdesk的id服务器地址 | 192.168.1.66:21116 |
RUSTDESK_API_RUSTDESK_RELAY_SERVER | Rustdesk的relay服务器地址 | 192.168.1.66:21117 |
RUSTDESK_API_RUSTDESK_API_SERVER | Rustdesk的api服务器地址 | http://192.168.1.66:21114 |
RUSTDESK_API_RUSTDESK_KEY | Rustdesk的key | 123456789 |
RUSTDESK_API_RUSTDESK_KEY_FILE | Rustdesk存放key的文件 | ./conf/data/id_ed25519.pub |
RUSTDESK_API_RUSTDESK_WEBCLIENT_MAGIC_QUERYONLINE | Web client v2 中是否启用新的在线状态查询方法; 1 :启用,0 :不启用,默认不启用 |
0 |
----PROXY配置----- | --------------- | ---------- |
RUSTDESK_API_PROXY_ENABLE | 是否启用代理:false , true |
false |
RUSTDESK_API_PROXY_HOST | 代理地址 | http://127.0.0.1:1080 |
-
直接docker运行,配置可以通过挂载配置文件
/app/conf/config.yaml
来修改,或者通过环境变量覆盖配置文件中的配置docker run -d --name rustdesk-api -p 21114:21114 \ -v /data/rustdesk/api:/app/data \ -e TZ=Asia/Shanghai \ -e RUSTDESK_API_LANG=zh-CN \ -e RUSTDESK_API_RUSTDESK_ID_SERVER=192.168.1.66:21116 \ -e RUSTDESK_API_RUSTDESK_RELAY_SERVER=192.168.1.66:21117 \ -e RUSTDESK_API_RUSTDESK_API_SERVER=http://192.168.1.66:21114 \ -e RUSTDESK_API_RUSTDESK_KEY=<key> \ lejianwen/rustdesk-api
-
使用
docker compose
,参考WIKI
-
克隆仓库
git clone https://github.com/lejianwen/rustdesk-api.git cd rustdesk-api
-
安装依赖
go mod tidy #安装swag,如果不需要生成文档,可以不安装 go install github.com/swaggo/swag/cmd/swag@latest
-
编译后台前端,前端代码在rustdesk-api-web中
cd resources mkdir -p admin git clone https://github.com/lejianwen/rustdesk-api-web cd rustdesk-api-web npm install npm run build cp -ar dist/* ../admin/
-
运行
#直接运行 go run cmd/apimain.go #或者使用generate_api.go生成api并运行 go generate generate_api.go
-
编译,如果想自己编译,先cd到项目根目录,然后windows下直接运行
build.bat
,linux下运行build.sh
,编译后会在release
目录下生成对应的可执行文件。直接运行编译后的可执行文件即可。 -
打开浏览器访问
http://<your server[:port]>/_admin/
,默认用户名密码为admin
,请及时更改密码。