Feat: save/load state

This commit is contained in:
Grail Finder
2025-05-05 06:55:33 +03:00
parent ca9b077070
commit 5e92523dcd
4 changed files with 44 additions and 3 deletions

View File

@@ -3,6 +3,7 @@ package handlers
import ( import (
"context" "context"
"encoding/json" "encoding/json"
"errors"
"golias/models" "golias/models"
) )
@@ -28,7 +29,44 @@ func getRoomIDFromCtx(ctx context.Context) string {
return id return id
} }
func getStateByCtx(ctx context.Context) (*models.UserState, error) {
username, ok := ctx.Value(models.CtxUsernameKey).(string)
if !ok {
log.Debug("no username in ctx")
return &models.UserState{}, errors.New("no username in ctx")
}
us, err := loadState(username)
if err != nil {
return &models.UserState{}, err
}
return us, nil
}
// cache // cache
func saveState(username string, state *models.UserState) error {
key := models.CacheStatePrefix + username
data, err := json.Marshal(state)
if err != nil {
return err
}
memcache.Set(key, data)
return nil
}
func loadState(username string) (*models.UserState, error) {
key := models.CacheStatePrefix + username
data, err := memcache.Get(key)
if err != nil {
return nil, err
}
resp := &models.UserState{}
if err := json.Unmarshal(data, &resp); err != nil {
return nil, err
}
return resp, nil
}
func getAllNames() []string { func getAllNames() []string {
names := []string{} names := []string{}
// will not scale // will not scale

View File

@@ -80,6 +80,8 @@ func HandleFrontLogin(w http.ResponseWriter, r *http.Request) {
// } // }
// state := models.InitState(cleanName) // state := models.InitState(cleanName)
state := models.MakeTestState() state := models.MakeTestState()
// save state to cache
saveState(cleanName, state)
tmpl.ExecuteTemplate(w, "base", state) tmpl.ExecuteTemplate(w, "base", state)
} }

View File

@@ -2,7 +2,6 @@ package handlers
import ( import (
"golias/config" "golias/config"
"golias/models"
"golias/pkg/cache" "golias/pkg/cache"
"html/template" "html/template"
"log/slog" "log/slog"
@@ -57,6 +56,7 @@ func HandleHome(w http.ResponseWriter, r *http.Request) {
// tmpl.ExecuteTemplate(w, "room", userState) // tmpl.ExecuteTemplate(w, "room", userState)
// return // return
// } // }
userState := models.MakeTestState() // userState := models.MakeTestState()
userState, _ := getStateByCtx(r.Context())
tmpl.ExecuteTemplate(w, "base", userState) tmpl.ExecuteTemplate(w, "base", userState)
} }

View File

@@ -6,4 +6,5 @@ var (
CtxSessionKey = "session" CtxSessionKey = "session"
// cache // cache
CacheRoomPrefix = "room#" CacheRoomPrefix = "room#"
CacheStatePrefix = "state-"
) )