2024-09-06 01:40:57 +02:00
|
|
|
package http
|
|
|
|
|
|
|
|
import (
|
|
|
|
"net/http"
|
2024-09-12 04:30:23 +02:00
|
|
|
"strconv"
|
2024-09-06 01:40:57 +02:00
|
|
|
|
|
|
|
"git.defalsify.org/vise.git/logging"
|
2024-09-11 18:53:12 +02:00
|
|
|
|
2024-09-12 04:30:23 +02:00
|
|
|
"git.grassecon.net/urdt/ussd/internal/handlers"
|
2024-09-06 01:40:57 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
var (
|
2025-01-06 07:59:47 +01:00
|
|
|
logg = logging.NewVanilla().WithDomain("httpserver")
|
2024-09-06 01:40:57 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
type SessionHandler struct {
|
2024-09-12 05:07:55 +02:00
|
|
|
handlers.RequestHandler
|
2024-09-06 01:40:57 +02:00
|
|
|
}
|
|
|
|
|
2024-09-12 05:07:55 +02:00
|
|
|
func ToSessionHandler(h handlers.RequestHandler) *SessionHandler {
|
2024-09-06 01:40:57 +02:00
|
|
|
return &SessionHandler{
|
2024-09-12 05:07:55 +02:00
|
|
|
RequestHandler: h,
|
2024-09-06 01:40:57 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2025-01-04 08:29:22 +01:00
|
|
|
func (f *SessionHandler) WriteError(w http.ResponseWriter, code int, err error) {
|
2024-09-12 04:30:23 +02:00
|
|
|
s := err.Error()
|
|
|
|
w.Header().Set("Content-Length", strconv.Itoa(len(s)))
|
2024-09-06 01:40:57 +02:00
|
|
|
w.WriteHeader(code)
|
2024-12-11 16:58:50 +01:00
|
|
|
_, err = w.Write([]byte(s))
|
2024-09-06 01:40:57 +02:00
|
|
|
if err != nil {
|
2024-09-12 04:30:23 +02:00
|
|
|
logg.Errorf("error writing error!!", "err", err, "olderr", s)
|
2024-09-06 01:40:57 +02:00
|
|
|
w.WriteHeader(500)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-12-11 16:58:50 +01:00
|
|
|
func (f *SessionHandler) ServeHTTP(w http.ResponseWriter, req *http.Request) {
|
2024-09-12 04:30:23 +02:00
|
|
|
var code int
|
|
|
|
var err error
|
2024-09-12 17:46:11 +02:00
|
|
|
var perr error
|
2024-09-12 04:30:23 +02:00
|
|
|
|
|
|
|
rqs := handlers.RequestSession{
|
2024-12-11 16:58:50 +01:00
|
|
|
Ctx: req.Context(),
|
2024-09-12 04:30:23 +02:00
|
|
|
Writer: w,
|
2024-09-06 01:40:57 +02:00
|
|
|
}
|
|
|
|
|
2024-09-12 05:07:55 +02:00
|
|
|
rp := f.GetRequestParser()
|
|
|
|
cfg := f.GetConfig()
|
2025-01-06 06:52:53 +01:00
|
|
|
cfg.SessionId, err = rp.GetSessionId(req.Context(), req)
|
2024-09-06 01:40:57 +02:00
|
|
|
if err != nil {
|
2024-09-12 04:30:23 +02:00
|
|
|
logg.ErrorCtxf(rqs.Ctx, "", "header processing error", err)
|
2025-01-04 08:29:22 +01:00
|
|
|
f.WriteError(w, 400, err)
|
2024-09-12 04:30:23 +02:00
|
|
|
}
|
|
|
|
rqs.Config = cfg
|
2024-09-12 05:07:55 +02:00
|
|
|
rqs.Input, err = rp.GetInput(req)
|
2024-09-12 04:30:23 +02:00
|
|
|
if err != nil {
|
|
|
|
logg.ErrorCtxf(rqs.Ctx, "", "header processing error", err)
|
2025-01-04 08:29:22 +01:00
|
|
|
f.WriteError(w, 400, err)
|
2024-09-06 01:40:57 +02:00
|
|
|
return
|
|
|
|
}
|
2024-09-12 04:30:23 +02:00
|
|
|
|
|
|
|
rqs, err = f.Process(rqs)
|
|
|
|
switch err {
|
|
|
|
case handlers.ErrStorage:
|
|
|
|
code = 500
|
|
|
|
case handlers.ErrEngineInit:
|
|
|
|
code = 500
|
|
|
|
case handlers.ErrEngineExec:
|
|
|
|
code = 500
|
|
|
|
default:
|
|
|
|
code = 200
|
2024-09-06 01:40:57 +02:00
|
|
|
}
|
2024-09-12 04:30:23 +02:00
|
|
|
|
|
|
|
if code != 200 {
|
2025-01-04 08:29:22 +01:00
|
|
|
f.WriteError(w, 500, err)
|
2024-09-06 01:40:57 +02:00
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
w.WriteHeader(200)
|
|
|
|
w.Header().Set("Content-Type", "text/plain")
|
2024-09-12 05:07:55 +02:00
|
|
|
rqs, err = f.Output(rqs)
|
2024-09-12 17:46:11 +02:00
|
|
|
rqs, perr = f.Reset(rqs)
|
2024-09-06 01:40:57 +02:00
|
|
|
if err != nil {
|
2025-01-04 08:29:22 +01:00
|
|
|
f.WriteError(w, 500, err)
|
2024-09-06 01:40:57 +02:00
|
|
|
return
|
|
|
|
}
|
2024-09-12 17:46:11 +02:00
|
|
|
if perr != nil {
|
2025-01-04 08:29:22 +01:00
|
|
|
f.WriteError(w, 500, perr)
|
2024-09-06 01:40:57 +02:00
|
|
|
return
|
|
|
|
}
|
|
|
|
}
|