permcheck: fix nil owner

This commit is contained in:
Eugene Burkov 2024-12-02 15:37:58 +03:00
parent b1fc67c4d1
commit e1d21c576d
1 changed files with 13 additions and 18 deletions

View File

@ -71,14 +71,11 @@ func migrate(ctx context.Context, logger *slog.Logger, workDir, _, _, _, _ strin
return return
} }
owner, err = adminsIfNot(owner) admins, err := windows.CreateWellKnownSid(windows.WinBuiltinAdministratorsSid)
switch { if err != nil {
case err != nil:
l.ErrorContext(ctx, "creating administrators sid", slogutil.KeyError, err) l.ErrorContext(ctx, "creating administrators sid", slogutil.KeyError, err)
case owner == nil:
l.DebugContext(ctx, "owner is already an administrator") return
default:
l.InfoContext(ctx, "migrating owner", "sid", owner)
} }
// TODO(e.burkov): Check for duplicates? // TODO(e.burkov): Check for duplicates?
@ -120,7 +117,15 @@ func migrate(ctx context.Context, logger *slog.Logger, workDir, _, _, _, _ strin
} }
if setACL { if setACL {
accessEntries = append(accessEntries, newFullExplicitAccess(owner)) accessEntries = append(accessEntries, newFullExplicitAccess(admins))
}
if !owner.IsWellKnown(windows.WinBuiltinAdministratorsSid) {
l.InfoContext(ctx, "migrating owner", "sid", owner)
owner = admins
} else {
l.DebugContext(ctx, "owner is already an administrator")
owner = nil
} }
err = setSecurityInfo(workDir, owner, accessEntries) err = setSecurityInfo(workDir, owner, accessEntries)
@ -128,13 +133,3 @@ func migrate(ctx context.Context, logger *slog.Logger, workDir, _, _, _, _ strin
l.ErrorContext(ctx, "setting security info", slogutil.KeyError, err) l.ErrorContext(ctx, "setting security info", slogutil.KeyError, err)
} }
} }
// adminsIfNot returns the administrators SID if sid is not a
// [windows.WinBuiltinAdministratorsSid] yet, or nil if it is.
func adminsIfNot(sid *windows.SID) (admins *windows.SID, err error) {
if sid.IsWellKnown(windows.WinBuiltinAdministratorsSid) {
return nil, nil
}
return windows.CreateWellKnownSid(windows.WinBuiltinAdministratorsSid)
}