Advisory Database
  • Advisories
  • Dependency Scanning
  1. cargo
  2. ›
  3. rusqlite
  4. ›
  5. GHSA-q89g-4vhh-mvvm

GHSA-q89g-4vhh-mvvm: Incorrect Lifetime Bounds on Closures in `rusqlite`

June 17, 2022

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.

References

  • github.com/advisories/GHSA-q89g-4vhh-mvvm
  • github.com/rusqlite/rusqlite
  • github.com/rusqlite/rusqlite/issues/1048
  • rustsec.org/advisories/RUSTSEC-2021-0128.html

Code Behaviors & Features

Detect and mitigate GHSA-q89g-4vhh-mvvm with GitLab Dependency Scanning

Secure your software supply chain by verifying that all open source dependencies used in your projects contain no disclosed vulnerabilities. Learn more about Dependency Scanning →

Affected versions

All versions starting from 0.25.0 before 0.25.4, all versions starting from 0.26.0 before 0.26.2

Fixed versions

  • 0.26.2
  • 0.25.4

Solution

Upgrade to versions 0.25.4, 0.26.2 or above.

Source file

cargo/rusqlite/GHSA-q89g-4vhh-mvvm.yml

Spotted a mistake? Edit the file on GitLab.

  • Site Repo
  • About GitLab
  • Terms
  • Privacy Statement
  • Contact

Page generated Wed, 14 May 2025 12:15:08 +0000.