Исправление функционала создания дирректорий для работы ALR
This commit is contained in:
34
fix.go
34
fix.go
@@ -131,22 +131,22 @@ func FixCmd() *cli.Command {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Создаем базовый каталог /tmp/alr с владельцем root:wheel и правами 775
|
// Создаем базовый каталог /tmp/alr с владельцем root:wheel и правами 2775
|
||||||
err = utils.EnsureTempDirWithRootOwner(tmpDir, 0o775)
|
err = utils.EnsureTempDirWithRootOwner(tmpDir, 0o2775)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
slog.Warn(gotext.Get("Unable to create temporary directory"), "error", err)
|
slog.Warn(gotext.Get("Unable to create temporary directory"), "error", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Создаем каталог dl с правами для группы wheel
|
// Создаем каталог dl с правами для группы wheel
|
||||||
dlDir := filepath.Join(tmpDir, "dl")
|
dlDir := filepath.Join(tmpDir, "dl")
|
||||||
err = utils.EnsureTempDirWithRootOwner(dlDir, 0o775)
|
err = utils.EnsureTempDirWithRootOwner(dlDir, 0o2775)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
slog.Warn(gotext.Get("Unable to create download directory"), "error", err)
|
slog.Warn(gotext.Get("Unable to create download directory"), "error", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Создаем каталог pkgs с правами для группы wheel
|
// Создаем каталог pkgs с правами для группы wheel
|
||||||
pkgsDir := filepath.Join(tmpDir, "pkgs")
|
pkgsDir := filepath.Join(tmpDir, "pkgs")
|
||||||
err = utils.EnsureTempDirWithRootOwner(pkgsDir, 0o775)
|
err = utils.EnsureTempDirWithRootOwner(pkgsDir, 0o2775)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
slog.Warn(gotext.Get("Unable to create packages directory"), "error", err)
|
slog.Warn(gotext.Get("Unable to create packages directory"), "error", err)
|
||||||
}
|
}
|
||||||
@@ -158,7 +158,8 @@ func FixCmd() *cli.Command {
|
|||||||
// Проверяем, есть ли файлы в директории
|
// Проверяем, есть ли файлы в директории
|
||||||
entries, err := os.ReadDir(tmpDir)
|
entries, err := os.ReadDir(tmpDir)
|
||||||
if err == nil && len(entries) > 0 {
|
if err == nil && len(entries) > 0 {
|
||||||
fixCmd := execWithPrivileges("chown", "-R", "root:wheel", tmpDir)
|
group := utils.GetPrivilegedGroup()
|
||||||
|
fixCmd := execWithPrivileges("chown", "-R", "root:"+group, tmpDir)
|
||||||
if fixErr := fixCmd.Run(); fixErr != nil {
|
if fixErr := fixCmd.Run(); fixErr != nil {
|
||||||
slog.Warn(gotext.Get("Unable to fix file ownership"), "error", fixErr)
|
slog.Warn(gotext.Get("Unable to fix file ownership"), "error", fixErr)
|
||||||
}
|
}
|
||||||
@@ -172,26 +173,11 @@ func FixCmd() *cli.Command {
|
|||||||
|
|
||||||
slog.Info(gotext.Get("Rebuilding cache"))
|
slog.Info(gotext.Get("Rebuilding cache"))
|
||||||
|
|
||||||
// Пробуем создать директорию кэша
|
// Создаем директорию кэша с правильными правами
|
||||||
err = os.MkdirAll(paths.CacheDir, 0o775)
|
slog.Info(gotext.Get("Creating cache directory"))
|
||||||
|
err = utils.EnsureTempDirWithRootOwner(paths.CacheDir, 0o2775)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
// Если не получилось, пробуем через sudo с правильными правами для группы wheel
|
return cliutils.FormatCliExit(gotext.Get("Unable to create new cache directory"), err)
|
||||||
slog.Info(gotext.Get("Creating cache directory with sudo"))
|
|
||||||
sudoCmd := execWithPrivileges("mkdir", "-p", paths.CacheDir)
|
|
||||||
if sudoErr := sudoCmd.Run(); sudoErr != nil {
|
|
||||||
return cliutils.FormatCliExit(gotext.Get("Unable to create new cache directory"), err)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Устанавливаем права 775 и группу wheel
|
|
||||||
chmodCmd := execWithPrivileges("chmod", "775", paths.CacheDir)
|
|
||||||
if chmodErr := chmodCmd.Run(); chmodErr != nil {
|
|
||||||
return cliutils.FormatCliExit(gotext.Get("Unable to set cache directory permissions"), chmodErr)
|
|
||||||
}
|
|
||||||
|
|
||||||
chgrpCmd := execWithPrivileges("chgrp", "wheel", paths.CacheDir)
|
|
||||||
if chgrpErr := chgrpCmd.Run(); chgrpErr != nil {
|
|
||||||
return cliutils.FormatCliExit(gotext.Get("Unable to set cache directory group"), chgrpErr)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
deps, err = appbuilder.
|
deps, err = appbuilder.
|
||||||
|
@@ -62,11 +62,9 @@ func (d *Database) Connect() error {
|
|||||||
dbDir := filepath.Dir(dsn)
|
dbDir := filepath.Dir(dsn)
|
||||||
if _, err := os.Stat(dbDir); err != nil {
|
if _, err := os.Stat(dbDir); err != nil {
|
||||||
if os.IsNotExist(err) {
|
if os.IsNotExist(err) {
|
||||||
// Директория не существует - пытаемся создать
|
// Директория не существует - не пытаемся создать
|
||||||
if mkErr := os.MkdirAll(dbDir, 0775); mkErr != nil {
|
// Пользователь должен использовать alr fix для создания системных каталогов
|
||||||
// Не смогли создать - вернём ошибку, пользователь должен использовать alr fix
|
return fmt.Errorf("cache directory does not exist, please run 'sudo alr fix' to create it")
|
||||||
return fmt.Errorf("cache directory does not exist, please run 'alr fix' to create it: %w", mkErr)
|
|
||||||
}
|
|
||||||
} else {
|
} else {
|
||||||
return fmt.Errorf("failed to check database directory: %w", err)
|
return fmt.Errorf("failed to check database directory: %w", err)
|
||||||
}
|
}
|
||||||
|
@@ -21,6 +21,7 @@ import (
|
|||||||
"github.com/urfave/cli/v2"
|
"github.com/urfave/cli/v2"
|
||||||
|
|
||||||
appbuilder "gitea.plemya-x.ru/Plemya-x/ALR/internal/cliutils/app_builder"
|
appbuilder "gitea.plemya-x.ru/Plemya-x/ALR/internal/cliutils/app_builder"
|
||||||
|
"gitea.plemya-x.ru/Plemya-x/ALR/internal/utils"
|
||||||
)
|
)
|
||||||
|
|
||||||
func RefreshCmd() *cli.Command {
|
func RefreshCmd() *cli.Command {
|
||||||
@@ -29,6 +30,9 @@ func RefreshCmd() *cli.Command {
|
|||||||
Usage: gotext.Get("Pull all repositories that have changed"),
|
Usage: gotext.Get("Pull all repositories that have changed"),
|
||||||
Aliases: []string{"ref"},
|
Aliases: []string{"ref"},
|
||||||
Action: func(c *cli.Context) error {
|
Action: func(c *cli.Context) error {
|
||||||
|
if err := utils.CheckUserPrivileges(); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
ctx := c.Context
|
ctx := c.Context
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user