summaryrefslogtreecommitdiffstats
path: root/remote-curl.c
diff options
context:
space:
mode:
authorJulian Phillips <julian@quantumfyre.co.uk>2011-07-16 20:23:51 +0200
committerJunio C Hamano <gitster@pobox.com>2011-07-21 00:51:55 +0200
commit6e8e67f3071ecdc139f6a77f90afee50b5ec1664 (patch)
tree51b14758f0731a26b60bc43e7092297e06a11587 /remote-curl.c
parentgit-config: Remove extra whitespaces (diff)
downloadgit-6e8e67f3071ecdc139f6a77f90afee50b5ec1664.tar.xz
git-6e8e67f3071ecdc139f6a77f90afee50b5ec1664.zip
remote-curl: Add a format check to parsing of info/refs
When parsing info/refs, no checks were applied that the file was in the requried format. Since the file is read from a remote webserver, this isn't guarenteed to be true. Add a check that the file at least only contains lines that consist of 40 characters followed by a tab and then the ref name. Signed-off-by: Julian Phillips <julian@quantumfyre.co.uk> Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'remote-curl.c')
-rw-r--r--remote-curl.c2
1 files changed, 2 insertions, 0 deletions
diff --git a/remote-curl.c b/remote-curl.c
index b5be25ce96..8ac5028343 100644
--- a/remote-curl.c
+++ b/remote-curl.c
@@ -227,6 +227,8 @@ static struct ref *parse_info_refs(struct discovery *heads)
if (data[i] == '\t')
mid = &data[i];
if (data[i] == '\n') {
+ if (mid - start != 40)
+ die("%sinfo/refs not valid: is this a git repository?", url);
data[i] = 0;
ref_name = mid + 1;
ref = xmalloc(sizeof(struct ref) +