From f171f5b78d87a77312d9237f89736b1e1d86cc2b Mon Sep 17 00:00:00 2001
From: raja <rafaelraja.sitorus@gmail.com>
Date: Fri, 28 Mar 2025 21:54:32 +0800
Subject: [PATCH] Implement list 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 e36f56d..2f86000 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, notification::unsubscribe, notification::receive])
+        .mount("/", routes![notification::subscribe, notification::unsubscribe, notification::receive, notification::list])
     });
 }
diff --git a/src/controller/notification.rs b/src/controller/notification.rs
index 7d947c5..14c0720 100644
--- a/src/controller/notification.rs
+++ b/src/controller/notification.rs
@@ -27,4 +27,12 @@ pub fn subscribe(product_type: &str) -> Result<Json<SubscriberRequest>> {
          Ok(f) => Ok(Json::from(f)),
          Err(e) => Err(e)
      };
+ }
+
+ #[get("/")]
+ pub fn list() -> Result<Json<Vec<String>>> {
+     return match NotificationService::list_messages() {
+         Ok(f) => Ok(Json::from(f)),
+         Err(e) => Err(e)
+     };
  }
\ No newline at end of file
-- 
GitLab