fix: render only specified gists, if specification is provided

This commit is contained in:
Aravinth Manivannan 2022-01-16 14:14:58 +05:30
parent df14f8b0b8
commit 574d14714d
Signed by: realaravinth
GPG key ID: AD9F0F08E855ED88
3 changed files with 56 additions and 20 deletions

View file

@ -50,10 +50,6 @@ pub type PostResp = get_post::GetPostPost;
pub type AppData = web::Data<Data>; pub type AppData = web::Data<Data>;
impl PostResp { impl PostResp {
pub fn get_gist_id<'a>(&self, url: &'a str) -> &'a str {
url.split('/').last().unwrap()
}
pub fn get_subtitle(&self) -> &str { pub fn get_subtitle(&self) -> &str {
self.preview_content.as_ref().unwrap().subtitle.as_str() self.preview_content.as_ref().unwrap().subtitle.as_str()
} }
@ -65,7 +61,7 @@ pub struct GistContent {
pub html_url: String, pub html_url: String,
} }
#[derive(Deserialize, Serialize)] #[derive(Deserialize, Clone, Serialize)]
pub struct GistFile { pub struct GistFile {
pub file_name: String, pub file_name: String,
pub content: String, pub content: String,
@ -191,9 +187,25 @@ impl Data {
} }
} }
pub async fn get_gist(&self, id: String) -> (String, GistContent) { pub fn get_gist_id(url: &str) -> &str {
match self.gists.get(&id) { url.split('/').last().unwrap()
Ok(Some(v)) => (id, bincode::deserialize(&v[..]).unwrap()), }
pub async fn get_gist(&self, gist_url: String) -> (String, GistContent) {
let id = Self::get_gist_id(&gist_url).to_owned();
let file_name = if gist_url.contains('?') {
let parsed = url::Url::parse(&gist_url).unwrap();
if let Some((_, file_name)) = parsed.query_pairs().find(|(k, _)| k == "file") {
Some(file_name.into_owned())
} else {
None
}
} else {
None
};
let gist = match self.gists.get(&id) {
Ok(Some(v)) => bincode::deserialize(&v[..]).unwrap(),
_ => { _ => {
const URL: &str = "https://api.github.com/gists/"; const URL: &str = "https://api.github.com/gists/";
@ -211,9 +223,9 @@ impl Data {
.unwrap(); .unwrap();
let files = resp.get("files").unwrap(); let files = resp.get("files").unwrap();
let v = files.as_object().unwrap(); let v = files.as_object().unwrap();
let mut files = Vec::with_capacity(v.len());
v.iter().for_each(|(name, file_obj)| { fn to_gist_file(name: &str, file_obj: &serde_json::Value) -> GistFile {
let file = GistFile { GistFile {
file_name: name.to_string(), file_name: name.to_string(),
content: file_obj content: file_obj
.get("content") .get("content")
@ -233,9 +245,15 @@ impl Data {
.as_str() .as_str()
.unwrap() .unwrap()
.to_owned(), .to_owned(),
}; }
}
let mut files = Vec::with_capacity(v.len());
v.iter().for_each(|(name, file_obj)| {
let file = to_gist_file(name, file_obj);
files.push(file); files.push(file);
}); });
let gist = GistContent { let gist = GistContent {
files, files,
html_url: resp.get("html_url").unwrap().as_str().unwrap().to_owned(), html_url: resp.get("html_url").unwrap().as_str().unwrap().to_owned(),
@ -244,8 +262,27 @@ impl Data {
self.gists self.gists
.insert(&id, bincode::serialize(&gist).unwrap()) .insert(&id, bincode::serialize(&gist).unwrap())
.unwrap(); .unwrap();
gist
}
};
let gist = if let Some(file_name) = file_name {
let mut files: Vec<GistFile> = Vec::with_capacity(1);
let file = gist
.files
.iter()
.find(|f| f.file_name == file_name)
.unwrap()
.to_owned();
files.push(file);
GistContent {
files,
html_url: gist_url,
}
} else {
gist
};
(id, gist) (id, gist)
} }
} }
}
}

View file

@ -185,8 +185,7 @@ async fn page(path: web::Path<(String, String)>, data: AppData) -> impl Responde
.unwrap() .unwrap()
.href; .href;
if src.contains("gist.github.com") { if src.contains("gist.github.com") {
let gist_id = post_data.get_gist_id(src); let fut = data.get_gist(src.to_owned());
let fut = data.get_gist(gist_id.to_owned());
futs.push(fut); futs.push(fut);
} }
} }

View file

@ -1,4 +1,4 @@
<. let gist_id = data.get_gist_id(src); .> <. let gist_id = crate::data::Data::get_gist_id(src); .>
<. let (_, gist)= gists.as_ref().unwrap().iter().find(|(id, _)| id == gist_id).as_ref().unwrap(); .> <. let (_, gist)= gists.as_ref().unwrap().iter().find(|(id, _)| id == gist_id).as_ref().unwrap(); .>
<div class="gist_container"> <div class="gist_container">
<. for file in &gist.files {.> <. for file in &gist.files {.>