diff --git a/src/endpoints/admin/quest/get_quest_users.rs b/src/endpoints/admin/quest/get_quest_users.rs index a04636f..40ad5e7 100644 --- a/src/endpoints/admin/quest/get_quest_users.rs +++ b/src/endpoints/admin/quest/get_quest_users.rs @@ -1,5 +1,6 @@ use crate::middleware::auth::auth_middleware; use crate::utils::verify_quest_auth; +use crate::utils::to_hex; use crate::{ models::{AppState, CompletedTaskDocument, QuestDocument, QuestTaskDocument}, utils::get_error, @@ -14,6 +15,7 @@ use futures::TryStreamExt; use mongodb::bson::doc; use serde::Deserialize; use serde_json::json; +use starknet::core::types::FieldElement; use std::collections::HashSet; use std::sync::Arc; @@ -79,7 +81,10 @@ pub async fn get_quest_users_handler( .map(|task: CompletedTaskDocument| task.address().to_string()) .collect(); - let users_list: Vec = user_set.into_iter().collect(); + let users_list: Vec = user_set + .into_iter() + .filter_map(|addr| FieldElement::from_dec_str(&addr).ok().map(to_hex)) + .collect(); users_list } Err(e) => return get_error(format!("Error processing completed tasks: {}", e)), diff --git a/src/models.rs b/src/models.rs index 5840294..64413f0 100644 --- a/src/models.rs +++ b/src/models.rs @@ -47,8 +47,19 @@ pub_struct!(Debug, Serialize, Deserialize; QuestDocument { expired: Option, experience: i64, start_time: i64, + banner: Option }); +#[derive(Debug, Serialize, Deserialize)] +pub struct Banner { + tag: String, + title: String, + description: String, + cta: String, + href: String, + image: String, +} + pub_struct!(Debug, Serialize, Deserialize; QuestInsertDocument { id: u32, name: String,