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