diff options
| author | Christine Dodrill <me@christine.website> | 2021-01-16 21:38:22 -0500 |
|---|---|---|
| committer | Christine Dodrill <me@christine.website> | 2021-01-16 21:38:22 -0500 |
| commit | 4bcc848bb178d9e4372ba13b750d620cabc2a9ac (patch) | |
| tree | e2a97a5a03c934de6307b3d543d5f4b249675ce7 /src/app | |
| parent | 17af42bc698237d1560b8add144641ae3950b469 (diff) | |
| download | xesite-4bcc848bb178d9e4372ba13b750d620cabc2a9ac.tar.xz xesite-4bcc848bb178d9e4372ba13b750d620cabc2a9ac.zip | |
move poking services into app boot after systemd notify
Signed-off-by: Christine Dodrill <me@christine.website>
Diffstat (limited to 'src/app')
| -rw-r--r-- | src/app/mod.rs | 1 | ||||
| -rw-r--r-- | src/app/poke.rs | 86 |
2 files changed, 87 insertions, 0 deletions
diff --git a/src/app/mod.rs b/src/app/mod.rs index e763792..6c01b2f 100644 --- a/src/app/mod.rs +++ b/src/app/mod.rs @@ -5,6 +5,7 @@ use std::{fs, path::PathBuf}; use tracing::{error, instrument}; pub mod markdown; +pub mod poke; #[derive(Clone, Deserialize)] pub struct Config { diff --git a/src/app/poke.rs b/src/app/poke.rs new file mode 100644 index 0000000..dd6f9fe --- /dev/null +++ b/src/app/poke.rs @@ -0,0 +1,86 @@ +use color_eyre::eyre::Result; +use std::{env, time::Duration}; +use tokio::time::delay_for; + +#[instrument(err)] +pub async fn the_cloud() -> Result<()> { + info!("waiting for things to settle"); + delay_for(Duration::from_secs(10)).await; + + info!("purging cloudflare cache"); + cloudflare().await?; + + info!("waiting for the cloudflare cache to purge globally"); + delay_for(Duration::from_secs(45)).await; + + info!("poking mi"); + mi().await?; + + info!("poking bing"); + bing().await?; + + info!("poking google"); + google().await?; + + Ok(()) +} + +#[instrument(err)] +async fn bing() -> Result<()> { + let cli = reqwest::Client::new(); + cli.get("https://www.bing.com/ping") + .query(&[("sitemap", "https://christine.website/sitemap.xml")]) + .header("User-Agent", crate::APPLICATION_NAME) + .send() + .await? + .error_for_status()?; + + Ok(()) +} + +#[instrument(err)] +async fn google() -> Result<()> { + let cli = reqwest::Client::new(); + cli.get("https://www.google.com/ping") + .query(&[("sitemap", "https://christine.website/sitemap.xml")]) + .header("User-Agent", crate::APPLICATION_NAME) + .send() + .await? + .error_for_status()?; + + Ok(()) +} + +#[instrument(err)] +async fn cloudflare() -> Result<()> { + let cli = cfcache::Client::new(env::var("CF_TOKEN")?, env::var("CF_ZONE_ID")?)?; + cli.purge( + vec![ + "https://christine.website/sitemap.xml", + "https://christine.website", + "https://christine.website/blog", + "https://christine.website/blog.atom", + "https://christine.website/blog.json", + "https://christine.website/blog.rss", + "https://christine.website/gallery", + "https://christine.website/talks", + "https://christine.website/resume", + "https://christine.website/signalboost", + "https://christine.website/feeds", + ] + .into_iter() + .map(|i| i.to_string()) + .collect(), + ) + .await?; + + Ok(()) +} + +#[instrument(err)] +async fn mi() -> Result<()> { + let cli = mi::Client::new(env::var("MI_TOKEN")?, crate::APPLICATION_NAME.to_string())?; + cli.refresh().await?; + + Ok(()) +} |
