on strange tcp error; log local port number and socket type
git-svn-id: svn://svn.h5l.se/heimdal/trunk/heimdal@13449 ec53bebd-3082-4978-b11e-865c3cabbd6b
This commit is contained in:
		| @@ -1,5 +1,5 @@ | |||||||
| /* | /* | ||||||
|  * Copyright (c) 1997-2003 Kungliga Tekniska H<>gskolan |  * Copyright (c) 1997-2004 Kungliga Tekniska H<>gskolan | ||||||
|  * (Royal Institute of Technology, Stockholm, Sweden).  |  * (Royal Institute of Technology, Stockholm, Sweden).  | ||||||
|  * All rights reserved.  |  * All rights reserved.  | ||||||
|  * |  * | ||||||
| @@ -195,6 +195,7 @@ parse_ports(const char *str) | |||||||
| struct descr { | struct descr { | ||||||
|     int s; |     int s; | ||||||
|     int type; |     int type; | ||||||
|  |     int port; | ||||||
|     unsigned char *buf; |     unsigned char *buf; | ||||||
|     size_t size; |     size_t size; | ||||||
|     size_t len; |     size_t len; | ||||||
| @@ -264,6 +265,7 @@ init_socket(struct descr *d, krb5_address *a, int family, int type, int port) | |||||||
|     } |     } | ||||||
| #endif | #endif | ||||||
|     d->type = type; |     d->type = type; | ||||||
|  |     d->port = port; | ||||||
|  |  | ||||||
|     if(bind(d->s, sa, sa_size) < 0){ |     if(bind(d->s, sa, sa_size) < 0){ | ||||||
| 	char a_str[256]; | 	char a_str[256]; | ||||||
| @@ -344,6 +346,20 @@ init_sockets(struct descr **desc) | |||||||
|     return num; |     return num; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | /* | ||||||
|  |  * | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | static const char * | ||||||
|  | descr_type(struct descr *d) | ||||||
|  | { | ||||||
|  |     if (d->type == SOCK_DGRAM) | ||||||
|  | 	return "udp"; | ||||||
|  |     else if (d->type == SOCK_STREAM) | ||||||
|  | 	return "tcp"; | ||||||
|  |     return "unknown"; | ||||||
|  | } | ||||||
|  |  | ||||||
| /* | /* | ||||||
|  * handle the request in `buf, len', from `addr' (or `from' as a string), |  * handle the request in `buf, len', from `addr' (or `from' as a string), | ||||||
|  * sending a reply in `reply'. |  * sending a reply in `reply'. | ||||||
| @@ -706,7 +722,9 @@ handle_tcp(struct descr *d, int index, int min_free) | |||||||
| 	return; | 	return; | ||||||
|     } else if (n == 0) { |     } else if (n == 0) { | ||||||
| 	krb5_warnx(context, "connection closed before end of data after %d " | 	krb5_warnx(context, "connection closed before end of data after %d " | ||||||
| 		   "bytes from %s", d[index].len, d[index].addr_string); | 		   "bytes from %s to %s/%d", d[index].len,  | ||||||
|  | 		   d[index].addr_string, descr_type(d + index),  | ||||||
|  | 		   ntohs(d[index].port)); | ||||||
| 	clear_descr (d + index); | 	clear_descr (d + index); | ||||||
| 	return; | 	return; | ||||||
|     } |     } | ||||||
| @@ -725,7 +743,10 @@ handle_tcp(struct descr *d, int index, int min_free) | |||||||
| 	if (ret < 0) | 	if (ret < 0) | ||||||
| 	    clear_descr (d + index); | 	    clear_descr (d + index); | ||||||
|     } else if (d[index].len > 4) { |     } else if (d[index].len > 4) { | ||||||
| 	kdc_log (0, "TCP data of strange type from %s", d[index].addr_string); | 	kdc_log (0, "TCP data of strange type from %s to %s/%d", | ||||||
|  | 		 d[index].addr_string, descr_type(d + index),  | ||||||
|  | 		 ntohs(d[index].port)); | ||||||
|  | 	clear_descr(d + index); | ||||||
| 	return; | 	return; | ||||||
|     } |     } | ||||||
|     if (ret < 0) |     if (ret < 0) | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Love Hörnquist Åstrand
					Love Hörnquist Åstrand