From 7eb47c49dc31d348e0ce031545c6730d12197dbb Mon Sep 17 00:00:00 2001 From: vissutagunawan <vglim3653@gmail.com> Date: Thu, 27 Mar 2025 10:11:28 +0700 Subject: [PATCH] Implement subscribe function in Notification controller. --- src/controller/mod.rs | 2 +- src/controller/notification.rs | 11 ++++++++++- 2 files changed, 11 insertions(+), 2 deletions(-) diff --git a/src/controller/mod.rs b/src/controller/mod.rs index 5f156e9..e5f9997 100644 --- a/src/controller/mod.rs +++ b/src/controller/mod.rs @@ -5,6 +5,6 @@ use rocket::fairing::AdHoc; pub fn route_stage() -> AdHoc { return AdHoc::on_ignite("Initializing controller routes...", |rocket| async { rocket - .mount("/", routes![]) + .mount("/", routes![notification::subscribe]) }); } diff --git a/src/controller/notification.rs b/src/controller/notification.rs index 8aed8db..9ef817a 100644 --- a/src/controller/notification.rs +++ b/src/controller/notification.rs @@ -2,4 +2,13 @@ use crate::model::notification::Notification; use crate::model::subscriber::SubscriberRequest; use crate::repository::notification::NotificationRepository; use bambangshop_receiver::Result; - use rocket::serde::json::Json; \ No newline at end of file + use rocket::serde::json::Json; + use crate::service::notification::NotificationService; + +#[get("/subscribe/<product_type>")] +pub fn subscribe(product_type: &str) -> Result<Json<SubscriberRequest>> { + return match NotificationService::subscribe(product_type) { + Ok(f) => Ok(Json::from(f)), + Err(e) => Err(e), + }; +} \ No newline at end of file -- GitLab