Merge pull request #25 from pluots/hash-updates #161
Security advisories found
2 unsound
Details
Warnings
RUSTSEC-2023-0033
Parsing borsh messages with ZST which are not-copy/clone is unsound
Details | |
---|---|
Status | unsound |
Package | borsh |
Version | 0.10.3 |
URL | near/borsh-rs#19 |
Date | 2023-04-12 |
Affected versions of borsh cause undefined behavior when zero-sized-types (ZST)
are parsed and the Copy/Clone traits are not implemented/derived.
For instance if 1000 instances of a ZST are deserialized, and the ZST is not copy
(this can be achieved through a singleton), then accessing/writing to deserialized
data will cause a segmentation fault.
There is currently no way for borsh to read data without also providing a Rust type.
Therefore, if not ZST are used for serialization, then you are not affected by this issue.
RUSTSEC-2023-0055
Multiple soundness issues
Details | |
---|---|
Status | unsound |
Package | lexical |
Version | 6.1.1 |
Date | 2023-09-03 |
lexical
contains multiple soundness issues:
- Bytes::read() allows creating instances of types with invalid bit patterns
- BytesIter::read() advances iterators out of bounds
- The
BytesIter
trait has safety invariants but is public and not markedunsafe
write_float()
callsMaybeUninit::assume_init()
on uninitialized data, which is is not allowed by the Rust abstract machine
The crate also has some correctness issues and appears to be unmaintained.
Alternatives
For quickly parsing floating-point numbers third-party crates are no longer needed. A fast float parsing algorith by the author of lexical
has been merged into libcore.
For quickly parsing integers, consider atoi
and btoi
crates (100% safe code). atoi_radix10
provides even faster parsing, but only with -C target-cpu=native
, and at the cost of some unsafe
.
For formatting integers in a #[no_std]
context consider the numtoa
crate.
For working with big numbers consider num-bigint
and num-traits
.