🐛 工作空间列表中出现多个相同的路径 Fix https://github.com/siyuan-note/siyuan/issues/7061

This commit is contained in:
Liang Ding 2023-01-12 21:58:15 +08:00
parent 8468982005
commit ee72b848dd
No known key found for this signature in database
GPG key ID: 136F30F901A2231D
3 changed files with 66 additions and 89 deletions

View file

@ -17,7 +17,6 @@
package api package api
import ( import (
"errors"
"fmt" "fmt"
"net/http" "net/http"
"os" "os"
@ -29,7 +28,6 @@ import (
"github.com/88250/gulu" "github.com/88250/gulu"
"github.com/gin-gonic/gin" "github.com/gin-gonic/gin"
"github.com/gofrs/flock" "github.com/gofrs/flock"
"github.com/siyuan-note/logging"
"github.com/siyuan-note/siyuan/kernel/model" "github.com/siyuan-note/siyuan/kernel/model"
"github.com/siyuan-note/siyuan/kernel/util" "github.com/siyuan-note/siyuan/kernel/util"
) )
@ -64,7 +62,7 @@ func createWorkspaceDir(c *gin.Context) {
return return
} }
workspacePaths, err := readWorkspacePaths() workspacePaths, err := util.ReadWorkspacePaths()
if nil != err { if nil != err {
ret.Code = -1 ret.Code = -1
ret.Msg = err.Error() ret.Msg = err.Error()
@ -73,7 +71,7 @@ func createWorkspaceDir(c *gin.Context) {
workspacePaths = append(workspacePaths, absPath) workspacePaths = append(workspacePaths, absPath)
if err = writeWorkspacePaths(workspacePaths); nil != err { if err = util.WriteWorkspacePaths(workspacePaths); nil != err {
ret.Code = -1 ret.Code = -1
ret.Msg = err.Error() ret.Msg = err.Error()
return return
@ -91,7 +89,7 @@ func removeWorkspaceDir(c *gin.Context) {
path := arg["path"].(string) path := arg["path"].(string)
workspacePaths, err := readWorkspacePaths() workspacePaths, err := util.ReadWorkspacePaths()
if nil != err { if nil != err {
ret.Code = -1 ret.Code = -1
ret.Msg = err.Error() ret.Msg = err.Error()
@ -100,7 +98,7 @@ func removeWorkspaceDir(c *gin.Context) {
workspacePaths = gulu.Str.RemoveElem(workspacePaths, path) workspacePaths = gulu.Str.RemoveElem(workspacePaths, path)
if err = writeWorkspacePaths(workspacePaths); nil != err { if err = util.WriteWorkspacePaths(workspacePaths); nil != err {
ret.Code = -1 ret.Code = -1
ret.Msg = err.Error() ret.Msg = err.Error()
return return
@ -120,7 +118,7 @@ func getWorkspaces(c *gin.Context) {
ret := gulu.Ret.NewResult() ret := gulu.Ret.NewResult()
defer c.JSON(http.StatusOK, ret) defer c.JSON(http.StatusOK, ret)
workspacePaths, err := readWorkspacePaths() workspacePaths, err := util.ReadWorkspacePaths()
if nil != err { if nil != err {
ret.Code = -1 ret.Code = -1
ret.Msg = err.Error() ret.Msg = err.Error()
@ -169,7 +167,7 @@ func setWorkspaceDir(c *gin.Context) {
} }
} }
workspacePaths, err := readWorkspacePaths() workspacePaths, err := util.ReadWorkspacePaths()
if nil != err { if nil != err {
ret.Code = -1 ret.Code = -1
ret.Msg = err.Error() ret.Msg = err.Error()
@ -181,7 +179,7 @@ func setWorkspaceDir(c *gin.Context) {
workspacePaths = gulu.Str.RemoveElem(workspacePaths, path) workspacePaths = gulu.Str.RemoveElem(workspacePaths, path)
workspacePaths = append(workspacePaths, path) // 切换的工作空间固定放在最后一个 workspacePaths = append(workspacePaths, path) // 切换的工作空间固定放在最后一个
if err = writeWorkspacePaths(workspacePaths); nil != err { if err = util.WriteWorkspacePaths(workspacePaths); nil != err {
ret.Code = -1 ret.Code = -1
ret.Msg = err.Error() ret.Msg = err.Error()
return return
@ -194,45 +192,6 @@ func setWorkspaceDir(c *gin.Context) {
} }
} }
func readWorkspacePaths() (ret []string, err error) {
ret = []string{}
workspaceConf := filepath.Join(util.HomeDir, ".config", "siyuan", "workspace.json")
data, err := os.ReadFile(workspaceConf)
if nil != err {
msg := fmt.Sprintf("read workspace conf [%s] failed: %s", workspaceConf, err)
logging.LogErrorf(msg)
err = errors.New(msg)
return
}
if err = gulu.JSON.UnmarshalJSON(data, &ret); nil != err {
msg := fmt.Sprintf("unmarshal workspace conf [%s] failed: %s", workspaceConf, err)
logging.LogErrorf(msg)
err = errors.New(msg)
return
}
return
}
func writeWorkspacePaths(workspacePaths []string) (err error) {
workspaceConf := filepath.Join(util.HomeDir, ".config", "siyuan", "workspace.json")
data, err := gulu.JSON.MarshalJSON(workspacePaths)
if nil != err {
msg := fmt.Sprintf("marshal workspace conf [%s] failed: %s", workspaceConf, err)
logging.LogErrorf(msg)
err = errors.New(msg)
return
}
if err = os.WriteFile(workspaceConf, data, 0644); nil != err {
msg := fmt.Sprintf("write workspace conf [%s] failed: %s", workspaceConf, err)
logging.LogErrorf(msg)
err = errors.New(msg)
return
}
return
}
func isInvalidWorkspacePath(absPath string) bool { func isInvalidWorkspacePath(absPath string) bool {
if "" == absPath { if "" == absPath {
return true return true

View file

@ -18,7 +18,9 @@ package util
import ( import (
"bytes" "bytes"
"errors"
"flag" "flag"
"fmt"
"log" "log"
"math/rand" "math/rand"
"mime" "mime"
@ -216,20 +218,7 @@ func initWorkspaceDir(workspaceArg string) {
} }
workspacePaths = append(workspacePaths, WorkspaceDir) workspacePaths = append(workspacePaths, WorkspaceDir)
} else { } else {
data, err := os.ReadFile(workspaceConf) workspacePaths, _ = ReadWorkspacePaths()
if err = gulu.JSON.UnmarshalJSON(data, &workspacePaths); nil != err {
log.Printf("unmarshal workspace conf [%s] failed: %s", workspaceConf, err)
}
var tmp []string
for _, d := range workspacePaths {
d = strings.TrimRight(d, " \t\n") // 去掉工作空间路径尾部空格 https://github.com/siyuan-note/siyuan/issues/6353
if gulu.File.IsDir(d) {
tmp = append(tmp, d)
}
}
workspacePaths = tmp
if 0 < len(workspacePaths) { if 0 < len(workspacePaths) {
WorkspaceDir = workspacePaths[len(workspacePaths)-1] WorkspaceDir = workspacePaths[len(workspacePaths)-1]
if "" != workspaceArg { if "" != workspaceArg {
@ -253,12 +242,8 @@ func initWorkspaceDir(workspaceArg string) {
} }
} }
if data, err := gulu.JSON.MarshalJSON(workspacePaths); nil == err { if err := WriteWorkspacePaths(workspacePaths); nil != err {
if err = os.WriteFile(workspaceConf, data, 0644); nil != err { log.Fatalf("write workspace conf [%s] failed: %s", workspaceConf, err)
log.Fatalf("write workspace conf [%s] failed: %s", workspaceConf, err)
}
} else {
log.Fatalf("marshal workspace conf [%s] failed: %s", workspaceConf, err)
} }
ConfDir = filepath.Join(WorkspaceDir, "conf") ConfDir = filepath.Join(WorkspaceDir, "conf")
@ -281,6 +266,57 @@ func initWorkspaceDir(workspaceArg string) {
SnippetsPath = filepath.Join(DataDir, "snippets") SnippetsPath = filepath.Join(DataDir, "snippets")
} }
func ReadWorkspacePaths() (ret []string, err error) {
ret = []string{}
workspaceConf := filepath.Join(HomeDir, ".config", "siyuan", "workspace.json")
data, err := os.ReadFile(workspaceConf)
if nil != err {
msg := fmt.Sprintf("read workspace conf [%s] failed: %s", workspaceConf, err)
logging.LogErrorf(msg)
err = errors.New(msg)
return
}
if err = gulu.JSON.UnmarshalJSON(data, &ret); nil != err {
msg := fmt.Sprintf("unmarshal workspace conf [%s] failed: %s", workspaceConf, err)
logging.LogErrorf(msg)
err = errors.New(msg)
return
}
ret = gulu.Str.RemoveDuplicatedElem(ret)
var tmp []string
for _, d := range ret {
d = strings.TrimRight(d, " \t\n") // 去掉工作空间路径尾部空格 https://github.com/siyuan-note/siyuan/issues/6353
if gulu.File.IsDir(d) {
tmp = append(tmp, d)
}
}
ret = tmp
return
}
func WriteWorkspacePaths(workspacePaths []string) (err error) {
workspacePaths = gulu.Str.RemoveDuplicatedElem(workspacePaths)
workspaceConf := filepath.Join(HomeDir, ".config", "siyuan", "workspace.json")
data, err := gulu.JSON.MarshalJSON(workspacePaths)
if nil != err {
msg := fmt.Sprintf("marshal workspace conf [%s] failed: %s", workspaceConf, err)
logging.LogErrorf(msg)
err = errors.New(msg)
return
}
if err = os.WriteFile(workspaceConf, data, 0644); nil != err {
msg := fmt.Sprintf("write workspace conf [%s] failed: %s", workspaceConf, err)
logging.LogErrorf(msg)
err = errors.New(msg)
return
}
return
}
var ( var (
ServerPort = "0" // HTTP/WebSocket 端口0 为使用随机端口 ServerPort = "0" // HTTP/WebSocket 端口0 为使用随机端口
ReadOnly bool ReadOnly bool

View file

@ -21,7 +21,6 @@ import (
"math/rand" "math/rand"
"os" "os"
"path/filepath" "path/filepath"
"strings"
"time" "time"
"github.com/88250/gulu" "github.com/88250/gulu"
@ -122,20 +121,7 @@ func initWorkspaceDirMobile(workspaceBaseDir string) {
} }
workspacePaths = append(workspacePaths, WorkspaceDir) workspacePaths = append(workspacePaths, WorkspaceDir)
} else { } else {
data, err := os.ReadFile(workspaceConf) workspacePaths, _ = ReadWorkspacePaths()
if err = gulu.JSON.UnmarshalJSON(data, &workspacePaths); nil != err {
log.Printf("unmarshal workspace conf [%s] failed: %s", workspaceConf, err)
}
var tmp []string
for _, d := range workspacePaths {
d = strings.TrimRight(d, " \t\n") // 去掉工作空间路径尾部空格 https://github.com/siyuan-note/siyuan/issues/6353
if gulu.File.IsDir(d) {
tmp = append(tmp, d)
}
}
workspacePaths = tmp
if 0 < len(workspacePaths) { if 0 < len(workspacePaths) {
WorkspaceDir = workspacePaths[len(workspacePaths)-1] WorkspaceDir = workspacePaths[len(workspacePaths)-1]
if !gulu.File.IsDir(WorkspaceDir) { if !gulu.File.IsDir(WorkspaceDir) {
@ -149,12 +135,8 @@ func initWorkspaceDirMobile(workspaceBaseDir string) {
} }
} }
if data, err := gulu.JSON.MarshalJSON(workspacePaths); nil == err { if err := WriteWorkspacePaths(workspacePaths); nil != err {
if err = os.WriteFile(workspaceConf, data, 0644); nil != err { log.Fatalf("write workspace conf [%s] failed: %s", workspaceConf, err)
log.Fatalf("write workspace conf [%s] failed: %s", workspaceConf, err)
}
} else {
log.Fatalf("marshal workspace conf [%s] failed: %s", workspaceConf, err)
} }
ConfDir = filepath.Join(WorkspaceDir, "conf") ConfDir = filepath.Join(WorkspaceDir, "conf")