2 * Copyright (c) 1995 - 2001 Kungliga Tekniska Högskolan
3 * (Royal Institute of Technology, Stockholm, Sweden).
6 * Redistribution and use in source and binary forms, with or without
7 * modification, are permitted provided that the following conditions
10 * 1. Redistributions of source code must retain the above copyright
11 * notice, this list of conditions and the following disclaimer.
13 * 2. Redistributions in binary form must reproduce the above copyright
14 * notice, this list of conditions and the following disclaimer in the
15 * documentation and/or other materials provided with the distribution.
17 * 3. Neither the name of the Institute nor the names of its contributors
18 * may be used to endorse or promote products derived from this software
19 * without specific prior written permission.
21 * THIS SOFTWARE IS PROVIDED BY THE INSTITUTE AND CONTRIBUTORS ``AS IS'' AND
22 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
23 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
24 * ARE DISCLAIMED. IN NO EVENT SHALL THE INSTITUTE OR CONTRIBUTORS BE LIABLE
25 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
26 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
27 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
28 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
29 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
30 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
34 /* $Heimdal: kx.h 20452 2007-04-19 20:04:19Z lha $
39 #endif /* HAVE_CONFIG_H */
59 #ifdef HAVE_SYS_TYPES_H
60 #include <sys/types.h>
62 #ifdef TIME_WITH_SYS_TIME
65 #elif defined(HAVE_SYS_TIME_H)
70 #ifdef HAVE_SYS_RESOURCE_H
71 #include <sys/resource.h>
73 #ifdef HAVE_SYS_SELECT_H
74 #include <sys/select.h>
76 #ifdef HAVE_SYS_WAIT_H
79 #ifdef HAVE_SYS_STAT_H
82 #ifdef HAVE_SYS_SOCKET_H
83 #include <sys/socket.h>
85 #ifdef HAVE_NETINET_IN_H
86 #include <netinet/in.h>
88 #ifdef HAVE_NETINET_TCP_H
89 #include <netinet/tcp.h>
91 #ifdef HAVE_ARPA_INET_H
92 #include <arpa/inet.h>
101 #include <X11/Xlib.h>
102 #include <X11/Xauth.h>
104 #ifdef HAVE_SYS_STREAM_H
105 #include <sys/stream.h>
107 #ifdef HAVE_SYS_STROPTS_H
108 #include <sys/stropts.h>
111 /* defined by aix's sys/stream.h and again by arpa/nameser.h */
115 /* as far as we know, this is only used with later versions of Slowlaris */
116 #if SunOS >= 50 && defined(HAVE_SYS_STROPTS_H) && defined(HAVE_FATTACH) && defined(I_PUSH)
117 #define MAY_HAVE_X11_PIPES
122 /* This doesn't belong here. */
123 struct tm
*localtime(const time_t *);
124 struct hostent
*gethostbyname(const char *);
145 UNIX_SOCKET
= LISTENP
| 2,
150 extern char x_socket
[];
151 extern uint32_t display_num
;
152 extern char display
[];
153 extern int display_size
;
154 extern char xauthfile
[];
155 extern int xauthfile_size
;
156 extern u_char cookie
[];
157 extern size_t cookie_len
;
159 int get_xsockets (int *number
, struct x_socket
**sockets
, int tcpp
);
160 int chown_xsockets (int n
, struct x_socket
*sockets
, uid_t uid
, gid_t gid
);
162 int connect_local_xsocket (unsigned dnr
);
163 int create_and_write_cookie (char *file
,
167 int verify_and_remove_cookies (int fd
, int sock
, int cookiesp
);
168 int replace_cookie(int xserver
, int fd
, char *filename
, int cookiesp
);
170 int suspicious_address (int sock
, struct sockaddr
*addr
);
174 #define KX_OLD_VERSION "KXSERV.1"
175 #define KX_VERSION "KXSERV.2"
177 #define COOKIE_TYPE "MIT-MAGIC-COOKIE-1"
179 enum { INIT
= 0, ACK
= 1, NEW_CONN
= 2, ERROR
= 3 };
181 enum kx_flags
{ PASSIVE
= 1, KEEP_ALIVE
= 2 };
183 typedef enum kx_flags kx_flags
;
186 int (*authenticate
)(struct kx_context
*kc
, int s
);
187 int (*userok
)(struct kx_context
*kc
, char *user
);
188 ssize_t (*read
)(struct kx_context
*kc
,
189 int fd
, void *buf
, size_t len
);
190 ssize_t (*write
)(struct kx_context
*kc
,
191 int fd
, const void *buf
, size_t len
);
192 int (*copy_encrypted
)(struct kx_context
*kc
,
194 void (*destroy
)(struct kx_context
*kc
);
201 struct sockaddr_storage __ss_this
;
202 struct sockaddr_storage __ss_that
;
203 struct sockaddr
*thisaddr
;
204 struct sockaddr
*thataddr
;
205 socklen_t thisaddr_len
, thataddr_len
;
209 typedef struct kx_context kx_context
;
212 context_set (kx_context
*kc
, const char *host
, const char *user
, int port
,
213 int debug_flag
, int keepalive_flag
, int tcp_flag
);
216 context_destroy (kx_context
*kc
);
219 context_authenticate (kx_context
*kc
, int s
);
222 context_userok (kx_context
*kc
, char *user
);
225 kx_read (kx_context
*kc
, int fd
, void *buf
, size_t len
);
228 kx_write (kx_context
*kc
, int fd
, const void *buf
, size_t len
);
231 copy_encrypted (kx_context
*kc
, int fd1
, int fd2
);
236 krb4_make_context (kx_context
*c
);
239 recv_v4_auth (kx_context
*kc
, int sock
, u_char
*buf
);
246 krb5_make_context (kx_context
*c
);
249 recv_v5_auth (kx_context
*kc
, int sock
, u_char
*buf
);
254 fatal (kx_context
*kc
, int fd
, char *format
, ...)
256 __attribute__ ((format (printf
, 3, 4)))
261 kx_get_int(void *f
, uint32_t *to
, int size
, int lsb
);
264 kx_put_int(uint32_t from
, void *to
, size_t rem
, int size
);