]> git.ipfire.org Git - thirdparty/freeswitch.git/commitdiff
FS-3000 mod_conference: if more digits than the length of the correct pin the remaini...
authorJeff Lenk <jeff@jefflenk.com>
Sun, 23 Jan 2011 04:51:48 +0000 (22:51 -0600)
committerJeff Lenk <jeff@jefflenk.com>
Sun, 23 Jan 2011 04:51:48 +0000 (22:51 -0600)
src/mod/applications/mod_conference/mod_conference.c

index 7f7ee83795e7b62ae6352943625fd1e50338a9d6..e6a47bf1ece70e36cbb22c31fc8ca55047531551 100644 (file)
@@ -5597,6 +5597,7 @@ SWITCH_STANDARD_APP(conference_function)
                        char pin_buf[80] = "";
                        int pin_retries = 3;    /* XXX - this should be configurable - i'm too lazy to do it right now... */
                        int pin_valid = 0;
+                       int be_friendly = 0;
                        switch_status_t status = SWITCH_STATUS_SUCCESS;
                        char *supplied_pin_value;
 
@@ -5631,20 +5632,24 @@ SWITCH_STANDARD_APP(conference_function)
                                switch_status_t pstatus = SWITCH_STATUS_FALSE;
 
                                /* be friendly */
-                               if (conference->pin_sound) {
-                                       pstatus = conference_local_play_file(conference, session, conference->pin_sound, 20, pin_buf, sizeof(pin_buf));
-                               } else if (conference->tts_engine && conference->tts_voice) {
-                                       pstatus =
-                                               switch_ivr_speak_text(session, conference->tts_engine, conference->tts_voice, "please enter the conference pin number", NULL);
-                               } else {
-                                       pstatus = switch_ivr_speak_text(session, "flite", "slt", "please enter the conference pin number", NULL);
-                               }
+                               if (!be_friendly) {
+                                       if (conference->pin_sound) {
+                                               pstatus = conference_local_play_file(conference, session, conference->pin_sound, 20, pin_buf, sizeof(pin_buf));
+                                       } else if (conference->tts_engine && conference->tts_voice) {
+                                               pstatus =
+                                                       switch_ivr_speak_text(session, conference->tts_engine, conference->tts_voice, "please enter the conference pin number", NULL);
+                                       } else {
+                                               pstatus = switch_ivr_speak_text(session, "flite", "slt", "please enter the conference pin number", NULL);
+                                       }
 
-                               if (pstatus != SWITCH_STATUS_SUCCESS && pstatus != SWITCH_STATUS_BREAK) {
-                                       switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(session), SWITCH_LOG_WARNING, "Cannot ask the user for a pin, ending call");
-                                       switch_channel_hangup(channel, SWITCH_CAUSE_DESTINATION_OUT_OF_ORDER);
+                                       if (pstatus != SWITCH_STATUS_SUCCESS && pstatus != SWITCH_STATUS_BREAK) {
+                                               switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(session), SWITCH_LOG_WARNING, "Cannot ask the user for a pin, ending call");
+                                               switch_channel_hangup(channel, SWITCH_CAUSE_DESTINATION_OUT_OF_ORDER);
+                                       }
                                }
 
+                               be_friendly = 1;
+
                                /* wait for them if neccessary */
                                if (strlen(pin_buf) < strlen(dpin)) {
                                        char *buf = pin_buf + strlen(pin_buf);
@@ -5660,13 +5665,12 @@ SWITCH_STANDARD_APP(conference_function)
 
                                pin_valid = (status == SWITCH_STATUS_SUCCESS && strcmp(pin_buf, dpin) == 0);
                                if (!pin_valid) {
-                                       /* zero the collected pin */
-                                       memset(pin_buf, 0, sizeof(pin_buf));
-
                                        /* more friendliness */
                                        if (conference->bad_pin_sound) {
                                                conference_local_play_file(conference, session, conference->bad_pin_sound, 20, pin_buf, sizeof(pin_buf));
                                        }
+                                       /* zero the collected pin */
+                                       memset(pin_buf, 0, sizeof(pin_buf));
                                }
                                pin_retries--;
                        }