I have C# code (at the end) which:
- Creates a file
- Prints the current ACL
- Gives the builtin users group "write permissions" to the previously created file
- Prints the current modified ACL
The write permissions are successfully assigned via code as you can see in the console ouput.
data:image/s3,"s3://crabby-images/8bee7/8bee74b419ea112ee4abd4b43023c59fd133b423" alt="enter image description here"
My question is: Why does the security tab of the file, not reflect this permission change for the Users group ?
data:image/s3,"s3://crabby-images/39aee/39aeec08dec3e2c26245ab817f4c886e5a1eb80b" alt="enter image description here"
C# code:
var file = "sectest.txt";
File.WriteAllText(file, "File security test.");
var sid = new SecurityIdentifier(WellKnownSidType.BuiltinUsersSid, null);
string strBuiltInUsersAccount = sid.Translate(typeof(NTAccount)).ToString();
FileSecurity fileSecurity = new FileSecurity(file,
AccessControlSections.Owner |
AccessControlSections.Group |
AccessControlSections.Access);
Console.WriteLine("AFTER CREATE:");
ShowSecurity(fileSecurity); // BUILTIN\Users group doesn't have Write permission
// short: give "builtin\users" write permissions
var fsAccessRule = new FileSystemAccessRule(strBuiltInUsersAccount,
FileSystemRights.Write,
AccessControlType.Allow);
fileSecurity.ModifyAccessRule(AccessControlModification.Add, fsAccessRule, out bool modified);
Console.WriteLine();
Console.WriteLine("AFTER MODIFY:");
ShowSecurity(fileSecurity); // BUILTIN\Users has Write permission