From 6deca50592a8276004d229e204d80573129c2742 Mon Sep 17 00:00:00 2001 From: Aron Podrigal Date: Wed, 15 Jan 2025 14:16:31 -0600 Subject: [PATCH] Add "record-wait-mod" flag to control auto recording behavior Introduced a new conference flag, CFLAG_RECORD_WAIT_MOD, to delay auto recording until a moderator joins. Updated relevant logic to test and clear this flag based on moderator presence and participant count. This enhances flexibility in managing recording settings for moderated conferences. --- src/mod/applications/mod_conference/conference_member.c | 3 +++ src/mod/applications/mod_conference/conference_utils.c | 2 ++ src/mod/applications/mod_conference/mod_conference.c | 6 +++++- src/mod/applications/mod_conference/mod_conference.h | 1 + 4 files changed, 11 insertions(+), 1 deletion(-) diff --git a/src/mod/applications/mod_conference/conference_member.c b/src/mod/applications/mod_conference/conference_member.c index c258e59783..78f5691442 100644 --- a/src/mod/applications/mod_conference/conference_member.c +++ b/src/mod/applications/mod_conference/conference_member.c @@ -903,6 +903,9 @@ switch_status_t conference_member_add(conference_obj_t *conference, conference_m conference_utils_clear_flag(conference, CFLAG_WAIT_MOD); } + if (conference_utils_test_flag(conference, CFLAG_RECORD_WAIT_MOD) && conference_utils_member_test_flag(member, MFLAG_MOD)) { + conference_utils_clear_flag(conference, CFLAG_RECORD_WAIT_MOD); + } if (conference->count > 1) { if (((conference->moh_sound || conference->tmp_moh_sound) && !conference_utils_test_flag(conference, CFLAG_WAIT_MOD)) || (conference_utils_test_flag(conference, CFLAG_WAIT_MOD) && !switch_true(switch_channel_get_variable(channel, "conference_permanent_wait_mod_moh")))) { diff --git a/src/mod/applications/mod_conference/conference_utils.c b/src/mod/applications/mod_conference/conference_utils.c index a441594ddc..37e0ae5e5b 100644 --- a/src/mod/applications/mod_conference/conference_utils.c +++ b/src/mod/applications/mod_conference/conference_utils.c @@ -190,6 +190,8 @@ void conference_utils_set_cflags(const char *flags, conference_flag_t *f) for (i = 0; i < argc && argv[i]; i++) { if (!strcasecmp(argv[i], "wait-mod")) { f[CFLAG_WAIT_MOD] = 1; + } else if (!strcasecmp(argv[i], "record-wait-mod")) { + f[CFLAG_RECORD_WAIT_MOD] = 1; } else if (!strcasecmp(argv[i], "video-floor-only")) { f[CFLAG_VID_FLOOR] = 1; } else if (!strcasecmp(argv[i], "audio-always")) { diff --git a/src/mod/applications/mod_conference/mod_conference.c b/src/mod/applications/mod_conference/mod_conference.c index aa606170d5..fd7feaf382 100644 --- a/src/mod/applications/mod_conference/mod_conference.c +++ b/src/mod/applications/mod_conference/mod_conference.c @@ -433,7 +433,7 @@ void *SWITCH_THREAD_FUNC conference_thread_run(switch_thread_t *thread, void *ob } /* Start auto recording if there's the minimum number of required participants. */ - if (conference->auto_record && !conference->auto_recording && (conference->count >= conference->min_recording_participants)) { + if (conference->auto_record && !conference->auto_recording && (conference->count >= conference->min_recording_participants) && !conference_utils_test_flag(conference, CFLAG_RECORD_WAIT_MOD)) { conference->auto_recording++; conference->record_count++; imember = conference->members; @@ -1175,6 +1175,10 @@ void conference_xlist(conference_obj_t *conference, switch_xml_t x_conference, i switch_xml_set_attr_d(x_conference, "wait_mod", "true"); } + if (conference_utils_test_flag(conference, CFLAG_RECORD_WAIT_MOD)) { + switch_xml_set_attr_d(x_conference, "record_wait_mod", "true"); + } + if (conference_utils_test_flag(conference, CFLAG_AUDIO_ALWAYS)) { switch_xml_set_attr_d(x_conference, "audio_always", "true"); } diff --git a/src/mod/applications/mod_conference/mod_conference.h b/src/mod/applications/mod_conference/mod_conference.h index e45a921c21..d0000f29be 100644 --- a/src/mod/applications/mod_conference/mod_conference.h +++ b/src/mod/applications/mod_conference/mod_conference.h @@ -258,6 +258,7 @@ typedef enum { CFLAG_NO_MOH, CFLAG_DED_VID_LAYER_AUDIO_FLOOR, CFLAG_BREAKABLE, + CFLAG_RECORD_WAIT_MOD, ///////////////////////////////// CFLAG_MAX } conference_flag_t;