Modify handlers to replace package "pages" with "web"

This commit is contained in:
Melon 2024-12-02 00:40:19 +00:00
parent ba858c19bd
commit 611cb5c6d5
Signed by: melon
GPG Key ID: 6C9D970C50D26A25
11 changed files with 32 additions and 35 deletions

View File

@ -8,9 +8,9 @@ import (
"github.com/1f349/lavender/conf" "github.com/1f349/lavender/conf"
"github.com/1f349/lavender/database" "github.com/1f349/lavender/database"
"github.com/1f349/lavender/logger" "github.com/1f349/lavender/logger"
"github.com/1f349/lavender/pages"
"github.com/1f349/lavender/role" "github.com/1f349/lavender/role"
"github.com/1f349/lavender/server" "github.com/1f349/lavender/server"
"github.com/1f349/lavender/web"
"github.com/1f349/mjwt" "github.com/1f349/mjwt"
"github.com/charmbracelet/log" "github.com/charmbracelet/log"
"github.com/cloudflare/tableflip" "github.com/cloudflare/tableflip"
@ -121,7 +121,7 @@ func (s *serveCmd) Execute(_ context.Context, _ *flag.FlagSet, _ ...interface{})
logger.Logger.Fatal("Failed to add initial user", "err", err) logger.Logger.Fatal("Failed to add initial user", "err", err)
} }
if err := pages.LoadPages(wd); err != nil { if err := web.LoadPages(wd); err != nil {
logger.Logger.Fatal("Failed to load page templates:", err) logger.Logger.Fatal("Failed to load page templates:", err)
} }

View File

