From 1ff061ce669b33b645f4077561e9ed7c19fc1195 Mon Sep 17 00:00:00 2001 From: Andrew4Coding <andrewdevitoaryo@gmail.com> Date: Fri, 28 Mar 2025 01:21:02 +0800 Subject: [PATCH] Implement unsubscribe function in Notification controller. --- src/controller/mod.rs | 2 +- src/controller/notification.rs | 8 ++++++++ 2 files changed, 9 insertions(+), 1 deletion(-) diff --git a/src/controller/mod.rs b/src/controller/mod.rs index fcdeefc..df6df1a 100644 --- a/src/controller/mod.rs +++ b/src/controller/mod.rs @@ -7,6 +7,6 @@ pub fn route_stage() -> AdHoc { return AdHoc::on_ignite("Initializing controller routes...", |rocket| async { rocket .mount("/product", routes![product::create, product::list, product::read, product::delete]) - .mount("/notification", routes![notification::subscribe]) + .mount("/notification", routes![notification::subscribe, notification::unsubscribe]) }); } \ No newline at end of file diff --git a/src/controller/notification.rs b/src/controller/notification.rs index 0f18dd2..bb5e3f1 100644 --- a/src/controller/notification.rs +++ b/src/controller/notification.rs @@ -11,4 +11,12 @@ pub fn subscribe(product_type: &str, subscriber: Json<Subscriber>) -> Result<Cre Ok(f) => Ok(Created::new("/").body(Json::from(f))), Err(e) => Err(e) }; +} + +#[post("/unsubscribe/<product_type>?<url>")] +pub fn unsubscribe(product_type: &str, url: &str) -> Result<Json<Subscriber>> { + return match NotificationService::unsubscribe(product_type, url) { + Ok(f) => Ok(Json::from(f)), + Err(e) => Err(e) + }; } \ No newline at end of file -- GitLab