Leaked source code of windows server 2003
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

178 lines
7.0 KiB

#ifndef EXLDAP_H
#define EXLDAP_H
#include <windows.h>
#include <winldap.h>
#include <stdio.h>
#include "EaLen.hpp"
#include "Common.hpp"
#include "UString.hpp"
typedef WINLDAPAPI LDAP * LDAPAPI LDAP_OPEN( PWCHAR HostName, ULONG PortNumber );
typedef WINLDAPAPI LDAP * LDAPAPI LDAP_INIT( PWCHAR HostName, ULONG PortNumber );
typedef WINLDAPAPI LDAP * LDAPAPI LDAP_SSLINIT(PWCHAR HostName, ULONG PortNumber, int secure);
typedef WINLDAPAPI ULONG LDAPAPI LDAPMAPERRORTOWIN32( ULONG LdapError );
typedef WINLDAPAPI ULONG LDAPAPI LDAP_UNBIND( LDAP *ld );
typedef WINLDAPAPI ULONG LDAPAPI LDAP_BIND( LDAP *ld, PWCHAR dn, PWCHAR cred, ULONG method );
typedef WINLDAPAPI ULONG LDAPAPI LDAP_CONNECT(LDAP* ld, struct l_timeval* timeout);
typedef WINLDAPAPI ULONG LDAPAPI LDAP_SIMPLE_BIND(LDAP* ld, PWCHAR dn, PWCHAR passwd);
typedef WINLDAPAPI ULONG LDAPAPI LDAPGETLASTERROR( VOID );
typedef WINLDAPAPI ULONG LDAPAPI LDAP_MODIFY_S( LDAP *ld, PWCHAR dn, LDAPModW *mods[] );
typedef WINLDAPAPI ULONG LDAPAPI LDAP_MSGFREE( LDAPMessage *res );
typedef WINLDAPAPI ULONG LDAPAPI LDAP_COUNT_ENTRIES( LDAP *ld, LDAPMessage *res );
typedef WINLDAPAPI ULONG LDAPAPI LDAP_SEARCH_EXT_S(
LDAP *ld,
PWCHAR base,
ULONG scope,
PWCHAR filter,
PWCHAR attrs[],
ULONG attrsonly,
PLDAPControlW *ServerControls,
PLDAPControlW *ClientControls,
struct l_timeval *timeout,
ULONG SizeLimit,
LDAPMessage **res
);
typedef WINLDAPAPI ULONG LDAPAPI LDAP_CREATE_PAGE_CONTROL(
PLDAP ExternalHandle,
ULONG PageSize,
struct berval *Cookie,
UCHAR IsCritical,
PLDAPControlW *Control
);
typedef WINLDAPAPI ULONG LDAPAPI LDAP_PARSE_PAGE_CONTROL (
PLDAP ExternalHandle,
PLDAPControlW *ServerControls,
ULONG *TotalCount,
struct berval **Cookie // Use ber_bvfree to free
);
typedef WINLDAPAPI PWCHAR *LDAPAPI LDAP_GET_VALUES(
LDAP *ld,
LDAPMessage *entry,
PWCHAR attr
);
typedef WINLDAPAPI ULONG LDAPAPI LDAP_VALUE_FREE( PWCHAR *vals );
typedef WINLDAPAPI LDAPMessage *LDAPAPI LDAP_NEXT_ENTRY( LDAP *ld, LDAPMessage *entry );
typedef WINLDAPAPI LDAPMessage *LDAPAPI LDAP_FIRST_ENTRY( LDAP *ld, LDAPMessage *res );
typedef WINLDAPAPI VOID LDAPAPI BER_BVFREE( struct berval *bv );
typedef WINLDAPAPI ULONG LDAPAPI LDAP_CONTROLS_FREE (
LDAPControlW **Control
);
typedef WINLDAPAPI ULONG LDAPAPI LDAP_PARSE_RESULT (
LDAP *Connection,
LDAPMessage *ResultMessage,
ULONG *ReturnCode OPTIONAL, // returned by server
PWCHAR *MatchedDNs OPTIONAL, // free with ldap_memfree
PWCHAR *ErrorMessage OPTIONAL, // free with ldap_memfree
PWCHAR **Referrals OPTIONAL, // free with ldap_value_freeW
PLDAPControlW **ServerControls OPTIONAL, // free with ldap_free_controlsW
BOOLEAN Freeit
);
typedef WINLDAPAPI ULONG LDAPAPI LDAP_GET_OPTION( LDAP *ld, int option, void *outvalue );
typedef WINLDAPAPI ULONG LDAPAPI LDAP_SET_OPTION( LDAP *ld, int option, void *invalue );
class CLdapConnection
{
WCHAR m_exchServer[LEN_Computer];
LDAP * m_LD;
ULONG m_port;
HMODULE m_hDll;
BOOL m_bUseSSL;
WCHAR m_credentials[300];
WCHAR m_password[LEN_Password];
SEC_WINNT_AUTH_IDENTITY_W m_creds;
public:
LDAP_PARSE_RESULT * ldap_parse_result;
LDAP_PARSE_PAGE_CONTROL * ldap_parse_page_control;
LDAP_CONTROLS_FREE * ldap_controls_free;
BER_BVFREE * ber_bvfree;
LDAP_FIRST_ENTRY * ldap_first_entry;
LDAP_NEXT_ENTRY * ldap_next_entry;
LDAP_VALUE_FREE * ldap_value_free;
LDAP_GET_VALUES * ldap_get_values;
LDAP_CREATE_PAGE_CONTROL * ldap_create_page_control;
LDAP_SEARCH_EXT_S * ldap_search_ext_s;
LDAP_COUNT_ENTRIES * ldap_count_entries;
LDAP_MSGFREE * ldap_msgfree;
LDAP_MODIFY_S * ldap_modify_s;
LDAPGETLASTERROR * LdapGetLastError;
LDAP_BIND * ldap_bind_sW;
LDAP_SIMPLE_BIND * ldap_simple_bind_sW;
LDAP_CONNECT * ldap_connect;
LDAP_UNBIND * ldap_unbind;
LDAPMAPERRORTOWIN32 * LdapMapErrorToWin32;
LDAP_OPEN * ldap_open;
LDAP_GET_OPTION * ldap_get_option;
LDAP_SET_OPTION * ldap_set_option;
LDAP_INIT * ldap_init;
LDAP_SSLINIT *ldap_sslinit;
public:
CLdapConnection();
~CLdapConnection();
void SetCredentials(WCHAR const *domain, WCHAR const * cred, WCHAR const * pwd);
LDAP * GetHandle() { return m_LD; }
DWORD Connect(WCHAR const * server,ULONG port);
DWORD SSLConnect(WCHAR const * server, BOOL* sslEnabled, ULONG port = LDAP_SSL_PORT);
DWORD UpdateSimpleStringValue(WCHAR const * dn, WCHAR const * property, WCHAR const * value);
void Close();
BOOL StringToBytes(WCHAR const * pString,BYTE * pBytes);
BOOL BytesToString(BYTE * pBytes,WCHAR * sidString,DWORD numBytes);
protected:
// helper functions
BYTE HexValue(WCHAR value);
void AddByteToString(WCHAR ** string,BYTE value);
};
class CLdapEnum
{
BOOL m_bOpen;
ULONG m_nReturned;
ULONG m_nCurrent;
ULONG m_totalCount;
LDAPMessage * m_message;
LDAPMessage * m_currMsg;
WCHAR m_query[1000];
WCHAR m_basepoint[LEN_DistName];
int m_scope;
long m_pageSize;
int m_nAttributes;
WCHAR ** m_AttrNames;
public:
CLdapConnection m_connection;
public:
CLdapEnum() { m_bOpen = FALSE; m_nReturned = 0; m_nCurrent = 0; m_totalCount = 0; m_message = NULL;
m_query[0] = 0; m_basepoint[0] = 0; m_scope = 2; m_pageSize = 100; m_currMsg = NULL;
m_nAttributes = 0; m_AttrNames =NULL;}
~CLdapEnum();
DWORD InitConnection(WCHAR const * server,ULONG port) { return m_connection.Connect(server,port); }
DWORD InitSSLConnection(WCHAR const * server,BOOL* sslEnabled,ULONG port) { return m_connection.SSLConnect(server,sslEnabled,port); }
DWORD Open(WCHAR const * query,WCHAR const * basePoint,short scope, long pageSize,int numAttributes,
WCHAR ** attrs);
DWORD Next(PWCHAR ** ppAttrs);
void FreeData(PWCHAR* pValues);
protected:
DWORD GetNextEntry(PWCHAR ** ppAttrs);
DWORD GetNextPage();
};
void GetLDAPPort(DWORD *LDAPPort, DWORD *SSLPort);
#endif // EXLDAP_H