rogueserver/api/daily.go

106 lines
2.2 KiB
Go
Raw Normal View History

2024-03-16 18:51:13 -07:00
package api
import (
2024-03-18 16:55:02 -07:00
"crypto/md5"
"crypto/rand"
"encoding/base64"
"encoding/binary"
2024-03-17 10:18:51 -07:00
"fmt"
2024-03-16 18:51:13 -07:00
"log"
2024-03-18 16:55:02 -07:00
"os"
"time"
2024-03-16 18:51:13 -07:00
"github.com/Flashfyre/pokerogue-server/db"
2024-04-08 17:44:36 -07:00
"github.com/Flashfyre/pokerogue-server/defs"
2024-03-19 19:05:37 -07:00
"github.com/go-co-op/gocron"
2024-03-16 18:51:13 -07:00
)
2024-03-18 16:55:02 -07:00
const secondsPerDay = 60 * 60 * 24
2024-03-16 18:51:13 -07:00
var (
2024-03-19 19:05:37 -07:00
dailyRunScheduler = gocron.NewScheduler(time.UTC)
dailyRunSecret []byte
dailyRunSeed string
2024-03-16 18:51:13 -07:00
)
func ScheduleDailyRunRefresh() {
2024-04-08 15:15:09 -07:00
dailyRunScheduler.Every(1).Day().At("00:00").Do(func() error {
err := InitDailyRun()
if err != nil {
log.Fatal(err)
}
return nil
}())
2024-03-19 19:05:37 -07:00
dailyRunScheduler.StartAsync()
2024-03-16 18:51:13 -07:00
}
2024-04-08 15:15:09 -07:00
func InitDailyRun() error {
2024-03-18 16:55:02 -07:00
secret, err := os.ReadFile("secret.key")
2024-03-16 18:51:13 -07:00
if err != nil {
2024-03-18 16:55:02 -07:00
if !os.IsNotExist(err) {
2024-04-08 15:15:09 -07:00
return fmt.Errorf("failed to read daily seed secret: %s", err)
2024-03-18 16:55:02 -07:00
}
2024-03-18 16:55:02 -07:00
newSecret := make([]byte, 32)
_, err := rand.Read(newSecret)
if err != nil {
2024-04-08 15:15:09 -07:00
return fmt.Errorf("failed to generate daily seed secret: %s", err)
}
2024-03-18 16:55:02 -07:00
err = os.WriteFile("secret.key", newSecret, 0400)
if err != nil {
2024-04-08 15:15:09 -07:00
return fmt.Errorf("failed to write daily seed secret: %s", err)
2024-03-18 16:55:02 -07:00
}
secret = newSecret
}
dailyRunSecret = secret
2024-04-01 19:54:55 -07:00
dailyRunSeed = base64.StdEncoding.EncodeToString(deriveDailyRunSeed(time.Now().UTC()))
2024-03-18 16:55:02 -07:00
err = db.TryAddDailyRun(dailyRunSeed)
if err != nil {
2024-04-01 19:54:55 -07:00
log.Print(err)
2024-03-16 18:51:13 -07:00
}
2024-04-01 19:54:55 -07:00
2024-03-19 19:05:37 -07:00
log.Printf("Daily Run Seed: %s", dailyRunSeed)
2024-04-08 15:15:09 -07:00
return nil
2024-03-16 18:51:13 -07:00
}
2024-04-01 19:54:55 -07:00
func deriveDailyRunSeed(seedTime time.Time) []byte {
2024-03-18 16:55:02 -07:00
day := make([]byte, 8)
binary.BigEndian.PutUint64(day, uint64(seedTime.Unix()/secondsPerDay))
hashedSeed := md5.Sum(append(day, dailyRunSecret...))
return hashedSeed[:]
}
2024-03-17 10:18:51 -07:00
// /daily/rankings - fetch daily rankings
2024-04-08 17:44:36 -07:00
func handleRankings(uuid []byte, category, page int) ([]defs.DailyRanking, error) {
err := db.UpdateAccountLastActivity(uuid)
if err != nil {
log.Print("failed to update account last activity")
}
rankings, err := db.FetchRankings(category, page)
2024-03-17 10:18:51 -07:00
if err != nil {
log.Print("failed to retrieve rankings")
}
2024-04-08 17:44:36 -07:00
return rankings, nil
2024-03-17 10:18:51 -07:00
}
// /daily/rankingpagecount - fetch daily ranking page count
2024-04-08 17:44:36 -07:00
func handleRankingPageCount(category int) (int, error) {
pageCount, err := db.FetchRankingPageCount(category)
if err != nil {
log.Print("failed to retrieve ranking page count")
}
2024-04-08 17:44:36 -07:00
return pageCount, nil
}