From 8a21f47608db0d9a81f0b6913dcb7c332354967c Mon Sep 17 00:00:00 2001
From: Christian Raphael Heryanto <christian.raphael@ui.ac.id>
Date: Fri, 28 Mar 2025 16:01:28 +0800
Subject: [PATCH] Implement unsubscribe function in Notification controller.

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

diff --git a/src/controller/mod.rs b/src/controller/mod.rs
index 9383800..f76c4f3 100644
--- a/src/controller/mod.rs
+++ b/src/controller/mod.rs
@@ -3,6 +3,9 @@ pub mod notification;
 
 pub fn route_stage() -> AdHoc {
     return AdHoc::on_ignite("Initializing controller routes...", |rocket| async {
-        rocket.mount("/", routes![notification::subscribe])
+        rocket.mount(
+            "/",
+            routes![notification::subscribe, notification::unsubscribe],
+        )
     });
 }
diff --git a/src/controller/notification.rs b/src/controller/notification.rs
index 8e6573f..0677a67 100644
--- a/src/controller/notification.rs
+++ b/src/controller/notification.rs
@@ -12,3 +12,11 @@ pub fn subscribe(product_type: &str) -> Result<Json<SubscriberRequest>> {
         Err(e) => Err(e),
     };
 }
+
+#[get("/unsubscribe/<product_type>")]
+pub fn unsubscribe(product_type: &str) -> Result<Json<SubscriberRequest>> {
+    return match NotificationService::unsubscribe(product_type) {
+        Ok(f) => Ok(Json::from(f)),
+        Err(e) => Err(e),
+    };
+}
-- 
GitLab