#unix-domain-socket #sockets #unix-socket #networking #address

socket-address

A simple implementation of a socket address that can be either a network socket or a Unix domain socket

3 releases (breaking)

0.3.0 Oct 1, 2024
0.2.0 Nov 5, 2023
0.1.0 Jul 26, 2023

#6 in #socket-programming

Download history 26/week @ 2024-11-17 53/week @ 2024-11-24 82/week @ 2024-12-01 131/week @ 2024-12-08 5/week @ 2024-12-15 17/week @ 2024-12-22 51/week @ 2024-12-29 80/week @ 2025-01-05 29/week @ 2025-01-12 44/week @ 2025-01-19 85/week @ 2025-01-26 71/week @ 2025-02-02 47/week @ 2025-02-09 171/week @ 2025-02-16 51/week @ 2025-02-23 237/week @ 2025-03-02

518 downloads per month

MIT license

6KB
81 lines

ListenAddress

use core::str::FromStr;
use std::net::{IpAddr, Ipv4Addr, SocketAddr};

use socket_address::ListenAddress;

let addr = ListenAddress::from_str("0.0.0.0:80").unwrap();
assert_eq!(addr, ListenAddress::Network(SocketAddr::new(IpAddr::V4(Ipv4Addr::new(0, 0, 0, 0)), 80)));
use core::str::FromStr;
use std::path::PathBuf;

use socket_address::ListenAddress;

let addr = ListenAddress::from_str("unix:myapp.sock").unwrap();
assert_eq!(addr, ListenAddress::UnixSocket("myapp.sock".into()));

ConnectAddress

use core::str::FromStr;
use http::Uri;

use socket_address::ConnectAddress;

let addr = ConnectAddress::from_str("http://127.0.0.1/").unwrap();
assert_eq!(addr, ConnectAddress::Uri(Uri::from_str("http://127.0.0.1/").unwrap()));
use core::str::FromStr;
use std::path::PathBuf;

use socket_address::ConnectAddress;

let addr = ConnectAddress::from_str("unix:myapp.sock").unwrap();
assert_eq!(addr, ConnectAddress::UnixSocket("myapp.sock".into()));

Dependencies

~0.8–1.3MB
~25K SLoC