mirror of
https://github.com/mamoe/mirai.git
synced 2025-01-22 01:49:12 +08:00
Mirai Console (Terminal)V0.01
This commit is contained in:
parent
bd381b8083
commit
e971fd769d
@ -12,22 +12,24 @@ import com.googlecode.lanterna.terminal.TerminalResizeListener
|
|||||||
import com.googlecode.lanterna.terminal.swing.SwingTerminal
|
import com.googlecode.lanterna.terminal.swing.SwingTerminal
|
||||||
import com.googlecode.lanterna.terminal.swing.SwingTerminalFontConfiguration
|
import com.googlecode.lanterna.terminal.swing.SwingTerminalFontConfiguration
|
||||||
import com.googlecode.lanterna.terminal.swing.SwingTerminalFrame
|
import com.googlecode.lanterna.terminal.swing.SwingTerminalFrame
|
||||||
import kotlinx.coroutines.GlobalScope
|
import kotlinx.coroutines.*
|
||||||
import kotlinx.coroutines.Job
|
import kotlinx.coroutines.io.close
|
||||||
import kotlinx.coroutines.delay
|
import kotlinx.io.core.IoBuffer
|
||||||
import kotlinx.coroutines.launch
|
import kotlinx.io.core.use
|
||||||
import net.mamoe.mirai.Bot
|
import net.mamoe.mirai.Bot
|
||||||
import net.mamoe.mirai.console.MiraiConsoleTerminalUI.LoggerDrawer.cleanPage
|
import net.mamoe.mirai.console.MiraiConsoleTerminalUI.LoggerDrawer.cleanPage
|
||||||
import net.mamoe.mirai.console.MiraiConsoleTerminalUI.LoggerDrawer.drawLog
|
import net.mamoe.mirai.console.MiraiConsoleTerminalUI.LoggerDrawer.drawLog
|
||||||
import net.mamoe.mirai.console.MiraiConsoleTerminalUI.LoggerDrawer.redrawLogs
|
import net.mamoe.mirai.console.MiraiConsoleTerminalUI.LoggerDrawer.redrawLogs
|
||||||
|
import net.mamoe.mirai.utils.LoginSolver
|
||||||
|
import net.mamoe.mirai.utils.writeChannel
|
||||||
import java.awt.Font
|
import java.awt.Font
|
||||||
|
import java.io.File
|
||||||
import java.io.OutputStream
|
import java.io.OutputStream
|
||||||
import java.io.PrintStream
|
import java.io.PrintStream
|
||||||
import java.nio.charset.Charset
|
import java.nio.charset.Charset
|
||||||
import java.util.*
|
import java.util.*
|
||||||
import java.util.concurrent.ConcurrentHashMap
|
import java.util.concurrent.ConcurrentHashMap
|
||||||
import java.util.concurrent.ConcurrentLinkedDeque
|
import java.util.concurrent.ConcurrentLinkedDeque
|
||||||
import java.util.concurrent.ConcurrentLinkedQueue
|
|
||||||
import kotlin.concurrent.thread
|
import kotlin.concurrent.thread
|
||||||
import kotlin.system.exitProcess
|
import kotlin.system.exitProcess
|
||||||
|
|
||||||
@ -97,6 +99,52 @@ object MiraiConsoleTerminalUI : MiraiConsoleUI {
|
|||||||
botAdminCount[identity] = admins.size
|
botAdminCount[identity] = admins.size
|
||||||
}
|
}
|
||||||
|
|
||||||
|
override fun createLoginSolver(): LoginSolver {
|
||||||
|
return object : LoginSolver() {
|
||||||
|
override suspend fun onSolvePicCaptcha(bot: Bot, data: IoBuffer): String? {
|
||||||
|
val tempFile: File = createTempFile(suffix = ".png").apply { deleteOnExit() }
|
||||||
|
withContext(Dispatchers.IO) {
|
||||||
|
tempFile.createNewFile()
|
||||||
|
pushLog(0, "[Login Solver]需要图片验证码登录, 验证码为 4 字母")
|
||||||
|
try {
|
||||||
|
tempFile.writeChannel().apply { writeFully(data); close() }
|
||||||
|
pushLog(0, "将会显示字符图片. 若看不清字符图片, 请查看文件 ${tempFile.absolutePath}")
|
||||||
|
} catch (e: Exception) {
|
||||||
|
error("[Login Solver]验证码无法保存[Error0001]")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
pushLog(0, "[Login Solver]请输入 4 位字母验证码. 若要更换验证码, 请直接回车")
|
||||||
|
return requestInput("[Login Solver]请输入 4 位字母验证码. 若要更换验证码, 请直接回车")!!.takeUnless { it.isEmpty() || it.length != 4 }
|
||||||
|
.also {
|
||||||
|
pushLog(0, "[Login Solver]正在提交[$it]中...")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
override suspend fun onSolveSliderCaptcha(bot: Bot, url: String): String? {
|
||||||
|
pushLog(0, "[Login Solver]需要滑动验证码")
|
||||||
|
pushLog(0, "[Login Solver]请在任意浏览器中打开以下链接并完成验证码. ")
|
||||||
|
pushLog(0, "[Login Solver]完成后请输入任意字符 ")
|
||||||
|
pushLog(0, url)
|
||||||
|
return requestInput("[Login Solver]完成后请输入任意字符").also {
|
||||||
|
pushLog(0, "[Login Solver]正在提交中")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
override suspend fun onSolveUnsafeDeviceLoginVerify(bot: Bot, url: String): String? {
|
||||||
|
pushLog(0, "[Login Solver]需要进行账户安全认证")
|
||||||
|
pushLog(0, "[Login Solver]该账户有[设备锁]/[不常用登陆地点]/[不常用设备登陆]的问题")
|
||||||
|
pushLog(0, "[Login Solver]完成以下账号认证即可成功登陆|理论本认证在mirai每个账户中最多出现1次")
|
||||||
|
pushLog(0, "[Login Solver]请将该链接在QQ浏览器中打开并完成认证, 成功后输入任意字符")
|
||||||
|
pushLog(0, "[Login Solver]这步操作将在后续的版本中优化")
|
||||||
|
pushLog(0, url)
|
||||||
|
return requestInput("[Login Solver]完成后请输入任意字符").also {
|
||||||
|
pushLog(0, "[Login Solver]正在提交中...")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
val log = ConcurrentHashMap<Long, LimitLinkedQueue<String>>().also {
|
val log = ConcurrentHashMap<Long, LimitLinkedQueue<String>>().also {
|
||||||
it[0L] = LimitLinkedQueue(cacheLogSize)
|
it[0L] = LimitLinkedQueue(cacheLogSize)
|
||||||
|
@ -123,19 +123,7 @@ object MiraiConsole {
|
|||||||
runBlocking {
|
runBlocking {
|
||||||
frontEnd.prePushBot(qqNumber)
|
frontEnd.prePushBot(qqNumber)
|
||||||
val bot = Bot(qqNumber, qqPassword) {
|
val bot = Bot(qqNumber, qqPassword) {
|
||||||
this.loginSolver = DefaultLoginSolver(object : LoginSolverInputReader {
|
this.loginSolver = frontEnd.createLoginSolver()
|
||||||
override suspend fun read(question: String): String? {
|
|
||||||
return frontEnd.requestInput(question)
|
|
||||||
}
|
|
||||||
},
|
|
||||||
SimpleLogger("Login Helper") { _, message, e ->
|
|
||||||
logger("[Login Helper]", qqNumber, message)
|
|
||||||
if (e != null) {
|
|
||||||
logger("[NETWORK ERROR]", qqNumber, e.toString())//因为在一页 所以可以不打QQ
|
|
||||||
e.printStackTrace()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
)
|
|
||||||
this.botLoggerSupplier = {
|
this.botLoggerSupplier = {
|
||||||
SimpleLogger("BOT $qqNumber]") { _, message, e ->
|
SimpleLogger("BOT $qqNumber]") { _, message, e ->
|
||||||
logger("[BOT $qqNumber]", qqNumber, message)
|
logger("[BOT $qqNumber]", qqNumber, message)
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
package net.mamoe.mirai.console
|
package net.mamoe.mirai.console
|
||||||
|
|
||||||
import net.mamoe.mirai.Bot
|
import net.mamoe.mirai.Bot
|
||||||
|
import net.mamoe.mirai.utils.LoginSolver
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 只需要实现一个这个 传入MiraiConsole 就可以绑定UI层与Console层
|
* 只需要实现一个这个 传入MiraiConsole 就可以绑定UI层与Console层
|
||||||
@ -57,4 +58,9 @@ interface MiraiConsoleUI {
|
|||||||
admins: List<Long>
|
admins: List<Long>
|
||||||
)
|
)
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 由UI层创建一个LoginSolver
|
||||||
|
*/
|
||||||
|
fun createLoginSolver(): LoginSolver
|
||||||
|
|
||||||
}
|
}
|
@ -118,7 +118,7 @@ class DefaultLoginSolver(
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Copied from Ktor CIO
|
// Copied from Ktor CIO
|
||||||
private fun File.writeChannel(
|
public fun File.writeChannel(
|
||||||
coroutineContext: CoroutineContext = Dispatchers.IO
|
coroutineContext: CoroutineContext = Dispatchers.IO
|
||||||
): ByteWriteChannel = GlobalScope.reader(CoroutineName("file-writer") + coroutineContext, autoFlush = true) {
|
): ByteWriteChannel = GlobalScope.reader(CoroutineName("file-writer") + coroutineContext, autoFlush = true) {
|
||||||
@Suppress("BlockingMethodInNonBlockingContext")
|
@Suppress("BlockingMethodInNonBlockingContext")
|
||||||
|
Loading…
Reference in New Issue
Block a user