mirror of https://github.com/tongzx/nt5src
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.
140 lines
4.1 KiB
140 lines
4.1 KiB
#include <nt.h>
|
|
#include <ntrtl.h>
|
|
#include <nturtl.h>
|
|
#include <windows.h>
|
|
#include <winsock2.h>
|
|
#include <wsipx.h>
|
|
#include <svcguid.h>
|
|
#include <stdio.h>
|
|
#include <stdlib.h>
|
|
#include <rpc.h>
|
|
#include <rpcdce.h>
|
|
|
|
#define BUFFSIZE 3000
|
|
|
|
GUID ServiceClassId = { /* 5b50962a-e5a5-11cf-a555-00c04fd8d4ac */
|
|
0x5b50962a,
|
|
0xe5a5,
|
|
0x11cf,
|
|
{0xa5, 0x55, 0x00, 0xc0, 0x4f, 0xd8, 0xd4, 0xac}
|
|
};
|
|
|
|
_cdecl
|
|
main(int argc, char **argv)
|
|
{
|
|
HANDLE hLib;
|
|
WCHAR Buffer[BUFFSIZE];
|
|
PWSAQUERYSETW Query = (PWSAQUERYSETW)Buffer;
|
|
HANDLE hRnr;
|
|
DWORD dwIp;
|
|
DWORD dwQuerySize = BUFFSIZE;
|
|
WSADATA wsaData;
|
|
ANSI_STRING asServiceInstanceName;
|
|
UNICODE_STRING usServiceInstanceName;
|
|
WCHAR UnicodeStringBuf[1024];
|
|
ANSI_STRING asContext;
|
|
UNICODE_STRING usContext;
|
|
WCHAR UnicodeStringBuf2[1024];
|
|
|
|
usServiceInstanceName.Length = 0;
|
|
usServiceInstanceName.MaximumLength = 1024;
|
|
usServiceInstanceName.Buffer = UnicodeStringBuf;
|
|
|
|
usContext.Length = 0;
|
|
usContext.MaximumLength = 1024;
|
|
usContext.Buffer = UnicodeStringBuf2;
|
|
|
|
if ( argc < 2 || argc > 4 )
|
|
{
|
|
printf( "\nUsage: lookup <Name> <Context> Deep\n" );
|
|
|
|
return( -1 );
|
|
}
|
|
|
|
RtlInitAnsiString( &asServiceInstanceName, argv[1] );
|
|
RtlAnsiStringToUnicodeString( &usServiceInstanceName,
|
|
&asServiceInstanceName,
|
|
FALSE );
|
|
RtlInitAnsiString( &asContext, argv[2] );
|
|
RtlAnsiStringToUnicodeString( &usContext,
|
|
&asContext,
|
|
FALSE );
|
|
|
|
WSAStartup(MAKEWORD(1, 1), &wsaData);
|
|
|
|
memset(Query, 0, sizeof(*Query));
|
|
|
|
Query->dwSize = sizeof(*Query);
|
|
Query->lpszServiceInstanceName = usServiceInstanceName.Buffer;
|
|
Query->lpVersion = 0;
|
|
Query->dwNameSpace = NS_NTDS;
|
|
Query->lpNSProviderId = 0;
|
|
Query->lpszContext = usContext.Buffer;
|
|
Query->dwNumberOfProtocols = 0;
|
|
Query->lpServiceClassId = &ServiceClassId;
|
|
|
|
if( WSALookupServiceBegin( Query,
|
|
( argv[3][0] == 'D' ? LUP_DEEP : 0 ) |
|
|
LUP_RETURN_NAME |
|
|
// LUP_RETURN_TYPE |
|
|
// LUP_RETURN_VERSION |
|
|
LUP_RETURN_COMMENT |
|
|
// LUP_RETURN_ADDR |
|
|
// LUP_RETURN_BLOB |
|
|
// LUP_RETURN_ALIASES |
|
|
// LUP_RETURN_QUERY_STRING |
|
|
LUP_CONTAINERS,
|
|
// LUP_RETURN_ALL,
|
|
&hRnr ) == SOCKET_ERROR )
|
|
{
|
|
printf( "LookupBegin failed %d\n", GetLastError() );
|
|
}
|
|
|
|
while ( WSALookupServiceNext( hRnr,
|
|
0,
|
|
&dwQuerySize,
|
|
Query ) == NO_ERROR )
|
|
{
|
|
printf( "Next got: \n" );
|
|
printf( " dwSize = %d\n",
|
|
Query->dwSize );
|
|
printf( " dwOutputFlags = %d\n",
|
|
Query->dwOutputFlags );
|
|
printf( " lpszServiceInstanceName = %ws\n",
|
|
Query->lpszServiceInstanceName );
|
|
if ( Query->lpVersion )
|
|
{
|
|
printf( " lpVersion->dwVersion = %d\n",
|
|
Query->lpVersion->dwVersion );
|
|
printf( " lpVersion->ecHow = %d\n",
|
|
Query->lpVersion->ecHow );
|
|
}
|
|
if ( Query->lpszComment )
|
|
{
|
|
printf( " lpszComment = %ws\n",
|
|
Query->lpszComment );
|
|
}
|
|
printf( " dwNameSpace = %d\n",
|
|
Query->dwNameSpace );
|
|
if ( Query->lpszContext )
|
|
{
|
|
printf( " lpszContext = %ws\n",
|
|
Query->lpszContext );
|
|
}
|
|
printf( " dwNumberOfCsAddrs = %d\n",
|
|
Query->dwNumberOfCsAddrs );
|
|
}
|
|
|
|
printf( "Next finished with %d\n", GetLastError() );
|
|
|
|
if( WSALookupServiceEnd( hRnr ) )
|
|
{
|
|
printf( "ServiceEnd failed %d\n", GetLastError() );
|
|
}
|
|
|
|
WSACleanup();
|
|
|
|
return(0);
|
|
}
|
|
|
|
|