@ -5,7 +5,7 @@ import (
auth2 "github.com/1f349/lavender/auth" auth2 "github.com/1f349/lavender/auth"
"github.com/1f349/lavender/database" "github.com/1f349/lavender/database"
"github.com/1f349/lavender/lists" "github.com/1f349/lavender/lists"
"github.com/1f349/lavender/pages" "github.com/1f349/lavender/web"
"github.com/google/uuid" "github.com/google/uuid"
"github.com/julienschmidt/httprouter" "github.com/julienschmidt/httprouter"
"net/http" "net/http"
@ -35,7 +35,7 @@ func (h *httpServer) EditGet(rw http.ResponseWriter, req *http.Request, _ httpro
Secure: true, Secure: true,
SameSite: http.SameSiteLaxMode, SameSite: http.SameSiteLaxMode,
}) })
pages.RenderPageTemplate(rw, "edit", map[string]any{ web.RenderPageTemplate(rw, "edit", map[string]any{
"ServiceName": h.conf.ServiceName, "ServiceName": h.conf.ServiceName,
"User": user, "User": user,
"Nonce": lNonce, "Nonce": lNonce,

View File

@ -3,8 +3,8 @@ package server
import ( import (
auth2 "github.com/1f349/lavender/auth" auth2 "github.com/1f349/lavender/auth"
"github.com/1f349/lavender/database" "github.com/1f349/lavender/database"
"github.com/1f349/lavender/pages"
"github.com/1f349/lavender/role" "github.com/1f349/lavender/role"
"github.com/1f349/lavender/web"
"github.com/google/uuid" "github.com/google/uuid"
"github.com/julienschmidt/httprouter" "github.com/julienschmidt/httprouter"
"net/http" "net/http"
@ -24,7 +24,7 @@ func (h *httpServer) Home(rw http.ResponseWriter, req *http.Request, _ httproute
}) })
if auth.IsGuest() { if auth.IsGuest() {
pages.RenderPageTemplate(rw, "index-guest", map[string]any{ web.RenderPageTemplate(rw, "index-guest", map[string]any{
"ServiceName": h.conf.ServiceName, "ServiceName": h.conf.ServiceName,
}) })
return return
@ -37,7 +37,7 @@ func (h *httpServer) Home(rw http.ResponseWriter, req *http.Request, _ httproute
return nil return nil
}) })
pages.RenderPageTemplate(rw, "index", map[string]any{ web.RenderPageTemplate(rw, "index", map[string]any{
"ServiceName": h.conf.ServiceName, "ServiceName": h.conf.ServiceName,
"Auth": auth, "Auth": auth,
"Nonce": lNonce, "Nonce": lNonce,

View File

@ -10,7 +10,7 @@ import (
"github.com/1f349/lavender/database" "github.com/1f349/lavender/database"
"github.com/1f349/lavender/database/types" "github.com/1f349/lavender/database/types"
"github.com/1f349/lavender/issuer" "github.com/1f349/lavender/issuer"
"github.com/1f349/lavender/pages" "github.com/1f349/lavender/web"
"github.com/1f349/mjwt" "github.com/1f349/mjwt"
"github.com/1f349/mjwt/auth" "github.com/1f349/mjwt/auth"
"github.com/golang-jwt/jwt/v4" "github.com/golang-jwt/jwt/v4"
@ -78,7 +78,7 @@ func (h *httpServer) loginGet(rw http.ResponseWriter, req *http.Request, _ httpr
fmt.Printf("%#v\n", h.testAuthSources(req, userPtr, auth2.FactorFirst)) fmt.Printf("%#v\n", h.testAuthSources(req, userPtr, auth2.FactorFirst))
pages.RenderPageTemplate(rw, "login-memory", map[string]any{ web.RenderPageTemplate(rw, "login-memory", map[string]any{
"ServiceName": h.conf.ServiceName, "ServiceName": h.conf.ServiceName,
"LoginName": cookie.Value, "LoginName": cookie.Value,
"Redirect": req.URL.Query().Get("redirect"), "Redirect": req.URL.Query().Get("redirect"),
@ -89,7 +89,7 @@ func (h *httpServer) loginGet(rw http.ResponseWriter, req *http.Request, _ httpr
} }
// render different page sources // render different page sources
pages.RenderPageTemplate(rw, "login", map[string]any{ web.RenderPageTemplate(rw, "login", map[string]any{
"ServiceName": h.conf.ServiceName, "ServiceName": h.conf.ServiceName,
"LoginName": "", "LoginName": "",
"Redirect": req.URL.Query().Get("redirect"), "Redirect": req.URL.Query().Get("redirect"),

View File

@ -2,7 +2,7 @@ package server
import ( import (
"github.com/1f349/lavender/database" "github.com/1f349/lavender/database"
"github.com/1f349/lavender/pages" "github.com/1f349/lavender/web"
"github.com/emersion/go-message/mail" "github.com/emersion/go-message/mail"
"github.com/julienschmidt/httprouter" "github.com/julienschmidt/httprouter"
"net/http" "net/http"
@ -39,7 +39,7 @@ func (h *httpServer) MailPassword(rw http.ResponseWriter, _ *http.Request, param
return return
} }
pages.RenderPageTemplate(rw, "reset-password", map[string]any{ web.RenderPageTemplate(rw, "reset-password", map[string]any{
"ServiceName": h.conf.ServiceName, "ServiceName": h.conf.ServiceName,
"Code": code, "Code": code,
}) })

View File

@ -3,9 +3,9 @@ package server
import ( import (
auth2 "github.com/1f349/lavender/auth" auth2 "github.com/1f349/lavender/auth"
"github.com/1f349/lavender/database" "github.com/1f349/lavender/database"
"github.com/1f349/lavender/pages"
"github.com/1f349/lavender/password" "github.com/1f349/lavender/password"
"github.com/1f349/lavender/role" "github.com/1f349/lavender/role"
"github.com/1f349/lavender/web"
"github.com/google/uuid" "github.com/google/uuid"
"github.com/julienschmidt/httprouter" "github.com/julienschmidt/httprouter"
"net/http" "net/http"
@ -54,7 +54,7 @@ func (h *httpServer) ManageAppsGet(rw http.ResponseWriter, req *http.Request, _
m["EditApp"] = i m["EditApp"] = i
rw.Header().Set("Content-Type", "text/html") rw.Header().Set("Content-Type", "text/html")
rw.WriteHeader(http.StatusOK) rw.WriteHeader(http.StatusOK)
pages.RenderPageTemplate(rw, "manage-apps-edit", m) web.RenderPageTemplate(rw, "manage-apps-edit", m)
return return
} }
} }
@ -64,7 +64,7 @@ func (h *httpServer) ManageAppsGet(rw http.ResponseWriter, req *http.Request, _
rw.Header().Set("Content-Type", "text/html") rw.Header().Set("Content-Type", "text/html")
rw.WriteHeader(http.StatusOK) rw.WriteHeader(http.StatusOK)
pages.RenderPageTemplate(rw, "manage-apps", m) web.RenderPageTemplate(rw, "manage-apps", m)
} }
func (h *httpServer) ManageAppsCreateGet(rw http.ResponseWriter, req *http.Request, _ httprouter.Params, auth auth2.UserAuth) { func (h *httpServer) ManageAppsCreateGet(rw http.ResponseWriter, req *http.Request, _ httprouter.Params, auth auth2.UserAuth) {
@ -83,7 +83,7 @@ func (h *httpServer) ManageAppsCreateGet(rw http.ResponseWriter, req *http.Reque
rw.Header().Set("Content-Type", "text/html") rw.Header().Set("Content-Type", "text/html")
rw.WriteHeader(http.StatusOK) rw.WriteHeader(http.StatusOK)
pages.RenderPageTemplate(rw, "manage-apps-create", m) web.RenderPageTemplate(rw, "manage-apps-create", m)
} }
func (h *httpServer) ManageAppsPost(rw http.ResponseWriter, req *http.Request, _ httprouter.Params, auth auth2.UserAuth) { func (h *httpServer) ManageAppsPost(rw http.ResponseWriter, req *http.Request, _ httprouter.Params, auth auth2.UserAuth) {

View File

@ -3,8 +3,8 @@ package server
import ( import (
auth2 "github.com/1f349/lavender/auth" auth2 "github.com/1f349/lavender/auth"
"github.com/1f349/lavender/database" "github.com/1f349/lavender/database"
"github.com/1f349/lavender/pages"
"github.com/1f349/lavender/role" "github.com/1f349/lavender/role"
"github.com/1f349/lavender/web"
"github.com/julienschmidt/httprouter" "github.com/julienschmidt/httprouter"
"golang.org/x/sync/errgroup" "golang.org/x/sync/errgroup"
"net/http" "net/http"
@ -51,7 +51,7 @@ func (h *httpServer) ManageUsersGet(rw http.ResponseWriter, req *http.Request, _
m["EditUser"] = i m["EditUser"] = i
rw.Header().Set("Content-Type", "text/html") rw.Header().Set("Content-Type", "text/html")
rw.WriteHeader(http.StatusOK) rw.WriteHeader(http.StatusOK)
pages.RenderPageTemplate(rw, "manage-users-edit", m) web.RenderPageTemplate(rw, "manage-users-edit", m)
return return
} }
} }
@ -61,7 +61,7 @@ func (h *httpServer) ManageUsersGet(rw http.ResponseWriter, req *http.Request, _
rw.Header().Set("Content-Type", "text/html") rw.Header().Set("Content-Type", "text/html")
rw.WriteHeader(http.StatusOK) rw.WriteHeader(http.StatusOK)
pages.RenderPageTemplate(rw, "manage-users", m) web.RenderPageTemplate(rw, "manage-users", m)
} }
func (h *httpServer) ManageUsersPost(rw http.ResponseWriter, req *http.Request, _ httprouter.Params, auth auth2.UserAuth) { func (h *httpServer) ManageUsersPost(rw http.ResponseWriter, req *http.Request, _ httprouter.Params, auth auth2.UserAuth) {

View File

@ -7,9 +7,9 @@ import (
clientStore "github.com/1f349/lavender/client-store" clientStore "github.com/1f349/lavender/client-store"
"github.com/1f349/lavender/database" "github.com/1f349/lavender/database"
"github.com/1f349/lavender/logger" "github.com/1f349/lavender/logger"
"github.com/1f349/lavender/pages"
"github.com/1f349/lavender/scope" "github.com/1f349/lavender/scope"
"github.com/1f349/lavender/utils" "github.com/1f349/lavender/utils"
"github.com/1f349/lavender/web"
"github.com/1f349/mjwt" "github.com/1f349/mjwt"
"github.com/go-oauth2/oauth2/v4" "github.com/go-oauth2/oauth2/v4"
"github.com/go-oauth2/oauth2/v4/errors" "github.com/go-oauth2/oauth2/v4/errors"
@ -232,7 +232,7 @@ func (h *httpServer) authorizeEndpoint(rw http.ResponseWriter, req *http.Request
} }
rw.WriteHeader(http.StatusOK) rw.WriteHeader(http.StatusOK)
pages.RenderPageTemplate(rw, "oauth-authorize", map[string]any{ web.RenderPageTemplate(rw, "oauth-authorize", map[string]any{
"ServiceName": h.conf.ServiceName, "ServiceName": h.conf.ServiceName,
"AppName": appName, "AppName": appName,
"AppDomain": appDomain, "AppDomain": appDomain,

View File

@ -5,7 +5,7 @@ import (
"encoding/base64" "encoding/base64"
auth2 "github.com/1f349/lavender/auth" auth2 "github.com/1f349/lavender/auth"
"github.com/1f349/lavender/database" "github.com/1f349/lavender/database"
"github.com/1f349/lavender/pages" "github.com/1f349/lavender/web"
"github.com/julienschmidt/httprouter" "github.com/julienschmidt/httprouter"
"github.com/skip2/go-qrcode" "github.com/skip2/go-qrcode"
"github.com/xlzd/gotp" "github.com/xlzd/gotp"
@ -19,7 +19,7 @@ func (h *httpServer) editOtpPost(rw http.ResponseWriter, req *http.Request, _ ht
if req.Method == http.MethodPost && req.FormValue("remove") == "1" { if req.Method == http.MethodPost && req.FormValue("remove") == "1" {
if !req.Form.Has("code") { if !req.Form.Has("code") {
// render page // render page
pages.RenderPageTemplate(rw, "remove-otp", map[string]any{ web.RenderPageTemplate(rw, "remove-otp", map[string]any{
"ServiceName": h.conf.ServiceName, "ServiceName": h.conf.ServiceName,
}) })
return return
@ -95,7 +95,7 @@ func (h *httpServer) editOtpPost(rw http.ResponseWriter, req *http.Request, _ ht
} }
// render page // render page
pages.RenderPageTemplate(rw, "edit-otp", map[string]any{ web.RenderPageTemplate(rw, "edit-otp", map[string]any{
"ServiceName": h.conf.ServiceName, "ServiceName": h.conf.ServiceName,
"OtpQr": template.URL("data:qrImg/png;base64," + base64.StdEncoding.EncodeToString(qrBuf.Bytes())), "OtpQr": template.URL("data:qrImg/png;base64," + base64.StdEncoding.EncodeToString(qrBuf.Bytes())),
"QrWidth": qrWidth, "QrWidth": qrWidth,

View File

@ -8,16 +8,14 @@ import (
"github.com/1f349/lavender/database" "github.com/1f349/lavender/database"
"github.com/1f349/lavender/issuer" "github.com/1f349/lavender/issuer"
"github.com/1f349/lavender/logger" "github.com/1f349/lavender/logger"
"github.com/1f349/lavender/pages" "github.com/1f349/lavender/web"
"github.com/1f349/mjwt" "github.com/1f349/mjwt"
"github.com/go-oauth2/oauth2/v4/manage" "github.com/go-oauth2/oauth2/v4/manage"
"github.com/go-oauth2/oauth2/v4/server" "github.com/go-oauth2/oauth2/v4/server"
"github.com/julienschmidt/httprouter" "github.com/julienschmidt/httprouter"
"net/http" "net/http"
"net/url" "net/url"
"path"
"strings" "strings"
"time"
) )
var errInvalidScope = errors.New("missing required scope") var errInvalidScope = errors.New("missing required scope")
@ -58,8 +56,6 @@ func SetupRouter(r *httprouter.Router, config conf.Conf, db *database.Queries, s
// remove last slash from baseUrl // remove last slash from baseUrl
config.BaseUrl = strings.TrimRight(config.BaseUrl, "/") config.BaseUrl = strings.TrimRight(config.BaseUrl, "/")
contentCache := time.Now()
authBasic := &auth.BasicLogin{DB: db} authBasic := &auth.BasicLogin{DB: db}
authOtp := &auth.OtpLogin{DB: db} authOtp := &auth.OtpLogin{DB: db}
authOAuth := &auth.OAuthLogin{DB: db, BaseUrl: config.BaseUrl} authOAuth := &auth.OAuthLogin{DB: db, BaseUrl: config.BaseUrl}
@ -101,8 +97,7 @@ func SetupRouter(r *httprouter.Router, config conf.Conf, db *database.Queries, s
http.Error(rw, http.StatusText(http.StatusBadRequest), http.StatusBadRequest) http.Error(rw, http.StatusText(http.StatusBadRequest), http.StatusBadRequest)
return return
} }
out := pages.RenderCss(path.Join("assets", name)) web.RenderWebAsset(rw, req, name)
http.ServeContent(rw, req, path.Base(name), contentCache, out)
}) })
// login steps // login steps

View File

@ -58,13 +58,15 @@ func RenderPageTemplate(wr io.Writer, name string, data any) {
} }
} }
func RenderWebAsset(rw http.ResponseWriter, req *http.Request) { func RenderWebAsset(rw http.ResponseWriter, req *http.Request, name string) {
name := req.URL.Path
// Disallow paths containing ".." - directory traversal is a security issue. // Disallow paths containing ".." - directory traversal is a security issue.
if containsDotDot(name) {
http.Error(rw, "400 Bad Request", http.StatusBadRequest)
}
// Disallow paths ending in ".html" - these should only be processed by HTML // Disallow paths ending in ".html" - these should only be processed by HTML
// template. // template.
if containsDotDot(name) || strings.HasSuffix(name, ".html") { if strings.HasSuffix(name, ".html") {
http.Error(rw, "404 Not Found", http.StatusNotFound) http.Error(rw, "404 Not Found", http.StatusNotFound)
return return
} }