windows-nt/Source/XPSP1/NT/ds/nameres/rnr/setup/test/rnratm.c
2020-09-26 16:20:57 +08:00

184 lines
5.3 KiB
C

#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 <ws2atm.h>
GUID ATMAType = SVCID_DNS_TYPE_ATMA;
#define BUFFSIZE 3000
_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];
AFPROTOCOLS lpAfpProtocols[1];
usServiceInstanceName.Length = 0;
usServiceInstanceName.MaximumLength = 1024;
usServiceInstanceName.Buffer = UnicodeStringBuf;
usContext.Length = 0;
usContext.MaximumLength = 1024;
usContext.Buffer = UnicodeStringBuf2;
if ( argc != 2 )
{
printf( "\nUsage: rnrtst <Name>\n" );
return( -1 );
}
RtlInitAnsiString( &asServiceInstanceName, argv[1] );
RtlAnsiStringToUnicodeString( &usServiceInstanceName,
&asServiceInstanceName,
FALSE );
WSAStartup(MAKEWORD(1, 1), &wsaData);
memset(Query, 0, sizeof(*Query));
Query->dwSize = sizeof(*Query);
if ( usServiceInstanceName.Buffer[0] != L'*' )
{
Query->lpszServiceInstanceName = usServiceInstanceName.Buffer;
}
Query->lpServiceClassId = &ATMAType;
Query->lpVersion = 0;
Query->dwNameSpace = NS_ALL;
Query->lpNSProviderId = 0;
Query->lpszContext = NULL;
Query->dwNumberOfProtocols = 1;
lpAfpProtocols[0].iAddressFamily = AF_ATM;
lpAfpProtocols[0].iProtocol = PF_ATM;
Query->lpafpProtocols = lpAfpProtocols;
if( WSALookupServiceBegin( Query,
LUP_RETURN_NAME |
LUP_RETURN_TYPE |
LUP_RETURN_VERSION |
LUP_RETURN_COMMENT |
LUP_RETURN_ADDR |
LUP_RETURN_BLOB,
&hRnr ) == SOCKET_ERROR )
{
printf( "LookupBegin failed %d\n", GetLastError() );
}
while ( WSALookupServiceNext( hRnr,
0,
&dwQuerySize,
Query ) == NO_ERROR )
{
PCSADDR_INFO csaddrInfo;
PSOCKADDR_ATM sockaddrAtm;
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 );
if ( Query->dwNumberOfCsAddrs )
{
DWORD iter;
csaddrInfo = Query->lpcsaBuffer;
for ( iter = 0; iter < Query->dwNumberOfCsAddrs; iter++ )
{
sockaddrAtm =
(PSOCKADDR_ATM) csaddrInfo->RemoteAddr.lpSockaddr;
printf( " CsAddrInfo[%d]\n", iter );
printf( " iSocketType = %d\n",
csaddrInfo->iSocketType );
printf( " iProtocol = %d\n",
csaddrInfo->iProtocol );
printf( " ATM address (Remote)\n" );
printf( " Address Type = %d\n",
sockaddrAtm->satm_number.AddressType );
printf( " Address Length = %d\n",
sockaddrAtm->satm_number.NumofDigits );
if ( sockaddrAtm->satm_number.AddressType == ATM_E164 )
printf( " Address = %s\n",
sockaddrAtm->satm_number.Addr );
else
{
DWORD jiter;
printf( " Address = " );
for ( jiter = 0; jiter < ATM_ADDR_SIZE; jiter++ )
{
printf( "%02x", sockaddrAtm->satm_number.Addr[jiter] );
}
printf( "\n" );
}
csaddrInfo++;
}
}
}
printf( "Next finished with %d\n", GetLastError() );
if( WSALookupServiceEnd( hRnr ) )
{
printf( "ServiceEnd failed %d\n", GetLastError() );
}
WSACleanup();
return(0);
}