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