]> arthur.barton.de Git - ngircd-alex.git/commitdiff
Wait for DNS reverse lookup (and ident request) before writing results to pipe.
authorFlorian Westphal <fw@strlen.de>
Sat, 3 Sep 2005 11:17:16 +0000 (11:17 +0000)
committerFlorian Westphal <fw@strlen.de>
Sat, 3 Sep 2005 11:17:16 +0000 (11:17 +0000)
src/ngircd/resolve.c

index 723880f662ac846e53f3e74718d9dca75bfeb4dd..3ce055c8339821b4b37aa0826fefd3bb497b9368 100644 (file)
@@ -14,7 +14,7 @@
 
 #include "portab.h"
 
 
 #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 <assert.h>
 
 #include "imp.h"
 #include <assert.h>
@@ -192,10 +192,13 @@ Do_ResolveAddr( struct sockaddr_in *Addr, int w_fd )
        size_t len;
        struct in_addr *addr;
        char *ntoaptr;
        size_t len;
        struct in_addr *addr;
        char *ntoaptr;
+       array resolved_addr;
 #ifdef IDENTAUTH
        char *res;
 #endif
 
 #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 ));
        /* 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 );
 
        }
        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++;
        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
                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 : "" );
 
        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) {
        if (res) {
-               len = strlen(res);
-               res[len] = '\n';
-               len++;
-       } else len = 1;
+               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( (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_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
 #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 */
 
 
 } /* Do_ResolveAddr */