forked from SteamWar/SteamWar
Revert "Add EventCache for efficient retrieval of event groups and teams"
This reverts commit8b4f864f99. Revert "Refactor EventFights and Fight classes to improve player initialization and retrieval" This reverts commit8d705e7a84. Revert "Refactor EventFights and Fight classes to improve player initialization and retrieval" This reverts commit78352a3e67.
This commit is contained in:
@@ -141,7 +141,7 @@ class Fight(id: EntityID<Int>) : IntEntity(id) {
|
|||||||
lateinit var bluePlayers: List<FightPlayer>
|
lateinit var bluePlayers: List<FightPlayer>
|
||||||
lateinit var redPlayers: List<FightPlayer>
|
lateinit var redPlayers: List<FightPlayer>
|
||||||
|
|
||||||
fun initPlayers(fightPlayers: List<FightPlayer>) {
|
private fun initPlayers(fightPlayers: List<FightPlayer>) {
|
||||||
val blue = mutableListOf<FightPlayer>()
|
val blue = mutableListOf<FightPlayer>()
|
||||||
val red = mutableListOf<FightPlayer>()
|
val red = mutableListOf<FightPlayer>()
|
||||||
|
|
||||||
|
|||||||
@@ -23,7 +23,6 @@ import de.steamwar.sql.internal.useDb
|
|||||||
import org.jetbrains.exposed.v1.core.dao.id.CompositeID
|
import org.jetbrains.exposed.v1.core.dao.id.CompositeID
|
||||||
import org.jetbrains.exposed.v1.core.dao.id.CompositeIdTable
|
import org.jetbrains.exposed.v1.core.dao.id.CompositeIdTable
|
||||||
import org.jetbrains.exposed.v1.core.dao.id.EntityID
|
import org.jetbrains.exposed.v1.core.dao.id.EntityID
|
||||||
import org.jetbrains.exposed.v1.core.eq
|
|
||||||
import org.jetbrains.exposed.v1.core.inList
|
import org.jetbrains.exposed.v1.core.inList
|
||||||
import org.jetbrains.exposed.v1.dao.CompositeEntity
|
import org.jetbrains.exposed.v1.dao.CompositeEntity
|
||||||
import org.jetbrains.exposed.v1.dao.CompositeEntityClass
|
import org.jetbrains.exposed.v1.dao.CompositeEntityClass
|
||||||
@@ -68,11 +67,6 @@ class FightPlayer(id: EntityID<CompositeID>) : CompositeEntity(id) {
|
|||||||
fun batchGet(fightIds: List<Int>) = useDb {
|
fun batchGet(fightIds: List<Int>) = useDb {
|
||||||
find { FightPlayerTable.fightId inList fightIds.toList() }.toList()
|
find { FightPlayerTable.fightId inList fightIds.toList() }.toList()
|
||||||
}
|
}
|
||||||
|
|
||||||
@JvmStatic
|
|
||||||
fun getFight(fightId: Int) = useDb {
|
|
||||||
find { FightPlayerTable.fightId eq fightId }.toList()
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
val fightID by FightPlayerTable.fightId.transform({ EntityID(it, FightTable) }, { it.value })
|
val fightID by FightPlayerTable.fightId.transform({ EntityID(it, FightTable) }, { it.value })
|
||||||
|
|||||||
@@ -43,10 +43,10 @@ class Team(id: EntityID<Int>) : IntEntity(id) {
|
|||||||
private val teamCache = mutableMapOf<Int, Team>()
|
private val teamCache = mutableMapOf<Int, Team>()
|
||||||
|
|
||||||
@JvmStatic
|
@JvmStatic
|
||||||
fun clear() = synchronized(teamCache) { teamCache.clear() }
|
fun clear() = teamCache.clear()
|
||||||
|
|
||||||
@JvmStatic
|
@JvmStatic
|
||||||
fun byId(id: Int) = synchronized(teamCache) { teamCache.computeIfAbsent(id) { useDb { Team[id] } } }
|
fun byId(id: Int) = teamCache.computeIfAbsent(id) { useDb { Team[id] } }
|
||||||
|
|
||||||
@JvmStatic
|
@JvmStatic
|
||||||
fun get(name: String) = useDb { find { TeamTable.name.lowerCase() eq name.lowercase() or (TeamTable.kuerzel.lowerCase() eq name.lowercase()) }.firstOrNull() }
|
fun get(name: String) = useDb { find { TeamTable.name.lowerCase() eq name.lowercase() or (TeamTable.kuerzel.lowerCase() eq name.lowercase()) }.firstOrNull() }
|
||||||
|
|||||||
@@ -1,36 +0,0 @@
|
|||||||
/*
|
|
||||||
* This file is a part of the SteamWar software.
|
|
||||||
*
|
|
||||||
* Copyright (C) 2025 SteamWar.de-Serverteam
|
|
||||||
*
|
|
||||||
* This program is free software: you can redistribute it and/or modify
|
|
||||||
* it under the terms of the GNU Affero General Public License as published by
|
|
||||||
* the Free Software Foundation, either version 3 of the License, or
|
|
||||||
* (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it will be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU Affero General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU Affero General Public License
|
|
||||||
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
||||||
*/
|
|
||||||
|
|
||||||
package de.steamwar.data
|
|
||||||
|
|
||||||
import de.steamwar.routes.ResponseGroups
|
|
||||||
import de.steamwar.routes.ResponseTeam
|
|
||||||
import de.steamwar.sql.EventGroup
|
|
||||||
import de.steamwar.sql.Team
|
|
||||||
|
|
||||||
class EventCache {
|
|
||||||
private val groupCache = mutableMapOf<Int, ResponseGroups>()
|
|
||||||
private val teamCache = mutableMapOf<Int, ResponseTeam>()
|
|
||||||
|
|
||||||
fun getGroup(id: Int): ResponseGroups = groupCache.getOrPut(id) { ResponseGroups(EventGroup.byId(id).get()) }
|
|
||||||
fun getTeam(id: Int): ResponseTeam = teamCache.getOrPut(id) { ResponseTeam(Team.byId(id)) }
|
|
||||||
|
|
||||||
fun convertGroup(group: EventGroup) = ResponseGroups(group).also { groupCache[group.getId()] = it }
|
|
||||||
fun convertTeam(team: Team) = ResponseTeam(team).also { teamCache[team.teamId] = it }
|
|
||||||
}
|
|
||||||
@@ -20,9 +20,7 @@
|
|||||||
package de.steamwar.routes
|
package de.steamwar.routes
|
||||||
|
|
||||||
import de.steamwar.ResponseError
|
import de.steamwar.ResponseError
|
||||||
import de.steamwar.data.EventCache
|
|
||||||
import de.steamwar.sql.*
|
import de.steamwar.sql.*
|
||||||
import de.steamwar.sql.internal.useDb
|
|
||||||
import io.ktor.http.*
|
import io.ktor.http.*
|
||||||
import io.ktor.server.application.*
|
import io.ktor.server.application.*
|
||||||
import io.ktor.server.request.*
|
import io.ktor.server.request.*
|
||||||
@@ -43,55 +41,19 @@ data class ResponseEventFight(
|
|||||||
val ergebnis: Int,
|
val ergebnis: Int,
|
||||||
val spectatePort: Int?,
|
val spectatePort: Int?,
|
||||||
val group: ResponseGroups?,
|
val group: ResponseGroups?,
|
||||||
val hasFinished: Boolean,
|
val hasFinished: Boolean
|
||||||
val fightData: FightData? = null
|
|
||||||
) {
|
) {
|
||||||
constructor(eventFight: EventFight, cache: EventCache = EventCache()) : this(
|
constructor(eventFight: EventFight) : this(
|
||||||
eventFight.fightID,
|
eventFight.fightID,
|
||||||
eventFight.spielmodus,
|
eventFight.spielmodus,
|
||||||
eventFight.map,
|
eventFight.map,
|
||||||
cache.getTeam(eventFight.teamBlue),
|
ResponseTeam(Team.byId(eventFight.teamBlue)),
|
||||||
cache.getTeam(eventFight.teamRed),
|
ResponseTeam(Team.byId(eventFight.teamRed)),
|
||||||
eventFight.startTime.time,
|
eventFight.startTime.time,
|
||||||
eventFight.ergebnis,
|
eventFight.ergebnis,
|
||||||
eventFight.spectatePort,
|
eventFight.spectatePort,
|
||||||
eventFight.groupId?.let { cache.getGroup(it.value) },
|
eventFight.group.orElse(null)?.let { ResponseGroups(it, short = true) },
|
||||||
eventFight.hasFinished(),
|
eventFight.hasFinished()
|
||||||
eventFight.fight?.let { FightData(Fight.getById(it)) }
|
|
||||||
)
|
|
||||||
}
|
|
||||||
|
|
||||||
@Serializable
|
|
||||||
data class FightData(
|
|
||||||
val id: Int,
|
|
||||||
val gamemode: String,
|
|
||||||
val server: String,
|
|
||||||
val start: Long,
|
|
||||||
val duration: Int,
|
|
||||||
val blueLeader: ResponseUser,
|
|
||||||
val redLeader: ResponseUser,
|
|
||||||
val blueSchem: String?,
|
|
||||||
val redSchem: String?,
|
|
||||||
val win: String,
|
|
||||||
val winCondition: String,
|
|
||||||
|
|
||||||
val bluePlayers: List<ResponseUser>,
|
|
||||||
val redPlayers: List<ResponseUser>,
|
|
||||||
) {
|
|
||||||
constructor(fight: Fight, players: List<FightPlayer> = FightPlayer.getFight(fight.fightID)) : this(
|
|
||||||
fight.id.value,
|
|
||||||
fight.gameMode,
|
|
||||||
fight.server,
|
|
||||||
fight.startTime.time,
|
|
||||||
fight.duration,
|
|
||||||
ResponseUser.get(fight.blueLeader),
|
|
||||||
ResponseUser.get(fight.redLeader),
|
|
||||||
fight.blueSchem?.let { SchematicNode.getSchematicNode(it.value)?.name },
|
|
||||||
fight.redSchem?.let { SchematicNode.getSchematicNode(it.value)?.name },
|
|
||||||
fight.winner.name,
|
|
||||||
fight.winCondition,
|
|
||||||
players.filter { it.team == 1 }.map { ResponseUser.get(it.userID) },
|
|
||||||
players.filter { it.team == 2 }.map { ResponseUser.get(it.userID) },
|
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -20,7 +20,6 @@
|
|||||||
package de.steamwar.routes
|
package de.steamwar.routes
|
||||||
|
|
||||||
import de.steamwar.ResponseError
|
import de.steamwar.ResponseError
|
||||||
import de.steamwar.data.EventCache
|
|
||||||
import de.steamwar.plugins.SWPermissionCheck
|
import de.steamwar.plugins.SWPermissionCheck
|
||||||
import de.steamwar.sql.*
|
import de.steamwar.sql.*
|
||||||
import de.steamwar.sql.EventGroup.EventGroupType
|
import de.steamwar.sql.EventGroup.EventGroupType
|
||||||
@@ -114,10 +113,10 @@ data class ExtendedResponseEvent(
|
|||||||
val referees: List<ResponseUser>,
|
val referees: List<ResponseUser>,
|
||||||
val relations: List<ResponseRelation>
|
val relations: List<ResponseRelation>
|
||||||
) {
|
) {
|
||||||
constructor(event: Event, cache: EventCache = EventCache()) : this(
|
constructor(event: Event) : this(
|
||||||
ResponseEvent(event),
|
ResponseEvent(event),
|
||||||
TeamTeilnahme.getTeams(event.eventID).map { cache.convertTeam(it) },
|
TeamTeilnahme.getTeams(event.eventID).map { ResponseTeam(it) },
|
||||||
EventGroup.get(event).map { cache.convertGroup(it) },
|
EventGroup.get(event).map { ResponseGroups(it) },
|
||||||
EventFight.getEvent(event.eventID).map { ResponseEventFight(it) },
|
EventFight.getEvent(event.eventID).map { ResponseEventFight(it) },
|
||||||
Referee.get(event.eventID).map { ResponseUser.get(SteamwarUser.byId(it)!!) },
|
Referee.get(event.eventID).map { ResponseUser.get(SteamwarUser.byId(it)!!) },
|
||||||
EventRelation.get(event).map { ResponseRelation(it) }
|
EventRelation.get(event).map { ResponseRelation(it) }
|
||||||
|
|||||||
Reference in New Issue
Block a user