📄 ldapcomparerequest.cpp
字号:
/* * Copyright 2000, OpenLDAP Foundation, All Rights Reserved. * COPYING RESTRICTIONS APPLY, see COPYRIGHT file */#include <ldap.h>#include "debug.h"#include "LDAPCompareRequest.h"#include "LDAPException.h"#include "LDAPMessageQueue.h"#include "LDAPResult.h"using namespace std;LDAPCompareRequest::LDAPCompareRequest(const LDAPCompareRequest& req){ DEBUG(LDAP_DEBUG_CONSTRUCT, "LDAPCompareRequest::LDAPCompareRequest(&)" << endl); m_dn=req.m_dn; m_attr=req.m_attr;}LDAPCompareRequest::LDAPCompareRequest(const string& dn, const LDAPAttribute& attr, LDAPAsynConnection *connect, const LDAPConstraints *cons, bool isReferral, const LDAPRequest* parent) : LDAPRequest(connect, cons, isReferral,parent){ DEBUG(LDAP_DEBUG_CONSTRUCT, "LDAPCompareRequest::LDAPCompareRequest()" << endl); DEBUG(LDAP_DEBUG_CONSTRUCT | LDAP_DEBUG_PARAMETER, " dn:" << dn << endl << " attr:" << attr << endl); m_requestType=LDAPRequest::COMPARE; m_dn=dn; m_attr=attr;} LDAPCompareRequest::~LDAPCompareRequest(){ DEBUG(LDAP_DEBUG_DESTROY, "LDAPCompareRequest::~LDAPCompareRequest()" << endl);}LDAPMessageQueue* LDAPCompareRequest::sendRequest(){ DEBUG(LDAP_DEBUG_TRACE, "LDAPCompareRequest::sendRequest()" << endl); int msgID=0; BerValue **val=m_attr.getBerValues(); LDAPControl** tmpSrvCtrls=m_cons->getSrvCtrlsArray(); LDAPControl** tmpClCtrls=m_cons->getClCtrlsArray(); int err=ldap_compare_ext(m_connection->getSessionHandle(),m_dn.c_str(), m_attr.getName().c_str(), val[0], tmpSrvCtrls, tmpClCtrls, &msgID); ber_bvecfree(val); LDAPControlSet::freeLDAPControlArray(tmpSrvCtrls); LDAPControlSet::freeLDAPControlArray(tmpClCtrls); if(err != LDAP_SUCCESS){ throw LDAPException(err); }else{ m_msgID=msgID; return new LDAPMessageQueue(this); }}LDAPRequest* LDAPCompareRequest::followReferral(LDAPMsg* ref){ DEBUG(LDAP_DEBUG_TRACE, "LDAPCompareRequest::followReferral()" << endl); LDAPUrlList::const_iterator usedUrl; LDAPUrlList urls = ((LDAPResult*)ref)->getReferralUrls(); LDAPAsynConnection* con = 0; try{ con=getConnection()->referralConnect(urls,usedUrl,m_cons); }catch(LDAPException e){ return 0; } if(con != 0){ return new LDAPCompareRequest(m_dn, m_attr, con, m_cons, true, this); } return 0;}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -