Update cargo configs. #1076
Security advisories found
2 unmaintained, 1 unsound, 1 other
Details
Warnings
RUSTSEC-2024-0384
instant
is unmaintained
Details | |
---|---|
Status | unmaintained |
Package | instant |
Version | 0.1.13 |
Date | 2024-09-01 |
This crate is no longer maintained, and the author recommends using the maintained web-time
crate instead.
RUSTSEC-2024-0370
proc-macro-error is unmaintained
Details | |
---|---|
Status | unmaintained |
Package | proc-macro-error |
Version | 1.0.4 |
URL | https://gitlab.com/CreepySkeleton/proc-macro-error/-/issues/20 |
Date | 2024-09-01 |
proc-macro-error's maintainer seems to be unreachable, with no commits for 2 years, no releases pushed for 4 years, and no activity on the GitLab repo or response to email.
proc-macro-error also depends on syn 1.x
, which may be bringing duplicate dependencies into dependant build trees.
Possible Alternative(s)
RUSTSEC-2024-0429
Unsoundness in
Iterator
andDoubleEndedIterator
impls forglib::VariantStrIter
Details | |
---|---|
Status | unsound |
Package | glib |
Version | 0.17.10 |
URL | gtk-rs/gtk-rs-core#1343 |
Date | 2024-03-30 |
The VariantStrIter::impl_get
function (called internally by implementations of the Iterator
and DoubleEndedIterator
traits for this type) was unsound, resulting in undefined behaviour.
An immutable reference &p
to a *mut libc::c_char
pointer initialized to NULL
was passed as an argument to a C function that that mutates the pointer behind &p
in-place (i.e. as an out-argument), which was unsound. After changes in recent versions of the Rust compiler, these unsound writes through &p
now seem to be completely disregarded when building the glib
crate with optimizations.
This subsequently caused all calls of VariantStrIter::impl_get
to violate the safety requirements of the std::ffi::CStr::from_ptr
function - which requires its argument to be a valid pointer to a C-style string - resulting in crashes due to NULL
pointer dereferences.
This was fixed by passing the out-argument pointer explitly as &mut p
instead of &p
.
This issue has been present since this code was initially added in glib
v0.15.0. The mismatch in mutability was likely missed (and not raised as an error by the compiler) because the C function wrapped by VariantStrIter::impl_get
is variadic (glib_sys::g_variant_get_child
), and the pointer in question is one of the variadic arguments.
Crate metrics-exporter-prometheus
is yanked
No extra details provided.