Allow external links to start with "www.*" (#2100)

* Make www.* URLs considered valid external links

* Tweak description of is_external_link
This commit is contained in:
Katie Watson 2023-02-14 04:20:41 -08:00 committed by Vincent Prouillet
parent bc27c01024
commit 902fd3a9fb
2 changed files with 3 additions and 2 deletions

View File

@ -593,6 +593,7 @@ mod tests {
fn test_is_external_link() { fn test_is_external_link() {
assert!(is_external_link("http://example.com/")); assert!(is_external_link("http://example.com/"));
assert!(is_external_link("https://example.com/")); assert!(is_external_link("https://example.com/"));
assert!(is_external_link("www.example.com"));
assert!(is_external_link("https://example.com/index.html#introduction")); assert!(is_external_link("https://example.com/index.html#introduction"));
assert!(!is_external_link("mailto:user@example.com")); assert!(!is_external_link("mailto:user@example.com"));

View File

@ -10,7 +10,7 @@ pub fn port_is_available(port: u16) -> bool {
TcpListener::bind(("127.0.0.1", port)).is_ok() TcpListener::bind(("127.0.0.1", port)).is_ok()
} }
/// Returns whether a link starts with an HTTP(s) scheme. /// Returns whether a link starts with an HTTP(s) scheme or "www.".
pub fn is_external_link(link: &str) -> bool { pub fn is_external_link(link: &str) -> bool {
link.starts_with("http:") || link.starts_with("https:") link.starts_with("http:") || link.starts_with("https:") || link.starts_with("www.")
} }