[+] Mai2 broker

pull/131/head
Azalea 2025-03-11 05:11:10 -04:00
parent aecb5572cd
commit 8fd378852f
2 changed files with 33 additions and 3 deletions

View File

@ -53,6 +53,7 @@ class AllNetClient(val dns: String, val keychip: String, val game: String, val v
fun findDataBroker(log: (String) -> Unit) = when (game) {
"SDHD" -> ChusanDataBroker(this, log)
"SDEZ", "SDGA" -> MaimaiDataBroker(this, log)
else -> throw IllegalArgumentException("Unsupported game: $game")
}
}

View File

@ -6,6 +6,9 @@ import icu.samnyan.aqua.sega.chusan.model.userdata.UserActivity
import icu.samnyan.aqua.sega.chusan.model.userdata.UserItem
import icu.samnyan.aqua.sega.chusan.model.userdata.UserMusicDetail
import icu.samnyan.aqua.sega.maimai2.model.request.Mai2UserAll
import icu.samnyan.aqua.sega.maimai2.model.userdata.Mai2UserFavorite
import icu.samnyan.aqua.sega.maimai2.model.userdata.Mai2UserItem
import icu.samnyan.aqua.sega.maimai2.model.userdata.Mai2UserMusicDetail
import icu.samnyan.aqua.sega.util.jackson.BasicMapper
import icu.samnyan.aqua.sega.util.jackson.IMapper
import icu.samnyan.aqua.sega.util.jackson.StringMapper
@ -18,7 +21,7 @@ abstract class DataBroker(
abstract val mapper: IMapper
abstract val url: String
inline fun <reified T> String.get(key: String, data: JDict): T = "$url/$this".request()
inline fun <reified T> String.getNullable(key: String, data: JDict): T? = "$url/$this".request()
.postZ(mapper.write(data))
.bodyMaybeZ()
.jsonMap()[key]
@ -26,7 +29,12 @@ abstract class DataBroker(
?.also {
if (it is List<*>) log("$this: ${it.size}")
else log("$this")
} ?: throw NullPointerException("$this")
}
inline fun <reified T> String.get(key: String, data: JDict): T = getNullable(key, data) ?: run {
log("$this")
throw Exception("Failed to get $this")
}
abstract fun pull(): String
fun push(data: String) {
@ -79,6 +87,8 @@ class MaimaiDataBroker(allNet: AllNetClient, log: (String) -> Unit): DataBroker(
override val mapper = BasicMapper()
override val url by lazy { "${allNet.gameUrl.ensureEndingSlash()}Maimai2Servlet" }
class UserMusicWrapper(var userMusicDetailList: List<Mai2UserMusicDetail>)
override fun pull(): String {
log("Game URL: ${allNet.gameUrl}")
log("User ID: ${allNet.userId}")
@ -88,8 +98,27 @@ class MaimaiDataBroker(allNet: AllNetClient, log: (String) -> Unit): DataBroker(
return Mai2UserAll().apply {
userData = ls("GetUserDataApi".get("userData", userId))
// userGameOption = ls("GetUserOptionApi".get("userGameOption", userId))
userOption = ls("GetUserOptionApi".get("userOption", userId))
userExtend = ls("GetUserExtendApi".get("userExtend", userId))
userRatingList = ls("GetUserRatingApi".get("userRating", userId))
userActivityList = ls("GetUserActivityApi".get("userActivity", userId))
userMusicDetailList = "GetUserMusicApi".get<List<UserMusicWrapper>>("userMusicList", paged)
.flatMap { it.userMusicDetailList }
userFriendSeasonRankingList = "GetUserFriendSeasonRankingApi".get("userFriendSeasonRankingList", paged)
userCharacterList = "GetUserCharacterApi".get("userCharacterList", paged)
userItemList = (1..12).flatMap {
"GetUserItemApi".get<List<Mai2UserItem>>("userItemList", paged + mapOf("nextIndex" to 10000000000 * it))
}
userCourseList = "GetUserCourseApi".get("userCourseList", paged)
userFavoriteList = (1..5).mapNotNull {
"GetUserFavoriteApi".getNullable<Mai2UserFavorite>("userFavorite", userId + mapOf("itemKind" to it))
}
userGhost = "GetUserGhostApi".get("userGhostList", userId)
userMapList = "GetUserMapApi".get("userMapList", paged)
userLoginBonusList = "GetUserLoginBonusApi".get("userLoginBonusList", userId)
// TODO: userFavoriteMusicList
}.toJson()
}