Add endpoints for stats
parent
99d3490172
commit
dcb1c76370
49
api/game.go
49
api/game.go
|
@ -8,25 +8,36 @@ import (
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/Flashfyre/pokerogue-server/db"
|
"github.com/Flashfyre/pokerogue-server/db"
|
||||||
|
"github.com/Flashfyre/pokerogue-server/defs"
|
||||||
"github.com/go-co-op/gocron"
|
"github.com/go-co-op/gocron"
|
||||||
)
|
)
|
||||||
|
|
||||||
var (
|
var (
|
||||||
playerCountScheduler = gocron.NewScheduler(time.UTC)
|
statScheduler = gocron.NewScheduler(time.UTC)
|
||||||
playerCount int
|
playerCount int
|
||||||
|
battleCount int
|
||||||
|
classicSessionCount int
|
||||||
)
|
)
|
||||||
|
|
||||||
func SchedulePlayerCountRefresh() {
|
func ScheduleStatRefresh() {
|
||||||
playerCountScheduler.Every(10).Second().Do(updatePlayerCount)
|
statScheduler.Every(10).Second().Do(updateStats)
|
||||||
playerCountScheduler.StartAsync()
|
statScheduler.StartAsync()
|
||||||
}
|
}
|
||||||
|
|
||||||
func updatePlayerCount() {
|
func updateStats() {
|
||||||
var err error
|
var err error
|
||||||
playerCount, err = db.FetchPlayerCount()
|
playerCount, err = db.FetchPlayerCount()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Print(err)
|
log.Print(err)
|
||||||
}
|
}
|
||||||
|
battleCount, err = db.FetchBattleCount()
|
||||||
|
if err != nil {
|
||||||
|
log.Print(err)
|
||||||
|
}
|
||||||
|
classicSessionCount, err = db.FetchClassicSessionCount()
|
||||||
|
if err != nil {
|
||||||
|
log.Print(err)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// /game/playercount - get player count
|
// /game/playercount - get player count
|
||||||
|
@ -39,3 +50,29 @@ func (s *Server) handlePlayerCountGet(w http.ResponseWriter) {
|
||||||
|
|
||||||
w.Write(response)
|
w.Write(response)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// /game/titlestats - get title stats
|
||||||
|
func (s *Server) handleTitleStatsGet(w http.ResponseWriter) {
|
||||||
|
titleStats := &defs.TitleStats{
|
||||||
|
PlayerCount: playerCount,
|
||||||
|
BattleCount: battleCount,
|
||||||
|
}
|
||||||
|
response, err := json.Marshal(titleStats)
|
||||||
|
if err != nil {
|
||||||
|
http.Error(w, fmt.Sprintf("failed to marshal response json: %s", err), http.StatusInternalServerError)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
w.Write(response)
|
||||||
|
}
|
||||||
|
|
||||||
|
// /game/classicsessioncount - get classic session count
|
||||||
|
func (s *Server) handleClassicSessionCountGet(w http.ResponseWriter) {
|
||||||
|
response, err := json.Marshal(classicSessionCount)
|
||||||
|
if err != nil {
|
||||||
|
http.Error(w, fmt.Sprintf("failed to marshal response json: %s", err), http.StatusInternalServerError)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
w.Write(response)
|
||||||
|
}
|
||||||
|
|
|
@ -36,6 +36,10 @@ func (s *Server) ServeHTTP(w http.ResponseWriter, r *http.Request) {
|
||||||
|
|
||||||
case "/game/playercount":
|
case "/game/playercount":
|
||||||
s.handlePlayerCountGet(w)
|
s.handlePlayerCountGet(w)
|
||||||
|
case "/game/titlestats":
|
||||||
|
s.handleTitleStatsGet(w)
|
||||||
|
case "/game/classicsessioncount":
|
||||||
|
s.handleClassicSessionCountGet(w)
|
||||||
|
|
||||||
case "/savedata/get":
|
case "/savedata/get":
|
||||||
s.handleSavedataGet(w, r)
|
s.handleSavedataGet(w, r)
|
||||||
|
|
20
db/game.go
20
db/game.go
|
@ -9,3 +9,23 @@ func FetchPlayerCount() (int, error) {
|
||||||
|
|
||||||
return playerCount, nil
|
return playerCount, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func FetchBattleCount() (int, error) {
|
||||||
|
var battleCount int
|
||||||
|
err := handle.QueryRow("SELECT SUM(battles) FROM accountStats").Scan(&battleCount)
|
||||||
|
if err != nil {
|
||||||
|
return 0, err
|
||||||
|
}
|
||||||
|
|
||||||
|
return battleCount, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func FetchClassicSessionCount() (int, error) {
|
||||||
|
var classicSessionCount int
|
||||||
|
err := handle.QueryRow("SELECT SUM(classicSessionsPlayed) FROM accountStats").Scan(&classicSessionCount)
|
||||||
|
if err != nil {
|
||||||
|
return 0, err
|
||||||
|
}
|
||||||
|
|
||||||
|
return classicSessionCount, nil
|
||||||
|
}
|
||||||
|
|
|
@ -0,0 +1,6 @@
|
||||||
|
package defs
|
||||||
|
|
||||||
|
type TitleStats struct {
|
||||||
|
PlayerCount int `json:"playerCount"`
|
||||||
|
BattleCount int `json:"battleCount"`
|
||||||
|
}
|
|
@ -43,7 +43,7 @@ func main() {
|
||||||
os.Chmod(*addr, 0777)
|
os.Chmod(*addr, 0777)
|
||||||
}
|
}
|
||||||
|
|
||||||
api.SchedulePlayerCountRefresh()
|
api.ScheduleStatRefresh()
|
||||||
api.ScheduleDailyRunRefresh()
|
api.ScheduleDailyRunRefresh()
|
||||||
api.InitDailyRun()
|
api.InitDailyRun()
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue