rogueserver/api/common.go

89 lines
2.3 KiB
Go
Raw Normal View History

2023-12-31 13:12:20 -08:00
package api
import (
"encoding/base64"
"fmt"
2024-04-24 17:23:20 -07:00
"log"
2023-12-31 13:12:20 -08:00
"net/http"
2024-04-15 00:24:45 -07:00
"github.com/pagefaultgames/pokerogue-server/api/account"
"github.com/pagefaultgames/pokerogue-server/api/daily"
2024-04-14 16:25:36 -07:00
"github.com/pagefaultgames/pokerogue-server/db"
2023-12-31 13:12:20 -08:00
)
func Init(mux *http.ServeMux) {
scheduleStatRefresh()
daily.Init()
// account
mux.HandleFunc("/account/info", handleAccountInfo)
mux.HandleFunc("/account/register", handleAccountRegister)
mux.HandleFunc("/account/login", handleAccountLogin)
mux.HandleFunc("/account/logout", handleAccountLogout)
// game
mux.HandleFunc("/game/playercount", handleGamePlayerCount)
mux.HandleFunc("/game/titlestats", handleGameTitleStats)
mux.HandleFunc("/game/classicsessioncount", handleGameClassicSessionCount)
// savedata
mux.HandleFunc("/savedata/get", handleSaveData)
mux.HandleFunc("/savedata/update", handleSaveData)
mux.HandleFunc("/savedata/delete", handleSaveData)
mux.HandleFunc("/savedata/clear", handleSaveData)
// daily
mux.HandleFunc("/daily/seed", handleDailySeed)
mux.HandleFunc("/daily/rankings", handleDailyRankings)
mux.HandleFunc("/daily/rankingpagecount", handleDailyRankingPageCount)
}
func tokenFromRequest(r *http.Request) ([]byte, error) {
2024-04-01 19:54:55 -07:00
if r.Header.Get("Authorization") == "" {
2024-04-21 13:52:26 -07:00
return nil, fmt.Errorf("missing token")
2023-12-31 13:12:20 -08:00
}
2024-04-01 19:54:55 -07:00
token, err := base64.StdEncoding.DecodeString(r.Header.Get("Authorization"))
2023-12-31 13:12:20 -08:00
if err != nil {
2024-04-21 13:52:26 -07:00
return nil, fmt.Errorf("failed to decode token: %s", err)
2023-12-31 13:12:20 -08:00
}
2024-04-21 15:57:27 -07:00
2024-04-15 00:24:45 -07:00
if len(token) != account.TokenSize {
2024-04-21 13:52:26 -07:00
return nil, fmt.Errorf("invalid token length: got %d, expected %d", len(token), account.TokenSize)
}
return token, nil
}
func usernameFromRequest(r *http.Request) (string, error) {
token, err := tokenFromRequest(r)
2024-04-21 13:52:26 -07:00
if err != nil {
return "", err
2023-12-31 13:12:20 -08:00
}
2024-03-18 16:55:02 -07:00
username, err := db.FetchUsernameFromToken(token)
2023-12-31 13:12:20 -08:00
if err != nil {
return "", fmt.Errorf("failed to validate token: %s", err)
}
return username, nil
}
func uuidFromRequest(r *http.Request) ([]byte, error) {
token, err := tokenFromRequest(r)
2023-12-31 13:12:20 -08:00
if err != nil {
2024-04-21 13:52:26 -07:00
return nil, err
2023-12-31 13:12:20 -08:00
}
2024-04-08 15:15:09 -07:00
uuid, err := db.FetchUUIDFromToken(token)
2023-12-31 13:12:20 -08:00
if err != nil {
return nil, fmt.Errorf("failed to validate token: %s", err)
}
return uuid, nil
}
2024-04-24 17:23:20 -07:00
func httpError(w http.ResponseWriter, r *http.Request, err error, code int) {
log.Printf("%s: %s\n", r.URL.Path, err)
http.Error(w, err.Error(), code)
}