2 * Copyright 2000, OpenLDAP Foundation, All Rights Reserved.
3 * COPYING RESTRICTIONS APPLY, see COPYRIGHT file
10 #include "LDAPModifyRequest.h"
11 #include "LDAPException.h"
12 #include "LDAPMessageQueue.h"
13 #include "LDAPResult.h"
17 LDAPModifyRequest::LDAPModifyRequest(const LDAPModifyRequest& req) :
19 DEBUG(LDAP_DEBUG_CONSTRUCT,
20 "LDAPModifyRequest::LDAPModifyRequest(&)" << endl);
21 m_modList = new LDAPModList(*(req.m_modList));
25 LDAPModifyRequest::LDAPModifyRequest(const string& dn,
26 const LDAPModList *modList, LDAPAsynConnection *connect,
27 const LDAPConstraints *cons, bool isReferral,
28 const LDAPRequest* parent) :
29 LDAPRequest(connect, cons, isReferral, parent){
30 DEBUG(LDAP_DEBUG_CONSTRUCT,
31 "LDAPModifyRequest::LDAPModifyRequest(&)" << endl);
32 DEBUG(LDAP_DEBUG_CONSTRUCT | LDAP_DEBUG_PARAMETER,
33 " dn:" << dn << endl);
35 m_modList = new LDAPModList(*modList);
38 LDAPModifyRequest::~LDAPModifyRequest(){
39 DEBUG(LDAP_DEBUG_DESTROY,
40 "LDAPModifyRequest::~LDAPModifyRequest()" << endl);
42 // flush this entry from cache.
43 //m_connection->uncache_entry(m_dn);
44 // I think we need to do this... (j.costlow)
45 m_connection->flush_cache();
48 LDAPMessageQueue* LDAPModifyRequest::sendRequest(){
49 DEBUG(LDAP_DEBUG_TRACE, "LDAPModifyRequest::sendRequest()" << endl);
51 LDAPControl** tmpSrvCtrls=m_cons->getSrvCtrlsArray();
52 LDAPControl** tmpClCtrls=m_cons->getClCtrlsArray();
53 LDAPMod** tmpMods=m_modList->toLDAPModArray();
54 int err=ldap_modify_ext(m_connection->getSessionHandle(),m_dn.c_str(),
55 tmpMods, tmpSrvCtrls, tmpClCtrls,&msgID);
56 LDAPControlSet::freeLDAPControlArray(tmpSrvCtrls);
57 LDAPControlSet::freeLDAPControlArray(tmpClCtrls);
58 ldap_mods_free(tmpMods,1);
59 if(err != LDAP_SUCCESS){
60 throw LDAPException(err);
63 return new LDAPMessageQueue(this);
67 LDAPRequest* LDAPModifyRequest::followReferral(LDAPMsg* ref){
68 DEBUG(LDAP_DEBUG_TRACE, "LDAPModifyRequest::followReferral()" << endl);
69 LDAPUrlList::const_iterator usedUrl;
70 LDAPUrlList urls = ((LDAPResult*)ref)->getReferralUrls();
71 LDAPAsynConnection* con = 0;
73 con = getConnection()->referralConnect(urls,usedUrl,m_cons);
74 } catch(LDAPException e){
79 return new LDAPModifyRequest(m_dn, m_modList, con, m_cons,true,this);