Исправление владельца каталогов и файлов
This commit is contained in:
@@ -19,43 +19,115 @@
|
|||||||
package permissions
|
package permissions
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"fmt"
|
||||||
"os"
|
"os"
|
||||||
|
"os/user"
|
||||||
"path/filepath"
|
"path/filepath"
|
||||||
|
"strconv"
|
||||||
)
|
)
|
||||||
|
|
||||||
// FixFilePermissions устанавливает права 664 для файла
|
// FixFilePermissions устанавливает права 664 для файла и владельца alr-updater:wheel
|
||||||
// Используется для всех файлов, создаваемых программой, чтобы они были доступны
|
// Используется для всех файлов, создаваемых программой, чтобы они были доступны
|
||||||
// для чтения и записи группе (wheel), даже если файл создан от пользователя alr-updater
|
// для чтения и записи группе (wheel), даже если файл создан от другого пользователя
|
||||||
func FixFilePermissions(filePath string) error {
|
func FixFilePermissions(filePath string) error {
|
||||||
|
// Получаем UID и GID для alr-updater:wheel
|
||||||
|
uid, gid, err := getAlrUpdaterIDs()
|
||||||
|
if err != nil {
|
||||||
|
// Если не можем получить ID (например, в dev-окружении), просто меняем права
|
||||||
|
return os.Chmod(filePath, 0o664)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Изменяем владельца
|
||||||
|
if err := os.Chown(filePath, uid, gid); err != nil {
|
||||||
|
// Если не удалось изменить владельца (недостаточно прав), игнорируем
|
||||||
|
// но устанавливаем права
|
||||||
|
_ = os.Chmod(filePath, 0o664)
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
return os.Chmod(filePath, 0o664)
|
return os.Chmod(filePath, 0o664)
|
||||||
}
|
}
|
||||||
|
|
||||||
// FixDirectoryPermissions устанавливает права 2775 для директории (с setgid битом)
|
// FixDirectoryPermissions устанавливает права 2775 для директории (с setgid битом) и владельца alr-updater:wheel
|
||||||
// Бит setgid (2000) гарантирует, что все новые файлы в директории будут принадлежать группе директории
|
// Бит setgid (2000) гарантирует, что все новые файлы в директории будут принадлежать группе директории
|
||||||
func FixDirectoryPermissions(dirPath string) error {
|
func FixDirectoryPermissions(dirPath string) error {
|
||||||
|
// Получаем UID и GID для alr-updater:wheel
|
||||||
|
uid, gid, err := getAlrUpdaterIDs()
|
||||||
|
if err != nil {
|
||||||
|
// Если не можем получить ID (например, в dev-окружении), просто меняем права
|
||||||
|
return os.Chmod(dirPath, 0o2775)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Изменяем владельца
|
||||||
|
if err := os.Chown(dirPath, uid, gid); err != nil {
|
||||||
|
// Если не удалось изменить владельца (недостаточно прав), игнорируем
|
||||||
|
// но устанавливаем права
|
||||||
|
_ = os.Chmod(dirPath, 0o2775)
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
return os.Chmod(dirPath, 0o2775)
|
return os.Chmod(dirPath, 0o2775)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// getAlrUpdaterIDs возвращает UID пользователя alr-updater и GID группы wheel
|
||||||
|
func getAlrUpdaterIDs() (int, int, error) {
|
||||||
|
// Получаем пользователя alr-updater
|
||||||
|
u, err := user.Lookup("alr-updater")
|
||||||
|
if err != nil {
|
||||||
|
return -1, -1, fmt.Errorf("failed to lookup user alr-updater: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
uid, err := strconv.Atoi(u.Uid)
|
||||||
|
if err != nil {
|
||||||
|
return -1, -1, fmt.Errorf("failed to parse UID: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Получаем группу wheel
|
||||||
|
g, err := user.LookupGroup("wheel")
|
||||||
|
if err != nil {
|
||||||
|
return -1, -1, fmt.Errorf("failed to lookup group wheel: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
gid, err := strconv.Atoi(g.Gid)
|
||||||
|
if err != nil {
|
||||||
|
return -1, -1, fmt.Errorf("failed to parse GID: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
return uid, gid, nil
|
||||||
|
}
|
||||||
|
|
||||||
// FixRepoPermissions рекурсивно устанавливает права 775 для директорий и 664 для файлов
|
// FixRepoPermissions рекурсивно устанавливает права 775 для директорий и 664 для файлов
|
||||||
// Пропускает директорию .git, так как Git управляет правами самостоятельно
|
// Включая директорию .git, чтобы обеспечить доступ к объектам Git для группы wheel
|
||||||
|
// Также изменяет владельца на alr-updater:wheel
|
||||||
func FixRepoPermissions(path string) error {
|
func FixRepoPermissions(path string) error {
|
||||||
|
// Получаем UID и GID для alr-updater:wheel
|
||||||
|
uid, gid, err := getAlrUpdaterIDs()
|
||||||
|
if err != nil {
|
||||||
|
return fmt.Errorf("failed to get alr-updater IDs: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
return filepath.Walk(path, func(filePath string, info os.FileInfo, err error) error {
|
return filepath.Walk(path, func(filePath string, info os.FileInfo, err error) error {
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
// Пропускаем директорию .git и её содержимое
|
// Изменяем владельца на alr-updater:wheel
|
||||||
// Git управляет правами самостоятельно, не нужно их трогать
|
if err := os.Chown(filePath, uid, gid); err != nil {
|
||||||
if info.IsDir() && info.Name() == ".git" {
|
return fmt.Errorf("failed to chown %s: %w", filePath, err)
|
||||||
return filepath.SkipDir
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if info.IsDir() {
|
if info.IsDir() {
|
||||||
// Устанавливаем права 2775 для директорий (setgid)
|
// Устанавливаем права 2775 для директорий (setgid)
|
||||||
return os.Chmod(filePath, 0o2775)
|
if err := os.Chmod(filePath, 0o2775); err != nil {
|
||||||
|
return fmt.Errorf("failed to chmod directory %s: %w", filePath, err)
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
// Устанавливаем права 664 для файлов
|
// Устанавливаем права 664 для файлов
|
||||||
return os.Chmod(filePath, 0o664)
|
if err := os.Chmod(filePath, 0o664); err != nil {
|
||||||
|
return fmt.Errorf("failed to chmod file %s: %w", filePath, err)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return nil
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user