FS-10802: [mod_conference] Convert conference floor to id based #resolve
This commit is contained in:
parent
2e1f828363
commit
2b5b9341e7
|
@ -321,7 +321,7 @@ switch_status_t conference_api_sub_mute(conference_member_t *member, switch_stre
|
||||||
if (!(data) || !strstr((char *) data, "quiet")) {
|
if (!(data) || !strstr((char *) data, "quiet")) {
|
||||||
conference_utils_member_set_flag(member, MFLAG_INDICATE_MUTE);
|
conference_utils_member_set_flag(member, MFLAG_INDICATE_MUTE);
|
||||||
}
|
}
|
||||||
member->score_iir = 0;
|
conference_member_set_score_iir(member, 0);
|
||||||
|
|
||||||
if (stream != NULL) {
|
if (stream != NULL) {
|
||||||
stream->write_function(stream, "+OK mute %u\n", member->id);
|
stream->write_function(stream, "+OK mute %u\n", member->id);
|
||||||
|
@ -2046,26 +2046,22 @@ switch_status_t conference_api_sub_floor(conference_member_t *member, switch_str
|
||||||
if (member == NULL)
|
if (member == NULL)
|
||||||
return SWITCH_STATUS_GENERR;
|
return SWITCH_STATUS_GENERR;
|
||||||
|
|
||||||
switch_mutex_lock(member->conference->mutex);
|
if (member->conference->floor_holder == member->id) {
|
||||||
|
conference_member_set_floor_holder(member->conference, NULL, 0);
|
||||||
if (member->conference->floor_holder == member) {
|
|
||||||
conference_member_set_floor_holder(member->conference, NULL);
|
|
||||||
if (stream != NULL) {
|
if (stream != NULL) {
|
||||||
stream->write_function(stream, "+OK floor none\n");
|
stream->write_function(stream, "+OK floor none\n");
|
||||||
}
|
}
|
||||||
} else if (member->conference->floor_holder == NULL) {
|
} else if (member->conference->floor_holder == 0) {
|
||||||
conference_member_set_floor_holder(member->conference, member);
|
conference_member_set_floor_holder(member->conference, member, 0);
|
||||||
if (stream != NULL) {
|
if (stream != NULL) {
|
||||||
stream->write_function(stream, "+OK floor %u\n", member->id);
|
stream->write_function(stream, "+OK floor %u\n", member->id);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if (stream != NULL) {
|
if (stream != NULL) {
|
||||||
stream->write_function(stream, "-ERR floor is held by %u\n", member->conference->floor_holder->id);
|
stream->write_function(stream, "-ERR floor is held by %u\n", member->conference->floor_holder);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
switch_mutex_unlock(member->conference->mutex);
|
|
||||||
|
|
||||||
return SWITCH_STATUS_SUCCESS;
|
return SWITCH_STATUS_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2356,8 +2352,6 @@ switch_status_t conference_api_sub_vid_floor(conference_member_t *member, switch
|
||||||
return SWITCH_STATUS_FALSE;
|
return SWITCH_STATUS_FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
switch_mutex_lock(member->conference->mutex);
|
|
||||||
|
|
||||||
if (data && switch_stristr("force", (char *) data)) {
|
if (data && switch_stristr("force", (char *) data)) {
|
||||||
force = 1;
|
force = 1;
|
||||||
}
|
}
|
||||||
|
@ -2365,7 +2359,7 @@ switch_status_t conference_api_sub_vid_floor(conference_member_t *member, switch
|
||||||
if (member->conference->video_floor_holder == member->id && conference_utils_test_flag(member->conference, CFLAG_VID_FLOOR_LOCK)) {
|
if (member->conference->video_floor_holder == member->id && conference_utils_test_flag(member->conference, CFLAG_VID_FLOOR_LOCK)) {
|
||||||
conference_utils_clear_flag(member->conference, CFLAG_VID_FLOOR_LOCK);
|
conference_utils_clear_flag(member->conference, CFLAG_VID_FLOOR_LOCK);
|
||||||
|
|
||||||
conference_member_set_floor_holder(member->conference, member);
|
conference_member_set_floor_holder(member->conference, member, 0);
|
||||||
if (stream == NULL) {
|
if (stream == NULL) {
|
||||||
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_INFO, "conference %s OK video floor auto\n", member->conference->name);
|
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_INFO, "conference %s OK video floor auto\n", member->conference->name);
|
||||||
} else {
|
} else {
|
||||||
|
@ -2392,8 +2386,6 @@ switch_status_t conference_api_sub_vid_floor(conference_member_t *member, switch
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
switch_mutex_unlock(member->conference->mutex);
|
|
||||||
|
|
||||||
return SWITCH_STATUS_SUCCESS;
|
return SWITCH_STATUS_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2911,7 +2903,12 @@ void _conference_api_sub_relate_clear_member_relationship(conference_obj_t *conf
|
||||||
if (conference_utils_member_test_flag(other_member, MFLAG_RECEIVING_VIDEO)) {
|
if (conference_utils_member_test_flag(other_member, MFLAG_RECEIVING_VIDEO)) {
|
||||||
conference_utils_member_clear_flag(other_member, MFLAG_RECEIVING_VIDEO);
|
conference_utils_member_clear_flag(other_member, MFLAG_RECEIVING_VIDEO);
|
||||||
if (conference->floor_holder) {
|
if (conference->floor_holder) {
|
||||||
switch_core_session_request_video_refresh(conference->floor_holder->session);
|
conference_member_t *omember = NULL;
|
||||||
|
|
||||||
|
if ((omember = conference_member_get(member->conference, conference->floor_holder))) {
|
||||||
|
switch_core_session_request_video_refresh(omember->session);
|
||||||
|
switch_thread_rwlock_unlock(omember->rwlock);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
switch_thread_rwlock_unlock(other_member->rwlock);
|
switch_thread_rwlock_unlock(other_member->rwlock);
|
||||||
|
|
|
@ -910,9 +910,8 @@ void *SWITCH_THREAD_FUNC conference_loop_input(switch_thread_t *thread, void *ob
|
||||||
}
|
}
|
||||||
conference_utils_member_clear_flag_locked(member, MFLAG_TALKING);
|
conference_utils_member_clear_flag_locked(member, MFLAG_TALKING);
|
||||||
conference_member_update_status_field(member);
|
conference_member_update_status_field(member);
|
||||||
member->score_iir = 0;
|
conference_member_set_score_iir(member, 0);
|
||||||
member->floor_packets = 0;
|
member->floor_packets = 0;
|
||||||
|
|
||||||
stop_talking_handler(member);
|
stop_talking_handler(member);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -926,7 +925,8 @@ void *SWITCH_THREAD_FUNC conference_loop_input(switch_thread_t *thread, void *ob
|
||||||
uint32_t energy = 0, i = 0, samples = 0, j = 0;
|
uint32_t energy = 0, i = 0, samples = 0, j = 0;
|
||||||
int16_t *data;
|
int16_t *data;
|
||||||
int gate_check = 0;
|
int gate_check = 0;
|
||||||
|
int score_iir = 0;
|
||||||
|
|
||||||
data = read_frame->data;
|
data = read_frame->data;
|
||||||
member->score = 0;
|
member->score = 0;
|
||||||
|
|
||||||
|
@ -953,11 +953,13 @@ void *SWITCH_THREAD_FUNC conference_loop_input(switch_thread_t *thread, void *ob
|
||||||
switch_agc_feed(member->agc, (int16_t *)read_frame->data, (read_frame->datalen / 2) * member->conference->channels, 1);
|
switch_agc_feed(member->agc, (int16_t *)read_frame->data, (read_frame->datalen / 2) * member->conference->channels, 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
member->score_iir = (int) (((1.0 - SCORE_DECAY) * (float) member->score) + (SCORE_DECAY * (float) member->score_iir));
|
score_iir = (int) (((1.0 - SCORE_DECAY) * (float) member->score) + (SCORE_DECAY * (float) member->score_iir));
|
||||||
|
|
||||||
if (member->score_iir > SCORE_MAX_IIR) {
|
if (score_iir > SCORE_MAX_IIR) {
|
||||||
member->score_iir = SCORE_MAX_IIR;
|
score_iir = SCORE_MAX_IIR;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
conference_member_set_score_iir(member, score_iir);
|
||||||
|
|
||||||
if (member->auto_energy_level && !conference_utils_member_test_flag(member, MFLAG_TALKING)) {
|
if (member->auto_energy_level && !conference_utils_member_test_flag(member, MFLAG_TALKING)) {
|
||||||
if (++member->auto_energy_track >= (1000 / member->conference->interval * member->conference->auto_energy_sec)) {
|
if (++member->auto_energy_track >= (1000 / member->conference->interval * member->conference->auto_energy_sec)) {
|
||||||
|
@ -1091,7 +1093,7 @@ void *SWITCH_THREAD_FUNC conference_loop_input(switch_thread_t *thread, void *ob
|
||||||
hangover_hits--;
|
hangover_hits--;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (member == member->conference->floor_holder) {
|
if (member->id == member->conference->floor_holder) {
|
||||||
member->floor_packets++;
|
member->floor_packets++;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1164,7 +1166,7 @@ void *SWITCH_THREAD_FUNC conference_loop_input(switch_thread_t *thread, void *ob
|
||||||
|
|
||||||
member->last_score = member->score;
|
member->last_score = member->score;
|
||||||
|
|
||||||
if (member == member->conference->floor_holder) {
|
if (member->id == member->conference->floor_holder) {
|
||||||
if (member->id != member->conference->video_floor_holder &&
|
if (member->id != member->conference->video_floor_holder &&
|
||||||
(member->floor_packets > member->conference->video_floor_packets || member->energy_level == 0)) {
|
(member->floor_packets > member->conference->video_floor_packets || member->energy_level == 0)) {
|
||||||
conference_video_set_floor_holder(member->conference, member, SWITCH_FALSE);
|
conference_video_set_floor_holder(member->conference, member, SWITCH_FALSE);
|
||||||
|
|
|
@ -137,7 +137,7 @@ void conference_member_update_status_field(conference_member_t *member)
|
||||||
str = "MUTE";
|
str = "MUTE";
|
||||||
} else if (switch_channel_test_flag(member->channel, CF_HOLD)) {
|
} else if (switch_channel_test_flag(member->channel, CF_HOLD)) {
|
||||||
str = "HOLD";
|
str = "HOLD";
|
||||||
} else if (member == member->conference->floor_holder) {
|
} else if (member->id == member->conference->floor_holder) {
|
||||||
if (conference_utils_member_test_flag(member, MFLAG_TALKING)) {
|
if (conference_utils_member_test_flag(member, MFLAG_TALKING)) {
|
||||||
str = "TALKING (FLOOR)";
|
str = "TALKING (FLOOR)";
|
||||||
} else {
|
} else {
|
||||||
|
@ -169,7 +169,7 @@ void conference_member_update_status_field(conference_member_t *member)
|
||||||
cJSON_AddItemToObject(audio, "deaf", cJSON_CreateBool(!conference_utils_member_test_flag(member, MFLAG_CAN_HEAR)));
|
cJSON_AddItemToObject(audio, "deaf", cJSON_CreateBool(!conference_utils_member_test_flag(member, MFLAG_CAN_HEAR)));
|
||||||
cJSON_AddItemToObject(audio, "onHold", cJSON_CreateBool(switch_channel_test_flag(member->channel, CF_HOLD)));
|
cJSON_AddItemToObject(audio, "onHold", cJSON_CreateBool(switch_channel_test_flag(member->channel, CF_HOLD)));
|
||||||
cJSON_AddItemToObject(audio, "talking", cJSON_CreateBool(conference_utils_member_test_flag(member, MFLAG_TALKING)));
|
cJSON_AddItemToObject(audio, "talking", cJSON_CreateBool(conference_utils_member_test_flag(member, MFLAG_TALKING)));
|
||||||
cJSON_AddItemToObject(audio, "floor", cJSON_CreateBool(member == member->conference->floor_holder));
|
cJSON_AddItemToObject(audio, "floor", cJSON_CreateBool(member->id == member->conference->floor_holder));
|
||||||
cJSON_AddItemToObject(audio, "energyScore", cJSON_CreateNumber(member->score));
|
cJSON_AddItemToObject(audio, "energyScore", cJSON_CreateNumber(member->score));
|
||||||
cJSON_AddItemToObject(json, "audio", audio);
|
cJSON_AddItemToObject(json, "audio", audio);
|
||||||
|
|
||||||
|
@ -237,7 +237,7 @@ switch_status_t conference_member_add_event_data(conference_member_t *member, sw
|
||||||
|
|
||||||
if (member->conference) {
|
if (member->conference) {
|
||||||
status = conference_event_add_data(member->conference, event);
|
status = conference_event_add_data(member->conference, event);
|
||||||
switch_event_add_header(event, SWITCH_STACK_BOTTOM, "Floor", "%s", (member == member->conference->floor_holder) ? "true" : "false" );
|
switch_event_add_header(event, SWITCH_STACK_BOTTOM, "Floor", "%s", (member->id == member->conference->floor_holder) ? "true" : "false" );
|
||||||
}
|
}
|
||||||
|
|
||||||
if (member->session) {
|
if (member->session) {
|
||||||
|
@ -629,6 +629,14 @@ conference_relationship_t *conference_member_add_relationship(conference_member_
|
||||||
return rel;
|
return rel;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void conference_member_set_score_iir(conference_member_t *member, uint32_t score)
|
||||||
|
{
|
||||||
|
member->score_iir = score;
|
||||||
|
if (member->id == member->conference->floor_holder) {
|
||||||
|
member->conference->floor_holder_score_iir = score;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/* Remove a custom relationship from a member */
|
/* Remove a custom relationship from a member */
|
||||||
switch_status_t conference_member_del_relationship(conference_member_t *member, uint32_t id)
|
switch_status_t conference_member_del_relationship(conference_member_t *member, uint32_t id)
|
||||||
{
|
{
|
||||||
|
@ -703,7 +711,7 @@ switch_status_t conference_member_add(conference_obj_t *conference, conference_m
|
||||||
member->max_energy_level = conference->max_energy_level;
|
member->max_energy_level = conference->max_energy_level;
|
||||||
member->max_energy_hit_trigger = conference->max_energy_hit_trigger;
|
member->max_energy_hit_trigger = conference->max_energy_hit_trigger;
|
||||||
member->burst_mute_count = conference->burst_mute_count;;
|
member->burst_mute_count = conference->burst_mute_count;;
|
||||||
member->score_iir = 0;
|
conference_member_set_score_iir(member, 0);
|
||||||
member->verbose_events = conference->verbose_events;
|
member->verbose_events = conference->verbose_events;
|
||||||
member->video_layer_id = -1;
|
member->video_layer_id = -1;
|
||||||
member->layer_timeout = DEFAULT_LAYER_TIMEOUT;
|
member->layer_timeout = DEFAULT_LAYER_TIMEOUT;
|
||||||
|
@ -1049,43 +1057,53 @@ switch_status_t conference_member_add(conference_obj_t *conference, conference_m
|
||||||
return status;
|
return status;
|
||||||
}
|
}
|
||||||
|
|
||||||
void conference_member_set_floor_holder(conference_obj_t *conference, conference_member_t *member)
|
void conference_member_set_floor_holder(conference_obj_t *conference, conference_member_t *member, uint32_t id)
|
||||||
{
|
{
|
||||||
switch_event_t *event;
|
switch_event_t *event;
|
||||||
conference_member_t *old_member = NULL;
|
int old_member = 0;
|
||||||
int old_id = 0;
|
uint32_t old_id = 0;
|
||||||
|
conference_member_t *lmember = NULL;
|
||||||
|
|
||||||
|
conference->floor_holder_score_iir = 0;
|
||||||
|
|
||||||
if (conference->floor_holder) {
|
if (conference->floor_holder) {
|
||||||
if (conference->floor_holder == member) {
|
if ((member && conference->floor_holder == member->id) || (id && conference->floor_holder == id)) {
|
||||||
return;
|
goto end;
|
||||||
} else {
|
} else {
|
||||||
old_member = conference->floor_holder;
|
old_member = conference->floor_holder;
|
||||||
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_DEBUG1, "Dropping floor %s\n",
|
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_DEBUG1, "Dropping floor %d\n", old_member);
|
||||||
switch_channel_get_name(old_member->channel));
|
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
switch_mutex_lock(conference->mutex);
|
if (!member && id) {
|
||||||
|
member = lmember = conference_member_get(conference, id);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
if (member) {
|
if (member) {
|
||||||
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_DEBUG1, "Adding floor %s\n",
|
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_DEBUG1, "Adding floor %s\n",
|
||||||
switch_channel_get_name(member->channel));
|
switch_channel_get_name(member->channel));
|
||||||
|
|
||||||
conference->floor_holder = member;
|
conference->floor_holder = member->id;
|
||||||
|
conference_member_set_score_iir(member, 0);
|
||||||
conference_member_update_status_field(member);
|
conference_member_update_status_field(member);
|
||||||
} else {
|
} else {
|
||||||
conference->floor_holder = NULL;
|
conference->floor_holder = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
if (old_member) {
|
if (old_member) {
|
||||||
old_id = old_member->id;
|
conference_member_t *omember = NULL;
|
||||||
conference_member_update_status_field(old_member);
|
|
||||||
old_member->floor_packets = 0;
|
if ((omember = conference_member_get(conference, old_member))) {
|
||||||
|
old_id = old_member;
|
||||||
|
conference_member_update_status_field(omember);
|
||||||
|
omember->floor_packets = 0;
|
||||||
|
switch_thread_rwlock_unlock(omember->rwlock);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
conference_utils_set_flag(conference, CFLAG_FLOOR_CHANGE);
|
conference_utils_set_flag(conference, CFLAG_FLOOR_CHANGE);
|
||||||
switch_mutex_unlock(conference->mutex);
|
|
||||||
|
|
||||||
if (test_eflag(conference, EFLAG_FLOOR_CHANGE)) {
|
if (test_eflag(conference, EFLAG_FLOOR_CHANGE)) {
|
||||||
switch_event_create_subclass(&event, SWITCH_EVENT_CUSTOM, CONF_EVENT_MAINT);
|
switch_event_create_subclass(&event, SWITCH_EVENT_CUSTOM, CONF_EVENT_MAINT);
|
||||||
|
@ -1098,8 +1116,8 @@ void conference_member_set_floor_holder(conference_obj_t *conference, conference
|
||||||
}
|
}
|
||||||
|
|
||||||
if (conference->floor_holder) {
|
if (conference->floor_holder) {
|
||||||
conference_member_add_event_data(conference->floor_holder, event);
|
conference_member_add_event_data(member, event);
|
||||||
switch_event_add_header(event, SWITCH_STACK_BOTTOM, "New-ID", "%d", conference->floor_holder->id);
|
switch_event_add_header(event, SWITCH_STACK_BOTTOM, "New-ID", "%d", conference->floor_holder);
|
||||||
} else {
|
} else {
|
||||||
switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "New-ID", "none");
|
switch_event_add_header_string(event, SWITCH_STACK_BOTTOM, "New-ID", "none");
|
||||||
}
|
}
|
||||||
|
@ -1107,6 +1125,11 @@ void conference_member_set_floor_holder(conference_obj_t *conference, conference
|
||||||
switch_event_fire(&event);
|
switch_event_fire(&event);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
end:
|
||||||
|
|
||||||
|
if (lmember) {
|
||||||
|
switch_thread_rwlock_unlock(lmember->rwlock);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Gain exclusive access and remove the member from the list */
|
/* Gain exclusive access and remove the member from the list */
|
||||||
|
@ -1224,8 +1247,8 @@ switch_status_t conference_member_del(conference_obj_t *conference, conference_m
|
||||||
switch_core_speech_close(&member->lsh, &flags);
|
switch_core_speech_close(&member->lsh, &flags);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (member == member->conference->floor_holder) {
|
if (member->id == member->conference->floor_holder) {
|
||||||
conference_member_set_floor_holder(member->conference, NULL);
|
conference_member_set_floor_holder(member->conference, NULL, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (member->id == member->conference->video_floor_holder) {
|
if (member->id == member->conference->video_floor_holder) {
|
||||||
|
|
|
@ -4481,7 +4481,7 @@ void conference_video_find_floor(conference_member_t *member, switch_bool_t ente
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (conference->floor_holder && imember == conference->floor_holder) {
|
if (conference->floor_holder && imember->id == conference->floor_holder) {
|
||||||
conference_video_set_floor_holder(conference, imember, 0);
|
conference_video_set_floor_holder(conference, imember, 0);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
|
@ -117,7 +117,7 @@ void conference_list(conference_obj_t *conference, switch_stream_handle_t *strea
|
||||||
count++;
|
count++;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (member == member->conference->floor_holder) {
|
if (member->id == member->conference->floor_holder) {
|
||||||
stream->write_function(stream, "%s%s", count ? "|" : "", "floor");
|
stream->write_function(stream, "%s%s", count ? "|" : "", "floor");
|
||||||
count++;
|
count++;
|
||||||
}
|
}
|
||||||
|
@ -242,7 +242,7 @@ void *SWITCH_THREAD_FUNC conference_thread_run(switch_thread_t *thread, void *ob
|
||||||
switch_size_t file_data_len = samples * 2 * conference->channels;
|
switch_size_t file_data_len = samples * 2 * conference->channels;
|
||||||
int has_file_data = 0, members_with_video = 0, members_with_avatar = 0, members_seeing_video = 0;
|
int has_file_data = 0, members_with_video = 0, members_with_avatar = 0, members_seeing_video = 0;
|
||||||
int nomoh = 0;
|
int nomoh = 0;
|
||||||
conference_member_t *floor_holder;
|
uint32_t floor_holder;
|
||||||
switch_status_t moh_status = SWITCH_STATUS_SUCCESS;
|
switch_status_t moh_status = SWITCH_STATUS_SUCCESS;
|
||||||
|
|
||||||
/* Sync the conference to a single timing source */
|
/* Sync the conference to a single timing source */
|
||||||
|
@ -301,10 +301,12 @@ void *SWITCH_THREAD_FUNC conference_thread_run(switch_thread_t *thread, void *ob
|
||||||
if (conference_utils_member_test_flag(imember, MFLAG_RUNNING) && imember->session) {
|
if (conference_utils_member_test_flag(imember, MFLAG_RUNNING) && imember->session) {
|
||||||
switch_channel_t *channel = switch_core_session_get_channel(imember->session);
|
switch_channel_t *channel = switch_core_session_get_channel(imember->session);
|
||||||
switch_media_flow_t video_media_flow;
|
switch_media_flow_t video_media_flow;
|
||||||
|
|
||||||
if ((!floor_holder || (imember->score_iir > SCORE_IIR_SPEAKING_MAX && (floor_holder->score_iir < SCORE_IIR_SPEAKING_MIN)))) {// &&
|
if ((!floor_holder || (imember->id != conference->floor_holder && imember->score_iir > SCORE_IIR_SPEAKING_MAX && (conference->floor_holder_score_iir < SCORE_IIR_SPEAKING_MIN)))) {// &&
|
||||||
//(!conference_utils_test_flag(conference, CFLAG_VID_FLOOR) || switch_channel_test_flag(channel, CF_VIDEO))) {
|
//(!conference_utils_test_flag(conference, CFLAG_VID_FLOOR) || switch_channel_test_flag(channel, CF_VIDEO))) {
|
||||||
floor_holder = imember;
|
|
||||||
|
conference_member_set_floor_holder(conference, imember, 0);
|
||||||
|
floor_holder = imember->id;
|
||||||
}
|
}
|
||||||
|
|
||||||
video_media_flow = switch_core_session_media_flow(imember->session, SWITCH_MEDIA_TYPE_VIDEO);
|
video_media_flow = switch_core_session_media_flow(imember->session, SWITCH_MEDIA_TYPE_VIDEO);
|
||||||
|
@ -364,7 +366,7 @@ void *SWITCH_THREAD_FUNC conference_thread_run(switch_thread_t *thread, void *ob
|
||||||
conference->members_with_avatar = members_with_avatar;
|
conference->members_with_avatar = members_with_avatar;
|
||||||
|
|
||||||
if (floor_holder != conference->floor_holder) {
|
if (floor_holder != conference->floor_holder) {
|
||||||
conference_member_set_floor_holder(conference, floor_holder);
|
conference_member_set_floor_holder(conference, NULL, floor_holder);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (conference->moh_wait > 0) {
|
if (conference->moh_wait > 0) {
|
||||||
|
@ -1271,7 +1273,7 @@ void conference_xlist(conference_obj_t *conference, switch_xml_t x_conference, i
|
||||||
switch_xml_set_txt_d(x_tag, conference_utils_member_test_flag(member, MFLAG_VIDEO_BRIDGE) ? "true" : "false");
|
switch_xml_set_txt_d(x_tag, conference_utils_member_test_flag(member, MFLAG_VIDEO_BRIDGE) ? "true" : "false");
|
||||||
|
|
||||||
x_tag = switch_xml_add_child_d(x_flags, "has_floor", count++);
|
x_tag = switch_xml_add_child_d(x_flags, "has_floor", count++);
|
||||||
switch_xml_set_txt_d(x_tag, (member == member->conference->floor_holder) ? "true" : "false");
|
switch_xml_set_txt_d(x_tag, (member->id == member->conference->floor_holder) ? "true" : "false");
|
||||||
|
|
||||||
x_tag = switch_xml_add_child_d(x_flags, "is_moderator", count++);
|
x_tag = switch_xml_add_child_d(x_flags, "is_moderator", count++);
|
||||||
switch_xml_set_txt_d(x_tag, conference_utils_member_test_flag(member, MFLAG_MOD) ? "true" : "false");
|
switch_xml_set_txt_d(x_tag, conference_utils_member_test_flag(member, MFLAG_MOD) ? "true" : "false");
|
||||||
|
@ -1376,7 +1378,7 @@ void conference_jlist(conference_obj_t *conference, cJSON *json_conferences)
|
||||||
ADDBOOL(json_conference_member_flags, "talking", conference_utils_member_test_flag(member, MFLAG_TALKING));
|
ADDBOOL(json_conference_member_flags, "talking", conference_utils_member_test_flag(member, MFLAG_TALKING));
|
||||||
ADDBOOL(json_conference_member_flags, "has_video", switch_channel_test_flag(switch_core_session_get_channel(member->session), CF_VIDEO));
|
ADDBOOL(json_conference_member_flags, "has_video", switch_channel_test_flag(switch_core_session_get_channel(member->session), CF_VIDEO));
|
||||||
ADDBOOL(json_conference_member_flags, "video_bridge", conference_utils_member_test_flag(member, MFLAG_VIDEO_BRIDGE));
|
ADDBOOL(json_conference_member_flags, "video_bridge", conference_utils_member_test_flag(member, MFLAG_VIDEO_BRIDGE));
|
||||||
ADDBOOL(json_conference_member_flags, "has_floor", member == member->conference->floor_holder);
|
ADDBOOL(json_conference_member_flags, "has_floor", member->id == member->conference->floor_holder);
|
||||||
ADDBOOL(json_conference_member_flags, "is_moderator", conference_utils_member_test_flag(member, MFLAG_MOD));
|
ADDBOOL(json_conference_member_flags, "is_moderator", conference_utils_member_test_flag(member, MFLAG_MOD));
|
||||||
ADDBOOL(json_conference_member_flags, "end_conference", conference_utils_member_test_flag(member, MFLAG_ENDCONF));
|
ADDBOOL(json_conference_member_flags, "end_conference", conference_utils_member_test_flag(member, MFLAG_ENDCONF));
|
||||||
}
|
}
|
||||||
|
|
|
@ -673,7 +673,7 @@ typedef struct conference_obj {
|
||||||
uint32_t channels;
|
uint32_t channels;
|
||||||
switch_mutex_t *mutex;
|
switch_mutex_t *mutex;
|
||||||
conference_member_t *members;
|
conference_member_t *members;
|
||||||
conference_member_t *floor_holder;
|
uint32_t floor_holder;
|
||||||
uint32_t video_floor_holder;
|
uint32_t video_floor_holder;
|
||||||
uint32_t last_video_floor_holder;
|
uint32_t last_video_floor_holder;
|
||||||
switch_mutex_t *member_mutex;
|
switch_mutex_t *member_mutex;
|
||||||
|
@ -754,6 +754,7 @@ typedef struct conference_obj {
|
||||||
int scale_h264_canvas_fps_divisor;
|
int scale_h264_canvas_fps_divisor;
|
||||||
char *scale_h264_canvas_bandwidth;
|
char *scale_h264_canvas_bandwidth;
|
||||||
uint32_t moh_wait;
|
uint32_t moh_wait;
|
||||||
|
uint32_t floor_holder_score_iir;
|
||||||
} conference_obj_t;
|
} conference_obj_t;
|
||||||
|
|
||||||
/* Relationship with another member */
|
/* Relationship with another member */
|
||||||
|
@ -1025,7 +1026,7 @@ al_handle_t *conference_al_create(switch_memory_pool_t *pool);
|
||||||
switch_status_t conference_member_parse_position(conference_member_t *member, const char *data);
|
switch_status_t conference_member_parse_position(conference_member_t *member, const char *data);
|
||||||
video_layout_t *conference_video_find_best_layout(conference_obj_t *conference, layout_group_t *lg, uint32_t count, uint32_t file_count);
|
video_layout_t *conference_video_find_best_layout(conference_obj_t *conference, layout_group_t *lg, uint32_t count, uint32_t file_count);
|
||||||
void conference_list_count_only(conference_obj_t *conference, switch_stream_handle_t *stream);
|
void conference_list_count_only(conference_obj_t *conference, switch_stream_handle_t *stream);
|
||||||
void conference_member_set_floor_holder(conference_obj_t *conference, conference_member_t *member);
|
void conference_member_set_floor_holder(conference_obj_t *conference, conference_member_t *member, uint32_t id);
|
||||||
void conference_utils_member_clear_flag(conference_member_t *member, member_flag_t flag);
|
void conference_utils_member_clear_flag(conference_member_t *member, member_flag_t flag);
|
||||||
void conference_utils_member_clear_flag_locked(conference_member_t *member, member_flag_t flag);
|
void conference_utils_member_clear_flag_locked(conference_member_t *member, member_flag_t flag);
|
||||||
switch_status_t conference_video_attach_video_layer(conference_member_t *member, mcu_canvas_t *canvas, int idx);
|
switch_status_t conference_video_attach_video_layer(conference_member_t *member, mcu_canvas_t *canvas, int idx);
|
||||||
|
@ -1084,7 +1085,7 @@ void conference_member_check_channels(switch_frame_t *frame, conference_member_t
|
||||||
|
|
||||||
void conference_fnode_toggle_pause(conference_file_node_t *fnode, switch_stream_handle_t *stream);
|
void conference_fnode_toggle_pause(conference_file_node_t *fnode, switch_stream_handle_t *stream);
|
||||||
void conference_fnode_check_status(conference_file_node_t *fnode, switch_stream_handle_t *stream);
|
void conference_fnode_check_status(conference_file_node_t *fnode, switch_stream_handle_t *stream);
|
||||||
|
void conference_member_set_score_iir(conference_member_t *member, uint32_t score);
|
||||||
// static conference_relationship_t *conference_member_get_relationship(conference_member_t *member, conference_member_t *other_member);
|
// static conference_relationship_t *conference_member_get_relationship(conference_member_t *member, conference_member_t *other_member);
|
||||||
// static void conference_list(conference_obj_t *conference, switch_stream_handle_t *stream, char *delim);
|
// static void conference_list(conference_obj_t *conference, switch_stream_handle_t *stream, char *delim);
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue