mirror of
https://github.com/ViaVersion/VIAaaS.git
synced 2025-01-24 22:01:49 +01:00
fix fallback when using non-ipv6 compatible proxy
This commit is contained in:
parent
61cd7b0b44
commit
942908341a
@ -7,6 +7,7 @@ import com.viaversion.viaversion.exception.CancelCodecException
|
|||||||
import io.netty.channel.Channel
|
import io.netty.channel.Channel
|
||||||
import io.netty.channel.ChannelHandlerContext
|
import io.netty.channel.ChannelHandlerContext
|
||||||
import io.netty.channel.SimpleChannelInboundHandler
|
import io.netty.channel.SimpleChannelInboundHandler
|
||||||
|
import io.netty.handler.proxy.ProxyConnectException
|
||||||
import io.netty.handler.proxy.ProxyHandler
|
import io.netty.handler.proxy.ProxyHandler
|
||||||
import kotlinx.coroutines.CoroutineScope
|
import kotlinx.coroutines.CoroutineScope
|
||||||
import kotlinx.coroutines.Dispatchers
|
import kotlinx.coroutines.Dispatchers
|
||||||
@ -34,8 +35,10 @@ class MinecraftHandler(
|
|||||||
}
|
}
|
||||||
|
|
||||||
override fun channelInactive(ctx: ChannelHandlerContext) {
|
override fun channelInactive(ctx: ChannelHandlerContext) {
|
||||||
|
if (!failedProxy(ctx)) {
|
||||||
other?.close()
|
other?.close()
|
||||||
data.state.onInactivated(this)
|
data.state.onInactivated(this)
|
||||||
|
}
|
||||||
coroutineScope.cancel()
|
coroutineScope.cancel()
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -47,7 +50,13 @@ class MinecraftHandler(
|
|||||||
other?.setAutoRead(ctx.channel().isWritable)
|
other?.setAutoRead(ctx.channel().isWritable)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private fun failedProxy(ctx: ChannelHandlerContext): Boolean {
|
||||||
|
// proxy connect future fails are handled in another part
|
||||||
|
return (ctx.channel().pipeline().get("proxy") as? ProxyHandler)?.connectFuture()?.isSuccess == false
|
||||||
|
}
|
||||||
|
|
||||||
override fun exceptionCaught(ctx: ChannelHandlerContext, cause: Throwable) {
|
override fun exceptionCaught(ctx: ChannelHandlerContext, cause: Throwable) {
|
||||||
|
if (cause is ProxyConnectException && failedProxy(ctx)) return
|
||||||
if (cause is CancelCodecException) return
|
if (cause is CancelCodecException) return
|
||||||
if (cause is ClosedChannelException) return
|
if (cause is ClosedChannelException) return
|
||||||
mcLogger.debug("Exception: ", cause)
|
mcLogger.debug("Exception: ", cause)
|
||||||
|
@ -16,6 +16,7 @@ import io.netty.bootstrap.Bootstrap
|
|||||||
import io.netty.channel.Channel
|
import io.netty.channel.Channel
|
||||||
import io.netty.channel.ChannelOption
|
import io.netty.channel.ChannelOption
|
||||||
import io.netty.channel.socket.SocketChannel
|
import io.netty.channel.socket.SocketChannel
|
||||||
|
import io.netty.handler.proxy.ProxyHandler
|
||||||
import io.netty.resolver.NoopAddressResolverGroup
|
import io.netty.resolver.NoopAddressResolverGroup
|
||||||
import kotlinx.coroutines.future.await
|
import kotlinx.coroutines.future.await
|
||||||
import kotlinx.coroutines.withTimeoutOrNull
|
import kotlinx.coroutines.withTimeoutOrNull
|
||||||
@ -41,6 +42,7 @@ private suspend fun createBackChannel(
|
|||||||
.connect(socketAddr)
|
.connect(socketAddr)
|
||||||
.also { it.suspendAwait() }
|
.also { it.suspendAwait() }
|
||||||
.channel()
|
.channel()
|
||||||
|
(channel.pipeline().get("proxy") as? ProxyHandler)?.connectFuture()?.suspendAwait()
|
||||||
|
|
||||||
mcLogger.info("+ ${handler.endRemoteAddress} -> $socketAddr")
|
mcLogger.info("+ ${handler.endRemoteAddress} -> $socketAddr")
|
||||||
handler.data.backChannel = channel as SocketChannel
|
handler.data.backChannel = channel as SocketChannel
|
||||||
@ -69,7 +71,8 @@ private suspend fun autoDetectVersion(handler: MinecraftHandler, socketAddr: Ine
|
|||||||
|
|
||||||
if (detectedProtocol != null
|
if (detectedProtocol != null
|
||||||
&& detectedProtocol.version !in arrayOf(-1, -2)
|
&& detectedProtocol.version !in arrayOf(-1, -2)
|
||||||
&& ProtocolVersion.isRegistered(detectedProtocol.version)) {
|
&& ProtocolVersion.isRegistered(detectedProtocol.version)
|
||||||
|
) {
|
||||||
handler.data.backServerVer = detectedProtocol.version
|
handler.data.backServerVer = detectedProtocol.version
|
||||||
} else {
|
} else {
|
||||||
handler.data.backServerVer = 47 // fallback 1.8
|
handler.data.backServerVer = 47 // fallback 1.8
|
||||||
|
Loading…
Reference in New Issue
Block a user