|
|
BSD 4.3reno
/*
******************************************************************************
*
* Module: bb_server.c
*
* Functions:
* main() - The main routine, mostly generated by rpcgen
* bb_server_init() - Initialize all of the data structures.
* bb_get_ip() - Get the IP address of the calling function.
* billboard_prog_1() - The dispatch routine, generated by rpcgen.
*
*
******************************************************************************
*/
/*
******************************************************************************
* Include Files
******************************************************************************
*/
#include <stdio.h>
#include <syslog.h>
#include <rpc/rpc.h>
#include "common.h"
#include "protocol.h"
#include "server.h"
static void billboard_prog_1();
char *itoa();
/*************************************************************************
** **
** main() - The main server routine. This was generated by rpcgen. **
** It was cut out of the rpcgen'ed code because there needs to be **
** initialization done inside of main. **
** **
*************************************************************************/
main()
{
register SVCXPRT *transp;
(void) pmap_unset(BILLBOARD_PROG, BILLBOARD_VERS);
transp = svcudp_create(RPC_ANYSOCK);
if (transp == NULL) {
fprintf(stderr, "cannot create udp service.");
exit(1);
}
if (!svc_register(transp, BILLBOARD_PROG, BILLBOARD_VERS, billboard_prog_1, IPPROTO_UDP)) {
fprintf(stderr, "unable to register (BILLBOARD_PROG, BILLBOARD_VERS, udp).");
exit(1);
}
transp = svctcp_create(RPC_ANYSOCK, 0, 0);
if (transp == NULL) {
fprintf(stderr, "cannot create tcp service.");
exit(1);
}
if (!svc_register(transp, BILLBOARD_PROG, BILLBOARD_VERS, billboard_prog_1, IPPROTO_TCP)) {
fprintf(stderr, "unable to register (BILLBOARD_PROG, BILLBOARD_VERS, tcp).");
exit(1);
}
/*
** Initialize the server. Read all of the data structures and
** create the files that do not exist.
*/
if ( bb_server_init() != BB_SUCCESS )
{
fprintf( stderr, "ABORTING: Unable to init server database.\n");
return BB_FAILURE;
}
svc_run();
fprintf(stderr, "svc_run returned");
exit(1);
/* NOTREACHED */
}
/*************************************************************************
** **
** bb_server_init() - Initialize the servers database structures. **
** Setup or create the files if they do not exist. Most errors with **
** the files will cause an abort. **
** **
*************************************************************************/
int
bb_server_init()
{
if ( bb_read_companies() != BB_SUCCESS )
{
fprintf( stderr, "Unable to read company data file.\n");
return BB_FAILURE;
}
if ( bb_read_passwords() != BB_SUCCESS )
{
fprintf( stderr, "Unable to read password file.\n");
return BB_FAILURE;
}
if ( bb_read_phases() != BB_SUCCESS )
{
fprintf( stderr, "Unable to read phases file.\n");
return BB_FAILURE;
}
if ( bb_read_board() != BB_SUCCESS )
{
fprintf( stderr, "Unable to read board file.\n");
return BB_FAILURE;
}
return BB_SUCCESS;
}
/*************************************************************************
** **
** bb_get_ip() - From the transport structure of the caller copy the **
** IP address into an IP structure. **
** **
*************************************************************************/
static SVCXPRT *bb_xprt; /* The xport struct of the request. */
void
bb_get_ip( ip)
BB_ip ip; /* Pointer to an ip for output. */
{
char line[20]; /* Just some space for an ip number. */
(void)memset( (char *)ip, (int)0, (int)BB_IP_ADDR_LEN);
sprintf( line, "%u.", bb_xprt->xp_raddr.sin_addr.S_un.S_un_b.s_b1);
strncpy( ip, line, 4);
sprintf( line, "%u.", bb_xprt->xp_raddr.sin_addr.S_un.S_un_b.s_b2);
strncat( ip, line, 4);
sprintf( line, "%u.", bb_xprt->xp_raddr.sin_addr.S_un.S_un_b.s_b3);
strncat( ip, line, 4);
sprintf( line, "%u", bb_xprt->xp_raddr.sin_addr.S_un.S_un_b.s_b4);
strncat( ip, line, 3);
}
static void
billboard_prog_1(rqstp, transp)
struct svc_req *rqstp;
register SVCXPRT *transp;
{
union {
BB_set_in bb_set_1_arg;
BB_set_in bb_unset_1_arg;
BB_list_in bb_alist_1_arg;
BB_list_in bb_blist_1_arg;
BB_list_in bb_clist_1_arg;
BB_list_in bb_dlist_1_arg;
BB_passwd_in bb_passwd_set_1_arg;
} argument;
char *result;
bool_t (*xdr_argument)(), (*xdr_result)();
char *(*local)();
/*
** This was added after rpcgen.
*/
bb_xprt = transp;
switch (rqstp->rq_proc) {
case NULLPROC:
(void) svc_sendreply(transp, xdr_void, (char *)NULL);
return;
case BB_SET:
xdr_argument = xdr_BB_set_in;
xdr_result = xdr_BB_set_out;
local = (char *(*)()) bb_set_1;
break;
case BB_UNSET:
xdr_argument = xdr_BB_set_in;
xdr_result = xdr_BB_set_out;
local = (char *(*)()) bb_unset_1;
break;
case BB_ALIST:
xdr_argument = xdr_BB_list_in;
xdr_result = xdr_BB_list_out;
local = (char *(*)()) bb_alist_1;
break;
case BB_BLIST:
xdr_argument = xdr_BB_list_in;
xdr_result = xdr_BB_list_out;
local = (char *(*)()) bb_blist_1;
break;
case BB_CLIST:
xdr_argument = xdr_BB_list_in;
xdr_result = xdr_BB_list_out;
local = (char *(*)()) bb_clist_1;
break;
case BB_DLIST:
xdr_argument = xdr_BB_list_in;
xdr_result = xdr_BB_list_out;
local = (char *(*)()) bb_dlist_1;
break;
case BB_PASSWD_SET:
xdr_argument = xdr_BB_passwd_in;
xdr_result = xdr_int;
local = (char *(*)()) bb_passwd_set_1;
break;
case BB_GRID:
xdr_argument = xdr_void;
xdr_result = xdr_BB_grid;
local = (char *(*)()) bb_grid_1;
break;
default:
svcerr_noproc(transp);
return;
}
bzero((char *)&argument, sizeof(argument));
if (!svc_getargs(transp, xdr_argument, &argument)) {
svcerr_decode(transp);
return;
}
result = (*local)(&argument, rqstp);
if (result != NULL && !svc_sendreply(transp, xdr_result, result)) {
svcerr_systemerr(transp);
}
if (!svc_freeargs(transp, xdr_argument, &argument)) {
fprintf(stderr, "unable to free arguments");
exit(1);
}
return;
}
This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.