161 stable releases

new 2.1.58 Nov 20, 2024
2.1.55 Jul 24, 2024
2.1.29 Mar 29, 2024
2.1.13 Dec 15, 2023
0.0.2 Jan 8, 2017

#147 in Web programming

Download history 88627/week @ 2024-07-31 101707/week @ 2024-08-07 114745/week @ 2024-08-14 114376/week @ 2024-08-21 102542/week @ 2024-08-28 130479/week @ 2024-09-04 128265/week @ 2024-09-11 125734/week @ 2024-09-18 138480/week @ 2024-09-25 147952/week @ 2024-10-02 154356/week @ 2024-10-09 152788/week @ 2024-10-16 179813/week @ 2024-10-23 159859/week @ 2024-10-30 172141/week @ 2024-11-06 128905/week @ 2024-11-13

673,586 downloads per month
Used in 80 crates (11 directly)

MIT/Apache

2.5MB
96K SLoC

PSL

A native Rust library for Mozilla's Public Suffix List

CI Publish Latest Version Crates.io downloads Docs Minimum supported Rust version Maintenance License

This library uses Mozilla's Public Suffix List to reliably determine the suffix of a domain name.

It compiles the list down to native Rust code for ultimate speed. This list compilation is done as a separate step by the Publish GitHub Action so the crate still compiles very quickly. The Publish action automatically checks for updates everyday and pushes an updated crate to crates.io if there were any updates in the upstream domain suffixes. This keeps the crate automatically synchronised with the official list.

If you need a dynamic list that can be updated at runtime, though a bit slower, please use the publicsuffix crate instead (which also has optional support for looking up domain names in any case).

Setting Up

Add this crate to your Cargo.toml:

[dependencies]
psl = "2"

Examples

let suffix = psl::suffix(b"www.example.com")?;
assert_eq!(suffix, "com");
assert_eq!(suffix.typ(), Some(psl::Type::Icann));

let domain = psl::domain(b"www.example.com")?;
assert_eq!(domain, "example.com");
assert_eq!(domain.suffix(), "com");

let domain = psl::domain("www.食狮.中国".as_bytes())?;
assert_eq!(domain, "食狮.中国");
assert_eq!(domain.suffix(), "中国");

let domain = psl::domain(b"www.xn--85x722f.xn--55qx5d.cn")?;
assert_eq!(domain, "xn--85x722f.xn--55qx5d.cn");
assert_eq!(domain.suffix(), "xn--55qx5d.cn");

let domain = psl::domain(b"a.b.example.uk.com")?;
assert_eq!(domain, "example.uk.com");
assert_eq!(domain.suffix(), "uk.com");

let domain = psl::domain(b"_tcp.example.com.")?;
assert_eq!(domain, "example.com.");
assert_eq!(domain.suffix(), "com.");

Dependencies