From 21d58c80a3167fbf44c599e4be427f575b19cd86 Mon Sep 17 00:00:00 2001 From: nurfed Date: Sat, 23 Dec 2023 22:54:27 +0100 Subject: [PATCH] Fix authentication with DirectoryEntry --- src/CommonLib/LDAPUtils.cs | 24 ++++++++++++++++++------ 1 file changed, 18 insertions(+), 6 deletions(-) diff --git a/src/CommonLib/LDAPUtils.cs b/src/CommonLib/LDAPUtils.cs index bb757da8..7804ad4d 100644 --- a/src/CommonLib/LDAPUtils.cs +++ b/src/CommonLib/LDAPUtils.cs @@ -1702,18 +1702,30 @@ private class ResolvedWellKnownPrincipal public string GetConfigurationPath(string domainName = null) { - var rootDse = domainName == null - ? new DirectoryEntry("LDAP://RootDSE") - : new DirectoryEntry($"LDAP://{NormalizeDomainName(domainName)}/RootDSE"); + string path = domainName == null + ? "LDAP://RootDSE" + : $"LDAP://{NormalizeDomainName(domainName)}/RootDSE"; + + DirectoryEntry rootDse; + if (_ldapConfig.Username != null) + rootDse = new DirectoryEntry(path, _ldapConfig.Username, _ldapConfig.Password); + else + rootDse = new DirectoryEntry(path); return $"{rootDse.Properties["configurationNamingContext"]?[0]}"; } public string GetSchemaPath(string domainName) { - var rootDse = domainName == null - ? new DirectoryEntry("LDAP://RootDSE") - : new DirectoryEntry($"LDAP://{NormalizeDomainName(domainName)}/RootDSE"); + string path = domainName == null + ? "LDAP://RootDSE" + : $"LDAP://{NormalizeDomainName(domainName)}/RootDSE"; + + DirectoryEntry rootDse; + if (_ldapConfig.Username != null) + rootDse = new DirectoryEntry(path, _ldapConfig.Username, _ldapConfig.Password); + else + rootDse = new DirectoryEntry(path); return $"{rootDse.Properties["schemaNamingContext"]?[0]}"; }