/ricq

Rust 高性能 QQ 协议(原RS-QQ)。Linux-musl运行内存1.6MB

Primary LanguageRustGNU Affero General Public License v3.0AGPL-3.0

RICQ

qq-android 协议的 rust 实现 移植于 MiraiGoOICQMirai

  • ricq: 提供异步 API
  • ricq-core: 不带 IO 的数据包构造器、解析器(通常用于ffi)
  • ricq-axum-api:提供 HTTP API 形式的登录接口,配合 ricq-react-ui,只需要开发登录后的逻辑。

如何使用

本项目是协议 lib,如果需要直接使用,可以参考 examples 中的例子进行开发。

普通开发者推荐使用 SDK、框架进行开发:

框架/SDK 语言 说明
rust_proc_qq Rust 模仿rocket
Walle-Q - onebot协议
pbrq - websocket+protobuf协议(附带Web-UI

本项目是一个年轻的项目,请使用 nightly channel 构建本项目哦(正经人谁用 stable 啊)

相关项目

项目名称 作者 描述
gtk-qq lomirus Unofficial Linux QQ client, based on GTK4 and libadwaita, developed with Rust and Relm4.
esp32c3-rs-qq a1967629423 在单片机上运行QQ

已完成功能/开发计划

登录

  • 账号密码登录
  • 二维码登录
  • 验证码提交
  • 设备锁验证
  • 错误信息解析

消息类型

  • 文本
  • 表情
  • At
  • 回复
  • 匿名
  • 骰子
  • 石头剪刀布
  • 图片
  • 语音
  • 长消息(仅支持群聊发送)
  • 合并转发(仅支持群聊发送)
  • 链接分享
  • 小程序(暂只支持RAW)
  • 短视频
  • 群文件(上传与接收信息)

事件

  • 群消息
  • 好友消息
  • 新好友请求
  • 收到其他用户进群请求
  • 新好友
  • 群禁言
  • 好友消息撤回
  • 群消息撤回
  • 收到邀请进群请求
  • 群名称变更
  • 好友删除
  • 群成员权限变更
  • 新成员进群/退群
  • 登录号加群
  • 临时会话消息
  • 群解散
  • 登录号退群(包含T出)
  • 客户端离线
  • 群提示 (戳一戳/运气王等)

主动操作

为防止滥用,将不支持主动邀请新成员进群

  • 修改昵称
  • 发送群消息
  • 获取群列表
  • 获取群成员列表
  • 获取好友列表/分组
  • 获取好友个性签名
  • 添加/删除/重命名好友分组
  • 群成员禁言/解除禁言
  • 踢出群成员
  • 戳一戳群友
  • 戳一戳好友
  • 设置群管理员
  • 设置群公告
  • 设置群名称
  • 全员禁言
  • 获取群@全体剩余次数
  • 翻译
  • 修改群成员头衔
  • 设置群精华消息
  • 发送好友消息
  • 发送临时会话消息
  • 修改群成员Card
  • 撤回群消息
  • 撤回好友消息
  • 处理被邀请加群请求
  • 处理加群请求
  • 处理好友请求
  • 删除好友
  • 获取陌生人信息
  • 设置在线状态
  • 修改个人资料
  • 修改个性签名
  • 获取群荣誉 (龙王/群聊火焰等)
  • 获取群文件下载链接
  • 群成员邀请

敏感操作

由于QQ钱包支付用户服务协议, 将不支持一切有关QQ钱包的协议

4.13 您不得利用本服务实施下列任一的行为:
(9) 侵害QQ钱包支付服务系統;

  • QQ钱包协议(收款/付款等)