mirror of
				https://github.com/asterisk/asterisk.git
				synced 2025-10-24 21:50:53 +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 | ||||
|  */ | ||||
|  | ||||
| #include <ctype.h> | ||||
| #include <asterisk/lock.h> | ||||
| #include <asterisk/utils.h> | ||||
|  | ||||
| @@ -120,8 +121,20 @@ struct hostent *ast_gethostbyname(const char *host, struct ast_hostent *hp) | ||||
| { | ||||
| 	int res; | ||||
| 	int herrno; | ||||
| 	const char *s; | ||||
| 	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); | ||||
|  | ||||
| 	if (res || !hp->hp.h_addr_list || !hp->hp.h_addr_list[0]) | ||||
|   | ||||
		Reference in New Issue
	
	Block a user