Skip to content

Commit

Permalink
Bump version to 0.0.8
Browse files Browse the repository at this point in the history
  • Loading branch information
SajjadPourali committed Apr 7, 2024
1 parent 31ca1b3 commit 9da1566
Show file tree
Hide file tree
Showing 2 changed files with 14 additions and 12 deletions.
2 changes: 1 addition & 1 deletion Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
authors = ['Narrowlink <[email protected]>']
description = 'Asynchronous lightweight userspace implementation of TCP/IP stack for Tun device'
name = "ipstack"
version = "0.0.7"
version = "0.0.8"
edition = "2021"
license = "Apache-2.0"
repository = 'https://github.com/narrowlink/ipstack'
Expand Down
24 changes: 13 additions & 11 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -13,18 +13,19 @@ Unstable, under development.
### Usage

```rust
use etherparse::{IcmpEchoHeader, Icmpv4Header};
use ipstack::stream::IpStackStream;
use std::net::{IpAddr, Ipv4Addr, SocketAddr};
use tokio::net::TcpStream;
use udp_stream::UdpStream;
use tokio::io{AsyncRead, AsyncWrite};
use etherparse::{IcmpEchoHeader, Icmpv4Header};

#[tokio::main]
async fn main(){
async fn main() {
const MTU: u16 = 1500;
let ipv4 = Ipv4Addr::new(10, 0, 0, 1);
let netmask = Ipv4Addr::new(255, 255, 255, 0);
let mut config = tun2::Configuration::default();
config.address(ipv4).netmask(netmask).mtu(MTU as usize).up();
config.address(ipv4).netmask(netmask).mtu(MTU).up();

#[cfg(target_os = "linux")]
config.platform_config(|config| {
Expand All @@ -38,26 +39,27 @@ async fn main(){

let mut ipstack_config = ipstack::IpStackConfig::default();
ipstack_config.mtu(MTU);
let mut ip_stack = ipstack::IpStack::new(ipstack_config, tun2::create_as_async(&config).unwrap());
let mut ip_stack =
ipstack::IpStack::new(ipstack_config, tun2::create_as_async(&config).unwrap());

while let Ok(stream) = ip_stack.accept().await {
match stream {
IpStackStream::Tcp(mut tcp) => {
let mut rhs = TcpStream::connect("1.1.1.1:80").await.unwrap();
tokio::spawn(async move {
let _ = tokio::io::copy_bidirectional(& mut tcp, & mut rhs).await;
let _ = tokio::io::copy_bidirectional(&mut tcp, &mut rhs).await;
});
}
IpStackStream::Udp(mut udp) => {
let addr = SocketAddr::new(IpAddr::V4(Ipv4Addr::new(1, 1, 1, 1)), 53);
let mut rhs = UdpStream::connect(addr).await.unwrap();
tokio::spawn(async move {
let _ = tokio::io::copy_bidirectional(& mut udp, & mut rhs).await;
let _ = tokio::io::copy_bidirectional(&mut udp, &mut rhs).await;
});
}
IpStackStream::UnknownTransport(u) => {
if u.src_addr().is_ipv4() && u.ip_protocol() == 1 {
let (icmp_header, req_payload) = Icmpv4Header::from_slice(u.payload())?;
if u.src_addr().is_ipv4() && u.ip_protocol() == etherparse::IpNumber(1) {
let (icmp_header, req_payload) = Icmpv4Header::from_slice(u.payload()).unwrap();
if let etherparse::Icmpv4Type::EchoRequest(req) = icmp_header.icmp_type {
println!("ICMPv4 echo");
let echo = IcmpEchoHeader {
Expand All @@ -68,13 +70,13 @@ async fn main(){
resp.update_checksum(req_payload);
let mut payload = resp.to_bytes().to_vec();
payload.extend_from_slice(req_payload);
u.send(payload)?;
u.send(payload).unwrap();
} else {
println!("ICMPv4");
}
continue;
}
println!("unknown transport - Ip Protocol {}", u.ip_protocol());
println!("unknown transport - Ip Protocol {}", u.ip_protocol().0);
continue;
}
IpStackStream::UnknownNetwork(pkt) => {
Expand Down

0 comments on commit 9da1566

Please sign in to comment.