diff options
Diffstat (limited to '')
-rw-r--r-- | .goreleaser.yaml | 46 | ||||
-rw-r--r-- | frontend/handler.go | 48 |
2 files changed, 94 insertions, 0 deletions
diff --git a/.goreleaser.yaml b/.goreleaser.yaml new file mode 100644 index 0000000..3a008a5 --- /dev/null +++ b/.goreleaser.yaml @@ -0,0 +1,46 @@ +# This is an example .goreleaser.yml file with some sensible defaults. +# Make sure to check the documentation at https://goreleaser.com + +# The lines below are called `modelines`. See `:help modeline` +# Feel free to remove those if you don't want/need to use them. +# yaml-language-server: $schema=https://goreleaser.com/static/schema.json +# vim: set ts=2 sw=2 tw=0 fo=cnqoj + +version: 2 + +# before: +# hooks: +# # You may remove this if you don't use go modules. +# - go mod tidy +# # you may remove this if you don't need go generate +# - go generate ./... + +builds: + - env: + - CGO_ENABLED=0 + goos: + - linux + # - windows + # - darwin + +archives: + - format: tar.gz + # this name template makes the OS and Arch compatible with the results of `uname`. + name_template: >- + {{ .ProjectName }}_ + {{- title .Os }}_ + {{- if eq .Arch "amd64" }}x86_64 + {{- else if eq .Arch "386" }}i386 + {{- else }}{{ .Arch }}{{ end }} + {{- if .Arm }}v{{ .Arm }}{{ end }} + # use zip for windows archives + format_overrides: + - goos: windows + format: zip + +changelog: + sort: asc + filters: + exclude: + - "^docs:" + - "^test:" 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) +} |