* OleDbParameterCollectionTest.cs: Fix compile error in 1.1 profile.
[mono.git] / mcs / class / System.DirectoryServices / System.DirectoryServices / DirectoryServicesPermission.cs
index b521f50231a94df6c7f32d6a61eaba5fa53778dd..d0d23937e27ba259b0da0292382f6a564f2d4fde 100644 (file)
 //
 // System.DirectoryServices.DirectoryEntry.cs
 //
-// Copyright (C) 2004  Novell Inc.
+// Copyright (C) 2004 Novell, Inc (http://www.novell.com)
 //
-// Stub implementation written by Raja R Harinath <rharinath@novell.com>
+// Authors
+//     Raja R Harinath <rharinath@novell.com>
+//     Sebastien Pouliot  <sebastien@ximian.com>
 //
 
-using System.Security;
 using System.Security.Permissions;
 
-namespace System.DirectoryServices
-{
-       public class DirectoryServicesPermission : ResourcePermissionBase
-       {
-               DirectoryServicesPermissionEntryCollection entries;
+namespace System.DirectoryServices {
+
+       [Serializable]
+       public sealed class DirectoryServicesPermission : ResourcePermissionBase {
+
+               DirectoryServicesPermissionEntryCollection innerCollection;
 
-               [MonoTODO]
                public DirectoryServicesPermission ()
-               { throw new NotImplementedException ("System.DirectoryServices.DirectoryServicesPermission()"); }
+               {
+                       SetUp ();
+               }
 
-               [MonoTODO]
                public DirectoryServicesPermission (DirectoryServicesPermissionEntry[] entries)
                {
-                       entries = new DirectoryServicesPermissionEntryCollection ();
-                       entries.AddRange (entries);
+                       SetUp ();
+                       innerCollection = new DirectoryServicesPermissionEntryCollection (this);
+                       innerCollection.AddRange (entries);
                }
 
-               [MonoTODO]
-               public DirectoryServicesPermission (PermissionState ps)
-               { throw new NotImplementedException ("System.DirectoryServices.DirectoryServicesPermission(permission_state)"); }
+               public DirectoryServicesPermission (PermissionState state)
+                       : base (state)
+               {
+                       SetUp ();
+               }
 
-               [MonoTODO]
                public DirectoryServicesPermission (DirectoryServicesPermissionAccess access, string path)
                {
-                       entries = new DirectoryServicesPermissionEntryCollection ();
-                       entries.Add (new DirectoryServicesPermissionEntry (access, path));
+                       SetUp ();
+                       innerCollection = new DirectoryServicesPermissionEntryCollection (this);
+                       innerCollection.Add (new DirectoryServicesPermissionEntry (access, path));
+               }
+
+               public DirectoryServicesPermissionEntryCollection PermissionEntries {
+                       get {
+                               if (innerCollection == null) {
+                                       // must be here to work with XML deserialization
+                                       innerCollection = new DirectoryServicesPermissionEntryCollection (this);
+                               }
+                               return innerCollection;
+                       }
+               }
+
+               // helpers
+
+               private void SetUp ()
+               {
+                       PermissionAccessType = typeof (DirectoryServicesPermissionAccess);
+                       TagNames = new string[1] { "Path" };
                }
 
-               public DirectoryServicesPermissionEntryCollection PermissionEntries
+               internal ResourcePermissionBaseEntry[] GetEntries ()
                {
-                       [MonoTODO]
-                       get { return entries; }
+                       return base.GetPermissionEntries ();
+               }
+
+               internal void ClearEntries ()
+               {
+                       base.Clear ();
+               }
+
+               internal void Add (object obj) 
+               {
+                       DirectoryServicesPermissionEntry dspe = (obj as DirectoryServicesPermissionEntry);
+                       base.AddPermissionAccess (dspe.GetBaseEntry ());
+               }
+
+               internal void Remove (object obj) 
+               {
+                       DirectoryServicesPermissionEntry dspe = (obj as DirectoryServicesPermissionEntry);
+                       base.RemovePermissionAccess (dspe.GetBaseEntry ());
                }
        }
 }
-