xref: /netbsd-src/external/bsd/openldap/dist/contrib/ldapc++/src/LDAPModifyRequest.cpp (revision e670fd5c413e99c2f6a37901bb21c537fcd322d2)
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