diff options
author | Richard Jones <rjones@redhat.com> | 2010-05-06 21:55:32 +0100 |
---|---|---|
committer | Richard Jones <rjones@redhat.com> | 2010-05-07 15:27:28 +0100 |
commit | 7a4ec57e54ab98de05438bff838a7531391d3965 (patch) | |
tree | 14680b57eb8a9e8e37408d3e26832a85fbf8b95c | |
parent | 07369cb77a07f965cbf8e02f485c78a22c091f85 (diff) | |
download | libguestfs-7a4ec57e54ab98de05438bff838a7531391d3965.tar.gz libguestfs-7a4ec57e54ab98de05438bff838a7531391d3965.tar.xz libguestfs-7a4ec57e54ab98de05438bff838a7531391d3965.zip |
daemon: Fix hexdump to work on absolute symbolic links (RHBZ#579608).
-rw-r--r-- | daemon/hexdump.c | 18 | ||||
-rwxr-xr-x | src/generator.ml | 5 |
2 files changed, 15 insertions, 8 deletions
diff --git a/daemon/hexdump.c b/daemon/hexdump.c index 1b33eeb3..202f856c 100644 --- a/daemon/hexdump.c +++ b/daemon/hexdump.c @@ -21,6 +21,8 @@ #include <stdio.h> #include <stdlib.h> #include <string.h> +#include <unistd.h> +#include <fcntl.h> #include "daemon.h" #include "actions.h" @@ -28,18 +30,20 @@ char * do_hexdump (const char *path) { - char *buf; - int r; + int fd, flags, r; char *out, *err; - buf = sysroot_path (path); - if (!buf) { - reply_with_perror ("malloc"); + CHROOT_IN; + fd = open (path, O_RDONLY); + CHROOT_OUT; + + if (fd == -1) { + reply_with_perror ("%s", path); return NULL; } - r = command (&out, &err, "hexdump", "-C", buf, NULL); - free (buf); + flags = COMMAND_FLAG_CHROOT_COPY_FILE_TO_STDIN | fd; + r = commandf (&out, &err, flags, "hexdump", "-C", NULL); if (r == -1) { reply_with_error ("%s: %s", path, err); free (err); diff --git a/src/generator.ml b/src/generator.ml index cbed94b7..5b479e78 100755 --- a/src/generator.ml +++ b/src/generator.ml @@ -2474,7 +2474,10 @@ The returned strings are transcoded to UTF-8."); * commands to segfault. *) InitISOFS, Always, TestRun ( - [["hexdump"; "/100krandom"]])], + [["hexdump"; "/100krandom"]]); + (* Test for RHBZ#579608, absolute symbolic links. *) + InitISOFS, Always, TestRun ( + [["hexdump"; "/abssymlink"]])], "dump a file in hexadecimal", "\ This runs C<hexdump -C> on the given C<path>. The result is |