182 stable releases

new 2.1.79 Jan 17, 2025
2.1.73 Dec 25, 2024
2.1.64 Nov 30, 2024
2.1.55 Jul 24, 2024
0.0.2 Jan 8, 2017

#42 in Web programming

Download history 130952/week @ 2024-09-27 166023/week @ 2024-10-04 141225/week @ 2024-10-11 160218/week @ 2024-10-18 189266/week @ 2024-10-25 153946/week @ 2024-11-01 171497/week @ 2024-11-08 147289/week @ 2024-11-15 107924/week @ 2024-11-22 79039/week @ 2024-11-29 159399/week @ 2024-12-06 148795/week @ 2024-12-13 40877/week @ 2024-12-20 50422/week @ 2024-12-27 141391/week @ 2025-01-03 137496/week @ 2025-01-10

397,171 downloads per month
Used in 82 crates (11 directly)

MIT/Apache

2.5MB
95K 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