/* * Copyright 2000, OpenLDAP Foundation, All Rights Reserved. * COPYING RESTRICTIONS APPLY, see COPYRIGHT file */ #include #include "debug.h" #include "LDAPBindRequest.h" #include "LDAPException.h" LDAPBindRequest::LDAPBindRequest(const LDAPBindRequest& req) : LDAPRequest(req){ DEBUG(LDAP_DEBUG_CONSTRUCT, "LDAPBindRequest::LDAPBindRequest(&)" << endl); m_dn=req.m_dn; m_cred=req.m_cred; m_mech=req.m_mech; } LDAPBindRequest::LDAPBindRequest(const string& dn,const string& passwd, LDAPAsynConnection *connect, const LDAPConstraints *cons, bool isReferral=false) : LDAPRequest(connect, cons, isReferral){ DEBUG(LDAP_DEBUG_CONSTRUCT,"LDAPBindRequest::LDAPBindRequest()" << endl); DEBUG(LDAP_DEBUG_CONSTRUCT | LDAP_DEBUG_PARAMETER, " dn:" << dn << endl << " passwd:" << passwd << endl); m_dn = dn; m_cred = passwd; m_mech = ""; } LDAPBindRequest::~LDAPBindRequest(){ DEBUG(LDAP_DEBUG_DESTROY,"LDAPBindRequest::~LDAPBindRequest()" << endl); } LDAPMessageQueue* LDAPBindRequest::sendRequest(){ DEBUG(LDAP_DEBUG_TRACE,"LDAPBindRequest::sendRequest()" << endl); int msgID=0; const char* mech = (m_mech == "" ? 0 : m_mech.c_str()); BerValue* tmpcred=0; if(m_cred != ""){ char* tmppwd = new char[m_cred.size()+1]; m_cred.copy(tmppwd,string::npos); tmppwd[m_cred.size()]=0; tmpcred=ber_bvstr(tmppwd); }else{ tmpcred=new BerValue; tmpcred->bv_len=0; tmpcred->bv_val=0; } const char* dn = 0; if(m_dn != ""){ dn = m_dn.c_str(); } LDAPControl** tmpSrvCtrls=m_cons->getSrvCtrlsArray(); LDAPControl** tmpClCtrls=m_cons->getClCtrlsArray(); int err=ldap_sasl_bind(m_connection->getSessionHandle(),dn, mech, tmpcred, tmpSrvCtrls, tmpClCtrls, &msgID); ldap_controls_free(tmpSrvCtrls); ldap_controls_free(tmpClCtrls); ber_bvfree(tmpcred); if(err != LDAP_SUCCESS){ throw LDAPException(err); }else{ m_msgID=msgID; return new LDAPMessageQueue(this); } } LDAPRequest* LDAPBindRequest::followReferral(LDAPMsg* urls){ DEBUG(LDAP_DEBUG_TRACE,"LDAPBindRequest::followReferral()" << endl); cerr << "ReferralChasing for bind-operation not implemented yet" << endl; return 0; }