update.c revision 1.5 1 /* $NetBSD: update.c,v 1.5 1999/07/03 12:30:42 simonb Exp $ */
2
3 /*
4 * Routines for controlled update/initialization of request structures.
5 *
6 * request_init() initializes its argument. Pointers and string-valued members
7 * are initialized to zero, to indicate that no lookup has been attempted.
8 *
9 * request_set() adds information to an already initialized request structure.
10 *
11 * Both functions take a variable-length name-value list.
12 *
13 * Diagnostics are reported through syslog(3).
14 *
15 * Author: Wietse Venema, Eindhoven University of Technology, The Netherlands.
16 */
17
18 #include <sys/cdefs.h>
19 #ifndef lint
20 #if 0
21 static char sccsid[] = "@(#) update.c 1.1 94/12/28 17:42:56";
22 #else
23 __RCSID("$NetBSD: update.c,v 1.5 1999/07/03 12:30:42 simonb Exp $");
24 #endif
25 #endif
26
27 /* System libraries */
28
29 #include <stdio.h>
30 #include <syslog.h>
31 #include <string.h>
32 #include <unistd.h>
33
34 /* Local stuff. */
35
36 #include "mystdarg.h"
37 #include "tcpd.h"
38
39 static struct request_info *request_fill __P((struct request_info *, va_list));
40
41 /* request_fill - request update engine */
42
43 static struct request_info *request_fill(request, ap)
44 struct request_info *request;
45 va_list ap;
46 {
47 int key;
48 char *ptr;
49
50 while ((key = va_arg(ap, int)) > 0) {
51 switch (key) {
52 default:
53 tcpd_warn("request_fill: invalid key: %d", key);
54 return (request);
55 case RQ_FILE:
56 request->fd = va_arg(ap, int);
57 continue;
58 case RQ_CLIENT_SIN:
59 request->client->sin = va_arg(ap, struct sockaddr_in *);
60 continue;
61 case RQ_SERVER_SIN:
62 request->server->sin = va_arg(ap, struct sockaddr_in *);
63 continue;
64
65 /*
66 * All other fields are strings with the same maximal length.
67 */
68
69 case RQ_DAEMON:
70 ptr = request->daemon;
71 break;
72 case RQ_USER:
73 ptr = request->user;
74 break;
75 case RQ_CLIENT_NAME:
76 ptr = request->client->name;
77 break;
78 case RQ_CLIENT_ADDR:
79 ptr = request->client->addr;
80 break;
81 case RQ_SERVER_NAME:
82 ptr = request->server->name;
83 break;
84 case RQ_SERVER_ADDR:
85 ptr = request->server->addr;
86 break;
87 }
88 STRN_CPY(ptr, va_arg(ap, char *), STRING_LENGTH);
89 }
90 return (request);
91 }
92
93 /* request_init - initialize request structure */
94
95 struct request_info *VARARGS(request_init, struct request_info *, request)
96 {
97 static struct request_info default_info;
98 struct request_info *r;
99 va_list ap;
100
101 /*
102 * Initialize data members. We do not assign default function pointer
103 * members, to avoid pulling in the whole socket module when it is not
104 * really needed.
105 */
106 VASTART(ap, struct request_info *, request);
107 *request = default_info;
108 request->fd = -1;
109 (void)strncpy(request->daemon, unknown, sizeof(request->daemon) - 1);
110 (void)snprintf(request->pid, sizeof(request->pid), "%d", getpid());
111 request->client->request = request;
112 request->server->request = request;
113 r = request_fill(request, ap);
114 VAEND(ap);
115 return (r);
116 }
117
118 /* request_set - update request structure */
119
120 struct request_info *VARARGS(request_set, struct request_info *, request)
121 {
122 struct request_info *r;
123 va_list ap;
124
125 VASTART(ap, struct request_info *, request);
126 r = request_fill(request, ap);
127 VAEND(ap);
128 return (r);
129 }
130