go-ipld-prime/codec/json may panic if asked to encode bytes
Moderate severity
GitHub Reviewed
Published
Jan 3, 2023
in
ipld/go-ipld-prime
•
Updated Aug 29, 2023
Description
Published by the National Vulnerability Database
Jan 4, 2023
Published to the GitHub Advisory Database
Jan 5, 2023
Reviewed
Jan 5, 2023
Last updated
Aug 29, 2023
go-ipld-primeis a series of Go interfaces for manipulating IPLD data and a Go module that contains thego-ipld-prime/codec/jsoncodec.Impact
Encoding data which contains a
Byteskind Node will pass aBytestoken to the JSON encoder which will panic as it doesn't expect to receiveBytestokens. Such an encoding should be treated as an error, as plain JSON should not be able to encode Bytes.This only impacts uses of the "json" codec, "dag-json" is not impacted. Use of "json" as a decoder is not impacted.
Patches
Fixed in v0.19.0.
Workarounds
Prefer the "dag-json" codec which has the ability to encode bytes.
References
See fix in #472
References