modify.go 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121
  1. package config
  2. import (
  3. "net/http"
  4. "os"
  5. "path/filepath"
  6. "time"
  7. "github.com/0xJacky/Nginx-UI/internal/config"
  8. "github.com/0xJacky/Nginx-UI/internal/helper"
  9. "github.com/0xJacky/Nginx-UI/internal/nginx"
  10. "github.com/0xJacky/Nginx-UI/model"
  11. "github.com/0xJacky/Nginx-UI/query"
  12. "github.com/gin-gonic/gin"
  13. "github.com/sashabaranov/go-openai"
  14. "github.com/uozi-tech/cosy"
  15. "gorm.io/gen/field"
  16. )
  17. type EditConfigJson struct {
  18. Content string `json:"content" binding:"required"`
  19. }
  20. func EditConfig(c *gin.Context) {
  21. relativePath := c.Param("path")
  22. var json struct {
  23. Content string `json:"content"`
  24. SyncOverwrite bool `json:"sync_overwrite"`
  25. SyncNodeIds []uint64 `json:"sync_node_ids"`
  26. }
  27. if !cosy.BindAndValid(c, &json) {
  28. return
  29. }
  30. absPath := nginx.GetConfPath(relativePath)
  31. if !helper.FileExists(absPath) {
  32. c.JSON(http.StatusNotFound, gin.H{
  33. "message": "file not found",
  34. })
  35. return
  36. }
  37. content := json.Content
  38. origContent, err := os.ReadFile(absPath)
  39. if err != nil {
  40. cosy.ErrHandler(c, err)
  41. return
  42. }
  43. err = config.CheckAndCreateHistory(absPath, content)
  44. if err != nil {
  45. cosy.ErrHandler(c, err)
  46. return
  47. }
  48. if content != "" && content != string(origContent) {
  49. err = os.WriteFile(absPath, []byte(content), 0644)
  50. if err != nil {
  51. cosy.ErrHandler(c, err)
  52. return
  53. }
  54. }
  55. q := query.Config
  56. cfg, err := q.Assign(field.Attrs(&model.Config{
  57. Name: filepath.Base(absPath),
  58. })).Where(q.Filepath.Eq(absPath)).FirstOrCreate()
  59. if err != nil {
  60. cosy.ErrHandler(c, err)
  61. return
  62. }
  63. _, err = q.Where(q.Filepath.Eq(absPath)).
  64. Select(q.SyncNodeIds, q.SyncOverwrite).
  65. Updates(&model.Config{
  66. SyncNodeIds: json.SyncNodeIds,
  67. SyncOverwrite: json.SyncOverwrite,
  68. })
  69. if err != nil {
  70. cosy.ErrHandler(c, err)
  71. return
  72. }
  73. // use the new values
  74. cfg.SyncNodeIds = json.SyncNodeIds
  75. cfg.SyncOverwrite = json.SyncOverwrite
  76. g := query.ChatGPTLog
  77. err = config.SyncToRemoteServer(cfg)
  78. if err != nil {
  79. cosy.ErrHandler(c, err)
  80. return
  81. }
  82. output := nginx.Reload()
  83. if nginx.GetLogLevel(output) >= nginx.Warn {
  84. c.JSON(http.StatusInternalServerError, gin.H{
  85. "message": output,
  86. })
  87. return
  88. }
  89. chatgpt, err := g.Where(g.Name.Eq(absPath)).FirstOrCreate()
  90. if err != nil {
  91. cosy.ErrHandler(c, err)
  92. return
  93. }
  94. if chatgpt.Content == nil {
  95. chatgpt.Content = make([]openai.ChatCompletionMessage, 0)
  96. }
  97. c.JSON(http.StatusOK, config.Config{
  98. Name: filepath.Base(absPath),
  99. Content: content,
  100. ChatGPTMessages: chatgpt.Content,
  101. FilePath: absPath,
  102. ModifiedAt: time.Now(),
  103. Dir: filepath.Dir(relativePath),
  104. })
  105. }