[+] Chusan user summary

This commit is contained in:
Azalea
2024-02-26 11:55:43 -05:00
parent 0b29ac00a7
commit 50dfb95c48
8 changed files with 110 additions and 26 deletions

View File

@@ -0,0 +1,45 @@
package icu.samnyan.aqua.net.games
import ext.API
import ext.RP
import ext.Str
import icu.samnyan.aqua.net.db.AquaUserServices
import icu.samnyan.aqua.net.utils.TrendLog
import icu.samnyan.aqua.net.utils.chu3Scores
import icu.samnyan.aqua.net.utils.findTrend
import icu.samnyan.aqua.net.utils.genericUserSummary
import icu.samnyan.aqua.sega.chusan.dao.userdata.UserDataRepository
import icu.samnyan.aqua.sega.chusan.dao.userdata.UserGeneralDataRepository
import icu.samnyan.aqua.sega.chusan.dao.userdata.UserPlaylogRepository
import org.springframework.web.bind.annotation.RestController
import java.time.format.DateTimeFormatter
@RestController
@API("api/v2/game/chu3")
class Chusan(
val us: AquaUserServices,
val userPlaylogRepository: UserPlaylogRepository,
val userDataRepository: UserDataRepository,
val userGeneralDataRepository: UserGeneralDataRepository
): GameApiController
{
override fun trend(@RP username: Str): List<TrendOut> = us.byName(username) { u ->
val fmt = DateTimeFormatter.ofPattern("YYYY-MM-DD")
findTrend(userPlaylogRepository.findByUser_Card_ExtId(u.ghostCard.extId)
.map { TrendLog(fmt.format(it.playDate), it.playerRating) })
}
// Only show > AAA rank
private val shownRanks = chu3Scores.filter { it.first >= 95 }
override fun userSummary(@RP username: Str) = us.byName(username) { u ->
// Summary values: total plays, player rating, server-wide ranking
// number of each rank, max combo, number of full combo, number of all perfect
val extra = userGeneralDataRepository.findByUser_Card_ExtId(u.ghostCard.extId)
.associate { it.propertyKey to it.propertyValue }
// TODO: Rating composition
genericUserSummary(u, userDataRepository, userPlaylogRepository, shownRanks, emptyMap())
}
}

View File

@@ -1,8 +1,10 @@
package icu.samnyan.aqua.sega.chusan.dao.userdata; package icu.samnyan.aqua.sega.chusan.dao.userdata;
import icu.samnyan.aqua.net.utils.GenericUserDataRepo;
import icu.samnyan.aqua.sega.chusan.model.userdata.UserData; import icu.samnyan.aqua.sega.chusan.model.userdata.UserData;
import icu.samnyan.aqua.sega.general.model.Card; import icu.samnyan.aqua.sega.general.model.Card;
import org.springframework.data.jpa.repository.JpaRepository; import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.data.jpa.repository.Query;
import org.springframework.stereotype.Repository; import org.springframework.stereotype.Repository;
import java.util.Optional; import java.util.Optional;
@@ -11,9 +13,13 @@ import java.util.Optional;
* @author samnyan (privateamusement@protonmail.com) * @author samnyan (privateamusement@protonmail.com)
*/ */
@Repository("ChusanUserDataRepository") @Repository("ChusanUserDataRepository")
public interface UserDataRepository extends JpaRepository<UserData, Long> { public interface UserDataRepository extends JpaRepository<UserData, Long>, GenericUserDataRepo {
Optional<UserData> findByCard(Card card); UserData findByCard(Card card);
Optional<UserData> findByCard_ExtId(Long extId); Optional<UserData> findByCard_ExtId(Long extId);
@Override
@Query("select count(*) from Maimai2UserData where playerRating > :rating")
long getRanking(int rating);
} }

View File

@@ -1,20 +0,0 @@
package icu.samnyan.aqua.sega.chusan.dao.userdata;
import icu.samnyan.aqua.sega.chusan.model.userdata.UserData;
import icu.samnyan.aqua.sega.chusan.model.userdata.UserGeneralData;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.stereotype.Repository;
import java.util.Optional;
/**
* @author samnyan (privateamusement@protonmail.com)
*/
@Repository("ChusanUserGeneralDataRepository")
public interface UserGeneralDataRepository extends JpaRepository<UserGeneralData, Long> {
Optional<UserGeneralData> findByUserAndPropertyKey(UserData user, String key);
Optional<UserGeneralData> findByUser_Card_ExtIdAndPropertyKey(Long extId, String key);
}

View File

@@ -0,0 +1,19 @@
package icu.samnyan.aqua.sega.chusan.dao.userdata
import icu.samnyan.aqua.sega.chusan.model.userdata.UserData
import icu.samnyan.aqua.sega.chusan.model.userdata.UserGeneralData
import org.springframework.data.jpa.repository.JpaRepository
import org.springframework.stereotype.Repository
import java.util.*
/**
* @author samnyan (privateamusement@protonmail.com)
*/
@Repository("ChusanUserGeneralDataRepository")
interface UserGeneralDataRepository : JpaRepository<UserGeneralData, Long> {
fun findByUserAndPropertyKey(user: UserData, key: String): Optional<UserGeneralData>
fun findByUser_Card_ExtIdAndPropertyKey(extId: Long, key: String): Optional<UserGeneralData>
fun findByUser_Card_ExtId(extId: Long): List<UserGeneralData>
}

