Compare commits

..

No commits in common. "a79c0250ed7e5d3f35429bffb7d106c7972ce79c" and "5f425435f5642f833f4e3c30abcb57006f43c50b" have entirely different histories.

2 changed files with 5 additions and 10 deletions

View File

@ -68,10 +68,8 @@ pub mod general {
loop {
match dev_reader.read(&mut buf).await {
Ok(n) => {
#[cfg(not(target_os = "macos"))]
//info!("Read from tun.");
dx.send(buf[..n].to_vec()).unwrap();
#[cfg(target_os = "macos")]
dx.send(buf[4..n].to_vec()).unwrap();
},
Err(_e) => { /*error!("Read failed {}", e);*/ }
}
@ -89,8 +87,6 @@ pub mod general {
rr = rx.recv() => {
if let Some(bytes) = rr {
//info!("Write to tun. len={:?}", bytes.len());
#[cfg(target_os = "macos")]
let bytes = [vec![0, 0, 0, 2], bytes].concat();
if let Err(e) = dev_writer.write(&bytes).await {
//error!("Writing error: {:?}", e);
@ -344,7 +340,7 @@ pub mod desktop {
cmd("route", &["add", "-host", endpoint_ip, &gateway.unwrap()]);
cmd("route", &["change", "default", "-interface", "utun3"]); // TODO: change that
cmd("route", &["change", "default", "-interface", "utun3"]); // todo: change that
cmd("route", &["add", "-host", endpoint_ip, &gateway.unwrap()]);
}

View File

@ -1,10 +1,9 @@
use std::fs::File;
use std::io::{Read, Write};
use std::os::fd::{AsRawFd, FromRawFd};
use std::{ffi::CString, process::Command};
use std::sync::Arc;
use std::error::Error;
use log::info;
use tokio::fs::File;
use tokio::io::{AsyncReadExt, AsyncWriteExt};
use crate::device::AbstractDevice;
@ -50,12 +49,12 @@ pub struct DeviceReader {
impl DeviceWriter {
pub async fn write(&mut self, buf: &Vec<u8>) -> Result<usize, Box<dyn Error>> {
Ok(self.writer.write(buf)?)
Ok(self.writer.write(buf).await?)
}
}
impl DeviceReader {
pub async fn read(&mut self, buf: &mut Vec<u8>) -> Result<usize, Box<dyn Error>> {
Ok(self.reader.read(buf)?)
Ok(self.reader.read_buf(buf).await?)
}
}