diff options
author | Vika <vika@fireburn.ru> | 2021-05-04 21:14:31 +0300 |
---|---|---|
committer | Vika <vika@fireburn.ru> | 2021-05-04 21:14:31 +0300 |
commit | 1a78c48bd86ff72cc9c7020e69ec9a77302a2f8b (patch) | |
tree | 7a0bbd3f520d0eecdb8bcadc23e62f7f1f5757f5 /src/micropub/post.rs | |
parent | b0763ade5d16a68654256b4cbfd029210981970d (diff) | |
download | kittybox-1a78c48bd86ff72cc9c7020e69ec9a77302a2f8b.tar.zst |
Made StorageErrors directly convertible into Micropub JSON responses
Diffstat (limited to 'src/micropub/post.rs')
-rw-r--r-- | src/micropub/post.rs | 6 |
1 files changed, 3 insertions, 3 deletions
diff --git a/src/micropub/post.rs b/src/micropub/post.rs index 680f242..7ec3566 100644 --- a/src/micropub/post.rs +++ b/src/micropub/post.rs @@ -158,7 +158,7 @@ async fn new_post<S: Storage>(req: Request<ApplicationState<S>>, body: serde_jso Ok(exists) => if exists { return error_json!(409, "already_exists", format!("A post with the exact same UID already exists in the database: {}", uid)) }, - Err(err) => return error_json!(500, "database_error", err) + Err(err) => return Ok(err.into()) } // WARNING: WRITE BOUNDARY //let mut storage = RwLockUpgradableReadGuard::upgrade(storage).await; @@ -225,7 +225,7 @@ async fn process_json<S: Storage>(req: Request<ApplicationState<S>>, body: serde return error_json!(401, "insufficient_scope", "You need a `delete` scope to delete posts.") } if let Err(error) = req.state().storage.delete_post(&url).await { - return error_json!(500, "database_error", error) + return Ok(error.into()) } return Ok(Response::builder(200).build()); }, @@ -234,7 +234,7 @@ async fn process_json<S: Storage>(req: Request<ApplicationState<S>>, body: serde return error_json!(401, "insufficient_scope", "You need an `update` scope to update posts.") } if let Err(error) = req.state().storage.update_post(&url, body.clone()).await { - return error_json!(500, "database_error", error) + return Ok(error.into()) } else { return Ok(Response::builder(204).build()) } |