From a65f2b1db642e62ddb1ee55c70284d64174542a3 Mon Sep 17 00:00:00 2001
From: noQils <daffaaqilmahmud@gmail.com>
Date: Thu, 27 Mar 2025 16:16:48 +0700
Subject: [PATCH] Implement the receive function in Notification controller.

---
 src/controller/mod.rs          | 3 ++-
 src/controller/notification.rs | 8 ++++++++
 2 files changed, 10 insertions(+), 1 deletion(-)

diff --git a/src/controller/mod.rs b/src/controller/mod.rs
index 80195c4..b1d8df3 100644
--- a/src/controller/mod.rs
+++ b/src/controller/mod.rs
@@ -5,6 +5,7 @@ use rocket::fairing::AdHoc;
 pub fn route_stage() -> AdHoc {
     return AdHoc::on_ignite("Initializing controller routes...", |rocket| async {
         rocket
-            .mount("/", routes![notification::subscribe, notification::unsubscribe])
+            .mount("/", routes![notification::subscribe, notification::unsubscribe,
+            notification::receive])
     });
 }
diff --git a/src/controller/notification.rs b/src/controller/notification.rs
index f65f0f9..bc64944 100644
--- a/src/controller/notification.rs
+++ b/src/controller/notification.rs
@@ -21,3 +21,11 @@ pub fn unsubscribe(product_type: &str) -> Result<Json<SubscriberRequest>> {
     };  
 }  
 
+#[post("/receive", data = "<notification>")]  
+pub fn receive(notification: Json<Notification>) -> Result<Json<Notification>> {  
+    return match NotificationService::receive_notification(notification.into_inner()) {  
+        Ok(f) => Ok(Json::from(f)),  
+        Err(e) => Err(e)  
+    };  
+}  
+
-- 
GitLab