/*
RPC echo server.
Copyright (C) Tim Potter 2003
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see .
*/
#define _WIN32_WINNT 0x0500
#include
#include
#include
#include "rpcecho.h"
#define RPC_MIN_CALLS 1
#define RPC_MAX_CALLS 20
#define RPC_ENDPOINT "\\pipe\\rpcecho"
void AddOne(int in_data, __RPC_FAR int *out_data)
{
printf("AddOne: got in_data = %d\n", in_data);
*out_data = in_data + 1;
}
void EchoData(int len, unsigned char __RPC_FAR in_data[],
unsigned char __RPC_FAR out_data[])
{
printf("EchoData: got len = %d\n", len);
memcpy(out_data, in_data, len);
}
void SinkData(int len, unsigned char __RPC_FAR in_data[ ])
{
printf("SinkData: got len = %d\n", len);
}
void SourceData(int len, unsigned char __RPC_FAR out_data[ ])
{
int i;
printf("SourceData: got len = %d\n", len);
for (i = 0; i < len; i++)
out_data[i] = i & 0xff;
}
void TestCall(wchar_t **s1, wchar_t **s2)
{
if (*s1) {
printf("s1='%S'\n", *s1);
} else {
printf("s1=NULL\n");
}
*s2 = L"test string";
}
long TestCall2(short level, echo_Info **info)
{
static echo_Info i;
printf("TestCall2 level %d\n", level);
*info = &i;
switch (level) {
case 1:
i.info1.v = 10;
break;
case 2:
i.info2.v = 20;
break;
case 3:
i.info3.v = 30;
break;
case 4:
i.info4.v = 40;
break;
case 5:
i.info5.v1 = 50;
i.info5.v2 = 51;
break;
case 6:
i.info6.v1 = 60;
i.info6.info1.v = 61;
break;
case 7:
i.info7.v1 = 70;
i.info7.info4.v = 71;
break;
default:
return -1;
}
return 0;
}
#if 0
void TestSleep(PRPC_ASYNC_STATE pAsync, long seconds)
{
long ret;
printf("async Sleeping for %d seconds\n", seconds);
Sleep(1000 * seconds);
ret = seconds;
RpcAsyncCompleteCall(pAsync, &ret);
}
#else
long TestSleep(long seconds)
{
printf("non-async Sleeping for %d seconds\n", seconds);
Sleep(1000 * seconds);
return seconds;
}
#endif
void echo_TestEnum(echo_Enum1 *foo1,
echo_Enum2 *foo2,
echo_Enum3 *foo3)
{
foo2->e1 = ECHO_ENUM2;
}
void echo_TestSurrounding(echo_Surrounding *data)
{
printf("Incoming array of size %d\n", data->x);
data->x *= 2;
}
short echo_TestDoublePointer(short ***data)
{
if (!*data) {
printf("WARNING: *data == NULL\n");
return 0;
}
if (!**data) {
printf("WARNING: **data == NULL\n");
return 0;
}
printf("Incoming double pointer: %d\n", ***data);
return ***data;
}
void main(int argc, char **argv)
{
RPC_STATUS status;
RPC_BINDING_VECTOR *pBindingVector;
if (argc != 1) {
printf("Usage: rpcechosrv\n");
exit(0);
}
status = RpcServerUseProtseqEp("ncacn_np", RPC_MAX_CALLS, "\\pipe\\rpcecho", NULL);
if (status) {
printf("Failed to register ncacn_np endpoint\n");
exit(status);
}
status = RpcServerUseProtseqEp("ncacn_ip_tcp", RPC_MAX_CALLS, "1234", NULL);
if (status) {
printf("Failed to register ncacn_ip_tcp endpoint\n");
exit(status);
}
status = RpcServerInqBindings(&pBindingVector);
if (status) {
printf("Failed RpcServerInqBindings\n");
exit(status);
}
status = RpcEpRegister(rpcecho_v1_0_s_ifspec, pBindingVector, NULL, "rpcecho server");
if (status) {
printf("Failed RpcEpRegister\n");
exit(status);
}
status = RpcServerRegisterIf(rpcecho_v1_0_s_ifspec, NULL, NULL);
if (status) {
printf("Failed to register interface\n");
exit(status);
}
status = RpcServerRegisterAuthInfo(NULL, RPC_C_AUTHN_WINNT, NULL, NULL);
if (status) {
printf("Failed to setup auth info\n");
}
status = RpcServerListen(RPC_MIN_CALLS, RPC_MAX_CALLS, FALSE);
if (status) {
printf("RpcServerListen returned error %d\n", status);
exit(status);
}
}