fix joinGame() error message

This commit is contained in:
creeper123123321 2021-06-06 11:59:59 -03:00
parent b0e09bee90
commit e034831b66
3 changed files with 33 additions and 31 deletions

View File

@ -168,11 +168,12 @@ fun readRemainingBytes(byteBuf: ByteBuf) = Type.REMAINING_BYTES.read(byteBuf)!!
fun ByteBuf.readByteArray(length: Int) = ByteArray(length).also { readBytes(it) }
suspend fun hasJoined(username: String, hash: String): JsonObject {
return httpClient.get(
"https://sessionserver.mojang.com/session/minecraft/hasJoined?username=" +
UrlEscapers.urlFormParameterEscaper().escape(username) +
"&serverId=$hash"
) ?: throw StacklessException("Couldn't authenticate with session servers")
return try {
httpClient.get("https://sessionserver.mojang.com/session/minecraft/hasJoined?username=" +
UrlEscapers.urlFormParameterEscaper().escape(username) + "&serverId=$hash")
} catch (e: Exception) {
throw StacklessException("Couldn't authenticate with session servers", e)
}
}
fun generate128Bits() = ByteArray(16).also { secureRandom.nextBytes(it) }

View File

@ -98,7 +98,7 @@ class LoginState : MinecraftConnectionState {
val frontHandler = handler.data.frontHandler
val backChan = handler.data.backChannel!!
handler.coroutineScope.launch(Dispatchers.IO) {
handler.coroutineScope.launch {
try {
val playerId = callbackPlayerId.await()

View File

@ -14,6 +14,7 @@ import com.viaversion.aas.parseUndashedId
import com.viaversion.aas.util.StacklessException
import com.viaversion.aas.webLogger
import io.ipinfo.api.IPInfo
import io.ipinfo.api.model.IPResponse
import io.ktor.client.request.*
import io.ktor.http.cio.websocket.*
import io.ktor.websocket.*
@ -65,7 +66,7 @@ class WebDashboardServer {
val usernameIdCache = CacheBuilder.newBuilder()
.expireAfterWrite(1, TimeUnit.HOURS)
.build<String, CompletableFuture<UUID?>>(CacheLoader.from { name ->
GlobalScope.async(Dispatchers.IO) {
CoroutineScope(Dispatchers.IO).async {
httpClient.get<JsonObject?>("https://api.mojang.com/users/profiles/minecraft/$name")
?.get("id")?.asString?.let { parseUndashedId(it) }
}.asCompletableFuture()
@ -83,34 +84,34 @@ class WebDashboardServer {
if (!listeners.containsKey(id)) {
future.completeExceptionally(StacklessException("No browser listening"))
} else {
val info = withContext(Dispatchers.IO) {
coroutineScope {
launch(Dispatchers.IO) {
var info: IPResponse? = null
(address as? InetSocketAddress)?.let {
try {
it.address?.hostName // resolve it
val ipLookup = async(Dispatchers.IO) {
ipInfo.lookupIP(it.address?.hostAddress?.substringBefore("%"))
}
val reverseLookup = async(Dispatchers.IO) {
it.address?.hostName
}
info = ipLookup.await()
reverseLookup.await()
} catch (ignored: Exception) {
null
}
}
}
val msg = """Requester: $id $address (${info?.org}, ${info?.city}, ${info?.region}, ${info?.countryCode})
Backend: $backAddress"""
val msg = "Requester: $id $address (${info?.org}, ${info?.city}, ${info?.region}, " +
"${info?.countryCode})\nBackend: $backAddress"
listeners[id]?.forEach {
coroutineScope {
launch {
it.ws.send(
JsonObject().also {
it.ws.send(JsonObject().also {
it.addProperty("action", "session_hash_request")
it.addProperty("user", name)
it.addProperty("session_hash", hash)
it.addProperty("message", msg)
}.toString()
)
}.toString())
it.ws.flush()
}
}
}
coroutineScope {
launch {
delay(20_000)
future.completeExceptionally(StacklessException("No response from browser"))