RUSTSEC-2021-0128

Source
https://rustsec.org/advisories/RUSTSEC-2021-0128
Import Source
https://github.com/rustsec/advisory-db/blob/osv/crates/RUSTSEC-2021-0128.json
JSON Data
https://api.osv.dev/v1/vulns/RUSTSEC-2021-0128
Aliases
Published
2021-12-07T12:00:00Z
Modified
2024-03-15T00:05:18.748750Z
Summary
Incorrect Lifetime Bounds on Closures in `rusqlite`
Details

The lifetime bound on several closure-accepting rusqlite functions (specifically, functions which register a callback to be later invoked by SQLite) was too relaxed. If a closure referencing borrowed values on the stack is was passed to one of these functions, it could allow Rust code to access objects on the stack after they have been dropped.

The impacted functions are:

  • Under cfg(feature = "functions"): Connection::create_scalar_function, Connection::create_aggregate_function and Connection::create_window_function.
  • Under cfg(feature = "hooks"): Connection::commit_hook, Connection::rollback_hook and Connection::update_hook.
  • Under cfg(feature = "collation"): Connection::create_collation.

The issue exists in all 0.25.* versions prior to 0.25.4, and all 0.26.* versions prior to 0.26.2 (specifically: 0.25.0, 0.25.1, 0.25.2, 0.25.3, 0.26.0, and 0.26.1).

The fix is available in versions 0.26.2 and newer, and also has been back-ported to 0.25.4. As it does not exist in 0.24.*, all affected versions should have an upgrade path to a semver-compatible release.

Database specific
{
    "license": "CC0-1.0"
}
References

Affected packages

crates.io / rusqlite

Package

Affected ranges

Type
SEMVER
Events
Introduced
0.25.0
Fixed
0.25.4
Introduced
0.26.0-0
Fixed
0.26.2

Ecosystem specific

{
    "affected_functions": null,
    "affects": {
        "os": [],
        "functions": [
            "rusqlite::Connection::commit_hook",
            "rusqlite::Connection::create_aggregate_function",
            "rusqlite::Connection::create_collation",
            "rusqlite::Connection::create_scalar_function",
            "rusqlite::Connection::create_window_function",
            "rusqlite::Connection::rollback_hook",
            "rusqlite::Connection::update_hook"
        ],
        "arch": []
    }
}

Database specific

{
    "cvss": null,
    "informational": null,
    "categories": [
        "memory-corruption"
    ]
}