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);
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 LDAPControlSet::freeLDAPControlArray(tmpSrvCtrls);
53 LDAPControlSet::freeLDAPControlArray(tmpClCtrls);
54 ldap_mods_free(tmpMods,1);
55 if(err != LDAP_SUCCESS){
56 throw LDAPException(err);
59 return new LDAPMessageQueue(this);
63 LDAPRequest* LDAPModifyRequest::followReferral(LDAPMsg* ref){
64 DEBUG(LDAP_DEBUG_TRACE, "LDAPModifyRequest::followReferral()" << endl);
65 LDAPUrlList::const_iterator usedUrl;
66 LDAPUrlList urls = ((LDAPResult*)ref)->getReferralUrls();
67 LDAPAsynConnection* con = 0;
69 con = getConnection()->referralConnect(urls,usedUrl,m_cons);
70 } catch(LDAPException e){
75 return new LDAPModifyRequest(m_dn, m_modList, con, m_cons,true,this);