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