Page MenuHomeFreeBSD

lang/rust: Make OpenSSL use the system default truststore in Cargo
ClosedPublic

Authored by michaelo on Feb 24 2025, 10:59 AM.
Tags
None
Referenced Files
F140884307: D49120.id151396.diff
Mon, Dec 29, 5:46 AM
Unknown Object (File)
Wed, Dec 24, 5:35 PM
Unknown Object (File)
Wed, Dec 24, 5:35 PM
Unknown Object (File)
Wed, Dec 24, 5:35 PM
Unknown Object (File)
Wed, Dec 24, 5:35 PM
Unknown Object (File)
Fri, Dec 5, 8:33 AM
Unknown Object (File)
Fri, Dec 5, 8:33 AM
Unknown Object (File)
Nov 20 2025, 5:44 AM
Subscribers

Details

Summary

Cargo uses curl-rust and git2-rs (which uses curl-rest as well).
Unfortunately, git2-rs calls openssl_probe::init_ssl_cert_env_vars()
unconditionally which breaks the process environment by setting an invalid
value for SSL_CERT_DIR and then the system default truststore is circumvented,
resulting in certificate validation errors even if certlctl(8) manages
everything nicely.

Upstream issues:

Diff Detail

Repository
R11 FreeBSD ports repository
Lint
Lint Skipped
Unit
Tests Skipped
Build Status
Buildable 62613
Build 59497: arc lint + arc unit

Event Timeline

Rust maintainers, please have a look. This is quite annoying issue especially because it is hard to diagnose from a high level perspective.

This revision is now accepted and ready to land.Mar 7 2025, 1:16 PM

Hope to remove patch when upstream accepts it.