System.DirectoryServices 9.0.1

Prefix Reserved
dotnet add package System.DirectoryServices --version 9.0.1                
NuGet\Install-Package System.DirectoryServices -Version 9.0.1                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="System.DirectoryServices" Version="9.0.1" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add System.DirectoryServices --version 9.0.1                
#r "nuget: System.DirectoryServices, 9.0.1"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install System.DirectoryServices as a Cake Addin
#addin nuget:?package=System.DirectoryServices&version=9.0.1

// Install System.DirectoryServices as a Cake Tool
#tool nuget:?package=System.DirectoryServices&version=9.0.1                

About

Provides easy access to Active Directory Domain Services from managed code. Microsoft Active Directory Domain Services are the foundation for distributed networks built on Windows 2000 Server, Windows Server 2003 and Microsoft Windows Server 2008 operating systems that use domain controllers. The namespace contains two component classes, DirectoryEntry and DirectorySearcher, which use the Active Directory Services Interfaces (ADSI) technology. ADSI is the set of interfaces that Microsoft provides as a flexible tool for working with a variety of network providers. ADSI gives the administrator the ability to locate and manage resources on a network with relative ease, regardless of the size of the network.

Key Features

Active Directory Domain Services use a tree structure. Each node in the tree contains a set of properties. Use this library to traverse, search, and modify the tree, and read and write to the properties of a node.

  • The DirectoryEntry class encapsulates a node or object in the Active Directory Domain Services hierarchy. Use this class for binding to objects, reading properties, and updating attributes. Together with helper classes, DirectoryEntry provides support for life-cycle management and navigation methods, including creating, deleting, renaming, moving a child node, and enumerating children.
  • Use the DirectorySearcher class to perform queries against the Active Directory Domain Services hierarchy. LDAP is the only system-supplied Active Directory Service Interfaces (ADSI) provider that supports searching. A search of the Active Directory Domain Services hierarchy through DirectorySearcher returns instances of SearchResult, which are contained in an instance of the SearchResultCollection class.
  • Network administrators write scripts and applications that access Active Directory Domain Services to automate common administrative tasks, such as adding users and groups, managing printers, and setting permissions for network resources.

How to Use

Install the System.DirectoryServices library from nuget

dotnet add package System.DirectoryServices --version 7.0.1

The sample needs a real path to an Active Directory server to work properly:

using System.DirectoryServices;

namespace TestDirectoryServices
{
    internal class Program
    {
        static void Main(string[] args)
        {
            DirectoryEntry rootDse = new DirectoryEntry("LDAP://RootDSE");
            string configNamingContext = rootDse.Properties["configurationNamingContext"].Value.ToString();

            DirectoryEntry certTemplates = new DirectoryEntry("LDAP://CN=Certificate Templates,CN=Public Key Services,CN=Services," + configNamingContext);
            DirectorySearcher templatesSearch = new DirectorySearcher(certTemplates, "(objectClass=pKICertificateTemplate)", null, SearchScope.OneLevel);

            SearchResultCollection templates = templatesSearch.FindAll();

            foreach (SearchResult template in templates)
            {
                Console.WriteLine($"Name: {template.Properties["name"][0]} ({template.Properties["displayName"][0]})");
                Console.WriteLine($"Flags: {template.Properties["msPKI-Enrollment-Flag"][0]}");
            }
        }
    }
}

Main Types

The main types provided by this library are:

  • System.DirectoryServices.DirectoryEntry
  • System.DirectoryServices.DirectorySearcher

Additional Documentation

Feedback & Contributing

System.DirectoryServices is released as open source under the MIT license. Bug reports and contributions are welcome at the GitHub repository.

Product Compatible and additional computed target framework versions.
.NET net5.0 was computed.  net5.0-windows was computed.  net6.0 was computed.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 was computed.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 is compatible.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed.  net9.0 is compatible.  net9.0-android was computed.  net9.0-browser was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-macos was computed.  net9.0-tvos was computed.  net9.0-windows was computed. 
.NET Core netcoreapp2.0 was computed.  netcoreapp2.1 was computed.  netcoreapp2.2 was computed.  netcoreapp3.0 was computed.  netcoreapp3.1 was computed. 
.NET Standard netstandard2.0 is compatible.  netstandard2.1 was computed. 
.NET Framework net461 was computed.  net462 is compatible.  net463 was computed.  net47 was computed.  net471 was computed.  net472 was computed.  net48 was computed.  net481 was computed. 
MonoAndroid monoandroid was computed. 
MonoMac monomac was computed. 
MonoTouch monotouch was computed. 
Tizen tizen40 was computed.  tizen60 was computed. 
Xamarin.iOS xamarinios was computed. 
Xamarin.Mac xamarinmac was computed. 
Xamarin.TVOS xamarintvos was computed. 
Xamarin.WatchOS xamarinwatchos was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (232)

Showing the top 5 NuGet packages that depend on System.DirectoryServices:

Package Downloads
System.DirectoryServices.AccountManagement

Provides uniform access and manipulation of user, computer, and group security principals across the multiple principal stores: Active Directory Domain Services (AD DS), Active Directory Lightweight Directory Services (AD LDS), and Machine SAM (MSAM).

Microsoft.Windows.Compatibility

This Windows Compatibility Pack provides access to APIs that were previously available only for .NET Framework. It can be used from both .NET as well as .NET Standard.

System.Management.Automation

Runtime for hosting PowerShell

Microsoft.Exchange.WebServices.NETStandard

The Exchange Web Services (EWS) Managed API provides a managed interface for developing .NET client applications that use EWS. By using the EWS Managed API, you can access almost all the information stored in an Office 365, Exchange Online, or Exchange Server mailbox.

CoreWCF.Primitives

