gnunet-svn
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[GNUnet-SVN] [gnunet] branch master updated: fixing #5437


From: gnunet
Subject: [GNUnet-SVN] [gnunet] branch master updated: fixing #5437
Date: Thu, 22 Nov 2018 10:31:37 +0100

This is an automated email from the git hooks/post-receive script.

grothoff pushed a commit to branch master
in repository gnunet.

The following commit(s) were added to refs/heads/master by this push:
     new a9c5183b1 fixing #5437
a9c5183b1 is described below

commit a9c5183b1b40792dff463b32b7e884e36a8ed5de
Author: Christian Grothoff <address@hidden>
AuthorDate: Thu Nov 22 10:31:36 2018 +0100

    fixing #5437
---
 src/gns/nss/nss_gns_query.c | 88 +++++++++++++++++++++++++++++----------------
 1 file changed, 57 insertions(+), 31 deletions(-)

diff --git a/src/gns/nss/nss_gns_query.c b/src/gns/nss/nss_gns_query.c
index 032b2c93b..58c38323a 100644
--- a/src/gns/nss/nss_gns_query.c
+++ b/src/gns/nss/nss_gns_query.c
@@ -22,8 +22,23 @@
 #include <arpa/inet.h>
 #include <sys/types.h>
 #include <sys/socket.h>
+#include <sys/wait.h>
 #include <netinet/in.h>
 #include <errno.h>
+#include <unistd.h>
+#include <signal.h>
+
+
+static void
+kwait (pid_t chld)
+{
+  int ret;
+
+  kill (chld, SIGKILL);
+  waitpid (chld,
+           &ret,
+           0);
+}
 
 
 /**
@@ -44,36 +59,45 @@ gns_resolve_name (int af,
                  struct userdata *u)
 {
   FILE *p;
-  char *cmd;
   char line[128];
   int ret;
-  int es;
+  int out[2];
+  pid_t pid;
 
-  if (AF_INET6 == af)
+  if (0 != pipe (out))
+    return -1;
+  pid = fork ();
+  if (-1 == pid)
+    return -1;
+  if (0 == pid)
   {
-    if (-1 == asprintf (&cmd,
-                       "%s -t AAAA -u %s\n",
-                       "gnunet-gns -r",
-                        name))
-      return -1;
+    char *argv[] = {
+      "gnunet-gns",
+      "-r",
+      "-t",
+      (AF_INET6 == af) ? "AAAA" : "A",
+      "-u",
+      (char *) name,
+      NULL
+    };
+
+    (void) close (STDOUT_FILENO);
+    if ( (0 != close (out[0])) ||
+         (STDOUT_FILENO != dup2 (out[1], STDOUT_FILENO)) )
+      _exit (1);
+    (void) execvp ("gnunet-gns",
+                   argv);
+    _exit (1);
   }
-  else
-  {
-    if (-1 == asprintf (&cmd,
-                       "%s %s\n",
-                       "gnunet-gns -r -u",
-                        name))
+  (void) close (out[1]);
+  p = fdopen (out[0], "r");
+  if (NULL == p)
+    {
+      kwait (pid);
       return -1;
-  }
-  if (NULL == (p = popen (cmd, "r")))
-  {
-    es = errno;
-    free (cmd);
-    errno = es;
-    return -1;
-  }
+    }
   while (NULL != fgets (line,
-                        sizeof(line),
+                        sizeof (line),
                         p))
   {
     if (u->count >= MAX_ENTRIES)
@@ -92,8 +116,8 @@ gns_resolve_name (int af,
        }
        else
        {
-         (void) pclose (p);
-         free (cmd);
+         (void) fclose (p);
+          kwait (pid);
          errno = EINVAL;
          return -1;
        }
@@ -109,19 +133,21 @@ gns_resolve_name (int af,
        }
        else
         {
-         (void) pclose (p);
-         free (cmd);
+         (void) fclose (p);
+          kwait (pid);
          errno = EINVAL;
          return -1;
        }
       }
     }
   }
-  ret = pclose (p);
-  free (cmd);
-  if (! WIFEXITED (ret)) 
+  (void) fclose (p);
+  waitpid (pid,
+           &ret,
+           0);
+  if (! WIFEXITED (ret))
     return -1;
-  if (4 == WEXITSTATUS (ret)) 
+  if (4 == WEXITSTATUS (ret))
     return -2; /* not for GNS */
   if (3 == ret)
     return -3; /* timeout -> not found */

-- 
To stop receiving notification emails like this one, please contact
address@hidden



reply via email to

[Prev in Thread] Current Thread [Next in Thread]