| id: GO-2021-0142 |
| modules: |
| - module: std |
| versions: |
| - fixed: 1.13.15 |
| - introduced: 1.14.0-0 |
| fixed: 1.14.7 |
| vulnerable_at: 1.14.6 |
| packages: |
| - package: encoding/binary |
| symbols: |
| - ReadUvarint |
| - ReadVarint |
| summary: 'TODO(https://go.dev/issue/56443): fill in summary field' |
| description: | |
| ReadUvarint and ReadVarint can read an unlimited number of bytes from |
| invalid inputs. |
| |
| Certain invalid inputs to ReadUvarint or ReadVarint can cause these |
| functions to read an unlimited number of bytes from the ByteReader |
| parameter before returning an error. This can lead to processing more |
| input than expected when the caller is reading directly from a |
| network and depends on ReadUvarint or ReadVarint only consuming a |
| small, bounded number of bytes, even from invalid inputs. |
| published: 2022-07-01T20:11:09Z |
| cves: |
| - CVE-2020-16845 |
| ghsas: |
| - GHSA-q6gq-997w-f55g |
| credits: |
| - Diederik Loerakker |
| - Jonny Rhea |
| - Raúl Kripalani |
| - Preston Van Loon |
| references: |
| - fix: https://go.dev/cl/247120 |
| - fix: https://go.googlesource.com/go/+/027d7241ce050d197e7fabea3d541ffbe3487258 |
| - report: https://go.dev/issue/40618 |
| - web: https://groups.google.com/g/golang-announce/c/NyPIaucMgXo |