diff options
author | Mo Tarbin <mhed.t91@gmail.com> | 2024-07-24 00:44:33 -0400 |
---|---|---|
committer | Mo Tarbin <mhed.t91@gmail.com> | 2024-07-24 00:44:33 -0400 |
commit | 066ef5e5519b47438c669013278f0e5f8e190878 (patch) | |
tree | ee80ea21c22db693a770f8955faf004671967ce8 /frontend | |
parent | 10d1528e276a6608e34394a6e88b84b5dfb9fbed (diff) | |
parent | 62246fc5f7f6b913edcf0da23c1cc78586b60a75 (diff) | |
download | donetick-066ef5e5519b47438c669013278f0e5f8e190878.tar.gz donetick-066ef5e5519b47438c669013278f0e5f8e190878.tar.bz2 donetick-066ef5e5519b47438c669013278f0e5f8e190878.zip |
Merge branch 'dev'
Diffstat (limited to '')
-rw-r--r-- | frontend/handler.go | 48 |
1 files changed, 48 insertions, 0 deletions
diff --git a/frontend/handler.go b/frontend/handler.go new file mode 100644 index 0000000..1a5337e --- /dev/null +++ b/frontend/handler.go @@ -0,0 +1,48 @@ +package frontend + +import ( + "embed" + "io/fs" + "net/http" + + "github.com/gin-gonic/gin" +) + +//go:embed dist +var embeddedFiles embed.FS + +type Handler struct { +} + +func NewHandler() *Handler { + return &Handler{} +} + +func Routes(router *gin.Engine, h *Handler) { + + router.Use(staticMiddleware("dist")) + router.Static("/assets", "dist/assets") + + // Gzip compression middleware + router.Group("/assets").Use(func(c *gin.Context) { + c.Header("Cache-Control", "max-age=31536000, immutable") + c.Next() + }) + +} + +func staticMiddleware(root string) gin.HandlerFunc { + fileServer := http.FileServer(getFileSystem(root)) + + return func(c *gin.Context) { + fileServer.ServeHTTP(c.Writer, c.Request) + } +} + +func getFileSystem(path string) http.FileSystem { + fs, err := fs.Sub(embeddedFiles, path) + if err != nil { + panic(err) + } + return http.FS(fs) +} |