]>
Commit | Line | Data |
---|---|---|
eab30d01 | 1 | /* |
2 | * $Source$ | |
3 | * $Author$ | |
4 | * $Header$ | |
5 | * | |
6 | * Copyright (C) 1987 by the Massachusetts Institute of Technology | |
7 | * | |
eab30d01 | 8 | */ |
9 | ||
5dbd09a0 | 10 | #include <sys/types.h> |
11 | #include <sys/uio.h> | |
12 | #include <sys/socket.h> | |
13 | #include <netinet/in.h> | |
c27b3454 | 14 | #include "sms_proto.h" |
0311b667 | 15 | #include <krb.h> |
5dbd09a0 | 16 | |
c27b3454 | 17 | typedef struct returned_tuples { |
18 | struct returned_tuples *next; | |
19 | OPERATION op; | |
0311b667 | 20 | sms_params *retval; |
c27b3454 | 21 | } returned_tuples; |
5dbd09a0 | 22 | |
0311b667 | 23 | /* |
24 | * This should be in the kerberos header file. | |
25 | */ | |
26 | ||
27 | struct krbname { | |
28 | char name[ANAME_SZ]; | |
29 | char inst[INST_SZ]; | |
30 | char realm[REALM_SZ]; | |
31 | }; | |
32 | ||
33 | /* | |
34 | * This structure holds all per-client information; one of these is | |
35 | * allocated for each active client. | |
36 | */ | |
37 | ||
0fa91a0a | 38 | typedef struct _client { |
0311b667 | 39 | OPERATION pending_op; /* Primary pending operation */ |
40 | CONNECTION con; /* Connection to the client */ | |
41 | int state; /* XXX this is really superfluous and should */ | |
42 | /* be removed */ | |
43 | int action; /* what action is pending? */ | |
eab30d01 | 44 | sms_params *args, reply; |
45 | int id; /* Unique id of client */ | |
0311b667 | 46 | struct sockaddr_in haddr; /* IP address of client */ |
47 | char *clname; /* Name client authenticated to */ | |
7a2ebcdf | 48 | int users_id; /* SMS internal ID of authenticated user */ |
0311b667 | 49 | struct krbname kname; /* Parsed version of the above */ |
c27b3454 | 50 | returned_tuples *first, *last; |
50f51267 | 51 | time_t last_time_used; /* Last time connection used */ |
7a2ebcdf | 52 | char *entity; /* entity on other end of the connection */ |
0fa91a0a | 53 | } client; |
54 | ||
55 | /* | |
56 | * States | |
57 | */ | |
58 | ||
59 | #define CL_DEAD 0 | |
60 | #define CL_STARTING 1 | |
61 | ||
62 | /* | |
63 | * Actions. | |
64 | */ | |
65 | ||
66 | #define CL_ACCEPT 0 | |
67 | #define CL_RECEIVE 1 | |
68 | #define CL_SEND 2 | |
69 | ||
0311b667 | 70 | extern char *krb_realm; |
16904979 | 71 | |
72 | /* | |
73 | * Debugging options. | |
74 | */ | |
75 | ||
76 | extern int log_flags; | |
77 | ||
78 | #define LOG_CONNECT 0x0001 | |
79 | #define LOG_REQUESTS 0x0002 | |
80 | #define LOG_ARGS 0x0004 | |
81 | #define LOG_RESP 0x0008 | |
82 | #define LOG_RES 0x0010 | |
15516f43 | 83 | #define LOG_VALID 0x0020 |
16904979 | 84 | |
90052a6f | 85 | |
86 | /* max length of query argument allowed */ | |
9608e722 | 87 | #define ARGLEN 257 |
7a2ebcdf | 88 | |
89 | /* statistics on number of queries by version number */ | |
90 | extern int newqueries, oldqueries; | |
91 | ||
fcd67f6a | 92 | /* Maximum and minimum values that will ever be chosen for IDs */ |
93 | #define MAX_ID_VALUE 32765 | |
94 | #define MIN_ID_VALUE 100 |