浏览代码

Merge remote-tracking branch 'origin/dev' into dev

Vanessa 9 月之前
父节点
当前提交
1f47be1a11
共有 3 个文件被更改,包括 94 次插入1 次删除
  1. 1 0
      kernel/api/router.go
  2. 92 0
      kernel/api/system.go
  3. 1 1
      kernel/model/conf.go

+ 1 - 0
kernel/api/router.go

@@ -62,6 +62,7 @@ func ServeAPI(ginServer *gin.Engine) {
 	ginServer.Handle("POST", "/api/system/exportLog", model.CheckAuth, model.CheckAdminRole, exportLog)
 	ginServer.Handle("POST", "/api/system/getChangelog", model.CheckAuth, getChangelog)
 	ginServer.Handle("POST", "/api/system/getNetwork", model.CheckAuth, model.CheckAdminRole, getNetwork)
+	ginServer.Handle("POST", "/api/system/exportConf", model.CheckAuth, model.CheckAdminRole, exportConf)
 
 	ginServer.Handle("POST", "/api/storage/setLocalStorage", model.CheckAuth, model.CheckAdminRole, model.CheckReadonly, setLocalStorage)
 	ginServer.Handle("POST", "/api/storage/getLocalStorage", model.CheckAuth, getLocalStorage)

+ 92 - 0
kernel/api/system.go

@@ -17,6 +17,7 @@
 package api
 
 import (
+	"github.com/jinzhu/copier"
 	"net/http"
 	"os"
 	"path/filepath"
@@ -206,6 +207,97 @@ func exportLog(c *gin.Context) {
 	}
 }
 
+func exportConf(c *gin.Context) {
+	ret := gulu.Ret.NewResult()
+	defer c.JSON(http.StatusOK, ret)
+
+	name := "siyuan-conf-" + time.Now().Format("20060102150405") + ".json"
+	tmpDir := filepath.Join(util.TempDir, "export")
+	if err := os.MkdirAll(tmpDir, 0755); err != nil {
+		logging.LogErrorf("export WebDAV provider failed: %s", err)
+		ret.Code = -1
+		ret.Msg = err.Error()
+		return
+	}
+
+	clonedConf := &model.AppConf{}
+	if err := copier.Copy(clonedConf, model.Conf); err != nil {
+		logging.LogErrorf("export conf failed: %s", err)
+		ret.Code = -1
+		ret.Msg = err.Error()
+		return
+	}
+
+	if nil != clonedConf.Editor {
+		clonedConf.Editor.Emoji = []string{}
+	}
+	if nil != clonedConf.Export {
+		clonedConf.Export.PandocBin = ""
+	}
+	clonedConf.UserData = ""
+	clonedConf.Account = nil
+	clonedConf.AccessAuthCode = ""
+	if nil != clonedConf.System {
+		clonedConf.System.ID = ""
+		clonedConf.System.Name = ""
+		clonedConf.System.OSPlatform = ""
+		clonedConf.System.Container = ""
+		clonedConf.System.IsMicrosoftStore = false
+		clonedConf.System.IsInsider = false
+	}
+	clonedConf.Sync = nil
+	clonedConf.Stat = nil
+	clonedConf.Api = nil
+	clonedConf.Repo = nil
+	clonedConf.Publish = nil
+	clonedConf.CloudRegion = 0
+	clonedConf.DataIndexState = 0
+
+	data, err := gulu.JSON.MarshalIndentJSON(clonedConf, "", "  ")
+	if err != nil {
+		logging.LogErrorf("export conf failed: %s", err)
+		ret.Code = -1
+		ret.Msg = err.Error()
+		return
+	}
+
+	tmp := filepath.Join(tmpDir, name)
+	if err = os.WriteFile(tmp, data, 0644); err != nil {
+		logging.LogErrorf("export conf failed: %s", err)
+		ret.Code = -1
+		ret.Msg = err.Error()
+		return
+	}
+
+	zipFile, err := gulu.Zip.Create(tmp + ".zip")
+	if err != nil {
+		logging.LogErrorf("export conf failed: %s", err)
+		ret.Code = -1
+		ret.Msg = err.Error()
+		return
+	}
+
+	if err = zipFile.AddEntry(name, tmp); err != nil {
+		logging.LogErrorf("export conf failed: %s", err)
+		ret.Code = -1
+		ret.Msg = err.Error()
+		return
+	}
+
+	if err = zipFile.Close(); err != nil {
+		logging.LogErrorf("export conf failed: %s", err)
+		ret.Code = -1
+		ret.Msg = err.Error()
+		return
+	}
+
+	zipPath := "/export/" + name + ".zip"
+	ret.Data = map[string]interface{}{
+		"name": name,
+		"zip":  zipPath,
+	}
+}
+
 func getConf(c *gin.Context) {
 	ret := gulu.Ret.NewResult()
 	defer c.JSON(http.StatusOK, ret)

+ 1 - 1
kernel/model/conf.go

@@ -19,7 +19,6 @@ package model
 import (
 	"bytes"
 	"fmt"
-	"github.com/siyuan-note/siyuan/kernel/task"
 	"os"
 	"path/filepath"
 	"runtime"
@@ -41,6 +40,7 @@ import (
 	"github.com/siyuan-note/logging"
 	"github.com/siyuan-note/siyuan/kernel/conf"
 	"github.com/siyuan-note/siyuan/kernel/sql"
+	"github.com/siyuan-note/siyuan/kernel/task"
 	"github.com/siyuan-note/siyuan/kernel/treenode"
 	"github.com/siyuan-note/siyuan/kernel/util"
 	"golang.org/x/mod/semver"