Upgraded to Fiber v3
This commit is contained in:
parent
cb45f6aa53
commit
fdd2ecc7fc
|
@ -3,31 +3,30 @@ package handlers
|
||||||
import (
|
import (
|
||||||
"encoding/json"
|
"encoding/json"
|
||||||
"errors"
|
"errors"
|
||||||
"github.com/gofiber/fiber/v2"
|
"github.com/gofiber/fiber/v3"
|
||||||
"lmika.dev/lmika/hugo-cms/models"
|
"lmika.dev/lmika/hugo-cms/models"
|
||||||
"lmika.dev/lmika/hugo-cms/services/users"
|
"lmika.dev/lmika/hugo-cms/services/users"
|
||||||
"net/http"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
type AuthHandler struct {
|
type AuthHandler struct {
|
||||||
UserService *users.Service
|
UserService *users.Service
|
||||||
}
|
}
|
||||||
|
|
||||||
func (h *AuthHandler) ShowLogin(c *fiber.Ctx) error {
|
func (h *AuthHandler) ShowLogin(c fiber.Ctx) error {
|
||||||
return c.Render("auth/login", fiber.Map{}, "layouts/login")
|
return c.Render("auth/login", fiber.Map{}, "layouts/login")
|
||||||
}
|
}
|
||||||
|
|
||||||
func (h *AuthHandler) Login(c *fiber.Ctx) error {
|
func (h *AuthHandler) Login(c fiber.Ctx) error {
|
||||||
var req struct {
|
var req struct {
|
||||||
Email string `form:"email"`
|
Email string `form:"email"`
|
||||||
Password string `form:"password"`
|
Password string `form:"password"`
|
||||||
}
|
}
|
||||||
|
|
||||||
if err := c.BodyParser(&req); err != nil {
|
if err := c.Bind().Body(&req); err != nil {
|
||||||
return errors.New("invalid email or password")
|
return errors.New("invalid email or password")
|
||||||
}
|
}
|
||||||
|
|
||||||
user, err := h.UserService.VerifyLogin(c.UserContext(), req.Email, req.Password)
|
user, err := h.UserService.VerifyLogin(c.Context(), req.Email, req.Password)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return errors.New("invalid email or password")
|
return errors.New("invalid email or password")
|
||||||
}
|
}
|
||||||
|
@ -41,20 +40,20 @@ func (h *AuthHandler) Login(c *fiber.Ctx) error {
|
||||||
Name: models.AuthCookieName,
|
Name: models.AuthCookieName,
|
||||||
Value: string(bts),
|
Value: string(bts),
|
||||||
})
|
})
|
||||||
return c.Redirect("/", http.StatusFound)
|
return c.Redirect().To("/")
|
||||||
}
|
}
|
||||||
|
|
||||||
func (h *AuthHandler) RequireAuth(c *fiber.Ctx) error {
|
func (h *AuthHandler) RequireAuth(c fiber.Ctx) error {
|
||||||
user, err := h.readAuthCookie(c)
|
user, err := h.readAuthCookie(c)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return c.Redirect("/auth/login", http.StatusFound)
|
return c.Redirect().To("/auth/login")
|
||||||
}
|
}
|
||||||
|
|
||||||
c.Locals("user", user)
|
c.Locals("user", user)
|
||||||
return c.Next()
|
return c.Next()
|
||||||
}
|
}
|
||||||
|
|
||||||
func (h *AuthHandler) readAuthCookie(c *fiber.Ctx) (user models.User, err error) {
|
func (h *AuthHandler) readAuthCookie(c fiber.Ctx) (user models.User, err error) {
|
||||||
authData := c.Cookies(models.AuthCookieName)
|
authData := c.Cookies(models.AuthCookieName)
|
||||||
if authData == "" {
|
if authData == "" {
|
||||||
return models.User{}, errors.New("no auth cookie")
|
return models.User{}, errors.New("no auth cookie")
|
||||||
|
@ -65,5 +64,5 @@ func (h *AuthHandler) readAuthCookie(c *fiber.Ctx) (user models.User, err error)
|
||||||
return models.User{}, err
|
return models.User{}, err
|
||||||
}
|
}
|
||||||
|
|
||||||
return h.UserService.GetUserByID(c.UserContext(), ac.UserID)
|
return h.UserService.GetUserByID(c.Context(), ac.UserID)
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,35 +2,26 @@ package handlers
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"encoding/json"
|
"encoding/json"
|
||||||
"errors"
|
"github.com/gofiber/fiber/v3"
|
||||||
"github.com/gofiber/fiber/v2"
|
|
||||||
"lmika.dev/lmika/hugo-cms/models"
|
"lmika.dev/lmika/hugo-cms/models"
|
||||||
"log"
|
"log"
|
||||||
)
|
)
|
||||||
|
|
||||||
func GetUser(c *fiber.Ctx) models.User {
|
func GetUser(c fiber.Ctx) models.User {
|
||||||
u, ok := c.Locals("user").(models.User)
|
return fiber.Locals[models.User](c, "user")
|
||||||
if !ok {
|
|
||||||
panic(errors.New("user not found in context"))
|
|
||||||
}
|
|
||||||
return u
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func GetSite(c *fiber.Ctx) models.Site {
|
func GetSite(c fiber.Ctx) models.Site {
|
||||||
s, ok := c.Locals("site").(models.Site)
|
return fiber.Locals[models.Site](c, "site")
|
||||||
if !ok {
|
|
||||||
panic(errors.New("no site in context"))
|
|
||||||
}
|
|
||||||
return s
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func UpdatePrefCookie(c *fiber.Ctx, update func(prefs *models.PrefCookie)) {
|
func UpdatePrefCookie(c fiber.Ctx, update func(prefs *models.PrefCookie)) {
|
||||||
cookie := GetPrefCookie(c)
|
cookie := GetPrefCookie(c)
|
||||||
update(&cookie)
|
update(&cookie)
|
||||||
setPrefCookie(c, cookie)
|
setPrefCookie(c, cookie)
|
||||||
}
|
}
|
||||||
|
|
||||||
func GetPrefCookie(c *fiber.Ctx) models.PrefCookie {
|
func GetPrefCookie(c fiber.Ctx) models.PrefCookie {
|
||||||
prefCookieValue := c.Cookies(models.PrefCookieName)
|
prefCookieValue := c.Cookies(models.PrefCookieName)
|
||||||
if prefCookieValue == "" {
|
if prefCookieValue == "" {
|
||||||
return models.PrefCookie{}
|
return models.PrefCookie{}
|
||||||
|
@ -45,7 +36,7 @@ func GetPrefCookie(c *fiber.Ctx) models.PrefCookie {
|
||||||
return prefCookie
|
return prefCookie
|
||||||
}
|
}
|
||||||
|
|
||||||
func setPrefCookie(c *fiber.Ctx, prefCookie models.PrefCookie) {
|
func setPrefCookie(c fiber.Ctx, prefCookie models.PrefCookie) {
|
||||||
if prefJson, err := json.Marshal(prefCookie); err == nil {
|
if prefJson, err := json.Marshal(prefCookie); err == nil {
|
||||||
c.Cookie(&fiber.Cookie{
|
c.Cookie(&fiber.Cookie{
|
||||||
Name: models.PrefCookieName,
|
Name: models.PrefCookieName,
|
||||||
|
|
|
@ -2,17 +2,16 @@ package handlers
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
"github.com/gofiber/fiber/v2"
|
"github.com/gofiber/fiber/v3"
|
||||||
"net/http"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
type IndexHandler struct {
|
type IndexHandler struct {
|
||||||
}
|
}
|
||||||
|
|
||||||
func (h IndexHandler) Index(c *fiber.Ctx) error {
|
func (h IndexHandler) Index(c fiber.Ctx) error {
|
||||||
prefs := GetPrefCookie(c)
|
prefs := GetPrefCookie(c)
|
||||||
if prefs.SiteID > 0 {
|
if prefs.SiteID > 0 {
|
||||||
return c.Redirect(fmt.Sprintf("/sites/%v/posts", prefs.SiteID), http.StatusFound)
|
return c.Redirect().To(fmt.Sprintf("/sites/%v/posts", prefs.SiteID))
|
||||||
}
|
}
|
||||||
|
|
||||||
return c.Render("index", fiber.Map{}, "layouts/main")
|
return c.Render("index", fiber.Map{}, "layouts/main")
|
||||||
|
|
|
@ -1,33 +1,33 @@
|
||||||
package handlers
|
package handlers
|
||||||
|
|
||||||
import "github.com/gofiber/fiber/v2"
|
import "github.com/gofiber/fiber/v3"
|
||||||
|
|
||||||
type mimeTypeHandler interface {
|
type mimeTypeHandler interface {
|
||||||
CanHandle(c *fiber.Ctx) bool
|
CanHandle(c fiber.Ctx) bool
|
||||||
Handle(c *fiber.Ctx) error
|
Handle(c fiber.Ctx) error
|
||||||
}
|
}
|
||||||
|
|
||||||
type HTMX func(c *fiber.Ctx) error
|
type HTMX func(c fiber.Ctx) error
|
||||||
|
|
||||||
func (h HTMX) CanHandle(c *fiber.Ctx) bool {
|
func (h HTMX) CanHandle(c fiber.Ctx) bool {
|
||||||
return c.Get("Hx-request") == "true"
|
return c.Get("Hx-request") == "true"
|
||||||
}
|
}
|
||||||
|
|
||||||
func (h HTMX) Handle(c *fiber.Ctx) error {
|
func (h HTMX) Handle(c fiber.Ctx) error {
|
||||||
return h(c)
|
return h(c)
|
||||||
}
|
}
|
||||||
|
|
||||||
type Otherwise func(c *fiber.Ctx) error
|
type Otherwise func(c fiber.Ctx) error
|
||||||
|
|
||||||
func (h Otherwise) CanHandle(c *fiber.Ctx) bool {
|
func (h Otherwise) CanHandle(c fiber.Ctx) bool {
|
||||||
return true
|
return true
|
||||||
}
|
}
|
||||||
|
|
||||||
func (h Otherwise) Handle(c *fiber.Ctx) error {
|
func (h Otherwise) Handle(c fiber.Ctx) error {
|
||||||
return h(c)
|
return h(c)
|
||||||
}
|
}
|
||||||
|
|
||||||
func Select(c *fiber.Ctx, mimeTypes ...mimeTypeHandler) error {
|
func Select(c fiber.Ctx, mimeTypes ...mimeTypeHandler) error {
|
||||||
for _, mt := range mimeTypes {
|
for _, mt := range mimeTypes {
|
||||||
if mt.CanHandle(c) {
|
if mt.CanHandle(c) {
|
||||||
return mt.Handle(c)
|
return mt.Handle(c)
|
||||||
|
|
|
@ -1,8 +1,9 @@
|
||||||
package handlers
|
package handlers
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"errors"
|
||||||
"fmt"
|
"fmt"
|
||||||
"github.com/gofiber/fiber/v2"
|
"github.com/gofiber/fiber/v3"
|
||||||
"lmika.dev/lmika/hugo-cms/models"
|
"lmika.dev/lmika/hugo-cms/models"
|
||||||
"lmika.dev/lmika/hugo-cms/services/posts"
|
"lmika.dev/lmika/hugo-cms/services/posts"
|
||||||
"net/http"
|
"net/http"
|
||||||
|
@ -12,10 +13,10 @@ type Post struct {
|
||||||
Post *posts.Service
|
Post *posts.Service
|
||||||
}
|
}
|
||||||
|
|
||||||
func (h *Post) Posts(c *fiber.Ctx) error {
|
func (h *Post) Posts(c fiber.Ctx) error {
|
||||||
site := GetSite(c)
|
site := GetSite(c)
|
||||||
|
|
||||||
posts, err := h.Post.ListPostOfSite(c.UserContext(), site)
|
posts, err := h.Post.ListPostOfSite(c.Context(), site)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
@ -25,24 +26,24 @@ func (h *Post) Posts(c *fiber.Ctx) error {
|
||||||
}, "layouts/site")
|
}, "layouts/site")
|
||||||
}
|
}
|
||||||
|
|
||||||
func (h *Post) New(c *fiber.Ctx) error {
|
func (h *Post) New(c fiber.Ctx) error {
|
||||||
return c.Render("posts/new", fiber.Map{
|
return c.Render("posts/new", fiber.Map{
|
||||||
"post": models.Post{},
|
"post": models.Post{},
|
||||||
}, "layouts/site")
|
}, "layouts/site")
|
||||||
}
|
}
|
||||||
|
|
||||||
func (h *Post) Create(c *fiber.Ctx) error {
|
func (h *Post) Create(c fiber.Ctx) error {
|
||||||
site := GetSite(c)
|
site := GetSite(c)
|
||||||
|
|
||||||
var req struct {
|
var req struct {
|
||||||
Title string `json:"title" form:"title"`
|
Title string `json:"title" form:"title"`
|
||||||
Body string `json:"body" form:"body"`
|
Body string `json:"body" form:"body"`
|
||||||
}
|
}
|
||||||
if err := c.BodyParser(&req); err != nil {
|
if err := c.Bind().Body(&req); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
_, err := h.Post.Create(c.UserContext(), site, posts.NewPost{
|
_, err := h.Post.Create(c.Context(), site, posts.NewPost{
|
||||||
Title: req.Title,
|
Title: req.Title,
|
||||||
Body: req.Body,
|
Body: req.Body,
|
||||||
})
|
})
|
||||||
|
@ -50,18 +51,18 @@ func (h *Post) Create(c *fiber.Ctx) error {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
return c.Redirect(fmt.Sprintf("/sites/%v/posts", site.ID))
|
return c.Redirect().To(fmt.Sprintf("/sites/%v/posts", site.ID))
|
||||||
}
|
}
|
||||||
|
|
||||||
func (h *Post) Edit(c *fiber.Ctx) error {
|
func (h *Post) Edit(c fiber.Ctx) error {
|
||||||
site := GetSite(c)
|
site := GetSite(c)
|
||||||
|
|
||||||
postID, err := c.ParamsInt("postId")
|
postID := fiber.Params[int](c, "postId")
|
||||||
if err != nil {
|
if postID == 0 {
|
||||||
return err
|
return errors.New("postId is required")
|
||||||
}
|
}
|
||||||
|
|
||||||
post, err := h.Post.GetPost(c.UserContext(), postID)
|
post, err := h.Post.GetPost(c.Context(), postID)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
} else if post.SiteID != site.ID {
|
} else if post.SiteID != site.ID {
|
||||||
|
@ -73,23 +74,23 @@ func (h *Post) Edit(c *fiber.Ctx) error {
|
||||||
}, "layouts/site")
|
}, "layouts/site")
|
||||||
}
|
}
|
||||||
|
|
||||||
func (h *Post) Update(c *fiber.Ctx) error {
|
func (h *Post) Update(c fiber.Ctx) error {
|
||||||
site := GetSite(c)
|
site := GetSite(c)
|
||||||
|
|
||||||
postID, err := c.ParamsInt("postId")
|
postID := fiber.Params[int](c, "postId")
|
||||||
if err != nil {
|
if postID == 0 {
|
||||||
return err
|
return errors.New("postId is required")
|
||||||
}
|
}
|
||||||
|
|
||||||
var req struct {
|
var req struct {
|
||||||
Title string `json:"title" form:"title"`
|
Title string `json:"title" form:"title"`
|
||||||
Body string `json:"body" form:"body"`
|
Body string `json:"body" form:"body"`
|
||||||
}
|
}
|
||||||
if err := c.BodyParser(&req); err != nil {
|
if err := c.Bind().Body(&req); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
post, err := h.Post.GetPost(c.UserContext(), postID)
|
post, err := h.Post.GetPost(c.Context(), postID)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
} else if post.SiteID != site.ID {
|
} else if post.SiteID != site.ID {
|
||||||
|
@ -99,31 +100,31 @@ func (h *Post) Update(c *fiber.Ctx) error {
|
||||||
post.Title = req.Title
|
post.Title = req.Title
|
||||||
post.Body = req.Body
|
post.Body = req.Body
|
||||||
|
|
||||||
if err := h.Post.Save(c.UserContext(), site, &post); err != nil {
|
if err := h.Post.Save(c.Context(), site, &post); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
return c.Redirect(fmt.Sprintf("/sites/%v/posts", site.ID))
|
return c.Redirect().To(fmt.Sprintf("/sites/%v/posts", site.ID))
|
||||||
}
|
}
|
||||||
|
|
||||||
func (h *Post) Delete(c *fiber.Ctx) error {
|
func (h *Post) Delete(c fiber.Ctx) error {
|
||||||
site := GetSite(c)
|
site := GetSite(c)
|
||||||
|
|
||||||
postID, err := c.ParamsInt("postId")
|
postID := fiber.Params[int](c, "postId")
|
||||||
if err != nil {
|
if postID == 0 {
|
||||||
return err
|
return errors.New("postId is required")
|
||||||
}
|
}
|
||||||
|
|
||||||
if err := h.Post.DeletePost(c.UserContext(), site, postID); err != nil {
|
if err := h.Post.DeletePost(c.Context(), site, postID); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
return Select(c,
|
return Select(c,
|
||||||
HTMX(func(c *fiber.Ctx) error {
|
HTMX(func(c fiber.Ctx) error {
|
||||||
return c.Status(http.StatusOK).SendString("")
|
return c.Status(http.StatusOK).SendString("")
|
||||||
}),
|
}),
|
||||||
Otherwise(func(c *fiber.Ctx) error {
|
Otherwise(func(c fiber.Ctx) error {
|
||||||
return c.Redirect(fmt.Sprintf("/sites/%v/posts", site.ID), http.StatusSeeOther)
|
return c.Redirect().To(fmt.Sprintf("/sites/%v/posts", site.ID))
|
||||||
}),
|
}),
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
|
@ -3,7 +3,7 @@ package handlers
|
||||||
import (
|
import (
|
||||||
"errors"
|
"errors"
|
||||||
"fmt"
|
"fmt"
|
||||||
"github.com/gofiber/fiber/v2"
|
"github.com/gofiber/fiber/v3"
|
||||||
"github.com/jackc/pgx/v5"
|
"github.com/jackc/pgx/v5"
|
||||||
"lmika.dev/lmika/hugo-cms/models"
|
"lmika.dev/lmika/hugo-cms/models"
|
||||||
"lmika.dev/lmika/hugo-cms/services/sites"
|
"lmika.dev/lmika/hugo-cms/services/sites"
|
||||||
|
@ -15,10 +15,10 @@ type Site struct {
|
||||||
Site *sites.Service
|
Site *sites.Service
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *Site) Create(c *fiber.Ctx) error {
|
func (s *Site) Create(c fiber.Ctx) error {
|
||||||
user := GetUser(c)
|
user := GetUser(c)
|
||||||
|
|
||||||
site, err := s.Site.CreateSite(c.UserContext(), user, "New Site "+time.Now().Format("2006-01-02 15:04:05"))
|
site, err := s.Site.CreateSite(c.Context(), user, "New Site "+time.Now().Format("2006-01-02 15:04:05"))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
@ -27,16 +27,16 @@ func (s *Site) Create(c *fiber.Ctx) error {
|
||||||
prefs.SiteID = site.ID
|
prefs.SiteID = site.ID
|
||||||
})
|
})
|
||||||
|
|
||||||
return c.Redirect(fmt.Sprintf("/sites/%v/posts", site.ID))
|
return c.Redirect().To(fmt.Sprintf("/sites/%v/posts", site.ID))
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *Site) Show(c *fiber.Ctx) error {
|
func (s *Site) Show(c fiber.Ctx) error {
|
||||||
id, err := c.ParamsInt("siteId")
|
id := fiber.Params[int](c, "siteId")
|
||||||
if err != nil {
|
if id == 0 {
|
||||||
return err
|
return errors.New("siteId is required")
|
||||||
}
|
}
|
||||||
|
|
||||||
site, err := s.Site.GetSite(c.UserContext(), id)
|
site, err := s.Site.GetSite(c.Context(), id)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
@ -46,17 +46,17 @@ func (s *Site) Show(c *fiber.Ctx) error {
|
||||||
}, "layouts/main")
|
}, "layouts/main")
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *Site) Settings(c *fiber.Ctx) error {
|
func (s *Site) Settings(c fiber.Ctx) error {
|
||||||
return c.Render("sites/settings", fiber.Map{
|
return c.Render("sites/settings", fiber.Map{
|
||||||
"themes": s.Site.Themes(),
|
"themes": s.Site.Themes(),
|
||||||
}, "layouts/site")
|
}, "layouts/site")
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *Site) SaveSettings(c *fiber.Ctx) error {
|
func (s *Site) SaveSettings(c fiber.Ctx) error {
|
||||||
site := GetSite(c)
|
site := GetSite(c)
|
||||||
|
|
||||||
var req sites.NewSettings
|
var req sites.NewSettings
|
||||||
if err := c.BodyParser(&req); err != nil {
|
if err := c.Bind().Body(&req); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -64,25 +64,25 @@ func (s *Site) SaveSettings(c *fiber.Ctx) error {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
return c.Redirect(fmt.Sprintf("/sites/%v/settings", site.ID))
|
return c.Redirect().To(fmt.Sprintf("/sites/%v/settings", site.ID))
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *Site) Rebuild(c *fiber.Ctx) error {
|
func (s *Site) Rebuild(c fiber.Ctx) error {
|
||||||
if err := s.Site.Rebuild(c.UserContext(), GetSite(c)); err != nil {
|
if err := s.Site.Rebuild(c.Context(), GetSite(c)); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
return c.Redirect(fmt.Sprintf("/sites/%v/posts", GetSite(c).ID))
|
return c.Redirect().To(fmt.Sprintf("/sites/%v/posts", GetSite(c).ID))
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *Site) WithSite() fiber.Handler {
|
func (s *Site) WithSite() fiber.Handler {
|
||||||
return func(c *fiber.Ctx) (err error) {
|
return func(c fiber.Ctx) (err error) {
|
||||||
id, err := c.ParamsInt("siteId")
|
id := fiber.Params[int](c, "siteId")
|
||||||
if err != nil {
|
if id == 0 {
|
||||||
return err
|
return errors.New("siteId is required")
|
||||||
}
|
}
|
||||||
|
|
||||||
site, err := s.Site.GetSite(c.UserContext(), id)
|
site, err := s.Site.GetSite(c.Context(), id)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
@ -94,7 +94,7 @@ func (s *Site) WithSite() fiber.Handler {
|
||||||
|
|
||||||
c.Locals("site", site)
|
c.Locals("site", site)
|
||||||
|
|
||||||
if prodTarget, err := s.Site.GetProdTargetOfSite(c.UserContext(), int(site.ID)); err == nil {
|
if prodTarget, err := s.Site.GetProdTargetOfSite(c.Context(), int(site.ID)); err == nil {
|
||||||
c.Locals("prodTarget", prodTarget)
|
c.Locals("prodTarget", prodTarget)
|
||||||
} else if !errors.Is(err, pgx.ErrNoRows) {
|
} else if !errors.Is(err, pgx.ErrNoRows) {
|
||||||
return err
|
return err
|
||||||
|
|
37
main.go
37
main.go
|
@ -5,9 +5,9 @@ import (
|
||||||
"context"
|
"context"
|
||||||
"flag"
|
"flag"
|
||||||
"fmt"
|
"fmt"
|
||||||
"github.com/gofiber/fiber/v2"
|
"github.com/gofiber/fiber/v3"
|
||||||
"github.com/gofiber/fiber/v2/middleware/encryptcookie"
|
"github.com/gofiber/fiber/v3/middleware/encryptcookie"
|
||||||
"github.com/gofiber/fiber/v2/middleware/filesystem"
|
"github.com/gofiber/fiber/v3/middleware/static"
|
||||||
"github.com/gofiber/template/html/v2"
|
"github.com/gofiber/template/html/v2"
|
||||||
"github.com/yuin/goldmark"
|
"github.com/yuin/goldmark"
|
||||||
"html/template"
|
"html/template"
|
||||||
|
@ -36,7 +36,7 @@ func main() {
|
||||||
flag.Parse()
|
flag.Parse()
|
||||||
|
|
||||||
if *flagGenKey {
|
if *flagGenKey {
|
||||||
fmt.Println(encryptcookie.GenerateKey())
|
fmt.Println(encryptcookie.GenerateKey(32))
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -100,7 +100,7 @@ func main() {
|
||||||
|
|
||||||
if cfg.EncryptedCookieKey == "" {
|
if cfg.EncryptedCookieKey == "" {
|
||||||
log.Println("No encrypt cookie key defined. Generating random key")
|
log.Println("No encrypt cookie key defined. Generating random key")
|
||||||
cfg.EncryptedCookieKey = encryptcookie.GenerateKey()
|
cfg.EncryptedCookieKey = encryptcookie.GenerateKey(32)
|
||||||
}
|
}
|
||||||
|
|
||||||
app := fiber.New(fiber.Config{
|
app := fiber.New(fiber.Config{
|
||||||
|
@ -109,7 +109,9 @@ func main() {
|
||||||
})
|
})
|
||||||
app.Use(encryptcookie.New(encryptcookie.Config{Key: cfg.EncryptedCookieKey}))
|
app.Use(encryptcookie.New(encryptcookie.Config{Key: cfg.EncryptedCookieKey}))
|
||||||
|
|
||||||
app.Use("/assets", filesystem.New(filesystem.Config{Root: http.FS(assets.FS)}))
|
app.Use("/assets", static.New("", static.Config{
|
||||||
|
FS: assets.FS,
|
||||||
|
}))
|
||||||
|
|
||||||
app.Get("/auth/login", authHandlers.ShowLogin)
|
app.Get("/auth/login", authHandlers.ShowLogin)
|
||||||
app.Post("/auth/login", authHandlers.Login)
|
app.Post("/auth/login", authHandlers.Login)
|
||||||
|
@ -119,20 +121,19 @@ func main() {
|
||||||
app.Post("/sites", siteHandlers.Create)
|
app.Post("/sites", siteHandlers.Create)
|
||||||
app.Get("/sites/:siteId", siteHandlers.Show)
|
app.Get("/sites/:siteId", siteHandlers.Show)
|
||||||
|
|
||||||
app.Route("/sites/:siteId", func(r fiber.Router) {
|
sr := app.Group("/sites/:siteId")
|
||||||
r.Use(siteHandlers.WithSite())
|
sr.Use(siteHandlers.WithSite())
|
||||||
r.Post("/rebuild", siteHandlers.Rebuild)
|
sr.Post("/rebuild", siteHandlers.Rebuild)
|
||||||
|
|
||||||
r.Get("/posts", postHandlers.Posts)
|
sr.Get("/posts", postHandlers.Posts)
|
||||||
r.Get("/posts/new", postHandlers.New)
|
sr.Get("/posts/new", postHandlers.New)
|
||||||
r.Post("/posts", postHandlers.Create)
|
sr.Post("/posts", postHandlers.Create)
|
||||||
r.Get("/posts/:postId", postHandlers.Edit)
|
sr.Get("/posts/:postId", postHandlers.Edit)
|
||||||
r.Post("/posts/:postId", postHandlers.Update)
|
sr.Post("/posts/:postId", postHandlers.Update)
|
||||||
r.Delete("/posts/:postId", postHandlers.Delete)
|
sr.Delete("/posts/:postId", postHandlers.Delete)
|
||||||
|
|
||||||
r.Get("/settings", siteHandlers.Settings)
|
sr.Get("/settings", siteHandlers.Settings)
|
||||||
r.Post("/settings", siteHandlers.SaveSettings)
|
sr.Post("/settings", siteHandlers.SaveSettings)
|
||||||
})
|
|
||||||
|
|
||||||
jobService.Start()
|
jobService.Start()
|
||||||
defer jobService.Stop()
|
defer jobService.Stop()
|
||||||
|
|
Loading…
Reference in a new issue