aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authornea <nea@nea.moe>2023-08-31 18:19:06 +0200
committernea <nea@nea.moe>2023-08-31 18:19:06 +0200
commitb7b01f1c6fbf889ae9bfcdb5b34c5ccfa48d5ba0 (patch)
tree535b601405763736109be9ff281a71c06155b52f
parentba72aedf7fb98c1ec72a8745402f577fb0024508 (diff)
downloadFirmament-b7b01f1c6fbf889ae9bfcdb5b34c5ccfa48d5ba0.tar.gz
Firmament-b7b01f1c6fbf889ae9bfcdb5b34c5ccfa48d5ba0.tar.bz2
Firmament-b7b01f1c6fbf889ae9bfcdb5b34c5ccfa48d5ba0.zip
Fix profile viewer for missing uuid pets
-rw-r--r--src/main/kotlin/moe/nea/firmament/apis/Profiles.kt25
-rw-r--r--src/main/kotlin/moe/nea/firmament/apis/UrsaManager.kt11
-rw-r--r--src/main/kotlin/moe/nea/firmament/gui/profileviewer/ProfileViewer.kt20
-rw-r--r--src/main/kotlin/moe/nea/firmament/util/assertions.kt7
4 files changed, 36 insertions, 27 deletions
diff --git a/src/main/kotlin/moe/nea/firmament/apis/Profiles.kt b/src/main/kotlin/moe/nea/firmament/apis/Profiles.kt
index 06fe31f..a7922c3 100644
--- a/src/main/kotlin/moe/nea/firmament/apis/Profiles.kt
+++ b/src/main/kotlin/moe/nea/firmament/apis/Profiles.kt
@@ -10,19 +10,20 @@ package moe.nea.firmament.apis
import io.github.moulberry.repo.constants.Leveling
import io.github.moulberry.repo.data.Rarity
-import java.util.*
import kotlinx.datetime.Instant
import kotlinx.serialization.SerialName
import kotlinx.serialization.Serializable
import kotlinx.serialization.UseSerializers
-import kotlin.reflect.KProperty1
-import net.minecraft.util.DyeColor
-import net.minecraft.util.Formatting
import moe.nea.firmament.repo.RepoManager
import moe.nea.firmament.util.LegacyFormattingCode
import moe.nea.firmament.util.SkyblockId
+import moe.nea.firmament.util.assertNotNullOr
import moe.nea.firmament.util.json.DashlessUUIDSerializer
import moe.nea.firmament.util.json.InstantAsLongSerializer
+import net.minecraft.util.DyeColor
+import net.minecraft.util.Formatting
+import java.util.*
+import kotlin.reflect.KProperty1
@Serializable
@@ -81,7 +82,7 @@ enum class Skill(val accessor: KProperty1<Member, Double>, val color: DyeColor,
ENCHANTING(Member::experienceSkillEnchanting, DyeColor.MAGENTA, SkyblockId("ENCHANTMENT_TABLE")),
;
- fun getMaximumLevel(leveling: Leveling) = leveling.maximumLevels[name.lowercase()] ?: TODO("Repo error")
+ fun getMaximumLevel(leveling: Leveling) = assertNotNullOr(leveling.maximumLevels[name.lowercase()]) { 50 }
fun getLadder(leveling: Leveling): List<Int> {
if (this == SOCIAL) return leveling.socialExperienceRequiredPerLevel
@@ -149,14 +150,14 @@ value class PetType(val name: String)
@Serializable
data class Pet(
- val uuid: UUID?,
+ val uuid: UUID? = null,
val type: PetType,
- val exp: Double,
- val active: Boolean,
+ val exp: Double = 0.0,
+ val active: Boolean = false,
val tier: Rarity,
- val candyUsed: Int,
- val heldItem: String?,
- val skin: String?,
+ val candyUsed: Int = 0,
+ val heldItem: String? = null,
+ val skin: String? = null,
) {
val itemId get() = SkyblockId("${type.name};${tier.ordinal}")
}
@@ -184,7 +185,7 @@ data class PlayerData(
val rankData get() = RepoManager.neuRepo.constants.misc.ranks[if (monthlyPackageRank == "NONE" || monthlyPackageRank == null) packageRank else monthlyPackageRank]
fun getDisplayName(name: String = playerName) = rankData?.let {
("§${it.color}[${it.tag}${rankPlusDyeColor.modern}" +
- "${it.plus ?: ""}§${it.color}] $name")
+ "${it.plus ?: ""}§${it.color}] $name")
} ?: "${Formatting.GRAY}$name"
diff --git a/src/main/kotlin/moe/nea/firmament/apis/UrsaManager.kt b/src/main/kotlin/moe/nea/firmament/apis/UrsaManager.kt
index a72d633..8288283 100644
--- a/src/main/kotlin/moe/nea/firmament/apis/UrsaManager.kt
+++ b/src/main/kotlin/moe/nea/firmament/apis/UrsaManager.kt
@@ -9,14 +9,14 @@ package moe.nea.firmament.apis
import io.ktor.client.request.*
import io.ktor.client.statement.*
import io.ktor.http.*
-import java.time.Duration
-import java.time.Instant
-import java.util.*
import kotlinx.coroutines.Dispatchers
import kotlinx.coroutines.sync.Mutex
import kotlinx.coroutines.withContext
-import net.minecraft.client.MinecraftClient
import moe.nea.firmament.Firmament
+import net.minecraft.client.MinecraftClient
+import java.time.Duration
+import java.time.Instant
+import java.util.*
object UrsaManager {
private data class Token(
@@ -64,6 +64,9 @@ object UrsaManager {
?: (Instant.now() + Duration.ofMinutes(55))
currentToken = Token(validUntil, savedToken, host)
}
+ if (response.status.value != 200) {
+ Firmament.logger.error("Failed to contact ursa minor: ${response.bodyAsText()}")
+ }
return response
} finally {
if (didLock)
diff --git a/src/main/kotlin/moe/nea/firmament/gui/profileviewer/ProfileViewer.kt b/src/main/kotlin/moe/nea/firmament/gui/profileviewer/ProfileViewer.kt
index 5561476..e811663 100644
--- a/src/main/kotlin/moe/nea/firmament/gui/profileviewer/ProfileViewer.kt
+++ b/src/main/kotlin/moe/nea/firmament/gui/profileviewer/ProfileViewer.kt
@@ -9,16 +9,15 @@ package moe.nea.firmament.gui.profileviewer
import io.github.cottonmc.cotton.gui.client.CottonClientScreen
import io.github.cottonmc.cotton.gui.client.LightweightGuiDescription
import io.github.cottonmc.cotton.gui.widget.WTabPanel
-import java.util.*
-import net.fabricmc.fabric.api.client.command.v2.FabricClientCommandSource
-import kotlinx.coroutines.launch
-import net.minecraft.text.Text
import moe.nea.firmament.Firmament
import moe.nea.firmament.apis.Member
import moe.nea.firmament.apis.PlayerData
import moe.nea.firmament.apis.Profile
import moe.nea.firmament.apis.Routes
import moe.nea.firmament.util.ScreenUtil
+import net.fabricmc.fabric.api.client.command.v2.FabricClientCommandSource
+import net.minecraft.text.Text
+import java.util.*
class ProfileViewer(
val primaryPlayer: UUID,
@@ -44,29 +43,32 @@ class ProfileViewer(
}
companion object {
- fun onCommand(source: FabricClientCommandSource, name: String) {
+ suspend fun onCommand(source: FabricClientCommandSource, name: String) {
source.sendFeedback(Text.translatable("firmament.pv.lookingup", name))
- Firmament.coroutineScope.launch {
+ try {
val uuid = Routes.getUUIDForPlayerName(name)
if (uuid == null) {
source.sendError(Text.translatable("firmament.pv.noplayer", name))
- return@launch
+ return
}
val name = Routes.getPlayerNameForUUID(uuid) ?: name
val names = mapOf(uuid to (name))
val data = Routes.getAccountData(uuid)
if (data == null) {
source.sendError(Text.translatable("firmament.pv.noprofile", name))
- return@launch
+ return
}
val accountData = mapOf(data.uuid to data)
val profiles = Routes.getProfiles(uuid)
val profile = profiles?.profiles?.find { it.selected }
if (profile == null) {
source.sendFeedback(Text.translatable("firmament.pv.noprofile", name))
- return@launch
+ return
}
ScreenUtil.setScreenLater(CottonClientScreen(ProfileViewer(uuid, names, accountData, profile)))
+ } catch (e: Exception) {
+ Firmament.logger.error("Error loading profile data for $name", e)
+ source.sendError(Text.translatable("firmament.pv.badprofile", name, e.message))
}
}
}
diff --git a/src/main/kotlin/moe/nea/firmament/util/assertions.kt b/src/main/kotlin/moe/nea/firmament/util/assertions.kt
index 2e2e01a..5505422 100644
--- a/src/main/kotlin/moe/nea/firmament/util/assertions.kt
+++ b/src/main/kotlin/moe/nea/firmament/util/assertions.kt
@@ -9,8 +9,11 @@ package moe.nea.firmament.util
/**
* Less aggressive version of `require(obj != null)`, which fails in devenv but continues at runtime.
*/
-inline fun <T : Any> assertNotNullOr(obj: T?, block: () -> T): T {
- assert(obj != null)
+inline fun <T : Any> assertNotNullOr(obj: T?, message: String? = null, block: () -> T): T {
+ if (message == null)
+ assert(obj != null)
+ else
+ assert(obj != null) { message }
return obj ?: block()
}