Commit 324f7959 authored by Johnny's avatar Johnny

fix: improve default data directory handling

parent d3ed069d
...@@ -54,17 +54,26 @@ func checkDataDir(dataDir string) (string, error) { ...@@ -54,17 +54,26 @@ func checkDataDir(dataDir string) (string, error) {
} }
func (p *Profile) Validate() error { func (p *Profile) Validate() error {
if !p.Demo && p.Data == "" { // Set default data directory if not specified
if runtime.GOOS == "windows" { if p.Data == "" {
p.Data = filepath.Join(os.Getenv("ProgramData"), "memos") if p.Demo {
if _, err := os.Stat(p.Data); os.IsNotExist(err) { // In demo mode, use a temporary directory or current directory
if err := os.MkdirAll(p.Data, 0770); err != nil { p.Data = "."
slog.Error("failed to create data directory", slog.String("data", p.Data), slog.String("error", err.Error()))
return err
}
}
} else { } else {
p.Data = "/var/opt/memos" // In production mode, use system directory
if runtime.GOOS == "windows" {
p.Data = filepath.Join(os.Getenv("ProgramData"), "memos")
} else {
p.Data = "/var/opt/memos"
}
}
}
// Create data directory if it doesn't exist
if _, err := os.Stat(p.Data); os.IsNotExist(err) {
if err := os.MkdirAll(p.Data, 0770); err != nil {
slog.Error("failed to create data directory", slog.String("data", p.Data), slog.String("error", err.Error()))
return err
} }
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment