From: Felix Ableitner Date: Wed, 8 Apr 2020 11:23:59 +0000 (+0200) Subject: Improve error handling X-Git-Url: http://these/git/%7B%60/feeds/u/%7BpictshareAvatarThumbnail%28?a=commitdiff_plain;h=d2bad5f79e32c124a374a7c36477f779a818be9d;p=lemmy.git Improve error handling --- diff --git a/server/src/apub/puller.rs b/server/src/apub/puller.rs index 5b73dd73..01a70d96 100644 --- a/server/src/apub/puller.rs +++ b/server/src/apub/puller.rs @@ -8,6 +8,7 @@ use crate::settings::Settings; use activitystreams::collection::{OrderedCollection, UnorderedCollection}; use activitystreams::object::Page; use activitystreams::BaseBox; +use diesel::result::Error::NotFound; use diesel::PgConnection; use failure::Error; use isahc::prelude::*; @@ -99,9 +100,9 @@ pub fn fetch_remote_user(apub_id: &str, conn: &PgConnection) -> Result User_::create(conn, &uf)?, + Err(NotFound {}) => User_::create(conn, &uf)?, Ok(u) => User_::update(conn, u.id, &uf)?, + Err(e) => return Err(Error::from(e)), }) } @@ -114,18 +115,18 @@ pub fn fetch_all(conn: &PgConnection) -> Result<(), Error> { for community in &communities { let existing = Community::read_from_actor_id(conn, &community.actor_id); let community_id = match existing { - // TODO: should make sure that this is actually a `NotFound` error - Err(_) => Community::create(conn, community)?.id, + Err(NotFound {}) => Community::create(conn, community)?.id, Ok(c) => Community::update(conn, c.id, community)?.id, + Err(e) => return Err(Error::from(e)), }; let mut posts = fetch_remote_community_posts(instance, &community.name, conn)?; for post_ in &mut posts { post_.community_id = community_id; let existing = Post::read_from_apub_id(conn, &post_.ap_id); match existing { - // TODO: should make sure that this is actually a `NotFound` error - Err(_) => Post::create(conn, post_)?, + Err(NotFound {}) => Post::create(conn, post_)?, Ok(p) => Post::update(conn, p.id, post_)?, + Err(e) => return Err(Error::from(e)), }; } }