xref: /netbsd-src/external/bsd/openldap/dist/contrib/ldapc++/src/LDAPExtRequest.cpp (revision e670fd5c413e99c2f6a37901bb21c537fcd322d2)
12de962bdSlukem /*
2*e670fd5cSchristos  * Copyright 2000-2021 The OpenLDAP Foundation, All Rights Reserved.
32de962bdSlukem  * COPYING RESTRICTIONS APPLY, see COPYRIGHT file
42de962bdSlukem  */
52de962bdSlukem 
62de962bdSlukem #include <ldap.h>
72de962bdSlukem #include <lber.h>
82de962bdSlukem 
92de962bdSlukem #include "debug.h"
102de962bdSlukem 
112de962bdSlukem #include "LDAPExtRequest.h"
122de962bdSlukem #include "LDAPException.h"
132de962bdSlukem #include "LDAPResult.h"
142de962bdSlukem 
152de962bdSlukem #include <cstdlib>
162de962bdSlukem 
172de962bdSlukem using namespace std;
182de962bdSlukem 
LDAPExtRequest(const LDAPExtRequest & req)192de962bdSlukem LDAPExtRequest::LDAPExtRequest(const LDAPExtRequest& req) :
202de962bdSlukem         LDAPRequest(req){
212de962bdSlukem     DEBUG(LDAP_DEBUG_CONSTRUCT,"LDAPExtRequest::LDAPExtRequest(&)" << endl);
222de962bdSlukem     m_data=req.m_data;
232de962bdSlukem     m_oid=req.m_oid;
242de962bdSlukem }
252de962bdSlukem 
LDAPExtRequest(const string & oid,const string & data,LDAPAsynConnection * connect,const LDAPConstraints * cons,bool isReferral,const LDAPRequest * parent)262de962bdSlukem LDAPExtRequest::LDAPExtRequest(const string& oid, const string& data,
272de962bdSlukem         LDAPAsynConnection *connect, const LDAPConstraints *cons,
282de962bdSlukem         bool isReferral, const LDAPRequest* parent)
292de962bdSlukem         : LDAPRequest(connect, cons, isReferral, parent){
302de962bdSlukem     DEBUG(LDAP_DEBUG_CONSTRUCT, "LDAPExtRequest::LDAPExtRequest()" << endl);
312de962bdSlukem     DEBUG(LDAP_DEBUG_CONSTRUCT | LDAP_DEBUG_PARAMETER,
322de962bdSlukem             "   oid:" << oid << endl);
332de962bdSlukem     m_oid=oid;
342de962bdSlukem     m_data=data;
352de962bdSlukem }
362de962bdSlukem 
~LDAPExtRequest()372de962bdSlukem LDAPExtRequest::~LDAPExtRequest(){
382de962bdSlukem     DEBUG(LDAP_DEBUG_DESTROY, "LDAPExtRequest::~LDAPExtRequest()" << endl);
392de962bdSlukem }
402de962bdSlukem 
sendRequest()412de962bdSlukem LDAPMessageQueue* LDAPExtRequest::sendRequest(){
422de962bdSlukem     DEBUG(LDAP_DEBUG_TRACE, "LDAPExtRequest::sendRequest()" << endl);
432de962bdSlukem     int msgID=0;
442de962bdSlukem     BerValue* tmpdata=0;
452de962bdSlukem     if(m_data != ""){
462de962bdSlukem         tmpdata=(BerValue*) malloc(sizeof(BerValue));
472de962bdSlukem         tmpdata->bv_len = m_data.size();
482de962bdSlukem         tmpdata->bv_val = (char*) malloc(sizeof(char) * (m_data.size()) );
492de962bdSlukem         m_data.copy(tmpdata->bv_val, string::npos);
502de962bdSlukem     }
512de962bdSlukem     LDAPControl** tmpSrvCtrls=m_cons->getSrvCtrlsArray();
522de962bdSlukem     LDAPControl** tmpClCtrls=m_cons->getClCtrlsArray();
532de962bdSlukem     int err=ldap_extended_operation(m_connection->getSessionHandle(),
542de962bdSlukem             m_oid.c_str(), tmpdata, tmpSrvCtrls, tmpClCtrls, &msgID);
552de962bdSlukem     LDAPControlSet::freeLDAPControlArray(tmpSrvCtrls);
562de962bdSlukem     LDAPControlSet::freeLDAPControlArray(tmpClCtrls);
572de962bdSlukem     ber_bvfree(tmpdata);
582de962bdSlukem     if(err != LDAP_SUCCESS){
592de962bdSlukem         delete this;
602de962bdSlukem         throw LDAPException(err);
612de962bdSlukem     }else{
622de962bdSlukem         m_msgID=msgID;
632de962bdSlukem         return new LDAPMessageQueue(this);
642de962bdSlukem     }
652de962bdSlukem }
662de962bdSlukem 
followReferral(LDAPMsg * ref)672de962bdSlukem LDAPRequest* LDAPExtRequest::followReferral(LDAPMsg* ref){
682de962bdSlukem     DEBUG(LDAP_DEBUG_TRACE, "LDAPExtRequest::followReferral()" << endl);
692de962bdSlukem     LDAPUrlList::const_iterator usedUrl;
702de962bdSlukem     LDAPUrlList urls = ((LDAPResult*)ref)->getReferralUrls();
712de962bdSlukem     LDAPAsynConnection* con = 0;
722de962bdSlukem     try {
732de962bdSlukem         con = getConnection()->referralConnect(urls,usedUrl,m_cons);
742de962bdSlukem     } catch(LDAPException e){
752de962bdSlukem         delete con;
762de962bdSlukem         return 0;
772de962bdSlukem     }
782de962bdSlukem     if(con != 0){
792de962bdSlukem         return new LDAPExtRequest(m_oid, m_data, con, m_cons,true,this);
802de962bdSlukem     }
812de962bdSlukem     return 0;
822de962bdSlukem }
832de962bdSlukem 
842de962bdSlukem 
85