1// $OpenLDAP$
2/*
3 * Copyright 2000-2011 The OpenLDAP Foundation, All Rights Reserved.
4 * COPYING RESTRICTIONS APPLY, see COPYRIGHT file
5 */
6
7
8#include "LDAPControl.h"
9#include "debug.h"
10
11using namespace std;
12
13LDAPCtrl::LDAPCtrl(const char *oid, bool critical, const char* data,
14        int length){
15    DEBUG(LDAP_DEBUG_CONSTRUCT,"LDAPCtrl::LDAPCtrl()" << endl);
16    DEBUG(LDAP_DEBUG_CONSTRUCT | LDAP_DEBUG_PARAMETER,
17            "   oid:" << oid << endl << "   critical:" << critical << endl);
18    m_oid = oid;
19    m_isCritical=critical;
20    if (data != 0 && length !=0){
21        m_data.assign(data,length);
22        m_noData=false;
23    }else{
24        m_data=string();
25        m_noData=true;
26    }
27}
28
29LDAPCtrl::LDAPCtrl(const string& oid, bool critical, const string& data){
30    DEBUG(LDAP_DEBUG_CONSTRUCT,"LDAPCtrl::LDAPCtrl()" << endl);
31    DEBUG(LDAP_DEBUG_CONSTRUCT | LDAP_DEBUG_PARAMETER,
32            "   oid:" << oid << endl << "   critical:" << critical << endl);
33    m_oid=oid;
34    m_isCritical=critical;
35    m_data=data;
36    m_noData=false;
37}
38
39LDAPCtrl::LDAPCtrl(const LDAPControl* ctrl){
40    DEBUG(LDAP_DEBUG_CONSTRUCT,"LDAPCtrl::LDAPCtrl()" << endl);
41    m_oid = string(ctrl->ldctl_oid);
42    m_oid = ctrl->ldctl_iscritical ? true : false;
43    m_oid = string(ctrl->ldctl_value.bv_val, ctrl->ldctl_value.bv_len );
44}
45
46LDAPCtrl::~LDAPCtrl(){
47    DEBUG(LDAP_DEBUG_DESTROY,"LDAPCtrl::~LDAPCtrl" << endl);
48}
49
50string LDAPCtrl::getOID() const{
51    DEBUG(LDAP_DEBUG_TRACE,"LDAPCtrl::getOID()" << endl);
52    return m_oid;
53}
54
55bool LDAPCtrl::isCritical()const {
56    DEBUG(LDAP_DEBUG_TRACE,"LDAPCtrl::isCritical()" << endl);
57    return m_isCritical;
58}
59
60bool LDAPCtrl::hasData() const{
61    return !m_noData;
62}
63
64string LDAPCtrl::getData() const {
65    DEBUG(LDAP_DEBUG_TRACE,"LDAPCtrl::getData()" << endl);
66    return m_data;
67}
68
69LDAPControl* LDAPCtrl::getControlStruct() const {
70    DEBUG(LDAP_DEBUG_TRACE,"LDAPCtrl::getControlStruct()" << endl);
71    LDAPControl* ret = new LDAPControl;
72    ret->ldctl_oid= new char[m_oid.size() + 1];
73    m_oid.copy(ret->ldctl_oid,string::npos);
74    ret->ldctl_oid[m_oid.size()]=0;
75    if ( m_noData ) {
76        ret->ldctl_value.bv_len = 0;
77        ret->ldctl_value.bv_val = NULL;
78    } else {
79        ret->ldctl_value.bv_len=m_data.size();
80        ret->ldctl_value.bv_val= new char[m_data.size()];
81        m_data.copy(ret->ldctl_value.bv_val,string::npos);
82    }
83    ret->ldctl_iscritical = ( m_isCritical ? 1:0);
84    return ret;
85}
86
87void LDAPCtrl::freeLDAPControlStruct(LDAPControl *ctrl){
88    DEBUG(LDAP_DEBUG_TRACE,"LDAPCtrl::freeControlStruct()" << endl);
89    delete[] ctrl->ldctl_oid;
90    delete[] ctrl->ldctl_value.bv_val;
91    delete ctrl;
92}
93
94