Simple Robot | OneBot v1.0.0 Help

OneBotBot

公告

站点迁移啦~!

为什么迁移?

作为由我们官方维护的组件库,分散在各自的文档站点中的确有好处:它们可以各自维护自己所需的东西、互不干扰。

但是缺点也很明显: 太过分散。

组件库与核心库之间的关系是比较紧密的, 我们希望你能够在一个站点内就可以查阅或搜索到所有你想要得知的信息。

      表示一个 OneBot 的 bot 客户端实例,实现 Bot ,由 OneBotBotManager 注册产生。

      Bot

      OneBot 实现simbot标准接口 Bot ,提供可支持的属性或能力。

      id

      配置中提供的 botUniqueId, 用与 OneBotBotManager 中作为唯一标识。

      isMe(ID)

      判断提供的 ID 是否为自己。 首先依据 id 属性,如果内部的 userId 已经初始化, 则也会依据 userId 进行判断。

      name

      Bot自己的用户名。需要 start 后才会初始化, 否则获取会抛出异常。

      contactRelation

      联系人相关操作,即好友相关的关系操作。

      groupRelation

      与群聊相关的操作。

      guildRelation

      OneBot11协议不支持 Guild (即频道) 相关的操作,始终得到 null

      start()

      启动Bot。在 Spring Boot 环境默认配置下会自动启动扫描注册的所有Bot。

      除了上述的属性和API, OneBotBot 还提供了一些额外的内容:

      decoderJson

      Bot内部在进行一些API调用时使用的JSON序列化器。

      configuration

      注册Bot时使用的配置类信息。

      apiClient

      Bot进行API请求时使用的HttpClient。

      apiHost

      Bot进行API请求时使用的服务地址的host,来自配置信息。

      apiAccessToken

      Bot进行API请求时使用的 accessToken,来自配置信息。

      eventAccessToken

      Bot进行事件订阅的ws连接请求时使用的 accessToken,来自配置信息。

      userId

      Bot自己的信息,在使用 start 之后会通过API查询获取。 如果尚未 start 或调用 queryLoginInfo() 就获取会得到异常。

      queryLoginInfo()

      通过API查询当前Bot的信息,并同时更新 userIdname

      getCookies(...)

      使用API查询 Cookies。

      getCredentials(...)

      使用API查询 Credentials。

      getCsrfToken()

      使用API查询 CsrfToken。

      关系对象

      即对好友和群的相关操作,通过 contactRelationgroupRelation 进行。

      OneBotBotFriendRelation

      通过 contactRelation 获取, 代表对联系人(也就是好友 OneBotFriend )和陌生人(OneBotStranger )的查询操作。

      val bot: OneBotBot = ... val relation = bot.contactRelation // 获取所有好友信息并遍历 relation.contacts .asFlow() .collect { friend -> println("Friend: $friend") } // 根据ID寻找指定的好友 val friend = relation.contact(123L.ID) // 根据ID寻找指定的陌生人 val stranger = relation.stranger(456L.ID)
      final var relation = bot.getContactRelation(); // 在异步中遍历好友列表,使用bot作为 CoroutineScope relation.getContacts().collectAsync( bot, friend -> System.out.println("Friend: " + friend) ); // 也可以使用 transform 或 Collectables 提供的能力转化为某种异步结果 final var friendCollectable = relation.getContacts(); Collectables.toListAsync(friendCollectable) .thenAccept(friendList -> { // ... }); // 根据ID寻找指定的好友 relation.getContactAsync(Identifies.of(123L)) .thenAccept(friend -> { // Warn: nullable // ... }); // 根据ID寻找指定的陌生人 relation.getStrangerAsync(Identifies.of(123L)) .thenAccept(stranger -> { // Warn: nullable // ... });
      final var relation = bot.getContactRelation(); // 查询所有角色列表并阻塞地收集为List final var list = relation.getContacts() .transform(SuspendReserves.list()); for (var friend : list) { System.out.println("Friend: " + friend); } // 根据ID寻找指定的好友 final var friend = relation.getContact(Identifies.of(123L)); // 根据ID寻找指定的陌生人 final var stranger = relation.getStranger(Identifies.of(123L));
      final var relation = bot.getContactRelation(); // 查询所有的好友并转化为 Flux 后遍历 relation.getContacts() .transform(SuspendReserves.flux()) .subscribe(friend -> System.out.println("Friend: " + friend)); // 根据ID寻找指定的好友 relation.getContactReserve(Identifies.of(123L)) .transform(SuspendReserves.mono()) .subscribe(friend -> { // ... }); // 根据ID寻找指定的陌生人 relation.getStrangerReserve(Identifies.of(123L)) .transform(SuspendReserves.mono()) .subscribe(friend -> { // ... });

      OneBotBotGroupRelation

      通过 contactRelation 获取, 代表对群(OneBotGroup )的查询操作。

      val bot: OneBotBot = ... val relation = bot.groupRelation // 获取所有群并遍历 relation.groups .asFlow() .collect { group -> println("Group: $group") } // 根据ID寻找指定的群 val group = relation.group(123L.ID) // 根据ID直接寻找指定的群内的群成员 val member = relation.member(123L.ID, 456L.ID)
      final var relation = bot.getGroupRelation(); // 在异步中遍历群列表,使用bot作为 CoroutineScope relation.getGroups().collectAsync( bot, group -> System.out.println("Group: " + group) ); // 也可以使用 transform 或 Collectables 提供的能力转化为某种异步结果 final var groupCollectable = relation.getGroups(); Collectables.toListAsync(groupCollectable) .thenAccept(groupList -> { // ... }); // 根据ID寻找指定的群 relation.getGroupAsync(Identifies.of(123L)) .thenAccept(group -> { // Warn: nullable // ... }); // 根据ID寻找指定的群内成员 relation.getMemberAsync(Identifies.of(123L), Identifies.of(456L)) .thenAccept(member -> { // Warn: nullable // ... });
      final var relation = bot.getGroupRelation(); // 查询所有角色列表并阻塞地收集为List final var list = relation.getContacts() .transform(SuspendReserves.list()); for (var friend : list) { System.out.println("Friend: " + friend); } // 根据ID寻找指定的好友 final var friend = relation.getContact(Identifies.of(123L)); // 根据ID寻找指定的陌生人 final var stranger = relation.getStranger(Identifies.of(123L));
      final var relation = bot.getGroupRelation(); // 查询所有的群并转化为 Flux 后遍历 relation.getGroup() .transform(SuspendReserves.flux()) .subscribe(group -> System.out.println("Group: " + group)); // 根据ID寻找指定的群 relation.getGroupReserve(Identifies.of(123L)) .transform(SuspendReserves.mono()) .subscribe(group -> { // ... }); // 根据ID寻找指定的群内成员 relation.getMemberReserve(Identifies.of(123L), Identifies.of(456L)) .transform(SuspendReserves.mono()) .subscribe(group -> { // ... });

      OneBotBotManager

      OneBotBotManager 实现simbot标准API的 BotManager ,作为一个Bot管理器, 它用于注册生产与管理 OneBotBot

      获取 OneBotBotManager

      Application 注册完成后,即可通过其中的 botManagers 寻找所需的 BotManager。 在 OneBot 组件中,我们通常要寻找 OneBotBotManager

      val application: Application = ... // 得到第一个 OneBotBotManager val obManager = application.botManagers.firstOneBotBotManager() obManager.all().forEach { // 遍历所有的bot。。。 } // 通过你配置的 uniqueBotId 获取 val bot = obManager["123456789".ID]
      final Application application; // 得到第一个 OneBotBotManager var obManager = application.getBotManagers() .stream() .filter(it -> it instanceof OneBotBotManager) .map(it -> (OneBotBotManager) it) .findFirst() .orElseThrow(); // 遍历bot obManager.all().iterator().forEachRemaining(bot -> { // ... }); // 也可以转成List final var list = SequencesKt.toList(obManager.all()); // 通过你配置的 uniqueBotId 获取 final var bot = obManager.get(Identifies.of("123456789"));

      注册 OneBotBot

      如果你打算以编程的方式动态注册 OneBotBot ,那么在获取到 OneBotBotManager 之后使用 register 即可。

      val manager: OneBotBotManager = ... val bot = manager.register { botUniqueId = "" apiServerHost = ... eventServerHost = ... // 上面是必填属性,不过两个Host有默认值 // 其他可选参数可自行探索,此处省略 }
      final var configuration = new OneBotBotConfiguration(); configuration.setBotUniqueId(...); configuration.setApiServerHost(...); configuration.setEventServerHost(...); // 上面是必填属性,不过两个Host有默认值 // 其他可选参数可自行探索,此处省略 final var bot = onManager.register(configuration);

      Spring Boot

      在 Spring Boot starter 默认配置环境下, OneBotBotManager 会被自动注册, 并会扫描所有 Bot配置文件 并解析、注册为 OneBotBot 后自动在 异步中 启动。

      在 Spring 中,你可以通过注入 Application 来获取到 BotManager

      @Component class MyComponent( val application: Application ) { // 假设它会被定时任务或者HTTP接口等其他地方调用 fun run() { val obManager = application.botManagers.firstOneBotBotManager() obManager.all().forEach { // 遍历所有的bot。。。 } // 通过你配置的 uniqueBotId 获取 val bot = obManager["123456789".ID] } }
      @Component public class MyComponent { private final Application application; public MyComponent(Application application) { this.application = application; } // 假设它会被定时任务或者HTTP接口等其他地方调用 public void run() { var obManager = application.getBotManagers() .stream() .filter(it -> it instanceof OneBotBotManager) .map(it -> (OneBotBotManager) it) .findFirst() .orElseThrow(); // 遍历bot obManager.all().iterator().forEachRemaining(bot -> { // ... }); // 也可以转成List final var list = SequencesKt.toList(obManager.all()); // 通过你配置的 uniqueBotId 获取 final var bot = obManager.get(Identifies.of("123456789")); } }

      外部事件

      OneBotBot 提供了 push(String) 来允许直接从外部推送一个原始的事件字符串。

      val json = """ { "time": 1515204254, "self_id": 10001000, "post_type": "message", "message_type": "private", "sub_type": "friend", "message_id": 12, "user_id": 12345678, "message": "你好~", "raw_message": "你好~", "font": 456, "sender": { "nickname": "小不点", "sex": "male", "age": 18 } } """ bot.push(json).collect()
      var json = """ { "time": 1515204254, "self_id": 10001000, "post_type": "message", "message_type": "private", "sub_type": "friend", "message_id": 12, "user_id": 12345678, "message": "你好~", "raw_message": "你好~", "font": 456, "sender": { "nickname": "小不点", "sex": "male", "age": 18 } } """ // 推送并在异步中处理 bot.pushAndLaunch(json);

      由于 bot.push 返回的结果是 Flow, 因此 Java 中想要直接使用它会比较困难。 你可以先通过 Collectables.valueOf(flow) 将其转化为 Collectable (与关系对象相关API的结果类型一样), 然后再做进一步操作。

      var collectable = Collectables.valueOf(flow); // 使用 collectAsync 异步遍历 // 或者 Collectables 中提供的各种辅助API // 或者 transform 转化为其他的类型,比如响应式的 Flux

      这可以让你能够使用反向事件推送来接收事件,比如通过接收来自 HTTP 的事件推送请求。

      简单示例:

      suspend fun main() { val application = launchSimpleApplication { useOneBot11() } // 注册事件省略... // 注册bot并启动 val bot = application.oneBot11Bots { register { // 内容省略 }.apply { start() } } // 启动一个Ktor Server embeddedServer(Netty, port = 5959, module = { serverModule(bot) }) .start(wait = true) } fun io.ktor.server.application.Application.serverModule(bot: OneBotBot) { routing { post("/event") { // 收到事件,推送并在异步中处理 // 你也可以选择直接 push(body).collect(), // 直到事件被完全处理后在返回 val body = call.receiveText() bot.pushAndLaunch(body) // 响应一个默认的空JSON结果 call.response.header(HttpHeaders.ContentType, "application/json") call.respond("{}") } } }
      @RestController public class MyController { private final Application application; // 一个简单的返回值类型,假设始终返回空JSON {} public record Result() { } private static final Result OK = new Result(); public MyController(Application application) { this.application = application; } /** * 通过 /xxx/event 接收事件, * xxx 为你bot配置的 uniqueBotId */ @PostMapping("/{botId}/event") public Result onEvent(@PathVariable String botId, @RequestBody String body) { for (var botManager : application.getBotManagers()) { if (botManager instanceof OneBotBotManager obManager) { // 找到这个bot var bot = obManager.find(Identifies.of(botId)); // 如果有就推送这个事件并退出寻找 if (bot != null) { // 推送事件并在异步中处理 // 你也可以参考上面有关 Flux 和 Collectable 的说明 // 来阻塞地等待事件处理完成后再返回 bot.pushAndLaunch(body); break; } } } return OK; } }

      如果选择直接异步处理,那么其实跟 Spring Boot Web 的情况下没什么太大区别。

      @RestController public class MyController { private final Application application; public record Result() { } private static final Result OK = new Result(); public MyController(Application application) { this.application = application; } /** * 通过 /xxx/event 接收事件, * xxx 为你bot配置的 uniqueBotId */ @PostMapping("/{botId}/event") public Mono<Result> onEvent(@PathVariable String botId, @RequestBody String body) { for (var botManager : application.getBotManagers()) { if (botManager instanceof OneBotBotManager obManager) { // 找到这个bot var bot = obManager.find(Identifies.of(botId)); // 如果有就推送这个事件并退出寻找 if (bot != null) { bot.pushAndLaunch(body); break; } } } return Mono.just(OK); } }
      @RestController public class MyController { private final Application application; public record Result() { } private static final Result OK = new Result(); public MyController(Application application) { this.application = application; } /** * 通过 /xxx/event 接收事件, * xxx 为你bot配置的 uniqueBotId */ @PostMapping("/{botId}/event") public Mono<Result> onEvent(@PathVariable String botId, @RequestBody String body) { for (var botManager : application.getBotManagers()) { if (botManager instanceof OneBotBotManager obManager) { // 找到这个bot var bot = obManager.find(Identifies.of(botId)); // 如果有就推送这个事件并退出寻找 if (bot != null) { final var flow = bot.push(body); // 将 flow 转为 reactor 的 Flux // 需要添加依赖 [[[kotlinx-coroutines-reactor|https://github.com/Kotlin/kotlinx.coroutines/tree/master/reactive]]] return ReactorFlowKt .asFlux(flow) .then(Mono.just(OK)); } } } // 没找到,直接返回 return Mono.just(OK); } }
      Last modified: 26 July 2024