mirror of
https://github.com/bitwarden/browser
synced 2025-12-21 02:33:46 +00:00
* clean crate deps * update lint workflow * add rustfmt.toml * apply rust fmt * missed one * fix lint of lint lol * more deps platform fixes * fix macos_provider * some more deps clean * more cleanup * add --all-targets * remove another unused dep * generate index.d.ts * fix whitespace * fix split comment in biometric * formatting comment in biometric_v2 * apply fmt
49 lines
1.7 KiB
Rust
49 lines
1.7 KiB
Rust
#![cfg(target_os = "linux")]
|
|
|
|
//! This library compiles to a pre-loadable shared object. When preloaded, it
|
|
//! immediately isolates the process using the methods available on the platform.
|
|
//! On Linux, this is PR_SET_DUMPABLE to prevent debuggers from attaching, the env
|
|
//! from being read and the memory from being stolen.
|
|
|
|
use std::{ffi::c_char, sync::LazyLock};
|
|
|
|
use desktop_core::process_isolation;
|
|
use tracing::info;
|
|
|
|
static ORIGINAL_UNSETENV: LazyLock<unsafe extern "C" fn(*const c_char) -> i32> =
|
|
LazyLock::new(|| unsafe {
|
|
std::mem::transmute(libc::dlsym(libc::RTLD_NEXT, c"unsetenv".as_ptr()))
|
|
});
|
|
|
|
/// Hooks unsetenv to fix a bug in zypak-wrapper.
|
|
/// Zypak unsets the env in Flatpak as a side-effect, which means that only the top level
|
|
/// processes would be hooked. With this work-around all processes in the tree are hooked
|
|
#[unsafe(no_mangle)]
|
|
unsafe extern "C" fn unsetenv(name: *const c_char) -> i32 {
|
|
unsafe {
|
|
let Ok(name_str) = std::ffi::CStr::from_ptr(name).to_str() else {
|
|
return ORIGINAL_UNSETENV(name);
|
|
};
|
|
|
|
if name_str == "LD_PRELOAD" {
|
|
// This env variable is provided by the flatpak configuration
|
|
let ld_preload = std::env::var("PROCESS_ISOLATION_LD_PRELOAD").unwrap_or_default();
|
|
std::env::set_var("LD_PRELOAD", ld_preload);
|
|
return 0;
|
|
}
|
|
|
|
ORIGINAL_UNSETENV(name)
|
|
}
|
|
}
|
|
|
|
// Hooks the shared object being loaded into the process
|
|
#[ctor::ctor]
|
|
fn preload_init() {
|
|
let pid = unsafe { libc::getpid() };
|
|
info!(pid, "Enabling memory security for process.");
|
|
unsafe {
|
|
process_isolation::isolate_process();
|
|
process_isolation::disable_coredumps();
|
|
}
|
|
}
|