mirai/mirai-core/src/commonMain/kotlin/net.mamoe.mirai/BotHelper.kt

60 lines
1.9 KiB
Kotlin
Raw Normal View History

2019-10-13 20:19:54 +08:00
@file:Suppress("unused", "EXPERIMENTAL_API_USAGE")
package net.mamoe.mirai
2019-10-24 15:01:56 +08:00
import net.mamoe.mirai.contact.*
2019-10-26 17:06:40 +08:00
import net.mamoe.mirai.network.BotNetworkHandler
2019-10-26 15:54:02 +08:00
import net.mamoe.mirai.network.BotSession
2019-10-22 20:08:08 +08:00
import net.mamoe.mirai.network.protocol.tim.packet.OutgoingPacket
2019-10-13 20:19:54 +08:00
import net.mamoe.mirai.network.protocol.tim.packet.login.LoginResult
2019-10-26 15:54:02 +08:00
import net.mamoe.mirai.network.session
2019-10-19 11:59:08 +08:00
import net.mamoe.mirai.utils.BotNetworkConfiguration
2019-10-13 20:19:54 +08:00
2019-10-24 15:01:56 +08:00
/*
2019-10-26 17:06:40 +08:00
* [Bot] 中的方法的捷径
2019-10-13 20:19:54 +08:00
*/
//Contacts
2019-10-26 17:06:40 +08:00
suspend inline fun Bot.getQQ(number: UInt): QQ = this.contacts.getQQ(number)
2019-10-13 20:19:54 +08:00
2019-10-26 17:06:40 +08:00
suspend inline fun Bot.getGroup(id: GroupId): Group = this.contacts.getGroup(id)
suspend inline fun Bot.getGroup(internalId: GroupInternalId): Group = this.contacts.getGroup(internalId)
2019-10-13 20:19:54 +08:00
2019-10-26 17:06:40 +08:00
/**
2019-10-26 17:17:46 +08:00
* 取得机器人的群成员列表
2019-10-26 17:06:40 +08:00
*/
2019-10-26 17:17:46 +08:00
inline val Bot.groups: ContactList<Group>
2019-10-26 17:06:40 +08:00
get() = this.contacts.groups
2019-10-13 20:19:54 +08:00
2019-10-26 17:17:46 +08:00
/**
* 取得机器人的好友列表
*/
inline val Bot.qqs: ContactList<QQ>
2019-10-26 17:06:40 +08:00
get() = this.contacts.qqs
2019-10-26 15:54:02 +08:00
2019-10-26 17:06:40 +08:00
/**
* [BotSession] 作为接收器 (receiver) 并调用 [block], 返回 [block] 的返回值.
* 这个方法将能帮助使用在 [BotSession] 中定义的一些扩展方法, [BotSession.sendAndExpect]
*/
inline fun <R> Bot.withSession(block: BotSession.() -> R): R = with(this.network.session) { block() }
2019-10-13 20:19:54 +08:00
2019-10-26 17:06:40 +08:00
/**
* 发送数据包
* @throws IllegalStateException [BotNetworkHandler.socket] 未开启时
*/
suspend inline fun Bot.sendPacket(packet: OutgoingPacket) = this.network.sendPacket(packet)
2019-10-13 20:19:54 +08:00
2019-10-26 17:06:40 +08:00
/**
* 使用在默认配置基础上修改的配置登录
*/
suspend inline fun Bot.login(noinline configuration: BotNetworkConfiguration.() -> Unit): LoginResult = this.network.login(BotNetworkConfiguration().apply(configuration))
2019-10-13 20:19:54 +08:00
2019-10-26 17:06:40 +08:00
/**
* 使用默认的配置 ([BotNetworkConfiguration.Default]) 登录
*/
suspend inline fun Bot.login(): LoginResult = this.network.login(BotNetworkConfiguration.Default)
2019-10-13 20:19:54 +08:00
2019-10-26 17:17:46 +08:00
/**
* 取得机器人的 QQ
*/
2019-10-26 17:06:40 +08:00
inline val Bot.qqAccount: UInt get() = this.account.id