add conference wait-mod flags and member moderator flag to delay starting a conference until someone with a moderator flag has joined
git-svn-id: http://svn.freeswitch.org/svn/freeswitch/trunk@13442 d0543943-73ff-0310-b7d9-9358b9ac24b2
This commit is contained in:
parent
fc6c8e05aa
commit
f382d5327c
|
@ -627,13 +627,14 @@ static switch_status_t conference_add_member(conference_obj_t *conference, confe
|
||||||
switch_clear_flag(conference, CFLAG_WAIT_MOD);
|
switch_clear_flag(conference, CFLAG_WAIT_MOD);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (conference->count > 1 && (!switch_test_flag(conference, CFLAG_WAIT_MOD))) {
|
if (conference->count > 1) {
|
||||||
if (conference->moh_sound) {
|
if (conference->moh_sound && !switch_test_flag(conference, CFLAG_WAIT_MOD)) {
|
||||||
/* stop MoH if any */
|
/* stop MoH if any */
|
||||||
conference_stop_file(conference, FILE_STOP_ASYNC);
|
conference_stop_file(conference, FILE_STOP_ASYNC);
|
||||||
}
|
}
|
||||||
if (conference->enter_sound) {
|
if (conference->enter_sound) {
|
||||||
conference_play_file(conference, conference->enter_sound, CONF_DEFAULT_LEADIN, switch_core_session_get_channel(member->session), 1);
|
conference_play_file(conference, conference->enter_sound, CONF_DEFAULT_LEADIN, switch_core_session_get_channel(member->session),
|
||||||
|
switch_test_flag(conference, CFLAG_WAIT_MOD) ? 0 : 1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -650,7 +651,7 @@ static switch_status_t conference_add_member(conference_obj_t *conference, confe
|
||||||
if (conference->count >= conference->announce_count && conference->announce_count > 1) {
|
if (conference->count >= conference->announce_count && conference->announce_count > 1) {
|
||||||
switch_snprintf(msg, sizeof(msg), "There are %d callers", conference->count);
|
switch_snprintf(msg, sizeof(msg), "There are %d callers", conference->count);
|
||||||
conference_member_say(member, msg, CONF_DEFAULT_LEADIN);
|
conference_member_say(member, msg, CONF_DEFAULT_LEADIN);
|
||||||
} else if (conference->count == 1 && !conference->perpetual_sound) {
|
} else if (conference->count == 1 && !conference->perpetual_sound && !switch_test_flag(conference, CFLAG_WAIT_MOD)) {
|
||||||
/* as long as its not a bridge_to conference, announce if person is alone */
|
/* as long as its not a bridge_to conference, announce if person is alone */
|
||||||
if (!switch_test_flag(conference, CFLAG_BRIDGE_TO)) {
|
if (!switch_test_flag(conference, CFLAG_BRIDGE_TO)) {
|
||||||
if (conference->alone_sound) {
|
if (conference->alone_sound) {
|
||||||
|
@ -788,7 +789,7 @@ static switch_status_t conference_del_member(conference_obj_t *conference, confe
|
||||||
if (conference->exit_sound) {
|
if (conference->exit_sound) {
|
||||||
conference_play_file(conference, conference->exit_sound, 0, switch_core_session_get_channel(member->session), 0);
|
conference_play_file(conference, conference->exit_sound, 0, switch_core_session_get_channel(member->session), 0);
|
||||||
}
|
}
|
||||||
if (conference->count == 1 && conference->alone_sound) {
|
if (conference->count == 1 && conference->alone_sound && !switch_test_flag(conference, CFLAG_WAIT_MOD)) {
|
||||||
conference_stop_file(conference, FILE_STOP_ASYNC);
|
conference_stop_file(conference, FILE_STOP_ASYNC);
|
||||||
conference_play_file(conference, conference->alone_sound, 0, switch_core_session_get_channel(member->session), 1);
|
conference_play_file(conference, conference->alone_sound, 0, switch_core_session_get_channel(member->session), 1);
|
||||||
}
|
}
|
||||||
|
@ -4558,7 +4559,7 @@ static switch_status_t conference_local_play_file(conference_obj_t *conference,
|
||||||
return status;
|
return status;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void set_mflags(char *flags, member_flag_t *f)
|
static void set_mflags(const char *flags, member_flag_t *f)
|
||||||
{
|
{
|
||||||
if (flags) {
|
if (flags) {
|
||||||
char *dup = strdup(flags);
|
char *dup = strdup(flags);
|
||||||
|
@ -4600,7 +4601,7 @@ static void set_mflags(char *flags, member_flag_t *f)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
static void set_cflags(char *flags, member_flag_t *f)
|
static void set_cflags(const char *flags, member_flag_t *f)
|
||||||
{
|
{
|
||||||
if (flags) {
|
if (flags) {
|
||||||
char *dup = strdup(flags);
|
char *dup = strdup(flags);
|
||||||
|
@ -4844,7 +4845,7 @@ SWITCH_STANDARD_APP(conference_function)
|
||||||
char *bridgeto = NULL;
|
char *bridgeto = NULL;
|
||||||
char *profile_name = NULL;
|
char *profile_name = NULL;
|
||||||
switch_xml_t cxml = NULL, cfg = NULL, profiles = NULL;
|
switch_xml_t cxml = NULL, cfg = NULL, profiles = NULL;
|
||||||
char *flags_str;
|
const char *flags_str;
|
||||||
member_flag_t mflags = 0;
|
member_flag_t mflags = 0;
|
||||||
switch_core_session_message_t msg = { 0 };
|
switch_core_session_message_t msg = { 0 };
|
||||||
uint8_t rl = 0, isbr = 0;
|
uint8_t rl = 0, isbr = 0;
|
||||||
|
@ -4874,12 +4875,13 @@ SWITCH_STANDARD_APP(conference_function)
|
||||||
|
|
||||||
if ((flags_str = strstr(mydata, flags_prefix))) {
|
if ((flags_str = strstr(mydata, flags_prefix))) {
|
||||||
char *p;
|
char *p;
|
||||||
|
*((char *)flags_str) = '\0';
|
||||||
*flags_str = '\0';
|
|
||||||
flags_str += strlen(flags_prefix);
|
flags_str += strlen(flags_prefix);
|
||||||
if ((p = strchr(flags_str, '}'))) {
|
if ((p = strchr(flags_str, '}'))) {
|
||||||
*p = '\0';
|
*p = '\0';
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
flags_str = switch_channel_get_variable(channel, "conference_member_flags");
|
||||||
}
|
}
|
||||||
|
|
||||||
/* is this a bridging conference ? */
|
/* is this a bridging conference ? */
|
||||||
|
|
Loading…
Reference in New Issue