-
Notifications
You must be signed in to change notification settings - Fork 349
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
WIP Add end-to-end test for MLLVD_CR_24_03
- Loading branch information
1 parent
a602649
commit 31d803f
Showing
2 changed files
with
82 additions
and
0 deletions.
There are no files selected for viewing
This file contains 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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,81 @@ | ||
#![cfg(target_os = "linux")] | ||
//! Test mitigation for mllv_cr_24_03 | ||
//! | ||
//! TODO: Describe the audit issue and how it is tested. | ||
//! | ||
//! Victim: test-runner | ||
//! Network adjacent attacker: test-manager | ||
//! | ||
//! # Setup | ||
//! Have test-runner connect to relay. Then let the test-manager know about the test-runner's | ||
//! private in-tunnel IP (such that we don't have to enumerate all possible private IPs). | ||
//! | ||
//! # Procedure | ||
//! Have test-manager invoke the `arping` command with a fixed timeout targetting the bridge | ||
//! network between test-manager <-> test-runner. . If `arping` times out without a reply, it will | ||
//! exit with a non-0 exit code. If it got a reply from test-runner, it will exit with code 0. | ||
//! | ||
//! Note that only linux was susceptible to this vulnerability. | ||
use std::ffi::OsStr; | ||
use std::process::ExitStatus; | ||
|
||
use anyhow::bail; | ||
use mullvad_management_interface::MullvadProxyClient; | ||
use test_macro::test_function; | ||
use test_rpc::ServiceClient; | ||
|
||
use crate::tests::helpers::*; | ||
use crate::tests::TestContext; | ||
use crate::vm::network::bridge; | ||
|
||
#[test_function(target_os = "linux")] | ||
pub async fn test_mllvd_cr_24_03( | ||
_: TestContext, | ||
rpc: ServiceClient, | ||
mut mullvad_client: MullvadProxyClient, | ||
) -> anyhow::Result<()> { | ||
// Get the bridge network between manager and runner. This will be used when invoking `arping`. | ||
let bridge = bridge()?; | ||
// Connect runner to a relay. After this point we will be able to acquire the runner's private | ||
// in-tunnel IP. | ||
connect_and_wait(&mut mullvad_client).await?; | ||
// Get the private ip address | ||
|
||
let in_tunnel_ip = { | ||
let vpn_interface = get_tunnel_interface(&mut mullvad_client).await.unwrap(); // :cat-scream: | ||
rpc.get_interface_ip(vpn_interface).await? | ||
}; | ||
// Invoke arping | ||
let Some(code) = arping([ | ||
"-w", | ||
"5", | ||
"-i", | ||
"1", | ||
"-I", | ||
&bridge, | ||
&in_tunnel_ip.to_string(), | ||
]) | ||
.await? | ||
.code() else { | ||
bail!("arping terminated by signal") | ||
}; | ||
// If arping exited with code 0, that means that the runner replied to the ARP request. | ||
// I.e., the runner leaked its private in-tunnel IP! | ||
if code == 0 { | ||
// TODO: Add a more descriptive error message! | ||
bail!("ARP leak detected") | ||
} | ||
// test runner did not respond to ARP request, leak mitigation seems to work! | ||
Ok(()) | ||
} | ||
|
||
async fn arping<I, S>(args: I) -> std::io::Result<ExitStatus> | ||
where | ||
I: IntoIterator<Item = S>, | ||
S: AsRef<OsStr>, | ||
{ | ||
let mut arping = tokio::process::Command::new("arping"); | ||
arping.args(args); | ||
arping.spawn()?.wait().await | ||
} |
This file contains 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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,3 +1,4 @@ | ||
//! This module collects tests for old audit issues to prevent any potential regression. | ||
pub mod cve_2019_14899; | ||
pub mod mllvd_cr_24_03; | ||
pub mod mul_02_002; |