Merge pull request #757 from mlintner/master
[mono.git] / mcs / class / corlib / System.Security.AccessControl / FileSystemAuditRule.cs
index 4fe3694d547b81ed52c3a68240328d45ca2e5b05..ff29ab2eb7673009cab237207ecf5a37454a6092 100644 (file)
@@ -1,10 +1,11 @@
 //
 // System.Security.AccessControl.FileSystemAuditRule implementation
 //
-// Author:
+// Authors:
 //     Dick Porter  <dick@ximian.com>
+//     Atsushi Enomoto  <atsushi@ximian.com>
 //
-// Copyright (C) 2006 Novell, Inc (http://www.novell.com)
+// Copyright (C) 2006-2007 Novell, Inc (http://www.novell.com)
 //
 // Permission is hereby granted, free of charge, to any person obtaining
 // a copy of this software and associated documentation files (the
 // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
 //
 
-#if NET_2_0
 
 using System.Security.Principal;
 
-namespace System.Security.AccessControl {
+namespace System.Security.AccessControl
+{
        public sealed class FileSystemAuditRule : AuditRule
        {
-               FileSystemRights fileSystemRights;
-               
                public FileSystemAuditRule (IdentityReference identity,
                                            FileSystemRights fileSystemRights,
                                            AuditFlags flags)
+                       : this (identity, fileSystemRights, InheritanceFlags.None, PropagationFlags.None, flags)
                {
-                       this.fileSystemRights = fileSystemRights;
                }
                
                public FileSystemAuditRule (string identity,
                                            FileSystemRights fileSystemRights,
                                            AuditFlags flags)
+                       : this (new NTAccount (identity), fileSystemRights, flags)
                {
-                       this.fileSystemRights = fileSystemRights;
                }
 
                public FileSystemAuditRule (IdentityReference identity,
@@ -54,8 +53,18 @@ namespace System.Security.AccessControl {
                                            InheritanceFlags inheritanceFlags,
                                            PropagationFlags propagationFlags,
                                            AuditFlags flags)
+                       : this (identity, fileSystemRights, false, inheritanceFlags, propagationFlags, flags)
+               {
+               }
+               
+               internal FileSystemAuditRule (IdentityReference identity,
+                                             FileSystemRights fileSystemRights,
+                                             bool isInherited,
+                                             InheritanceFlags inheritanceFlags,
+                                             PropagationFlags propagationFlags,
+                                             AuditFlags flags)
+                       : base (identity, (int)fileSystemRights, isInherited, inheritanceFlags, propagationFlags, flags)
                {
-                       this.fileSystemRights = fileSystemRights;
                }
                
                public FileSystemAuditRule (string identity,
@@ -63,17 +72,12 @@ namespace System.Security.AccessControl {
                                            InheritanceFlags inheritanceFlags,
                                            PropagationFlags propagationFlags,
                                            AuditFlags flags)
+                       : this (new NTAccount (identity), fileSystemRights, inheritanceFlags, propagationFlags, flags)
                {
-                       this.fileSystemRights = fileSystemRights;
                }
                
-               public FileSystemRights FileSystemRights
-               {
-                       get {
-                               return(fileSystemRights);
-                       }
+               public FileSystemRights FileSystemRights {
+                       get { return (FileSystemRights)AccessMask; }
                }
        }
 }
-
-#endif