Feedback

C# - Liefert ein Dictionary von Attributen von einem LDAP Object

Veröffentlicht von am 16.03.2007
(1 Bewertungen)
Habe mal das Snippet "Liefert ein Dictionary Object von LDAP Userattributen" dahingend verallgemeinert, so dass es auf alle LDAP-Objekte angewendet werden kann
GFU-Schulungen  [Anzeige]

ASP.NET 2.0 und 3.5

Dieser Kurs vermittelt Ihnen alle Erweiterungen von Microsoft ASP.NET 2.0. Zu diesen zählen u. a. Data Bindung, Master Pages, und Security.

JavaScript für .NET-Entwickler

Sie sind .NET-Entwickler und nun stehen Sie vor der Aufgabe, JavaScript in Ihre Arbeit einzubinden. Die Schulung vermittelt Ihnen die JavaScript Grundlagen und die Funktionen der Scriptsprache. Sie wissen, wie objektorientierte Programmierung in JavaScript funktioniert und lernen abschließend Best Practicies Fälle kennen.

/// <summary>
/// Liefert ein Dictionary von einem LDAP Object
/// </summary>
/// <param name="LDAPcn">Der eindeutige LDAP cn</param>
/// <param name="objectClass">Mögliche Werte "computer", "user", "group","organizationalunit" oder null.</param>
/// <param name="LDAPProperties">Liste der zu ermittelnden Properties
/// <example>
///    System.Collections.Generic.Dictionary<string, object> LDAPAttributs  = GetLDAPAttributes(Environment.UserName,"user",new List<string>(new string[] {"mail","cn", "lastlogon","distinguishedName"}));
///    System.Collections.Generic.Dictionary<string, object> LDAPAttributs1 = GetLDAPAttributes(Environment.MachineName, "computer", new List<string>(new string[] { "operatingSystem", "pwdLastSet", "lastlogon", "distinguishedName" }));
/// </example>
/// <returns></returns>
public System.Collections.Generic.Dictionary<string, object> GetLDAPAttributes(string LDAPcn, string objectClass, List<string> LDAPProperties)
{
	DirectorySearcher Searcher = new DirectorySearcher();
	SearchResultCollection SearchResults = null;
	for (int i = 0; i <= LDAPProperties.Count - 1; i++)
	{
		Searcher.PropertiesToLoad.Add(LDAPProperties[i]);
	}
	Searcher.SearchScope = SearchScope.Subtree;
	if (objectClass == null)
	{
		Searcher.Filter = "(cn=" + LDAPcn + ")";
	}
	else
	{
		objectClass = objectClass.ToUpper();
		switch (objectClass)
		{
			case "COMPUTER":
				Searcher.Filter = "(&(objectClass=computer)(cn=" + LDAPcn + "))";
				break;
			case "USER":
				Searcher.Filter = "(&(objectClass=user)(cn=" + LDAPcn + "))";
				break;
			case "GROUP":
				Searcher.Filter = "(&(objectClass=group)(cn=" + LDAPcn + "))";
				break;
			case "ORGANIZATIONALUNIT":
				Searcher.Filter = "(&(objectClass=organizationalUnit)(cn=" + LDAPcn + "))";
				break;
		}
	}
	System.DirectoryServices.DirectoryEntry adsiRoot = new System.DirectoryServices.DirectoryEntry("LDAP://RootDSE");
	Searcher.SearchRoot = new DirectoryEntry("LDAP://" + adsiRoot.Properties["defaultNamingContext"][0]);
	SearchResults = Searcher.FindAll();
	if (SearchResults.Count > 1)
	{
		return null;
	}
	else
	{
		System.Collections.Generic.Dictionary<string, object> LDAPPropertiesResults = new System.Collections.Generic.Dictionary<string, object>();
		foreach (SearchResult OutPut in SearchResults)
		{
			for (int i = 0; i <= LDAPProperties.Count - 1; i++)
			{
				try
				{
					LDAPPropertiesResults.Add(LDAPProperties[i], OutPut.Properties[LDAPProperties[i]][0]);
				}
				catch
				{
					LDAPPropertiesResults.Add(LDAPProperties[i], null);
				}
			}
		}
		return LDAPPropertiesResults;
	}
}
Abgelegt unter LDAP.

Kommentare zum Snippet

 

Logge dich ein, um hier zu kommentieren!