Исправление работы с правами каталогов + скрипт установки

This commit is contained in:
2025-09-14 13:16:06 +03:00
parent 5b2b370a39
commit 4c4e645d21
2 changed files with 156 additions and 1 deletions

34
main.go
View File

@@ -142,6 +142,20 @@ func main() {
return
}
// Создаем директорию для базы данных, если её нет
dbDir := filepath.Dir(*dbPath)
if _, err := os.Stat(dbDir); os.IsNotExist(err) {
err = os.MkdirAll(dbDir, 0o755)
if err != nil {
log.Fatal("Error creating database directory").
Err(err).
Str("path", dbDir).
Str("hint", "Run as root or create directory manually: sudo mkdir -p "+dbDir+" && sudo chown alr-updater:alr-updater "+dbDir).
Send()
}
log.Info("Created database directory").Str("path", dbDir).Send()
}
db, err := bbolt.Open(*dbPath, 0o644, nil)
if err != nil {
log.Fatal("Error opening database").Err(err).Send()
@@ -155,8 +169,13 @@ func main() {
if _, err := os.Stat(cfg.ReposBaseDir); os.IsNotExist(err) {
err = os.MkdirAll(cfg.ReposBaseDir, 0o755)
if err != nil {
log.Fatal("Error creating repositories base directory").Err(err).Send()
log.Fatal("Error creating repositories base directory").
Err(err).
Str("path", cfg.ReposBaseDir).
Str("hint", "Run as root or create directory manually: sudo mkdir -p "+cfg.ReposBaseDir+" && sudo chown alr-updater:alr-updater "+cfg.ReposBaseDir).
Send()
}
log.Info("Created repositories base directory").Str("path", cfg.ReposBaseDir).Send()
} else if err != nil {
log.Fatal("Cannot stat configured repos base directory").Err(err).Send()
}
@@ -194,6 +213,19 @@ func main() {
log.Fatal("No repositories configured. At least one repository is required.").Send()
}
// Создаем директорию для плагинов, если её нет
if _, err := os.Stat(*pluginDir); os.IsNotExist(err) {
err = os.MkdirAll(*pluginDir, 0o755)
if err != nil {
log.Fatal("Error creating plugin directory").
Err(err).
Str("path", *pluginDir).
Str("hint", "Run as root or create directory manually: sudo mkdir -p "+*pluginDir+" && sudo chown root:alr-updater "+*pluginDir).
Send()
}
log.Info("Created plugin directory").Str("path", *pluginDir).Send()
}
starFiles, err := filepath.Glob(filepath.Join(*pluginDir, "*.star"))
if err != nil {
log.Fatal("Error finding plugin files").Err(err).Send()