mirror of
https://github.com/EFForg/rayhunter.git
synced 2026-05-30 08:09:27 -07:00
* client mode added
* Prevent OTA daemons dmclient and upgrade from running and phoning home to Verizon
* Fix workflow
* WIFI changes to support moxee. May need to rebase as delivering refactoring under other PR.
* code changes for rust based wifi client mode docs next
* Doc changes & security fixes
* Added watchdog and recover if crash occurs for wifi.
* Remove changes which were from device UI work (seperate feature which snuck into this branch)
* Add missing wifi and firewall module declarations
* cleaning up the code a bit
* Gate wpa_suplicant in installer and workflow to avoid building binary every push
* fix to check diskspace
* Improved support for subnet colisions, and attempts to rejoin network.
* Add WiFi client support and S01iptables to T-Mobile and Wingtech installers
Both installers now deploy wpa_supplicant, wpa_cli, udhcpc-hook.sh, and
the S01iptables boot-time firewall script. Config generation uses the
shared install_config/install_wifi_creds helpers instead of manual string
replacement.
* Revert "Add WiFi client support and S01iptables to T-Mobile and Wingtech installers"
This reverts commit 944b369c4f.
* Fix build: ignore unused wifi_ssid/wifi_password fields in T-Mobile and Wingtech installers
* Moved to a wifi crate
* Add host route and arp_filter to prevent subnet collisions
* add wakelock so kernel doesn't shut down wifi on battery when wifi is enabled
* Move wifi to external wifi-station crate, remove wifi from installer, extract OTA blocking
* fixed outdated info, moved udhcpc hook to wifi-station crate.
* Update to new version of wifi-station
* Address PR review feedback: replace Docker wpa build, add iw, remove OTA, revert unrelated changes
- Replace Docker-based wpa_supplicant build with shell script (scripts/build-wpa-supplicant.sh)
- Add iw cross-compilation and deployment to Orbic installer
- Skip wifi tool install if binary already exists on device
- Remove OTA daemon blocker (extracted for separate PR)
- Revert unrelated UZ801 and T-Mobile installer changes
- Remove connection.rs test scaffolding
- Rewrite S01iptables init script to read config.toml directly
- Pin url crate to 2.5.4 to fix MSRV
* Fix build script: use bash for parameter substitution
The ${VAR//pattern/replacement} syntax is a bash extension that
doesn't work in dash (Ubuntu's /bin/sh).
* Fix iw build: export PKG_CONFIG_LIBDIR as env var
Passing PKG_CONFIG_LIBDIR as a make variable doesn't export it to
$(shell pkg-config ...) calls. Set it as an environment variable
so pkg-config finds the cross-compiled libnl.
* Point wifi-station to GitHub rev 97c579a
* add comment
* Update daemon/src/config.rs
Add decorators
Co-authored-by: Andrej Walilko <walilkoa@gmail.com>
* Update daemon/src/server.rs
add utopia doc support
Co-authored-by: Andrej Walilko <walilkoa@gmail.com>
* Update daemon/src/server.rs
add utopia doc support
Co-authored-by: Andrej Walilko <walilkoa@gmail.com>
* Update to wifi-station with utoipa doc strings
* add utoipa to wifi-station
* added WPA3 support
* fix firewall port detection, update wifi-station to c267d37
fix ntfy port_or_known_default, comment out ntfy_url in config
template, update wifi-station with resolv.conf bind mount
fallback, udhcpc_bin config, and module path fix for UZ801
* show wifi UI for tmobile and wingtech, add udhcpc_bin config
both devices have wifi hardware and backend support. wingtech
verified on hardware (QCA6174 via PCIe). uz801 excluded for now
due to driver scan limitations with hostapd active.
* install wifi tools from orbic-usb installer, fix DNS default to Quad9, bump wifi-station rev
* fix Modal scroll listener leak, correct file transfer timeout math, document firewall fail-open, clarify UZ801 wifi status
* build-dev.sh: build wifi tools so install-dev works for orbic-family devices
* update Cargo.lock for wifi-station e8ec5b4
* fix setup_timeout_server crypto provider install, apply rustfmt
* Update installer/src/connection.rs
Co-authored-by: Cooper Quintin <cooperq@users.noreply.github.com>
* Update installer/src/orbic.rs
Co-authored-by: Cooper Quintin <cooperq@users.noreply.github.com>
* apply rustfmt to AdbConnection::run_command
---------
Co-authored-by: Andrej Walilko <walilkoa@gmail.com>
Co-authored-by: Cooper Quintin <cooperq@users.noreply.github.com>
93 lines
2.7 KiB
Rust
93 lines
2.7 KiB
Rust
use anyhow::{Result, bail};
|
|
use log::{info, warn};
|
|
use tokio::process::Command;
|
|
|
|
use wifi_station::detect_bridge_iface;
|
|
|
|
use crate::config::Config;
|
|
|
|
async fn run_iptables(args: &[&str]) -> Result<()> {
|
|
let out = Command::new("iptables").args(args).output().await?;
|
|
if !out.status.success() {
|
|
bail!(
|
|
"iptables {} failed: {}",
|
|
args.join(" "),
|
|
String::from_utf8_lossy(&out.stderr)
|
|
);
|
|
}
|
|
Ok(())
|
|
}
|
|
|
|
pub async fn apply(config: &Config) {
|
|
let _ = Command::new("iptables")
|
|
.args(["-F", "OUTPUT"])
|
|
.output()
|
|
.await;
|
|
|
|
if config.firewall_restrict_outbound {
|
|
// Fail open on partial setup error: reachability beats restriction when recovery means physical access.
|
|
match setup_outbound_whitelist(&config.firewall_allowed_ports, &config.ntfy_url).await {
|
|
Ok(()) => info!("outbound firewall active: allowing DHCP, DNS, HTTPS only"),
|
|
Err(e) => warn!("firewall setup failed: {e} (fail-open, outbound unrestricted)"),
|
|
}
|
|
}
|
|
}
|
|
|
|
async fn setup_outbound_whitelist(
|
|
extra_ports: &Option<Vec<u16>>,
|
|
ntfy_url: &Option<String>,
|
|
) -> Result<()> {
|
|
run_iptables(&["-A", "OUTPUT", "-o", "lo", "-j", "ACCEPT"]).await?;
|
|
run_iptables(&["-A", "OUTPUT", "-o", detect_bridge_iface(), "-j", "ACCEPT"]).await?;
|
|
run_iptables(&[
|
|
"-A",
|
|
"OUTPUT",
|
|
"-m",
|
|
"state",
|
|
"--state",
|
|
"ESTABLISHED,RELATED",
|
|
"-j",
|
|
"ACCEPT",
|
|
])
|
|
.await?;
|
|
run_iptables(&[
|
|
"-A", "OUTPUT", "-p", "udp", "--dport", "67:68", "-j", "ACCEPT",
|
|
])
|
|
.await?;
|
|
run_iptables(&["-A", "OUTPUT", "-p", "udp", "--dport", "53", "-j", "ACCEPT"]).await?;
|
|
run_iptables(&["-A", "OUTPUT", "-p", "tcp", "--dport", "53", "-j", "ACCEPT"]).await?;
|
|
run_iptables(&[
|
|
"-A", "OUTPUT", "-p", "tcp", "--dport", "443", "-j", "ACCEPT",
|
|
])
|
|
.await?;
|
|
|
|
if let Some(url) = ntfy_url
|
|
&& let Ok(parsed) = url::Url::parse(url)
|
|
&& let Some(port) = parsed.port_or_known_default()
|
|
&& port != 443
|
|
{
|
|
let port_str = port.to_string();
|
|
run_iptables(&[
|
|
"-A", "OUTPUT", "-p", "tcp", "--dport", &port_str, "-j", "ACCEPT",
|
|
])
|
|
.await?;
|
|
info!("firewall: auto-allowed port {port} for ntfy");
|
|
}
|
|
|
|
if let Some(ports) = extra_ports {
|
|
for port in ports {
|
|
let port_str = port.to_string();
|
|
run_iptables(&[
|
|
"-A", "OUTPUT", "-p", "tcp", "--dport", &port_str, "-j", "ACCEPT",
|
|
])
|
|
.await?;
|
|
}
|
|
}
|
|
|
|
run_iptables(&["-A", "OUTPUT", "-j", "DROP"]).await?;
|
|
|
|
let _ = tokio::fs::write("/proc/sys/net/bridge/bridge-nf-call-iptables", "0").await;
|
|
|
|
Ok(())
|
|
}
|