Skip to content

Commit

Permalink
fix: symbol links are not displayed in config list #272
Browse files Browse the repository at this point in the history
  • Loading branch information
0xJacky committed Feb 6, 2024
1 parent 371472e commit abe43c5
Show file tree
Hide file tree
Showing 3 changed files with 87 additions and 87 deletions.
89 changes: 45 additions & 44 deletions api/config/get.go
Original file line number Diff line number Diff line change
@@ -1,51 +1,52 @@
package config

import (
"github.com/0xJacky/Nginx-UI/api"
"github.com/0xJacky/Nginx-UI/internal/config"
"github.com/0xJacky/Nginx-UI/internal/nginx"
"github.com/0xJacky/Nginx-UI/query"
"github.com/gin-gonic/gin"
"github.com/sashabaranov/go-openai"
"net/http"
"os"
"github.com/0xJacky/Nginx-UI/api"
"github.com/0xJacky/Nginx-UI/internal/config"
"github.com/0xJacky/Nginx-UI/internal/nginx"
"github.com/0xJacky/Nginx-UI/query"
"github.com/gin-gonic/gin"
"github.com/sashabaranov/go-openai"
"net/http"
"os"
)

func GetConfig(c *gin.Context) {
name := c.Param("name")
path := nginx.GetConfPath("/", name)

stat, err := os.Stat(path)

if err != nil {
api.ErrHandler(c, err)
return
}

content, err := os.ReadFile(path)

if err != nil {
api.ErrHandler(c, err)
return
}

g := query.ChatGPTLog
chatgpt, err := g.Where(g.Name.Eq(path)).FirstOrCreate()

if err != nil {
api.ErrHandler(c, err)
return
}

if chatgpt.Content == nil {
chatgpt.Content = make([]openai.ChatCompletionMessage, 0)
}

c.JSON(http.StatusOK, config.Config{
Name: name,
Content: string(content),
ChatGPTMessages: chatgpt.Content,
FilePath: path,
ModifiedAt: stat.ModTime(),
})
name := c.Param("name")

path := nginx.GetConfPath("/", name)

stat, err := os.Stat(path)

if err != nil {
api.ErrHandler(c, err)
return
}

content, err := os.ReadFile(path)

if err != nil {
api.ErrHandler(c, err)
return
}

g := query.ChatGPTLog
chatgpt, err := g.Where(g.Name.Eq(path)).FirstOrCreate()

if err != nil {
api.ErrHandler(c, err)
return
}

if chatgpt.Content == nil {
chatgpt.Content = make([]openai.ChatCompletionMessage, 0)
}

c.JSON(http.StatusOK, config.Config{
Name: name,
Content: string(content),
ChatGPTMessages: chatgpt.Content,
FilePath: path,
ModifiedAt: stat.ModTime(),
})
}
4 changes: 2 additions & 2 deletions api/config/list.go
Original file line number Diff line number Diff line change
Expand Up @@ -35,7 +35,7 @@ func GetConfigs(c *gin.Context) {
}
case mode&os.ModeSymlink != 0: // is a symbol
var targetPath string
targetPath, err = os.Readlink(nginx.GetConfPath(file.Name()))
targetPath, err = os.Readlink(nginx.GetConfPath(dir, file.Name()))
if err != nil {
logger.Error("Read Symlink Error", targetPath, err)
continue
Expand All @@ -47,7 +47,7 @@ func GetConfigs(c *gin.Context) {
logger.Error("Stat Error", targetPath, err)
continue
}
// but target file is not a dir
// hide the file if it's target file is a directory
if targetInfo.IsDir() {
continue
}
Expand Down
81 changes: 40 additions & 41 deletions api/config/modify.go
Original file line number Diff line number Diff line change
@@ -1,51 +1,50 @@
package config

import (
"github.com/0xJacky/Nginx-UI/api"
"github.com/0xJacky/Nginx-UI/internal/nginx"
"github.com/gin-gonic/gin"
"net/http"
"os"
"github.com/0xJacky/Nginx-UI/api"
"github.com/0xJacky/Nginx-UI/internal/nginx"
"github.com/gin-gonic/gin"
"net/http"
"os"
)

type EditConfigJson struct {
Content string `json:"content" binding:"required"`
Content string `json:"content" binding:"required"`
}

func EditConfig(c *gin.Context) {
name := c.Param("name")
var request EditConfigJson
err := c.BindJSON(&request)
if err != nil {
api.ErrHandler(c, err)
return
}
path := nginx.GetConfPath("/", name)
content := request.Content

origContent, err := os.ReadFile(path)
if err != nil {
api.ErrHandler(c, err)
return
}

if content != "" && content != string(origContent) {
// model.CreateBackup(path)
err = os.WriteFile(path, []byte(content), 0644)
if err != nil {
api.ErrHandler(c, err)
return
}
}

output := nginx.Reload()

if nginx.GetLogLevel(output) >= nginx.Warn {
c.JSON(http.StatusInternalServerError, gin.H{
"message": output,
})
return
}

GetConfig(c)
name := c.Param("name")
var request EditConfigJson
err := c.BindJSON(&request)
if err != nil {
api.ErrHandler(c, err)
return
}
path := nginx.GetConfPath("/", name)
content := request.Content

origContent, err := os.ReadFile(path)
if err != nil {
api.ErrHandler(c, err)
return
}

if content != "" && content != string(origContent) {
err = os.WriteFile(path, []byte(content), 0644)
if err != nil {
api.ErrHandler(c, err)
return
}
}

output := nginx.Reload()

if nginx.GetLogLevel(output) >= nginx.Warn {
c.JSON(http.StatusInternalServerError, gin.H{
"message": output,
})
return
}

GetConfig(c)
}

0 comments on commit abe43c5

Please sign in to comment.