chunks: fix potential "index out of range" error

When binary.Uvarint() fails, the returned number of bytes is less than
or equal to zero.

Signed-off-by: Simon Pasquier <spasquie@redhat.com>
pull/5805/head
Simon Pasquier 2018-06-08 10:25:12 +02:00
parent c848349f07
commit ee5fe8ea9f
1 changed files with 3 additions and 3 deletions

View File

@ -296,7 +296,7 @@ func newReader(bs []ByteSlice, cs []io.Closer, pool chunkenc.Pool) (*Reader, err
} }
// Verify magic number. // Verify magic number.
if m := binary.BigEndian.Uint32(b.Range(0, 4)); m != MagicChunks { if m := binary.BigEndian.Uint32(b.Range(0, 4)); m != MagicChunks {
return nil, fmt.Errorf("invalid magic number %x", m) return nil, errors.Errorf("invalid magic number %x", m)
} }
} }
return &cr, nil return &cr, nil
@ -357,8 +357,8 @@ func (s *Reader) Chunk(ref uint64) (chunkenc.Chunk, error) {
r := b.Range(off, off+binary.MaxVarintLen32) r := b.Range(off, off+binary.MaxVarintLen32)
l, n := binary.Uvarint(r) l, n := binary.Uvarint(r)
if n < 0 { if n <= 0 {
return nil, fmt.Errorf("reading chunk length failed") return nil, errors.Errorf("reading chunk length failed with %d", n)
} }
r = b.Range(off+n, off+n+int(l)) r = b.Range(off+n, off+n+int(l))