Crates.io | netsock |
lib.rs | netsock |
version | 0.2.0 |
source | src |
created_at | 2024-04-06 08:23:15.827277 |
updated_at | 2024-04-07 14:17:49.39381 |
description | Cross-platform library for network sockets information |
homepage | |
repository | https://github.com/shellrow/netsock |
max_upload_size | |
id | 1198160 |
size | 309,813 |
Cross-platform library for network sockets information.
Add netsock
to your dependencies
[dependencies]
netsock = "0.2"
For more details, see examples or doc.
use netsock::family::AddressFamilyFlags;
use netsock::protocol::ProtocolFlags;
use netsock::socket::ProtocolSocketInfo;
use netsock::get_sockets;
fn main() {
// Combine IPv4 and IPv6 address family flags to search for sockets across both families.
let af_flags = AddressFamilyFlags::IPV4 | AddressFamilyFlags::IPV6;
// Combine TCP and UDP protocol flags to search for both types of sockets.
let proto_flags = ProtocolFlags::TCP | ProtocolFlags::UDP;
// Call get_sockets with the specified address family and protocol flags.
// This function returns a Result, which we match on to handle both the Ok and Err cases.
match get_sockets(af_flags, proto_flags) {
Ok(sockets) => {
// If successful, iterate over the returned sockets and print their information.
for socket in sockets {
// Print the socket and process information
match socket.protocol_socket_info {
ProtocolSocketInfo::Tcp(tcp_socket) => println!(
"[TCP] {}:{} -> {}:{} {:?} - [{}]",
tcp_socket.local_addr,
tcp_socket.local_port,
tcp_socket.remote_addr,
tcp_socket.remote_port,
socket.processes,
tcp_socket.state
),
ProtocolSocketInfo::Udp(udp_socket) => println!(
"[UDP] {}:{} -> *:* {:?}",
udp_socket.local_addr, udp_socket.local_port, socket.processes
),
}
}
}
Err(e) => {
// If an error occurs, print the error message.
eprintln!("Error: {}", e);
}
}
}