all: revert permcheck

This commit is contained in:
Eugene Burkov 2024-10-28 18:23:54 +03:00
parent bcc85d50f5
commit 9008ee93b1
5 changed files with 49 additions and 60 deletions

BIN
agh_test.exe Executable file

Binary file not shown.

View File

@ -64,7 +64,7 @@ func stat(name string) (fi os.FileInfo, err error) {
case entrySid.Equals(group): case entrySid.Equals(group):
groupMask |= ace.Mask groupMask |= ace.Mask
default: default:
otherMask = ace.Mask otherMask |= ace.Mask
} }
} }
@ -143,7 +143,7 @@ func chmod(name string, perm fs.FileMode) (err error) {
continue continue
} }
var trustee *windows.TRUSTEE var trustee windows.TRUSTEE
trustee, err = newWellKnownTrustee(sidMask.Key) trustee, err = newWellKnownTrustee(sidMask.Key)
if err != nil { if err != nil {
errs = append(errs, err) errs = append(errs, err)
@ -155,7 +155,7 @@ func chmod(name string, perm fs.FileMode) (err error) {
AccessPermissions: sidMask.Value, AccessPermissions: sidMask.Value,
AccessMode: windows.GRANT_ACCESS, AccessMode: windows.GRANT_ACCESS,
Inheritance: windows.NO_INHERITANCE, Inheritance: windows.NO_INHERITANCE,
Trustee: *trustee, Trustee: trustee,
}) })
} }
@ -208,10 +208,12 @@ func mkdir(name string, perm os.FileMode) (err error) {
func mkdirAll(path string, perm os.FileMode) (err error) { func mkdirAll(path string, perm os.FileMode) (err error) {
parent, _ := filepath.Split(path) parent, _ := filepath.Split(path)
if parent != "" {
err = os.MkdirAll(parent, perm) err = os.MkdirAll(parent, perm)
if err != nil && !errors.Is(err, os.ErrExist) { if err != nil && !errors.Is(err, os.ErrExist) {
return fmt.Errorf("creating parent directories: %w", err) return fmt.Errorf("creating parent directories: %w", err)
} }
}
err = mkdir(path, perm) err = mkdir(path, perm)
if errors.Is(err, os.ErrExist) { if errors.Is(err, os.ErrExist) {
@ -258,13 +260,13 @@ func openFile(name string, flag int, perm os.FileMode) (file *os.File, err error
} }
// newWellKnownTrustee returns a trustee for a well-known SID. // newWellKnownTrustee returns a trustee for a well-known SID.
func newWellKnownTrustee(stype windows.WELL_KNOWN_SID_TYPE) (t *windows.TRUSTEE, err error) { func newWellKnownTrustee(stype windows.WELL_KNOWN_SID_TYPE) (t windows.TRUSTEE, err error) {
sid, err := windows.CreateWellKnownSid(stype) sid, err := windows.CreateWellKnownSid(stype)
if err != nil { if err != nil {
return nil, fmt.Errorf("creating sid for type %d: %w", stype, err) return windows.TRUSTEE{}, fmt.Errorf("creating sid for type %d: %w", stype, err)
} }
return &windows.TRUSTEE{ return windows.TRUSTEE{
TrusteeForm: windows.TRUSTEE_IS_SID, TrusteeForm: windows.TRUSTEE_IS_SID,
TrusteeValue: windows.TrusteeValueFromSID(sid), TrusteeValue: windows.TrusteeValueFromSID(sid),
}, nil }, nil
@ -280,14 +282,14 @@ const (
// Windows access masks for appropriate UNIX file mode permission bits and // Windows access masks for appropriate UNIX file mode permission bits and
// file types. // file types.
const ( const (
fileReadRights = windows.READ_CONTROL | fileReadRights windows.ACCESS_MASK = windows.READ_CONTROL |
windows.FILE_READ_DATA | windows.FILE_READ_DATA |
windows.FILE_READ_ATTRIBUTES | windows.FILE_READ_ATTRIBUTES |
windows.FILE_READ_EA | windows.FILE_READ_EA |
windows.SYNCHRONIZE | windows.SYNCHRONIZE |
windows.ACCESS_SYSTEM_SECURITY windows.ACCESS_SYSTEM_SECURITY
fileWriteRights = windows.WRITE_DAC | fileWriteRights windows.ACCESS_MASK = windows.WRITE_DAC |
windows.WRITE_OWNER | windows.WRITE_OWNER |
windows.FILE_WRITE_DATA | windows.FILE_WRITE_DATA |
windows.FILE_WRITE_ATTRIBUTES | windows.FILE_WRITE_ATTRIBUTES |
@ -297,16 +299,16 @@ const (
windows.SYNCHRONIZE | windows.SYNCHRONIZE |
windows.ACCESS_SYSTEM_SECURITY windows.ACCESS_SYSTEM_SECURITY
fileExecuteRights = windows.FILE_EXECUTE fileExecuteRights windows.ACCESS_MASK = windows.FILE_EXECUTE
dirReadRights = windows.READ_CONTROL | dirReadRights windows.ACCESS_MASK = windows.READ_CONTROL |
windows.FILE_LIST_DIRECTORY | windows.FILE_LIST_DIRECTORY |
windows.FILE_READ_EA | windows.FILE_READ_EA |
windows.FILE_READ_ATTRIBUTES<<1 | windows.FILE_READ_ATTRIBUTES<<1 |
windows.SYNCHRONIZE | windows.SYNCHRONIZE |
windows.ACCESS_SYSTEM_SECURITY windows.ACCESS_SYSTEM_SECURITY
dirWriteRights = windows.WRITE_DAC | dirWriteRights windows.ACCESS_MASK = windows.WRITE_DAC |
windows.WRITE_OWNER | windows.WRITE_OWNER |
windows.DELETE | windows.DELETE |
windows.FILE_WRITE_DATA | windows.FILE_WRITE_DATA |
@ -316,7 +318,7 @@ const (
windows.SYNCHRONIZE | windows.SYNCHRONIZE |
windows.ACCESS_SYSTEM_SECURITY windows.ACCESS_SYSTEM_SECURITY
dirExecuteRights = windows.FILE_TRAVERSE dirExecuteRights windows.ACCESS_MASK = windows.FILE_TRAVERSE
) )
// permToMasks converts a UNIX file mode permissions to the corresponding // permToMasks converts a UNIX file mode permissions to the corresponding
@ -336,26 +338,19 @@ func permToMasks(fm os.FileMode, isDir bool) (owner, group, world windows.ACCESS
// corresponding Windows access mask. The [isDir] argument is used to set // corresponding Windows access mask. The [isDir] argument is used to set
// specific access bits for directories. // specific access bits for directories.
func permToMask(p byte, isDir bool) (mask windows.ACCESS_MASK) { func permToMask(p byte, isDir bool) (mask windows.ACCESS_MASK) {
if p&permRead != 0 { readRights, writeRights, executeRights := fileReadRights, fileWriteRights, fileExecuteRights
if isDir { if isDir {
mask |= dirReadRights readRights, writeRights, executeRights = dirReadRights, dirWriteRights, dirExecuteRights
} else {
mask |= fileReadRights
} }
if p&permRead != 0 {
mask |= readRights
} }
if p&permWrite != 0 { if p&permWrite != 0 {
if isDir { mask |= writeRights
mask |= dirWriteRights
} else {
mask |= fileWriteRights
}
} }
if p&permExecute != 0 { if p&permExecute != 0 {
if isDir { mask |= executeRights
mask |= dirExecuteRights
} else {
mask |= fileExecuteRights
}
} }
return mask return mask
@ -374,27 +369,24 @@ func masksToPerm(u, g, o windows.ACCESS_MASK, isDir bool) (perm fs.FileMode) {
// maskToPerm converts a Windows access mask to the corresponding UNIX file // maskToPerm converts a Windows access mask to the corresponding UNIX file
// mode permission bits. // mode permission bits.
func maskToPerm(mask windows.ACCESS_MASK, isDir bool) (perm byte) { func maskToPerm(mask windows.ACCESS_MASK, isDir bool) (perm byte) {
readMask, writeMask, executeMask := fileReadRights, fileWriteRights, fileExecuteRights
if isDir { if isDir {
if mask&dirReadRights != 0 { readMask, writeMask, executeMask = dirReadRights, dirWriteRights, dirExecuteRights
}
// Remove common bits to avoid false positive detection of unset rights.
readMask ^= windows.SYNCHRONIZE | windows.ACCESS_SYSTEM_SECURITY
writeMask ^= windows.SYNCHRONIZE | windows.ACCESS_SYSTEM_SECURITY
if mask&readMask != 0 {
perm |= permRead perm |= permRead
} }
if mask&dirWriteRights != 0 { if mask&writeMask != 0 {
perm |= permWrite perm |= permWrite
} }
if mask&dirExecuteRights != 0 { if mask&executeMask != 0 {
perm |= permExecute perm |= permExecute
} }
} else {
if mask&fileReadRights != 0 {
perm |= permRead
}
if mask&fileWriteRights != 0 {
perm |= permWrite
}
if mask&fileExecuteRights != 0 {
perm |= permExecute
}
}
return perm return perm
} }

View File

@ -29,14 +29,14 @@ func TestPermToMasks(t *testing.T) {
isDir: false, isDir: false,
}, { }, {
name: "user_write", name: "user_write",
perm: 0o010_000_000, perm: 0b010_000_000,
wantUser: fileWriteRights, wantUser: fileWriteRights,
wantGroup: 0, wantGroup: 0,
wantOther: 0, wantOther: 0,
isDir: false, isDir: false,
}, { }, {
name: "group_read", name: "group_read",
perm: 0o000_010_000, perm: 0b000_100_000,
wantUser: 0, wantUser: 0,
wantGroup: fileReadRights, wantGroup: fileReadRights,
wantOther: 0, wantOther: 0,
@ -50,7 +50,7 @@ func TestPermToMasks(t *testing.T) {
isDir: true, isDir: true,
}, { }, {
name: "user_write_dir", name: "user_write_dir",
perm: 0o010_000_000, perm: 0b010_000_000,
wantUser: dirWriteRights, wantUser: dirWriteRights,
wantGroup: 0, wantGroup: 0,
wantOther: 0, wantOther: 0,
@ -91,14 +91,14 @@ func TestMasksToPerm(t *testing.T) {
user: fileWriteRights, user: fileWriteRights,
group: 0, group: 0,
other: 0, other: 0,
wantPerm: 0o010_000_000, wantPerm: 0b010_000_000,
isDir: false, isDir: false,
}, { }, {
name: "group_read", name: "group_read",
user: 0, user: 0,
group: fileReadRights, group: fileReadRights,
other: 0, other: 0,
wantPerm: 0o000_010_000, wantPerm: 0b000_100_000,
isDir: false, isDir: false,
}, { }, {
name: "no_access", name: "no_access",
@ -119,7 +119,7 @@ func TestMasksToPerm(t *testing.T) {
user: dirWriteRights, user: dirWriteRights,
group: 0, group: 0,
other: 0, other: 0,
wantPerm: 0o010_000_000, wantPerm: 0b010_000_000,
isDir: true, isDir: true,
}} }}

View File

@ -687,7 +687,7 @@ func run(opts options, clientBuildFS fs.FS, done chan struct{}) {
} }
if permcheck.NeedsMigration(confPath) { if permcheck.NeedsMigration(confPath) {
permcheck.Migrate(Context.workDir, dataDir, statsDir, querylogDir, confPath, execPath) permcheck.Migrate(Context.workDir, dataDir, statsDir, querylogDir, confPath)
} }
permcheck.Check(Context.workDir, dataDir, statsDir, querylogDir, confPath) permcheck.Check(Context.workDir, dataDir, statsDir, querylogDir, confPath)

View File

@ -32,14 +32,11 @@ func NeedsMigration(confFilePath string) (ok bool) {
// Migrate attempts to change the permissions of AdGuard Home's files. It logs // Migrate attempts to change the permissions of AdGuard Home's files. It logs
// the results at an appropriate level. // the results at an appropriate level.
func Migrate(workDir, dataDir, statsDir, querylogDir, confFilePath, execPath string) { func Migrate(workDir, dataDir, statsDir, querylogDir, confFilePath string) {
chmodDir(workDir) chmodDir(workDir)
chmodFile(confFilePath) chmodFile(confFilePath)
// Allow the binary to be executed.
chmodPath(execPath, typeFile, aghos.DefaultPermFile|0b001_000_000)
// TODO(a.garipov): Put all paths in one place and remove this duplication. // TODO(a.garipov): Put all paths in one place and remove this duplication.
chmodDir(dataDir) chmodDir(dataDir)
chmodDir(filepath.Join(dataDir, "filters")) chmodDir(filepath.Join(dataDir, "filters"))