mirai/docs/mirai.md
2020-05-12 13:18:51 +08:00

7.7 KiB
Raw Blame History

mirai

欢迎来到 mirai 文档.

本文档基于 mirai 1.0.0, 最后修改时间为 2020/5/11

声明

  1. mirai 为完全免费的开源项目. mirai 项目维护者和贡献者 (下文简称 '我们') 不通过任何方式收取任何费用, 也不提供任何稳定性保障.
  2. mirai 不允许被用于任何违反相关法律法规的工作, 包括但不限于: 盗取账号密码, 盗窃用户资金, 群发违禁内容. 因此我们没有支持设备锁验证, 也没有支持免密登录 (在非常用地点登录会频繁要求输入验证码).
  3. mirai 不提供任何可能促进上述违法行为的功能, 包括但不限于: 收发红包, 收发转账, 主动添加好友.
  4. mirai 不公开任何协议接口. 不支持任何协议扩展.

项目整体架构

mirai 项目整体由 核心 (mirai-core) 与 控制台(mirai-console) 组成.

  • mirai-core 是机器人服务支持. 提供所有机器人相关 API. 本身只包含抽象类和接口, 具体由协议模块实现.
    可用的协议模块:

    mirai-core 设计为一个 支持库, 意味着它可以被独立依赖, 在任意项目中使用. 详见下文.

  • mirai-core-qqandroid 继承 mirai-core, 是 Android QQ 协议的实现. 在使用时只需参考 mirai-core 的 API.

  • mirai-console 是基于 mirai-core 的, 支持插件加载, 指令系统, 和配置等的控制台框架.
    console 由 '后端' 和 '前端' 组成.
    mirai-console 即为后端, 包含所有开发时需要用到的功能.
    可用的前端:

  • MiraiAndroidmirai-console的Android前端程序支持大部分mirai-console功能以及多种脚本api

注意: mirai-core (将)于 2020 年 6 月发布的 1.0.0 版本正式进入稳定更新阶段,
mirai-console 仍处于快速迭代阶段, 任何 API 都有可能在不经过警告的情况下改动, 任何 API 都不具有任何稳定性.

mirai-core

mirai-core 仅包含抽象类和接口和一些扩展方法, 且拥有非常完整的 KDoc (源码内文档). 此处没有必要过多赘述.

你可以在这里快速地大致了解 mirai 的全部 API.

准备

要能看懂下文, 建议至少学习 Java, Kotlin 或 C# 其中一门语言.

mirai 全部使用 Kotlin, 若你无法理解部分 API, 可先简略阅读 Kotlin 参考: kotlincn.net
有关协程 (suspend)部分, mirai 做了大量的兼容性转换以让 Java 使用相同的 API 阻塞地调用一个协程函数.
因此, 对于函数如 suspend fun sendMessage(Message), Java 使用者也可以直接调用它.

开始

  1. 实验性 API 注解 MiraiExperimentalAPI

  2. '机器人' 和 '联系人'

    1. ContactOrBot
    2. 机器人对象 Bot
    3. Contact
    4. 用户对象 User
    5. 好友对象 Friend
    6. 群对象 Group
    7. 群成员对象 Member

    总结: 机器人和联系人架构. 其中 CoroutineScope 为 Kotlin 协程作用域, Java 使用者可忽略.

  3. '消息'

    1. 消息对象 Message
      特别注意, Message 分为 单个消息(SingleMessage) 和 多个消息, 即消息链(MessageChain ).
      // TODO 此处还有更详细的扩展 API 解释, 待更新
    2. 消息链 MessageChain
      // TODO 此处还有更详细的扩展 API 解释, 待更新
    3. 接下来可按需阅读各类型消息 各类型消息. 一个文件包含一种消息.
  4. '事件' mirai 支持异步的事件系统.

    1. 事件接口 Event
    2. 广播事件 Event.broadcast
    3. 内建事件列表 README.
      注意: mirai 将接收到的消息事件独立放置在 net.mamoe.mirai.message 下, 并命名为 MessageEvent. 并为他们实现了一些扩展. 详见 MessageEvent.kt
    4. 事件工具类和工具函数 (仅 Kotlin) (可以跳过本节): 标注 (*) 的几种处理方式可能需要比较好的 Kotlin 技能才能理解并正确使用. 建议在不熟悉时不要使用它们.





一切准备就绪. 现在开始构造 Bot 实例:

  1. Bot 的配置: BotConfiguration 可大致了解或跳过. 一般使用默认属性即可.
  2. 构造 Bot 实例: BotFactory, newBot

另外地, 你还可以了解 mirai 提供的多平台日志系统 (为了同时支持控制台和独立依赖): MiraiLogger, 也可以跳过这个内容

使用

使用 mirai 作为一个依赖库: 阅读 Quick Start 配置依赖.
使用 mirai 作为控制台框架: 使用 mirai-console 开发插件

mirai-core-qqandroid

mirai-core 的实现部分. 不提供任何说明. 使用者无需考虑任何协议实现过程.

mirai-console

此模块处于实验性阶段, 可能没有很好地文档支持, 详见 mirai-console