minor tweaks in conference

git-svn-id: http://svn.freeswitch.org/svn/freeswitch/trunk@3930 d0543943-73ff-0310-b7d9-9358b9ac24b2
This commit is contained in:
Anthony Minessale 2007-01-08 17:19:59 +00:00
parent 716a9fbd94
commit 97cf339c7e
1 changed files with 43 additions and 33 deletions

View File

@ -207,7 +207,6 @@ struct conference_member {
uint32_t id; uint32_t id;
switch_core_session_t *session; switch_core_session_t *session;
conference_obj_t *conference; conference_obj_t *conference;
conference_obj_t *last_conference;
switch_memory_pool_t *pool; switch_memory_pool_t *pool;
switch_buffer_t *audio_buffer; switch_buffer_t *audio_buffer;
switch_buffer_t *mux_buffer; switch_buffer_t *mux_buffer;
@ -461,7 +460,7 @@ static switch_status_t conference_add_member(conference_obj_t *conference, confe
switch_mutex_lock(member->audio_in_mutex); switch_mutex_lock(member->audio_in_mutex);
switch_mutex_lock(member->audio_out_mutex); switch_mutex_lock(member->audio_out_mutex);
switch_mutex_lock(member->flag_mutex); switch_mutex_lock(member->flag_mutex);
member->conference = member->last_conference = conference; member->conference = conference;
member->next = conference->members; member->next = conference->members;
member->energy_level = conference->energy_level; member->energy_level = conference->energy_level;
conference->members = member; conference->members = member;
@ -2548,10 +2547,12 @@ static switch_status_t conf_api_sub_list(conference_obj_t *conference, switch_st
switch_hash_this(hi, NULL, NULL, &val); switch_hash_this(hi, NULL, NULL, &val);
conference = (conference_obj_t *) val; conference = (conference_obj_t *) val;
stream->write_function(stream, "Conference %s (%u member%s)\n", stream->write_function(stream, "Conference %s (%u member%s%s)\n",
conference->name, conference->name,
conference->count, conference->count,
conference->count == 1 ? "" : "s"); conference->count == 1 ? "" : "s",
switch_test_flag(conference, CFLAG_LOCKED) ? " locked" : ""
);
if (pretty) { if (pretty) {
conference_list_pretty(conference, stream); conference_list_pretty(conference, stream);
} else { } else {
@ -2896,7 +2897,7 @@ static switch_status_t conf_api_sub_transfer(conference_obj_t *conference, switc
char *profile_name; char *profile_name;
switch_xml_t cxml = NULL, cfg = NULL, profiles = NULL; switch_xml_t cxml = NULL, cfg = NULL, profiles = NULL;
if (!(member = conference_member_get(conference, id))) { if (!id || !(member = conference_member_get(conference, id))) {
stream->write_function(stream, "No Member %u in conference %s.\n", id, conference->name); stream->write_function(stream, "No Member %u in conference %s.\n", id, conference->name);
continue; continue;
} }
@ -2919,6 +2920,9 @@ static switch_status_t conf_api_sub_transfer(conference_obj_t *conference, switc
if ((profile_name = strchr(conf_name, '@'))) { if ((profile_name = strchr(conf_name, '@'))) {
*profile_name++ = '\0'; *profile_name++ = '\0';
} else {
profile_name = "default";
}
/* Open the config from the xml registry */ /* Open the config from the xml registry */
if (!(cxml = switch_xml_open_cfg(global_cf_name, &cfg, NULL))) { if (!(cxml = switch_xml_open_cfg(global_cf_name, &cfg, NULL))) {
@ -2933,7 +2937,6 @@ static switch_status_t conf_api_sub_transfer(conference_obj_t *conference, switc
#ifdef OPTION_IVR_MENU_SUPPORT #ifdef OPTION_IVR_MENU_SUPPORT
xml_cfg.menus = switch_xml_child(cfg, "menus"); xml_cfg.menus = switch_xml_child(cfg, "menus");
#endif #endif
}
/* Release the config registry handle */ /* Release the config registry handle */
if (cxml) { if (cxml) {
@ -2958,13 +2961,18 @@ static switch_status_t conf_api_sub_transfer(conference_obj_t *conference, switc
/* Indicate the conference is dynamic */ /* Indicate the conference is dynamic */
switch_set_flag_locked(new_conference, CFLAG_DYNAMIC); switch_set_flag_locked(new_conference, CFLAG_DYNAMIC);
switch_mutex_lock(new_conference->mutex);
/* Start the conference thread for this conference */ /* Start the conference thread for this conference */
launch_conference_thread(new_conference); launch_conference_thread(new_conference);
} else {
switch_mutex_lock(new_conference->mutex);
} }
/* move the member from the old conference to the new one */ /* move the member from the old conference to the new one */
conference_del_member(member->last_conference, member); conference_del_member(conference, member);
conference_add_member(new_conference, member); conference_add_member(new_conference, member);
switch_mutex_unlock(new_conference->mutex);
stream->write_function(stream, "OK Members sent to conference %s.\n", argv[2]); stream->write_function(stream, "OK Members sent to conference %s.\n", argv[2]);
@ -3204,13 +3212,13 @@ static switch_status_t conf_api_main(char *buf, switch_core_session_t *session,
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_CRIT, "Read Lock Fail\n"); switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_CRIT, "Read Lock Fail\n");
goto done; goto done;
} }
switch_mutex_lock(conference->mutex);
if (argc >= 2) { if (argc >= 2) {
conf_api_dispatch(conference, stream, argc, argv, (const char *)buf, 1); conf_api_dispatch(conference, stream, argc, argv, (const char *)buf, 1);
} else { } else {
stream->write_function(stream, "Conference command, not specified.\nTry 'help'\n"); stream->write_function(stream, "Conference command, not specified.\nTry 'help'\n");
} }
switch_mutex_unlock(conference->mutex);
switch_thread_rwlock_unlock(conference->rwlock); switch_thread_rwlock_unlock(conference->rwlock);
} else { } else {
@ -3464,6 +3472,9 @@ static void conference_function(switch_core_session_t *session, char *data)
/* is there profile specification ? */ /* is there profile specification ? */
if ((profile_name = strchr(conf_name, '@'))) { if ((profile_name = strchr(conf_name, '@'))) {
*profile_name++ = '\0'; *profile_name++ = '\0';
} else {
profile_name = "default";
}
/* Open the config from the xml registry */ /* Open the config from the xml registry */
if (!(cxml = switch_xml_open_cfg(global_cf_name, &cfg, NULL))) { if (!(cxml = switch_xml_open_cfg(global_cf_name, &cfg, NULL))) {
@ -3479,7 +3490,6 @@ static void conference_function(switch_core_session_t *session, char *data)
#ifdef OPTION_IVR_MENU_SUPPORT #ifdef OPTION_IVR_MENU_SUPPORT
xml_cfg.menus = switch_xml_child(cfg, "menus"); xml_cfg.menus = switch_xml_child(cfg, "menus");
#endif #endif
}
/* if this is a bridging call, and it's not a duplicate, build a */ /* if this is a bridging call, and it's not a duplicate, build a */
/* conference object, and skip pin handling, and locked checking */ /* conference object, and skip pin handling, and locked checking */
@ -3730,7 +3740,7 @@ static void conference_function(switch_core_session_t *session, char *data)
switch_core_session_receive_message(session, &msg); switch_core_session_receive_message(session, &msg);
/* Remove the caller from the conference */ /* Remove the caller from the conference */
conference_del_member(member.last_conference, &member); conference_del_member(member.conference, &member);
/* Put the original codec back */ /* Put the original codec back */
switch_core_session_set_read_codec(member.session, read_codec); switch_core_session_set_read_codec(member.session, read_codec);