2 * Copyright 2000, OpenLDAP Foundation, All Rights Reserved.
3 * COPYING RESTRICTIONS APPLY, see COPYRIGHT file
7 #include "LDAPSearchRequest.h"
8 #include "LDAPException.h"
9 #include "LDAPSearchReference.h"
10 #include "LDAPResult.h"
11 #include "LDAPRequest.h"
14 LDAPSearchRequest::LDAPSearchRequest(const LDAPSearchRequest& req ) :
16 DEBUG(LDAP_DEBUG_CONSTRUCT,
17 "LDAPSearchRequest::LDAPSearchRequest(&)" << endl);
20 m_filter=req.m_filter;
22 m_attrsOnly=req.m_attrsOnly;
26 LDAPSearchRequest::LDAPSearchRequest(const string& base, int scope,
27 const string& filter, const StringList& attrs, bool attrsOnly,
28 LDAPAsynConnection *connect,
29 const LDAPConstraints* cons, bool isReferral,
30 const LDAPRequest* parent)
31 : LDAPRequest (connect,cons,isReferral,parent) {
33 DEBUG(LDAP_DEBUG_CONSTRUCT,
34 "LDAPSearchRequest:LDAPSearchRequest()" << endl);
35 DEBUG(LDAP_DEBUG_CONSTRUCT & LDAP_DEBUG_PARAMETER,
36 " base:" << base << endl << " scope:" << scope << endl
37 << " filter:" << filter << endl);
38 m_requestType=LDAPRequest::SEARCH;
39 //insert some validating and copying here
43 m_filter="objectClass=*";
48 m_attrsOnly=attrsOnly;
51 LDAPSearchRequest::~LDAPSearchRequest(){
52 DEBUG(LDAP_DEBUG_DESTROY, "LDAPSearchRequest::~LDAPSearchRequest" << endl);
55 LDAPMessageQueue* LDAPSearchRequest::sendRequest(){
57 DEBUG(LDAP_DEBUG_TRACE, "LDAPSearchRequest::sendRequest()" << endl);
58 timeval* tmptime=m_cons->getTimeoutStruct();
59 char** tmpattrs=m_attrs.toCharArray();
60 LDAPControl** tmpSrvCtrl=m_cons->getSrvCtrlsArray();
61 LDAPControl** tmpClCtrl=m_cons->getClCtrlsArray();
62 int aliasDeref = m_cons->getAliasDeref();
63 ldap_set_option(m_connection->getSessionHandle(), LDAP_OPT_DEREF,
65 int err=ldap_search_ext(m_connection->getSessionHandle(), m_base.c_str(),
66 m_scope, m_filter.c_str(), tmpattrs, m_attrsOnly, tmpSrvCtrl,
67 tmpClCtrl, tmptime, m_cons->getSizeLimit(), &msgID );
69 ldap_value_free(tmpattrs);
70 ldap_controls_free(tmpSrvCtrl);
71 ldap_controls_free(tmpClCtrl);
73 if (err != LDAP_SUCCESS){
74 throw LDAPException(err);
75 } else if (isReferral()){
80 return new LDAPMessageQueue(this);
84 LDAPRequest* LDAPSearchRequest::followReferral(LDAPMsg* ref){
85 DEBUG(LDAP_DEBUG_TRACE, "LDAPSearchRequest::followReferral()" << endl);
87 LDAPUrlList::const_iterator usedUrl;
88 LDAPAsynConnection* con;
91 if(ref->getMessageType() == LDAPMsg::SEARCH_REFERENCE){
92 urls = ((LDAPSearchReference *)ref)->getUrls();
94 urls = ((LDAPResult *)ref)->getReferralUrls();
96 con = getConnection()->referralConnect(urls,usedUrl,m_cons);
98 if((usedUrl->getFilter() != "") &&
99 (usedUrl->getFilter() != m_filter)){
100 filter=usedUrl->getFilter();
104 if( (ref->getMessageType() == LDAPMsg::SEARCH_REFERENCE) &&
105 (m_scope == LDAPAsynConnection::SEARCH_ONE)
107 scope = LDAPAsynConnection::SEARCH_BASE;
108 DEBUG(LDAP_DEBUG_TRACE," adjusted scope to BASE" << endl);
115 return new LDAPSearchRequest(usedUrl->getDN(), scope, filter,
116 m_attrs, m_attrsOnly, con, m_cons,true,this);
119 bool LDAPSearchRequest::equals(const LDAPRequest* req)const{
120 DEBUG(LDAP_DEBUG_TRACE,"LDAPSearchRequest::equals()" << endl);
121 if( LDAPRequest::equals(req)){
122 LDAPSearchRequest* sreq = (LDAPSearchRequest*)req;
123 if ( (m_base == sreq->m_base) &&
124 (m_scope == sreq->m_scope)