add.go 2.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118
  1. package config
  2. import (
  3. "net/http"
  4. "net/url"
  5. "os"
  6. "path/filepath"
  7. "time"
  8. "github.com/0xJacky/Nginx-UI/internal/config"
  9. "github.com/0xJacky/Nginx-UI/internal/helper"
  10. "github.com/0xJacky/Nginx-UI/internal/nginx"
  11. "github.com/0xJacky/Nginx-UI/model"
  12. "github.com/0xJacky/Nginx-UI/query"
  13. "github.com/gin-gonic/gin"
  14. "github.com/sashabaranov/go-openai"
  15. "github.com/uozi-tech/cosy"
  16. )
  17. func AddConfig(c *gin.Context) {
  18. var json struct {
  19. config.SyncConfigPayload
  20. SyncNodeIds []uint64 `json:"sync_node_ids"`
  21. }
  22. if !cosy.BindAndValid(c, &json) {
  23. return
  24. }
  25. name := json.Name
  26. content := json.Content
  27. // Decode paths from URL encoding
  28. decodedBaseDir, err := url.QueryUnescape(json.BaseDir)
  29. if err != nil {
  30. cosy.ErrHandler(c, err)
  31. return
  32. }
  33. decodedName, err := url.QueryUnescape(name)
  34. if err != nil {
  35. cosy.ErrHandler(c, err)
  36. return
  37. }
  38. dir := nginx.GetConfPath(decodedBaseDir)
  39. path := filepath.Join(dir, decodedName)
  40. if !helper.IsUnderDirectory(path, nginx.GetConfPath()) {
  41. c.JSON(http.StatusForbidden, gin.H{
  42. "message": "filepath is not under the nginx conf path",
  43. })
  44. return
  45. }
  46. if !json.Overwrite && helper.FileExists(path) {
  47. c.JSON(http.StatusNotAcceptable, gin.H{
  48. "message": "File exists",
  49. })
  50. return
  51. }
  52. // check if the dir exists, if not, use mkdirAll to create the dir
  53. if !helper.FileExists(dir) {
  54. err := os.MkdirAll(dir, 0755)
  55. if err != nil {
  56. cosy.ErrHandler(c, err)
  57. return
  58. }
  59. }
  60. err = os.WriteFile(path, []byte(content), 0644)
  61. if err != nil {
  62. cosy.ErrHandler(c, err)
  63. return
  64. }
  65. output := nginx.Reload()
  66. if nginx.GetLogLevel(output) >= nginx.Warn {
  67. c.JSON(http.StatusInternalServerError, gin.H{
  68. "message": output,
  69. })
  70. return
  71. }
  72. q := query.Config
  73. _, err = q.Where(q.Filepath.Eq(path)).Delete()
  74. if err != nil {
  75. cosy.ErrHandler(c, err)
  76. return
  77. }
  78. cfg := &model.Config{
  79. Name: name,
  80. Filepath: path,
  81. SyncNodeIds: json.SyncNodeIds,
  82. SyncOverwrite: json.Overwrite,
  83. }
  84. err = q.Create(cfg)
  85. if err != nil {
  86. cosy.ErrHandler(c, err)
  87. return
  88. }
  89. err = config.SyncToRemoteServer(cfg)
  90. if err != nil {
  91. cosy.ErrHandler(c, err)
  92. return
  93. }
  94. c.JSON(http.StatusOK, config.Config{
  95. Name: name,
  96. Content: content,
  97. ChatGPTMessages: make([]openai.ChatCompletionMessage, 0),
  98. FilePath: path,
  99. ModifiedAt: time.Now(),
  100. })
  101. }