aboutsummaryrefslogtreecommitdiff
path: root/src/hooks
diff options
context:
space:
mode:
Diffstat (limited to 'src/hooks')
-rw-r--r--src/hooks/url.rs36
1 files changed, 22 insertions, 14 deletions
diff --git a/src/hooks/url.rs b/src/hooks/url.rs
index d5836d0..252ac09 100644
--- a/src/hooks/url.rs
+++ b/src/hooks/url.rs
@@ -1,12 +1,11 @@
use anyhow::Result;
use irc::client::prelude::*;
-use macros::privmsg;
-use std::option::Option;
-use std::str::FromStr;
-use std::string::String;
use regex::Regex;
+extern crate kuchiki;
+use kuchiki::traits::*;
+
pub const URL_REGEX: &str = r#"(https?://|www.)\S+"#;
pub fn url_parser(msg: &str) -> Vec<String> {
@@ -19,18 +18,19 @@ pub fn url_parser(msg: &str) -> Vec<String> {
}
pub async fn url_title(url: &str) -> Option<String> {
- let body = reqwest::get(url).await.unwrap().text().await.unwrap();
-
- let parsed_body = html_parser::Dom::parse(&body).unwrap().to_json();
+ let body = reqwest::get(url).await.ok()?.text().await.ok()?;
-
- return Some("Hacker News".to_string());
+ let document = kuchiki::parse_html().one(body);
+ match document.select("title") {
+ Ok(title) => Some(title.into_iter().nth(0)?.text_contents()),
+ Err(_) => None,
+ }
}
pub fn url_preview(bot: &crate::Bot, msg: Message) -> Result<()> {
if let Command::PRIVMSG(target, text) = msg.command.clone() {
for url in url_parser(&text) {
- if let Some(title) = futures::executor::block_on(url_title(&url.as_str())){
+ if let Some(title) = futures::executor::block_on(url_title(&url.as_str())) {
bot.send_privmsg(&target, title.as_str())?;
}
}
@@ -45,10 +45,18 @@ mod tests {
#[test]
fn test_url_titel() {
- let title = tokio_test::block_on(
- url_title("https://news.ycombinator.com/")
- );
- assert_eq!(title.unwrap().as_str(), "Hackerr News");
+ let title: String =
+ tokio_test::block_on(url_title("https://news.ycombinator.com")).unwrap();
+ assert_eq!(title.as_str(), "Hacker News");
+
+ let title: String =
+ tokio_test::block_on(url_title("https://google.com")).unwrap();
+ assert_eq!(title.as_str(), "Google");
+
+ let title: Option<String> =
+ tokio_test::block_on(url_title("random_site"));
+ assert_eq!(title, None)
+
}
#[test]
fn test_url_parser() {
n class='deletions'>-47/+1744 2025-10-21add slskdMax Audron-1/+124 2025-10-10update nixpkgs-unstableMax Audron-3/+3 2025-10-10setup mailserverMax Audron-27/+213 2025-09-20replace dns bgp anouncementMax Audron-2/+2 2025-09-15update flaresolverrMax Audron-1/+1 2025-09-07add audron windows wg keyMax Audron-0/+8 2025-09-02switch out vultr dns ipv4 ipMax Audron-1/+5 2025-08-11disable homepage trackersMax Audron-3/+3 2025-08-11add mail serverMax Audron-1/+245 2025-08-05add prometheus alerting rulesMax Audron-38/+144 2025-08-01add homepage dashboardMax Audron-3/+284 2025-08-01disable not used gameserversMax Audron-1/+2 2025-08-01add minecraft prometheus exporterMax Audron-3/+67 2025-08-01more monitoring & scrape config shortcutsMax Audron-68/+63 2025-08-01update garage to 2.0Max Audron-6/+10 2025-07-31fix authentik-ldap port bindingsMax Audron-0/+5 2025-07-31update to nixos 25.05Max Audron-113/+65 2025-07-31add more monitoring exporters and scrapersMax Audron-17/+57 2025-07-30try to run authentik nativelyMax Audron-26/+303 2025-07-30more metricsMax Audron-1/+41 2025-07-30enable firewallsMax Audron-1/+39