CoreWCF is a port of the service side of Windows Communication Foundation (WCF) to .NET Core. The goal of this project is to enable existing WCF services to move to .NET Core.

GitHub repositories (32)

Showing the top 5 popular GitHub repositories that depend on System.DirectoryServices:

Repository Stars
PowerShell/PowerShell
PowerShell for every system!
mRemoteNG/mRemoteNG
mRemoteNG is the next generation of mRemote, open source, tabbed, multi-protocol, remote connections manager.
opserver/Opserver
Stack Exchange's Monitoring System
exceptionless/Exceptionless
Exceptionless application
filoe/cscore
An advanced audio library, written in C#. Provides tons of features. From playing/recording audio to decoding/encoding audio streams/files to processing audio data in realtime (e.g. applying custom effects during playback, create visualizations,...). The possibilities are nearly unlimited.
Version Downloads Last updated
9.0.1 17,571 1/14/2025
9.0.0 274,579 11/12/2024
9.0.0-rc.2.24473.5 23,117 10/8/2024
9.0.0-rc.1.24431.7 13,455 9/10/2024
9.0.0-preview.7.24405.7 8,063 8/13/2024
9.0.0-preview.6.24327.7 16,153 7/9/2024
9.0.0-preview.5.24306.7 6,972 6/11/2024
9.0.0-preview.4.24266.19 5,658 5/21/2024
9.0.0-preview.3.24172.9 9,555 4/11/2024
9.0.0-preview.2.24128.5 1,789 3/12/2024
9.0.0-preview.1.24080.9 17,166 2/13/2024
8.0.0 9,601,690 11/14/2023
8.0.0-rc.2.23479.6 18,709 10/10/2023
8.0.0-rc.1.23419.4 67,416 9/12/2023
8.0.0-preview.7.23375.6 24,136 8/8/2023
8.0.0-preview.6.23329.7 13,448 7/11/2023
8.0.0-preview.5.23280.8 2,331 6/13/2023
8.0.0-preview.4.23259.5 15,982 5/16/2023
8.0.0-preview.3.23174.8 30,436 4/11/2023
8.0.0-preview.2.23128.3 16,350 3/14/2023
8.0.0-preview.1.23110.8 11,905 2/21/2023
7.0.1 6,189,637 2/14/2023
7.0.0 4,799,836 11/7/2022
7.0.0-rc.2.22472.3 17,140 10/11/2022
7.0.0-rc.1.22426.10 64,299 9/14/2022
7.0.0-preview.7.22375.6 14,839 8/9/2022
7.0.0-preview.6.22324.4 5,139 7/12/2022
7.0.0-preview.5.22301.12 2,007 6/14/2022
7.0.0-preview.4.22229.4 11,700 5/10/2022
7.0.0-preview.3.22175.4 3,101 4/13/2022
7.0.0-preview.2.22152.2 13,466 3/14/2022
7.0.0-preview.1.22076.8 6,449 2/17/2022
6.0.2 17,007 11/12/2024
6.0.1 14,480,877 2/14/2023
6.0.0 17,298,970 11/8/2021
6.0.0-rc.2.21480.5 18,148 10/12/2021
6.0.0-rc.1.21451.13 14,350 9/14/2021
6.0.0-preview.7.21377.19 7,904 8/10/2021
6.0.0-preview.6.21352.12 9,593 7/14/2021
6.0.0-preview.5.21301.5 13,836 6/15/2021
6.0.0-preview.4.21253.7 24,245 5/24/2021
6.0.0-preview.3.21201.4 11,398 4/8/2021
6.0.0-preview.2.21154.6 24,484 3/11/2021
6.0.0-preview.1.21102.12 26,513 2/12/2021
5.0.0 43,578,420 11/9/2020 5.0.0 is deprecated because it is no longer maintained.
5.0.0-rc.2.20475.5 13,309 10/13/2020
5.0.0-rc.1.20451.14 14,255 9/14/2020
5.0.0-preview.8.20407.11 13,284 8/25/2020
5.0.0-preview.7.20364.11 22,819 7/21/2020
5.0.0-preview.6.20305.6 9,753 6/25/2020
5.0.0-preview.5.20278.1 7,388 6/10/2020
5.0.0-preview.4.20251.6 19,078 5/18/2020
5.0.0-preview.3.20214.6 32,933 4/23/2020
5.0.0-preview.2.20160.6 20,516 4/2/2020
5.0.0-preview.1.20120.5 4,663 3/16/2020
4.7.0 22,280,645 12/3/2019
4.7.0-preview3.19551.4 4,416 11/13/2019
4.7.0-preview2.19523.17 15,330 11/1/2019
4.7.0-preview1.19504.10 11,762 10/15/2019
4.6.0 3,061,609 9/23/2019
4.6.0-rc1.19456.4 59,149 9/16/2019
4.6.0-preview9.19421.4 4,085 9/4/2019
4.6.0-preview9.19416.11 517 9/4/2019
4.6.0-preview8.19405.3 7,142 8/13/2019
4.6.0-preview7.19362.9 12,254 7/23/2019
4.6.0-preview6.19303.8 50,699 6/12/2019
4.6.0-preview6.19264.9 523 9/4/2019
4.6.0-preview5.19224.8 28,104 5/6/2019
4.6.0-preview4.19212.13 3,703 4/18/2019
4.6.0-preview3.19128.7 9,647 3/6/2019
4.6.0-preview.19073.11 40,033 1/29/2019
4.6.0-preview.18571.3 18,517 12/3/2018
4.5.0 14,984,529 5/29/2018
4.5.0-rc1 99,578 5/6/2018
4.5.0-preview2-26406-04 34,280 4/10/2018
4.5.0-preview1-26216-02 84,173 2/26/2018
4.5.0-preview1-25914-04 376,179 11/15/2017