123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566 |
- package router
- import (
- "encoding/base64"
- "github.com/0xJacky/Nginx-UI/frontend"
- "github.com/0xJacky/Nginx-UI/server/model"
- "github.com/gin-contrib/static"
- "github.com/gin-gonic/gin"
- "io/fs"
- "log"
- "net/http"
- "path"
- )
- func authRequired() gin.HandlerFunc {
- return func(c *gin.Context) {
- token := c.GetHeader("Authorization")
- if token == "" {
- tmp, _ := base64.StdEncoding.DecodeString(c.Query("token"))
- token = string(tmp)
- if token == "" {
- c.JSON(http.StatusForbidden, gin.H{
- "message": "auth fail",
- })
- c.Abort()
- return
- }
- }
- n := model.CheckToken(token)
- if n < 1 {
- c.JSON(http.StatusForbidden, gin.H{
- "message": "auth fail",
- })
- c.Abort()
- return
- }
- c.Next()
- }
- }
- type serverFileSystemType struct {
- http.FileSystem
- }
- func (f serverFileSystemType) Exists(prefix string, _path string) bool {
- _, err := f.Open(path.Join(prefix, _path))
- return err == nil
- }
- func mustFS(dir string) (serverFileSystem static.ServeFileSystem) {
- sub, err := fs.Sub(frontend.DistFS, path.Join("dist", dir))
- if err != nil {
- log.Println(err)
- return
- }
- serverFileSystem = serverFileSystemType{
- http.FS(sub),
- }
- return
- }
|