2008-03-28 19:27:24 +08:00
|
|
|
// $OpenLDAP$
|
2000-09-02 02:46:32 +08:00
|
|
|
/*
|
2011-03-29 09:08:19 +08:00
|
|
|
* Copyright 2000-2011 The OpenLDAP Foundation, All Rights Reserved.
|
2000-09-02 02:46:32 +08:00
|
|
|
* COPYING RESTRICTIONS APPLY, see COPYRIGHT file
|
|
|
|
*/
|
|
|
|
|
2008-03-08 00:46:23 +08:00
|
|
|
#include <iostream>
|
|
|
|
#include <sstream>
|
2000-10-04 02:25:34 +08:00
|
|
|
#include "LDAPConnection.h"
|
2000-09-02 02:46:32 +08:00
|
|
|
#include "LDAPConstraints.h"
|
2000-10-04 02:25:34 +08:00
|
|
|
#include "LDAPSearchReference.h"
|
|
|
|
#include "LDAPSearchResults.h"
|
|
|
|
#include "LDAPAttribute.h"
|
|
|
|
#include "LDAPAttributeList.h"
|
|
|
|
#include "LDAPEntry.h"
|
|
|
|
#include "LDAPException.h"
|
|
|
|
#include "LDAPModification.h"
|
|
|
|
|
2008-03-08 00:46:23 +08:00
|
|
|
#include "debug.h"
|
2000-09-02 02:46:32 +08:00
|
|
|
|
|
|
|
int main(){
|
2000-10-04 02:25:34 +08:00
|
|
|
LDAPConstraints* cons=new LDAPConstraints;
|
|
|
|
LDAPControlSet* ctrls=new LDAPControlSet;
|
|
|
|
ctrls->add(LDAPCtrl(LDAP_CONTROL_MANAGEDSAIT));
|
|
|
|
cons->setServerControls(ctrls);
|
|
|
|
LDAPConnection *lc=new LDAPConnection("localhost",9009);
|
|
|
|
lc->setConstraints(cons);
|
2007-09-21 19:27:23 +08:00
|
|
|
std::cout << "----------------------doing bind...." << std::endl;
|
2000-09-02 02:46:32 +08:00
|
|
|
try{
|
2000-10-04 02:25:34 +08:00
|
|
|
lc->bind("cn=Manager,o=Organisation,c=DE" , "secret",cons);
|
2007-09-21 19:27:23 +08:00
|
|
|
std::cout << lc->getHost() << std::endl;
|
2000-10-04 02:25:34 +08:00
|
|
|
bool result = lc->compare("cn=Manager,o=Organisation,c=DE",
|
|
|
|
LDAPAttribute("cn","Manaer"));
|
2007-09-21 19:27:23 +08:00
|
|
|
std::cout << "Compare: " << result << std::endl;
|
2000-10-04 02:25:34 +08:00
|
|
|
|
|
|
|
LDAPAttributeList* attrs=new LDAPAttributeList();
|
|
|
|
StringList values;
|
2000-10-12 01:18:27 +08:00
|
|
|
StringList s2;
|
2000-10-04 02:25:34 +08:00
|
|
|
values.add("top");
|
|
|
|
values.add("Person");
|
|
|
|
attrs->addAttribute(LDAPAttribute("objectClass",values));
|
|
|
|
attrs->addAttribute(LDAPAttribute("cn","Peter"));
|
|
|
|
attrs->addAttribute(LDAPAttribute("sn","Peter,hallo"));
|
|
|
|
LDAPEntry* entry=new LDAPEntry(
|
|
|
|
"cn=Peter , o=Organisation, c=DE", attrs);
|
|
|
|
// lc->add(entry);
|
|
|
|
|
|
|
|
// lc->del("ou=Groups,o=Organisation,c=DE");
|
|
|
|
|
|
|
|
LDAPSearchResults* entries = lc->search("o=Organisation,c=DE",
|
|
|
|
LDAPConnection::SEARCH_ONE);
|
|
|
|
if (entries != 0){
|
|
|
|
LDAPEntry* entry = entries->getNext();
|
|
|
|
if(entry != 0){
|
2007-09-21 19:27:23 +08:00
|
|
|
std::cout << *(entry) << std::endl;
|
2000-10-04 02:25:34 +08:00
|
|
|
}
|
|
|
|
while(entry){
|
|
|
|
try{
|
|
|
|
entry = entries->getNext();
|
|
|
|
if(entry != 0){
|
2007-09-21 19:27:23 +08:00
|
|
|
std::cout << *(entry) << std::endl;
|
2000-10-04 02:25:34 +08:00
|
|
|
}
|
|
|
|
delete entry;
|
|
|
|
}catch(LDAPReferralException e){
|
2007-09-21 19:27:23 +08:00
|
|
|
std::cout << "Caught Referral" << std::endl;
|
2000-10-04 02:25:34 +08:00
|
|
|
}
|
|
|
|
}
|
2000-09-02 02:46:32 +08:00
|
|
|
}
|
2000-10-04 02:25:34 +08:00
|
|
|
|
|
|
|
lc->unbind();
|
|
|
|
delete lc;
|
2008-03-28 19:27:24 +08:00
|
|
|
}catch (LDAPException &e){
|
2007-09-21 19:27:23 +08:00
|
|
|
std::cout << "-------------- caught Exception ---------"<< std::endl;
|
|
|
|
std::cout << e << std::endl;
|
2000-09-02 02:46:32 +08:00
|
|
|
}
|
2000-10-04 02:25:34 +08:00
|
|
|
|
|
|
|
/*
|
2007-09-21 19:27:23 +08:00
|
|
|
std::cout << "--------------------starting search" << std::endl;
|
2000-10-04 02:25:34 +08:00
|
|
|
LDAPAttributeList* attrs=new LDAPAttributeList();
|
|
|
|
StringList values;
|
|
|
|
values.add("top");
|
|
|
|
values.add("organizationalUnit");
|
|
|
|
attrs->addAttribute(LDAPAttribute("objectClass",values));
|
|
|
|
attrs->addAttribute(LDAPAttribute("ou","Groups"));
|
|
|
|
LDAPEntry* entry=new LDAPEntry(
|
|
|
|
"ou=Groups, o=Organisation, c=DE", attrs);
|
|
|
|
|
|
|
|
LDAPAttribute newattr("description");
|
|
|
|
LDAPModification::mod_op op = LDAPModification::OP_DELETE;
|
|
|
|
LDAPModList *mod=new LDAPModList();
|
|
|
|
mod->addModification(LDAPModification(newattr,op));
|
|
|
|
LDAPMessageQueue* q=0;
|
2000-09-02 02:46:32 +08:00
|
|
|
try{
|
2000-10-04 02:25:34 +08:00
|
|
|
q=lc->search("o=Organisation,c=de",LDAPAsynConnection::SEARCH_SUB,
|
|
|
|
"objectClass=*",StringList());
|
|
|
|
// q=lc->add(entry);
|
|
|
|
// q=lc->modify("cn=Manager,o=Organisation,c=DE",
|
|
|
|
// mod);
|
|
|
|
LDAPMsg *res=q->getNext();
|
2000-09-02 02:46:32 +08:00
|
|
|
bool cont=true;
|
2000-10-04 02:25:34 +08:00
|
|
|
while( cont ) {
|
2000-09-02 02:46:32 +08:00
|
|
|
switch(res->getMessageType()){
|
|
|
|
LDAPSearchResult *res2;
|
2000-10-04 02:25:34 +08:00
|
|
|
const LDAPEntry *entry;
|
2000-09-02 02:46:32 +08:00
|
|
|
case LDAP_RES_SEARCH_ENTRY :
|
|
|
|
res2= (LDAPSearchResult*)res;
|
|
|
|
entry= res2->getEntry();
|
2007-09-21 19:27:23 +08:00
|
|
|
std::cout << "Entry: " << *entry << std::endl;
|
2000-09-02 02:46:32 +08:00
|
|
|
delete res;
|
|
|
|
res=q->getNext();
|
|
|
|
break;
|
|
|
|
case LDAP_RES_SEARCH_REFERENCE :
|
2007-09-21 19:27:23 +08:00
|
|
|
std::cout << "Reference: " << std::endl;
|
2000-09-02 02:46:32 +08:00
|
|
|
delete res;
|
|
|
|
res=q->getNext();
|
|
|
|
break;
|
|
|
|
default :
|
2007-09-21 19:27:23 +08:00
|
|
|
std::cout << ( *(LDAPResult*) res) << std::endl;
|
2000-09-02 02:46:32 +08:00
|
|
|
delete res;
|
2007-09-21 19:27:23 +08:00
|
|
|
std::cout << "-----------------search done" << std::endl;
|
2000-09-02 02:46:32 +08:00
|
|
|
cont=false;
|
|
|
|
break;
|
|
|
|
}
|
2000-10-04 02:25:34 +08:00
|
|
|
}
|
2000-09-02 02:46:32 +08:00
|
|
|
delete q;
|
2000-10-04 02:25:34 +08:00
|
|
|
}catch (LDAPException e){
|
2007-09-21 19:27:23 +08:00
|
|
|
std::cout << "----------------error during search" << std::endl;
|
2000-10-04 02:25:34 +08:00
|
|
|
delete q;
|
2007-09-21 19:27:23 +08:00
|
|
|
std::cout << e << std::endl;
|
2000-10-04 02:25:34 +08:00
|
|
|
}
|
|
|
|
lc->unbind();
|
|
|
|
*/
|
2000-09-02 02:46:32 +08:00
|
|
|
}
|
|
|
|
|