Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2006.06.18;
Скачать: CL | DM;

Вниз

Как улучшить поиск в LDAP? Есть такая конструкция, которая   Найти похожие ветки 

 
EgorovAlex ©   (2006-03-22 10:58) [0]

сначала возвращает путь пользователя, а потом по этому пути получает самого пользователя:

Connection := CreateOleObject("ADODB.Connection");
Command := CreateOleObject("ADODB.Command");
try
 Connection.Provider := "ADsDSOObject";
 Connection.Open("Active Directory Provider");
 Command.ActiveConnection := Connection;
 Command.Properties("Page Size") := 1000;
 Command.Properties("Searchscope") := ADS_SCOPE_SUBTREE;
 Command.CommandText := "SELECT distinguishedName FROM ""LDAP://" + UserDomain + """ WHERE objectCategory=""group"" AND sAMAccountName=""" + GrpName + """";
 try
   Res := Command.Execute;
   if not Res.EOF then
     AdsPath := Res.Fields[0].Value;
 except
 end;
 Res := NULL;
finally
 Command := NULL;
 Connection.Close;
 Connection := NULL;
end;
ADsGetObject(PWideChar("LDAP://" + AdsPath), IADsGroup, Group);

Так вот вопрос: как мне сразу после поиска в Res получить группу, а не путь для неё? Т.к. в данном случае делается лишний вызов ADsGetObject.
На vbs скрипте видел, что такое возможно.


 
Alex Konshin ©   (2006-03-22 11:56) [1]

Занятно... А я и не знал, что оно и SQL синтаксис поддерживает.
Насколько я понял тебе нужно выбрать объекты, у которых objectClass=person и memberOf=<DN_нужной_группы>. Сам думай, как оно в твоем случае будет выглядеть.
Сходи любым LDAP броузером на свой домен контролер, все становится понятно.
Единственная хитрость - узнать свой собственный DN чтобы приконнектится. Например, у меня дома CN=Alex Konshin,CN=Users,DC=home
Для меня откровением было, что в первом токене нужно не логин указывать, а полное имя.


 
EgorovAlex ©   (2006-03-22 13:02) [2]

Нет, мне не пользователи нужны, а нужно мне интерфейс группы из домена получить по её имени. Я не знаю как запрос построить и как потом результат в Group: IADsGroup загнать.


 
EgorovAlex ©   (2006-03-22 15:20) [3]

Ещё нашёл описание для интерфейса IADsNameTranslate - для получения LDAP пути. Но не могу на делфи это переделать:

" Determine DNS domain name from RootDSE object.
Set objRootDSE = G("LDAP://RootDSE")
strDNSDomain = objRootDSE.Get("defaultNamingContext")

" Use the NameTranslate object to find the NetBIS domain name from the
" DNS domain name.
Set objTrans = C("NameTranslate")
objTrans.Init 3, strDNSDomain
objTrans.Set 1, strDNSDomain
strNetBISDomain = objTrans.Get(3)
" Remove trailing backslash.
strNetBISDomain = Left(strNetBISDomain, Len(strNetBISDomain) - 1)

" Use the NameTranslate object to convert the NT user name to the
" Distinguished Name required for the LDAP provider.
objTrans.Init 1, strNetBISDomain
objTrans.Set 3, strNetBISDomain & "\" & strNTName
strUserDN = objTrans.Get(1)

" Bind to the user object in Active Directory with the LDAP provider.
Set objUser = G("LDAP://" & strUserDN)



Страницы: 1 вся ветка

Текущий архив: 2006.06.18;
Скачать: CL | DM;

Наверх




Память: 0.47 MB
Время: 0.081 c
2-1149239089
Trabl
2006-06-02 13:04
2006.06.18
Cannot focuse a disable or invisible window


1-1147537027
varfolomey
2006-05-13 20:17
2006.06.18
Баг с клавой


2-1148876092
lobach
2006-05-29 08:14
2006.06.18
Реестр


10-1120548108
WG
2005-07-05 11:21
2006.06.18
Глюк при передаче данных в Excel, не опознает дату


9-1131338381
JUS
2005-11-07 07:39
2006.06.18
DXWaveList1 : DelphiX