132 stable releases

new 2.1.29 Mar 29, 2024
2.1.25 Feb 14, 2024
2.1.13 Dec 15, 2023
2.1.12 Nov 23, 2023
0.0.2 Jan 8, 2017

#200 in Web programming

Download history 40915/week @ 2023-12-08 37206/week @ 2023-12-15 11697/week @ 2023-12-22 28347/week @ 2023-12-29 39984/week @ 2024-01-05 40323/week @ 2024-01-12 44032/week @ 2024-01-19 36459/week @ 2024-01-26 43976/week @ 2024-02-02 43015/week @ 2024-02-09 42847/week @ 2024-02-16 53213/week @ 2024-02-23 58972/week @ 2024-03-01 44318/week @ 2024-03-08 46137/week @ 2024-03-15 39967/week @ 2024-03-22

197,196 downloads per month
Used in 65 crates (6 directly)

MIT/Apache

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