📄 pldap.h
字号:
/*
* pldap.h
*
* Lightweight Directory Access Protocol interface class.
*
* Portable Windows Library
*
* Copyright (c) 1993-2003 Equivalence Pty. Ltd.
*
* The contents of this file are subject to the Mozilla Public License
* Version 1.0 (the "License"); you may not use this file except in
* compliance with the License. You may obtain a copy of the License at
* http://www.mozilla.org/MPL/
*
* Software distributed under the License is distributed on an "AS IS"
* basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See
* the License for the specific language governing rights and limitations
* under the License.
*
* The Original Code is Portable Windows Library.
*
* The Initial Developer of the Original Code is Equivalence Pty. Ltd.
*
* Contributor(s): ______________________________________.
*
* $Log: pldap.h,v $
* Revision 1.10 2006/01/16 19:52:05 dsandras
* Applied patch from Brian Lu <brian lu sun com> to allow compilation on
* Solaris using SUN's LDAP. Thanks!!
*
* Revision 1.9 2004/05/24 12:02:49 csoutheren
* Add function to permit setting a limit on the number of results returned
* from an LDAP query. Change the default number of results to unlimited,
* rather than MAX_INT which apparently is clamped to some arbitrary low value.
* Thanks to Damien Sandras
*
* Revision 1.8 2004/02/20 16:28:27 ykiryanov
* if'd LDAP code to enable non-LDAP builds
*
* Revision 1.7 2003/06/05 23:17:07 rjongbloed
* Added functions to get and set LDAP operation timeout.
*
* Revision 1.6 2003/06/05 05:29:30 rjongbloed
* Fixed LDAP bind authentication methods, thanks Ravelli Rossano
*
* Revision 1.5 2003/04/07 12:00:04 robertj
* Fixed search function returning an error if can't find anything for filter.
*
* Revision 1.4 2003/04/01 07:05:29 robertj
* Added ability to specify host:port in opening an LDAP server
*
* Revision 1.3 2003/03/31 09:02:43 robertj
* Added missing return for error number.
*
* Revision 1.2 2003/03/31 03:32:41 robertj
* Major addition of functionality.
*
* Revision 1.1 2003/03/28 01:15:44 robertj
* OpenLDAP support.
*
*
*/
#ifndef _PLDAP_H
#define _PLDAP_H
#ifdef P_USE_PRAGMA
#pragma interface
#endif
#if P_LDAP
#include <ptlib/sockets.h>
struct ldap;
struct ldapmsg;
struct ldapmod;
struct berval;
class PLDAPStructBase;
/**This class will create an LDAP client to access a remote LDAP server.
*/
class PLDAPSession : public PObject
{
PCLASSINFO(PLDAPSession, PObject);
public:
/**Create a LDAP client.
*/
PLDAPSession(
const PString & defaultBaseDN = PString::Empty()
);
/**Close the sesison on destruction
*/
~PLDAPSession();
/**Open the LDAP session to the specified server.
The server name string is of the form hostip[:port] where hostip is a
host name or IP address and the :port is an optional port number. If
not present then the port variable is used. If that is also zero then
the default port of 369 is used.
*/
BOOL Open(
const PString & server,
WORD port = 0
);
/**Close the LDAP session
*/
BOOL Close();
/**Determine of session is open.
*/
BOOL IsOpen() const { return ldapContext != NULL; }
/**Set LDAP option parameter (OpenLDAp specific values)
*/
BOOL SetOption(
int optcode,
int value
);
/**Set LDAP option parameter (OpenLDAP specific values)
*/
BOOL SetOption(
int optcode,
void * value
);
enum AuthenticationMethod {
AuthSimple,
AuthSASL,
AuthKerberos,
#ifdef SOLARIS
NumAuthenticationMethod1,
NumAuthenticationMethod2
#else
NumAuthenticationMethod
#endif
};
/**Bind to the remote LDAP server.
*/
BOOL Bind(
const PString & who = PString::Empty(),
const PString & passwd = PString::Empty(),
AuthenticationMethod authMethod = AuthSimple
);
class ModAttrib : public PObject {
PCLASSINFO(ModAttrib, PObject);
public:
enum Operation {
Add,
Replace,
Delete,
NumOperations
};
protected:
ModAttrib(
const PString & name,
Operation op = NumOperations
);
public:
const PString & GetName() const { return name; }
Operation GetOperation() const { return op; }
void SetLDAPMod(
struct ldapmod & mod,
Operation defaultOp
);
protected:
virtual BOOL IsBinary() const = 0;
virtual void SetLDAPModVars(struct ldapmod & mod) = 0;
PString name;
Operation op;
};
class StringModAttrib : public ModAttrib {
PCLASSINFO(StringModAttrib, ModAttrib);
public:
StringModAttrib(
const PString & name,
Operation op = NumOperations
);
StringModAttrib(
const PString & name,
const PString & value,
Operation op = NumOperations
);
StringModAttrib(
const PString & name,
const PStringList & values,
Operation op = NumOperations
);
void SetValue(
const PString & value
);
void AddValue(
const PString & value
);
protected:
virtual BOOL IsBinary() const;
virtual void SetLDAPModVars(struct ldapmod & mod);
PStringList values;
PBaseArray<char *> pointers;
};
class BinaryModAttrib : public ModAttrib {
PCLASSINFO(BinaryModAttrib, ModAttrib);
public:
BinaryModAttrib(
const PString & name,
Operation op = Add
);
BinaryModAttrib(
const PString & name,
const PBYTEArray & value,
Operation op = Add
);
BinaryModAttrib(
const PString & name,
const PList<PBYTEArray> & values,
Operation op = Add
);
void SetValue(
const PBYTEArray & value
);
void AddValue(
const PBYTEArray & value
);
protected:
virtual BOOL IsBinary() const;
virtual void SetLDAPModVars(struct ldapmod & mod);
PList<PBYTEArray> values;
PBaseArray<struct berval *> pointers;
PBYTEArray bervals;
};
/**Add a new distringuished name to LDAP dirctory.
*/
BOOL Add(
const PString & dn,
const PList<ModAttrib> & attributes
);
/**Add a new distringuished name to LDAP dirctory.
*/
BOOL Add(
const PString & dn,
const PStringToString & attributes
);
/**Add a new distringuished name to LDAP dirctory.
The attributes list is a string array of the form attr=value
*/
BOOL Add(
const PString & dn,
const PStringArray & attributes
);
/**Add a new distringuished name to LDAP dirctory.
The attributes list is a string array of the form attr=value
*/
BOOL Add(
const PString & dn,
const PLDAPStructBase & data
);
/**Modify an existing distringuished name to LDAP dirctory.
*/
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -