You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
38 lines
918 B
Go
38 lines
918 B
Go
package db
|
|
|
|
import (
|
|
"github.com/Flashfyre/pokerogue-server/defs"
|
|
)
|
|
|
|
func TryAddDailyRun(seed string) error {
|
|
_, err := handle.Exec("INSERT INTO dailyRuns (seed, date) VALUES (?, UTC_DATE()) ON DUPLICATE KEY UPDATE date = date", seed)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
func GetRankings() ([]defs.DailyRanking, error) {
|
|
var rankings []defs.DailyRanking
|
|
|
|
results, err := handle.Query("SELECT RANK() OVER (ORDER BY sc.score DESC, sc.timestamp), a.username, sc.score FROM seedCompletions sc JOIN dailyRuns dr ON dr.seed = sc.seed JOIN accounts a ON sc.uuid = a.uuid WHERE dr.date = UTC_DATE()")
|
|
if err != nil {
|
|
return rankings, err
|
|
}
|
|
|
|
defer results.Close()
|
|
|
|
for results.Next() {
|
|
ranking := defs.DailyRanking{}
|
|
err = results.Scan(&ranking.Rank, &ranking.Username, &ranking.Score)
|
|
if err != nil {
|
|
return rankings, err
|
|
}
|
|
|
|
rankings = append(rankings, ranking)
|
|
}
|
|
|
|
return rankings, nil
|
|
}
|