mirror of
				https://github.com/asterisk/asterisk.git
				synced 2025-10-25 22:18:07 +00:00 
			
		
		
		
	Refuse to gethostbyname on a pure integer
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@2949 65c4cc65-6c06-0410-ace0-fbb531ad65f3
This commit is contained in:
		
							
								
								
									
										15
									
								
								utils.c
									
									
									
									
									
								
							
							
						
						
									
										15
									
								
								utils.c
									
									
									
									
									
								
							| @@ -9,6 +9,7 @@ | |||||||
|  * the GNU General Public License |  * the GNU General Public License | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
|  | #include <ctype.h> | ||||||
| #include <asterisk/lock.h> | #include <asterisk/lock.h> | ||||||
| #include <asterisk/utils.h> | #include <asterisk/utils.h> | ||||||
|  |  | ||||||
| @@ -120,8 +121,20 @@ struct hostent *ast_gethostbyname(const char *host, struct ast_hostent *hp) | |||||||
| { | { | ||||||
| 	int res; | 	int res; | ||||||
| 	int herrno; | 	int herrno; | ||||||
|  | 	const char *s; | ||||||
| 	struct hostent *result = NULL; | 	struct hostent *result = NULL; | ||||||
|  | 	/* Although it is perfectly legitimate to lookup a pure integer, for | ||||||
|  | 	   the sake of the sanity of people who like to name their peers as | ||||||
|  | 	   integers, we break with tradition and refuse to look up a | ||||||
|  | 	   pure integer */ | ||||||
|  | 	s = host; | ||||||
|  | 	while(s && *s) { | ||||||
|  | 		if (!isdigit(*s)) | ||||||
|  | 			break; | ||||||
|  | 		s++; | ||||||
|  | 	} | ||||||
|  | 	if (!s || !*s) | ||||||
|  | 		return NULL; | ||||||
| 	res = gethostbyname_r(host, &hp->hp, hp->buf, sizeof(hp->buf), &result, &herrno); | 	res = gethostbyname_r(host, &hp->hp, hp->buf, sizeof(hp->buf), &result, &herrno); | ||||||
|  |  | ||||||
| 	if (res || !hp->hp.h_addr_list || !hp->hp.h_addr_list[0]) | 	if (res || !hp->hp.h_addr_list || !hp->hp.h_addr_list[0]) | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user