diff --git a/crates/sqlx/RUSTSEC-0000-0000.md b/crates/sqlx/RUSTSEC-0000-0000.md new file mode 100644 index 000000000..14f9e8090 --- /dev/null +++ b/crates/sqlx/RUSTSEC-0000-0000.md @@ -0,0 +1,56 @@ +```toml +[advisory] +id = "RUSTSEC-0000-0000" +package = "sqlx" +date = "2024-08-15" +url = "https://github.com/launchbadge/sqlx/issues/3440" + +categories = ["format-injection"] +keywords = ["sql", "injection", "overflow", "truncation"] + +[versions] +# Note: WIP as of 2024-08-15 +patched = [">= 0.8.1"] +``` + +# Binary Protocol Misinterpretation caused by Truncating or Overflowing Casts + +The following presentation at this year's DEF CON was brought to our attention on the SQLx Discord: + +> SQL Injection isn't Dead: Smuggling Queries at the Protocol Level +> +> (Archive link for posterity.) + +Essentially, encoding a value larger than 4GiB can cause the length prefix in the protocol to overflow, +causing the server to interpret the rest of the string as binary protocol commands or other data. + +It appears SQLx _does_ perform truncating casts in a way that could be problematic, +for example: + +This code has existed essentially since the beginning, +so it is reasonable to assume that all published versions `<= 0.8.0` are affected. + +## Mitigation + +As always, you should make sure your application is validating untrustworthy user input. +Reject any input over 4 GiB, or any input that could _encode_ to a string longer than 4 GiB. +Dynamically built queries are also potentially problematic if it pushes the message size over this 4 GiB bound. + +[`Encode::size_hint()`](https://docs.rs/sqlx/latest/sqlx/trait.Encode.html#method.size_hint) +can be used for sanity checks, but do not assume that the size returned is accurate. +For example, the `Json` and `Text` adapters have no reasonable way to predict or estimate the final encoded size, +so they just return `size_of::()` instead. + +For web application backends, consider adding some middleware that limits the size of request bodies by default. + +## Resolution + +Work has started on a branch to add `#[deny]` directives for the following Clippy lints: + +* [`cast_possible_truncation`](https://rust-lang.github.io/rust-clippy/master/#/cast_possible_truncation) +* [`cast_possible_wrap`](https://rust-lang.github.io/rust-clippy/master/#/cast_possible_wrap) +* [`cast_sign_loss`](https://rust-lang.github.io/rust-clippy/master/#/cast_sign_loss) + +and to manually audit the code that they flag. + +A fix is expected to be included in the `0.8.1` release (still WIP as of writing).