1d11b170bStron // $OpenLDAP$
22de962bdSlukem /*
3*e670fd5cSchristos * Copyright 2000-2021 The OpenLDAP Foundation, All Rights Reserved.
42de962bdSlukem * COPYING RESTRICTIONS APPLY, see COPYRIGHT file
52de962bdSlukem */
62de962bdSlukem
72de962bdSlukem #include <ldap.h>
82de962bdSlukem
92de962bdSlukem #include "debug.h"
102de962bdSlukem
112de962bdSlukem #include "LDAPModifyRequest.h"
122de962bdSlukem #include "LDAPException.h"
132de962bdSlukem #include "LDAPMessageQueue.h"
142de962bdSlukem #include "LDAPResult.h"
152de962bdSlukem
162de962bdSlukem using namespace std;
172de962bdSlukem
LDAPModifyRequest(const LDAPModifyRequest & req)182de962bdSlukem LDAPModifyRequest::LDAPModifyRequest(const LDAPModifyRequest& req) :
192de962bdSlukem LDAPRequest(req){
202de962bdSlukem DEBUG(LDAP_DEBUG_CONSTRUCT,
212de962bdSlukem "LDAPModifyRequest::LDAPModifyRequest(&)" << endl);
222de962bdSlukem m_modList = new LDAPModList(*(req.m_modList));
232de962bdSlukem m_dn = req.m_dn;
242de962bdSlukem }
252de962bdSlukem
LDAPModifyRequest(const string & dn,const LDAPModList * modList,LDAPAsynConnection * connect,const LDAPConstraints * cons,bool isReferral,const LDAPRequest * parent)262de962bdSlukem LDAPModifyRequest::LDAPModifyRequest(const string& dn,
272de962bdSlukem const LDAPModList *modList, LDAPAsynConnection *connect,
282de962bdSlukem const LDAPConstraints *cons, bool isReferral,
292de962bdSlukem const LDAPRequest* parent) :
302de962bdSlukem LDAPRequest(connect, cons, isReferral, parent){
312de962bdSlukem DEBUG(LDAP_DEBUG_CONSTRUCT,
322de962bdSlukem "LDAPModifyRequest::LDAPModifyRequest(&)" << endl);
332de962bdSlukem DEBUG(LDAP_DEBUG_CONSTRUCT | LDAP_DEBUG_PARAMETER,
342de962bdSlukem " dn:" << dn << endl);
352de962bdSlukem m_dn = dn;
362de962bdSlukem m_modList = new LDAPModList(*modList);
372de962bdSlukem }
382de962bdSlukem
~LDAPModifyRequest()392de962bdSlukem LDAPModifyRequest::~LDAPModifyRequest(){
402de962bdSlukem DEBUG(LDAP_DEBUG_DESTROY,
412de962bdSlukem "LDAPModifyRequest::~LDAPModifyRequest()" << endl);
422de962bdSlukem delete m_modList;
432de962bdSlukem }
442de962bdSlukem
sendRequest()452de962bdSlukem LDAPMessageQueue* LDAPModifyRequest::sendRequest(){
462de962bdSlukem DEBUG(LDAP_DEBUG_TRACE, "LDAPModifyRequest::sendRequest()" << endl);
472de962bdSlukem int msgID=0;
482de962bdSlukem LDAPControl** tmpSrvCtrls=m_cons->getSrvCtrlsArray();
492de962bdSlukem LDAPControl** tmpClCtrls=m_cons->getClCtrlsArray();
502de962bdSlukem LDAPMod** tmpMods=m_modList->toLDAPModArray();
512de962bdSlukem int err=ldap_modify_ext(m_connection->getSessionHandle(),m_dn.c_str(),
522de962bdSlukem tmpMods, tmpSrvCtrls, tmpClCtrls,&msgID);
532de962bdSlukem LDAPControlSet::freeLDAPControlArray(tmpSrvCtrls);
542de962bdSlukem LDAPControlSet::freeLDAPControlArray(tmpClCtrls);
552de962bdSlukem ldap_mods_free(tmpMods,1);
562de962bdSlukem if(err != LDAP_SUCCESS){
572de962bdSlukem throw LDAPException(err);
582de962bdSlukem }else{
592de962bdSlukem m_msgID=msgID;
602de962bdSlukem return new LDAPMessageQueue(this);
612de962bdSlukem }
622de962bdSlukem }
632de962bdSlukem
followReferral(LDAPMsg * ref)642de962bdSlukem LDAPRequest* LDAPModifyRequest::followReferral(LDAPMsg* ref){
652de962bdSlukem DEBUG(LDAP_DEBUG_TRACE, "LDAPModifyRequest::followReferral()" << endl);
662de962bdSlukem LDAPUrlList::const_iterator usedUrl;
672de962bdSlukem LDAPUrlList urls = ((LDAPResult*)ref)->getReferralUrls();
682de962bdSlukem LDAPAsynConnection* con = 0;
692de962bdSlukem try {
702de962bdSlukem con = getConnection()->referralConnect(urls,usedUrl,m_cons);
712de962bdSlukem } catch(LDAPException e){
722de962bdSlukem delete con;
732de962bdSlukem return 0;
742de962bdSlukem }
752de962bdSlukem if(con != 0){
762de962bdSlukem return new LDAPModifyRequest(m_dn, m_modList, con, m_cons,true,this);
772de962bdSlukem }
782de962bdSlukem return 0;
792de962bdSlukem }
802de962bdSlukem
812de962bdSlukem
82