|
|
//================================================================================
// Copyright (C) 2000 Microsoft Corporation
// Author : ThiruB
// Description: ADSI test app
//================================================================================
#define INC_OLE2
#include <activeds.h>
#include <stdio.h>
#include <stdlib.h>
#include <align.h>
#include <lmcons.h>
#include <netlib.h>
#include <lmapibuf.h>
#include <dsgetdc.h>
#include <adsi.h>
LPWSTR ConvertToLPWSTR( IN /* LPSTR */ char * s ) { LPWSTR u, v;
if( NULL == s ) return L"";
u = LocalAlloc(LMEM_FIXED, (strlen(s)+1)*sizeof(WCHAR)); if( NULL == u ) return L"";
v = u; while( *v++ = *s++) ;
return u; } // ConvertToLPWSTR()
void PrintRow( HANDLE lh, ADS_SEARCH_HANDLE sh, LPWSTR attribs[], DWORD count ) { DWORD i, j; HRESULT hr; ADS_SEARCH_COLUMN col;
for ( i = 0; i < count; i++ ) { hr = ADSIGetColumn( lh, sh, attribs[ i ], &col );
if ( FAILED( hr)) { printf( "Failed for attribute : %ws, ErrorCode: %ld\n", attribs[ i ], GetLastError()); continue; } printf( "AttrName : %ws\n", col.pszAttrName ); for ( j = 0; j < col.dwNumValues; j++ ) { printf( "\tAttr Value : %ws\n", col.pADsValues[j].DNString ); } } // for
} // PrintRow()
void DumpObject( LPWSTR url, LPWSTR searchFilter ) {
HANDLE ldapHandle; ADS_SEARCH_HANDLE sh; HRESULT hr;
ADS_SEARCHPREF_INFO SearchPref[3];
LPWSTR attribs[] = { L"name", L"dhcpServers" }; // LPWSTR attribs[] = { L"dhcpServers" };
// LPWSTR searchFilter = L"(objectClass=dHCPClass)";
// LPWSTR searchFilter = L"(dhcpServers~=127)";
hr = ADSIOpenDSObject( url, NULL, NULL, ADS_SECURE_AUTHENTICATION, &ldapHandle );
if ( SUCCEEDED( hr )) { printf( "Successfully opened %ws\n", url ); } else { printf( "Failed to open : %ws\n", url ); return; }
SearchPref[0].dwSearchPref = ADS_SEARCHPREF_SEARCH_SCOPE; SearchPref[0].vValue.dwType = ADSTYPE_INTEGER; SearchPref[0].vValue.Integer = ADS_SCOPE_SUBTREE;
// SearchPref.dwStatus = ERROR_SUCCESS;
SearchPref[1].dwSearchPref = ADS_SEARCHPREF_PAGESIZE; SearchPref[1].vValue.dwType = ADSTYPE_INTEGER; SearchPref[1].vValue.Integer = 250;
// Make it cache the results at the client side. This is
// default, but try it anyway.
SearchPref[2].dwSearchPref = ADS_SEARCHPREF_CACHE_RESULTS; SearchPref[2].vValue.dwType = ADSTYPE_BOOLEAN; SearchPref[2].vValue.Boolean = TRUE;
hr = ADSISetSearchPreference( /* hDSObject */ ldapHandle, /* pSearchPrefs */ SearchPref, /* dwNumPrefs */ 3 ); if ( FAILED( hr )) { printf( "SetSearchPrefs failed\n"); return; }
// Begin Search
hr = ADSIExecuteSearch( ldapHandle, searchFilter, attribs, sizeof(attribs) / sizeof(*attribs), &sh); if ( FAILED( hr)) { printf( "Search failed for %ws\n", searchFilter ); return; }
// Search
hr = ADSIGetFirstRow ( ldapHandle, sh ); if ( !FAILED( hr ) ) { PrintRow( ldapHandle, sh, attribs, sizeof(attribs) / sizeof(*attribs) ); } else { printf( "GetFirstRow failed \n"); return; }
while ( 1 ) { hr = ADSIGetNextRow( ldapHandle, sh ); if ((SUCCEEDED( hr )) && (hr != S_ADS_NOMORE_ROWS)) { PrintRow ( ldapHandle, sh, attribs, sizeof(attribs) / sizeof(*attribs) ); } else { break; } } // while
// End Search
hr = ADSICloseSearchHandle( ldapHandle, sh ); ADSICloseDSObject( ldapHandle );
} // DumpObject
void _cdecl main( int argc, char *argv[] ) { LPWSTR url; LPWSTR filter;
if ( argc > 2 ) { url = ConvertToLPWSTR( argv[ 1 ] ); filter = ConvertToLPWSTR( argv[ 2 ] ); DumpObject( url, filter ); } } // main()
void _cdecl _bad_main(int argc, char *argv[]) {
HANDLE ldapHandle; HRESULT hr; DWORD dwLastError; WCHAR szErrorBuf[MAX_PATH]; WCHAR szNameBuf[MAX_PATH]; HRESULT hr_return = S_OK;
hr = ADSIOpenDSObject( L"LDAP://192.168.73.1/ROOTDSE", NULL, NULL, 0, &ldapHandle );
if ( SUCCEEDED( hr ) ) { printf( "Successfully opened the ROOTDSE object! \n" ); ADSICloseDSObject( ldapHandle ); } else { printf( "Falied to open ROOTDSE ..\n" ); }
hr = ADSIOpenDSObject( // L"LDAP://192.168.73.1/CN=DhcpRoot,CN=NetServices,CN=Services,CN=Configuration,DC=rterala-test1,DC=officenet",
L"LDAP://192.168.73.1/CN=DhcpRoot,CN=NetServices,CN=Services,CN=Configuration,CN=rterala-test1.rterala.officenet", NULL, NULL, ADS_SECURE_AUTHENTICATION, &ldapHandle );
if ( SUCCEEDED( hr ) ) { printf( "Successfully opened the DhcpRoot object in RCOST.COM! \n" ); ADSICloseDSObject( ldapHandle ); } else { if ( FAILED( hr ) ) { printf( "Failed to open the DHCP ROOT object Errcode is 0x%Xh \n", hr );
if (HRESULT_FACILITY(hr)==FACILITY_WIN32) { hr_return = ADsGetLastError( &dwLastError, szErrorBuf, MAX_PATH-1, szNameBuf, MAX_PATH-1); if (SUCCEEDED(hr_return)) { wprintf(L"Error Code: %d\n Error Text: %ws\n Provider: %ws\n", dwLastError, szErrorBuf, szNameBuf); } }
} }
hr = ADSIOpenDSObject( L"LDAP://192.168.73.1/CN=DhcpRoot,CN=NetServices,CN=Services,CN=Configuration,DC=rterala-test1,DC=officenet", // L"Administrator",
// L"b4,checkin",
NULL, NULL, ADS_SECURE_AUTHENTICATION, &ldapHandle );
if ( SUCCEEDED( hr ) ) { printf( "Successfully opened the DhcpRoot object in RCOST.COM! \n" ); ADSICloseDSObject( &ldapHandle ); } else { if ( FAILED( hr ) ) { printf( "Failed to open the DHCP ROOT object Errcode is 0x%Xh \n", hr ); }
if ( HRESULT_FACILITY(hr) == FACILITY_WIN32 ) { hr_return = ADsGetLastError( &dwLastError, szErrorBuf, MAX_PATH-1, szNameBuf, MAX_PATH-1 );
if ( SUCCEEDED( hr_return ) ) { wprintf(L"Error code: %d \n Error Text: %ws\n Provider: %ws \n", dwLastError, szErrorBuf, szNameBuf ); } } }
exit(0); } // main()
|