delphi.market/server/router/middleware/session.go

56 lines
1.4 KiB
Go
Raw Normal View History

package middleware
import (
2024-07-12 13:30:41 +00:00
"database/sql"
"net/http"
"git.ekzyis.com/ekzyis/delphi.market/server/router/context"
2024-07-12 13:30:41 +00:00
"git.ekzyis.com/ekzyis/delphi.market/types"
"github.com/labstack/echo/v4"
)
2024-07-09 20:41:29 +00:00
func Session(sc context.Context) echo.MiddlewareFunc {
return func(next echo.HandlerFunc) echo.HandlerFunc {
return func(c echo.Context) error {
2024-07-12 13:30:41 +00:00
var (
db = sc.Db
ctx = c.Request().Context()
cookie *http.Cookie
err error
u = types.User{}
)
if cookie, err = c.Cookie("session"); err != nil {
// cookie not found
return next(c)
}
if err = db.QueryRowContext(
ctx,
""+
"SELECT u.id, u.name, u.created_at, COALESCE(u.ln_pubkey, ''), COALESCE(u.nostr_pubkey, ''), u.msats "+
2024-07-12 13:30:41 +00:00
"FROM sessions s LEFT JOIN users u ON u.id = s.user_id "+
"WHERE s.id = $1",
cookie.Value).
Scan(&u.Id, &u.Name, &u.CreatedAt, &u.LnPubkey, &u.NostrPubkey, &u.Msats); err == nil {
2024-07-12 13:30:41 +00:00
// session found
c.Set("session", u)
} else if err != sql.ErrNoRows {
return err
}
return next(c)
}
}
}
2024-07-09 20:41:29 +00:00
func SessionGuard(sc context.Context) echo.MiddlewareFunc {
return func(next echo.HandlerFunc) echo.HandlerFunc {
return func(c echo.Context) error {
session := c.Get("session")
if session == nil {
2024-07-14 10:57:40 +00:00
// this seems to work for non-interactive and htmx requests
2024-07-15 04:16:27 +00:00
return c.Redirect(http.StatusSeeOther, "/login")
}
return next(c)
}
}
}