From b97272438ed2ae66162ecc59ce9fae21c5f3bbcc Mon Sep 17 00:00:00 2001
From: Andrew4Coding <andrewdevitoaryo@gmail.com>
Date: Fri, 28 Mar 2025 13:43:56 +0800
Subject: [PATCH] Implement the receive function in Notification controller

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

diff --git a/src/controller/mod.rs b/src/controller/mod.rs
index 782fc65..e42fb65 100644
--- a/src/controller/mod.rs
+++ b/src/controller/mod.rs
@@ -4,6 +4,6 @@ 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 1bf721a..93ca2c6 100644
--- a/src/controller/notification.rs
+++ b/src/controller/notification.rs
@@ -19,4 +19,12 @@ pub fn unsubscribe(product_type: &str) -> Result<Json<SubscriberRequest>> {
         Ok(f) => Ok(Json::from(f)),
         Err(e) => Err(e)
     }
+}
+
+#[post("/receive", format = "application/json", 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)
+    }
 }
\ No newline at end of file
-- 
GitLab