📄 ldapmodifyrequest.cpp
字号:
/* * Copyright 2000, OpenLDAP Foundation, All Rights Reserved. * COPYING RESTRICTIONS APPLY, see COPYRIGHT file */#include <ldap.h>#include "debug.h"#include "LDAPModifyRequest.h"#include "LDAPException.h"#include "LDAPMessageQueue.h"#include "LDAPResult.h"using namespace std;LDAPModifyRequest::LDAPModifyRequest(const LDAPModifyRequest& req) : LDAPRequest(req){ DEBUG(LDAP_DEBUG_CONSTRUCT, "LDAPModifyRequest::LDAPModifyRequest(&)" << endl); m_modList = new LDAPModList(*(req.m_modList)); m_dn = req.m_dn;}LDAPModifyRequest::LDAPModifyRequest(const string& dn, const LDAPModList *modList, LDAPAsynConnection *connect, const LDAPConstraints *cons, bool isReferral, const LDAPRequest* parent) : LDAPRequest(connect, cons, isReferral, parent){ DEBUG(LDAP_DEBUG_CONSTRUCT, "LDAPModifyRequest::LDAPModifyRequest(&)" << endl); DEBUG(LDAP_DEBUG_CONSTRUCT | LDAP_DEBUG_PARAMETER, " dn:" << dn << endl); m_dn = dn; m_modList = new LDAPModList(*modList);}LDAPModifyRequest::~LDAPModifyRequest(){ DEBUG(LDAP_DEBUG_DESTROY, "LDAPModifyRequest::~LDAPModifyRequest()" << endl); delete m_modList;}LDAPMessageQueue* LDAPModifyRequest::sendRequest(){ DEBUG(LDAP_DEBUG_TRACE, "LDAPModifyRequest::sendRequest()" << endl); int msgID=0; LDAPControl** tmpSrvCtrls=m_cons->getSrvCtrlsArray(); LDAPControl** tmpClCtrls=m_cons->getClCtrlsArray(); LDAPMod** tmpMods=m_modList->toLDAPModArray(); int err=ldap_modify_ext(m_connection->getSessionHandle(),m_dn.c_str(), tmpMods, tmpSrvCtrls, tmpClCtrls,&msgID); LDAPControlSet::freeLDAPControlArray(tmpSrvCtrls); LDAPControlSet::freeLDAPControlArray(tmpClCtrls); ldap_mods_free(tmpMods,1); if(err != LDAP_SUCCESS){ throw LDAPException(err); }else{ m_msgID=msgID; return new LDAPMessageQueue(this); }}LDAPRequest* LDAPModifyRequest::followReferral(LDAPMsg* ref){ DEBUG(LDAP_DEBUG_TRACE, "LDAPModifyRequest::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){ delete con; return 0; } if(con != 0){ return new LDAPModifyRequest(m_dn, m_modList, con, m_cons,true,this); } return 0;}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -