Used a modified TailwindCLI with DaisyUI

This commit is contained in:
2024-01-28 17:51:56 -07:00
parent d9b0bc44fb
commit bd28ff5324
11 changed files with 28 additions and 65 deletions

43
main.go
View File

@ -1,14 +1,8 @@
package main
import (
"crypto/sha256"
"encoding/hex"
"log"
"net/http"
"os"
"path/filepath"
"strings"
"time"
"github.com/joho/godotenv"
"github.com/labstack/echo/v4"
@ -25,9 +19,6 @@ func main() {
// Initialize Echo router
e := echo.New()
// Generate a unique version identifier
version := time.Now().Format(time.RFC3339)
// Middleware
e.Use(middleware.Logger())
e.Use(middleware.Recover())
@ -39,40 +30,6 @@ func main() {
Level: 5,
}))
e.Use(middleware.RateLimiter(middleware.NewRateLimiterMemoryStore(50)))
// Use middleware to set ETag and Cache-Control headers
e.Use(func(next echo.HandlerFunc) echo.HandlerFunc {
return func(c echo.Context) error {
// Get the path of the requested resource
path := c.Request().URL.Path
// If the requested resource is a CSS file
if strings.HasSuffix(path, ".css") {
log.Println(path)
// Read the CSS file
data, err := os.ReadFile(filepath.Join("public", strings.TrimPrefix(path, "/public")))
if err != nil {
// Log the error and return a 500 status
log.Println(err)
return c.NoContent(http.StatusInternalServerError)
}
// Compute the hash of the CSS file contents
hash := sha256.Sum256(data)
// Set the ETag to the hash
c.Response().Header().Set("ETag", hex.EncodeToString(hash[:]))
// Set the Content-Type to text/css
c.Response().Header().Set("Content-Type", "text/css")
} else {
// For other resources, set the ETag to the server start time
c.Response().Header().Set("ETag", version)
}
c.Response().Header().Set("Cache-Control", "public, no-cache")
return next(c)
}
})
// Static server
e.Static("/public", "public")