]> granicus.if.org Git - git/commit
validate_headref: NUL-terminate HEAD buffer
authorJeff King <peff@peff.net>
Wed, 27 Sep 2017 06:17:23 +0000 (02:17 -0400)
committerJunio C Hamano <gitster@pobox.com>
Wed, 27 Sep 2017 07:01:24 +0000 (16:01 +0900)
commit6e68c914102774832c519804498538791cdddff9
tree733711e95b0cb996e465139b4e4f61b533a63a14
parent4010f1d1b782eb7585e0e0abcefa794bd5ff29a0
validate_headref: NUL-terminate HEAD buffer

When we are checking to see if we have a git repo, we peek
into the HEAD file and see if it's a plausible symlink,
symref, or detached HEAD.

For the latter two, we read the contents with read_in_full(),
which means they aren't NUL-terminated. The symref check is
careful to respect the length we got, but the sha1 check
will happily parse up to 40 bytes, even if we read fewer.

E.g.,:

  echo 1234 >.git/HEAD
  git rev-parse

will parse 36 uninitialized bytes from our stack buffer.

This isn't a big deal in practice. Our buffer is 256 bytes,
so we know we'll never read outside of it. The worst case is
that the uninitialized bytes look like valid hex, and we
claim a bogus HEAD file is valid. The chances of this
happening randomly are quite slim, but let's be careful.

One option would be to check that "len == 41" before feeding
the buffer to get_sha1_hex(). But we'd like to eventually
prepare for a world with variable-length hashes. Let's
NUL-terminate as soon as we've read the buffer (we already
even leave a spare byte to do so!). That fixes this problem
without depending on the size of an object id.

Signed-off-by: Jeff King <peff@peff.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
path.c