mirror of
https://github.com/MewoLab/AquaDX.git
synced 2026-02-12 08:27:26 +08:00
[+] Chusan user summary
This commit is contained in:
45
src/main/java/icu/samnyan/aqua/net/games/Chusan.kt
Normal file
45
src/main/java/icu/samnyan/aqua/net/games/Chusan.kt
Normal 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())
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -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);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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);
|
|
||||||
|
|
||||||
}
|
|
||||||
@@ -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>
|
||||||
|
}
|
||||||
@@ -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);
|
||||||
|
|||||||
@@ -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;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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) {
|
||||||
|
|||||||
Reference in New Issue
Block a user