~erk/inbox

[fix] Update to new website for comic themes v3 APPLIED

Ken Swenson: 1
 [fix] Update to new website for comic themes

 3 files changed, 29 insertions(+), 16 deletions(-)
Export patchset (mbox)
How do I use this?

Copy & paste the following snippet into your terminal to import this patchset into git:

curl -s https://lists.sr.ht/~erk/inbox/patches/11423/mbox | git am -3
Learn more about email & git

[PATCH v3] [fix] Update to new website for comic themes Export this patch

Signed-off-by: Ken Swenson <flat@esoteric.moe>
---
Third time is the charm. Rebased to master.
 src/comic.rs |  6 +++---
 src/main.rs  | 10 +++++-----
 src/theme.rs | 29 +++++++++++++++++++++--------
 3 files changed, 29 insertions(+), 16 deletions(-)

diff --git a/src/comic.rs b/src/comic.rs
index 8572b72..3e0cdc7 100644
--- a/src/comic.rs
+++ b/src/comic.rs
@@ -33,9 +33,9 @@ impl ComicEmbed {
            Embed {
                author: Some(EmbedAuthor {
                    icon_url: Some(String::from(FAVICON)),
                    name: Some(String::from("Garfield.com")),
                    name: Some(String::from("GoComics.com")),
                    proxy_icon_url: None,
                    url: Some(String::from("https://garfield.com")),
                    url: Some(String::from("https://www.gocomics.com/garfield")),
                }),
                color: Some(0x00D6_8717),
                description: None,
@@ -101,7 +101,7 @@ impl ComicEmbed {
            ));

            self.0.url = Some(format!(
                "https://garfield.com/comic/{}/{}/{}",
                "https://gocomics.com/garfield/{}/{:02}/{:02}",
                date.year(),
                date.month(),
                date.day()
diff --git a/src/main.rs b/src/main.rs
index fb00d96..c73e7db 100644
--- a/src/main.rs
+++ b/src/main.rs
@@ -5,9 +5,9 @@ use std::ops::Deref;

use twilight::command_parser::{Command, CommandParserConfig, Parser};
//use twilight::gateway::shard::Event;
use twilight::model::gateway::event::Event;
use twilight::http::Client as HttpClient;
use twilight::model::channel::message::Message;
use twilight::model::gateway::event::Event;
use twilight::model::gateway::presence::Activity;
use twilight::model::gateway::presence::ActivityType;
use twilight::model::id::*;
@@ -89,7 +89,7 @@ async fn async_main() -> GarfieldResult<()> {
    tokio::task::spawn_blocking(move || exporter.run());

    pretty_env_logger::init_timed();
    

    let db = sled::open("./lasagne.db")?;
    let subs = db.open_tree(b"syndicate")?;

@@ -144,16 +144,16 @@ async fn async_main() -> GarfieldResult<()> {
    let theme_client = ThemeClient::new_rwc(rqc.clone())?;

    let queue: Arc<Box<dyn Queue>> = Arc::new(Box::new(
        twilight::gateway::queue::LargeBotQueue::new(1, &http).await
        twilight::gateway::queue::LargeBotQueue::new(1, &http).await,
    ));

    let cache = InMemoryCache::new();
    

    let cluster_config = ClusterConfig::builder(&token)
        .http_client(http.clone())
        .queue(queue)
        .build();
    

    let cluster = Cluster::new(cluster_config).await?;

    let cluster_spawn = cluster.clone();
diff --git a/src/theme.rs b/src/theme.rs
index 0af270f..5a57c24 100644
--- a/src/theme.rs
+++ b/src/theme.rs
@@ -1,4 +1,4 @@
const COMICS_PER_PAGE: u64 = 6;
const COMICS_PER_PAGE: u64 = 10;

use regex::Regex;
use reqwest::Client as ReqwestClient;
@@ -16,9 +16,9 @@ pub struct ThemeClient {

impl ThemeClient {
    pub fn new_rwc(rwc: ReqwestClient) -> GarfieldResult<Self> {
        let count_re = Regex::new(r#"<span class="pull-right">(?:\d+) of (\d+)</span>"#)?;
        let count_re = Regex::new(r#">(\d.*) Results for Garfield"#)?;
        let comic_re = Regex::new(
            r#"src="https://d1ejxu6vysztl5.cloudfront.net/comics/garfield/[0-9]{4}/([0-9]{4}-[0-9]{2}-[0-9]{2}).gif"#,
            r#"href="/garfield/([0-9]+/[0-9]+/[0-9]+)""#,
        )?;
        Ok(Self {
            rwc,
@@ -28,8 +28,15 @@ impl ThemeClient {
    }

    async fn get_count(&self, theme: &str) -> GarfieldResult<Option<u64>> {
        let url =
            reqwest::Url::parse_with_params("https://garfield.com/comic", &[("keywords", theme)])?;
        let url = reqwest::Url::parse_with_params(
            "https://www.gocomics.com/search/full_results",
            &[
                ("terms", theme),
                ("category", "comic"),
                ("short_name", "garfield"),
                ("sort", "date_desc"),
            ],
        )?;

        let page = self
            .rwc
@@ -54,8 +61,14 @@ impl ThemeClient {
    ) -> GarfieldResult<Option<String>> {
        let page = n / COMICS_PER_PAGE;
        let url = reqwest::Url::parse_with_params(
            "https://garfield.com/comic",
            &[("keywords", theme), ("page", &format!("{}", page))],
            "https://www.gocomics.com/search/full_results",
            &[
                ("category", "comic"),
                ("short_name", "garfield"),
                ("sort", "date_desc"),
                ("terms", theme),
                ("page", &format!("{}", match page { 0 => 1, _ => page,})),
            ],
        )?;
        let text = self
            .rwc
@@ -73,7 +86,7 @@ impl ThemeClient {
        let mut rng = rand::thread_rng();

        match cap.choose(&mut rng) {
            Some(c) => Ok(Some(c[1].to_string())),
            Some(c) => Ok(Some(c[1].to_string().replace("/", "-"))),
            None => Ok(None),
        }
    }
-- 
2.27.0