You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
Panic payloads were written verbatim between DD_CRASHTRACK_BEGIN_MESSAGE / DD_CRASHTRACK_END_MESSAGE markers, allowing an attacker-controlled multiline panic to inject protocol markers and tamper with downstream parsing and configuration.
The intent of this change is to close the marker-injection channel while preserving the ability for the receiver to reconstruct the original panic text.
Description
Encode panic message text with serde_json::to_string before emitting it in the collector, preventing embedded newlines or marker text from becoming raw protocol lines (libdd-crashtracker/src/collector/emitters.rs).
Decode/normalize the received message line on the receiver by unescaping escaped newline and carriage-return sequences so JSON-encoded messages are reconstructed as original multiline text (libdd-crashtracker/src/receiver/receive_report.rs).
The change is minimal and backwards-compatible because the receiver falls back to treating non-JSON/raw lines as before via simple unescape handling.
Testing
Ran cargo test -p libdd-crashtracker emit_message -- --nocapture, which executed the emit_message unit tests and reported 8 passed; 0 failed.
The collector and receiver unit-test suites were built during testing; the targeted emit_message tests passed successfully.
This report tracks Clippy allow annotations for specific rules, showing how they've changed in this PR. Decreasing the number of these annotations generally improves code quality.
⚠️4 issue(s) found, showing only errors (advisories, bans, sources)
📦 libdd-crashtracker - 4 error(s)
Show output
error[unsound]: Rand is unsound with a custom logger using `rand::rng()`
┌─ /home/runner/work/libdatadog/libdatadog/Cargo.lock:144:1
│
144 │ rand 0.8.5 registry+https://github.com/rust-lang/crates.io-index
│ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ unsound advisory detected
│
├ ID: RUSTSEC-2026-0097
├ Advisory: https://rustsec.org/advisories/RUSTSEC-2026-0097
├ It has been reported (by @lopopolo) that the `rand` library is [unsound](https://rust-lang.github.io/unsafe-code-guidelines/glossary.html#soundness-of-code--of-a-library) (i.e. that safe code using the public API can cause Undefined Behaviour) when all the following conditions are met:
- The `log` and `thread_rng` features are enabled
- A [custom logger](https://docs.rs/log/latest/log/#implementing-a-logger) is defined
- The custom logger accesses `rand::rng()` (previously `rand::thread_rng()`) and calls any `TryRng` (previously `RngCore`) methods on `ThreadRng`
- The `ThreadRng` (attempts to) reseed while called from the custom logger (this happens every 64 kB of generated data)
- Trace-level logging is enabled or warn-level logging is enabled and the random source (the `getrandom` crate) is unable to provide a new seed
`TryRng` (previously `RngCore`) methods for `ThreadRng` use `unsafe` code to cast `*mut BlockRng<ReseedingCore>` to `&mut BlockRng<ReseedingCore>`. When all the above conditions are met this results in an aliased mutable reference, violating the Stacked Borrows rules. Miri is able to detect this violation in sample code. Since construction of [aliased mutable references is Undefined Behaviour](https://doc.rust-lang.org/stable/nomicon/references.html), the behaviour of optimized builds is hard to predict.
├ Announcement: https://github.com/rust-random/rand/pull/1763
├ Solution: Upgrade to >=0.10.1 OR <0.10.0, >=0.9.3 OR <0.9.0, >=0.8.6 (try `cargo update -p rand`)
├ rand v0.8.5
├── libdd-common v4.0.0
│ ├── (build) libdd-crashtracker v1.0.0
│ ├── libdd-shared-runtime v0.1.0
│ │ └── libdd-telemetry v5.0.0
│ │ └── libdd-crashtracker v1.0.0 (*)
│ └── libdd-telemetry v5.0.0 (*)
└── libdd-crashtracker v1.0.0 (*)
error[vulnerability]: Name constraints for URI names were incorrectly accepted
┌─ /home/runner/work/libdatadog/libdatadog/Cargo.lock:158:1
│
158 │ rustls-webpki 0.103.10 registry+https://github.com/rust-lang/crates.io-index
│ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ security vulnerability detected
│
├ ID: RUSTSEC-2026-0098
├ Advisory: https://rustsec.org/advisories/RUSTSEC-2026-0098
├ Name constraints for URI names were ignored and therefore accepted.
Note this library does not provide an API for asserting URI names, and URI name constraints are otherwise not implemented. URI name constraints are now rejected unconditionally.
Since name constraints are restrictions on otherwise properly-issued certificates, this bug is reachable only after signature verification and requires misissuance to exploit.
This vulnerability is identified as [GHSA-965h-392x-2mh5](https://github.com/rustls/webpki/security/advisories/GHSA-965h-392x-2mh5). Thank you to @1seal for the report.
├ Solution: Upgrade to >=0.103.12, <0.104.0-alpha.1 OR >=0.104.0-alpha.6 (try `cargo update -p rustls-webpki`)
├ rustls-webpki v0.103.10
└── rustls v0.23.37
├── hyper-rustls v0.27.7
│ └── libdd-common v4.0.0
│ ├── (build) libdd-crashtracker v1.0.0
│ ├── libdd-shared-runtime v0.1.0
│ │ └── libdd-telemetry v5.0.0
│ │ └── libdd-crashtracker v1.0.0 (*)
│ └── libdd-telemetry v5.0.0 (*)
├── libdd-common v4.0.0 (*)
└── tokio-rustls v0.26.0
├── hyper-rustls v0.27.7 (*)
└── libdd-common v4.0.0 (*)
error[vulnerability]: Name constraints were accepted for certificates asserting a wildcard name
┌─ /home/runner/work/libdatadog/libdatadog/Cargo.lock:158:1
│
158 │ rustls-webpki 0.103.10 registry+https://github.com/rust-lang/crates.io-index
│ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ security vulnerability detected
│
├ ID: RUSTSEC-2026-0099
├ Advisory: https://rustsec.org/advisories/RUSTSEC-2026-0099
├ Permitted subtree name constraints for DNS names were accepted for certificates asserting a wildcard name.
This was incorrect because, given a name constraint of `accept.example.com`, `*.example.com` could feasibly allow a name of `reject.example.com` which is outside the constraint.
This is very similar to [CVE-2025-61727](https://go.dev/issue/76442).
Since name constraints are restrictions on otherwise properly-issued certificates, this bug is reachable only after signature verification and requires misissuance to exploit.
This vulnerability is identified as [GHSA-xgp8-3hg3-c2mh](https://github.com/rustls/webpki/security/advisories/GHSA-xgp8-3hg3-c2mh). Thank you to @1seal for the report.
├ Solution: Upgrade to >=0.103.12, <0.104.0-alpha.1 OR >=0.104.0-alpha.6 (try `cargo update -p rustls-webpki`)
├ rustls-webpki v0.103.10
└── rustls v0.23.37
├── hyper-rustls v0.27.7
│ └── libdd-common v4.0.0
│ ├── (build) libdd-crashtracker v1.0.0
│ ├── libdd-shared-runtime v0.1.0
│ │ └── libdd-telemetry v5.0.0
│ │ └── libdd-crashtracker v1.0.0 (*)
│ └── libdd-telemetry v5.0.0 (*)
├── libdd-common v4.0.0 (*)
└── tokio-rustls v0.26.0
├── hyper-rustls v0.27.7 (*)
└── libdd-common v4.0.0 (*)
error[vulnerability]: Reachable panic in certificate revocation list parsing
┌─ /home/runner/work/libdatadog/libdatadog/Cargo.lock:158:1
│
158 │ rustls-webpki 0.103.10 registry+https://github.com/rust-lang/crates.io-index
│ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ security vulnerability detected
│
├ ID: RUSTSEC-2026-0104
├ Advisory: https://rustsec.org/advisories/RUSTSEC-2026-0104
├ A panic was reachable when parsing certificate revocation lists via [`BorrowedCertRevocationList::from_der`]
or [`OwnedCertRevocationList::from_der`]. This was the result of mishandling a syntactically valid empty
`BIT STRING` appearing in the `onlySomeReasons` element of a `IssuingDistributionPoint` CRL extension.
This panic is reachable prior to a CRL's signature being verified.
Applications that do not use CRLs are not affected.
Thank you to @tynus3 for the report.
├ Solution: Upgrade to >=0.103.13, <0.104.0-alpha.1 OR >=0.104.0-alpha.7 (try `cargo update -p rustls-webpki`)
├ rustls-webpki v0.103.10
└── rustls v0.23.37
├── hyper-rustls v0.27.7
│ └── libdd-common v4.0.0
│ ├── (build) libdd-crashtracker v1.0.0
│ ├── libdd-shared-runtime v0.1.0
│ │ └── libdd-telemetry v5.0.0
│ │ └── libdd-crashtracker v1.0.0 (*)
│ └── libdd-telemetry v5.0.0 (*)
├── libdd-common v4.0.0 (*)
└── tokio-rustls v0.26.0
├── hyper-rustls v0.27.7 (*)
└── libdd-common v4.0.0 (*)
advisories FAILED, bans ok, sources ok
⚠️4 issue(s) found, showing only errors (advisories, bans, sources)
📦 libdd-crashtracker - 4 error(s)
Show output
error[unsound]: Rand is unsound with a custom logger using `rand::rng()`
┌─ /home/runner/work/libdatadog/libdatadog/Cargo.lock:144:1
│
144 │ rand 0.8.5 registry+https://github.com/rust-lang/crates.io-index
│ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ unsound advisory detected
│
├ ID: RUSTSEC-2026-0097
├ Advisory: https://rustsec.org/advisories/RUSTSEC-2026-0097
├ It has been reported (by @lopopolo) that the `rand` library is [unsound](https://rust-lang.github.io/unsafe-code-guidelines/glossary.html#soundness-of-code--of-a-library) (i.e. that safe code using the public API can cause Undefined Behaviour) when all the following conditions are met:
- The `log` and `thread_rng` features are enabled
- A [custom logger](https://docs.rs/log/latest/log/#implementing-a-logger) is defined
- The custom logger accesses `rand::rng()` (previously `rand::thread_rng()`) and calls any `TryRng` (previously `RngCore`) methods on `ThreadRng`
- The `ThreadRng` (attempts to) reseed while called from the custom logger (this happens every 64 kB of generated data)
- Trace-level logging is enabled or warn-level logging is enabled and the random source (the `getrandom` crate) is unable to provide a new seed
`TryRng` (previously `RngCore`) methods for `ThreadRng` use `unsafe` code to cast `*mut BlockRng<ReseedingCore>` to `&mut BlockRng<ReseedingCore>`. When all the above conditions are met this results in an aliased mutable reference, violating the Stacked Borrows rules. Miri is able to detect this violation in sample code. Since construction of [aliased mutable references is Undefined Behaviour](https://doc.rust-lang.org/stable/nomicon/references.html), the behaviour of optimized builds is hard to predict.
├ Announcement: https://github.com/rust-random/rand/pull/1763
├ Solution: Upgrade to >=0.10.1 OR <0.10.0, >=0.9.3 OR <0.9.0, >=0.8.6 (try `cargo update -p rand`)
├ rand v0.8.5
├── libdd-common v4.0.0
│ ├── (build) libdd-crashtracker v1.0.0
│ ├── libdd-shared-runtime v0.1.0
│ │ └── libdd-telemetry v5.0.0
│ │ └── libdd-crashtracker v1.0.0 (*)
│ └── libdd-telemetry v5.0.0 (*)
└── libdd-crashtracker v1.0.0 (*)
error[vulnerability]: Name constraints for URI names were incorrectly accepted
┌─ /home/runner/work/libdatadog/libdatadog/Cargo.lock:158:1
│
158 │ rustls-webpki 0.103.10 registry+https://github.com/rust-lang/crates.io-index
│ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ security vulnerability detected
│
├ ID: RUSTSEC-2026-0098
├ Advisory: https://rustsec.org/advisories/RUSTSEC-2026-0098
├ Name constraints for URI names were ignored and therefore accepted.
Note this library does not provide an API for asserting URI names, and URI name constraints are otherwise not implemented. URI name constraints are now rejected unconditionally.
Since name constraints are restrictions on otherwise properly-issued certificates, this bug is reachable only after signature verification and requires misissuance to exploit.
This vulnerability is identified as [GHSA-965h-392x-2mh5](https://github.com/rustls/webpki/security/advisories/GHSA-965h-392x-2mh5). Thank you to @1seal for the report.
├ Solution: Upgrade to >=0.103.12, <0.104.0-alpha.1 OR >=0.104.0-alpha.6 (try `cargo update -p rustls-webpki`)
├ rustls-webpki v0.103.10
└── rustls v0.23.37
├── hyper-rustls v0.27.7
│ └── libdd-common v4.0.0
│ ├── (build) libdd-crashtracker v1.0.0
│ ├── libdd-shared-runtime v0.1.0
│ │ └── libdd-telemetry v5.0.0
│ │ └── libdd-crashtracker v1.0.0 (*)
│ └── libdd-telemetry v5.0.0 (*)
├── libdd-common v4.0.0 (*)
└── tokio-rustls v0.26.0
├── hyper-rustls v0.27.7 (*)
└── libdd-common v4.0.0 (*)
error[vulnerability]: Name constraints were accepted for certificates asserting a wildcard name
┌─ /home/runner/work/libdatadog/libdatadog/Cargo.lock:158:1
│
158 │ rustls-webpki 0.103.10 registry+https://github.com/rust-lang/crates.io-index
│ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ security vulnerability detected
│
├ ID: RUSTSEC-2026-0099
├ Advisory: https://rustsec.org/advisories/RUSTSEC-2026-0099
├ Permitted subtree name constraints for DNS names were accepted for certificates asserting a wildcard name.
This was incorrect because, given a name constraint of `accept.example.com`, `*.example.com` could feasibly allow a name of `reject.example.com` which is outside the constraint.
This is very similar to [CVE-2025-61727](https://go.dev/issue/76442).
Since name constraints are restrictions on otherwise properly-issued certificates, this bug is reachable only after signature verification and requires misissuance to exploit.
This vulnerability is identified as [GHSA-xgp8-3hg3-c2mh](https://github.com/rustls/webpki/security/advisories/GHSA-xgp8-3hg3-c2mh). Thank you to @1seal for the report.
├ Solution: Upgrade to >=0.103.12, <0.104.0-alpha.1 OR >=0.104.0-alpha.6 (try `cargo update -p rustls-webpki`)
├ rustls-webpki v0.103.10
└── rustls v0.23.37
├── hyper-rustls v0.27.7
│ └── libdd-common v4.0.0
│ ├── (build) libdd-crashtracker v1.0.0
│ ├── libdd-shared-runtime v0.1.0
│ │ └── libdd-telemetry v5.0.0
│ │ └── libdd-crashtracker v1.0.0 (*)
│ └── libdd-telemetry v5.0.0 (*)
├── libdd-common v4.0.0 (*)
└── tokio-rustls v0.26.0
├── hyper-rustls v0.27.7 (*)
└── libdd-common v4.0.0 (*)
error[vulnerability]: Reachable panic in certificate revocation list parsing
┌─ /home/runner/work/libdatadog/libdatadog/Cargo.lock:158:1
│
158 │ rustls-webpki 0.103.10 registry+https://github.com/rust-lang/crates.io-index
│ ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ security vulnerability detected
│
├ ID: RUSTSEC-2026-0104
├ Advisory: https://rustsec.org/advisories/RUSTSEC-2026-0104
├ A panic was reachable when parsing certificate revocation lists via [`BorrowedCertRevocationList::from_der`]
or [`OwnedCertRevocationList::from_der`]. This was the result of mishandling a syntactically valid empty
`BIT STRING` appearing in the `onlySomeReasons` element of a `IssuingDistributionPoint` CRL extension.
This panic is reachable prior to a CRL's signature being verified.
Applications that do not use CRLs are not affected.
Thank you to @tynus3 for the report.
├ Solution: Upgrade to >=0.103.13, <0.104.0-alpha.1 OR >=0.104.0-alpha.7 (try `cargo update -p rustls-webpki`)
├ rustls-webpki v0.103.10
└── rustls v0.23.37
├── hyper-rustls v0.27.7
│ └── libdd-common v4.0.0
│ ├── (build) libdd-crashtracker v1.0.0
│ ├── libdd-shared-runtime v0.1.0
│ │ └── libdd-telemetry v5.0.0
│ │ └── libdd-crashtracker v1.0.0 (*)
│ └── libdd-telemetry v5.0.0 (*)
├── libdd-common v4.0.0 (*)
└── tokio-rustls v0.26.0
├── hyper-rustls v0.27.7 (*)
└── libdd-common v4.0.0 (*)
advisories FAILED, bans ok, sources ok
test_crash_tracking_bin_panic_hook_after_fork from bin_tests::crashtracker_bin_test (Fix with Cursor)
thread 'test_crash_tracking_bin_panic_hook_after_fork' panicked at bin_tests/tests/crashtracker_bin_test.rs:895:9
thread 'test_crash_tracking_bin_panic_hook_after_fork' panicked at bin_tests/tests/crashtracker_bin_test.rs:895:9:
Expected panic message to start with 'Process panicked with message', got: "Process panicked with message \"child panicked after fork - hook should fire\" (bin_tests/src/modes/unix/test_013_panic_hook_after_fork.rs:69:13)"
stack backtrace:
0: 0x55865841c00a - std::backtrace_rs::backtrace::libunwind::trace::h886f3b0575353f6e
at /rustc/e71f9a9a98b0faf423844bf0ba7438f29dc27d58/library/std/src/../../backtrace/src/backtrace/libunwind.rs:116:5
1: 0x55865841c00a - std::backtrace_rs::backtrace::trace_unsynchronized::h652d1041ec67eb09
at /rustc/e71f9a9a98b0faf423844bf0ba7438f29dc27d58/library/std/src/../../backtrace/src/backtrace/mod.rs:66:5
2: 0x55865841c00a - std::sys::backtrace::_print_fmt::hd0317245a04c3039
...
test_crash_tracking_bin_panic_hook_string from bin_tests::crashtracker_bin_test (Fix with Cursor)
thread 'test_crash_tracking_bin_panic_hook_string' panicked at bin_tests/tests/crashtracker_bin_test.rs:895:9
thread 'test_crash_tracking_bin_panic_hook_string' panicked at bin_tests/tests/crashtracker_bin_test.rs:895:9:
Expected panic message to start with 'Process panicked with message', got: "Process panicked with message \"Panic with value: 42\" (bin_tests/src/modes/unix/test_014_panic_hook_string.rs:29:9)"
stack backtrace:
0: 0x55e0801c800a - std::backtrace_rs::backtrace::libunwind::trace::h886f3b0575353f6e
at /rustc/e71f9a9a98b0faf423844bf0ba7438f29dc27d58/library/std/src/../../backtrace/src/backtrace/libunwind.rs:116:5
1: 0x55e0801c800a - std::backtrace_rs::backtrace::trace_unsynchronized::h652d1041ec67eb09
at /rustc/e71f9a9a98b0faf423844bf0ba7438f29dc27d58/library/std/src/../../backtrace/src/backtrace/mod.rs:66:5
2: 0x55e0801c800a - std::sys::backtrace::_print_fmt::hd0317245a04c3039
...
test_crash_tracking_bin_panic_hook_unknown_type from bin_tests::crashtracker_bin_test (Fix with Cursor)
thread 'test_crash_tracking_bin_panic_hook_unknown_type' panicked at bin_tests/tests/crashtracker_bin_test.rs:895:9
thread 'test_crash_tracking_bin_panic_hook_unknown_type' panicked at bin_tests/tests/crashtracker_bin_test.rs:895:9:
Expected panic message to start with 'Process panicked with unknown type', got: "Process panicked with unknown type (bin_tests/src/modes/unix/test_015_panic_hook_unknown_type.rs:28:9)"
stack backtrace:
0: 0x561376d6c00a - std::backtrace_rs::backtrace::libunwind::trace::h886f3b0575353f6e
at /rustc/e71f9a9a98b0faf423844bf0ba7438f29dc27d58/library/std/src/../../backtrace/src/backtrace/libunwind.rs:116:5
1: 0x561376d6c00a - std::backtrace_rs::backtrace::trace_unsynchronized::h652d1041ec67eb09
at /rustc/e71f9a9a98b0faf423844bf0ba7438f29dc27d58/library/std/src/../../backtrace/src/backtrace/mod.rs:66:5
2: 0x561376d6c00a - std::sys::backtrace::_print_fmt::hd0317245a04c3039
...
test_crash_tracking_bin_unhandled_exception from bin_tests::crashtracker_bin_test (Fix with Cursor)
thread 'test_crash_tracking_bin_unhandled_exception' panicked at bin_tests/tests/crashtracker_bin_test.rs:160:83
thread 'test_crash_tracking_bin_unhandled_exception' panicked at bin_tests/tests/crashtracker_bin_test.rs:160:83:
called \`Result::unwrap()\` on an \`Err\` value: Expected error message to contain 'Process was terminated due to an unhandled exception of type 'RuntimeException'. Message:
an exception
occured
', got: '"Process was terminated due to an unhandled exception of type 'RuntimeException'. Message: \
an exception \
occured \
"'
...
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Add this suggestion to a batch that can be applied as a single commit.This suggestion is invalid because no changes were made to the code.Suggestions cannot be applied while the pull request is closed.Suggestions cannot be applied while viewing a subset of changes.Only one suggestion per line can be applied in a batch.Add this suggestion to a batch that can be applied as a single commit.Applying suggestions on deleted lines is not supported.You must change the existing code in this line in order to create a valid suggestion.Outdated suggestions cannot be applied.This suggestion has been applied or marked resolved.Suggestions cannot be applied from pending reviews.Suggestions cannot be applied on multi-line comments.Suggestions cannot be applied while the pull request is queued to merge.Suggestion cannot be applied right now. Please check back later.
Motivation
DD_CRASHTRACK_BEGIN_MESSAGE/DD_CRASHTRACK_END_MESSAGEmarkers, allowing an attacker-controlled multiline panic to inject protocol markers and tamper with downstream parsing and configuration.Description
serde_json::to_stringbefore emitting it in the collector, preventing embedded newlines or marker text from becoming raw protocol lines (libdd-crashtracker/src/collector/emitters.rs).libdd-crashtracker/src/receiver/receive_report.rs).Testing
cargo test -p libdd-crashtracker emit_message -- --nocapture, which executed theemit_messageunit tests and reported8 passed; 0 failed.emit_messagetests passed successfully.Codex Task