annotate zotnet/mts/client.c @ 12:441a2190cfae

Lion fix
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Sat, 21 Apr 2012 13:10:49 +0900
parents a6481689f99c
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
bce86c4163a3 Initial revision
kono
parents:
diff changeset
1 /* client.c - connect to a server */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
2 #ifndef lint
12
441a2190cfae Lion fix
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 10
diff changeset
3 static char ident[] = "@(#)$Id: client.c,v 1.3 2006/12/05 18:18:14 kono Exp $";
0
bce86c4163a3 Initial revision
kono
parents:
diff changeset
4 #endif /* lint */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
5
bce86c4163a3 Initial revision
kono
parents:
diff changeset
6 #if defined(SYS5) && defined(AUX)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
7 #define u_short ushort
bce86c4163a3 Initial revision
kono
parents:
diff changeset
8 #define u_long ulong
bce86c4163a3 Initial revision
kono
parents:
diff changeset
9 #endif
bce86c4163a3 Initial revision
kono
parents:
diff changeset
10
bce86c4163a3 Initial revision
kono
parents:
diff changeset
11
bce86c4163a3 Initial revision
kono
parents:
diff changeset
12 #if defined(BSD42) || defined(SOCKETS)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
13 #include "../h/strings.h"
bce86c4163a3 Initial revision
kono
parents:
diff changeset
14 #include <stdio.h>
bce86c4163a3 Initial revision
kono
parents:
diff changeset
15 #include "mts.h"
bce86c4163a3 Initial revision
kono
parents:
diff changeset
16 #include <errno.h>
bce86c4163a3 Initial revision
kono
parents:
diff changeset
17 #include <sys/types.h>
bce86c4163a3 Initial revision
kono
parents:
diff changeset
18 #include <sys/socket.h>
bce86c4163a3 Initial revision
kono
parents:
diff changeset
19 #include <netinet/in.h>
bce86c4163a3 Initial revision
kono
parents:
diff changeset
20 #include <netdb.h>
bce86c4163a3 Initial revision
kono
parents:
diff changeset
21 #ifndef hpux
bce86c4163a3 Initial revision
kono
parents:
diff changeset
22 #include <arpa/inet.h>
bce86c4163a3 Initial revision
kono
parents:
diff changeset
23 #endif
bce86c4163a3 Initial revision
kono
parents:
diff changeset
24
bce86c4163a3 Initial revision
kono
parents:
diff changeset
25 #ifdef HESIOD
bce86c4163a3 Initial revision
kono
parents:
diff changeset
26 #include <hesiod.h>
bce86c4163a3 Initial revision
kono
parents:
diff changeset
27 #endif
bce86c4163a3 Initial revision
kono
parents:
diff changeset
28
bce86c4163a3 Initial revision
kono
parents:
diff changeset
29 #ifdef KPOP
bce86c4163a3 Initial revision
kono
parents:
diff changeset
30 #include <krb.h>
bce86c4163a3 Initial revision
kono
parents:
diff changeset
31 #include <ctype.h>
bce86c4163a3 Initial revision
kono
parents:
diff changeset
32
bce86c4163a3 Initial revision
kono
parents:
diff changeset
33 static CREDENTIALS cred;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
34 static MSG_DAT msg_data;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
35 static KTEXT ticket = (KTEXT)NULL;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
36 static Key_schedule schedule;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
37 #endif /* KPOP */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
38
bce86c4163a3 Initial revision
kono
parents:
diff changeset
39 #define NOTOK (-1)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
40 #define OK 0
bce86c4163a3 Initial revision
kono
parents:
diff changeset
41 #define DONE 1
bce86c4163a3 Initial revision
kono
parents:
diff changeset
42
bce86c4163a3 Initial revision
kono
parents:
diff changeset
43 #define TRUE 1
bce86c4163a3 Initial revision
kono
parents:
diff changeset
44 #define FALSE 0
bce86c4163a3 Initial revision
kono
parents:
diff changeset
45
bce86c4163a3 Initial revision
kono
parents:
diff changeset
46 #define OOPS1 (-2)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
47 #define OOPS2 (-3)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
48
bce86c4163a3 Initial revision
kono
parents:
diff changeset
49 #define MAXARGS 1000
bce86c4163a3 Initial revision
kono
parents:
diff changeset
50 #define MAXNETS 5
bce86c4163a3 Initial revision
kono
parents:
diff changeset
51 #define MAXHOSTS 25
bce86c4163a3 Initial revision
kono
parents:
diff changeset
52
bce86c4163a3 Initial revision
kono
parents:
diff changeset
53 /* */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
54
bce86c4163a3 Initial revision
kono
parents:
diff changeset
55 #if !defined(BSD44) && !defined(__GNU_LIBRARY__)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
56 extern int sys_nerr;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
57 extern char *sys_errlist[];
bce86c4163a3 Initial revision
kono
parents:
diff changeset
58 #endif
bce86c4163a3 Initial revision
kono
parents:
diff changeset
59
bce86c4163a3 Initial revision
kono
parents:
diff changeset
60
bce86c4163a3 Initial revision
kono
parents:
diff changeset
61 struct addrent {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
62 int a_addrtype; /* assumes AF_INET for inet_netof () */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
63
bce86c4163a3 Initial revision
kono
parents:
diff changeset
64 union {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
65 int un_net;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
66 char un_addr[14];
bce86c4163a3 Initial revision
kono
parents:
diff changeset
67 } un;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
68 #define a_net un.un_net
bce86c4163a3 Initial revision
kono
parents:
diff changeset
69 #define a_addr un.un_addr
bce86c4163a3 Initial revision
kono
parents:
diff changeset
70 };
bce86c4163a3 Initial revision
kono
parents:
diff changeset
71
bce86c4163a3 Initial revision
kono
parents:
diff changeset
72 static struct addrent *ne, *nz;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
73 static struct addrent nets[MAXNETS];
bce86c4163a3 Initial revision
kono
parents:
diff changeset
74
bce86c4163a3 Initial revision
kono
parents:
diff changeset
75 static struct addrent *he, *hz;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
76 static struct addrent hosts[MAXHOSTS];
bce86c4163a3 Initial revision
kono
parents:
diff changeset
77
bce86c4163a3 Initial revision
kono
parents:
diff changeset
78 #ifdef KPOP
bce86c4163a3 Initial revision
kono
parents:
diff changeset
79 char krb_realm[REALM_SZ];
bce86c4163a3 Initial revision
kono
parents:
diff changeset
80 char *PrincipalHostname();
bce86c4163a3 Initial revision
kono
parents:
diff changeset
81 static char *kservice; /* "pop" if using kpop */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
82 #endif /* KPOP */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
83
bce86c4163a3 Initial revision
kono
parents:
diff changeset
84 #ifdef __STDC__
bce86c4163a3 Initial revision
kono
parents:
diff changeset
85 static int rcaux (struct servent *, struct hostent *, int, char *);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
86 static int getport (int, int, char *);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
87 static int inet (struct hostent *, int);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
88 #else
bce86c4163a3 Initial revision
kono
parents:
diff changeset
89 static int rcaux (), getport (), inet ();
bce86c4163a3 Initial revision
kono
parents:
diff changeset
90 #endif
bce86c4163a3 Initial revision
kono
parents:
diff changeset
91
bce86c4163a3 Initial revision
kono
parents:
diff changeset
92
bce86c4163a3 Initial revision
kono
parents:
diff changeset
93 #if defined(BIND) && !defined(h_addr)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
94 #define h_addr h_addr_list[0]
bce86c4163a3 Initial revision
kono
parents:
diff changeset
95 #endif
bce86c4163a3 Initial revision
kono
parents:
diff changeset
96
bce86c4163a3 Initial revision
kono
parents:
diff changeset
97 #define inaddr_copy(hp,sin) \
bce86c4163a3 Initial revision
kono
parents:
diff changeset
98 bcopy ((hp) -> h_addr, (char *) &((sin) -> sin_addr), (hp) -> h_length)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
99
bce86c4163a3 Initial revision
kono
parents:
diff changeset
100
bce86c4163a3 Initial revision
kono
parents:
diff changeset
101 struct hostent *gethostbystring ();
bce86c4163a3 Initial revision
kono
parents:
diff changeset
102
bce86c4163a3 Initial revision
kono
parents:
diff changeset
103
bce86c4163a3 Initial revision
kono
parents:
diff changeset
104 static int brkany ();
bce86c4163a3 Initial revision
kono
parents:
diff changeset
105 static char *getcpy (), **copyip (), **brkstring ();
bce86c4163a3 Initial revision
kono
parents:
diff changeset
106
bce86c4163a3 Initial revision
kono
parents:
diff changeset
107 /* */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
108
bce86c4163a3 Initial revision
kono
parents:
diff changeset
109 int client (args, protocol, service, rproto, response)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
110 char *args,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
111 *protocol,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
112 *service, /* "pop" or "pop/kpop" */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
113 *response;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
114 int rproto;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
115 {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
116 int sd;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
117 register char **ap;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
118 char *arguments[MAXARGS];
bce86c4163a3 Initial revision
kono
parents:
diff changeset
119 register struct hostent *hp;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
120 #ifndef BIND
bce86c4163a3 Initial revision
kono
parents:
diff changeset
121 register struct netent *np;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
122 #endif
bce86c4163a3 Initial revision
kono
parents:
diff changeset
123 register struct servent *sp;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
124 #ifdef KPOP
bce86c4163a3 Initial revision
kono
parents:
diff changeset
125 char *cp;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
126
bce86c4163a3 Initial revision
kono
parents:
diff changeset
127 if (cp = index (kservice = service, '/')) { /* "pop/kpop" */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
128 *cp++ = '\0'; /* kservice = "pop" */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
129 service = cp; /* service = "kpop" */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
130 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
131 else
bce86c4163a3 Initial revision
kono
parents:
diff changeset
132 kservice = NULL; /* not using KERBEROS */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
133 #endif /* KPOP */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
134
bce86c4163a3 Initial revision
kono
parents:
diff changeset
135
bce86c4163a3 Initial revision
kono
parents:
diff changeset
136 if ((sp = getservbyname (service, protocol)) == NULL) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
137 #ifdef HESIOD
bce86c4163a3 Initial revision
kono
parents:
diff changeset
138 if ((sp = hes_getservbyname (service, protocol)) == NULL) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
139 (void) sprintf (response, "%s/%s: unknown service",
bce86c4163a3 Initial revision
kono
parents:
diff changeset
140 protocol, service);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
141 return NOTOK;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
142 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
143 #else
bce86c4163a3 Initial revision
kono
parents:
diff changeset
144 (void) sprintf (response, "%s/%s: unknown service", protocol, service);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
145 return NOTOK;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
146 #endif
bce86c4163a3 Initial revision
kono
parents:
diff changeset
147 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
148
bce86c4163a3 Initial revision
kono
parents:
diff changeset
149 ap = arguments;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
150 if (args != NULL && *args != 0)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
151 ap = copyip (brkstring (getcpy (args), " ", "\n"), ap);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
152 else
bce86c4163a3 Initial revision
kono
parents:
diff changeset
153 if (servers != NULL && *servers != 0)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
154 ap = copyip (brkstring (getcpy (servers), " ", "\n"), ap);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
155 if (ap == arguments) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
156 *ap++ = getcpy ("localhost");
bce86c4163a3 Initial revision
kono
parents:
diff changeset
157 *ap = NULL;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
158 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
159
bce86c4163a3 Initial revision
kono
parents:
diff changeset
160 nz = (ne = nets) + sizeof nets / sizeof nets[0];
bce86c4163a3 Initial revision
kono
parents:
diff changeset
161 hz = (he = hosts) + sizeof hosts / sizeof hosts[0];
bce86c4163a3 Initial revision
kono
parents:
diff changeset
162
bce86c4163a3 Initial revision
kono
parents:
diff changeset
163 for (ap = arguments; *ap; ap++) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
164 if (**ap == '\01') {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
165 #if !defined(BIND) && !defined(__CYGWIN32__)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
166 if (np = getnetbyname (*ap + 1)) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
167 sethostent (1);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
168 while (hp = gethostent ())
bce86c4163a3 Initial revision
kono
parents:
diff changeset
169 if (np -> n_addrtype == hp -> h_addrtype
bce86c4163a3 Initial revision
kono
parents:
diff changeset
170 && inet (hp, np -> n_net)) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
171 switch (sd = rcaux (sp, hp, rproto, response)) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
172 case NOTOK:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
173 continue;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
174 case OOPS1:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
175 break;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
176 case OOPS2:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
177 return NOTOK;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
178
bce86c4163a3 Initial revision
kono
parents:
diff changeset
179 default:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
180 return sd;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
181 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
182 break;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
183 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
184 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
185 #endif
bce86c4163a3 Initial revision
kono
parents:
diff changeset
186 continue;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
187 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
188
bce86c4163a3 Initial revision
kono
parents:
diff changeset
189 if (hp = gethostbystring (*ap)) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
190 switch (sd = rcaux (sp, hp, rproto, response)) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
191 case NOTOK:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
192 case OOPS1:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
193 break;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
194 case OOPS2:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
195 return NOTOK;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
196
bce86c4163a3 Initial revision
kono
parents:
diff changeset
197 default:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
198 return sd;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
199 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
200 continue;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
201 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
202 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
203
bce86c4163a3 Initial revision
kono
parents:
diff changeset
204 (void) strcpy (response, "no servers available");
bce86c4163a3 Initial revision
kono
parents:
diff changeset
205 return NOTOK;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
206 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
207
bce86c4163a3 Initial revision
kono
parents:
diff changeset
208 /* */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
209
bce86c4163a3 Initial revision
kono
parents:
diff changeset
210 static int rcaux (sp, hp, rproto, response)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
211 register struct servent *sp;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
212 register struct hostent *hp;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
213 int rproto;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
214 register char *response;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
215 {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
216 int sd;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
217 struct in_addr in;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
218 register struct addrent *ap;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
219 struct sockaddr_in in_socket;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
220 register struct sockaddr_in *isock = &in_socket;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
221 #ifdef KPOP
bce86c4163a3 Initial revision
kono
parents:
diff changeset
222 int rem;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
223 #endif /* KPOP */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
224
bce86c4163a3 Initial revision
kono
parents:
diff changeset
225 for (ap = nets; ap < ne; ap++)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
226 if (ap -> a_addrtype == hp -> h_addrtype && inet (hp, ap -> a_net))
bce86c4163a3 Initial revision
kono
parents:
diff changeset
227 return NOTOK;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
228
bce86c4163a3 Initial revision
kono
parents:
diff changeset
229 for (ap = hosts; ap < he; ap++)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
230 if (ap -> a_addrtype == hp -> h_addrtype
bce86c4163a3 Initial revision
kono
parents:
diff changeset
231 && bcmp (ap -> a_addr, hp -> h_addr, hp -> h_length) == 0)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
232 return NOTOK;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
233
bce86c4163a3 Initial revision
kono
parents:
diff changeset
234 if ((sd = getport (rproto, hp -> h_addrtype, response)) == NOTOK)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
235 return OOPS2;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
236
bce86c4163a3 Initial revision
kono
parents:
diff changeset
237 bzero ((char *) isock, sizeof *isock);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
238 isock -> sin_family = hp -> h_addrtype;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
239 inaddr_copy (hp, isock);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
240 isock -> sin_port = sp -> s_port;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
241
bce86c4163a3 Initial revision
kono
parents:
diff changeset
242 if (connect (sd, (struct sockaddr *) isock, sizeof *isock) == NOTOK)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
243 switch (errno) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
244 case ENETDOWN:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
245 case ENETUNREACH:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
246 (void) close (sd);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
247 if (ne < nz) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
248 ne -> a_addrtype = hp -> h_addrtype;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
249 bcopy (hp -> h_addr, (char *) &in, sizeof in);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
250 ne -> a_net = inet_netof (in);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
251 ne++;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
252 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
253 return OOPS1;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
254
bce86c4163a3 Initial revision
kono
parents:
diff changeset
255 case ETIMEDOUT:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
256 case ECONNREFUSED:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
257 default:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
258 (void) close (sd);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
259 if (he < hz) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
260 he -> a_addrtype = hp -> h_addrtype;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
261 bcopy (hp -> h_addr, he -> a_addr, hp -> h_length);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
262 he++;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
263 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
264 return NOTOK;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
265 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
266
bce86c4163a3 Initial revision
kono
parents:
diff changeset
267 #ifdef KPOP
bce86c4163a3 Initial revision
kono
parents:
diff changeset
268 if (kservice) { /* "pop" */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
269 ticket = (KTEXT)malloc( sizeof(KTEXT_ST) );
bce86c4163a3 Initial revision
kono
parents:
diff changeset
270 rem = krb_sendauth(0L, sd, ticket, kservice, hp->h_name,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
271 (char *) krb_realmofhost(hp->h_name),
bce86c4163a3 Initial revision
kono
parents:
diff changeset
272 (unsigned long)0, &msg_data, &cred, schedule,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
273 (struct sockaddr_in *)NULL,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
274 (struct sockaddr_in *)NULL,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
275 "KPOPV0.1");
bce86c4163a3 Initial revision
kono
parents:
diff changeset
276 if (rem != KSUCCESS) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
277 close(sd);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
278 (void) strcpy(response, "Post office refused connection: ");
bce86c4163a3 Initial revision
kono
parents:
diff changeset
279 (void) strcat(response, krb_err_txt[rem]);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
280 return OOPS2;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
281 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
282 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
283 #endif /* KPOP */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
284
bce86c4163a3 Initial revision
kono
parents:
diff changeset
285 return sd;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
286 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
287
bce86c4163a3 Initial revision
kono
parents:
diff changeset
288 /* */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
289
bce86c4163a3 Initial revision
kono
parents:
diff changeset
290 static int getport (rproto, addrtype, response)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
291 int rproto,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
292 addrtype;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
293 register char *response;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
294 {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
295 int sd,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
296 port;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
297 struct sockaddr_in in_socket,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
298 *isock = &in_socket;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
299
bce86c4163a3 Initial revision
kono
parents:
diff changeset
300 if (rproto && addrtype != AF_INET) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
301 (void) sprintf (response, "reserved ports not supported for af=%d",
bce86c4163a3 Initial revision
kono
parents:
diff changeset
302 addrtype);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
303 errno = ENOPROTOOPT;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
304 return NOTOK;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
305 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
306
bce86c4163a3 Initial revision
kono
parents:
diff changeset
307 if ((sd = socket (AF_INET, SOCK_STREAM, 0)) == NOTOK) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
308 (void) sprintf (response, "unable to create socket: %s",
bce86c4163a3 Initial revision
kono
parents:
diff changeset
309 errno > 0 && errno < sys_nerr ? sys_errlist[errno]
bce86c4163a3 Initial revision
kono
parents:
diff changeset
310 : "unknown error");
bce86c4163a3 Initial revision
kono
parents:
diff changeset
311 return NOTOK;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
312 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
313 #ifdef KPOP
bce86c4163a3 Initial revision
kono
parents:
diff changeset
314 if (kservice) /* "pop" */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
315 return(sd);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
316 #endif /* KPOP */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
317 if (!rproto)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
318 return sd;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
319
bce86c4163a3 Initial revision
kono
parents:
diff changeset
320 bzero ((char *) isock, sizeof *isock);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
321 isock -> sin_family = addrtype;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
322 for (port = IPPORT_RESERVED - 1;;) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
323 isock -> sin_port = htons ((u_short) port);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
324 if (bind (sd, (struct sockaddr *) isock, sizeof *isock) != NOTOK)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
325 return sd;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
326
bce86c4163a3 Initial revision
kono
parents:
diff changeset
327 switch (errno) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
328 case EADDRINUSE:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
329 case EADDRNOTAVAIL:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
330 if (--port <= IPPORT_RESERVED / 2) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
331 (void) strcpy (response, "ports available");
bce86c4163a3 Initial revision
kono
parents:
diff changeset
332 return NOTOK;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
333 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
334 break;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
335
bce86c4163a3 Initial revision
kono
parents:
diff changeset
336 default:
bce86c4163a3 Initial revision
kono
parents:
diff changeset
337 (void) sprintf (response, "unable to bind socket: %s",
bce86c4163a3 Initial revision
kono
parents:
diff changeset
338 errno > 0 && errno < sys_nerr ? sys_errlist[errno]
bce86c4163a3 Initial revision
kono
parents:
diff changeset
339 : "unknown error");
bce86c4163a3 Initial revision
kono
parents:
diff changeset
340 return NOTOK;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
341 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
342 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
343 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
344
bce86c4163a3 Initial revision
kono
parents:
diff changeset
345 /* */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
346
bce86c4163a3 Initial revision
kono
parents:
diff changeset
347 static int inet (hp, net)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
348 register struct hostent *hp;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
349 int net;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
350 {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
351 struct in_addr in;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
352
bce86c4163a3 Initial revision
kono
parents:
diff changeset
353 bcopy (hp -> h_addr, (char *) &in, sizeof in);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
354 return (inet_netof (in) == net);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
355 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
356
bce86c4163a3 Initial revision
kono
parents:
diff changeset
357 /* */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
358
bce86c4163a3 Initial revision
kono
parents:
diff changeset
359 /* taken from ISODE's compat/internet.c */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
360
bce86c4163a3 Initial revision
kono
parents:
diff changeset
361 #if !defined(SOLARIS) && !defined(linux) && !defined(__bsdi__) && \
bce86c4163a3 Initial revision
kono
parents:
diff changeset
362 !defined(OSF1) && !defined(__osf__) && !defined(__FreeBSD__) && \
2
442dbbf0ac7d utf first try
kono
parents: 0
diff changeset
363 !defined(__NetBSD__) && !defined(__APPLE__)
0
bce86c4163a3 Initial revision
kono
parents:
diff changeset
364 #ifndef DG
bce86c4163a3 Initial revision
kono
parents:
diff changeset
365 #ifndef __alpha
bce86c4163a3 Initial revision
kono
parents:
diff changeset
366 u_long inet_addr ();
bce86c4163a3 Initial revision
kono
parents:
diff changeset
367 #else
bce86c4163a3 Initial revision
kono
parents:
diff changeset
368 u_int inet_addr ();
bce86c4163a3 Initial revision
kono
parents:
diff changeset
369 #endif
bce86c4163a3 Initial revision
kono
parents:
diff changeset
370 #else
bce86c4163a3 Initial revision
kono
parents:
diff changeset
371 struct in_addr inet_addr ();
bce86c4163a3 Initial revision
kono
parents:
diff changeset
372 #endif
bce86c4163a3 Initial revision
kono
parents:
diff changeset
373 #endif
bce86c4163a3 Initial revision
kono
parents:
diff changeset
374
bce86c4163a3 Initial revision
kono
parents:
diff changeset
375 static char *empty = NULL;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
376 #ifdef h_addr
bce86c4163a3 Initial revision
kono
parents:
diff changeset
377 static char *addrs[2] = { NULL };
bce86c4163a3 Initial revision
kono
parents:
diff changeset
378 #endif
bce86c4163a3 Initial revision
kono
parents:
diff changeset
379 struct hostent *mh_gethostbyname();
bce86c4163a3 Initial revision
kono
parents:
diff changeset
380
bce86c4163a3 Initial revision
kono
parents:
diff changeset
381 struct hostent *gethostbystring (s)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
382 char *s;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
383 {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
384 register struct hostent *h;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
385 #ifndef DG
bce86c4163a3 Initial revision
kono
parents:
diff changeset
386 #ifndef __alpha
bce86c4163a3 Initial revision
kono
parents:
diff changeset
387 static u_long iaddr;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
388 #else
bce86c4163a3 Initial revision
kono
parents:
diff changeset
389 static u_int iaddr;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
390 #endif
bce86c4163a3 Initial revision
kono
parents:
diff changeset
391 #else
bce86c4163a3 Initial revision
kono
parents:
diff changeset
392 static struct in_addr iaddr;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
393 #endif
bce86c4163a3 Initial revision
kono
parents:
diff changeset
394 static struct hostent hs;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
395
bce86c4163a3 Initial revision
kono
parents:
diff changeset
396 iaddr = inet_addr (s);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
397 #ifndef DG
bce86c4163a3 Initial revision
kono
parents:
diff changeset
398 if ((int)iaddr == NOTOK && strcmp (s, "255.255.255.255"))
bce86c4163a3 Initial revision
kono
parents:
diff changeset
399 #else
bce86c4163a3 Initial revision
kono
parents:
diff changeset
400 if (iaddr.s_addr == NOTOK && strcmp (s, "255.255.255.255"))
bce86c4163a3 Initial revision
kono
parents:
diff changeset
401 #endif
bce86c4163a3 Initial revision
kono
parents:
diff changeset
402 return mh_gethostbyname (s);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
403
bce86c4163a3 Initial revision
kono
parents:
diff changeset
404 h = &hs;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
405 h -> h_name = s;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
406 h -> h_aliases = &empty;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
407 h -> h_addrtype = AF_INET;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
408 h -> h_length = sizeof (iaddr);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
409 #ifdef h_addr
bce86c4163a3 Initial revision
kono
parents:
diff changeset
410 h -> h_addr_list = addrs;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
411 bzero ((char *) addrs, sizeof addrs);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
412 #endif
bce86c4163a3 Initial revision
kono
parents:
diff changeset
413 h -> h_addr = (char *) &iaddr;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
414
bce86c4163a3 Initial revision
kono
parents:
diff changeset
415 return h;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
416 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
417
bce86c4163a3 Initial revision
kono
parents:
diff changeset
418 /* */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
419
bce86c4163a3 Initial revision
kono
parents:
diff changeset
420 /* static copies of three MH subroutines... (sigh) */
bce86c4163a3 Initial revision
kono
parents:
diff changeset
421
bce86c4163a3 Initial revision
kono
parents:
diff changeset
422 static char *broken[MAXARGS + 1];
bce86c4163a3 Initial revision
kono
parents:
diff changeset
423
bce86c4163a3 Initial revision
kono
parents:
diff changeset
424
bce86c4163a3 Initial revision
kono
parents:
diff changeset
425 static char **brkstring (strg, brksep, brkterm)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
426 register char *strg;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
427 register char *brksep,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
428 *brkterm;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
429 {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
430 register int bi;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
431 register char c,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
432 *sp;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
433
bce86c4163a3 Initial revision
kono
parents:
diff changeset
434 sp = strg;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
435
bce86c4163a3 Initial revision
kono
parents:
diff changeset
436 for (bi = 0; bi < MAXARGS; bi++) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
437 while (brkany (c = *sp, brksep))
bce86c4163a3 Initial revision
kono
parents:
diff changeset
438 *sp++ = 0;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
439 if (!c || brkany (c, brkterm)) {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
440 *sp = 0;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
441 broken[bi] = 0;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
442 return broken;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
443 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
444
bce86c4163a3 Initial revision
kono
parents:
diff changeset
445 broken[bi] = sp;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
446 while ((c = *++sp) && !brkany (c, brksep) && !brkany (c, brkterm))
bce86c4163a3 Initial revision
kono
parents:
diff changeset
447 continue;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
448 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
449 broken[MAXARGS] = 0;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
450
bce86c4163a3 Initial revision
kono
parents:
diff changeset
451 return broken;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
452 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
453
bce86c4163a3 Initial revision
kono
parents:
diff changeset
454
bce86c4163a3 Initial revision
kono
parents:
diff changeset
455 static brkany (chr, strg)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
456 register char chr,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
457 *strg;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
458 {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
459 register char *sp;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
460
bce86c4163a3 Initial revision
kono
parents:
diff changeset
461 if (strg)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
462 for (sp = strg; *sp; sp++)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
463 if (chr == *sp)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
464 return 1;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
465 return 0;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
466 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
467
bce86c4163a3 Initial revision
kono
parents:
diff changeset
468
bce86c4163a3 Initial revision
kono
parents:
diff changeset
469 static char **copyip (p, q)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
470 register char **p,
bce86c4163a3 Initial revision
kono
parents:
diff changeset
471 **q;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
472 {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
473 while (*p)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
474 *q++ = *p++;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
475 *q = 0;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
476
bce86c4163a3 Initial revision
kono
parents:
diff changeset
477 return q;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
478 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
479
bce86c4163a3 Initial revision
kono
parents:
diff changeset
480
bce86c4163a3 Initial revision
kono
parents:
diff changeset
481 static char *getcpy (str)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
482 register char *str;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
483 {
bce86c4163a3 Initial revision
kono
parents:
diff changeset
484 register char *cp;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
485
bce86c4163a3 Initial revision
kono
parents:
diff changeset
486 if ((cp = malloc ((unsigned) (strlen (str) + 1))) == NULL)
bce86c4163a3 Initial revision
kono
parents:
diff changeset
487 return NULL;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
488
bce86c4163a3 Initial revision
kono
parents:
diff changeset
489 (void) strcpy (cp, str);
bce86c4163a3 Initial revision
kono
parents:
diff changeset
490 return cp;
bce86c4163a3 Initial revision
kono
parents:
diff changeset
491 }
bce86c4163a3 Initial revision
kono
parents:
diff changeset
492 #endif /* BSD42 or SOCKETS */