Improve kanji link validation using HEAD request
This commit is contained in:
parent
c4451c93e2
commit
f35bea5489
1 changed files with 4 additions and 18 deletions
|
@ -15,28 +15,14 @@ fn random_from_string(string: &str) -> char {
|
||||||
async fn display_kanji(ctx: &Context, msg: &Message, kanji: char, comment: &str) -> CommandResult {
|
async fn display_kanji(ctx: &Context, msg: &Message, kanji: char, comment: &str) -> CommandResult {
|
||||||
msg.reply(&ctx.http, format!("{}{}", kanji, comment))
|
msg.reply(&ctx.http, format!("{}{}", kanji, comment))
|
||||||
.await?;
|
.await?;
|
||||||
// Not all character codes are covered in mistval/kanji_images.
|
|
||||||
// The current implementation of 404-checking requires
|
|
||||||
// the loading of whatever content is hosted on the URL even though
|
|
||||||
// only the status code (404 for Not Found and 200 for OK) is needed.
|
|
||||||
//
|
|
||||||
// This may need to be disabled in production, since it makes
|
|
||||||
// response times feel sluggish.
|
|
||||||
//
|
|
||||||
// Possible ways of fixing this issue:
|
|
||||||
// - Store the entire mistval/kanji_images dataset locally and check for file presense
|
|
||||||
// (not desirable, since the remote repository may change)
|
|
||||||
// - Find a way to make requests but only get the status code
|
|
||||||
const VALIDATE_LINKS: bool = false;
|
|
||||||
let url = format!(
|
let url = format!(
|
||||||
"https://raw.githubusercontent.com/mistval/kanji_images/master/gifs/{}.gif",
|
"https://raw.githubusercontent.com/mistval/kanji_images/master/gifs/{}.gif",
|
||||||
format!("{:x}", kanji as i32)
|
format!("{:x}", kanji as i32)
|
||||||
);
|
);
|
||||||
let mut link_validated = true;
|
let client = reqwest::Client::new();
|
||||||
if VALIDATE_LINKS {
|
let request = client.head(&url).build().unwrap();
|
||||||
let response = reqwest::get(&url).await?.text().await?;
|
let response = client.execute(request).await?.status();
|
||||||
link_validated = response != "404: Not Found";
|
let link_validated = response != reqwest::StatusCode::NOT_FOUND;
|
||||||
}
|
|
||||||
msg.channel_id
|
msg.channel_id
|
||||||
.say(
|
.say(
|
||||||
&ctx.http,
|
&ctx.http,
|
||||||
|
|
Loading…
Add table
Reference in a new issue