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);
46 LDAPMessageQueue* LDAPModifyRequest::sendRequest(){
47 DEBUG(LDAP_DEBUG_TRACE, "LDAPModifyRequest::sendRequest()" << endl);
49 LDAPControl** tmpSrvCtrls=m_cons->getSrvCtrlsArray();
50 LDAPControl** tmpClCtrls=m_cons->getClCtrlsArray();
51 LDAPMod** tmpMods=m_modList->toLDAPModArray();
52 int err=ldap_modify_ext(m_connection->getSessionHandle(),m_dn.c_str(),
53 tmpMods, tmpSrvCtrls, tmpClCtrls,&msgID);
54 ldap_controls_free(tmpSrvCtrls);
55 ldap_controls_free(tmpClCtrls);
56 if(err != LDAP_SUCCESS){
57 throw LDAPException(err);
60 return new LDAPMessageQueue(this);
64 LDAPRequest* LDAPModifyRequest::followReferral(LDAPMsg* ref){
65 DEBUG(LDAP_DEBUG_TRACE, "LDAPModifyRequest::followReferral()" << endl);
66 LDAPUrlList::const_iterator usedUrl;
67 LDAPUrlList urls = ((LDAPResult*)ref)->getReferralUrls();
68 LDAPAsynConnection* con = 0;
70 con = getConnection()->referralConnect(urls,usedUrl,m_cons);
71 } catch(LDAPException e){
76 return new LDAPModifyRequest(m_dn, m_modList, con, m_cons,true,this);