init match stats before using

This commit is contained in:
2021-10-17 18:50:10 +02:00
parent 47ef2cf453
commit aa6eb72edf

21
main.go
View File

@@ -166,7 +166,7 @@ func getPlayer(w http.ResponseWriter, r *http.Request) {
db.Lock.RLock()
tMatches, err := tPlayer.QueryMatches().Order(ent.Desc(match.FieldDate)).Limit(10).All(context.Background())
db.Lock.RUnlock()
if err != nil || len(tMatches) == 0 || tMatches == nil {
if err != nil || len(tMatches) == 0 {
log.Debugf("[GP] No matches found for player %s", id)
err := utils.SendJSON(response, w)
if err != nil {
@@ -179,7 +179,7 @@ func getPlayer(w http.ResponseWriter, r *http.Request) {
metaStats := new(utils.MatchStats)
err = rdc.Get(context.Background(), fmt.Sprintf("csgowtfd_meta_%d", tPlayer.ID), &metaStats)
if err != nil || metaStats == nil {
if err != nil {
wins, ties, losses, err := utils.GetMatchStats(tPlayer, db.Lock)
if err != nil {
log.Errorf("[GP] Error retrieving match-stats for player %s: %v", id, err)
@@ -187,9 +187,11 @@ func getPlayer(w http.ResponseWriter, r *http.Request) {
return
}
response.MatchStats.Win = wins
response.MatchStats.Tie = ties
response.MatchStats.Loss = losses
response.MatchStats = &utils.MatchStats{
Win: wins,
Loss: losses,
Tie: ties,
}
err = rdc.Set(&cache.Item{
Ctx: context.Background(),
@@ -205,9 +207,12 @@ func getPlayer(w http.ResponseWriter, r *http.Request) {
log.Debugf("[GP] Metastats for %d saved to cache", tPlayer.ID)
} else {
log.Debugf("[GP] Metastats for %d from redis", tPlayer.ID)
response.MatchStats.Win = metaStats.Win
response.MatchStats.Tie = metaStats.Tie
response.MatchStats.Loss = metaStats.Loss
response.MatchStats = &utils.MatchStats{
Win: metaStats.Win,
Tie: metaStats.Tie,
Loss: metaStats.Loss,
}
}
for _, iMatch := range tMatches {