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"
15 LDAPModifyRequest::LDAPModifyRequest(const LDAPModifyRequest& req) :
17 DEBUG(LDAP_DEBUG_CONSTRUCT,
18 "LDAPModifyRequest::LDAPModifyRequest(&)" << endl);
19 m_modList = new LDAPModList(*(req.m_modList));
23 LDAPModifyRequest::LDAPModifyRequest(const string& dn,
24 const LDAPModList *modList, LDAPAsynConnection *connect,
25 const LDAPConstraints *cons, bool isReferral,
26 const LDAPRequest* parent) :
27 LDAPRequest(connect, cons, isReferral, parent){
28 DEBUG(LDAP_DEBUG_CONSTRUCT,
29 "LDAPModifyRequest::LDAPModifyRequest(&)" << endl);
30 DEBUG(LDAP_DEBUG_CONSTRUCT | LDAP_DEBUG_PARAMETER,
31 " dn:" << dn << endl);
33 m_modList = new LDAPModList(*modList);
36 LDAPModifyRequest::~LDAPModifyRequest(){
37 DEBUG(LDAP_DEBUG_DESTROY,
38 "LDAPModifyRequest::~LDAPModifyRequest()" << endl);
40 // flush this entry from cache.
41 m_connection->uncache_entry(m_dn);
44 LDAPMessageQueue* LDAPModifyRequest::sendRequest(){
45 DEBUG(LDAP_DEBUG_TRACE, "LDAPModifyRequest::sendRequest()" << endl);
47 LDAPControl** tmpSrvCtrls=m_cons->getSrvCtrlsArray();
48 LDAPControl** tmpClCtrls=m_cons->getClCtrlsArray();
49 LDAPMod** tmpMods=m_modList->toLDAPModArray();
50 int err=ldap_modify_ext(m_connection->getSessionHandle(),m_dn.c_str(),
51 tmpMods, tmpSrvCtrls, tmpClCtrls,&msgID);
52 ldap_controls_free(tmpSrvCtrls);
53 ldap_controls_free(tmpClCtrls);
54 if(err != LDAP_SUCCESS){
55 throw LDAPException(err);
58 return new LDAPMessageQueue(this);
62 LDAPRequest* LDAPModifyRequest::followReferral(LDAPMsg* ref){
63 DEBUG(LDAP_DEBUG_TRACE, "LDAPModifyRequest::followReferral()" << endl);
64 LDAPUrlList::const_iterator usedUrl;
65 LDAPUrlList urls = ((LDAPResult*)ref)->getReferralUrls();
66 LDAPAsynConnection* con = 0;
68 con = getConnection()->referralConnect(urls,usedUrl,m_cons);
69 } catch(LDAPException e){
74 return new LDAPModifyRequest(m_dn, m_modList, con, m_cons,true,this);