htmgo/main.go

50 lines
960 B
Go
Raw Normal View History

2024-01-22 15:22:16 +00:00
package main
import (
"github.com/gofiber/fiber/v2"
2024-09-11 00:52:18 +00:00
"github.com/google/uuid"
2024-09-11 17:31:40 +00:00
"log"
2024-01-22 15:22:16 +00:00
"mhtml/h"
2024-09-11 00:52:18 +00:00
"mhtml/pages"
"mhtml/partials/load"
2024-09-11 17:31:40 +00:00
"time"
2024-01-22 15:22:16 +00:00
)
func main() {
2024-09-11 00:52:18 +00:00
f := fiber.New()
f.Static("/js", "./js")
f.Use(func(ctx *fiber.Ctx) error {
if ctx.Cookies("mhtml-session") != "" {
return ctx.Next()
}
id := ctx.IP() + uuid.NewString()
ctx.Cookie(&fiber.Cookie{
Name: "mhtml-session",
Value: id,
SessionOnly: true,
})
return ctx.Next()
})
2024-01-22 15:22:16 +00:00
2024-09-11 17:31:40 +00:00
f.Use(func(ctx *fiber.Ctx) error {
if ctx.Path() == "/livereload" {
return ctx.Next()
}
now := time.Now()
err := ctx.Next()
duration := time.Since(now)
ctx.Set("X-Response-Time", duration.String())
// Log or print the request method, URL, and duration
2024-09-12 02:06:34 +00:00
log.Printf("Request: %s %s took %dms", ctx.Method(), ctx.OriginalURL(), duration.Milliseconds())
2024-09-11 17:31:40 +00:00
return err
})
load.RegisterPartials(f)
2024-09-11 00:52:18 +00:00
pages.RegisterPages(f)
2024-09-12 02:06:34 +00:00
2024-09-11 00:52:18 +00:00
h.Start(f, h.App{
LiveReload: true,
2024-01-22 15:22:16 +00:00
})
}