commit fc4cd39202a01b7a95c8e08b26003883dadc4f89 from: Florian Westphal date: Sat Sep 03 11:17:16 2005 UTC Wait for DNS reverse lookup (and ident request) before writing results to pipe. commit - b5b7c7f174041197f6018a24bdc7720a4244a533 commit + fc4cd39202a01b7a95c8e08b26003883dadc4f89 blob - 723880f662ac846e53f3e74718d9dca75bfeb4dd blob + 3ce055c8339821b4b37aa0826fefd3bb497b9368 --- src/ngircd/resolve.c +++ src/ngircd/resolve.c @@ -14,7 +14,7 @@ #include "portab.h" -static char UNUSED id[] = "$Id: resolve.c,v 1.18 2005/09/02 21:47:30 fw Exp $"; +static char UNUSED id[] = "$Id: resolve.c,v 1.19 2005/09/03 11:17:16 fw Exp $"; #include "imp.h" #include @@ -192,10 +192,13 @@ Do_ResolveAddr( struct sockaddr_in *Addr, int w_fd ) size_t len; struct in_addr *addr; char *ntoaptr; + array resolved_addr; #ifdef IDENTAUTH char *res; #endif + array_init(&resolved_addr); + /* Resolve IP address */ #ifdef DEBUG Log_Resolver( LOG_DEBUG, "Now resolving %s ...", inet_ntoa( Addr->sin_addr )); @@ -230,36 +233,41 @@ Do_ResolveAddr( struct sockaddr_in *Addr, int w_fd ) } Log_Resolver( LOG_DEBUG, "Ok, translated %s to \"%s\".", inet_ntoa( Addr->sin_addr ), hostname ); - /* Write resolver result into pipe to parent */ len = strlen( hostname ); hostname[len] = '\n'; len++; - if( (size_t)write( w_fd, hostname, len ) != (size_t)len ) - { - Log_Resolver( LOG_CRIT, "Resolver: Can't write to parent: %s!", strerror( errno )); + if (!array_copyb(&resolved_addr, hostname, len )) { + Log_Resolver( LOG_CRIT, "Resolver: Can't copy resolved name: %s!", strerror( errno )); close( w_fd ); return; } #ifdef IDENTAUTH - /* Do "IDENT" (aka "AUTH") lookup and write result to parent */ + /* Do "IDENT" (aka "AUTH") lookup and append result to resolved_addr array */ Log_Resolver( LOG_DEBUG, "Doing IDENT lookup on socket %d ...", Sock ); res = ident_id( Sock, 10 ); Log_Resolver( LOG_DEBUG, "Ok, IDENT lookup on socket %d done: \"%s\"", Sock, res ? res : "" ); - /* Write IDENT result into pipe to parent */ if (res) { - len = strlen(res); - res[len] = '\n'; - len++; - } else len = 1; - - if( (size_t)write( w_fd, res ? res : "\n", len ) != (size_t)len ) - { - Log_Resolver( LOG_CRIT, "Resolver: Can't write to parent (IDENT): %s!", strerror( errno )); - close( w_fd ); + if (!array_cats(&resolved_addr, res)) + Log_Resolver(LOG_WARNING, "Resolver: Cannot copy IDENT result: %s!", strerror(errno)); + /* try to omit ident and return hostname only */ + } + + if (!array_catb(&resolved_addr, "\n", 1)) { + close(w_fd); + Log_Resolver(LOG_CRIT, "Resolver: Cannot copy result: %s!", strerror(errno)); + array_free(&resolved_addr); + return; } - free( res ); + + if (res) free(res); #endif + len = array_bytes(&resolved_addr); + if( (size_t)write( w_fd, array_start(&resolved_addr), len) != len ) + Log_Resolver( LOG_CRIT, "Resolver: Can't write result to parent: %s!", strerror( errno )); + + close(w_fd); + array_free(&resolved_addr); } /* Do_ResolveAddr */