3 changed files with 130 additions and 4 deletions
@ -0,0 +1,112 @@ |
|||||
|
package app.services; |
||||
|
|
||||
|
import app.entities.other.SteamID; |
||||
|
import app.entities.server.Server; |
||||
|
import jakarta.persistence.EntityManager; |
||||
|
import jakarta.persistence.PersistenceContext; |
||||
|
import org.springframework.beans.factory.annotation.Autowired; |
||||
|
import org.springframework.stereotype.Service; |
||||
|
|
||||
|
import java.math.BigDecimal; |
||||
|
import java.sql.Timestamp; |
||||
|
import java.util.*; |
||||
|
|
||||
|
@Service |
||||
|
public class UsertimeService { |
||||
|
|
||||
|
@PersistenceContext |
||||
|
EntityManager entityManager; |
||||
|
|
||||
|
//Лучше это всегда держать в true
|
||||
|
boolean last_map = true; |
||||
|
Stats stats; |
||||
|
|
||||
|
@Autowired |
||||
|
public UsertimeService(Stats stats) { |
||||
|
this.stats = stats; |
||||
|
} |
||||
|
|
||||
|
public HashMap<String, HashMap<String, Long>> getPlayerLastplay(SteamID steamID) { |
||||
|
List<String> maps; |
||||
|
HashMap<String, HashMap<String, Long>> result = new HashMap<>(); |
||||
|
|
||||
|
for (Map.Entry<String, Server> stringServerEntry : stats.getServers().entrySet()) { |
||||
|
if(last_map) { |
||||
|
maps = getMap(stringServerEntry.getValue().getDb()).orElse(List.of()); |
||||
|
} else { |
||||
|
maps = getMaps(stringServerEntry.getValue().getDb()).orElse(List.of()); |
||||
|
} |
||||
|
|
||||
|
if(maps.size() == 0) {continue;} |
||||
|
|
||||
|
for(String map: maps){ |
||||
|
Timestamp lastplay = getLastplay(stringServerEntry.getValue().getDb(), steamID, map); |
||||
|
if(lastplay != null) { |
||||
|
if(!result.containsKey(stringServerEntry.getKey())){ |
||||
|
result.put(stringServerEntry.getKey(), new HashMap<>()); |
||||
|
} |
||||
|
result.get(stringServerEntry.getKey()).put(map, lastplay.getTime()/1000); |
||||
|
} |
||||
|
} |
||||
|
} |
||||
|
return result; |
||||
|
} |
||||
|
|
||||
|
public HashMap<String, HashMap<String, BigDecimal>> getPlayerUsertime(SteamID steamID) { |
||||
|
List<String> maps; |
||||
|
HashMap<String, HashMap<String, BigDecimal>> result = new HashMap<>(); |
||||
|
|
||||
|
for (Map.Entry<String, Server> stringServerEntry : stats.getServers().entrySet()) { |
||||
|
if(last_map) { |
||||
|
maps = getMap(stringServerEntry.getValue().getDb()).orElse(List.of()); |
||||
|
} else { |
||||
|
maps = getMaps(stringServerEntry.getValue().getDb()).orElse(List.of()); |
||||
|
} |
||||
|
|
||||
|
if(maps.size() == 0) {continue;} |
||||
|
|
||||
|
for(String map: maps){ |
||||
|
BigDecimal usertime = getTotalPlaytime(stringServerEntry.getValue().getDb(), steamID, map); |
||||
|
if(usertime != null) { |
||||
|
if(!result.containsKey(stringServerEntry.getKey())){ |
||||
|
result.put(stringServerEntry.getKey(), new HashMap<>()); |
||||
|
} |
||||
|
result.get(stringServerEntry.getKey()).put(map, usertime); |
||||
|
} |
||||
|
} |
||||
|
} |
||||
|
return result; |
||||
|
} |
||||
|
|
||||
|
public Timestamp getLastplay(String db, SteamID steamID, String map) { |
||||
|
List<Timestamp> response = entityManager.createNativeQuery("select timestamp from `"+db+"`.`user_connections` WHERE map LIKE ?3 and connection_type LIKE ?1 AND account_id = ?2 ORDER BY `user_connections`.`id` DESC LIMIT 1") |
||||
|
//.setParameter(1, db)
|
||||
|
.setParameter(1,"disconnect") |
||||
|
.setParameter(2, steamID.account_id) |
||||
|
.setParameter(3, map) |
||||
|
.getResultList(); |
||||
|
return response.size() > 0 ? response.get(0) : null; |
||||
|
} |
||||
|
|
||||
|
public BigDecimal getTotalPlaytime(String db, SteamID steamID, String map) { |
||||
|
List<BigDecimal> response = entityManager.createNativeQuery("select sum(connect_duration) total from `"+db+"`.`user_connections` WHERE map LIKE ?1 and connection_type LIKE ?2 AND account_id = ?3") |
||||
|
//.setParameter(1, db)
|
||||
|
.setParameter(1, map) |
||||
|
.setParameter(2, "disconnect") |
||||
|
.setParameter(3, steamID.account_id) |
||||
|
.getResultList(); |
||||
|
return response.size() > 0 ? response.get(0) : null; |
||||
|
} |
||||
|
|
||||
|
public Optional<List> getMap(String db) { |
||||
|
return Optional.ofNullable(entityManager.createNativeQuery("select `map` from `"+db+"`.`user_connections` WHERE 1 ORDER BY `user_connections`.`id` DESC LIMIT 1") |
||||
|
//.setParameter(1, db)
|
||||
|
.getResultList()); |
||||
|
} |
||||
|
|
||||
|
public Optional<List> getMaps(String db) { |
||||
|
return Optional.ofNullable(entityManager.createNativeQuery("select distinct `map` from `"+db+"`.`user_connections`") |
||||
|
//.setParameter(1, db)
|
||||
|
.getResultList()); |
||||
|
} |
||||
|
} |
Loading…
Reference in new issue