git.annexia.org
/
libguestfs.git
/ commitdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
| commitdiff |
tree
raw
|
patch
| inline |
side by side
(parent:
9674a73
)
filearch: Refuse to download initrd if it is huge.
author
Richard W.M. Jones
<rjones@redhat.com>
Sat, 13 Nov 2010 14:58:50 +0000
(14:58 +0000)
committer
Richard W.M. Jones
<rjones@redhat.com>
Sat, 13 Nov 2010 14:58:50 +0000
(14:58 +0000)
src/filearch.c
patch
|
blob
|
history
diff --git
a/src/filearch.c
b/src/filearch.c
index
35a2ceb
..
14c7c02
100644
(file)
--- a/
src/filearch.c
+++ b/
src/filearch.c
@@
-147,6
+147,14
@@
cpio_arch (guestfs_h *g, const char *file, const char *path)
else
method = "cat";
+ /* Security: Refuse to download initrd if it is huge. */
+ int64_t size = guestfs_filesize (g, path);
+ if (size == -1 || size > 100000000) {
+ error (g, _("size of %s unreasonable (%" PRIi64 " bytes)"),
+ path, size);
+ goto out;
+ }
+
if (mkdtemp (dir) == NULL) {
perrorf (g, "mkdtemp");
goto out;