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