From 0640f68f9cbfc680ceb1186643e920d6ff7dcd42 Mon Sep 17 00:00:00 2001 From: Paul Makles <paulmakles@gmail.com> Date: Wed, 30 Dec 2020 15:34:32 +0000 Subject: [PATCH] Add notifications to remaining routes. --- src/routes/users/block_user.rs | 45 ++++++++++++++++++++++++++++--- src/routes/users/remove_friend.rs | 24 +++++++++++++++-- src/routes/users/unblock_user.rs | 29 ++++++++++++++++++-- 3 files changed, 91 insertions(+), 7 deletions(-) diff --git a/src/routes/users/block_user.rs b/src/routes/users/block_user.rs index e7f1266..4f86bf9 100644 --- a/src/routes/users/block_user.rs +++ b/src/routes/users/block_user.rs @@ -1,4 +1,4 @@ -use crate::util::result::Result; +use crate::{notifications::{events::ClientboundNotification, hive}, util::result::Result}; use crate::{ database::entities::RelationshipStatus, database::entities::User, database::get_collection, database::guards::reference::Ref, database::permissions::get_relationship, util::result::Error, @@ -32,6 +32,12 @@ pub async fn req(user: User, target: Ref) -> Result<JsonValue> { with: "user", })?; + ClientboundNotification::UserRelationship { + id: user.id.clone(), + user: target.id.clone(), + status: RelationshipStatus::Blocked + }.publish(user.id.clone()).await.ok(); + Ok(json!({ "status": "Blocked" })) } RelationshipStatus::None => { @@ -65,7 +71,25 @@ pub async fn req(user: User, target: Ref) -> Result<JsonValue> { None ) ) { - Ok(_) => Ok(json!({ "status": "Blocked" })), + Ok(_) => { + try_join!( + ClientboundNotification::UserRelationship { + id: user.id.clone(), + user: target.id.clone(), + status: RelationshipStatus::Blocked + }.publish(user.id.clone()), + ClientboundNotification::UserRelationship { + id: target.id.clone(), + user: user.id.clone(), + status: RelationshipStatus::BlockedOther + }.publish(target.id.clone()) + ).ok(); + + hive::subscribe_if_exists(user.id.clone(), target.id.clone()).ok(); + hive::subscribe_if_exists(target.id.clone(), user.id.clone()).ok(); + + Ok(json!({ "status": "Blocked" })) + }, Err(_) => Err(Error::DatabaseError { operation: "update_one", with: "user", @@ -101,7 +125,22 @@ pub async fn req(user: User, target: Ref) -> Result<JsonValue> { None ) ) { - Ok(_) => Ok(json!({ "status": "Blocked" })), + Ok(_) => { + try_join!( + ClientboundNotification::UserRelationship { + id: user.id.clone(), + user: target.id.clone(), + status: RelationshipStatus::Blocked + }.publish(user.id.clone()), + ClientboundNotification::UserRelationship { + id: target.id.clone(), + user: user.id.clone(), + status: RelationshipStatus::BlockedOther + }.publish(target.id.clone()) + ).ok(); + + Ok(json!({ "status": "Blocked" })) + }, Err(_) => Err(Error::DatabaseError { operation: "update_one", with: "user", diff --git a/src/routes/users/remove_friend.rs b/src/routes/users/remove_friend.rs index 468a6be..97f6f20 100644 --- a/src/routes/users/remove_friend.rs +++ b/src/routes/users/remove_friend.rs @@ -1,4 +1,4 @@ -use crate::util::result::Result; +use crate::{notifications::{hive, events::ClientboundNotification}, util::result::Result}; use crate::{ database::entities::RelationshipStatus, database::entities::User, database::get_collection, database::guards::reference::Ref, database::permissions::get_relationship, util::result::Error, @@ -6,6 +6,7 @@ use crate::{ use futures::try_join; use mongodb::bson::doc; use rocket_contrib::json::JsonValue; +use hive_pubsub::PubSub; #[delete("/<target>/friend")] pub async fn req(user: User, target: Ref) -> Result<JsonValue> { @@ -47,7 +48,26 @@ pub async fn req(user: User, target: Ref) -> Result<JsonValue> { None ) ) { - Ok(_) => Ok(json!({ "status": "None" })), + Ok(_) => { + try_join!( + ClientboundNotification::UserRelationship { + id: user.id.clone(), + user: target.id.clone(), + status: RelationshipStatus::None + }.publish(user.id.clone()), + ClientboundNotification::UserRelationship { + id: target.id.clone(), + user: user.id.clone(), + status: RelationshipStatus::None + }.publish(target.id.clone()) + ).ok(); + + let hive = hive::get_hive(); + hive.unsubscribe(&user.id, &target.id).ok(); + hive.unsubscribe(&target.id, &user.id).ok(); + + Ok(json!({ "status": "None" })) + }, Err(_) => Err(Error::DatabaseError { operation: "update_one", with: "user", diff --git a/src/routes/users/unblock_user.rs b/src/routes/users/unblock_user.rs index 585170f..68ebec2 100644 --- a/src/routes/users/unblock_user.rs +++ b/src/routes/users/unblock_user.rs @@ -1,4 +1,4 @@ -use crate::util::result::Result; +use crate::{notifications::{events::ClientboundNotification, hive}, util::result::Result}; use crate::{ database::entities::RelationshipStatus, database::entities::User, database::get_collection, database::guards::reference::Ref, database::permissions::get_relationship, util::result::Error, @@ -39,6 +39,12 @@ pub async fn req(user: User, target: Ref) -> Result<JsonValue> { with: "user", })?; + ClientboundNotification::UserRelationship { + id: user.id.clone(), + user: target.id.clone(), + status: RelationshipStatus::BlockedOther + }.publish(user.id.clone()).await.ok(); + Ok(json!({ "status": "BlockedOther" })) } RelationshipStatus::BlockedOther => { @@ -70,7 +76,26 @@ pub async fn req(user: User, target: Ref) -> Result<JsonValue> { None ) ) { - Ok(_) => Ok(json!({ "status": "None" })), + Ok(_) => { + try_join!( + ClientboundNotification::UserRelationship { + id: user.id.clone(), + user: target.id.clone(), + status: RelationshipStatus::None + }.publish(user.id.clone()), + ClientboundNotification::UserRelationship { + id: target.id.clone(), + user: user.id.clone(), + status: RelationshipStatus::None + }.publish(target.id.clone()) + ).ok(); + + let hive = hive::get_hive(); + hive.unsubscribe(&user.id, &target.id).ok(); + hive.unsubscribe(&target.id, &user.id).ok(); + + Ok(json!({ "status": "None" })) + }, Err(_) => Err(Error::DatabaseError { operation: "update_one", with: "user", -- GitLab