From 2dcb71709c618ffeb91d916e1739a4eb1fc31f1e Mon Sep 17 00:00:00 2001
From: dzak27567 <fadhlurohmandzaki@gmail.com>
Date: Thu, 27 Mar 2025 14:04:51 +0700
Subject: [PATCH] Implement unsubscribe 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 63b8872..dfcb943 100644
--- a/src/controller/mod.rs
+++ b/src/controller/mod.rs
@@ -3,6 +3,7 @@ pub mod notification;
 pub fn route_stage() -> AdHoc {
     return AdHoc::on_ignite("Initializing controller routes...", |rocket| async {
         rocket
-            .mount("/", routes![notification::subscribe])
+        .mount("/", routes![notification::subscribe, notification::unsubscribe])
     });
 }
+
diff --git a/src/controller/notification.rs b/src/controller/notification.rs
index ca866c4..af4edbb 100644
--- a/src/controller/notification.rs
+++ b/src/controller/notification.rs
@@ -11,4 +11,12 @@ pub fn subscribe(product_type: &str) -> Result<Json<SubscriberRequest>> {
         Ok(r) => Ok(Json::from(r)),
         Err(e) => Err(e)
     };
+}
+
+#[get("/unsubscribe/<product_type>")]
+pub fn unsubscribe(product_type: &str) -> Result<Json<SubscriberRequest>> {
+    return match NotificationService::unsubscribe(product_type) {
+        Ok(r) => Ok(Json::from(r)),
+        Err(e) => Err(e)
+    };
 }
\ No newline at end of file
-- 
GitLab