[F] Fix DFI response compat

pull/131/head
Azalea 2025-03-20 09:50:23 -04:00
parent 4f3a6cba45
commit e7085f7602
5 changed files with 26 additions and 16 deletions

View File

@ -1,11 +1,11 @@
package icu.samnyan.aqua.net.transfer
import ext.bodyString
import ext.header
import ext.post
import ext.request
import icu.samnyan.aqua.sega.aimedb.AimeDbClient
import icu.samnyan.aqua.sega.util.AllNetBillingDecoder
import icu.samnyan.aqua.sega.allnet.AllNetBillingDecoder
import icu.samnyan.aqua.sega.allnet.AllNetBillingDecoder.decodeAllNetResp
val keychipPattern = Regex("([A-Z\\d]{4}-[A-Z\\d]{11}|[A-Z\\d]{11})")
@ -28,6 +28,7 @@ class AllNetClient(val dns: String, val keychip: String, val game: String, val v
// Send AllNet PowerOn request to obtain game URL
val gameUrl by lazy {
"$dns/sys/servlet/PowerOn".request()
.header("User-Agent" to "AquaTrans/1.0")
.header("Content-Type" to "application/x-www-form-urlencoded")
.header("Pragma" to "DFI")
.post(AllNetBillingDecoder.encodeAllNet(mapOf(
@ -37,11 +38,10 @@ class AllNetClient(val dns: String, val keychip: String, val game: String, val v
"ip" to "127.0.0.1", "firm_ver" to "60001", "boot_ver" to "0000",
"encode" to "UTF-8", "format_ver" to "3", "hops" to "1", "token" to "2864179931"
)))
.bodyString()
?.split("&")
?.map { it.split("=") }
?.filter { it.size == 2 }
?.associate { it[0] to it[1] }?.get("uri")
?.also {
println(it)
}
?.decodeAllNetResp()?.get("uri")
?: throw Exception("PowerOn Failed: No game URL returned")
}

View File

@ -35,7 +35,8 @@ abstract class DataBroker(
inline fun <reified T> String.get(key: String, data: JDict): T = getNullable(key, data) ?: run {
log("$this")
throw Exception("Failed to get $this")
if (this == "GetUserDataApi") 404 - "Failed to get $this (User not found?)"
else 417 - "Failed to get $this"
}
fun prePull(): Pair<Map<String, Long>, MutableMap<String, Long>> {

View File

@ -2,7 +2,7 @@ package icu.samnyan.aqua.sega.allnet
import ext.*
import icu.samnyan.aqua.net.db.AquaNetUserRepo
import icu.samnyan.aqua.sega.util.AllNetBillingDecoder.decodeAllNet
import icu.samnyan.aqua.sega.allnet.AllNetBillingDecoder.decodeAllNet
import icu.samnyan.aqua.sega.util.AquaConst
import jakarta.servlet.http.HttpServletRequest
import jakarta.servlet.http.HttpServletResponse

View File

@ -1,9 +1,15 @@
package icu.samnyan.aqua.sega.util
package icu.samnyan.aqua.sega.allnet
import ext.bodyString
import ext.header
import icu.samnyan.aqua.sega.util.ZLib
import java.net.http.HttpResponse
import java.util.*
import kotlin.text.Charsets.UTF_8
object AllNetBillingDecoder {
fun String.urlToMap() = split("&").map { it.split("=") }.filter { it.size == 2 }.associate { it[0] to it[1] }
/**
* Decode the input byte array from Base64 MIME encoding and decompress the decoded byte array
*/
@ -15,10 +21,7 @@ object AllNetBillingDecoder {
val output = ZLib.decompress(bytes, nowrap).toString(UTF_8).trim()
// Split the string by '&' symbol to separate key-value pairs
return output.split("&").associate {
val (key, value) = it.split("=")
key to value
}
return output.urlToMap()
}
fun encode(src: Map<String, String>, base64: Boolean): ByteArray {
@ -29,7 +32,7 @@ object AllNetBillingDecoder {
val bytes = ZLib.compress(output.toByteArray(UTF_8))
// Encode the compressed byte array to Base64 MIME encoding
return if (!base64) bytes else Base64.getMimeEncoder().encode(bytes)
return if (!base64) bytes else Base64.getEncoder().encode(bytes)
}
@JvmStatic
@ -38,4 +41,10 @@ object AllNetBillingDecoder {
@JvmStatic
fun decodeBilling(src: ByteArray) = decode(src, base64 = false, nowrap = true)
fun HttpResponse<ByteArray>.decodeAllNetResp() =
if (header("Pragma") == "DFI") decodeAllNet(body())
else bodyString()?.urlToMap()
}

View File

@ -2,7 +2,7 @@ package icu.samnyan.aqua.sega.billing
import ext.logger
import ext.toUrl
import icu.samnyan.aqua.sega.util.AllNetBillingDecoder.decodeBilling
import icu.samnyan.aqua.sega.allnet.AllNetBillingDecoder.decodeBilling
import jakarta.annotation.PostConstruct
import jakarta.servlet.http.HttpServletRequest
import org.eclipse.jetty.http.HttpVersion