From 91dd5f1d9dd730157cf164234a33c7010e007367 Mon Sep 17 00:00:00 2001 From: raja <rafaelraja.sitorus@gmail.com> Date: Fri, 28 Mar 2025 21:48:38 +0800 Subject: [PATCH] Implement unsubscribe function in Notification controller. --- src/controller/mod.rs | 2 +- src/controller/notification.rs | 10 +++++++++- 2 files changed, 10 insertions(+), 2 deletions(-) diff --git a/src/controller/mod.rs b/src/controller/mod.rs index a977435..2a921fb 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]) + .mount("/", routes![notification::subscribe, notification::unsubscribe]) }); } diff --git a/src/controller/notification.rs b/src/controller/notification.rs index 2bb89f1..cb6c658 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(f) => Ok(Json::from(f)), Err(e) => Err(e) }; -} \ No newline at end of file +} + +#[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) + }; + } \ No newline at end of file -- GitLab