You've already forked linux-packaging-mono
							
							
		
			
				
	
	
		
			272 lines
		
	
	
		
			9.3 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
			
		
		
	
	
			272 lines
		
	
	
		
			9.3 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
| #region Using directives
 | |
| 
 | |
| using System;
 | |
| using System.Collections.Generic;
 | |
| using System.Text;
 | |
| using System.DirectoryServices;
 | |
| using System.Security.Permissions;
 | |
| using System.Security.Principal;
 | |
| using System.Runtime.Serialization;
 | |
| 
 | |
| using System.Workflow.ComponentModel;
 | |
| using System.Diagnostics;
 | |
| 
 | |
| #endregion
 | |
| 
 | |
| namespace System.Workflow.Activities
 | |
| {
 | |
|     [Serializable]
 | |
|     [Obsolete("The System.Workflow.* types are deprecated.  Instead, please use the new types from System.Activities.*")]
 | |
|     public abstract class WorkflowRole
 | |
|     {
 | |
|         public abstract String Name { set; get; }
 | |
| 
 | |
|         public abstract IList<String> GetIdentities();
 | |
| 
 | |
|         public abstract bool IncludesIdentity(String identity);
 | |
|     }
 | |
| 
 | |
|     [Serializable]
 | |
|     [Obsolete("The System.Workflow.* types are deprecated.  Instead, please use the new types from System.Activities.*")]
 | |
|     sealed public class WorkflowRoleCollection : List<WorkflowRole>
 | |
|     {
 | |
|         public WorkflowRoleCollection()
 | |
|             : base()
 | |
|         {
 | |
|         }
 | |
| 
 | |
|         public bool IncludesIdentity(String identity)
 | |
|         {
 | |
|             if (identity == null)
 | |
|                 return false;
 | |
| 
 | |
|             foreach (WorkflowRole role in this)
 | |
|             {
 | |
|                 if (role != null)
 | |
|                 {
 | |
|                     if (role.IncludesIdentity(identity))
 | |
|                         return true;
 | |
|                 }
 | |
|             }
 | |
| 
 | |
|             return false;
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     [Serializable]
 | |
|     [Obsolete("The System.Workflow.* types are deprecated.  Instead, please use the new types from System.Activities.*")]
 | |
|     sealed public class ActiveDirectoryRole : WorkflowRole, ISerializable, IDisposable
 | |
|     {
 | |
|         private String m_name;
 | |
|         private DirectoryEntry m_root;
 | |
|         private List<IDirectoryOperation> m_operations;
 | |
| 
 | |
|         internal ActiveDirectoryRole(DirectoryEntry rootEntry, IDirectoryOperation operation)
 | |
|         {
 | |
|             if (rootEntry == null)
 | |
|                 throw new ArgumentNullException("rootEntry");
 | |
| 
 | |
|             this.m_root = rootEntry;
 | |
| 
 | |
|             this.m_operations = new List<IDirectoryOperation>();
 | |
|             if (operation != null)
 | |
|                 this.m_operations.Add(operation);
 | |
|         }
 | |
| 
 | |
|         internal ActiveDirectoryRole(DirectoryEntry rootEntry, ICollection<IDirectoryOperation> operations)
 | |
|         {
 | |
|             if (rootEntry == null)
 | |
|                 throw new ArgumentNullException("rootEntry");
 | |
| 
 | |
|             this.m_root = rootEntry;
 | |
| 
 | |
|             if (operations == null)
 | |
|                 this.m_operations = new List<IDirectoryOperation>();
 | |
|             else
 | |
|                 this.m_operations = new List<IDirectoryOperation>(operations);
 | |
|         }
 | |
| 
 | |
|         private ActiveDirectoryRole(SerializationInfo info, StreamingContext context)
 | |
|         {
 | |
|             this.m_name = info.GetString("m_name");
 | |
|             this.m_operations = (List<IDirectoryOperation>)info.GetValue("m_operations", typeof(List<IDirectoryOperation>));
 | |
| 
 | |
|             String path = info.GetString("m_root\\path");
 | |
| 
 | |
|             this.m_root = new DirectoryEntry(path);
 | |
|         }
 | |
| 
 | |
|         [SecurityPermission(SecurityAction.Demand, SerializationFormatter = true)]
 | |
|         void ISerializable.GetObjectData(SerializationInfo info, StreamingContext context)
 | |
|         {
 | |
|             info.AddValue("m_name", this.m_name);
 | |
|             info.AddValue("m_operations", this.m_operations);
 | |
| 
 | |
|             info.AddValue("m_root\\path", this.m_root.Path);
 | |
|         }
 | |
| 
 | |
|         public override String Name
 | |
|         {
 | |
|             get
 | |
|             {
 | |
|                 return this.m_name;
 | |
|             }
 | |
| 
 | |
|             set
 | |
|             {
 | |
|                 this.m_name = value;
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         public DirectoryEntry RootEntry
 | |
|         {
 | |
|             get
 | |
|             {
 | |
|                 return this.m_root;
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         internal ICollection<IDirectoryOperation> Operations
 | |
|         {
 | |
|             get
 | |
|             {
 | |
|                 return this.m_operations;
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         public ActiveDirectoryRole GetManager()
 | |
|         {
 | |
|             List<IDirectoryOperation> queries = new List<IDirectoryOperation>(this.Operations);
 | |
|             queries.Add(new DirectoryRedirect(ActiveDirectoryRoleFactory.Configuration.DistinguishedName, ActiveDirectoryRoleFactory.Configuration.DirectReports));
 | |
| 
 | |
|             return new ActiveDirectoryRole(this.RootEntry, queries);
 | |
|         }
 | |
| 
 | |
|         public ActiveDirectoryRole GetManagerialChain()
 | |
|         {
 | |
|             List<IDirectoryOperation> queries = new List<IDirectoryOperation>(this.Operations);
 | |
|             queries.Add(new DirectoryRedirect(ActiveDirectoryRoleFactory.Configuration.DistinguishedName, ActiveDirectoryRoleFactory.Configuration.DirectReports, true));
 | |
| 
 | |
|             return new ActiveDirectoryRole(this.RootEntry, queries);
 | |
|         }
 | |
| 
 | |
|         public ActiveDirectoryRole GetDirectReports()
 | |
|         {
 | |
|             List<IDirectoryOperation> queries = new List<IDirectoryOperation>(this.Operations);
 | |
|             queries.Add(new DirectoryRedirect(ActiveDirectoryRoleFactory.Configuration.DistinguishedName, ActiveDirectoryRoleFactory.Configuration.Manager));
 | |
| 
 | |
|             return new ActiveDirectoryRole(this.RootEntry, queries);
 | |
|         }
 | |
| 
 | |
|         public ActiveDirectoryRole GetAllReports()
 | |
|         {
 | |
|             List<IDirectoryOperation> queries = new List<IDirectoryOperation>(this.Operations);
 | |
|             queries.Add(new DirectoryRedirect(ActiveDirectoryRoleFactory.Configuration.DistinguishedName, ActiveDirectoryRoleFactory.Configuration.Manager, true));
 | |
| 
 | |
|             return new ActiveDirectoryRole(this.RootEntry, queries);
 | |
|         }
 | |
| 
 | |
|         public ActiveDirectoryRole GetPeers()
 | |
|         {
 | |
|             ICollection<DirectoryEntry> entries = this.GetEntries();
 | |
| 
 | |
|             List<IDirectoryOperation> queries = new List<IDirectoryOperation>(this.Operations);
 | |
|             queries.Add(new DirectoryRedirect(ActiveDirectoryRoleFactory.Configuration.DistinguishedName, ActiveDirectoryRoleFactory.Configuration.DirectReports));
 | |
|             queries.Add(new DirectoryRedirect(ActiveDirectoryRoleFactory.Configuration.DistinguishedName, ActiveDirectoryRoleFactory.Configuration.Manager));
 | |
| 
 | |
|             foreach (DirectoryEntry entry in entries)
 | |
|             {
 | |
|                 queries.Add(new DirectoryLocalQuery(ActiveDirectoryRoleFactory.Configuration.DistinguishedName, (String)entry.Properties[ActiveDirectoryRoleFactory.Configuration.DistinguishedName][0], DirectoryQueryOperation.NotEqual));
 | |
|             }
 | |
| 
 | |
|             return new ActiveDirectoryRole(this.RootEntry, queries);
 | |
|         }
 | |
| 
 | |
| 
 | |
|         public ICollection<DirectoryEntry> GetEntries()
 | |
|         {
 | |
|             List<DirectoryEntry> currentEntries = new List<DirectoryEntry>();
 | |
|             currentEntries.Add(this.m_root);
 | |
|             List<DirectoryEntry> newEntries = new List<DirectoryEntry>();
 | |
| 
 | |
|             for (int i = 0; i < this.m_operations.Count; ++i)
 | |
|             {
 | |
|                 for (int j = 0; j < currentEntries.Count; ++j)
 | |
|                 {
 | |
|                     this.m_operations[i].GetResult(this.m_root, currentEntries[j], newEntries);
 | |
|                 }
 | |
| 
 | |
|                 // Swap between new and current, as the for the new iteration the 'new' of
 | |
|                 // now will be the current.  After the swap we clear out the 'new' list as to
 | |
|                 // reuse it.
 | |
| 
 | |
|                 List<DirectoryEntry> tempEntries = currentEntries;
 | |
|                 currentEntries = newEntries;
 | |
|                 newEntries = tempEntries;
 | |
|                 newEntries.Clear();
 | |
|             }
 | |
| 
 | |
|             // Remove duplicates
 | |
| 
 | |
|             Dictionary<Guid, DirectoryEntry> dFinal = new Dictionary<Guid, DirectoryEntry>();
 | |
|             for (int i = 0; i < currentEntries.Count; ++i)
 | |
|             {
 | |
|                 if (!dFinal.ContainsKey(currentEntries[i].Guid))
 | |
|                     dFinal.Add(currentEntries[i].Guid, currentEntries[i]);
 | |
|             }
 | |
| 
 | |
|             return dFinal.Values;
 | |
|         }
 | |
| 
 | |
|         public IList<SecurityIdentifier> GetSecurityIdentifiers()
 | |
|         {
 | |
|             List<SecurityIdentifier> identifiers = new List<SecurityIdentifier>();
 | |
| 
 | |
|             foreach (DirectoryEntry entry in this.GetEntries())
 | |
|             {
 | |
|                 if (entry.Properties["objectSid"] != null &&
 | |
|                     entry.Properties["objectSid"].Count != 0)
 | |
|                 {
 | |
|                     identifiers.Add(new SecurityIdentifier((byte[])(entry.Properties["objectSid"][0]), 0));
 | |
|                 }
 | |
|                 else
 | |
|                 {
 | |
|                     WorkflowActivityTrace.Activity.TraceEvent(TraceEventType.Information, 0, "Unable to find 'objectSid' property for directory entry = {0}.", entry.Path);
 | |
|                 }
 | |
|             }
 | |
| 
 | |
|             return identifiers;
 | |
|         }
 | |
| 
 | |
|         public override IList<String> GetIdentities()
 | |
|         {
 | |
|             List<String> identityRefs = new List<String>();
 | |
|             foreach (SecurityIdentifier entrySid in this.GetSecurityIdentifiers())
 | |
|             {
 | |
|                 identityRefs.Add(entrySid.Translate(typeof(NTAccount)).ToString());
 | |
|             }
 | |
|             return identityRefs;
 | |
|         }
 | |
| 
 | |
|         public override bool IncludesIdentity(String identity)
 | |
|         {
 | |
|             if (identity == null)
 | |
|                 return false;
 | |
| 
 | |
|             foreach (String roleIdentity in this.GetIdentities())
 | |
|             {
 | |
|                 if (String.Compare(identity, roleIdentity, StringComparison.Ordinal) == 0)
 | |
|                     return true;
 | |
|             }
 | |
| 
 | |
|             return false;
 | |
|         }
 | |
| 
 | |
|         void IDisposable.Dispose()
 | |
|         {
 | |
|             this.m_root.Dispose();
 | |
|         }
 | |
| 
 | |
|     }
 | |
| }
 |