View File

@@ -1,5 +1,6 @@
package icu.samnyan.aqua.sega.chusan.dao.userdata; package icu.samnyan.aqua.sega.chusan.dao.userdata;
import icu.samnyan.aqua.net.utils.GenericPlaylogRepo;
import icu.samnyan.aqua.sega.chusan.model.userdata.UserPlaylog; import icu.samnyan.aqua.sega.chusan.model.userdata.UserPlaylog;
import org.springframework.data.domain.Page; import org.springframework.data.domain.Page;
import org.springframework.data.domain.Pageable; import org.springframework.data.domain.Pageable;
@@ -12,7 +13,7 @@ import java.util.List;
* @author samnyan (privateamusement@protonmail.com) * @author samnyan (privateamusement@protonmail.com)
*/ */
@Repository("ChusanUserPlaylogRepository") @Repository("ChusanUserPlaylogRepository")
public interface UserPlaylogRepository extends JpaRepository<UserPlaylog, Long> { public interface UserPlaylogRepository extends JpaRepository<UserPlaylog, Long>, GenericPlaylogRepo {
List<UserPlaylog> findByUser_Card_ExtIdAndLevelNot(Long extId, int levelNot, Pageable page); List<UserPlaylog> findByUser_Card_ExtIdAndLevelNot(Long extId, int levelNot, Pageable page);
Page<UserPlaylog> findByUser_Card_ExtId(Long extId, Pageable page); Page<UserPlaylog> findByUser_Card_ExtId(Long extId, Pageable page);

View File

@@ -5,6 +5,7 @@ import com.fasterxml.jackson.annotation.JsonInclude;
import com.fasterxml.jackson.annotation.JsonProperty; import com.fasterxml.jackson.annotation.JsonProperty;
import com.fasterxml.jackson.annotation.JsonPropertyOrder; import com.fasterxml.jackson.annotation.JsonPropertyOrder;
import com.fasterxml.jackson.databind.annotation.JsonSerialize; import com.fasterxml.jackson.databind.annotation.JsonSerialize;
import icu.samnyan.aqua.net.utils.IGenericUserData;
import icu.samnyan.aqua.sega.chusan.model.response.data.UserEmoney; import icu.samnyan.aqua.sega.chusan.model.response.data.UserEmoney;
import icu.samnyan.aqua.sega.general.model.Card; import icu.samnyan.aqua.sega.general.model.Card;
import icu.samnyan.aqua.sega.util.jackson.AccessCodeSerializer; import icu.samnyan.aqua.sega.util.jackson.AccessCodeSerializer;
@@ -124,7 +125,7 @@ import java.util.List;
"rankUpChallengeResults", "rankUpChallengeResults",
"isNetBattleHost", "isNetBattleHost",
"netBattleEndState" }) "netBattleEndState" })
public class UserData implements Serializable { public class UserData implements Serializable, IGenericUserData {
private static final long serialVersionUID = 1L; private static final long serialVersionUID = 1L;
@@ -344,4 +345,13 @@ public class UserData implements Serializable {
@Transient @Transient
private UserEmoney userEmoney; private UserEmoney userEmoney;
@Override
public int getIconId() {
return characterId;
}
@Override
public long getTotalScore() {
return totalHiScore;
}
} }

View File

@@ -2,10 +2,12 @@ package icu.samnyan.aqua.sega.chusan.model.userdata;
import com.fasterxml.jackson.annotation.JsonIgnore; import com.fasterxml.jackson.annotation.JsonIgnore;
import com.fasterxml.jackson.annotation.JsonProperty; import com.fasterxml.jackson.annotation.JsonProperty;
import icu.samnyan.aqua.net.utils.IGenericGamePlaylog;
import jakarta.persistence.*; import jakarta.persistence.*;
import lombok.AllArgsConstructor; import lombok.AllArgsConstructor;
import lombok.Data; import lombok.Data;
import lombok.NoArgsConstructor; import lombok.NoArgsConstructor;
import org.jetbrains.annotations.NotNull;
import java.io.Serializable; import java.io.Serializable;
import java.time.LocalDateTime; import java.time.LocalDateTime;
@@ -18,7 +20,7 @@ import java.time.LocalDateTime;
@Data @Data
@NoArgsConstructor @NoArgsConstructor
@AllArgsConstructor @AllArgsConstructor
public class UserPlaylog implements Serializable { public class UserPlaylog implements Serializable, IGenericGamePlaylog {
private static final long serialVersionUID = 1L; private static final long serialVersionUID = 1L;
@@ -148,4 +150,25 @@ public class UserPlaylog implements Serializable {
public UserPlaylog(UserData userData) { public UserPlaylog(UserData userData) {
user = userData; user = userData;
} }
@Override
public int getAchievement() {
return score;
}
@Override
public int getTotalCombo() {
return maxCombo;
}
@Override
public int getAfterRating() {
return playerRating;
}
@NotNull
@Override
public String getDate() {
return playDate.toString();
}
} }

View File

@@ -35,7 +35,7 @@ public class UserDataService {
} }
public Optional<UserData> getUserByCard(Card card) { public Optional<UserData> getUserByCard(Card card) {
return userDataRepository.findByCard(card); return Optional.ofNullable(userDataRepository.findByCard(card));
} }
public void updateLoginTime(UserData userData) { public void updateLoginTime(UserData userData) {