2024-09-12 05:07:55 +02:00
|
|
|
package handlers
|
|
|
|
|
|
|
|
import (
|
2025-01-10 15:04:23 +01:00
|
|
|
"context"
|
|
|
|
"fmt"
|
|
|
|
|
|
|
|
"git.defalsify.org/vise.git/asm"
|
2024-09-13 15:02:04 +02:00
|
|
|
"git.defalsify.org/vise.git/db"
|
2025-01-10 15:04:23 +01:00
|
|
|
"git.defalsify.org/vise.git/state"
|
|
|
|
"git.defalsify.org/vise.git/cache"
|
2024-09-12 05:07:55 +02:00
|
|
|
"git.defalsify.org/vise.git/engine"
|
|
|
|
"git.defalsify.org/vise.git/persist"
|
2024-09-13 15:02:04 +02:00
|
|
|
"git.defalsify.org/vise.git/resource"
|
2025-01-05 12:17:58 +01:00
|
|
|
"git.defalsify.org/vise.git/logging"
|
2024-09-12 05:07:55 +02:00
|
|
|
|
2025-01-10 11:53:27 +01:00
|
|
|
"git.grassecon.net/grassrootseconomics/visedriver/request"
|
|
|
|
"git.grassecon.net/grassrootseconomics/visedriver/errors"
|
2025-01-10 15:04:23 +01:00
|
|
|
dbstorage "git.grassecon.net/grassrootseconomics/visedriver/storage/db"
|
|
|
|
"git.grassecon.net/grassrootseconomics/visedriver/common"
|
2025-01-10 11:53:27 +01:00
|
|
|
"git.grassecon.net/grassrootseconomics/visedriver/storage"
|
2025-01-10 15:04:23 +01:00
|
|
|
"git.grassecon.net/grassrootseconomics/visedriver/remote"
|
|
|
|
"git.grassecon.net/grassrootseconomics/visedriver/models"
|
|
|
|
"git.grassecon.net/grassrootseconomics/visedriver/utils"
|
2024-09-12 05:07:55 +02:00
|
|
|
)
|
|
|
|
|
2025-01-05 12:17:58 +01:00
|
|
|
var (
|
|
|
|
logg = logging.NewVanilla().WithDomain("handlers")
|
|
|
|
)
|
|
|
|
|
2025-01-10 13:03:37 +01:00
|
|
|
type Handlers struct {
|
|
|
|
pe *persist.Persister
|
|
|
|
st *state.State
|
|
|
|
ca cache.Memory
|
|
|
|
userdataStore common.DataStore
|
|
|
|
adminstore *utils.AdminStore
|
|
|
|
flagManager *asm.FlagParser
|
|
|
|
accountService remote.AccountServiceInterface
|
|
|
|
prefixDb dbstorage.PrefixDb
|
|
|
|
profile *models.Profile
|
|
|
|
ReplaceSeparatorFunc func(string) string
|
|
|
|
}
|
|
|
|
|
2025-01-10 15:04:23 +01:00
|
|
|
// NewHandlers creates a new instance of the Handlers struct with the provided dependencies.
|
|
|
|
func NewHandlers(appFlags *asm.FlagParser, userdataStore db.Db, adminstore *utils.AdminStore, accountService remote.AccountServiceInterface, replaceSeparatorFunc func(string) string) (*Handlers, error) {
|
|
|
|
if userdataStore == nil {
|
|
|
|
return nil, fmt.Errorf("cannot create handler with nil userdata store")
|
|
|
|
}
|
|
|
|
userDb := &common.UserDataStore{
|
|
|
|
Db: userdataStore,
|
|
|
|
}
|
|
|
|
|
|
|
|
// Instantiate the SubPrefixDb with "DATATYPE_USERDATA" prefix
|
|
|
|
prefix := common.ToBytes(db.DATATYPE_USERDATA)
|
|
|
|
prefixDb := dbstorage.NewSubPrefixDb(userdataStore, prefix)
|
|
|
|
|
|
|
|
h := &Handlers{
|
|
|
|
userdataStore: userDb,
|
|
|
|
flagManager: appFlags,
|
|
|
|
adminstore: adminstore,
|
|
|
|
accountService: accountService,
|
|
|
|
prefixDb: prefixDb,
|
|
|
|
profile: &models.Profile{Max: 6},
|
|
|
|
ReplaceSeparatorFunc: replaceSeparatorFunc,
|
|
|
|
}
|
|
|
|
return h, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (h *Handlers) Exit() {
|
|
|
|
h.pe = nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (h *Handlers) Init(ctx context.Context, sym string, input []byte) (resource.Result, error) {
|
|
|
|
return resource.Result{}, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// WithPersister sets persister instance to the handlers.
|
|
|
|
func (h *Handlers) WithPersister(pe *persist.Persister) *Handlers {
|
|
|
|
if h.pe != nil {
|
|
|
|
panic("persister already set")
|
|
|
|
}
|
|
|
|
h.pe = pe
|
|
|
|
return h
|
|
|
|
}
|
2024-09-12 05:07:55 +02:00
|
|
|
type BaseSessionHandler struct {
|
|
|
|
cfgTemplate engine.Config
|
2025-01-04 23:27:46 +01:00
|
|
|
rp request.RequestParser
|
2024-09-12 05:07:55 +02:00
|
|
|
rs resource.Resource
|
2025-01-10 13:03:37 +01:00
|
|
|
hn *Handlers
|
2024-09-12 05:07:55 +02:00
|
|
|
provider storage.StorageProvider
|
|
|
|
}
|
|
|
|
|
2025-01-10 15:04:23 +01:00
|
|
|
func NewBaseSessionHandler(cfg engine.Config, rs resource.Resource, stateDb db.Db, userdataDb db.Db, rp request.RequestParser, hn *Handlers) *BaseSessionHandler {
|
2024-09-12 05:07:55 +02:00
|
|
|
return &BaseSessionHandler{
|
|
|
|
cfgTemplate: cfg,
|
2025-01-08 13:34:08 +01:00
|
|
|
rs: rs,
|
|
|
|
hn: hn,
|
|
|
|
rp: rp,
|
|
|
|
provider: storage.NewSimpleStorageProvider(stateDb, userdataDb),
|
2024-09-12 05:07:55 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2025-01-08 13:34:08 +01:00
|
|
|
func (f *BaseSessionHandler) Shutdown() {
|
2024-09-12 05:07:55 +02:00
|
|
|
err := f.provider.Close()
|
|
|
|
if err != nil {
|
|
|
|
logg.Errorf("handler shutdown error", "err", err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2025-01-08 13:34:08 +01:00
|
|
|
func (f *BaseSessionHandler) GetEngine(cfg engine.Config, rs resource.Resource, pr *persist.Persister) engine.Engine {
|
2024-09-12 05:07:55 +02:00
|
|
|
en := engine.NewEngine(cfg, rs)
|
|
|
|
en = en.WithPersister(pr)
|
|
|
|
return en
|
|
|
|
}
|
|
|
|
|
2025-01-04 23:27:46 +01:00
|
|
|
func(f *BaseSessionHandler) Process(rqs request.RequestSession) (request.RequestSession, error) {
|
2024-09-12 05:07:55 +02:00
|
|
|
var r bool
|
|
|
|
var err error
|
|
|
|
var ok bool
|
2025-01-08 13:34:08 +01:00
|
|
|
|
2024-09-23 18:35:17 +02:00
|
|
|
logg.InfoCtxf(rqs.Ctx, "new request", "data", rqs)
|
2024-09-12 05:07:55 +02:00
|
|
|
|
|
|
|
rqs.Storage, err = f.provider.Get(rqs.Config.SessionId)
|
|
|
|
if err != nil {
|
2024-09-12 17:46:11 +02:00
|
|
|
logg.ErrorCtxf(rqs.Ctx, "", "storage get error", err)
|
2025-01-05 12:17:58 +01:00
|
|
|
return rqs, errors.ErrStorage
|
2024-09-12 05:07:55 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
f.hn = f.hn.WithPersister(rqs.Storage.Persister)
|
2024-12-03 17:16:46 +01:00
|
|
|
defer func() {
|
|
|
|
f.hn.Exit()
|
|
|
|
}()
|
2024-09-12 05:07:55 +02:00
|
|
|
eni := f.GetEngine(rqs.Config, f.rs, rqs.Storage.Persister)
|
|
|
|
en, ok := eni.(*engine.DefaultEngine)
|
|
|
|
if !ok {
|
2024-09-12 17:46:11 +02:00
|
|
|
perr := f.provider.Put(rqs.Config.SessionId, rqs.Storage)
|
|
|
|
rqs.Storage = nil
|
|
|
|
if perr != nil {
|
|
|
|
logg.ErrorCtxf(rqs.Ctx, "", "storage put error", perr)
|
|
|
|
}
|
2025-01-05 12:17:58 +01:00
|
|
|
return rqs, errors.ErrEngineType
|
2024-09-12 05:07:55 +02:00
|
|
|
}
|
|
|
|
en = en.WithFirst(f.hn.Init)
|
|
|
|
if rqs.Config.EngineDebug {
|
|
|
|
en = en.WithDebug(nil)
|
|
|
|
}
|
|
|
|
rqs.Engine = en
|
|
|
|
|
2024-09-20 12:13:20 +02:00
|
|
|
r, err = rqs.Engine.Exec(rqs.Ctx, rqs.Input)
|
2024-09-12 05:07:55 +02:00
|
|
|
if err != nil {
|
2024-09-12 17:46:11 +02:00
|
|
|
perr := f.provider.Put(rqs.Config.SessionId, rqs.Storage)
|
|
|
|
rqs.Storage = nil
|
|
|
|
if perr != nil {
|
|
|
|
logg.ErrorCtxf(rqs.Ctx, "", "storage put error", perr)
|
|
|
|
}
|
2024-09-12 05:07:55 +02:00
|
|
|
return rqs, err
|
|
|
|
}
|
|
|
|
|
2025-01-08 13:34:08 +01:00
|
|
|
rqs.Continue = r
|
2024-09-12 05:07:55 +02:00
|
|
|
return rqs, nil
|
|
|
|
}
|
|
|
|
|
2025-01-04 23:27:46 +01:00
|
|
|
func(f *BaseSessionHandler) Output(rqs request.RequestSession) (request.RequestSession, error) {
|
2024-09-12 05:07:55 +02:00
|
|
|
var err error
|
2024-09-20 21:15:24 +02:00
|
|
|
_, err = rqs.Engine.Flush(rqs.Ctx, rqs.Writer)
|
2024-09-12 05:07:55 +02:00
|
|
|
return rqs, err
|
|
|
|
}
|
|
|
|
|
2025-01-04 23:27:46 +01:00
|
|
|
func(f *BaseSessionHandler) Reset(rqs request.RequestSession) (request.RequestSession, error) {
|
2024-09-12 05:07:55 +02:00
|
|
|
defer f.provider.Put(rqs.Config.SessionId, rqs.Storage)
|
|
|
|
return rqs, rqs.Engine.Finish()
|
|
|
|
}
|
|
|
|
|
2025-01-08 13:34:08 +01:00
|
|
|
func (f *BaseSessionHandler) GetConfig() engine.Config {
|
2024-09-12 05:07:55 +02:00
|
|
|
return f.cfgTemplate
|
|
|
|
}
|
|
|
|
|
2025-01-04 23:27:46 +01:00
|
|
|
func(f *BaseSessionHandler) GetRequestParser() request.RequestParser {
|
2024-09-12 05:07:55 +02:00
|
|
|
return f.rp
|
|
|
|
}
|