mirror of
https://gitlab.com/comunic/comunicapiv3
synced 2025-06-20 16:35:17 +00:00
Can get the list of members of a call
This commit is contained in:
@ -4,6 +4,7 @@
|
||||
|
||||
use std::collections::HashMap;
|
||||
|
||||
use crate::api_data::call_member_info::CallMemberInfo;
|
||||
use crate::api_data::joined_call_message::JoinedCallMessage;
|
||||
use crate::api_data::user_calls_config::UserCallsConfig;
|
||||
use crate::controllers::routes::RequestResult;
|
||||
@ -61,6 +62,23 @@ pub fn join_call(r: &mut UserWsRequestHandler) -> RequestResult {
|
||||
Ok(())
|
||||
}
|
||||
|
||||
/// Get the list of members of a call
|
||||
pub fn get_members_list(r: &mut UserWsRequestHandler) -> RequestResult {
|
||||
let conv_id = r.post_call_id("callID")?;
|
||||
let mut list = vec![];
|
||||
|
||||
user_ws_controller::foreach_connection(|conn| {
|
||||
if conn.is_having_call_with_conversation(&conv_id) {
|
||||
list.push(CallMemberInfo::new(&conn.user_id, &conn.active_call.as_ref().unwrap()));
|
||||
}
|
||||
|
||||
Ok(())
|
||||
})?;
|
||||
|
||||
r.set_response(list)
|
||||
}
|
||||
|
||||
|
||||
/// Events handler
|
||||
pub fn handle_event(e: &events_helper::Event) -> Res {
|
||||
match e {
|
||||
|
@ -560,6 +560,16 @@ pub fn disconnect_user_from_all_sockets(user_id: &UserID) -> Res {
|
||||
Ok(())
|
||||
}
|
||||
|
||||
/// Do something with all active connections
|
||||
pub fn foreach_connection<F>(mut f: F) -> Res
|
||||
where F: FnMut(&UserWsConnection) -> Res {
|
||||
for conn in get_ws_connections_list().lock().unwrap().iter() {
|
||||
f(conn)?;
|
||||
}
|
||||
|
||||
Ok(())
|
||||
}
|
||||
|
||||
/// Events handler
|
||||
pub fn handle_event(e: &events_helper::Event) -> Res {
|
||||
match e {
|
||||
|
@ -40,6 +40,7 @@ pub fn get_user_ws_routes() -> Vec<UserWsRoute> {
|
||||
// Calls controller
|
||||
UserWsRoute::new("calls/config", calls_controller::get_config),
|
||||
UserWsRoute::new("calls/join", calls_controller::join_call),
|
||||
UserWsRoute::new("calls/members", calls_controller::get_members_list),
|
||||
]
|
||||
}
|
||||
|
||||
|
Reference in New Issue
Block a user