From cb1d126c44ec2dcd2d2c5c118195e285c13b55d3 Mon Sep 17 00:00:00 2001 From: mcrane Date: Mon, 13 Jul 2009 16:10:08 -0600 Subject: FreeSWITCH add new dev package to seperate development from release. --- config/freeswitch_dev/begin_recording.wav | Bin 0 -> 19480 bytes .../call_forward_has_been_deleted.wav | Bin 0 -> 28668 bytes .../freeswitch_dev/call_forward_has_been_set.wav | Bin 0 -> 30976 bytes config/freeswitch_dev/class.phpmailer.tmp | 1896 +++++++++++ config/freeswitch_dev/class.smtp.tmp | 1062 ++++++ config/freeswitch_dev/dialplan.default.xml | 684 ++++ config/freeswitch_dev/dialplan.public.xml | 69 + config/freeswitch_dev/disa.js | 78 + config/freeswitch_dev/fax_to_email.tmp | 182 + config/freeswitch_dev/freeswitch.inc | 3515 ++++++++++++++++++++ config/freeswitch_dev/freeswitch.xml | 267 ++ config/freeswitch_dev/freeswitch_cmd.tmp | 49 + config/freeswitch_dev/freeswitch_dialplan.tmp | 163 + .../freeswitch_dialplan_includes.tmp | 278 ++ .../freeswitch_dialplan_includes_details.tmp | 53 + .../freeswitch_dialplan_includes_details_edit.tmp | 389 +++ .../freeswitch_dialplan_includes_edit.tmp | 543 +++ config/freeswitch_dev/freeswitch_extensions.tmp | 220 ++ .../freeswitch_dev/freeswitch_extensions_edit.tmp | 417 +++ config/freeswitch_dev/freeswitch_fax.tmp | 305 ++ config/freeswitch_dev/freeswitch_fax_edit.tmp | 723 ++++ config/freeswitch_dev/freeswitch_features.tmp | 216 ++ config/freeswitch_dev/freeswitch_gateways.tmp | 214 ++ config/freeswitch_dev/freeswitch_gateways_edit.tmp | 685 ++++ config/freeswitch_dev/freeswitch_hunt_group.tmp | 176 + .../freeswitch_hunt_group_destinations.tmp | 52 + .../freeswitch_hunt_group_destinations_edit.tmp | 269 ++ .../freeswitch_dev/freeswitch_hunt_group_edit.tmp | 471 +++ config/freeswitch_dev/freeswitch_ivr.tmp | 177 + config/freeswitch_dev/freeswitch_ivr_edit.tmp | 697 ++++ config/freeswitch_dev/freeswitch_ivr_options.tmp | 52 + .../freeswitch_dev/freeswitch_ivr_options_edit.tmp | 248 ++ config/freeswitch_dev/freeswitch_mailto.tmp | 243 ++ config/freeswitch_dev/freeswitch_modules.xml | 1203 +++++++ config/freeswitch_dev/freeswitch_profile_edit.tmp | 143 + config/freeswitch_dev/freeswitch_profiles.tmp | 214 ++ config/freeswitch_dev/freeswitch_public.tmp | 162 + .../freeswitch_dev/freeswitch_public_includes.tmp | 282 ++ .../freeswitch_public_includes_details.tmp | 53 + .../freeswitch_public_includes_details_edit.tmp | 419 +++ .../freeswitch_public_includes_edit.tmp | 543 +++ config/freeswitch_dev/freeswitch_recordings.tmp | 494 +++ .../freeswitch_dev/freeswitch_recordings_edit.tmp | 172 + .../freeswitch_dev/freeswitch_recordings_play.tmp | 70 + config/freeswitch_dev/freeswitch_status.tmp | 339 ++ .../freeswitch_dev/freeswitch_time_conditions.tmp | 178 + .../freeswitch_time_conditions_edit.tmp | 201 ++ config/freeswitch_dev/freeswitch_vars.tmp | 162 + config/freeswitch_dev/libcurl.so.5 | Bin 0 -> 293352 bytes config/freeswitch_dev/libiconv.so.3 | Bin 0 -> 1045332 bytes config/freeswitch_dev/libncurses.so.5.6 | Bin 0 -> 127748 bytes config/freeswitch_dev/libncurses.so.5.7 | Bin 0 -> 127748 bytes config/freeswitch_dev/libodbc.so.1 | Bin 0 -> 456398 bytes config/freeswitch_dev/libogg.so.5.3 | Bin 0 -> 43004 bytes config/freeswitch_dev/libspandsp.so.1 | Bin 0 -> 1398998 bytes config/freeswitch_dev/libtinfo.so.5.6 | Bin 0 -> 187069 bytes config/freeswitch_dev/libvorbis.so.4 | Bin 0 -> 179138 bytes .../please_enter_the_extension_number.wav | Bin 0 -> 32360 bytes .../please_enter_the_phone_number.wav | Bin 0 -> 26552 bytes .../freeswitch_dev/please_enter_the_pin_number.wav | Bin 0 -> 27504 bytes .../please_enter_your_pin_number.wav | Bin 0 -> 28212 bytes .../your_pin_number_is_incorect_goodbye.wav | Bin 0 -> 43420 bytes 62 files changed, 19028 insertions(+) create mode 100755 config/freeswitch_dev/begin_recording.wav create mode 100644 config/freeswitch_dev/call_forward_has_been_deleted.wav create mode 100644 config/freeswitch_dev/call_forward_has_been_set.wav create mode 100755 config/freeswitch_dev/class.phpmailer.tmp create mode 100755 config/freeswitch_dev/class.smtp.tmp create mode 100644 config/freeswitch_dev/dialplan.default.xml create mode 100644 config/freeswitch_dev/dialplan.public.xml create mode 100644 config/freeswitch_dev/disa.js create mode 100644 config/freeswitch_dev/fax_to_email.tmp create mode 100644 config/freeswitch_dev/freeswitch.inc create mode 100644 config/freeswitch_dev/freeswitch.xml create mode 100644 config/freeswitch_dev/freeswitch_cmd.tmp create mode 100644 config/freeswitch_dev/freeswitch_dialplan.tmp create mode 100644 config/freeswitch_dev/freeswitch_dialplan_includes.tmp create mode 100755 config/freeswitch_dev/freeswitch_dialplan_includes_details.tmp create mode 100644 config/freeswitch_dev/freeswitch_dialplan_includes_details_edit.tmp create mode 100644 config/freeswitch_dev/freeswitch_dialplan_includes_edit.tmp create mode 100644 config/freeswitch_dev/freeswitch_extensions.tmp create mode 100644 config/freeswitch_dev/freeswitch_extensions_edit.tmp create mode 100644 config/freeswitch_dev/freeswitch_fax.tmp create mode 100644 config/freeswitch_dev/freeswitch_fax_edit.tmp create mode 100644 config/freeswitch_dev/freeswitch_features.tmp create mode 100644 config/freeswitch_dev/freeswitch_gateways.tmp create mode 100644 config/freeswitch_dev/freeswitch_gateways_edit.tmp create mode 100644 config/freeswitch_dev/freeswitch_hunt_group.tmp create mode 100644 config/freeswitch_dev/freeswitch_hunt_group_destinations.tmp create mode 100644 config/freeswitch_dev/freeswitch_hunt_group_destinations_edit.tmp create mode 100644 config/freeswitch_dev/freeswitch_hunt_group_edit.tmp create mode 100644 config/freeswitch_dev/freeswitch_ivr.tmp create mode 100644 config/freeswitch_dev/freeswitch_ivr_edit.tmp create mode 100755 config/freeswitch_dev/freeswitch_ivr_options.tmp create mode 100644 config/freeswitch_dev/freeswitch_ivr_options_edit.tmp create mode 100644 config/freeswitch_dev/freeswitch_mailto.tmp create mode 100644 config/freeswitch_dev/freeswitch_modules.xml create mode 100644 config/freeswitch_dev/freeswitch_profile_edit.tmp create mode 100644 config/freeswitch_dev/freeswitch_profiles.tmp create mode 100644 config/freeswitch_dev/freeswitch_public.tmp create mode 100644 config/freeswitch_dev/freeswitch_public_includes.tmp create mode 100755 config/freeswitch_dev/freeswitch_public_includes_details.tmp create mode 100644 config/freeswitch_dev/freeswitch_public_includes_details_edit.tmp create mode 100644 config/freeswitch_dev/freeswitch_public_includes_edit.tmp create mode 100644 config/freeswitch_dev/freeswitch_recordings.tmp create mode 100644 config/freeswitch_dev/freeswitch_recordings_edit.tmp create mode 100755 config/freeswitch_dev/freeswitch_recordings_play.tmp create mode 100644 config/freeswitch_dev/freeswitch_status.tmp create mode 100644 config/freeswitch_dev/freeswitch_time_conditions.tmp create mode 100644 config/freeswitch_dev/freeswitch_time_conditions_edit.tmp create mode 100644 config/freeswitch_dev/freeswitch_vars.tmp create mode 100755 config/freeswitch_dev/libcurl.so.5 create mode 100755 config/freeswitch_dev/libiconv.so.3 create mode 100755 config/freeswitch_dev/libncurses.so.5.6 create mode 100755 config/freeswitch_dev/libncurses.so.5.7 create mode 100755 config/freeswitch_dev/libodbc.so.1 create mode 100755 config/freeswitch_dev/libogg.so.5.3 create mode 100755 config/freeswitch_dev/libspandsp.so.1 create mode 100755 config/freeswitch_dev/libtinfo.so.5.6 create mode 100755 config/freeswitch_dev/libvorbis.so.4 create mode 100644 config/freeswitch_dev/please_enter_the_extension_number.wav create mode 100644 config/freeswitch_dev/please_enter_the_phone_number.wav create mode 100644 config/freeswitch_dev/please_enter_the_pin_number.wav create mode 100755 config/freeswitch_dev/please_enter_your_pin_number.wav create mode 100755 config/freeswitch_dev/your_pin_number_is_incorect_goodbye.wav diff --git a/config/freeswitch_dev/begin_recording.wav b/config/freeswitch_dev/begin_recording.wav new file mode 100755 index 00000000..9e4992ca Binary files /dev/null and b/config/freeswitch_dev/begin_recording.wav differ diff --git a/config/freeswitch_dev/call_forward_has_been_deleted.wav b/config/freeswitch_dev/call_forward_has_been_deleted.wav new file mode 100644 index 00000000..ebe6ed36 Binary files /dev/null and b/config/freeswitch_dev/call_forward_has_been_deleted.wav differ diff --git a/config/freeswitch_dev/call_forward_has_been_set.wav b/config/freeswitch_dev/call_forward_has_been_set.wav new file mode 100644 index 00000000..58262852 Binary files /dev/null and b/config/freeswitch_dev/call_forward_has_been_set.wav differ diff --git a/config/freeswitch_dev/class.phpmailer.tmp b/config/freeswitch_dev/class.phpmailer.tmp new file mode 100755 index 00000000..2ddc30fd --- /dev/null +++ b/config/freeswitch_dev/class.phpmailer.tmp @@ -0,0 +1,1896 @@ +ContentType = 'text/html'; + } else { + $this->ContentType = 'text/plain'; + } + } + + /** + * Sets Mailer to send message using SMTP. + * @return void + */ + function IsSMTP() { + $this->Mailer = 'smtp'; + } + + /** + * Sets Mailer to send message using PHP mail() function. + * @return void + */ + function IsMail() { + $this->Mailer = 'mail'; + } + + /** + * Sets Mailer to send message using the $Sendmail program. + * @return void + */ + function IsSendmail() { + $this->Mailer = 'sendmail'; + } + + /** + * Sets Mailer to send message using the qmail MTA. + * @return void + */ + function IsQmail() { + $this->Sendmail = '/var/qmail/bin/sendmail'; + $this->Mailer = 'sendmail'; + } + + ///////////////////////////////////////////////// + // METHODS, RECIPIENTS + ///////////////////////////////////////////////// + + /** + * Adds a "To" address. + * @param string $address + * @param string $name + * @return void + */ + function AddAddress($address, $name = '') { + $cur = count($this->to); + $this->to[$cur][0] = trim($address); + $this->to[$cur][1] = $name; + } + + /** + * Adds a "Cc" address. Note: this function works + * with the SMTP mailer on win32, not with the "mail" + * mailer. + * @param string $address + * @param string $name + * @return void + */ + function AddCC($address, $name = '') { + $cur = count($this->cc); + $this->cc[$cur][0] = trim($address); + $this->cc[$cur][1] = $name; + } + + /** + * Adds a "Bcc" address. Note: this function works + * with the SMTP mailer on win32, not with the "mail" + * mailer. + * @param string $address + * @param string $name + * @return void + */ + function AddBCC($address, $name = '') { + $cur = count($this->bcc); + $this->bcc[$cur][0] = trim($address); + $this->bcc[$cur][1] = $name; + } + + /** + * Adds a "Reply-To" address. + * @param string $address + * @param string $name + * @return void + */ + function AddReplyTo($address, $name = '') { + $cur = count($this->ReplyTo); + $this->ReplyTo[$cur][0] = trim($address); + $this->ReplyTo[$cur][1] = $name; + } + + ///////////////////////////////////////////////// + // METHODS, MAIL SENDING + ///////////////////////////////////////////////// + + /** + * Creates message and assigns Mailer. If the message is + * not sent successfully then it returns false. Use the ErrorInfo + * variable to view description of the error. + * @return bool + */ + function Send() { + $header = ''; + $body = ''; + $result = true; + + if((count($this->to) + count($this->cc) + count($this->bcc)) < 1) { + $this->SetError($this->Lang('provide_address')); + return false; + } + + /* Set whether the message is multipart/alternative */ + if(!empty($this->AltBody)) { + $this->ContentType = 'multipart/alternative'; + } + + $this->error_count = 0; // reset errors + $this->SetMessageType(); + $header .= $this->CreateHeader(); + $body = $this->CreateBody(); + + if($body == '') { + return false; + } + + /* Choose the mailer */ + switch($this->Mailer) { + case 'sendmail': + $result = $this->SendmailSend($header, $body); + break; + case 'smtp': + $result = $this->SmtpSend($header, $body); + break; + case 'mail': + $result = $this->MailSend($header, $body); + break; + default: + $result = $this->MailSend($header, $body); + break; + //$this->SetError($this->Mailer . $this->Lang('mailer_not_supported')); + //$result = false; + //break; + } + + return $result; + } + + /** + * Sends mail using the $Sendmail program. + * @access private + * @return bool + */ + function SendmailSend($header, $body) { + if ($this->Sender != '') { + $sendmail = sprintf("%s -oi -f %s -t", escapeshellcmd($this->Sendmail), escapeshellarg($this->Sender)); + } else { + $sendmail = sprintf("%s -oi -t", escapeshellcmd($this->Sendmail)); + } + + if(!@$mail = popen($sendmail, 'w')) { + $this->SetError($this->Lang('execute') . $this->Sendmail); + return false; + } + + fputs($mail, $header); + fputs($mail, $body); + + $result = pclose($mail); + if (version_compare(phpversion(), '4.2.3') == -1) { + $result = $result >> 8 & 0xFF; + } + if($result != 0) { + $this->SetError($this->Lang('execute') . $this->Sendmail); + return false; + } + return true; + } + + /** + * Sends mail using the PHP mail() function. + * @access private + * @return bool + */ + function MailSend($header, $body) { + + $to = ''; + for($i = 0; $i < count($this->to); $i++) { + if($i != 0) { $to .= ', '; } + $to .= $this->AddrFormat($this->to[$i]); + } + + $toArr = split(',', $to); + + $params = sprintf("-oi -f %s", $this->Sender); + if ($this->Sender != '' && strlen(ini_get('safe_mode')) < 1) { + $old_from = ini_get('sendmail_from'); + ini_set('sendmail_from', $this->Sender); + if ($this->SingleTo === true && count($toArr) > 1) { + foreach ($toArr as $key => $val) { + $rt = @mail($val, $this->EncodeHeader($this->SecureHeader($this->Subject)), $body, $header, $params); + } + } else { + $rt = @mail($to, $this->EncodeHeader($this->SecureHeader($this->Subject)), $body, $header, $params); + } + } else { + if ($this->SingleTo === true && count($toArr) > 1) { + foreach ($toArr as $key => $val) { + $rt = @mail($val, $this->EncodeHeader($this->SecureHeader($this->Subject)), $body, $header, $params); + } + } else { + $rt = @mail($to, $this->EncodeHeader($this->SecureHeader($this->Subject)), $body, $header); + } + } + + if (isset($old_from)) { + ini_set('sendmail_from', $old_from); + } + + if(!$rt) { + $this->SetError($this->Lang('instantiate')); + return false; + } + + return true; + } + + /** + * Sends mail via SMTP using PhpSMTP (Author: + * Chris Ryan). Returns bool. Returns false if there is a + * bad MAIL FROM, RCPT, or DATA input. + * @access private + * @return bool + */ + function SmtpSend($header, $body) { + include_once($this->PluginDir . 'class.smtp.php'); + $error = ''; + $bad_rcpt = array(); + + if(!$this->SmtpConnect()) { + return false; + } + + $smtp_from = ($this->Sender == '') ? $this->From : $this->Sender; + if(!$this->smtp->Mail($smtp_from)) { + $error = $this->Lang('from_failed') . $smtp_from; + $this->SetError($error); + $this->smtp->Reset(); + return false; + } + + /* Attempt to send attach all recipients */ + for($i = 0; $i < count($this->to); $i++) { + if(!$this->smtp->Recipient($this->to[$i][0])) { + $bad_rcpt[] = $this->to[$i][0]; + } + } + for($i = 0; $i < count($this->cc); $i++) { + if(!$this->smtp->Recipient($this->cc[$i][0])) { + $bad_rcpt[] = $this->cc[$i][0]; + } + } + for($i = 0; $i < count($this->bcc); $i++) { + if(!$this->smtp->Recipient($this->bcc[$i][0])) { + $bad_rcpt[] = $this->bcc[$i][0]; + } + } + + if(count($bad_rcpt) > 0) { // Create error message + for($i = 0; $i < count($bad_rcpt); $i++) { + if($i != 0) { + $error .= ', '; + } + $error .= $bad_rcpt[$i]; + } + $error = $this->Lang('recipients_failed') . $error; + $this->SetError($error); + $this->smtp->Reset(); + return false; + } + + if(!$this->smtp->Data($header . $body)) { + $this->SetError($this->Lang('data_not_accepted')); + $this->smtp->Reset(); + return false; + } + if($this->SMTPKeepAlive == true) { + $this->smtp->Reset(); + } else { + $this->SmtpClose(); + } + + return true; + } + + /** + * Initiates a connection to an SMTP server. Returns false if the + * operation failed. + * @access private + * @return bool + */ + function SmtpConnect() { + if($this->smtp == NULL) { + $this->smtp = new SMTP(); + } + + $this->smtp->do_debug = $this->SMTPDebug; + $hosts = explode(';', $this->Host); + $index = 0; + $connection = ($this->smtp->Connected()); + + /* Retry while there is no connection */ + while($index < count($hosts) && $connection == false) { + $hostinfo = array(); + if(eregi('^(.+):([0-9]+)$', $hosts[$index], $hostinfo)) { + $host = $hostinfo[1]; + $port = $hostinfo[2]; + } else { + $host = $hosts[$index]; + $port = $this->Port; + } + + if($this->smtp->Connect(((!empty($this->SMTPSecure))?$this->SMTPSecure.'://':'').$host, $port, $this->Timeout)) { + if ($this->Helo != '') { + $this->smtp->Hello($this->Helo); + } else { + $this->smtp->Hello($this->ServerHostname()); + } + + $connection = true; + if($this->SMTPAuth) { + if(!$this->smtp->Authenticate($this->Username, $this->Password)) { + $this->SetError($this->Lang('authenticate')); + $this->smtp->Reset(); + $connection = false; + } + } + } + $index++; + } + if(!$connection) { + $this->SetError($this->Lang('connect_host')); + } + + return $connection; + } + + /** + * Closes the active SMTP session if one exists. + * @return void + */ + function SmtpClose() { + if($this->smtp != NULL) { + if($this->smtp->Connected()) { + $this->smtp->Quit(); + $this->smtp->Close(); + } + } + } + + /** + * Sets the language for all class error messages. Returns false + * if it cannot load the language file. The default language type + * is English. + * @param string $lang_type Type of language (e.g. Portuguese: "br") + * @param string $lang_path Path to the language file directory + * @access public + * @return bool + */ + function SetLanguage($lang_type, $lang_path = 'language/') { + if(file_exists($lang_path.'phpmailer.lang-'.$lang_type.'.php')) { + include($lang_path.'phpmailer.lang-'.$lang_type.'.php'); + } elseif (file_exists($lang_path.'phpmailer.lang-en.php')) { + include($lang_path.'phpmailer.lang-en.php'); + } else { + $this->SetError('Could not load language file'); + return false; + } + $this->language = $PHPMAILER_LANG; + + return true; + } + + ///////////////////////////////////////////////// + // METHODS, MESSAGE CREATION + ///////////////////////////////////////////////// + + /** + * Creates recipient headers. + * @access private + * @return string + */ + function AddrAppend($type, $addr) { + $addr_str = $type . ': '; + $addr_str .= $this->AddrFormat($addr[0]); + if(count($addr) > 1) { + for($i = 1; $i < count($addr); $i++) { + $addr_str .= ', ' . $this->AddrFormat($addr[$i]); + } + } + $addr_str .= $this->LE; + + return $addr_str; + } + + /** + * Formats an address correctly. + * @access private + * @return string + */ + function AddrFormat($addr) { + if(empty($addr[1])) { + $formatted = $this->SecureHeader($addr[0]); + } else { + $formatted = $this->EncodeHeader($this->SecureHeader($addr[1]), 'phrase') . " <" . $this->SecureHeader($addr[0]) . ">"; + } + + return $formatted; + } + + /** + * Wraps message for use with mailers that do not + * automatically perform wrapping and for quoted-printable. + * Original written by philippe. + * @access private + * @return string + */ + function WrapText($message, $length, $qp_mode = false) { + $soft_break = ($qp_mode) ? sprintf(" =%s", $this->LE) : $this->LE; + // If utf-8 encoding is used, we will need to make sure we don't + // split multibyte characters when we wrap + $is_utf8 = (strtolower($this->CharSet) == "utf-8"); + + $message = $this->FixEOL($message); + if (substr($message, -1) == $this->LE) { + $message = substr($message, 0, -1); + } + + $line = explode($this->LE, $message); + $message = ''; + for ($i=0 ;$i < count($line); $i++) { + $line_part = explode(' ', $line[$i]); + $buf = ''; + for ($e = 0; $e $length)) { + $space_left = $length - strlen($buf) - 1; + if ($e != 0) { + if ($space_left > 20) { + $len = $space_left; + if ($is_utf8) { + $len = $this->UTF8CharBoundary($word, $len); + } elseif (substr($word, $len - 1, 1) == "=") { + $len--; + } elseif (substr($word, $len - 2, 1) == "=") { + $len -= 2; + } + $part = substr($word, 0, $len); + $word = substr($word, $len); + $buf .= ' ' . $part; + $message .= $buf . sprintf("=%s", $this->LE); + } else { + $message .= $buf . $soft_break; + } + $buf = ''; + } + while (strlen($word) > 0) { + $len = $length; + if ($is_utf8) { + $len = $this->UTF8CharBoundary($word, $len); + } elseif (substr($word, $len - 1, 1) == "=") { + $len--; + } elseif (substr($word, $len - 2, 1) == "=") { + $len -= 2; + } + $part = substr($word, 0, $len); + $word = substr($word, $len); + + if (strlen($word) > 0) { + $message .= $part . sprintf("=%s", $this->LE); + } else { + $buf = $part; + } + } + } else { + $buf_o = $buf; + $buf .= ($e == 0) ? $word : (' ' . $word); + + if (strlen($buf) > $length and $buf_o != '') { + $message .= $buf_o . $soft_break; + $buf = $word; + } + } + } + $message .= $buf . $this->LE; + } + + return $message; + } + + /** + * Finds last character boundary prior to maxLength in a utf-8 + * quoted (printable) encoded string. + * Original written by Colin Brown. + * @access private + * @param string $encodedText utf-8 QP text + * @param int $maxLength find last character boundary prior to this length + * @return int + */ + function UTF8CharBoundary($encodedText, $maxLength) { + $foundSplitPos = false; + $lookBack = 3; + while (!$foundSplitPos) { + $lastChunk = substr($encodedText, $maxLength - $lookBack, $lookBack); + $encodedCharPos = strpos($lastChunk, "="); + if ($encodedCharPos !== false) { + // Found start of encoded character byte within $lookBack block. + // Check the encoded byte value (the 2 chars after the '=') + $hex = substr($encodedText, $maxLength - $lookBack + $encodedCharPos + 1, 2); + $dec = hexdec($hex); + if ($dec < 128) { // Single byte character. + // If the encoded char was found at pos 0, it will fit + // otherwise reduce maxLength to start of the encoded char + $maxLength = ($encodedCharPos == 0) ? $maxLength : + $maxLength - ($lookBack - $encodedCharPos); + $foundSplitPos = true; + } elseif ($dec >= 192) { // First byte of a multi byte character + // Reduce maxLength to split at start of character + $maxLength = $maxLength - ($lookBack - $encodedCharPos); + $foundSplitPos = true; + } elseif ($dec < 192) { // Middle byte of a multi byte character, look further back + $lookBack += 3; + } + } else { + // No encoded character found + $foundSplitPos = true; + } + } + return $maxLength; + } + + /** + * Set the body wrapping. + * @access private + * @return void + */ + function SetWordWrap() { + if($this->WordWrap < 1) { + return; + } + + switch($this->message_type) { + case 'alt': + /* fall through */ + case 'alt_attachments': + $this->AltBody = $this->WrapText($this->AltBody, $this->WordWrap); + break; + default: + $this->Body = $this->WrapText($this->Body, $this->WordWrap); + break; + } + } + + /** + * Assembles message header. + * @access private + * @return string + */ + function CreateHeader() { + $result = ''; + + /* Set the boundaries */ + $uniq_id = md5(uniqid(time())); + $this->boundary[1] = 'b1_' . $uniq_id; + $this->boundary[2] = 'b2_' . $uniq_id; + + $result .= $this->HeaderLine('Date', $this->RFCDate()); + if($this->Sender == '') { + $result .= $this->HeaderLine('Return-Path', trim($this->From)); + } else { + $result .= $this->HeaderLine('Return-Path', trim($this->Sender)); + } + + /* To be created automatically by mail() */ + if($this->Mailer != 'mail') { + if(count($this->to) > 0) { + $result .= $this->AddrAppend('To', $this->to); + } elseif (count($this->cc) == 0) { + $result .= $this->HeaderLine('To', 'undisclosed-recipients:;'); + } + if(count($this->cc) > 0) { + $result .= $this->AddrAppend('Cc', $this->cc); + } + } + + $from = array(); + $from[0][0] = trim($this->From); + $from[0][1] = $this->FromName; + $result .= $this->AddrAppend('From', $from); + + /* sendmail and mail() extract Cc from the header before sending */ + if((($this->Mailer == 'sendmail') || ($this->Mailer == 'mail')) && (count($this->cc) > 0)) { + $result .= $this->AddrAppend('Cc', $this->cc); + } + + /* sendmail and mail() extract Bcc from the header before sending */ + if((($this->Mailer == 'sendmail') || ($this->Mailer == 'mail')) && (count($this->bcc) > 0)) { + $result .= $this->AddrAppend('Bcc', $this->bcc); + } + + if(count($this->ReplyTo) > 0) { + $result .= $this->AddrAppend('Reply-To', $this->ReplyTo); + } + + /* mail() sets the subject itself */ + if($this->Mailer != 'mail') { + $result .= $this->HeaderLine('Subject', $this->EncodeHeader($this->SecureHeader($this->Subject))); + } + + if($this->MessageID != '') { + $result .= $this->HeaderLine('Message-ID',$this->MessageID); + } else { + $result .= sprintf("Message-ID: <%s@%s>%s", $uniq_id, $this->ServerHostname(), $this->LE); + } + $result .= $this->HeaderLine('X-Priority', $this->Priority); + $result .= $this->HeaderLine('X-Mailer', 'PHPMailer (phpmailer.sourceforge.net) [version ' . $this->Version . ']'); + + if($this->ConfirmReadingTo != '') { + $result .= $this->HeaderLine('Disposition-Notification-To', '<' . trim($this->ConfirmReadingTo) . '>'); + } + + // Add custom headers + for($index = 0; $index < count($this->CustomHeader); $index++) { + $result .= $this->HeaderLine(trim($this->CustomHeader[$index][0]), $this->EncodeHeader(trim($this->CustomHeader[$index][1]))); + } + if (!$this->sign_key_file) { + $result .= $this->HeaderLine('MIME-Version', '1.0'); + $result .= $this->GetMailMIME(); + } + + return $result; + } + + /** + * Returns the message MIME. + * @access private + * @return string + */ + function GetMailMIME() { + $result = ''; + switch($this->message_type) { + case 'plain': + $result .= $this->HeaderLine('Content-Transfer-Encoding', $this->Encoding); + $result .= sprintf("Content-Type: %s; charset=\"%s\"", $this->ContentType, $this->CharSet); + break; + case 'attachments': + /* fall through */ + case 'alt_attachments': + if($this->InlineImageExists()){ + $result .= sprintf("Content-Type: %s;%s\ttype=\"text/html\";%s\tboundary=\"%s\"%s", 'multipart/related', $this->LE, $this->LE, $this->boundary[1], $this->LE); + } else { + $result .= $this->HeaderLine('Content-Type', 'multipart/mixed;'); + $result .= $this->TextLine("\tboundary=\"" . $this->boundary[1] . '"'); + } + break; + case 'alt': + $result .= $this->HeaderLine('Content-Type', 'multipart/alternative;'); + $result .= $this->TextLine("\tboundary=\"" . $this->boundary[1] . '"'); + break; + } + + if($this->Mailer != 'mail') { + $result .= $this->LE.$this->LE; + } + + return $result; + } + + /** + * Assembles the message body. Returns an empty string on failure. + * @access private + * @return string + */ + function CreateBody() { + $result = ''; + if ($this->sign_key_file) { + $result .= $this->GetMailMIME(); + } + + $this->SetWordWrap(); + + switch($this->message_type) { + case 'alt': + $result .= $this->GetBoundary($this->boundary[1], '', 'text/plain', ''); + $result .= $this->EncodeString($this->AltBody, $this->Encoding); + $result .= $this->LE.$this->LE; + $result .= $this->GetBoundary($this->boundary[1], '', 'text/html', ''); + $result .= $this->EncodeString($this->Body, $this->Encoding); + $result .= $this->LE.$this->LE; + $result .= $this->EndBoundary($this->boundary[1]); + break; + case 'plain': + $result .= $this->EncodeString($this->Body, $this->Encoding); + break; + case 'attachments': + $result .= $this->GetBoundary($this->boundary[1], '', '', ''); + $result .= $this->EncodeString($this->Body, $this->Encoding); + $result .= $this->LE; + $result .= $this->AttachAll(); + break; + case 'alt_attachments': + $result .= sprintf("--%s%s", $this->boundary[1], $this->LE); + $result .= sprintf("Content-Type: %s;%s" . "\tboundary=\"%s\"%s", 'multipart/alternative', $this->LE, $this->boundary[2], $this->LE.$this->LE); + $result .= $this->GetBoundary($this->boundary[2], '', 'text/plain', '') . $this->LE; // Create text body + $result .= $this->EncodeString($this->AltBody, $this->Encoding); + $result .= $this->LE.$this->LE; + $result .= $this->GetBoundary($this->boundary[2], '', 'text/html', '') . $this->LE; // Create the HTML body + $result .= $this->EncodeString($this->Body, $this->Encoding); + $result .= $this->LE.$this->LE; + $result .= $this->EndBoundary($this->boundary[2]); + $result .= $this->AttachAll(); + break; + } + + if($this->IsError()) { + $result = ''; + } else if ($this->sign_key_file) { + $file = tempnam("", "mail"); + $fp = fopen($file, "w"); + fwrite($fp, $result); + fclose($fp); + $signed = tempnam("", "signed"); + + if (@openssl_pkcs7_sign($file, $signed, "file://".$this->sign_key_file, array("file://".$this->sign_key_file, $this->sign_key_pass), null)) { + $fp = fopen($signed, "r"); + $result = fread($fp, filesize($this->sign_key_file)); + fclose($fp); + } else { + $this->SetError($this->Lang("signing").openssl_error_string()); + $result = ''; + } + + unlink($file); + unlink($signed); + } + + return $result; + } + + /** + * Returns the start of a message boundary. + * @access private + */ + function GetBoundary($boundary, $charSet, $contentType, $encoding) { + $result = ''; + if($charSet == '') { + $charSet = $this->CharSet; + } + if($contentType == '') { + $contentType = $this->ContentType; + } + if($encoding == '') { + $encoding = $this->Encoding; + } + $result .= $this->TextLine('--' . $boundary); + $result .= sprintf("Content-Type: %s; charset = \"%s\"", $contentType, $charSet); + $result .= $this->LE; + $result .= $this->HeaderLine('Content-Transfer-Encoding', $encoding); + $result .= $this->LE; + + return $result; + } + + /** + * Returns the end of a message boundary. + * @access private + */ + function EndBoundary($boundary) { + return $this->LE . '--' . $boundary . '--' . $this->LE; + } + + /** + * Sets the message type. + * @access private + * @return void + */ + function SetMessageType() { + if(count($this->attachment) < 1 && strlen($this->AltBody) < 1) { + $this->message_type = 'plain'; + } else { + if(count($this->attachment) > 0) { + $this->message_type = 'attachments'; + } + if(strlen($this->AltBody) > 0 && count($this->attachment) < 1) { + $this->message_type = 'alt'; + } + if(strlen($this->AltBody) > 0 && count($this->attachment) > 0) { + $this->message_type = 'alt_attachments'; + } + } + } + + /* Returns a formatted header line. + * @access private + * @return string + */ + function HeaderLine($name, $value) { + return $name . ': ' . $value . $this->LE; + } + + /** + * Returns a formatted mail line. + * @access private + * @return string + */ + function TextLine($value) { + return $value . $this->LE; + } + + ///////////////////////////////////////////////// + // CLASS METHODS, ATTACHMENTS + ///////////////////////////////////////////////// + + /** + * Adds an attachment from a path on the filesystem. + * Returns false if the file could not be found + * or accessed. + * @param string $path Path to the attachment. + * @param string $name Overrides the attachment name. + * @param string $encoding File encoding (see $Encoding). + * @param string $type File extension (MIME) type. + * @return bool + */ + function AddAttachment($path, $name = '', $encoding = 'base64', $type = 'application/octet-stream') { + if(!@is_file($path)) { + $this->SetError($this->Lang('file_access') . $path); + return false; + } + + $filename = basename($path); + if($name == '') { + $name = $filename; + } + + $cur = count($this->attachment); + $this->attachment[$cur][0] = $path; + $this->attachment[$cur][1] = $filename; + $this->attachment[$cur][2] = $name; + $this->attachment[$cur][3] = $encoding; + $this->attachment[$cur][4] = $type; + $this->attachment[$cur][5] = false; // isStringAttachment + $this->attachment[$cur][6] = 'attachment'; + $this->attachment[$cur][7] = 0; + + return true; + } + + /** + * Attaches all fs, string, and binary attachments to the message. + * Returns an empty string on failure. + * @access private + * @return string + */ + function AttachAll() { + /* Return text of body */ + $mime = array(); + + /* Add all attachments */ + for($i = 0; $i < count($this->attachment); $i++) { + /* Check for string attachment */ + $bString = $this->attachment[$i][5]; + if ($bString) { + $string = $this->attachment[$i][0]; + } else { + $path = $this->attachment[$i][0]; + } + + $filename = $this->attachment[$i][1]; + $name = $this->attachment[$i][2]; + $encoding = $this->attachment[$i][3]; + $type = $this->attachment[$i][4]; + $disposition = $this->attachment[$i][6]; + $cid = $this->attachment[$i][7]; + + $mime[] = sprintf("--%s%s", $this->boundary[1], $this->LE); + $mime[] = sprintf("Content-Type: %s; name=\"%s\"%s", $type, $name, $this->LE); + $mime[] = sprintf("Content-Transfer-Encoding: %s%s", $encoding, $this->LE); + + if($disposition == 'inline') { + $mime[] = sprintf("Content-ID: <%s>%s", $cid, $this->LE); + } + + $mime[] = sprintf("Content-Disposition: %s; filename=\"%s\"%s", $disposition, $name, $this->LE.$this->LE); + + /* Encode as string attachment */ + if($bString) { + $mime[] = $this->EncodeString($string, $encoding); + if($this->IsError()) { + return ''; + } + $mime[] = $this->LE.$this->LE; + } else { + $mime[] = $this->EncodeFile($path, $encoding); + if($this->IsError()) { + return ''; + } + $mime[] = $this->LE.$this->LE; + } + } + + $mime[] = sprintf("--%s--%s", $this->boundary[1], $this->LE); + + return join('', $mime); + } + + /** + * Encodes attachment in requested format. Returns an + * empty string on failure. + * @access private + * @return string + */ + function EncodeFile ($path, $encoding = 'base64') { + if(!@$fd = fopen($path, 'rb')) { + $this->SetError($this->Lang('file_open') . $path); + return ''; + } + $magic_quotes = get_magic_quotes_runtime(); + set_magic_quotes_runtime(0); + $file_buffer = fread($fd, filesize($path)); + $file_buffer = $this->EncodeString($file_buffer, $encoding); + fclose($fd); + set_magic_quotes_runtime($magic_quotes); + + return $file_buffer; + } + + /** + * Encodes string to requested format. Returns an + * empty string on failure. + * @access private + * @return string + */ + function EncodeString ($str, $encoding = 'base64') { + $encoded = ''; + switch(strtolower($encoding)) { + case 'base64': + /* chunk_split is found in PHP >= 3.0.6 */ + $encoded = chunk_split(base64_encode($str), 76, $this->LE); + break; + case '7bit': + case '8bit': + $encoded = $this->FixEOL($str); + if (substr($encoded, -(strlen($this->LE))) != $this->LE) + $encoded .= $this->LE; + break; + case 'binary': + $encoded = $str; + break; + case 'quoted-printable': + $encoded = $this->EncodeQP($str); + break; + default: + $this->SetError($this->Lang('encoding') . $encoding); + break; + } + return $encoded; + } + + /** + * Encode a header string to best of Q, B, quoted or none. + * @access private + * @return string + */ + function EncodeHeader ($str, $position = 'text') { + $x = 0; + + switch (strtolower($position)) { + case 'phrase': + if (!preg_match('/[\200-\377]/', $str)) { + /* Can't use addslashes as we don't know what value has magic_quotes_sybase. */ + $encoded = addcslashes($str, "\0..\37\177\\\""); + if (($str == $encoded) && !preg_match('/[^A-Za-z0-9!#$%&\'*+\/=?^_`{|}~ -]/', $str)) { + return ($encoded); + } else { + return ("\"$encoded\""); + } + } + $x = preg_match_all('/[^\040\041\043-\133\135-\176]/', $str, $matches); + break; + case 'comment': + $x = preg_match_all('/[()"]/', $str, $matches); + /* Fall-through */ + case 'text': + default: + $x += preg_match_all('/[\000-\010\013\014\016-\037\177-\377]/', $str, $matches); + break; + } + + if ($x == 0) { + return ($str); + } + + $maxlen = 75 - 7 - strlen($this->CharSet); + /* Try to select the encoding which should produce the shortest output */ + if (strlen($str)/3 < $x) { + $encoding = 'B'; + if (function_exists('mb_strlen') && $this->HasMultiBytes($str)) { + // Use a custom function which correctly encodes and wraps long + // multibyte strings without breaking lines within a character + $encoded = $this->Base64EncodeWrapMB($str); + } else { + $encoded = base64_encode($str); + $maxlen -= $maxlen % 4; + $encoded = trim(chunk_split($encoded, $maxlen, "\n")); + } + } else { + $encoding = 'Q'; + $encoded = $this->EncodeQ($str, $position); + $encoded = $this->WrapText($encoded, $maxlen, true); + $encoded = str_replace('='.$this->LE, "\n", trim($encoded)); + } + + $encoded = preg_replace('/^(.*)$/m', " =?".$this->CharSet."?$encoding?\\1?=", $encoded); + $encoded = trim(str_replace("\n", $this->LE, $encoded)); + + return $encoded; + } + + /** + * Checks if a string contains multibyte characters. + * @access private + * @param string $str multi-byte text to wrap encode + * @return bool + */ + function HasMultiBytes($str) { + if (function_exists('mb_strlen')) { + return (strlen($str) > mb_strlen($str, $this->CharSet)); + } else { // Assume no multibytes (we can't handle without mbstring functions anyway) + return False; + } + } + + /** + * Correctly encodes and wraps long multibyte strings for mail headers + * without breaking lines within a character. + * Adapted from a function by paravoid at http://uk.php.net/manual/en/function.mb-encode-mimeheader.php + * @access private + * @param string $str multi-byte text to wrap encode + * @return string + */ + function Base64EncodeWrapMB($str) { + $start = "=?".$this->CharSet."?B?"; + $end = "?="; + $encoded = ""; + + $mb_length = mb_strlen($str, $this->CharSet); + // Each line must have length <= 75, including $start and $end + $length = 75 - strlen($start) - strlen($end); + // Average multi-byte ratio + $ratio = $mb_length / strlen($str); + // Base64 has a 4:3 ratio + $offset = $avgLength = floor($length * $ratio * .75); + + for ($i = 0; $i < $mb_length; $i += $offset) { + $lookBack = 0; + + do { + $offset = $avgLength - $lookBack; + $chunk = mb_substr($str, $i, $offset, $this->CharSet); + $chunk = base64_encode($chunk); + $lookBack++; + } + while (strlen($chunk) > $length); + + $encoded .= $chunk . $this->LE; + } + + // Chomp the last linefeed + $encoded = substr($encoded, 0, -strlen($this->LE)); + return $encoded; + } + + /** + * Encode string to quoted-printable. + * @access private + * @return string + */ + function EncodeQP( $input = '', $line_max = 76, $space_conv = false ) { + $hex = array('0','1','2','3','4','5','6','7','8','9','A','B','C','D','E','F'); + $lines = preg_split('/(?:\r\n|\r|\n)/', $input); + $eol = "\r\n"; + $escape = '='; + $output = ''; + while( list(, $line) = each($lines) ) { + $linlen = strlen($line); + $newline = ''; + for($i = 0; $i < $linlen; $i++) { + $c = substr( $line, $i, 1 ); + $dec = ord( $c ); + if ( ( $i == 0 ) && ( $dec == 46 ) ) { // convert first point in the line into =2E + $c = '=2E'; + } + if ( $dec == 32 ) { + if ( $i == ( $linlen - 1 ) ) { // convert space at eol only + $c = '=20'; + } else if ( $space_conv ) { + $c = '=20'; + } + } elseif ( ($dec == 61) || ($dec < 32 ) || ($dec > 126) ) { // always encode "\t", which is *not* required + $h2 = floor($dec/16); + $h1 = floor($dec%16); + $c = $escape.$hex[$h2].$hex[$h1]; + } + if ( (strlen($newline) + strlen($c)) >= $line_max ) { // CRLF is not counted + $output .= $newline.$escape.$eol; // soft line break; " =\r\n" is okay + $newline = ''; + // check if newline first character will be point or not + if ( $dec == 46 ) { + $c = '=2E'; + } + } + $newline .= $c; + } // end of for + $output .= $newline.$eol; + } // end of while + return trim($output); + } + + /** + * Encode string to q encoding. + * @access private + * @return string + */ + function EncodeQ ($str, $position = 'text') { + /* There should not be any EOL in the string */ + $encoded = preg_replace("[\r\n]", '', $str); + + switch (strtolower($position)) { + case 'phrase': + $encoded = preg_replace("/([^A-Za-z0-9!*+\/ -])/e", "'='.sprintf('%02X', ord('\\1'))", $encoded); + break; + case 'comment': + $encoded = preg_replace("/([\(\)\"])/e", "'='.sprintf('%02X', ord('\\1'))", $encoded); + case 'text': + default: + /* Replace every high ascii, control =, ? and _ characters */ + $encoded = preg_replace('/([\000-\011\013\014\016-\037\075\077\137\177-\377])/e', + "'='.sprintf('%02X', ord('\\1'))", $encoded); + break; + } + + /* Replace every spaces to _ (more readable than =20) */ + $encoded = str_replace(' ', '_', $encoded); + + return $encoded; + } + + /** + * Adds a string or binary attachment (non-filesystem) to the list. + * This method can be used to attach ascii or binary data, + * such as a BLOB record from a database. + * @param string $string String attachment data. + * @param string $filename Name of the attachment. + * @param string $encoding File encoding (see $Encoding). + * @param string $type File extension (MIME) type. + * @return void + */ + function AddStringAttachment($string, $filename, $encoding = 'base64', $type = 'application/octet-stream') { + /* Append to $attachment array */ + $cur = count($this->attachment); + $this->attachment[$cur][0] = $string; + $this->attachment[$cur][1] = $filename; + $this->attachment[$cur][2] = $filename; + $this->attachment[$cur][3] = $encoding; + $this->attachment[$cur][4] = $type; + $this->attachment[$cur][5] = true; // isString + $this->attachment[$cur][6] = 'attachment'; + $this->attachment[$cur][7] = 0; + } + + /** + * Adds an embedded attachment. This can include images, sounds, and + * just about any other document. Make sure to set the $type to an + * image type. For JPEG images use "image/jpeg" and for GIF images + * use "image/gif". + * @param string $path Path to the attachment. + * @param string $cid Content ID of the attachment. Use this to identify + * the Id for accessing the image in an HTML form. + * @param string $name Overrides the attachment name. + * @param string $encoding File encoding (see $Encoding). + * @param string $type File extension (MIME) type. + * @return bool + */ + function AddEmbeddedImage($path, $cid, $name = '', $encoding = 'base64', $type = 'application/octet-stream') { + + if(!@is_file($path)) { + $this->SetError($this->Lang('file_access') . $path); + return false; + } + + $filename = basename($path); + if($name == '') { + $name = $filename; + } + + /* Append to $attachment array */ + $cur = count($this->attachment); + $this->attachment[$cur][0] = $path; + $this->attachment[$cur][1] = $filename; + $this->attachment[$cur][2] = $name; + $this->attachment[$cur][3] = $encoding; + $this->attachment[$cur][4] = $type; + $this->attachment[$cur][5] = false; + $this->attachment[$cur][6] = 'inline'; + $this->attachment[$cur][7] = $cid; + + return true; + } + + /** + * Returns true if an inline attachment is present. + * @access private + * @return bool + */ + function InlineImageExists() { + $result = false; + for($i = 0; $i < count($this->attachment); $i++) { + if($this->attachment[$i][6] == 'inline') { + $result = true; + break; + } + } + + return $result; + } + + ///////////////////////////////////////////////// + // CLASS METHODS, MESSAGE RESET + ///////////////////////////////////////////////// + + /** + * Clears all recipients assigned in the TO array. Returns void. + * @return void + */ + function ClearAddresses() { + $this->to = array(); + } + + /** + * Clears all recipients assigned in the CC array. Returns void. + * @return void + */ + function ClearCCs() { + $this->cc = array(); + } + + /** + * Clears all recipients assigned in the BCC array. Returns void. + * @return void + */ + function ClearBCCs() { + $this->bcc = array(); + } + + /** + * Clears all recipients assigned in the ReplyTo array. Returns void. + * @return void + */ + function ClearReplyTos() { + $this->ReplyTo = array(); + } + + /** + * Clears all recipients assigned in the TO, CC and BCC + * array. Returns void. + * @return void + */ + function ClearAllRecipients() { + $this->to = array(); + $this->cc = array(); + $this->bcc = array(); + } + + /** + * Clears all previously set filesystem, string, and binary + * attachments. Returns void. + * @return void + */ + function ClearAttachments() { + $this->attachment = array(); + } + + /** + * Clears all custom headers. Returns void. + * @return void + */ + function ClearCustomHeaders() { + $this->CustomHeader = array(); + } + + ///////////////////////////////////////////////// + // CLASS METHODS, MISCELLANEOUS + ///////////////////////////////////////////////// + + /** + * Adds the error message to the error container. + * Returns void. + * @access private + * @return void + */ + function SetError($msg) { + $this->error_count++; + $this->ErrorInfo = $msg; + } + + /** + * Returns the proper RFC 822 formatted date. + * @access private + * @return string + */ + function RFCDate() { + $tz = date('Z'); + $tzs = ($tz < 0) ? '-' : '+'; + $tz = abs($tz); + $tz = (int)($tz/3600)*100 + ($tz%3600)/60; + $result = sprintf("%s %s%04d", date('D, j M Y H:i:s'), $tzs, $tz); + + return $result; + } + + /** + * Returns the appropriate server variable. Should work with both + * PHP 4.1.0+ as well as older versions. Returns an empty string + * if nothing is found. + * @access private + * @return mixed + */ + function ServerVar($varName) { + global $HTTP_SERVER_VARS; + global $HTTP_ENV_VARS; + + if(!isset($_SERVER)) { + $_SERVER = $HTTP_SERVER_VARS; + if(!isset($_SERVER['REMOTE_ADDR'])) { + $_SERVER = $HTTP_ENV_VARS; // must be Apache + } + } + + if(isset($_SERVER[$varName])) { + return $_SERVER[$varName]; + } else { + return ''; + } + } + + /** + * Returns the server hostname or 'localhost.localdomain' if unknown. + * @access private + * @return string + */ + function ServerHostname() { + if ($this->Hostname != '') { + $result = $this->Hostname; + } elseif ($this->ServerVar('SERVER_NAME') != '') { + $result = $this->ServerVar('SERVER_NAME'); + } else { + $result = 'localhost.localdomain'; + } + + return $result; + } + + /** + * Returns a message in the appropriate language. + * @access private + * @return string + */ + function Lang($key) { + if(count($this->language) < 1) { + $this->SetLanguage('en'); // set the default language + } + + if(isset($this->language[$key])) { + return $this->language[$key]; + } else { + return 'Language string failed to load: ' . $key; + } + } + + /** + * Returns true if an error occurred. + * @return bool + */ + function IsError() { + return ($this->error_count > 0); + } + + /** + * Changes every end of line from CR or LF to CRLF. + * @access private + * @return string + */ + function FixEOL($str) { + $str = str_replace("\r\n", "\n", $str); + $str = str_replace("\r", "\n", $str); + $str = str_replace("\n", $this->LE, $str); + return $str; + } + + /** + * Adds a custom header. + * @return void + */ + function AddCustomHeader($custom_header) { + $this->CustomHeader[] = explode(':', $custom_header, 2); + } + + /** + * Evaluates the message and returns modifications for inline images and backgrounds + * @access public + * @return $message + */ + function MsgHTML($message,$basedir='') { + preg_match_all("/(src|background)=\"(.*)\"/Ui", $message, $images); + if(isset($images[2])) { + foreach($images[2] as $i => $url) { + // do not change urls for absolute images (thanks to corvuscorax) + if (!preg_match('/^[A-z][A-z]*:\/\//',$url)) { + $filename = basename($url); + $directory = dirname($url); + ($directory == '.')?$directory='':''; + $cid = 'cid:' . md5($filename); + $fileParts = split("\.", $filename); + $ext = $fileParts[1]; + $mimeType = $this->_mime_types($ext); + if ( strlen($basedir) > 1 && substr($basedir,-1) != '/') { $basedir .= '/'; } + if ( strlen($directory) > 1 && substr($basedir,-1) != '/') { $directory .= '/'; } + $this->AddEmbeddedImage($basedir.$directory.$filename, md5($filename), $filename, 'base64', $mimeType); + if ( $this->AddEmbeddedImage($basedir.$directory.$filename, md5($filename), $filename, 'base64',$mimeType) ) { + $message = preg_replace("/".$images[1][$i]."=\"".preg_quote($url, '/')."\"/Ui", $images[1][$i]."=\"".$cid."\"", $message); + } + } + } + } + $this->IsHTML(true); + $this->Body = $message; + $textMsg = trim(strip_tags(preg_replace('/<(head|title|style|script)[^>]*>.*?<\/\\1>/s','',$message))); + if ( !empty($textMsg) && empty($this->AltBody) ) { + $this->AltBody = $textMsg; + } + if ( empty($this->AltBody) ) { + $this->AltBody = 'To view this email message, open the email in with HTML compatibility!' . "\n\n"; + } + } + + /** + * Gets the mime type of the embedded or inline image + * @access private + * @return mime type of ext + */ + function _mime_types($ext = '') { + $mimes = array( + 'hqx' => 'application/mac-binhex40', + 'cpt' => 'application/mac-compactpro', + 'doc' => 'application/msword', + 'bin' => 'application/macbinary', + 'dms' => 'application/octet-stream', + 'lha' => 'application/octet-stream', + 'lzh' => 'application/octet-stream', + 'exe' => 'application/octet-stream', + 'class' => 'application/octet-stream', + 'psd' => 'application/octet-stream', + 'so' => 'application/octet-stream', + 'sea' => 'application/octet-stream', + 'dll' => 'application/octet-stream', + 'oda' => 'application/oda', + 'pdf' => 'application/pdf', + 'ai' => 'application/postscript', + 'eps' => 'application/postscript', + 'ps' => 'application/postscript', + 'smi' => 'application/smil', + 'smil' => 'application/smil', + 'mif' => 'application/vnd.mif', + 'xls' => 'application/vnd.ms-excel', + 'ppt' => 'application/vnd.ms-powerpoint', + 'wbxml' => 'application/vnd.wap.wbxml', + 'wmlc' => 'application/vnd.wap.wmlc', + 'dcr' => 'application/x-director', + 'dir' => 'application/x-director', + 'dxr' => 'application/x-director', + 'dvi' => 'application/x-dvi', + 'gtar' => 'application/x-gtar', + 'php' => 'application/x-httpd-php', + 'php4' => 'application/x-httpd-php', + 'php3' => 'application/x-httpd-php', + 'phtml' => 'application/x-httpd-php', + 'phps' => 'application/x-httpd-php-source', + 'js' => 'application/x-javascript', + 'swf' => 'application/x-shockwave-flash', + 'sit' => 'application/x-stuffit', + 'tar' => 'application/x-tar', + 'tgz' => 'application/x-tar', + 'xhtml' => 'application/xhtml+xml', + 'xht' => 'application/xhtml+xml', + 'zip' => 'application/zip', + 'mid' => 'audio/midi', + 'midi' => 'audio/midi', + 'mpga' => 'audio/mpeg', + 'mp2' => 'audio/mpeg', + 'mp3' => 'audio/mpeg', + 'aif' => 'audio/x-aiff', + 'aiff' => 'audio/x-aiff', + 'aifc' => 'audio/x-aiff', + 'ram' => 'audio/x-pn-realaudio', + 'rm' => 'audio/x-pn-realaudio', + 'rpm' => 'audio/x-pn-realaudio-plugin', + 'ra' => 'audio/x-realaudio', + 'rv' => 'video/vnd.rn-realvideo', + 'wav' => 'audio/x-wav', + 'bmp' => 'image/bmp', + 'gif' => 'image/gif', + 'jpeg' => 'image/jpeg', + 'jpg' => 'image/jpeg', + 'jpe' => 'image/jpeg', + 'png' => 'image/png', + 'tiff' => 'image/tiff', + 'tif' => 'image/tiff', + 'css' => 'text/css', + 'html' => 'text/html', + 'htm' => 'text/html', + 'shtml' => 'text/html', + 'txt' => 'text/plain', + 'text' => 'text/plain', + 'log' => 'text/plain', + 'rtx' => 'text/richtext', + 'rtf' => 'text/rtf', + 'xml' => 'text/xml', + 'xsl' => 'text/xml', + 'mpeg' => 'video/mpeg', + 'mpg' => 'video/mpeg', + 'mpe' => 'video/mpeg', + 'qt' => 'video/quicktime', + 'mov' => 'video/quicktime', + 'avi' => 'video/x-msvideo', + 'movie' => 'video/x-sgi-movie', + 'doc' => 'application/msword', + 'word' => 'application/msword', + 'xl' => 'application/excel', + 'eml' => 'message/rfc822' + ); + return ( ! isset($mimes[strtolower($ext)])) ? 'application/octet-stream' : $mimes[strtolower($ext)]; + } + + /** + * Set (or reset) Class Objects (variables) + * + * Usage Example: + * $page->set('X-Priority', '3'); + * + * @access public + * @param string $name Parameter Name + * @param mixed $value Parameter Value + * NOTE: will not work with arrays, there are no arrays to set/reset + */ + function set ( $name, $value = '' ) { + if ( isset($this->$name) ) { + $this->$name = $value; + } else { + $this->SetError('Cannot set or reset variable ' . $name); + return false; + } + } + + /** + * Read a file from a supplied filename and return it. + * + * @access public + * @param string $filename Parameter File Name + */ + function getFile($filename) { + $return = ''; + if ($fp = fopen($filename, 'rb')) { + while (!feof($fp)) { + $return .= fread($fp, 1024); + } + fclose($fp); + return $return; + } else { + return false; + } + } + + /** + * Strips newlines to prevent header injection. + * @access private + * @param string $str String + * @return string + */ + function SecureHeader($str) { + $str = trim($str); + $str = str_replace("\r", "", $str); + $str = str_replace("\n", "", $str); + return $str; + } + + /** + * Set the private key file and password to sign the message. + * + * @access public + * @param string $key_filename Parameter File Name + * @param string $key_pass Password for private key + */ + function Sign($key_filename, $key_pass) { + $this->sign_key_file = $key_filename; + $this->sign_key_pass = $key_pass; + } + +} + +?> diff --git a/config/freeswitch_dev/class.smtp.tmp b/config/freeswitch_dev/class.smtp.tmp new file mode 100755 index 00000000..398c3ffb --- /dev/null +++ b/config/freeswitch_dev/class.smtp.tmp @@ -0,0 +1,1062 @@ +smtp_conn = 0; + $this->error = null; + $this->helo_rply = null; + + $this->do_debug = 0; + } + + /************************************************************* + * CONNECTION FUNCTIONS * + ***********************************************************/ + + /** + * Connect to the server specified on the port specified. + * If the port is not specified use the default SMTP_PORT. + * If tval is specified then a connection will try and be + * established with the server for that number of seconds. + * If tval is not specified the default is 30 seconds to + * try on the connection. + * + * SMTP CODE SUCCESS: 220 + * SMTP CODE FAILURE: 421 + * @access public + * @return bool + */ + function Connect($host,$port=0,$tval=30) { + # set the error val to null so there is no confusion + $this->error = null; + + # make sure we are __not__ connected + if($this->connected()) { + # ok we are connected! what should we do? + # for now we will just give an error saying we + # are already connected + $this->error = array("error" => "Already connected to a server"); + return false; + } + + if(empty($port)) { + $port = $this->SMTP_PORT; + } + + #connect to the smtp server + $this->smtp_conn = fsockopen($host, # the host of the server + $port, # the port to use + $errno, # error number if any + $errstr, # error message if any + $tval); # give up after ? secs + # verify we connected properly + if(empty($this->smtp_conn)) { + $this->error = array("error" => "Failed to connect to server", + "errno" => $errno, + "errstr" => $errstr); + if($this->do_debug >= 1) { + echo "SMTP -> ERROR: " . $this->error["error"] . + ": $errstr ($errno)" . $this->CRLF; + } + return false; + } + + # sometimes the SMTP server takes a little longer to respond + # so we will give it a longer timeout for the first read + // Windows still does not have support for this timeout function + if(substr(PHP_OS, 0, 3) != "WIN") + socket_set_timeout($this->smtp_conn, $tval, 0); + + # get any announcement stuff + $announce = $this->get_lines(); + + # set the timeout of any socket functions at 1/10 of a second + //if(function_exists("socket_set_timeout")) + // socket_set_timeout($this->smtp_conn, 0, 100000); + + if($this->do_debug >= 2) { + echo "SMTP -> FROM SERVER:" . $this->CRLF . $announce; + } + + return true; + } + + /** + * Performs SMTP authentication. Must be run after running the + * Hello() method. Returns true if successfully authenticated. + * @access public + * @return bool + */ + function Authenticate($username, $password) { + // Start authentication + fputs($this->smtp_conn,"AUTH LOGIN" . $this->CRLF); + + $rply = $this->get_lines(); + $code = substr($rply,0,3); + + if($code != 334) { + $this->error = + array("error" => "AUTH not accepted from server", + "smtp_code" => $code, + "smtp_msg" => substr($rply,4)); + if($this->do_debug >= 1) { + echo "SMTP -> ERROR: " . $this->error["error"] . + ": " . $rply . $this->CRLF; + } + return false; + } + + // Send encoded username + fputs($this->smtp_conn, base64_encode($username) . $this->CRLF); + + $rply = $this->get_lines(); + $code = substr($rply,0,3); + + if($code != 334) { + $this->error = + array("error" => "Username not accepted from server", + "smtp_code" => $code, + "smtp_msg" => substr($rply,4)); + if($this->do_debug >= 1) { + echo "SMTP -> ERROR: " . $this->error["error"] . + ": " . $rply . $this->CRLF; + } + return false; + } + + // Send encoded password + fputs($this->smtp_conn, base64_encode($password) . $this->CRLF); + + $rply = $this->get_lines(); + $code = substr($rply,0,3); + + if($code != 235) { + $this->error = + array("error" => "Password not accepted from server", + "smtp_code" => $code, + "smtp_msg" => substr($rply,4)); + if($this->do_debug >= 1) { + echo "SMTP -> ERROR: " . $this->error["error"] . + ": " . $rply . $this->CRLF; + } + return false; + } + + return true; + } + + /** + * Returns true if connected to a server otherwise false + * @access private + * @return bool + */ + function Connected() { + if(!empty($this->smtp_conn)) { + $sock_status = socket_get_status($this->smtp_conn); + if($sock_status["eof"]) { + # hmm this is an odd situation... the socket is + # valid but we are not connected anymore + if($this->do_debug >= 1) { + echo "SMTP -> NOTICE:" . $this->CRLF . + "EOF caught while checking if connected"; + } + $this->Close(); + return false; + } + return true; # everything looks good + } + return false; + } + + /** + * Closes the socket and cleans up the state of the class. + * It is not considered good to use this function without + * first trying to use QUIT. + * @access public + * @return void + */ + function Close() { + $this->error = null; # so there is no confusion + $this->helo_rply = null; + if(!empty($this->smtp_conn)) { + # close the connection and cleanup + fclose($this->smtp_conn); + $this->smtp_conn = 0; + } + } + + /*************************************************************** + * SMTP COMMANDS * + *************************************************************/ + + /** + * Issues a data command and sends the msg_data to the server + * finializing the mail transaction. $msg_data is the message + * that is to be send with the headers. Each header needs to be + * on a single line followed by a with the message headers + * and the message body being seperated by and additional . + * + * Implements rfc 821: DATA + * + * SMTP CODE INTERMEDIATE: 354 + * [data] + * . + * SMTP CODE SUCCESS: 250 + * SMTP CODE FAILURE: 552,554,451,452 + * SMTP CODE FAILURE: 451,554 + * SMTP CODE ERROR : 500,501,503,421 + * @access public + * @return bool + */ + function Data($msg_data) { + $this->error = null; # so no confusion is caused + + if(!$this->connected()) { + $this->error = array( + "error" => "Called Data() without being connected"); + return false; + } + + fputs($this->smtp_conn,"DATA" . $this->CRLF); + + $rply = $this->get_lines(); + $code = substr($rply,0,3); + + if($this->do_debug >= 2) { + echo "SMTP -> FROM SERVER:" . $this->CRLF . $rply; + } + + if($code != 354) { + $this->error = + array("error" => "DATA command not accepted from server", + "smtp_code" => $code, + "smtp_msg" => substr($rply,4)); + if($this->do_debug >= 1) { + echo "SMTP -> ERROR: " . $this->error["error"] . + ": " . $rply . $this->CRLF; + } + return false; + } + + # the server is ready to accept data! + # according to rfc 821 we should not send more than 1000 + # including the CRLF + # characters on a single line so we will break the data up + # into lines by \r and/or \n then if needed we will break + # each of those into smaller lines to fit within the limit. + # in addition we will be looking for lines that start with + # a period '.' and append and additional period '.' to that + # line. NOTE: this does not count towards are limit. + + # normalize the line breaks so we know the explode works + $msg_data = str_replace("\r\n","\n",$msg_data); + $msg_data = str_replace("\r","\n",$msg_data); + $lines = explode("\n",$msg_data); + + # we need to find a good way to determine is headers are + # in the msg_data or if it is a straight msg body + # currently I am assuming rfc 822 definitions of msg headers + # and if the first field of the first line (':' sperated) + # does not contain a space then it _should_ be a header + # and we can process all lines before a blank "" line as + # headers. + $field = substr($lines[0],0,strpos($lines[0],":")); + $in_headers = false; + if(!empty($field) && !strstr($field," ")) { + $in_headers = true; + } + + $max_line_length = 998; # used below; set here for ease in change + + while(list(,$line) = @each($lines)) { + $lines_out = null; + if($line == "" && $in_headers) { + $in_headers = false; + } + # ok we need to break this line up into several + # smaller lines + while(strlen($line) > $max_line_length) { + $pos = strrpos(substr($line,0,$max_line_length)," "); + + # Patch to fix DOS attack + if(!$pos) { + $pos = $max_line_length - 1; + } + + $lines_out[] = substr($line,0,$pos); + $line = substr($line,$pos + 1); + # if we are processing headers we need to + # add a LWSP-char to the front of the new line + # rfc 822 on long msg headers + if($in_headers) { + $line = "\t" . $line; + } + } + $lines_out[] = $line; + + # now send the lines to the server + while(list(,$line_out) = @each($lines_out)) { + if(strlen($line_out) > 0) + { + if(substr($line_out, 0, 1) == ".") { + $line_out = "." . $line_out; + } + } + fputs($this->smtp_conn,$line_out . $this->CRLF); + } + } + + # ok all the message data has been sent so lets get this + # over with aleady + fputs($this->smtp_conn, $this->CRLF . "." . $this->CRLF); + + $rply = $this->get_lines(); + $code = substr($rply,0,3); + + if($this->do_debug >= 2) { + echo "SMTP -> FROM SERVER:" . $this->CRLF . $rply; + } + + if($code != 250) { + $this->error = + array("error" => "DATA not accepted from server", + "smtp_code" => $code, + "smtp_msg" => substr($rply,4)); + if($this->do_debug >= 1) { + echo "SMTP -> ERROR: " . $this->error["error"] . + ": " . $rply . $this->CRLF; + } + return false; + } + return true; + } + + /** + * Expand takes the name and asks the server to list all the + * people who are members of the _list_. Expand will return + * back and array of the result or false if an error occurs. + * Each value in the array returned has the format of: + * [ ] + * The definition of is defined in rfc 821 + * + * Implements rfc 821: EXPN + * + * SMTP CODE SUCCESS: 250 + * SMTP CODE FAILURE: 550 + * SMTP CODE ERROR : 500,501,502,504,421 + * @access public + * @return string array + */ + function Expand($name) { + $this->error = null; # so no confusion is caused + + if(!$this->connected()) { + $this->error = array( + "error" => "Called Expand() without being connected"); + return false; + } + + fputs($this->smtp_conn,"EXPN " . $name . $this->CRLF); + + $rply = $this->get_lines(); + $code = substr($rply,0,3); + + if($this->do_debug >= 2) { + echo "SMTP -> FROM SERVER:" . $this->CRLF . $rply; + } + + if($code != 250) { + $this->error = + array("error" => "EXPN not accepted from server", + "smtp_code" => $code, + "smtp_msg" => substr($rply,4)); + if($this->do_debug >= 1) { + echo "SMTP -> ERROR: " . $this->error["error"] . + ": " . $rply . $this->CRLF; + } + return false; + } + + # parse the reply and place in our array to return to user + $entries = explode($this->CRLF,$rply); + while(list(,$l) = @each($entries)) { + $list[] = substr($l,4); + } + + return $list; + } + + /** + * Sends the HELO command to the smtp server. + * This makes sure that we and the server are in + * the same known state. + * + * Implements from rfc 821: HELO + * + * SMTP CODE SUCCESS: 250 + * SMTP CODE ERROR : 500, 501, 504, 421 + * @access public + * @return bool + */ + function Hello($host="") { + $this->error = null; # so no confusion is caused + + if(!$this->connected()) { + $this->error = array( + "error" => "Called Hello() without being connected"); + return false; + } + + # if a hostname for the HELO was not specified determine + # a suitable one to send + if(empty($host)) { + # we need to determine some sort of appopiate default + # to send to the server + $host = "localhost"; + } + + // Send extended hello first (RFC 2821) + if(!$this->SendHello("EHLO", $host)) + { + if(!$this->SendHello("HELO", $host)) + return false; + } + + return true; + } + + /** + * Sends a HELO/EHLO command. + * @access private + * @return bool + */ + function SendHello($hello, $host) { + fputs($this->smtp_conn, $hello . " " . $host . $this->CRLF); + + $rply = $this->get_lines(); + $code = substr($rply,0,3); + + if($this->do_debug >= 2) { + echo "SMTP -> FROM SERVER: " . $this->CRLF . $rply; + } + + if($code != 250) { + $this->error = + array("error" => $hello . " not accepted from server", + "smtp_code" => $code, + "smtp_msg" => substr($rply,4)); + if($this->do_debug >= 1) { + echo "SMTP -> ERROR: " . $this->error["error"] . + ": " . $rply . $this->CRLF; + } + return false; + } + + $this->helo_rply = $rply; + + return true; + } + + /** + * Gets help information on the keyword specified. If the keyword + * is not specified then returns generic help, ussually contianing + * A list of keywords that help is available on. This function + * returns the results back to the user. It is up to the user to + * handle the returned data. If an error occurs then false is + * returned with $this->error set appropiately. + * + * Implements rfc 821: HELP [ ] + * + * SMTP CODE SUCCESS: 211,214 + * SMTP CODE ERROR : 500,501,502,504,421 + * @access public + * @return string + */ + function Help($keyword="") { + $this->error = null; # to avoid confusion + + if(!$this->connected()) { + $this->error = array( + "error" => "Called Help() without being connected"); + return false; + } + + $extra = ""; + if(!empty($keyword)) { + $extra = " " . $keyword; + } + + fputs($this->smtp_conn,"HELP" . $extra . $this->CRLF); + + $rply = $this->get_lines(); + $code = substr($rply,0,3); + + if($this->do_debug >= 2) { + echo "SMTP -> FROM SERVER:" . $this->CRLF . $rply; + } + + if($code != 211 && $code != 214) { + $this->error = + array("error" => "HELP not accepted from server", + "smtp_code" => $code, + "smtp_msg" => substr($rply,4)); + if($this->do_debug >= 1) { + echo "SMTP -> ERROR: " . $this->error["error"] . + ": " . $rply . $this->CRLF; + } + return false; + } + + return $rply; + } + + /** + * Starts a mail transaction from the email address specified in + * $from. Returns true if successful or false otherwise. If True + * the mail transaction is started and then one or more Recipient + * commands may be called followed by a Data command. + * + * Implements rfc 821: MAIL FROM: + * + * SMTP CODE SUCCESS: 250 + * SMTP CODE SUCCESS: 552,451,452 + * SMTP CODE SUCCESS: 500,501,421 + * @access public + * @return bool + */ + function Mail($from) { + $this->error = null; # so no confusion is caused + + if(!$this->connected()) { + $this->error = array( + "error" => "Called Mail() without being connected"); + return false; + } + + $useVerp = ($this->do_verp ? "XVERP" : ""); + fputs($this->smtp_conn,"MAIL FROM:<" . $from . ">" . $useVerp . $this->CRLF); + + $rply = $this->get_lines(); + $code = substr($rply,0,3); + + if($this->do_debug >= 2) { + echo "SMTP -> FROM SERVER:" . $this->CRLF . $rply; + } + + if($code != 250) { + $this->error = + array("error" => "MAIL not accepted from server", + "smtp_code" => $code, + "smtp_msg" => substr($rply,4)); + if($this->do_debug >= 1) { + echo "SMTP -> ERROR: " . $this->error["error"] . + ": " . $rply . $this->CRLF; + } + return false; + } + return true; + } + + /** + * Sends the command NOOP to the SMTP server. + * + * Implements from rfc 821: NOOP + * + * SMTP CODE SUCCESS: 250 + * SMTP CODE ERROR : 500, 421 + * @access public + * @return bool + */ + function Noop() { + $this->error = null; # so no confusion is caused + + if(!$this->connected()) { + $this->error = array( + "error" => "Called Noop() without being connected"); + return false; + } + + fputs($this->smtp_conn,"NOOP" . $this->CRLF); + + $rply = $this->get_lines(); + $code = substr($rply,0,3); + + if($this->do_debug >= 2) { + echo "SMTP -> FROM SERVER:" . $this->CRLF . $rply; + } + + if($code != 250) { + $this->error = + array("error" => "NOOP not accepted from server", + "smtp_code" => $code, + "smtp_msg" => substr($rply,4)); + if($this->do_debug >= 1) { + echo "SMTP -> ERROR: " . $this->error["error"] . + ": " . $rply . $this->CRLF; + } + return false; + } + return true; + } + + /** + * Sends the quit command to the server and then closes the socket + * if there is no error or the $close_on_error argument is true. + * + * Implements from rfc 821: QUIT + * + * SMTP CODE SUCCESS: 221 + * SMTP CODE ERROR : 500 + * @access public + * @return bool + */ + function Quit($close_on_error=true) { + $this->error = null; # so there is no confusion + + if(!$this->connected()) { + $this->error = array( + "error" => "Called Quit() without being connected"); + return false; + } + + # send the quit command to the server + fputs($this->smtp_conn,"quit" . $this->CRLF); + + # get any good-bye messages + $byemsg = $this->get_lines(); + + if($this->do_debug >= 2) { + echo "SMTP -> FROM SERVER:" . $this->CRLF . $byemsg; + } + + $rval = true; + $e = null; + + $code = substr($byemsg,0,3); + if($code != 221) { + # use e as a tmp var cause Close will overwrite $this->error + $e = array("error" => "SMTP server rejected quit command", + "smtp_code" => $code, + "smtp_rply" => substr($byemsg,4)); + $rval = false; + if($this->do_debug >= 1) { + echo "SMTP -> ERROR: " . $e["error"] . ": " . + $byemsg . $this->CRLF; + } + } + + if(empty($e) || $close_on_error) { + $this->Close(); + } + + return $rval; + } + + /** + * Sends the command RCPT to the SMTP server with the TO: argument of $to. + * Returns true if the recipient was accepted false if it was rejected. + * + * Implements from rfc 821: RCPT TO: + * + * SMTP CODE SUCCESS: 250,251 + * SMTP CODE FAILURE: 550,551,552,553,450,451,452 + * SMTP CODE ERROR : 500,501,503,421 + * @access public + * @return bool + */ + function Recipient($to) { + $this->error = null; # so no confusion is caused + + if(!$this->connected()) { + $this->error = array( + "error" => "Called Recipient() without being connected"); + return false; + } + + fputs($this->smtp_conn,"RCPT TO:<" . $to . ">" . $this->CRLF); + + $rply = $this->get_lines(); + $code = substr($rply,0,3); + + if($this->do_debug >= 2) { + echo "SMTP -> FROM SERVER:" . $this->CRLF . $rply; + } + + if($code != 250 && $code != 251) { + $this->error = + array("error" => "RCPT not accepted from server", + "smtp_code" => $code, + "smtp_msg" => substr($rply,4)); + if($this->do_debug >= 1) { + echo "SMTP -> ERROR: " . $this->error["error"] . + ": " . $rply . $this->CRLF; + } + return false; + } + return true; + } + + /** + * Sends the RSET command to abort and transaction that is + * currently in progress. Returns true if successful false + * otherwise. + * + * Implements rfc 821: RSET + * + * SMTP CODE SUCCESS: 250 + * SMTP CODE ERROR : 500,501,504,421 + * @access public + * @return bool + */ + function Reset() { + $this->error = null; # so no confusion is caused + + if(!$this->connected()) { + $this->error = array( + "error" => "Called Reset() without being connected"); + return false; + } + + fputs($this->smtp_conn,"RSET" . $this->CRLF); + + $rply = $this->get_lines(); + $code = substr($rply,0,3); + + if($this->do_debug >= 2) { + echo "SMTP -> FROM SERVER:" . $this->CRLF . $rply; + } + + if($code != 250) { + $this->error = + array("error" => "RSET failed", + "smtp_code" => $code, + "smtp_msg" => substr($rply,4)); + if($this->do_debug >= 1) { + echo "SMTP -> ERROR: " . $this->error["error"] . + ": " . $rply . $this->CRLF; + } + return false; + } + + return true; + } + + /** + * Starts a mail transaction from the email address specified in + * $from. Returns true if successful or false otherwise. If True + * the mail transaction is started and then one or more Recipient + * commands may be called followed by a Data command. This command + * will send the message to the users terminal if they are logged + * in. + * + * Implements rfc 821: SEND FROM: + * + * SMTP CODE SUCCESS: 250 + * SMTP CODE SUCCESS: 552,451,452 + * SMTP CODE SUCCESS: 500,501,502,421 + * @access public + * @return bool + */ + function Send($from) { + $this->error = null; # so no confusion is caused + + if(!$this->connected()) { + $this->error = array( + "error" => "Called Send() without being connected"); + return false; + } + + fputs($this->smtp_conn,"SEND FROM:" . $from . $this->CRLF); + + $rply = $this->get_lines(); + $code = substr($rply,0,3); + + if($this->do_debug >= 2) { + echo "SMTP -> FROM SERVER:" . $this->CRLF . $rply; + } + + if($code != 250) { + $this->error = + array("error" => "SEND not accepted from server", + "smtp_code" => $code, + "smtp_msg" => substr($rply,4)); + if($this->do_debug >= 1) { + echo "SMTP -> ERROR: " . $this->error["error"] . + ": " . $rply . $this->CRLF; + } + return false; + } + return true; + } + + /** + * Starts a mail transaction from the email address specified in + * $from. Returns true if successful or false otherwise. If True + * the mail transaction is started and then one or more Recipient + * commands may be called followed by a Data command. This command + * will send the message to the users terminal if they are logged + * in and send them an email. + * + * Implements rfc 821: SAML FROM: + * + * SMTP CODE SUCCESS: 250 + * SMTP CODE SUCCESS: 552,451,452 + * SMTP CODE SUCCESS: 500,501,502,421 + * @access public + * @return bool + */ + function SendAndMail($from) { + $this->error = null; # so no confusion is caused + + if(!$this->connected()) { + $this->error = array( + "error" => "Called SendAndMail() without being connected"); + return false; + } + + fputs($this->smtp_conn,"SAML FROM:" . $from . $this->CRLF); + + $rply = $this->get_lines(); + $code = substr($rply,0,3); + + if($this->do_debug >= 2) { + echo "SMTP -> FROM SERVER:" . $this->CRLF . $rply; + } + + if($code != 250) { + $this->error = + array("error" => "SAML not accepted from server", + "smtp_code" => $code, + "smtp_msg" => substr($rply,4)); + if($this->do_debug >= 1) { + echo "SMTP -> ERROR: " . $this->error["error"] . + ": " . $rply . $this->CRLF; + } + return false; + } + return true; + } + + /** + * Starts a mail transaction from the email address specified in + * $from. Returns true if successful or false otherwise. If True + * the mail transaction is started and then one or more Recipient + * commands may be called followed by a Data command. This command + * will send the message to the users terminal if they are logged + * in or mail it to them if they are not. + * + * Implements rfc 821: SOML FROM: + * + * SMTP CODE SUCCESS: 250 + * SMTP CODE SUCCESS: 552,451,452 + * SMTP CODE SUCCESS: 500,501,502,421 + * @access public + * @return bool + */ + function SendOrMail($from) { + $this->error = null; # so no confusion is caused + + if(!$this->connected()) { + $this->error = array( + "error" => "Called SendOrMail() without being connected"); + return false; + } + + fputs($this->smtp_conn,"SOML FROM:" . $from . $this->CRLF); + + $rply = $this->get_lines(); + $code = substr($rply,0,3); + + if($this->do_debug >= 2) { + echo "SMTP -> FROM SERVER:" . $this->CRLF . $rply; + } + + if($code != 250) { + $this->error = + array("error" => "SOML not accepted from server", + "smtp_code" => $code, + "smtp_msg" => substr($rply,4)); + if($this->do_debug >= 1) { + echo "SMTP -> ERROR: " . $this->error["error"] . + ": " . $rply . $this->CRLF; + } + return false; + } + return true; + } + + /** + * This is an optional command for SMTP that this class does not + * support. This method is here to make the RFC821 Definition + * complete for this class and __may__ be implimented in the future + * + * Implements from rfc 821: TURN + * + * SMTP CODE SUCCESS: 250 + * SMTP CODE FAILURE: 502 + * SMTP CODE ERROR : 500, 503 + * @access public + * @return bool + */ + function Turn() { + $this->error = array("error" => "This method, TURN, of the SMTP ". + "is not implemented"); + if($this->do_debug >= 1) { + echo "SMTP -> NOTICE: " . $this->error["error"] . $this->CRLF; + } + return false; + } + + /** + * Verifies that the name is recognized by the server. + * Returns false if the name could not be verified otherwise + * the response from the server is returned. + * + * Implements rfc 821: VRFY + * + * SMTP CODE SUCCESS: 250,251 + * SMTP CODE FAILURE: 550,551,553 + * SMTP CODE ERROR : 500,501,502,421 + * @access public + * @return int + */ + function Verify($name) { + $this->error = null; # so no confusion is caused + + if(!$this->connected()) { + $this->error = array( + "error" => "Called Verify() without being connected"); + return false; + } + + fputs($this->smtp_conn,"VRFY " . $name . $this->CRLF); + + $rply = $this->get_lines(); + $code = substr($rply,0,3); + + if($this->do_debug >= 2) { + echo "SMTP -> FROM SERVER:" . $this->CRLF . $rply; + } + + if($code != 250 && $code != 251) { + $this->error = + array("error" => "VRFY failed on name '$name'", + "smtp_code" => $code, + "smtp_msg" => substr($rply,4)); + if($this->do_debug >= 1) { + echo "SMTP -> ERROR: " . $this->error["error"] . + ": " . $rply . $this->CRLF; + } + return false; + } + return $rply; + } + + /******************************************************************* + * INTERNAL FUNCTIONS * + ******************************************************************/ + + /** + * Read in as many lines as possible + * either before eof or socket timeout occurs on the operation. + * With SMTP we can tell if we have more lines to read if the + * 4th character is '-' symbol. If it is a space then we don't + * need to read anything else. + * @access private + * @return string + */ + function get_lines() { + $data = ""; + while($str = @fgets($this->smtp_conn,515)) { + if($this->do_debug >= 4) { + echo "SMTP -> get_lines(): \$data was \"$data\"" . + $this->CRLF; + echo "SMTP -> get_lines(): \$str is \"$str\"" . + $this->CRLF; + } + $data .= $str; + if($this->do_debug >= 4) { + echo "SMTP -> get_lines(): \$data is \"$data\"" . $this->CRLF; + } + # if the 4th character is a space then we are done reading + # so just break the loop + if(substr($str,3,1) == " ") { break; } + } + return $data; + } + +} + + + ?> diff --git a/config/freeswitch_dev/dialplan.default.xml b/config/freeswitch_dev/dialplan.default.xml new file mode 100644 index 00000000..93ecff16 --- /dev/null +++ b/config/freeswitch_dev/dialplan.default.xml @@ -0,0 +1,684 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + ]]> + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/config/freeswitch_dev/dialplan.public.xml b/config/freeswitch_dev/dialplan.public.xml new file mode 100644 index 00000000..f30227e0 --- /dev/null +++ b/config/freeswitch_dev/dialplan.public.xml @@ -0,0 +1,69 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/config/freeswitch_dev/disa.js b/config/freeswitch_dev/disa.js new file mode 100644 index 00000000..5cff6424 --- /dev/null +++ b/config/freeswitch_dev/disa.js @@ -0,0 +1,78 @@ +include("/usr/local/freeswitch/scripts/config.js"); + + //var admin_pin = ""; //don't require a pin + //if you choose not to require a pin then then you may want to add a dialplan condition for a specific caller id + var predefined_destination = ""; //example: 9999 + //predefined_destination leave empty in most cases + //Use this to define a single destination + var digitmaxlength = 0; + var timeoutpin = 7500; + var timeouttransfer = 7500; + + function mycb( session, type, obj, arg ) { + try { + if ( type == "dtmf" ) { + console_log( "info", "digit: "+obj.digit+"\n" ); + if ( obj.digit == "#" ) { + //console_log( "info", "detected pound sign.\n" ); + exit = true; + return( false ); + } + + dtmf.digits += obj.digit; + + if ( dtmf.digits.length >= digitmaxlength ) { + exit = true; + return( false ); + } + } + } catch (e) { + console_log( "err", e+"\n" ); + } + return( true ); + } //end function mycb + + + //console_log( "info", "DISA Request\n" ); + + var dtmf = new Object( ); + dtmf.digits = ""; + + if ( session.ready( ) ) { + session.answer( ); + + if (admin_pin.length > 0) { + digitmaxlength = 6; + session.streamFile( "/usr/local/freeswitch/sounds/custom/8000/please_enter_the_pin_number.wav", mycb, "dtmf"); + session.collectInput( mycb, dtmf, timeoutpin ); + //console_log( "info", "DISA pin: " + dtmf.digits + "\n" ); + } + + if (dtmf.digits == admin_pin || admin_pin.length == 0) { + + //console_log( "info", "DISA pin is correct\n" ); + + us_ring = session.getVariable("us-ring"); + session.execute("set", "ringback="+us_ring); //set to ringtone + session.execute("set", "transfer_ringback="+us_ring); //set to ringtone + session.execute("set", "hangup_after_bridge=true"); + + if (predefined_destination.length == 0) { + dtmf.digits = ""; //clear dtmf digits to prepare for next dtmf request + digitmaxlength = 11; + session.streamFile( "/usr/local/freeswitch/sounds/custom/8000/please_enter_the_phone_number.wav", mycb, "dtmf"); + session.collectInput( mycb, dtmf, timeouttransfer ); + console_log( "info", "DISA Transfer: " + dtmf.digits + "\n" ); + session.execute("transfer", dtmf.digits + " XML default"); + } + else { + session.execute("transfer", predefined_destination + " XML default"); + } + + } + else { + session.streamFile( "/usr/local/freeswitch/sounds/custom/8000/your_pin_number_is_incorect_goodbye.wav", mycb, "dtmf"); + console_log( "info", "DISA Pin: " + dtmf.digits + " is incorrect\n" ); + } + + } diff --git a/config/freeswitch_dev/fax_to_email.tmp b/config/freeswitch_dev/fax_to_email.tmp new file mode 100644 index 00000000..fcd6af06 --- /dev/null +++ b/config/freeswitch_dev/fax_to_email.tmp @@ -0,0 +1,182 @@ +IsSMTP(); // set mailer to use SMTP + if ($tmp_smtpauth == "true") { + $mail->SMTPAuth = $tmp_smtpauth; // turn on/off SMTP authentication + } + $mail->Host = $tmp_smtphost; + if (strlen($tmp_smtpsecure)>0) { + $mail->SMTPSecure = $tmp_smtpsecure; + } + if ($tmp_smtpusername) { + $mail->Username = $tmp_smtpusername; + $mail->Password = $tmp_smtppassword; + } + $mail->SMTPDebug = 2; + + echo "tmp_smtpfrom: $tmp_smtpfrom\n"; + echo "tmp_smtpfromname: $tmp_smtpfromname\n"; + echo "tmp_subject: $tmp_subject\n"; + + $mail->From = $tmp_smtpfrom; + $mail->FromName = $tmp_smtpfromname; + $mail->Subject = $tmp_subject; + $mail->AltBody = $tmp_textplain; // optional, comment out and test + $mail->MsgHTML($tmp_texthtml); + + + $tmp_to = $faxemail; + $tmp_to = str_replace(";", ",", $tmp_to); + $tmp_to_array = split(",", $tmp_to); + foreach($tmp_to_array as $tmp_to_row) { + if (strlen($tmp_to_row) > 0) { + echo "tmp_to_row: $tmp_to_row\n"; + $mail->AddAddress($tmp_to_row); + } + } + + if (strlen($faxname) > 0) { + $mail->AddAttachment($dir_fax.$faxname.'.tif'); // tif attachment + $mail->AddAttachment($dir_fax.$faxname.'.pdf'); // pdf attachment + $mail->AddAttachment($dir_fax.$faxname.'.png'); // png attachment + //$filename='fax.tif'; $encoding = "base64"; $type = "image/tif"; + //$mail->AddStringAttachment(base64_decode($strfax),$filename,$encoding,$type); + } + + if(!$mail->Send()) { + echo "Mailer Error: " . $mail->ErrorInfo; + } + else { + echo "Message sent!"; + } + + +$content = ob_get_contents(); //get the output from the buffer +ob_end_clean(); //clean the buffer + +fwrite($fp, $content); +fclose($fp); + +?> \ No newline at end of file diff --git a/config/freeswitch_dev/freeswitch.inc b/config/freeswitch_dev/freeswitch.inc new file mode 100644 index 00000000..511cf785 --- /dev/null +++ b/config/freeswitch_dev/freeswitch.inc @@ -0,0 +1,3515 @@ +"; + + $tab_array = array(); + $menu_selected = false; + if ($_SERVER["SCRIPT_NAME"] == "/pkg_edit.php?xml=freeswitch.xml&id=0") { $menu_selected = true; } + $tab_array[] = array(gettext("Settings"), $menu_selected, "/pkg_edit.php?xml=freeswitch.xml&id=0"); + unset($menu_selected); + + $menu_selected = false; + if ($_SERVER["SCRIPT_NAME"] == "/packages/freeswitch/freeswitch_dialplan_includes.php") { $menu_selected = true; } + if ($_SERVER["SCRIPT_NAME"] == "/packages/freeswitch/freeswitch_dialplan.php") { $menu_selected = true; } + if ($_SERVER["SCRIPT_NAME"] == "/packages/freeswitch/freeswitch_dialplan_includes_edit.php") { $menu_selected = true; } + if ($_SERVER["SCRIPT_NAME"] == "/packages/freeswitch/freeswitch_dialplan_includes_details_edit.php") { $menu_selected = true; } + $tab_array[] = array(gettext("Dialplan"), $menu_selected, "/packages/freeswitch/freeswitch_dialplan_includes.php"); + unset($menu_selected); + + $menu_selected = false; + if ($_SERVER["SCRIPT_NAME"] == "/packages/freeswitch/freeswitch_extensions.php") { $menu_selected = true; } + if ($_SERVER["SCRIPT_NAME"] == "/packages/freeswitch/freeswitch_extensions_edit.php") { $menu_selected = true; } + $tab_array[] = array(gettext("Extensions"), $menu_selected, "/packages/freeswitch/freeswitch_extensions.php"); + unset($menu_selected); + + $menu_selected = false; + if ($_SERVER["SCRIPT_NAME"] == "/packages/freeswitch/freeswitch_features.php") { $menu_selected = true; } + if ($_SERVER["SCRIPT_NAME"] == "/packages/freeswitch/freeswitch_fax.php") { $menu_selected = true; } + if ($_SERVER["SCRIPT_NAME"] == "/packages/freeswitch/freeswitch_fax_edit.php") { $menu_selected = true; } + if ($_SERVER["SCRIPT_NAME"] == "/packages/freeswitch/freeswitch_ivr.php") { $menu_selected = true; } + if ($_SERVER["SCRIPT_NAME"] == "/packages/freeswitch/freeswitch_ivr_edit.php") { $menu_selected = true; } + if ($_SERVER["SCRIPT_NAME"] == "/packages/freeswitch/freeswitch_ivr_options_edit.php") { $menu_selected = true; } + if ($_SERVER["SCRIPT_NAME"] == "/packages/freeswitch/freeswitch_recordings.php") { $menu_selected = true; } + if ($_SERVER["SCRIPT_NAME"] == "/packages/freeswitch/freeswitch_recordings_edit.php") { $menu_selected = true; } + if ($_SERVER["SCRIPT_NAME"] == "/packages/freeswitch/freeswitch_hunt_group.php") { $menu_selected = true; } + if ($_SERVER["SCRIPT_NAME"] == "/packages/freeswitch/freeswitch_hunt_group_edit.php") { $menu_selected = true; } + if ($_SERVER["SCRIPT_NAME"] == "/packages/freeswitch/freeswitch_hunt_group_destinations.php") { $menu_selected = true; } + if ($_SERVER["SCRIPT_NAME"] == "/packages/freeswitch/freeswitch_hunt_group_destinations_edit.php") { $menu_selected = true; } + $tab_array[] = array(gettext("Features"), $menu_selected, "/packages/freeswitch/freeswitch_features.php"); + unset($menu_selected); + + $menu_selected = false; + if ($_SERVER["SCRIPT_NAME"] == "/packages/freeswitch/freeswitch_gateways.php") { $menu_selected = true; } + if ($_SERVER["SCRIPT_NAME"] == "/packages/freeswitch/freeswitch_gateways_edit.php") { $menu_selected = true; } + $tab_array[] = array(gettext("Gateways"), $menu_selected, "/packages/freeswitch/freeswitch_gateways.php"); + unset($menu_selected); + + $menu_selected = false; + if ($_SERVER["SCRIPT_NAME"] == "/packages/freeswitch/freeswitch_profiles.php") { $menu_selected = true; } + if ($_SERVER["SCRIPT_NAME"] == "/packages/freeswitch/freeswitch_profile_edit.php") { $menu_selected = true; } + $tab_array[] = array(gettext("Profiles"), $menu_selected, "/packages/freeswitch/freeswitch_profiles.php"); + unset($menu_selected); + + $menu_selected = false; + if ($_SERVER["SCRIPT_NAME"] == "/packages/freeswitch/freeswitch_public.php") { $menu_selected = true; } + if ($_SERVER["SCRIPT_NAME"] == "/packages/freeswitch/freeswitch_public_includes.php") { $menu_selected = true; } + if ($_SERVER["SCRIPT_NAME"] == "/packages/freeswitch/freeswitch_public_includes_edit.php") { $menu_selected = true; } + if ($_SERVER["SCRIPT_NAME"] == "/packages/freeswitch/freeswitch_public_includes_details_edit.php") { $menu_selected = true; } + $tab_array[] = array(gettext("Public"), $menu_selected, "/packages/freeswitch/freeswitch_public_includes.php"); + unset($menu_selected); + + $menu_selected = false; + if ($_SERVER["SCRIPT_NAME"] == "/packages/freeswitch/freeswitch_status.php") { $menu_selected = true; } + $tab_array[] = array(gettext("Status"), $menu_selected, "/packages/freeswitch/freeswitch_status.php"); + unset($menu_selected); + + $menu_selected = false; + if ($_SERVER["SCRIPT_NAME"] == "/packages/freeswitch/freeswitch_vars.php") { $menu_selected = true; } + $tab_array[] = array(gettext("Vars"), $menu_selected, "/packages/freeswitch/freeswitch_vars.php"); + unset($menu_selected); + + return $tab_array; +} + + +function guid() +{ + if (function_exists('com_create_guid')){ + return com_create_guid(); + }else{ + mt_srand((double)microtime()*10000);//optional for php 4.2.0 and up. + $charid = strtoupper(md5(uniqid(rand(), true))); + $hyphen = chr(45);// "-" + $uuid = chr(123)// "{" + .substr($charid, 0, 8).$hyphen + .substr($charid, 8, 4).$hyphen + .substr($charid,12, 4).$hyphen + .substr($charid,16, 4).$hyphen + .substr($charid,20,12) + .chr(125);// "}" + return $uuid; + } +} +//echo guid(); + + +function pkg_is_service_running($servicename) +{ + exec("/bin/ps ax | awk '{ print $5 }'", $psout); + array_shift($psout); + foreach($psout as $line) { + $ps[] = trim(array_pop(explode(' ', array_pop(explode('/', $line))))); + } + if(is_service_running($servicename, $ps) or is_process_running($servicename) ) { + return true; + } + else { + return false; + } +} + + +function event_socket_create($host, $port, $password) +{ + //$host has been deprecated + + //build the interface list + $i = 0; $ifdescrs = array('wan' => 'WAN', 'lan' => 'LAN'); + for ($j = 1; isset($config['interfaces']['opt' . $j]); $j++) { + $ifdescrs['opt' . $j] = $config['interfaces']['opt' . $j]['descr']; + } + + //get the interface ip addresses and try to connect to them + foreach ($ifdescrs as $ifdescr => $ifname){ + $ifinfo = get_interface_info($ifdescr); + $interface_ip_address = $ifinfo['ipaddr']; + + if (strlen($interface_ip_address) > 0) { + + $fp = fsockopen($interface_ip_address, $port, $errno, $errdesc, 3); + socket_set_blocking($fp,false); + + if (!$fp) { + //connection failed continue through the loop testing other addresses + //invalid handle + } + else { + //connected to the socket return the handle + + while (!feof($fp)) { + $buffer = fgets($fp, 1024); + usleep(100); //allow time for reponse + if (trim($buffer) == "Content-Type: auth/request") { + fputs($fp, "auth $password\n\n"); + break; + } + } + return $fp; + } + + } //end if interface_ip_address + } //end foreach +} //end function + + +function event_socket_request($fp, $cmd) +{ + if ($fp) { + fputs($fp, $cmd."\n\n"); + usleep(100); //allow time for reponse + + $response = ""; + $i = 0; + $contentlength = 0; + while (!feof($fp)) { + $buffer = fgets($fp, 4096); + if ($contentlength > 0) { + $response .= $buffer; + } + + if ($contentlength == 0) { //if contentlenght is already don't process again + if (strlen(trim($buffer)) > 0) { //run only if buffer has content + $temparray = split(":", trim($buffer)); + if ($temparray[0] == "Content-Length") { + $contentlength = trim($temparray[1]); + } + } + } + + usleep(100); //allow time for reponse + + //optional because of script timeout //don't let while loop become endless + if ($i > 10000) { break; } + + if ($contentlength > 0) { //is contentlength set + //stop reading if all content has been read. + if (strlen($response) >= $contentlength) { + break; + } + } + $i++; + } + + return $response; + } + else { + echo "no handle"; + } +} + + +function event_socket_request_cmd($cmd) +{ + global $config; + $password = $config['installedpackages']['freeswitchsettings']['config'][0]['event_socket_password']; + $port = $config['installedpackages']['freeswitchsettings']['config'][0]['event_socket_port']; + $host = $config['interfaces']['lan']['ipaddr']; + + if (pkg_is_service_running('freeswitch')) { + $fp = event_socket_create($host, $port, $password); + $response = event_socket_request($fp, $cmd); + fclose($fp); + } + unset($host, $port, $password); + +} + +function byte_convert( $bytes ) { + + if ($bytes<=0) + return '0 Byte'; + + $convention=1000; //[1000->10^x|1024->2^x] + $s=array('B', 'kB', 'MB', 'GB', 'TB', 'PB', 'EB', 'ZB'); + $e=floor(log($bytes,$convention)); + return round($bytes/pow($convention,$e),2).' '.$s[$e]; +} + +function lan_sip_profile() +{ + global $config; + clearstatcache(); + + //if the lan directory does not exist then create it + if (!is_dir('/usr/local/freeswitch/conf/sip_profiles/lan/')) { + exec("mkdir /usr/local/freeswitch/conf/sip_profiles/lan/"); + } + + //create the LAN profile if it doesn't exist + if (!file_exists('/usr/local/freeswitch/conf/sip_profiles/lan.xml')) { + $lan_ip = $config['interfaces']['lan']['ipaddr']; + if (strlen($lan_ip) > 0) { + exec("cp /usr/local/freeswitch/conf/sip_profiles/internal.xml /usr/local/freeswitch/conf/sip_profiles/lan.xml"); + + $filename = "/usr/local/freeswitch/conf/sip_profiles/lan.xml"; + $handle = fopen($filename,"rb"); + $contents = fread($handle, filesize($filename)); + fclose($handle); + + $handle = fopen($filename,"w"); + $contents = str_replace("", "", $contents); + $contents = str_replace("", "", $contents); + $contents = str_replace("", "", $contents); + $contents = str_replace("", "", $contents); + $contents = str_replace("", "", $contents); + fwrite($handle, $contents); + unset($contents); + fclose($handle); + unset($filename); + } + } + +} + +function ListFiles($dir) { + + if($dh = opendir($dir)) { + + $files = Array(); + $inner_files = Array(); + + while($file = readdir($dh)) { + if($file != "." && $file != ".." && $file[0] != '.') { + if(is_dir($dir . "/" . $file)) { + //$inner_files = ListFiles($dir . "/" . $file); //recursive + if(is_array($inner_files)) $files = array_merge($files, $inner_files); + } else { + array_push($files, $file); + //array_push($files, $dir . "/" . $file); + } + } + } + + closedir($dh); + return $files; + } +} + +function recording_js() +{ + + global $config; + $admin_pin = $config['installedpackages']['freeswitchsettings']['config'][0]['admin_pin']; + + $fout = fopen("/usr/local/freeswitch/scripts/recordings.js","w"); + $tmp = " var pin = \"".$admin_pin."\";\n"; + $tmp .= " //var pin = \"\"; //don't require a pin\n"; + $tmp .= " //if you choose not to require a pin then then you may want to add a dialplan condition for a specific caller id\n"; + $tmp .= "\n"; + $tmp .= " var digitmaxlength = 0;\n"; + $tmp .= " var timeoutpin = 7500;\n"; + $tmp .= " var timeouttransfer = 7500;\n"; + $tmp .= " var objdate = new Date();\n"; + $tmp .= "\n"; + $tmp .= " var adjusthours = 0; //Adjust Server time that is set to GMT 7 hours\n"; + $tmp .= " var adjustoperator = \"-\"; //+ or -\n"; + $tmp .= "\n"; + $tmp .= " if (adjustoperator == \"-\") {\n"; + $tmp .= " var objdate2 = new Date(objdate.getFullYear(),objdate.getMonth(),objdate.getDate(),(objdate.getHours() - adjusthours),objdate.getMinutes(),objdate.getSeconds());\n"; + $tmp .= " }\n"; + $tmp .= " if (adjustoperator == \"+\") {\n"; + $tmp .= " var objdate2 = new Date(objdate.getFullYear(),objdate.getMonth(),objdate.getDate(),(objdate.getHours() + adjusthours),objdate.getMinutes(),objdate.getSeconds());\n"; + $tmp .= " }\n"; + $tmp .= "\n"; + $tmp .= " var Hours = objdate2.getHours();\n"; + $tmp .= " var Mins = objdate2.getMinutes();\n"; + $tmp .= " var Seconds = objdate2.getSeconds();\n"; + $tmp .= " var Month = objdate2.getMonth() + 1;\n"; + $tmp .= " var Date = objdate2.getDate();\n"; + $tmp .= " var Year = objdate2.getYear()\n"; + $tmp .= " var Day = objdate2.getDay()+1;\n"; + $tmp .= " var exit = false;\n"; + $tmp .= "\n"; + $tmp .= "\n"; + $tmp .= " function mycb( session, type, data, arg ) {\n"; + $tmp .= " if ( type == \"dtmf\" ) {\n"; + $tmp .= " //console_log( \"info\", \"digit: \"+data.digit+\"\\n\" );\n"; + $tmp .= " if ( data.digit == \"#\" ) {\n"; + $tmp .= " //console_log( \"info\", \"detected pound sign.\\n\" );\n"; + $tmp .= " return( true );\n"; + $tmp .= " }\n"; + $tmp .= " dtmf.digits += data.digit;\n"; + $tmp .= "\n"; + $tmp .= " if ( dtmf.digits.length < digitmaxlength ) {\n"; + $tmp .= " return( true );\n"; + $tmp .= " }\n"; + $tmp .= " }\n"; + $tmp .= " return( false );\n"; + $tmp .= " }\n"; + $tmp .= "\n"; + $tmp .= " //console_log( \"info\", \"Recording Request\\n\" );\n"; + $tmp .= "\n"; + $tmp .= " var dtmf = new Object( );\n"; + $tmp .= " dtmf.digits = \"\";\n"; + $tmp .= "\n"; + $tmp .= " if ( session.ready( ) ) {\n"; + $tmp .= " session.answer( );\n"; + $tmp .= "\n"; + + $tmp .= "\n"; + $tmp .= " if (pin.length > 0) {\n"; + //$tmp .= " session.execute(\"set\", \"tts_engine=flite\");\n"; + //$tmp .= " session.execute(\"set\", \"tts_voice=kal\");\n"; + //$tmp .= " session.execute(\"speak\", \"Please enter your pin number now.\");\n"; + $tmp .= " digitmaxlength = 6;\n"; + $tmp .= " session.execute(\"set\", \"playback_terminators=#\");\n"; + $tmp .= " session.streamFile( \"/usr/local/freeswitch/sounds/custom/8000/please_enter_the_pin_number.wav\", mycb, \"dtmf\");\n"; + $tmp .= " session.collectInput( mycb, dtmf, timeoutpin );\n"; + $tmp .= " }\n"; + $tmp .= "\n"; + $tmp .= " if (dtmf.digits == pin || pin.length == 0) {\n"; + //$tmp .= " //console_log( \"info\", \"Recordings pin is correct\\n\" );\n"; + //$tmp .= " session.execute(\"set\", \"tts_engine=flite\");\n"; + //$tmp .= " session.execute(\"set\", \"tts_voice=kal\");\n"; + //$tmp .= " session.execute(\"speak\", \"Begin recording.\");\n"; + $tmp .= " session.streamFile( \"/usr/local/freeswitch/sounds/custom/8000/begin_recording.wav\", mycb, \"dtmf\");\n"; + $tmp .= " session.execute(\"set\", \"playback_terminators=#\");\n"; + $tmp .= " session.execute(\"record\", \"/usr/local/freeswitch/recordings/temp\"+Year+Month+Day+Hours+Mins+Seconds+\".wav 180 200\");\n"; + $tmp .= " }\n"; + $tmp .= " else {\n"; + $tmp .= " console_log( \"info\", \"Pin: \" + dtmf.digits + \" is incorrect\\n\" );\n"; + //$tmp .= " session.execute(\"set\", \"tts_engine=flite\");\n"; + //$tmp .= " session.execute(\"set\", \"tts_voice=kal\");\n"; + //$tmp .= " session.execute(\"speak\", \"Your pin number is incorect, goodbye.\");\n"; + $tmp .= " session.streamFile( \"/usr/local/freeswitch/sounds/custom/8000/your_pin_number_is_incorect_goodbye.wav\", mycb, \"dtmf\");\n"; + $tmp .= " }\n"; + $tmp .= " session.hangup();\n"; + $tmp .= "\n"; + $tmp .= " }"; + fwrite($fout, $tmp); + unset($tmp); + fclose($fout); + +} + + +function sync_package_freeswitch_settings() +{ + + global $config; + if($config['installedpackages']['freeswitchsettings']['config'] != "") { + + conf_mount_rw(); + config_unlock(); + + foreach($config['installedpackages']['freeswitchsettings']['config'] as $rowhelper) { + + $fout = fopen("/usr/local/freeswitch/conf/directory/default/default.xml","w"); + $tmpxml = "\n"; + $tmpxml .= " \n"; + $tmpxml .= " \n"; + $tmpxml .= " \n"; + $tmpxml .= " \n"; + $tmpxml .= " \n"; + $tmpxml .= " \n"; + $tmpxml .= " \n"; + $tmpxml .= " \n"; + $tmpxml .= " \n"; + $tmpxml .= "\n"; + fwrite($fout, $tmpxml); + unset($tmpxml); + fclose($fout); + + $fout = fopen("/usr/local/freeswitch/conf/autoload_configs/event_socket.conf.xml","w"); + $tmpxml = "\n"; + $tmpxml .= " \n"; + $tmpxml .= " \n"; + $tmpxml .= " \n"; + $tmpxml .= " \n"; + $tmpxml .= " \n"; + $tmpxml .= " \n"; + $tmpxml .= ""; + fwrite($fout, $tmpxml); + unset($tmpxml, $event_socket_password); + fclose($fout); + + $fout = fopen("/usr/local/freeswitch/conf/autoload_configs/xml_rpc.conf","w"); + $tmpxml = "\n"; + $tmpxml .= " \n"; + $tmpxml .= " \n"; + $tmpxml .= " \n"; + $tmpxml .= " \n"; + $tmpxml .= " \n"; + $tmpxml .= " \n"; + $tmpxml .= " \n"; + $tmpxml .= " \n"; + $tmpxml .= "\n"; + fwrite($fout, $tmpxml); + unset($tmpxml); + fclose($fout); + + recording_js(); + + //shout.conf.xml + $fout = fopen("/usr/local/freeswitch/conf/autoload_configs/shout.conf.xml","w"); + $tmpxml = "\n"; + $tmpxml .= " \n"; + $tmpxml .= " \n"; + $tmpxml .= " \n"; + $tmpxml .= " \n"; + $tmpxml .= " \n"; + $tmpxml .= " \n"; + $tmpxml .= ""; + fwrite($fout, $tmpxml); + unset($tmpxml); + fclose($fout); + + //config.js + $admin_pin = $config['installedpackages']['freeswitchsettings']['config'][0]['admin_pin']; + $fout = fopen("/usr/local/freeswitch/scripts/config.js","w"); + $tmp = "//javascript include\n\n"; + $tmp .= "var admin_pin = \"" . $admin_pin . "\";\n"; + fwrite($fout, $tmp); + unset($tmp); + fclose($fout); + + } + + conf_mount_ro(); + $cmd = "api reloadxml"; + //event_socket_request_cmd($cmd); + unset($cmd); + } +} + + +function sync_package_freeswitch_dialplan() +{ + + global $config; + conf_mount_rw(); + config_unlock(); + + //using backup files rather than pfsense config.xml for this file + $config['installedpackages']['freeswitchpublic']['config'][0]['dialplan_default_xml'] = ""; + + //if(strlen($config['installedpackages']['freeswitchdialplan']['config'][0]['dialplan_default_xml']) == 0) { + /* dialplan not found in the pfsense config.xml get the default dialplan and save to config.xml. */ + //$filename = "/usr/local/freeswitch/conf/dialplan/default.xml"; + //$fout = fopen($filename,"r"); + //$tmpxml = fread($fout, filesize($filename)); + //$config['installedpackages']['freeswitchdialplan']['config'][0]['dialplan_default_xml'] = base64_encode($tmpxml); + //unset($filename, $dialplan); + //fclose($fout); + //} + //else { + /* found the dialplan in the pfsense config.xml save it to default.xml. */ + //$fout = fopen("/usr/local/freeswitch/conf/dialplan/default.xml","w"); + //$tmpxml = $config['installedpackages']['freeswitchdialplan']['config'][0]['dialplan_default_xml']; + //fwrite($fout, base64_decode($tmpxml)); + //fclose($fout); + //unset($tmpxml); + //} + + conf_mount_ro(); + //$cmd = "api reloadxml"; + //event_socket_request_cmd($cmd); + //unset($cmd); + +} + + +function sync_package_freeswitch_extensions() +{ + + global $config; + if($config['installedpackages']['freeswitchextensions']['config'] != "") { + + conf_mount_rw(); + config_unlock(); + + /* delete all old extensions to prepare for new ones */ + unlink_if_exists("/usr/local/freeswitch/conf/directory/default/1*.xml"); + unlink_if_exists("/usr/local/freeswitch/conf/directory/default/2*.xml"); + unlink_if_exists("/usr/local/freeswitch/conf/directory/default/3*.xml"); + unlink_if_exists("/usr/local/freeswitch/conf/directory/default/4*.xml"); + unlink_if_exists("/usr/local/freeswitch/conf/directory/default/5*.xml"); + unlink_if_exists("/usr/local/freeswitch/conf/directory/default/6*.xml"); + unlink_if_exists("/usr/local/freeswitch/conf/directory/default/7*.xml"); + unlink_if_exists("/usr/local/freeswitch/conf/directory/default/8*.xml"); + unlink_if_exists("/usr/local/freeswitch/conf/directory/default/9*.xml"); + + foreach($config['installedpackages']['freeswitchextensions']['config'] as $rowhelper) { + if ($rowhelper['enabled'] != "false") { + $fout = fopen("/usr/local/freeswitch/conf/directory/default/".$rowhelper['extension'].".xml","w"); + + $tmpxml = "\n"; + if (strlen($rowhelper['cidr']) == 0) { + $tmpxml .= " \n"; + } + else { + $tmpxml .= " \n"; + } + $tmpxml .= " \n"; + $tmpxml .= " \n"; + $tmpxml .= " \n"; + if (strlen($rowhelper['vm-mailto']) > 0) { + $tmpxml .= " \n"; + + switch ($rowhelper['vm-attach-file']) { + case "true": + $tmpxml .= " \n"; + break; + case "false": + $tmpxml .= " \n"; + break; + default: + $tmpxml .= " \n"; + } + switch ($rowhelper['vm-keep-local-after-email']) { + case "true": + $tmpxml .= " \n"; + break; + case "false": + $tmpxml .= " \n"; + break; + default: + $tmpxml .= " \n"; + } + $tmpxml .= " \n"; + } + if (strlen($rowhelper['auth-acl']) > 0) { + $tmpxml .= " \n"; + } + $tmpxml .= " \n"; + $tmpxml .= " \n"; + $tmpxml .= " \n"; + $tmpxml .= " \n"; + $tmpxml .= " \n"; + if (strlen($rowhelper['effective_caller_id_number']) > 0) { + $tmpxml .= " \n"; + $tmpxml .= " \n"; + } + if (strlen($rowhelper['outbound_caller_id_number']) > 0) { + $tmpxml .= " \n"; + $tmpxml .= " \n"; + } + if (strlen($rowhelper['sip-force-contact']) > 0) { + $tmpxml .= " \n"; + } + $tmpxml .= " \n"; + $tmpxml .= " \n"; + $tmpxml .= "\n"; + fwrite($fout, $tmpxml); + unset($tmpxml); + fclose($fout); + } + } + + conf_mount_ro(); + $cmd = "api reloadxml"; + //event_socket_request_cmd($cmd); + unset($cmd); + + } +} + + +function sync_package_freeswitch_gateways() +{ + + global $config; + if($config['installedpackages']['freeswitchgateways']['config'] != "") { + + conf_mount_rw(); + config_unlock(); + + /* delete all old gateways to prepare for new ones */ + unlink_if_exists("/usr/local/freeswitch/conf/sip_profiles/external/*.xml"); + + foreach($config['installedpackages']['freeswitchgateways']['config'] as $rowhelper) { + + if ($rowhelper['enabled'] != "false") { + $fout = fopen("/usr/local/freeswitch/conf/sip_profiles/external/".$rowhelper['gateway'].".xml","w"); + + $tmpxml .= "\n"; + $tmpxml .= " \n"; + if (strlen($rowhelper['username']) > 0) { + $tmpxml .= " \n"; + } + if (strlen($rowhelper['password']) > 0) { + $tmpxml .= " \n"; + } + if (strlen($rowhelper['realm']) > 0) { + $tmpxml .= " \n"; + } + if (strlen($rowhelper['from-user']) > 0) { + $tmpxml .= " \n"; + } + if (strlen($rowhelper['from-domain']) > 0) { + $tmpxml .= " \n"; + } + if (strlen($rowhelper['proxy']) > 0) { + $tmpxml .= " \n"; + } + if (strlen($rowhelper['expire-seconds']) > 0) { + $tmpxml .= " \n"; + } + if (strlen($rowhelper['register']) > 0) { + $tmpxml .= " \n"; + } + + if (strlen($rowhelper['register-transport']) > 0) { + switch ($rowhelper['register-transport']) { + case "udp": + $tmpxml .= " \n"; + break; + case "tcp": + $tmpxml .= " \n"; + break; + case "tls": + $tmpxml .= " \n"; + $tmpxml .= " \n"; + break; + default: + $tmpxml .= " \n"; + } + } + + if (strlen($rowhelper['retry-seconds']) > 0) { + $tmpxml .= " \n"; + } + if (strlen($rowhelper['extension']) > 0) { + $tmpxml .= " \n"; + } + if (strlen($rowhelper['ping']) > 0) { + $tmpxml .= " \n"; + } + if (strlen($rowhelper['context']) > 0) { + $tmpxml .= " \n"; + } + if (strlen($rowhelper['caller-id-in-from']) > 0) { + $tmpxml .= " \n"; + } + if (strlen($rowhelper['supress-cng']) > 0) { + $tmpxml .= " \n"; + } + + $tmpxml .= " \n"; + $tmpxml .= ""; + + fwrite($fout, $tmpxml); + unset($tmpxml); + fclose($fout); + } + + } + + conf_mount_ro(); + $cmd = "api sofia profile external restart reloadxml"; + //event_socket_request_cmd($cmd); + unset($cmd); + + } + +} + + +function sync_package_freeswitch_modules() +{ + + global $config; + conf_mount_rw(); + config_unlock(); + + foreach($config['installedpackages']['freeswitchmodules']['config'] as $rowhelper) { + $fout = fopen("/usr/local/freeswitch/conf/autoload_configs/modules.conf.xml","w"); + + $tmpxml =""; + $tmpxml .= "\n"; + $tmpxml .= " \n"; + $tmpxml .= "\n"; + $tmpxml .= " \n"; + if ($rowhelper['mod_console'] == "enable"){ $tmpxml .= " \n"; } + if ($rowhelper['mod_logfile'] == "enable"){ $tmpxml .= " \n"; } + if ($rowhelper['mod_syslog'] == "enable"){ $tmpxml .= " \n"; } + $tmpxml .= "\n"; + if ($rowhelper['mod_yaml'] == "enable"){ $tmpxml .= " \n"; } + $tmpxml .= "\n"; + $tmpxml .= " \n"; + $tmpxml .= " \n"; + if ($rowhelper['mod_enum'] == "enable"){ $tmpxml .= " \n"; } + $tmpxml .= "\n"; + $tmpxml .= " \n"; + if ($rowhelper['mod_xml_rpc'] == "enable"){ $tmpxml .= " \n"; } + if ($rowhelper['mod_xml_curl'] == "enable"){ $tmpxml .= " \n"; } + if ($rowhelper['mod_xml_cdr'] == "enable"){ $tmpxml .= " \n"; } + $tmpxml .= "\n"; + $tmpxml .= " \n"; + if ($rowhelper['mod_cdr_csv'] == "enable"){ $tmpxml .= " \n"; } + if ($rowhelper['mod_event_multicast'] == "enable"){ $tmpxml .= " \n"; } + if ($rowhelper['mod_event_socket'] == "enable"){ $tmpxml .= " \n"; } + if ($rowhelper['mod_zeroconf'] == "enable"){ $tmpxml .= " \n"; } + $tmpxml .= "\n"; + $tmpxml .= " \n"; + if ($rowhelper['mod_ldap'] == "enable"){ $tmpxml .= " \n"; } + $tmpxml .= "\n"; + $tmpxml .= " \n"; + if ($rowhelper['mod_dingaling'] == "enable"){ $tmpxml .= " \n"; } + if ($rowhelper['mod_iax'] == "enable"){ $tmpxml .= " \n"; } + if ($rowhelper['mod_portaudio'] == "enable"){ $tmpxml .= " \n"; } + if ($rowhelper['mod_alsa'] == "enable"){ $tmpxml .= " \n"; } + if ($rowhelper['mod_sofia'] == "enable"){ $tmpxml .= " \n"; } + if ($rowhelper['mod_loopback'] == "enable"){ $tmpxml .= " \n"; } + if ($rowhelper['mod_wanpipe'] == "enable"){ $tmpxml .= " \n"; } + if ($rowhelper['mod_woomera'] == "enable"){ $tmpxml .= " \n"; } + if ($rowhelper['mod_openzap'] == "enable"){ $tmpxml .= " \n"; } + $tmpxml .= "\n"; + $tmpxml .= " \n"; + if ($rowhelper['mod_commands'] == "enable"){ $tmpxml .= " \n"; } + if ($rowhelper['mod_conference'] == "enable"){ $tmpxml .= " \n"; } + if ($rowhelper['mod_dptools'] == "enable"){ $tmpxml .= " \n"; } + if ($rowhelper['mod_expr'] == "enable"){ $tmpxml .= " \n"; } + if ($rowhelper['mod_fax'] == "enable"){ $tmpxml .= " \n"; } + if ($rowhelper['mod_fifo'] == "enable"){ $tmpxml .= " \n"; } + if ($rowhelper['mod_voicemail'] == "enable"){ $tmpxml .= " \n"; } + if ($rowhelper['mod_limit'] == "enable"){ $tmpxml .= " \n"; } + if ($rowhelper['mod_esf'] == "enable"){ $tmpxml .= " \n"; } + if ($rowhelper['mod_fsv'] == "enable"){ $tmpxml .= " \n"; } + $tmpxml .= "\n"; + $tmpxml .= " \n"; + if ($rowhelper['mod_snom'] == "enable"){ $tmpxml .= " \n"; } + $tmpxml .= "\n"; + $tmpxml .= " \n"; + if ($rowhelper['mod_dialplan_directory'] == "enable"){ $tmpxml .= " \n"; } + if ($rowhelper['mod_dialplan_xml'] == "enable"){ $tmpxml .= " \n"; } + if ($rowhelper['mod_dialplan_asterisk'] == "enable"){ $tmpxml .= " \n"; } + $tmpxml .= "\n"; + $tmpxml .= " \n"; + if ($rowhelper['mod_voipcodecs'] == "enable"){ $tmpxml .= " \n"; } + if ($rowhelper['mod_g723_1'] == "enable"){ $tmpxml .= " \n"; } + if ($rowhelper['mod_g729'] == "enable"){ $tmpxml .= " \n"; } + if ($rowhelper['mod_amr'] == "enable"){ $tmpxml .= " \n"; } + if ($rowhelper['mod_ilbc'] == "enable"){ $tmpxml .= " \n"; } + if ($rowhelper['mod_speex'] == "enable"){ $tmpxml .= " \n"; } + if ($rowhelper['mod_siren'] == "enable"){ $tmpxml .= " \n"; } + if ($rowhelper['mod_celt'] == "enable"){ $tmpxml .= " \n"; } + if ($rowhelper['mod_h26x'] == "enable"){ $tmpxml .= " \n"; } + $tmpxml .= "\n"; + $tmpxml .= " \n"; + if ($rowhelper['mod_sndfile'] == "enable"){ $tmpxml .= " \n"; } + if ($rowhelper['mod_native_file'] == "enable"){ $tmpxml .= " \n"; } + $tmpxml .= " \n"; + if ($rowhelper['mod_shout'] == "enable"){ $tmpxml .= " \n"; } + $tmpxml .= " \n"; + if ($rowhelper['mod_local_stream'] == "enable"){ $tmpxml .= " \n"; } + if ($rowhelper['mod_tone_stream'] == "enable"){ $tmpxml .= " \n"; } + $tmpxml .= "\n"; + $tmpxml .= " \n"; + $tmpxml .= "\n"; + $tmpxml .= " \n"; + if ($rowhelper['mod_spidermonkey'] == "enable"){ $tmpxml .= " \n"; } + if ($rowhelper['mod_spidermonkey_odbc'] == "enable"){ $tmpxml .= " \n"; } + if ($rowhelper['mod_perl'] == "enable"){ $tmpxml .= " \n"; } + if ($rowhelper['mod_python'] == "enable"){ $tmpxml .= " \n"; } + if ($rowhelper['mod_java'] == "enable"){ $tmpxml .= " \n"; } + if ($rowhelper['mod_lua'] == "enable"){ $tmpxml .= " \n"; } + $tmpxml .= "\n"; + $tmpxml .= " \n"; + if ($rowhelper['mod_flite'] == "enable"){ $tmpxml .= " \n"; } + if ($rowhelper['mod_pocketsphinx'] == "enable"){ $tmpxml .= " \n"; } + if ($rowhelper['mod_cepstral'] == "enable"){ $tmpxml .= " \n"; } + if ($rowhelper['mod_openmrcp'] == "enable"){ $tmpxml .= " \n"; } + if ($rowhelper['mod_rss'] == "enable"){ $tmpxml .= " \n"; } + $tmpxml .= "\n"; + $tmpxml .= " \n"; + if ($rowhelper['mod_say_en'] == "enable"){ $tmpxml .= " \n"; } + if ($rowhelper['mod_say_de'] == "enable"){ $tmpxml .= " \n"; } + if ($rowhelper['mod_say_es'] == "enable"){ $tmpxml .= " \n"; } + if ($rowhelper['mod_say_fr'] == "enable"){ $tmpxml .= " \n"; } + if ($rowhelper['mod_say_it'] == "enable"){ $tmpxml .= " \n"; } + if ($rowhelper['mod_say_nl'] == "enable"){ $tmpxml .= " \n"; } + if ($rowhelper['mod_say_ru'] == "enable"){ $tmpxml .= " \n"; } + if ($rowhelper['mod_say_zh'] == "enable"){ $tmpxml .= " \n"; } + $tmpxml .= " \n"; + $tmpxml .= ""; + + fwrite($fout, $tmpxml); + unset($tmpxml); + fclose($fout); + } + + conf_mount_ro(); + $cmd = "api reloadxml"; + //event_socket_request_cmd($cmd); + unset($cmd); + +} + + +function sync_package_freeswitch_public() +{ + + global $config; + conf_mount_rw(); + config_unlock(); + + //using backup files rather than pfsense config.xml for this file + $config['installedpackages']['freeswitchpublic']['config'][0]['public_xml'] = ""; + + //if(strlen($config['installedpackages']['freeswitchpublic']['config'][0]['public_xml']) == 0) { + // /* dialplan_public_xml not found in the pfsense config.xml get the default public.xml and save to config.xml. */ + // $filename = "/usr/local/freeswitch/conf/dialplan/public.xml"; + // $fout = fopen($filename,"r"); + // $tmpxml = fread($fout, filesize($filename)); + // $tmpxml = str_replace("", "", $tmpxml); + // $config['installedpackages']['freeswitchpublic']['config'][0]['public_xml'] = base64_encode($tmpxml); + + // unset($filename, $tmpxml); + // fclose($fout); + //} + //else { + // /* found dialplan_public_xml in the pfsense config.xml save it to public.xml. */ + // $fout = fopen("/usr/local/freeswitch/conf/dialplan/public.xml","w"); + // $tmpxml = $config['installedpackages']['freeswitchpublic']['config'][0]['public_xml']; + // fwrite($fout, base64_decode($tmpxml)); + // fclose($fout); + // unset($tmpxml); + //} + + conf_mount_ro(); + //$cmd = "api reloadxml"; + ////event_socket_request_cmd($cmd); + //unset($cmd); + +} + + +function sync_package_freeswitch_vars() +{ + + global $config; + conf_mount_rw(); + config_unlock(); + + //using backup files rather than pfsense config.xml for this file + $config['installedpackages']['freeswitchpublic']['config'][0]['vars_xml'] = ""; + + //if(strlen($config['installedpackages']['freeswitchvars']['config'][0]['vars_xml']) == 0) { + // /* dialplan not found in the pfsense config.xml get the default dialplan and save to config.xml. */ + // $filename = "/usr/local/freeswitch/conf/vars.xml"; + // $fout = fopen($filename,"r"); + // $tmpxml = fread($fout, filesize($filename)); + // $config['installedpackages']['freeswitchvars']['config'][0]['vars_xml'] = base64_encode($tmpxml); + // unset($filename, $dialplan); + // fclose($fout); + //} + //else { + // /* found the dialplan in the pfsense config.xml save it to default.xml. */ + // $fout = fopen("/usr/local/freeswitch/conf/vars.xml","w"); + // $tmpxml = $config['installedpackages']['freeswitchvars']['config'][0]['vars_xml']; + // fwrite($fout, base64_decode($tmpxml)); + // fclose($fout); + // unset($tmpxml); + //} + + conf_mount_ro(); + //$cmd = "api reloadxml"; + ////event_socket_request_cmd($cmd); + //unset($cmd); + +} + + +function sync_package_freeswitch_internal() +{ + global $config; + conf_mount_rw(); + config_unlock(); + + if(strlen($config['installedpackages']['freeswitchinternal']['config'][0]['internal_xml']) == 0) { + /* internal_xml not found in the pfsense config.xml get the internal.xml and save to config.xml. */ + $filename = "/usr/local/freeswitch/conf/sip_profiles/internal.xml"; + $fout = fopen($filename,"r"); + $tmpxml = fread($fout, filesize($filename)); + $config['installedpackages']['freeswitchinternal']['config'][0]['internal_xml'] = base64_encode($tmpxml); + unset($filename, $dialplan); + fclose($fout); + } + else { + /* found the internal_xml in the pfsense config.xml save it to internal.xml. */ + $fout = fopen("/usr/local/freeswitch/conf/sip_profiles/internal.xml","w"); + $tmpxml = $config['installedpackages']['freeswitchinternal']['config'][0]['internal_xml']; + fwrite($fout, base64_decode($tmpxml)); + fclose($fout); + unset($tmpxml); + } + + conf_mount_ro(); + $cmd = "api reloadxml"; + //event_socket_request_cmd($cmd); + unset($cmd); + +} + + +function sync_package_freeswitch_external() +{ + global $config; + conf_mount_rw(); + config_unlock(); + + if(strlen($config['installedpackages']['freeswitchexternal']['config'][0]['external_xml']) == 0) { + /* external_xml not found in the pfsense config.xml get the external.xml and save to config.xml. */ + $filename = "/usr/local/freeswitch/conf/sip_profiles/external.xml"; + $fout = fopen($filename,"r"); + $tmpxml = fread($fout, filesize($filename)); + $config['installedpackages']['freeswitchexternal']['config'][0]['external_xml'] = base64_encode($tmpxml); + unset($filename, $dialplan); + fclose($fout); + } + else { + /* found the external_xml in the pfsense config.xml save it to external.xml. */ + $fout = fopen("/usr/local/freeswitch/conf/sip_profiles/external.xml","w"); + $tmpxml = $config['installedpackages']['freeswitchexternal']['config'][0]['external_xml']; + fwrite($fout, base64_decode($tmpxml)); + fclose($fout); + unset($tmpxml); + } + + conf_mount_ro(); + $cmd = "api reloadxml"; + //event_socket_request_cmd($cmd); + unset($cmd); + +} + + +function sync_package_freeswitch_hunt_group() +{ + + //Hunt Group Javascript Notes: + //get the domain + //loop through all Hunt Groups + //get the Hunt Group information such as the name and description + //add each Hunt Group to the dialplan + //get the list of destinations then build the Hunt Group javascript + + + global $config; + conf_mount_rw(); + config_lock(); + + + //get the domain + $password = $config['installedpackages']['freeswitchsettings']['config'][0]['event_socket_password']; + $host = $config['interfaces']['lan']['ipaddr']; + $port = $config['installedpackages']['freeswitchsettings']['config'][0]['event_socket_port']; + + if (pkg_is_service_running('freeswitch')) { + $fp = event_socket_create($host, $port, $password); + $cmd = "api global_getvar domain"; + $domain = trim(event_socket_request($fp, $cmd)); + } + + $tmp = ""; + $tmp .= "\n"; + $tmp .= " var domain = \"".$domain."\"; //by default this is the ipv4 address of FreeSWITCH used for transfer to voicemail\n"; + //$tmp .= " var exit = false;\n"; + $tmp .= "\n"; + $tmp .= "\n"; + + //loop through all Hunt Groups + $x = 0; + $a_hunt_group = &$config['installedpackages']['freeswitchhuntgroup']['config']; + if (count($a_hunt_group) > 0) { + foreach($a_hunt_group as $rowhelper) { + + //get the Hunt Group information such as the name and description + //$rowhelper['huntgroupid'] + //$rowhelper['huntgroupextension'] + //$rowhelper['huntgroupname'] + //$rowhelper['huntgrouptype'] + //$rowhelper['huntgrouptimeout'] + //$rowhelper['huntgroupcontext'] + //$rowhelper['huntgroupringback'] + //$rowhelper['huntgroupcidnameprefix'] + //$rowhelper['huntgroupdescr'] + + //add each Hunt Group to the dialplan + $a_dialplan_includes = &$config['installedpackages']['freeswitchdialplanincludes']['config']; + $a_dialplan_include_details = &$config['installedpackages']['freeswitchdialplanincludedetails']['config']; + + + if (strlen($rowhelper['huntgroupid']) > 0) { + $action = 'add'; //set default action to add + $i = 0; + if (count($a_dialplan_includes) > 0) { + + foreach($a_dialplan_includes as $row) { + + //$row['dialplanincludeid']; + //$row['extensionname']; + //$row['context']; + //$row['enabled']; + + if ($row['opt1name'] == "huntgroupid" && $row['opt1value'] == $rowhelper['huntgroupid']) { + //update + $action = 'update'; + $dialplanincludeid = $row['dialplanincludeid']; + $extensionname = $row['extensionname']; + $order = $row['order']; + $context = $row['context']; + $enabled = $row['enabled']; + $descr = $row['descr']; + $opt1name = $row['opt1name']; + $opt1value = $row['opt1value']; + $id = $i; + //echo "update".$i."
\n"; + + } + $i++; + } + unset($i); + } + + + $ent = array(); + if ($action == 'add') { + + $dialplanincludeid = guid(); + $ent['dialplanincludeid'] = $dialplanincludeid; + $ent['extensionname'] = $rowhelper['huntgroupname']; + $ent['order'] = '9001'; //if update use the existing order number and extension name and desc + $ent['context'] = $rowhelper['huntgroupcontext']; + $ent['enabled'] = 'true'; + $ent['descr'] = 'huntgroup'; + $ent['opt1name'] = 'huntgroupid'; + $ent['opt1value'] = $rowhelper['huntgroupid']; + + //add to the config + $a_dialplan_includes[] = $ent; + unset($ent); + + $ent = array(); + $ent['dialplanincludeid'] = $dialplanincludeid; + $ent['tag'] = 'condition'; //condition, action, antiaction + $ent['fieldtype'] = 'destination_number'; + $ent['fielddata'] = '^'.$rowhelper['huntgroupextension'].'$'; + $a_dialplan_include_details[] = $ent; + unset($ent); + + $huntgroupid = str_replace(array("{", "}"), "", $rowhelper['huntgroupid']); + + $ent = array(); + $ent['dialplanincludeid'] = $dialplanincludeid; + $ent['tag'] = 'action'; //condition, action, antiaction + $ent['fieldtype'] = 'javascript'; + $ent['fielddata'] = 'huntgroup_'.$huntgroupid.'.js'; + $a_dialplan_include_details[] = $ent; + unset($ent); + + unset($huntgroupid); + + } + if ($action == 'update') { + + $ent['dialplanincludeid'] = $dialplanincludeid; + $ent['extensionname'] = $rowhelper['huntgroupname']; + $ent['order'] = $order; + $ent['context'] = $context; + $ent['enabled'] = $enabled; + $ent['descr'] = $descr; + $ent['opt1name'] = $opt1name; + $ent['opt1value'] = $opt1value; + + //update the config + $a_dialplan_includes[$id] = $ent; + + unset($ent); + unset($extensionname); + unset($order); + unset($context); + unset($enabled); + unset($descr); + unset($opt1name); + unset($opt1value); + unset($id); + } + write_config(); + + sync_package_freeswitch_dialplan_includes(); + unset($dialplanincludeid); + + } //end if strlen huntgroupid; add the Hunt Group to the dialplan + + //Get the list of destinations then build the Hunt Group javascript + $tmp = ""; + $tmp .= "\n"; + + $tmp .= " function get_sofia_contact(extension,domain_name, profile){\n"; + $tmp .= " if (profile == \"auto\") {\n"; + $i = 0; + foreach (ListFiles('/usr/local/freeswitch/conf/sip_profiles') as $key=>$sip_profile_file){ + $sip_profile_name = str_replace(".xml", "", $sip_profile_file); + if ($i == 0) { + $tmp .= " profile = \"".$sip_profile_name."\";\n"; + $tmp .= " session.execute(\"set\", \"sofia_contact_\"+extension+\"=\${sofia_contact(\"+profile+\"/\"+extension+\"@\"+domain_name+\")}\");\n"; + $tmp .= " sofia_contact = session.getVariable(\"sofia_contact_\"+extension);\n"; + } + else { + $tmp .= "\n"; + $tmp .= " if (sofia_contact == \"error/user_not_registered\") {\n"; + $tmp .= " profile = \"".$sip_profile_name."\";\n"; + $tmp .= " session.execute(\"set\", \"sofia_contact_\"+extension+\"=\${sofia_contact(\"+profile+\"/\"+extension+\"@\"+domain_name+\")}\");\n"; + $tmp .= " sofia_contact = session.getVariable(\"sofia_contact_\"+extension);\n"; + $tmp .= " }\n"; + } + $i++; + } + unset ($i); + $tmp .= " }\n"; + $tmp .= " else {\n"; + $tmp .= " session.execute(\"set\", \"sofia_contact_\"+extension+\"=\${sofia_contact(\"+profile+\"/\"+extension+\"@\"+domain_name+\")}\");\n"; + $tmp .= " sofia_contact = session.getVariable(\"sofia_contact_\"+extension);\n"; + $tmp .= " }\n"; + $tmp .= " console_log( \"info\", \"sofia_contact \"+profile+\": \"+sofia_contact+\".\\n\" );\n"; + $tmp .= " return sofia_contact;\n"; + $tmp .= " }\n"; + $tmp .= "\n"; + $tmp .= "\n"; + $tmp .= " dialed_extension = session.getVariable(\"dialed_extension\");\n"; + $tmp .= " domain_name = session.getVariable(\"domain_name\");\n"; + $tmp .= " domain = session.getVariable(\"domain\");\n"; + $tmp .= " us_ring = session.getVariable(\"us-ring\");\n"; + $tmp .= " caller_id_name = session.getVariable(\"caller_id_name\");\n"; + $tmp .= " caller_id_number = session.getVariable(\"caller_id_number\");\n"; + $tmp .= " effective_caller_id_name = session.getVariable(\"effective_caller_id_name\");\n"; + $tmp .= " effective_caller_id_number = session.getVariable(\"effective_caller_id_number\");\n"; + $tmp .= " outbound_caller_id_name = session.getVariable(\"outbound_caller_id_name\");\n"; + $tmp .= " outbound_caller_id_number = session.getVariable(\"outbound_caller_id_number\");\n"; + $tmp .= "\n"; + + //set caller id prefix + if (strlen($rowhelper['huntgroupcidnameprefix'])> 0) { + $tmp .= "session.execute(\"set\", \"caller_id_name=".$rowhelper['huntgroupcidnameprefix']."\"+caller_id_name);\n"; + $tmp .= "session.execute(\"set\", \"effective_caller_id_name=".$rowhelper['huntgroupcidnameprefix']."\"+effective_caller_id_name);\n"; + $tmp .= "session.execute(\"set\", \"outbound_caller_id_name=".$rowhelper['huntgroupcidnameprefix']."\"+outbound_caller_id_name);\n"; + } + + if (isset($rowhelper['huntgroupringback'])){ + if ($rowhelper['huntgroupringback'] == "ring"){ + $tmp .= " session.execute(\"set\", \"ringback=\"+us_ring); //set to ringtone\n"; + $tmp .= " session.execute(\"set\", \"transfer_ringback=\"+us_ring); //set to ringtone\n"; + } + if ($rowhelper['huntgroupringback'] == "music"){ + $tmp .= " session.execute(\"set\", \"ringback=\${hold_music}\"); //set to ringtone\n"; + $tmp .= " session.execute(\"set\", \"transfer_ringback=\${hold_music}\"); //set to ringtone\n"; + } + } + else { + $tmp .= " session.execute(\"set\", \"ringback=\${hold_music}\"); //set to ringtone\n"; + $tmp .= " session.execute(\"set\", \"transfer_ringback=\${hold_music}\"); //set to ringtone\n"; + } + + if ($rowhelper['huntgrouptimeout'] > 0) { + $tmp .= " session.execute(\"set\", \"call_timeout=".$rowhelper['huntgrouptimeout']."\");\n"; + $tmp .= " session.execute(\"set\", \"continue_on_fail=true\");\n"; + } + $tmp .= " session.execute(\"set\", \"hangup_after_bridge=true\");\n"; + $tmp .= "\n"; + $tmp .= " //console_log( \"info\", \"dialed extension:\"+dialed_extension+\".\\n\" );\n"; + $tmp .= " //console_log( \"info\", \"domain: \"+domain+\".\\n\" );\n"; + $tmp .= " //console_log( \"info\", \"us_ring: \"+us_ring+\".\\n\" );\n"; + $tmp .= " //console_log( \"info\", \"domain: \"+domain+\".\\n\" );\n"; + $tmp .= " //console_log( \"info\", \"domain_name: \"+domain_name+\".\\n\" );\n"; + $tmp .= "\n"; + + $tmp .= " //console_log( \"info\", \"action call now don't wait for dtmf\\n\" );\n"; + $tmp .= " if ( session.ready() ) {\n"; + $tmp .= " session.answer();\n"; + $tmp .= "\n"; + + $a_hunt_group = &$config['installedpackages']['freeswitchhuntgroup']['config']; + if (isset($id) && $a_hunt_group[0]) { + $huntgrouptimeout = $a_hunt_group[$id]['huntgrouptimeout']; + $huntgrouptimeoutdestination = $a_hunt_group[$id]['huntgrouptimeoutdestination']; + } + + //order the array + if (!function_exists(cmp_hunt_group_order)) { + function cmp_hunt_group_order($a, $b) { + if ($a["destinationorder"] > $b["destinationorder"]) { + return 1; + } + else { + return 0; + } + } + } + + + $a_hunt_group_destinations = &$config['installedpackages']['freeswitchhuntgroupdestinations']['config']; + if (count($a_hunt_group_destinations) > 0) { usort($a_hunt_group_destinations, "cmp_hunt_group_order"); } + if (count($a_hunt_group_destinations) > 0) { + + $i = 0; + foreach($a_hunt_group_destinations as $row) { + + /* + $row['huntgroupid'] + $row['destinationnumber'] + $row['destinationtype'] + $row['destinationprofile'] + $row['destinationorder'] + $row['destinationdescr'] + */ + + if ($row['huntgroupid'] == $rowhelper['huntgroupid']) { + + //set the default profile + if (strlen($row['destinationnumber']) == 0) { $row['destinationnumber'] = "internal"; } + + if ($row['destinationtype'] == "extension") { + $tmp .= " sofia_contact_".$row['destinationnumber']." = get_sofia_contact(\"".$row['destinationnumber']."\",domain_name, \"".$row['destinationprofile']."\");\n"; + $tmp_sub_array["application"] = "bridge"; + $tmp_sub_array["data"] = "sofia_contact_".$row['destinationnumber']; + $tmp_array[$i] = $tmp_sub_array; + unset($tmp_sub_array); + } + if ($row['destinationtype'] == "voicemail") { + $tmp .= " session.execute(\"voicemail\", \"default \${domain} ".$row['destinationnumber']."\");\n"; + $tmp_sub_array["application"] = "voicemail"; + $tmp_sub_array["data"] = "default \${domain} ".$row['destinationnumber']; + $tmp_array[$i] = $tmp_sub_array; + unset($tmp_sub_array); + } + if ($row['destinationtype'] == "sip uri") { + $tmp_sub_array["application"] = "bridge"; + $tmp_sub_array["data"] = "\"".$row['destinationnumber']."\""; + $tmp_array[$i] = $tmp_sub_array; + unset($tmp_sub_array); + } + $i++; + + } //end huntgroupid + + } //end for each + unset($i); + } //if count + + + + switch ($rowhelper['huntgrouptype']) { + case "simultaneous": + //print_r($tmp_array); + $i = 0; + if(count($tmp_array) > 0) { + foreach ($tmp_array as $row) { + if ($i < 1) { + $tmp_buffer = $row["data"]; + } + else { + $tmp_buffer .= "+\",\"+".$row["data"]; + } + $i++; + } + } + unset($i); + + $delimiter = ","; + $tmp_application = $tmp_array[0]["application"]; + unset($tmp_array); + + $tmp .= "\n"; + $tmp .= " session.execute(\"".$tmp_application."\", $tmp_buffer);\n"; + //$tmp .= " session.execute(\"bridge\", sofia_contact_100+\",\"+sofia_contact_101+\",\"+sofia_contact_102+\",\"+sofia_contact_103+\",\"+sofia_contact_104);\n"; + //$tmp .= " //session.execute(\"bridge\", \"sofia/gateway/flowroute.com/12081231234,\"+sofia_contact_101);\n"; + + break; + case "sequentially": + + $tmp .= "\n"; + //print_r($tmp_array); + $i = 0; + if (count($tmp_array) > 0) { + foreach ($tmp_array as $row) { + $tmp .= " session.execute(\"".$row["application"]."\", ".$row["data"].");\n"; + } + unset($tmp_array); + } + + break; + } + + + //set the timeout destination + $huntgrouptimeoutdestination = $a_hunt_group[$x]['huntgrouptimeoutdestination']; + $huntgrouptimeouttype = $a_hunt_group[$x]['huntgrouptimeouttype']; + if ($row['huntgrouptimeouttype'] == "extension") { $huntgrouptimeouttype = "bridge"; } + if ($row['huntgrouptimeouttype'] == "voicemail") { $huntgrouptimeouttype = "voicemail"; } + if ($row['huntgrouptimeouttype'] == "sip uri") { $huntgrouptimeouttype = "bridge"; } + $tmp .= "\n"; + $tmp .= " //timeout\n"; + $tmp .= " session.execute(\"".$huntgrouptimeouttype."\", \"default \${domain} ".$huntgrouptimeoutdestination."\");\n"; + + + $tmp .= "\n"; + $tmp .= " //clear variables\n"; + $tmp .= " dialed_extension = \"\";\n"; + $tmp .= " new_extension = \"\";\n"; + $tmp .= " domain_name = \"\";\n"; + $tmp .= " domain = \"\";"; + + $tmp .= "\n"; + $tmp .= " } //end if session.ready\n"; + $tmp .= "\n"; + + if (strlen($rowhelper['huntgroupid']) > 0) { + $huntgroupfilename = "huntgroup_".str_replace(array("{", "}"), "", $rowhelper['huntgroupid']).".js"; + $fout = fopen("/usr/local/freeswitch/scripts/".$huntgroupfilename,"w"); + fwrite($fout, $tmp); + unset($huntgroupfilename); + fclose($fout); + } + + $x++; + } //end foreach + } //end if count + conf_mount_ro(); + config_unlock(); + +} //end function + + +function sync_package_freeswitch_fax() +{ + + global $config; + conf_mount_rw(); + config_lock(); + + //loop through all faxes + $a_fax = &$config['installedpackages']['freeswitchfax']['config']; + if (count($a_fax) > 0) { + foreach($a_fax as $rowhelper) { + + //get the fax information such as the name and description + //$rowhelper['faxid'] + //$rowhelper['faxextension'] + //$rowhelper['faxname'] + //$rowhelper['faxemail'] + //$rowhelper['faxdomain'] + //$rowhelper['faxdescription'] + + //add each fax extension to the dialplan + $a_dialplan_includes = &$config['installedpackages']['freeswitchdialplanincludes']['config']; + $a_dialplan_include_details = &$config['installedpackages']['freeswitchdialplanincludedetails']['config']; + + //determine if the entry should be an add, or update to the dialplan + if (strlen($rowhelper['faxid']) > 0) { + $action = 'add'; //set default action to add + $i = 0; + if (count($a_dialplan_includes) > 0) { + + foreach($a_dialplan_includes as $row) { + + //$row['faxid']; + //$row['faxname']; + //$row['context']; + //$row['enabled']; + + if ($row['opt1name'] == "faxid" && $row['opt1value'] == $rowhelper['faxid']) { + //update + $action = 'update'; + + $dialplanincludeid = $rowhelper['dialplanincludeid']; + $extensionname = $row['extensionname']; + $order = $row['order']; + $context = $row['context']; + $enabled = $row['enabled']; + $descr = $row['descr']; + $opt1name = $row['opt1name']; + $opt1value = $row['opt1value']; + $id = $i; + //echo "update".$i."
\n"; + + if (file_exists("/usr/local/freeswitch/conf/dialplan/default/".$order."_".$extensionname.".xml")){ + unlink("/usr/local/freeswitch/conf/dialplan/default/".$order."_".$extensionname.".xml"); + } + } + $i++; + + } + } + + $ent = array(); + if ($action == 'add') { + $faxid = $rowhelper['faxid']; + if (strlen($rowhelper['faxname']) > 0) { + $ent['dialplanincludeid'] = $faxid; + $ent['extensionname'] = $rowhelper['faxname']; + $ent['order'] = '9001'; //if update use the existing order number and extension name and desc + $ent['context'] = "default"; + //$ent['context'] = $rowhelper['huntgroupcontext']; + $ent['enabled'] = 'true'; + $ent['descr'] = 'fax'; + $ent['opt1name'] = 'faxid'; + $ent['opt1value'] = $rowhelper['faxid']; + + //add to the config + $a_dialplan_includes[] = $ent; + unset($ent); + + // + // + $ent = array(); + $ent['dialplanincludeid'] = $faxid; + $ent['tag'] = 'condition'; //condition, action, antiaction + $ent['fieldorder'] = '000'; + $ent['fieldtype'] = 'destination_number'; + $ent['fielddata'] = '^'.$rowhelper['faxextension'].'$'; + $a_dialplan_include_details[] = $ent; + unset($ent); + + // + $ent = array(); + $ent['dialplanincludeid'] = $faxid; + $ent['tag'] = 'action'; //condition, action, antiaction + $ent['fieldorder'] = '001'; + $ent['fieldtype'] = 'answer'; + $ent['fielddata'] = ''; + $a_dialplan_include_details[] = $ent; + unset($ent); + + // + $ent = array(); + $ent['dialplanincludeid'] = $faxid; + $ent['tag'] = 'action'; //condition, action, antiaction + $ent['fieldorder'] = '002'; + $ent['fieldtype'] = 'playback'; + $ent['fielddata'] = 'silence_stream://2000'; + $a_dialplan_include_details[] = $ent; + unset($ent); + + // + $ent = array(); + $ent['dialplanincludeid'] = $faxid; + $ent['tag'] = 'action'; //condition, action, antiaction + $ent['fieldorder'] = '003'; + $ent['fieldtype'] = 'set'; + $ent['fielddata'] = 'last_fax=${caller_id_number}-${strftime(%Y-%m-%d-%H-%M-%S)}'; + $a_dialplan_include_details[] = $ent; + unset($ent); + + // + $ent = array(); + $ent['dialplanincludeid'] = $faxid; + $ent['tag'] = 'action'; //condition, action, antiaction + $ent['fieldorder'] = '004'; + $ent['fieldtype'] = 'rxfax'; + $ent['fielddata'] = '/usr/local/freeswitch/storage/fax/'.$rowhelper['faxextension'].'/inbox/${last_fax}.tif'; + $a_dialplan_include_details[] = $ent; + unset($ent); + + // + $ent = array(); + $ent['dialplanincludeid'] = $faxid; + $ent['tag'] = 'action'; //condition, action, antiaction + $ent['fieldorder'] = '005'; + $ent['fieldtype'] = 'system'; + $ent['fielddata'] = '/usr/local/bin/php /usr/local/www/packages/freeswitch/fax_to_email.php email='.$rowhelper['faxemail'].' extension='.$rowhelper['faxextension'].' name=${last_fax} >> /tmp/fax.txt'; + $a_dialplan_include_details[] = $ent; + unset($ent); + + // + $ent = array(); + $ent['dialplanincludeid'] = $faxid; + $ent['tag'] = 'action'; //condition, action, antiaction + $ent['fieldorder'] = '006'; + $ent['fieldtype'] = 'hangup'; + $ent['fielddata'] = ''; + $a_dialplan_include_details[] = $ent; + unset($ent); + } + + unset($faxid); + + } + if ($action == 'update') { + + $ent['dialplanincludeid'] = $rowhelper['faxid']; + $ent['extensionname'] = $rowhelper['faxname']; + $ent['order'] = $order; + $ent['context'] = $context; + $ent['enabled'] = $enabled; + $ent['descr'] = $faxdescription; + $ent['opt1name'] = $opt1name; + $ent['opt1value'] = $opt1value; + + //update the config + $a_dialplan_includes[$id] = $ent; + + unset($ent); + unset($extensionname); + unset($order); + unset($context); + unset($enabled); + unset($descr); + unset($opt1name); + unset($opt1value); + unset($id); + } + write_config(); + + sync_package_freeswitch_dialplan_includes(); + unset($dialplanincludeid); + + } //end if strlen faxid; add the fax to the dialplan + + } //end foreach + } //end if count + conf_mount_ro(); + config_unlock(); + +} //end function + + +function get_recording_filename($id) +{ + global $config; + $a_recordings = &$config['installedpackages']['freeswitchrecordings']['config']; + if (count($a_recordings) > 0) { + global $config; + foreach($a_recordings as $rowhelper) { + if ($rowhelper['recordingid'] == $id) { + return $rowhelper['filename']; + } + } + } +} + + +function sync_package_freeswitch_ivr() +{ + + global $config; + conf_mount_rw(); + config_lock(); + + $a_ivr = &$config['installedpackages']['freeswitchivr']['config']; + if (count($a_ivr) > 0) { + foreach($a_ivr as $rowhelper) { + + /* + $rowhelper['ivrid'] + $rowhelper['ivrextension'] + $rowhelper['ivrname'] + $rowhelper['recordingid'] + $rowhelper['ivrtimeout'] + $rowhelper['ivrcalltimeout'] + $rowhelper['ivrcontext'] + $rowhelper['ivrdirectdial'] + $rowhelper['ivrconditionjs'] + $rowhelper['ivrringback'] + $rowhelper['ivrcidnameprefix'] + $rowhelper['ivrdescr'] + */ + + $a_dialplan_includes = &$config['installedpackages']['freeswitchdialplanincludes']['config']; + $a_dialplan_include_details = &$config['installedpackages']['freeswitchdialplanincludedetails']['config']; + + + //add the IVR to the dialplan + if (strlen($rowhelper['ivrid']) > 0) { + $action = 'add'; //set default action to add + $i = 0; + if (count($a_dialplan_includes) > 0) { + foreach($a_dialplan_includes as $row) { + + //$row['dialplanincludeid']; + //$row['extensionname']; + //$row['context']; + //$row['enabled']; + //echo "if (".$row['opt1name']." == \"ivrid\" && ".$row['opt1value']." == ".$rowhelper['ivrid'].") \n"; + + if ($row['opt1name'] == "ivrid" && $row['opt1value'] == $rowhelper['ivrid']) { + //update + $action = 'update'; + $dialplanincludeid = $row['dialplanincludeid']; + $extensionname = $row['extensionname']; + $order = $row['order']; + $context = $row['context']; + $enabled = $row['enabled']; + $descr = $row['descr']; + $opt1name = $row['opt1name']; + $opt1value = $row['opt1value']; + $id = $i; + //echo "update".$i."
\n"; + + } + $i++; + + } //end foreach + } //if count + + + $ent = array(); + if ($action == 'add') { + + $dialplanincludeid = guid(); + $ent['dialplanincludeid'] = $dialplanincludeid; + $ent['extensionname'] = $rowhelper['ivrextension']; + $ent['order'] = '9001'; //if update use the existing order number and extension name and desc + $ent['context'] = $rowhelper['ivrcontext']; + $ent['enabled'] = 'true'; + $ent['descr'] = 'IVR'; + $ent['opt1name'] = 'ivrid'; + $ent['opt1value'] = $rowhelper['ivrid']; + + //add to the config + $a_dialplan_includes[] = $ent; + unset($ent); + + $ent = array(); + $ent['dialplanincludeid'] = $dialplanincludeid; + $ent['tag'] = 'condition'; //condition, action, antiaction + $ent['fieldtype'] = 'destination_number'; + $ent['fielddata'] = '^'.$rowhelper['ivrextension'].'$'; + $a_dialplan_include_details[] = $ent; + unset($ent); + + $ivrid = str_replace(array("{", "}"), "", $rowhelper['ivrid']); + + $ent = array(); + $ent['dialplanincludeid'] = $dialplanincludeid; + $ent['tag'] = 'action'; //condition, action, antiaction + $ent['fieldtype'] = 'javascript'; + $ent['fielddata'] = 'ivr_'.$ivrid.'.js'; + $a_dialplan_include_details[] = $ent; + unset($ent); + + unset($ivrid); + + } + if ($action == 'update') { + + $ent['dialplanincludeid'] = $dialplanincludeid; + $ent['extensionname'] = $rowhelper['ivrextension']; + $ent['order'] = $order; + $ent['context'] = $context; + $ent['enabled'] = $enabled; + $ent['descr'] = $descr; + $ent['opt1name'] = $opt1name; + $ent['opt1value'] = $opt1value; + + //update the config + $a_dialplan_includes[$id] = $ent; + + unset($ent); + unset($extensionname); + unset($order); + unset($context); + unset($enabled); + unset($descr); + unset($opt1name); + unset($opt1value); + unset($id); + } + write_config(); + + sync_package_freeswitch_dialplan_includes(); + unset($dialplanincludeid); + + } //end if strlen ivrid; add the IVR to the dialplan + + // Build the IVR javascript + $recording_action_filename = get_recording_filename($rowhelper['recordingidaction']); + $recording_antiaction_filename = get_recording_filename($rowhelper['recordingidantiaction']); + + $password = $config['installedpackages']['freeswitchsettings']['config'][0]['event_socket_password']; + $port = $config['installedpackages']['freeswitchsettings']['config'][0]['event_socket_port']; + $host = $config['interfaces']['lan']['ipaddr']; + + if (pkg_is_service_running('freeswitch')) { + $fp = event_socket_create($host, $port, $password); + $cmd = "api global_getvar domain"; + $domain = trim(event_socket_request($fp, $cmd)); + } + + + $tmp = ""; //make sure the variable starts with no value + $tmp .= "\n"; + $tmp .= " var condition = true;\n"; + $tmp .= "\n"; + $tmp .= " var domain = \"".$domain."\"; //by default this is the ipv4 address of FreeSWITCH used for transfer to voicemail\n"; + $tmp .= " var digitmaxlength = 0;\n"; + $tmp .= " var objdate = new Date();\n"; + $tmp .= "\n"; + $tmp .= " var adjusthours = 0; //Adjust Server time that is set to GMT 7 hours\n"; + $tmp .= " var adjustoperator = \"-\"; //+ or -\n"; + $tmp .= "\n"; + $tmp .= " if (adjustoperator == \"-\") {\n"; + $tmp .= " var objdate2 = new Date(objdate.getFullYear(),objdate.getMonth(),objdate.getDate(),(objdate.getHours() - adjusthours),objdate.getMinutes(),objdate.getSeconds());\n"; + $tmp .= " }\n"; + $tmp .= " if (adjustoperator == \"+\") {\n"; + $tmp .= " var objdate2 = new Date(objdate.getFullYear(),objdate.getMonth(),objdate.getDate(),(objdate.getHours() + adjusthours),objdate.getMinutes(),objdate.getSeconds());\n"; + $tmp .= " }\n"; + $tmp .= "\n"; + $tmp .= " var Hours = objdate2.getHours();\n"; + $tmp .= " var Mins = objdate2.getMinutes();\n"; + $tmp .= " var Seconds = objdate2.getSeconds();\n"; + $tmp .= " var Month = objdate2.getMonth() + 1;\n"; + $tmp .= " var Date = objdate2.getDate();\n"; + $tmp .= " var Year = objdate2.getYear()\n"; + $tmp .= " var Day = objdate2.getDay()+1;\n"; + $tmp .= " var exit = false;\n"; + $tmp .= "\n"; + $tmp .= " dialed_extension = session.getVariable(\"dialed_extension\");\n"; + $tmp .= " domain_name = session.getVariable(\"domain_name\");\n"; + $tmp .= " domain = session.getVariable(\"domain\");\n"; + $tmp .= " us_ring = session.getVariable(\"us-ring\");\n"; + $tmp .= " caller_id_name = session.getVariable(\"caller_id_name\");\n"; + $tmp .= " caller_id_number = session.getVariable(\"caller_id_number\");\n"; + $tmp .= " effective_caller_id_name = session.getVariable(\"effective_caller_id_name\");\n"; + $tmp .= " effective_caller_id_number = session.getVariable(\"effective_caller_id_number\");\n"; + $tmp .= " outbound_caller_id_name = session.getVariable(\"outbound_caller_id_name\");\n"; + $tmp .= " outbound_caller_id_number = session.getVariable(\"outbound_caller_id_number\");\n"; + $tmp .= "\n"; + + //set caller id prefix + if (strlen($rowhelper['ivrcidnameprefix'])> 0) { + $tmp .= "session.execute(\"set\", \"caller_id_name=".$rowhelper['ivrcidnameprefix']."\"+caller_id_name);\n"; + $tmp .= "session.execute(\"set\", \"effective_caller_id_name=".$rowhelper['ivrcidnameprefix']."\"+effective_caller_id_name);\n"; + $tmp .= "session.execute(\"set\", \"outbound_caller_id_name=".$rowhelper['ivrcidnameprefix']."\"+outbound_caller_id_name);\n"; + } + + $tmp .= "\n"; + + $tmp .= " session.execute(\"set\", \"continue_on_fail=true\");\n"; + if (strlen($rowhelper['ivrcalltimeout']) == 0){ + $tmp .= " session.execute(\"set\", \"call_timeout=30\");\n"; //ivrcalltimeout + } + else { + $tmp .= " session.execute(\"set\", \"call_timeout=".$rowhelper['ivrcalltimeout']."\");\n"; //ivrcalltimeout + } + + if (isset($rowhelper['ivrringback'])){ + if ($rowhelper['ivrringback'] == "ring"){ + $tmp .= " session.execute(\"set\", \"ringback=\"+us_ring); //set to ringtone\n"; + $tmp .= " session.execute(\"set\", \"transfer_ringback=\"+us_ring); //set to ringtone\n"; + } + if ($rowhelper['ivrringback'] == "music"){ + $tmp .= " session.execute(\"set\", \"ringback=\${hold_music}\"); //set to ringtone\n"; + $tmp .= " session.execute(\"set\", \"transfer_ringback=\${hold_music}\"); //set to ringtone\n"; + } + } + else { + $tmp .= " session.execute(\"set\", \"ringback=\${hold_music}\"); //set to ringtone\n"; + $tmp .= " session.execute(\"set\", \"transfer_ringback=\${hold_music}\"); //set to ringtone\n"; + } + $tmp .= "\n"; + $tmp .= "//console_log( \"info\", \"IVR Server Time is: \"+Hours+\":\"+Mins+\" \\n\" );\n"; + $tmp .= "\n"; + + $tmp .= " function get_sofia_contact(extension,domain_name, profile){\n"; + $tmp .= " if (profile == \"auto\") {\n"; + $i = 0; + foreach (ListFiles('/usr/local/freeswitch/conf/sip_profiles') as $key=>$sip_profile_file){ + $sip_profile_name = str_replace(".xml", "", $sip_profile_file); + if ($i == 0) { + $tmp .= " profile = \"".$sip_profile_name."\";\n"; + $tmp .= " session.execute(\"set\", \"sofia_contact_\"+extension+\"=\${sofia_contact(\"+profile+\"/\"+extension+\"@\"+domain_name+\")}\");\n"; + $tmp .= " sofia_contact = session.getVariable(\"sofia_contact_\"+extension);\n"; + } + else { + $tmp .= "\n"; + $tmp .= " if (sofia_contact == \"error/user_not_registered\") {\n"; + $tmp .= " profile = \"".$sip_profile_name."\";\n"; + $tmp .= " session.execute(\"set\", \"sofia_contact_\"+extension+\"=\${sofia_contact(\"+profile+\"/\"+extension+\"@\"+domain_name+\")}\");\n"; + $tmp .= " sofia_contact = session.getVariable(\"sofia_contact_\"+extension);\n"; + $tmp .= " }\n"; + } + $i++; + } + unset ($i); + $tmp .= " }\n"; + $tmp .= " else {\n"; + $tmp .= " session.execute(\"set\", \"sofia_contact_\"+extension+\"=\${sofia_contact(\"+profile+\"/\"+extension+\"@\"+domain_name+\")}\");\n"; + $tmp .= " sofia_contact = session.getVariable(\"sofia_contact_\"+extension);\n"; + $tmp .= " }\n"; + $tmp .= " console_log( \"info\", \"sofia_contact \"+profile+\": \"+sofia_contact+\".\\n\" );\n"; + $tmp .= " return sofia_contact;\n"; + $tmp .= " }\n"; + $tmp .= "\n"; + + $tmp .= " function mycb( session, type, obj, arg ) {\n"; + $tmp .= " try {\n"; + $tmp .= " if ( type == \"dtmf\" ) {\n"; + $tmp .= " console_log( \"info\", \"digit: \"+obj.digit+\"\\n\" );\n"; + $tmp .= " if ( obj.digit == \"#\" ) {\n"; + $tmp .= " //console_log( \"info\", \"detected pound sign.\\n\" );\n"; + $tmp .= " exit = true;\n"; + $tmp .= " return( false );\n"; + $tmp .= " }\n"; + $tmp .= "\n"; + $tmp .= " dtmf.digits += obj.digit;\n"; + $tmp .= "\n"; + $tmp .= " if ( dtmf.digits.length >= digitmaxlength ) {\n"; + $tmp .= " exit = true;\n"; + $tmp .= " return( false );\n"; + $tmp .= " }\n"; + $tmp .= " }\n"; + $tmp .= " } catch (e) {\n"; + $tmp .= " console_log( \"err\", e+\"\\n\" );\n"; + $tmp .= " }\n"; + $tmp .= " return( true );\n"; + $tmp .= " } //end function mycb\n"; + + $tmp .= "\n"; + $tmp .= base64_decode($rowhelper['ivrconditionjs']); + $tmp .= "\n"; + $tmp .= "\n"; + + //$tmp .= " //condition = true; //debugging\n"; + + $actiondirect = false; + $actiondefault = false; + $actioncount = 0; + foreach($config['installedpackages']['freeswitchivroptions']['config'] as $row) { + //find the correct IVR options with the correct action + if ($row['ivrid'] == $rowhelper['ivrid']) { + + if ($row['optionaction'] == "action") { + $actioncount++; + if (strtolower($row['optionnumber']) == "n") { //direct the call now don't wait for dtmf + //echo "now found\n"; + $actiondirect = true; + $actiondirecttype = $row['optiontype']; + $actiondirectprofile = $row['optionprofile']; + $actiondirectdest = $row['optiondest']; + } + if (strtolower($row['optionnumber']) == "d") { //default option used when dtmf doesn't match any other option + //echo "default found\n"; + $actiondefault = true; + $actiondefaulttype = $row['optiontype']; + $actiondefaultprofile = $row['optionprofile']; + $actiondefaultdest = $row['optiondest']; + } + } + } + } + //$tmp .= "action count: ".$actioncount."
\n"; + if ($actioncount > 0) { + if ($actiondirect) { + $tmp .= " if (condition) {\n"; + $tmp .= " //direct\n"; + $tmp .= " //console_log( \"info\", \"action direct\\n\" );\n"; + if ($actiondirecttype == "extension") { + $tmp .= " sofia_contact_".$actiondirectdest." = get_sofia_contact(\"".$actiondirectdest."\",domain_name, \"".$actiondirectprofile."\");\n"; + $tmp .= " session.execute(\"bridge\", sofia_contact_".$actiondirectdest."); //".$actiondirectdest."\n"; + if ($actiondirectprofile == "auto") { + $tmp .= " session.execute(\"voicemail\", \"default \${domain} ".$actiondirectdest."\");\n"; + } + else { + $tmp .= " session.execute(\"voicemail\", \"default \${domain} ".$actiondirectdest."\");\n"; + } + } + if ($actiondirecttype == "voicemail") { + if ($actiondirectprofile == "auto") { + $tmp .= " session.execute(\"voicemail\", \"default \${domain} ".$actiondirectdest."\");\n"; + } + else { + $tmp .= " session.execute(\"voicemail\", \"default \${domain} ".$actiondirectdest."\");\n"; + } + } + if ($actiondirecttype == "sip uri") { + $tmp .= " session.execute(\"bridge\", \"".$actiondirectdest."\"); //".$actiondirectdest."\n"; + + } + + $tmp .= "}\n"; + + } + else { + $tmp .= " if (condition) {\n"; + $tmp .= " //action\n"; + $tmp .= "\n"; + $tmp .= " //console_log( \"info\", \"action call now don't wait for dtmf\\n\" );\n"; + $tmp .= " var dtmf = new Object( );\n"; + $tmp .= " dtmf.digits = \"\";\n"; + $tmp .= " if ( session.ready( ) ) {\n"; + $tmp .= " session.answer( );\n"; + $tmp .= "\n"; + $tmp .= " digitmaxlength = 1;\n"; + $tmp .= " while (session.ready() && ! exit ) {\n"; + $tmp .= " //session.streamFile( \"C:/Program Files/FreeSWITCH/sounds/".$recording_action_filename."\", mycb, \"dtmf ".$rowhelper['ivrtimeout']."\" );\n"; + $tmp .= " session.streamFile( \"/usr/local/freeswitch/recordings/".$recording_action_filename."\", mycb, \"dtmf ".$rowhelper['ivrtimeout']."\" );\n"; + $tmp .= " if (session.ready()) {\n"; + $tmp .= " if (dtmf.digits.length == 0) {\n"; + $tmp .= " dtmf.digits += session.getDigits(1, \"#\", ".($rowhelper['ivrtimeout']*1000)."); // ".$rowhelper['ivrtimeout']." seconds\n"; + $tmp .= " if (dtmf.digits.length == 0) {\n"; + //$tmp .= " console_log( "info", "time out option: " + dtmf.digits + "\n" );\n"; + + $a_ivr_options = &$config['installedpackages']['freeswitchivroptions']['config']; + //find the timeout IVR options with the correct action + if (count($a_ivr_options) > 0) { + foreach($a_ivr_options as $row) { + + if ($row['ivrid'] == $rowhelper['ivrid']) { + + if ($row['optionaction'] == "action") { + if (strtolower($row['optionnumber']) == "t") { + if ($row['optiontype'] == "extension") { + $tmp .= " sofia_contact_".$row['optiondest']." = get_sofia_contact(\"".$row['optiondest']."\",domain_name, \"".$row['optionprofile']."\");\n"; + $tmp .= " session.execute(\"bridge\", sofia_contact_".$row['optiondest']."); //".$row['optiondescr']."\n"; + if ($row['optionprofile'] == "auto") { + $tmp .= " session.execute(\"voicemail\", \"default \${domain} ".$row['optiondest']."\");\n"; + } + else { + $tmp .= " session.execute(\"voicemail\", \"default \${domain} ".$row['optiondest']."\");\n"; + } + } + if ($row['optiontype'] == "voicemail") { + if ($row['optionprofile'] == "auto") { + $tmp .= " session.execute(\"voicemail\", \"default \${domain} ".$row['optiondest']."\"); //".$row['optiondescr']."\n"; + } + else { + $tmp .= " session.execute(\"voicemail\", \"default \${domain} ".$row['optiondest']."\"); //".$row['optiondescr']."\n"; + } + } + if ($row['optiontype'] == "sip uri") { + $tmp .= " session.execute(\"bridge\", \"".$row['optiondest']."\"); //".$row['optiondescr']."\n"; + } + } + } //end anti-action + + } //end ivrid + + } //end for each + } //if count + + $tmp .= " }\n"; + $tmp .= " else {\n"; + $tmp .= " break; //dtmf found end the while loop\n"; + $tmp .= " }\n"; + $tmp .= " }\n"; + $tmp .= " }\n"; + $tmp .= " }\n"; + $tmp .= "\n"; + $tmp .= " //pickup the remaining digits\n"; + //$tmp .= " //http://wiki.freeswitch.org/wiki/Session_getDigits\n"; + //$tmp .= " //getDigits(length, terminators, timeout, digit_timeout, abs_timeout)\n"; + //$tmp .= " //dtmf.digits += session.getDigits(2, \"#\", 3000); //allow up to 3 digits\n"; + $tmp .= " dtmf.digits += session.getDigits(4, \"#\", 3000); //allow up to 5 digits\n"; + $tmp .= "\n"; + $tmp .= "\n"; + //$tmp .= " console_log( \"info\", \"IVR Digit Pressed: \" + dtmf.digits + \"\\n\" );\n"; + + + //action + $tmpaction = ""; + + $tmp .= " if ( dtmf.digits.length > \"0\" ) {\n"; + $x = 0; + $a_ivr_options = &$config['installedpackages']['freeswitchivroptions']['config']; + if (count($a_ivr_options) > 0) { + foreach($a_ivr_options as $row) { + + /* + $row['ivrid'] + $row['optionnumber'] + $row['optiontype'] + $row['optionaction'] + $row['optiondest'] + $row['optiondescr'] + */ + + $tmpactiondefault = ""; + + //find the correct IVR options with the correct action + if ($row['ivrid'] == $rowhelper['ivrid']){ + + if ($row['optionaction'] == "action") { + //$tmpaction .= "\n"; + + switch ($row['optionnumber']) { + //case "t": + // break; + //case "d": + // break; + default: + //$tmpaction .= " //console_log( \"info\", \"IVR Detected 1 digit \\n\" );\n"; + if ($x == 0) { + $tmpaction .= " if ( dtmf.digits == \"".$row['optionnumber']."\" ) { //".$row['optiondescr']."\n"; + } + else { + $tmpaction .= " else if ( dtmf.digits == \"".$row['optionnumber']."\" ) { //".$row['optiondescr']."\n"; + } + if ($row['optiontype'] == "extension") { + $tmpaction .= " sofia_contact_".$row['optiondest']." = get_sofia_contact(\"".$row['optiondest']."\",domain_name, \"".$row['optionprofile']."\");\n"; + $tmpaction .= " session.execute(\"bridge\", sofia_contact_".$row['optiondest']."); //".$row['optiondescr']."\n"; + if ($row['optionprofile'] == "auto") { + $tmpaction .= " session.execute(\"voicemail\", \"default \${domain} ".$row['optiondest']."\");\n"; + } + else { + $tmpaction .= " session.execute(\"voicemail\", \"default \${domain} ".$row['optiondest']."\"); //".$row['optiondescr']."\n"; + } + } + if ($row['optiontype'] == "voicemail") { + if ($row['optionprofile'] == "auto") { + $tmpaction .= " session.execute(\"voicemail\", \"default \${domain} ".$row['optiondest']."\"); //".$row['optiondescr']."\n"; + } + else { + $tmpaction .= " session.execute(\"voicemail\", \"default \${domain} ".$row['optiondest']."\"); //".$row['optiondescr']."\n"; + } + } + if ($row['optiontype'] == "sip uri") { + $tmpaction .= " session.execute(\"bridge\", \"".$row['optiondest']."\"); //".$row['optiondescr']."\n"; + } + + $tmpaction .= " }\n"; + + } + + $x++; + } //end if action + + } //end ivrid + + + } //end foreach + } //end if count + + $tmp .= $tmpaction; + if ($rowhelper['ivrdirectdial'] == "true") { + $tmp .= " else {\n"; + $tmp .= " session.execute(\"transfer\", dtmf.digits+\" XML default\");\n"; + //$tmp .= $tmpactiondefault; + $tmp .= " }\n"; + } + else { + if ($actiondefault) { + $tmp .= " else {\n"; + $tmp .= " //console_log( \"info\", \"default option when there is no matching dtmf found\\n\" );\n"; + if ($actiondefaulttype == "extension") { + $tmp .= " sofia_contact_".$actiondefaultdest." = get_sofia_contact(\"".$actiondefaultdest."\",domain_name, \"".$actiondirectprofile."\");\n"; + $tmp .= " session.execute(\"bridge\", sofia_contact_".$actiondefaultdest."); //".$actiondefaultdest."\n"; + if ($actiondirectprofile == "auto") { + $tmp .= " session.execute(\"voicemail\", \"default \${domain} ".$actiondefaultdest."\");\n"; + } + else { + $tmp .= " session.execute(\"voicemail\", \"default \${domain} ".$actiondefaultdest."\");\n"; + } + } + if ($actiondefaulttype == "voicemail") { + if ($actiondirectprofile == "auto") { + $tmp .= " session.execute(\"voicemail\", \"default \${domain} ".$actiondefaultdest."\");\n"; + } + else { + $tmp .= " session.execute(\"voicemail\", \"default \${domain} ".$actiondefaultdest."\");\n"; + } + } + if ($actiondefaulttype == "sip uri") { + $tmp .= " session.execute(\"bridge\", \"".$actiondefaultdest."\"); //".$actiondefaultdest."\n"; + } + $tmp .= " }\n"; + + } + } + + $tmp .= "\n"; + unset($tmpaction); + + + $tmp .= " } \n"; + //$tmp .= " else if ( dtmf.digits.length == \"4\" ) {\n"; + //$tmp .= " //Transfer to the extension the caller\n"; + //$tmp .= " session.execute(\"transfer\", dtmf.digits+\" XML default\");\n"; + //$tmp .= " } else {\n"; + //$tmp .= $tmpactiondefault; + //$tmp .= " }\n"; + $tmp .= "\n"; + $tmp .= " } //end if session.ready\n"; + $tmp .= "\n"; + $tmp .= " }\n"; //end if condition + + } //if ($actiondirect) + } //actioncount + + $antiactiondirect = false; + $antiactiondefault = false; + $antiactioncount = 0; + foreach($config['installedpackages']['freeswitchivroptions']['config'] as $row) { + //find the correct IVR options with the correct action + if ($row['ivrid'] == $rowhelper['ivrid']) { + if ($row['optionaction'] == "anti-action") { + $antiactioncount++; + if (strtolower($row['optionnumber']) == "n") { //direct the call now don't wait for dtmf + $antiactiondirect = true; + $antiactiondirecttype = $row['optiontype']; + $antiactiondirectdest = $row['optiondest']; + $antiactiondirectprofile = $row['optionprofile']; + } + if (strtolower($row['optionnumber']) == "d") { //default option used when an dtmf doesn't match any option + $antiactiondefault = true; + $antiactiondefaulttype = $row['optiontype']; + $antiactiondefaultdest = $row['optiondest']; + $antiactiondefaultprofile = $row['optionprofile']; + } + } + } + } + //$tmp .= "anti-action count: ".$antiactioncount."
\n"; + + + if ($antiactioncount > 0) { + if ($antiactiondirect) { + $tmp .= " else {\n"; + $tmp .= " //console_log( \"info\", \"anti-action call now don't wait for dtmf\\n\" );\n"; + + if ($antiactiondirecttype == "extension") { + $tmp .= " sofia_contact_".$antiactiondirectdest." = get_sofia_contact(\"".$antiactiondirectdest."\",domain_name, \"".$antiactiondirectprofile."\");\n"; + $tmp .= " session.execute(\"bridge\", sofia_contact_".$antiactiondirectdest."); //".$antiactiondirectdest."\n"; + if ($antiactiondirectprofile == "auto") { + $tmp .= " session.execute(\"voicemail\", \"default \${domain} ".$antiactiondirectdest."\");\n"; + } + else { + $tmp .= " session.execute(\"voicemail\", \"default \${domain} ".$antiactiondirectdest."\");\n"; + } + } + if ($antiactiondirecttype == "voicemail") { + if ($antiactiondirectprofile == "auto") { + $tmp .= " session.execute(\"voicemail\", \"default \${domain} ".$antiactiondirectdest."\");\n"; + } + else { + $tmp .= " session.execute(\"voicemail\", \"default \${domain} ".$antiactiondirectdest."\");\n"; + } + } + if ($antiactiondirecttype == "sip uri") { + $tmp .= " session.execute(\"bridge\", \"".$antiactiondirectdest."\"); //".$antiactiondirectdest."\n"; + } + $tmp .= "}\n"; + } + else { + $tmp .= " else {\n"; + $tmp .= " //anti-action\n"; + $tmp .= " //console_log( \"info\", \"anti-action options\\n\" );\n"; + $tmp .= "\n"; + $tmp .= " var dtmf = new Object( );\n"; + $tmp .= " dtmf.digits = \"\";\n"; + $tmp .= " if ( session.ready( ) ) {\n"; + $tmp .= " session.answer( );\n"; + $tmp .= "\n"; + $tmp .= " digitmaxlength = 1;\n"; + $tmp .= " while (session.ready() && ! exit ) {\n"; + $tmp .= " session.streamFile( \"/usr/local/freeswitch/recordings/".$recording_antiaction_filename."\", mycb, \"dtmf ".$rowhelper['ivrtimeout']."\" );\n"; + $tmp .= " if (session.ready()) {\n"; + $tmp .= " if (dtmf.digits.length == 0) {\n"; + $tmp .= " dtmf.digits += session.getDigits(1, \"#\", ".($rowhelper['ivrtimeout']*1000)."); // ".$rowhelper['ivrtimeout']." seconds\n"; + $tmp .= " if (dtmf.digits.length == 0) {\n"; + //$tmp .= " console_log( "info", "time out option: " + dtmf.digits + "\n" );\n"; + + + //find the timeout IVR options with the correct action + if (count($a_ivr_options) > 0) { + foreach($a_ivr_options as $row) { + + if ($row['ivrid'] == $rowhelper['ivrid']) { + + if ($row['optionaction'] == "anti-action") { + if (strtolower($row['optionnumber']) == "t") { + if ($row['optiontype'] == "extension") { + $tmp .= " sofia_contact_".$row['optiondest']." = get_sofia_contact(\"".$row['optiondest']."\",domain_name, \"".$row['optionprofile']."\");\n"; + $tmp .= " session.execute(\"bridge\", sofia_contact_".$row['optiondest']."); //".$row['optiondescr']."\n"; + if ($row['optionprofile'] == "auto") { + $tmp .= " session.execute(\"voicemail\", \"default \${domain} ".$row['optiondest']."\");\n"; + } + else { + $tmp .= " session.execute(\"voicemail\", \"default \${domain} ".$row['optiondest']."\");\n"; + } + } + if ($row['optiontype'] == "voicemail") { + if ($row['optionprofile'] == "auto") { + $tmp .= " session.execute(\"voicemail\", \"default \${domain} ".$row['optiondest']."\"); //".$row['optiondescr']."\n"; + } + else { + $tmp .= " session.execute(\"voicemail\", \"default \${domain} ".$row['optiondest']."\"); //".$row['optiondescr']."\n"; + } + } + if ($row['optiontype'] == "sip uri") { + $tmp .= " session.execute(\"bridge\", \"".$row['optiondest']."\"); //".$row['optiondescr']."\n"; + } + } + + } //end anti-action + + } //end ivrid + + } //end for each + } //if count + + + $tmp .= " }\n"; + $tmp .= " else {\n"; + $tmp .= " break; //dtmf found end the while loop\n"; + $tmp .= " }\n"; + + $tmp .= " }\n"; + $tmp .= " }\n"; + $tmp .= " }\n"; + $tmp .= "\n"; + $tmp .= " //pickup the remaining digits\n"; + $tmp .= " //http://wiki.freeswitch.org/wiki/Session_getDigits\n"; + $tmp .= " //getDigits(length, terminators, timeout, digit_timeout, abs_timeout)\n"; + $tmp .= " dtmf.digits += session.getDigits(4, \"#\", 3000);\n"; + $tmp .= "\n"; + $tmp .= " console_log( \"info\", \"IVR Digit Pressed: \" + dtmf.digits + \"\\n\" );\n"; + $tmp .= "\n"; + + + $tmpantiaction = ""; + $tmp .= " if ( dtmf.digits.length > \"0\" ) {\n"; + + $x = 0; + if (count($a_ivr_options) > 0) { + foreach($a_ivr_options as $row) { + + /* + $row['ivrid'] + $row['optionnumber'] + $row['optiontype'] + $row['optionaction'] + $row['optiondest'] + $row['optiondescr'] + */ + //$tmpantiactiondefault = ""; + + //find the correct IVR options with the correct action + if ($row['ivrid'] == $rowhelper['ivrid']) { + + if ($row['optionaction'] == "anti-action") { + + switch ($row['optionnumber']) { + //case "t": + // //break; + //case "d": + // //break; + default: + //$tmpantiaction .= " //console_log( \"info\", \"IVR Detected 1 digit \\n\" );\n"; + + if ($x == 0) { + $tmpantiaction .= " if ( dtmf.digits == \"".$row['optionnumber']."\" ) { //".$row['optiondescr']."\n"; + } + else { + $tmpantiaction .= " else if ( dtmf.digits == \"".$row['optionnumber']."\" ) { //".$row['optiondescr']."\n"; + } + + if ($row['optiontype'] == "extension") { + $tmpantiaction .= " sofia_contact_".$row['optiondest']." = get_sofia_contact(\"".$row['optiondest']."\",domain_name, \"".$row['optionprofile']."\");\n"; + $tmpantiaction .= " session.execute(\"bridge\", sofia_contact_".$row['optiondest']."); //".$row['optiondescr']."\n"; + if ($row['optionprofile'] == "auto") { + $tmpantiaction .= " session.execute(\"voicemail\", \"default \${domain} ".$row['optiondest']."\");\n"; + } + else { + $tmpantiaction .= " session.execute(\"voicemail\", \"default \${domain} ".$row['optiondest']."\");\n"; + } + } + if ($row['optiontype'] == "voicemail") { + if ($row['optionprofile'] == "auto") { + $tmpantiaction .= " session.execute(\"voicemail\", \"default \${domain} ".$row['optiondest']."\"); //".$row['optiondescr']."\n"; + } + else { + $tmpantiaction .= " session.execute(\"voicemail\", \"default \${domain} ".$row['optiondest']."\"); //".$row['optiondescr']."\n"; + } + } + if ($row['optiontype'] == "sip uri") { + $tmpantiaction .= " session.execute(\"bridge\", \"".$row['optiondest']."\"); //".$row['optiondescr']."\n"; + } + $tmpantiaction .= " }\n"; + + } //end switch + + $x++; + } //end anti-action + + } //end ivrid + + + } //end for each + } //if count + + $tmp .= $tmpantiaction; + if ($rowhelper['ivrdirectdial'] == "true") { + $tmp .= " else {\n"; + $tmp .= " session.execute(\"transfer\", dtmf.digits+\" XML default\");\n"; + //$tmp .= $tmpantiactiondefault; + $tmp .= " }\n"; + } + else { + if ($antiactiondefault) { + $tmp .= " else {\n"; + $tmp .= " //console_log( \"info\", \"default option used when dtmf doesn't match any other option\\n\" );\n"; + + if ($antiactiondefaulttype == "extension") { + $tmp .= " sofia_contact_".$antiactiondefaultdest." = get_sofia_contact(\"".$antiactiondefaultdest."\",domain_name, \"".$actiondirectprofile."\");\n"; + $tmp .= " session.execute(\"bridge\", sofia_contact_".$antiactiondefaultdest."); //".$antiactiondefaultdest."\n"; + if ($actiondirectprofile == "auto") { + $tmp .= " session.execute(\"voicemail\", \"default \${domain} ".$antiactiondefaultdest."\");\n"; + } + else { + $tmp .= " session.execute(\"voicemail\", \"default \${domain} ".$antiactiondefaultdest."\");\n"; + } + } + if ($antiactiondefaulttype == "voicemail") { + if ($actiondirectprofile == "auto") { + $tmp .= " session.execute(\"voicemail\", \"default \${domain} ".$antiactiondefaultdest."\");\n"; + } + else { + $tmp .= " session.execute(\"voicemail\", \"default \${domain} ".$antiactiondefaultdest."\");\n"; + } + } + if ($antiactiondefaulttype == "sip uri") { + $tmp .= " session.execute(\"bridge\", \"".$antiactiondefaultdest."\"); //".$antiactiondefaultdest."\n"; + } + $tmp .= " }\n"; + } + } + $tmp .= "\n"; + unset($tmpantiaction); + + $tmp .= " } \n"; + //$tmp .= " else if ( dtmf.digits.length == \"3\" ) {\n"; + //$tmp .= " //Transfer to the extension the caller chose\n"; + //$tmp .= " session.execute(\"transfer\", dtmf.digits+\" XML default\"); \n"; + //$tmp .= " }\n"; + //$tmp .= " else {\n"; + //$tmp .= $tmpantiactiondefault; + //$tmp .= " }\n"; + $tmp .= "\n"; + $tmp .= " } //end if session.ready\n"; + $tmp .= "\n"; + $tmp .= " } //end if condition"; + + } //if ($antiactiondirect) + } //antiactioncount + unset($tmpactiondefault); + unset($tmpantiactiondefault); + + if (strlen($rowhelper['ivrid']) > 0) { + $ivrfilename = "ivr_".str_replace(array("{", "}"), "", $rowhelper['ivrid']).".js"; + $fout = fopen("/usr/local/freeswitch/scripts/".$ivrfilename,"w"); + fwrite($fout, $tmp); + unset($ivrfilename); + fclose($fout); + } + + } //end foreach + } //end if count + conf_mount_ro(); + config_unlock(); + +} //end function + + + +function sync_package_freeswitch_dialplan_includes() +{ + + global $config; + conf_mount_rw(); + config_lock(); + + $a_dialplan_includes = &$config['installedpackages']['freeswitchdialplanincludes']['config']; + $a_dialplan_include_details = &$config['installedpackages']['freeswitchdialplanincludedetails']['config']; + + //order the array + if (!function_exists('cmp_number_dialplan_details')) { + function cmp_number_dialplan_details($a, $b) { + if ($a["fieldorder"] > $b["fieldorder"]) { + return 1; + } + else { + return 0; + } + } + } + + if (count($a_dialplan_includes) > 0) { + foreach($config['installedpackages']['freeswitchdialplanincludes']['config'] as $rowhelper) { + $tmp = ""; + $tmp .= "\n"; + + //$rowhelper['dialplanincludeid']; + //$rowhelper['extensionname']; + //$rowhelper['context']; + //$rowhelper['enabled']; + + $tmp = "\n"; + + if (count($a_dialplan_include_details) > 0) { + + if (count($a_dialplan_include_details) > 0) { usort($a_dialplan_include_details, "cmp_number_dialplan_details"); } + + $conditioncount = 0; + $i = 0; + foreach ($a_dialplan_include_details as $ent) { + if ($ent['tag'] == "condition" && $rowhelper['dialplanincludeid'] == $ent['dialplanincludeid']) { + $conditioncount++; + $i++; + } + } + + $i = 1; + foreach ($a_dialplan_include_details as $ent) { + if ($ent['tag'] == "condition" && $rowhelper['dialplanincludeid'] == $ent['dialplanincludeid']) { + if ($conditioncount == 1) { //single condition + //start tag + $tmp .= " \n"; + } + else { //more than one condition + if ($i < $conditioncount) { + //all tags should be self-closing except the last one + $tmp .= " \n"; + } + else { + //for the last tag use the start tag + $tmp .= " \n"; + } + } + $i++; + } + } //end for each + + } //end if count + + if (count($a_dialplan_include_details) > 0) { + $i = 0; + foreach ($a_dialplan_include_details as $ent) { + if ($ent['tag'] == "action" && $rowhelper['dialplanincludeid'] == $ent['dialplanincludeid']) { + $tmp .= " \n"; + } + $i++; + } + } + + if (count($a_dialplan_include_details) > 0) { + $i = 0; + foreach ($a_dialplan_include_details as $ent) { + if ($ent['tag'] == "anti-action" && $rowhelper['dialplanincludeid'] == $ent['dialplanincludeid']) { + $tmp .= " \n"; + } + $i++; + } + } + + //if (count($a_dialplan_include_details) > 0) { + //foreach ($a_dialplan_include_details as $ent) { + // $i = 0; + // if ($ent['tag'] == "param" && $rowhelper['dialplanincludeid'] == $ent['dialplanincludeid']) { + //$ent['tag'] + //$ent['fieldtype'] + //$ent['fielddata'] + // } + // $i++; + // } + //} + + if ($conditioncount > 0) { + $tmp .= " \n"; + } + unset ($conditioncount); + $tmp .= "\n"; + + + if ($rowhelper['enabled'] == "true") { + $dialplanincludefilename = $rowhelper['order']."_".$rowhelper['extensionname'].".xml"; + $fout = fopen("/usr/local/freeswitch/conf/dialplan/default/".$dialplanincludefilename,"w"); + fwrite($fout, $tmp); + fclose($fout); + } + unset($dialplanincludefilename); + unset($tmp); + + + } //end foreach + } //if array count + + conf_mount_ro(); + config_unlock(); + +} + + +function sync_package_freeswitch_public_includes() +{ + + global $config; + conf_mount_rw(); + config_lock(); + + $a_public_includes = &$config['installedpackages']['freeswitchpublicincludes']['config']; + $a_public_include_details = &$config['installedpackages']['freeswitchpublicincludedetails']['config']; + + if (count($a_public_includes) > 0) { + + //order the array + function cmp_number_public_include_details($a, $b) { + if ($a["fieldorder"] > $b["fieldorder"]) { + return 1; + } + else { + return 0; + } + } + + + foreach($a_public_includes as $rowhelper) { + $tmp = ""; + $tmp .= "\n"; + + //$rowhelper['publicincludeid']; + //$rowhelper['extensionname']; + //$rowhelper['context']; + //$rowhelper['enabled']; + + $tmp = "\n"; + + if (count($a_public_include_details) > 0) { + + if (count($a_public_include_details) > 0) { usort($a_public_include_details, "cmp_number_public_include_details"); } + + $conditioncount = 0; + $i = 0; + foreach ($a_public_include_details as $ent) { + if ($ent['tag'] == "condition" && $rowhelper['publicincludeid'] == $ent['publicincludeid']) { + $conditioncount++; + $i++; + } + } + + $i = 1; + foreach ($a_public_include_details as $ent) { + if ($ent['tag'] == "condition" && $rowhelper['publicincludeid'] == $ent['publicincludeid']) { + if ($conditioncount == 1) { //single condition + //start tag + $tmp .= " \n"; + } + else { //more than one condition + if ($i < $conditioncount) { + //all tags should be self-closing except the last one + $tmp .= " \n"; + } + else { + //for the last tag use the start tag + $tmp .= " \n"; + } + } + $i++; + } + } //end for each + + } //end if count + + + if (count($a_public_include_details) > 0) { + $i = 0; + foreach ($a_public_include_details as $ent) { + if ($ent['tag'] == "action" && $rowhelper['publicincludeid'] == $ent['publicincludeid']) { + $tmp .= " \n"; + } + $i++; + } + } + + if (count($a_public_include_details) > 0) { + $i = 0; + foreach ($a_public_include_details as $ent) { + if ($ent['tag'] == "anti-action" && $rowhelper['publicincludeid'] == $ent['publicincludeid']) { + $tmp .= " \n"; + } + $i++; + } + } + + //if (count($a_public_include_details) > 0) { + //foreach ($a_public_include_details as $ent) { + // $i = 0; + // if ($ent['tag'] == "param" && $rowhelper['publicincludeid'] == $ent['publicincludeid']) { + //$ent['tag'] + //$ent['fieldtype'] + //$ent['fielddata'] + // } + // $i++; + // } + //} + + if ($conditioncount > 0) { + $tmp .= " \n"; + } + unset ($conditioncount); + $tmp .= "\n"; + + + if ($rowhelper['enabled'] == "true") { + $publicincludefilename = $rowhelper['order']."_".$rowhelper['extensionname'].".xml"; + $fout = fopen("/usr/local/freeswitch/conf/dialplan/public/".$publicincludefilename,"w"); + fwrite($fout, $tmp); + fclose($fout); + } + unset($publicincludefilename); + unset($tmp); + + + } //end foreach + } //end if count + conf_mount_ro(); + config_unlock(); + +} + + +function sync_package_freeswitch() +{ + global $config; + sync_package_freeswitch_settings(); + sync_package_freeswitch_dialplan(); + sync_package_freeswitch_dialplan_includes(); + sync_package_freeswitch_extensions(); + sync_package_freeswitch_gateways(); + sync_package_freeswitch_modules(); + sync_package_freeswitch_public(); + sync_package_freeswitch_public_includes(); + sync_package_freeswitch_vars(); + sync_package_freeswitch_internal(); + sync_package_freeswitch_external(); + //sync_package_freeswitch_recordings(); + if (pkg_is_service_running('freeswitch')) { + sync_package_freeswitch_ivr(); + } + +} + + +function freeswitch_php_install_command() +{ + global $config; + exec("/etc/./rc.conf_mount_rw"); + + $freeswitch_package_version = "0.9.4.4"; + $freeswitch_build_version = "1.0.4 pre 8"; + $freeswitch_build_revision = "13784"; + + //set script execution time limit to 24 hours + set_time_limit (86400); + ini_set(max_execution_time,86400); + + //hide errors + ini_set('display_errors', '0'); + + //used with fax to png, and fax to pdf conversion + exec("pkg_add -r tiff2png"); + + clearstatcache(); + if (!is_dir('/usr/local/www/packages/')) { + exec("mkdir /usr/local/www/packages/"); + } + + if (!is_dir('/usr/local/www/packages/freeswitch/')) { + exec("mkdir /usr/local/www/packages/freeswitch/"); + } + + //$struname = exec('uname -v'); + //if (stristr($struname, 'FreeBSD 7.0')) { + // $freebsd_version = "7.0"; + //} + + //exec("cd /tmp/;fetch http://www.pfsense.com/packages/config/freeswitch/freeswitch.tgz"); //handled by freeswitch.xml + exec("tar zxvf /tmp/freeswitch.tgz -C /usr/local/"); + unlink_if_exists("/tmp/freeswitch.tgz"); + + if (!is_dir('/usr/local/freeswitch/storage/fax/')) { + exec("mkdir /usr/local/freeswitch/storage/fax/"); + } + + if (!is_dir('/usr/local/freeswitch/storage/fax/receive/')) { + exec("mkdir /usr/local/freeswitch/storage/fax/receive/"); + } + + //download the dialplan default.xml + exec("cd /tmp/;fetch http://www.pfsense.com/packages/config/freeswitch/dialplan.default.xml"); + exec("cp /tmp/dialplan.default.xml /usr/local/freeswitch/conf/dialplan/default.xml"); + unlink_if_exists("/tmp/dialplan.default.xml"); + + //download the dialplan public.xml + exec("cd /tmp/;fetch http://www.pfsense.com/packages/config/freeswitch/dialplan.public.xml"); + exec("cp /tmp/dialplan.public.xml /usr/local/freeswitch/conf/dialplan/public.xml"); + unlink_if_exists("/tmp/dialplan.public.xml"); + + //make a backup copy of the default config used with the 'Restore Default' buttons on the text areas. + exec("cp -R /usr/local/freeswitch/conf /usr/local/freeswitch/conf.orig"); + + //remove some default config files that are not needed + unlink_if_exists("/usr/local/freeswitch/conf/dialplan/default/01_example.com.xml"); + unlink_if_exists("/usr/local/freeswitch/conf/dialplan/public/00_inbound_did.xml"); + + if (!is_dir('/usr/local/freeswitch/sounds/custom/')) { + exec("mkdir /usr/local/freeswitch/sounds/custom/"); + } + + if (!is_dir('/usr/local/freeswitch/sounds/custom/8000/')) { + exec("mkdir /usr/local/freeswitch/sounds/custom/8000/"); + } + + //copy audio files + exec("cd /usr/local/freeswitch/sounds/custom/8000/;fetch http://www.pfsense.com/packages/config/freeswitch/please_enter_your_pin_number.wav"); + exec("cd /usr/local/freeswitch/sounds/custom/8000/;fetch http://www.pfsense.com/packages/config/freeswitch/please_enter_the_pin_number.wav"); + exec("cd /usr/local/freeswitch/sounds/custom/8000/;fetch http://www.pfsense.com/packages/config/freeswitch/please_enter_the_extension_number.wav"); + exec("cd /usr/local/freeswitch/sounds/custom/8000/;fetch http://www.pfsense.com/packages/config/freeswitch/please_enter_the_phone_number.wav"); + exec("cd /usr/local/freeswitch/sounds/custom/8000/;fetch http://www.pfsense.com/packages/config/freeswitch/call_forward_has_been_set.wav"); + exec("cd /usr/local/freeswitch/sounds/custom/8000/;fetch http://www.pfsense.com/packages/config/freeswitch/call_forward_has_been_deleted.wav"); + exec("cd /usr/local/freeswitch/sounds/custom/8000/;fetch http://www.pfsense.com/packages/config/freeswitch/begin_recording.wav"); + exec("cd /usr/local/freeswitch/sounds/custom/8000/;fetch http://www.pfsense.com/packages/config/freeswitch/your_pin_number_is_incorect_goodbye.wav"); + + //mod_fax + exec("cd /usr/local/freeswitch/mod/;fetch http://www.pfsense.com/packages/config/freeswitch/mod_fax.so"); + + //download lib files + exec("cd /usr/local/lib/;fetch http://www.pfsense.com/packages/config/freeswitch/libtinfo.so.5.6"); + exec("cd /usr/local/lib/;fetch http://www.pfsense.com/packages/config/freeswitch/libncurses.so.5.6"); + exec("cd /usr/local/lib/;fetch http://www.pfsense.com/packages/config/freeswitch/libncurses.so.5.7"); + exec("cd /usr/local/lib/;fetch http://www.pfsense.com/packages/config/freeswitch/libogg.so.5.3"); + exec("cp /usr/local/lib/libogg.so.5.3 /usr/local/lib/libogg.so.5"); + exec("cd /usr/local/lib/;fetch http://www.pfsense.com/packages/config/freeswitch/libvorbis.so.4"); + exec("cd /usr/local/lib/;fetch http://www.pfsense.com/packages/config/freeswitch/libcurl.so.5"); + exec("cd /usr/local/lib/;fetch http://www.pfsense.com/packages/config/freeswitch/libodbc.so.1"); + exec("cd /usr/local/lib/;fetch http://www.pfsense.com/packages/config/freeswitch/libiconv.so.3"); + exec("cd /usr/local/lib/;fetch http://www.pfsense.com/packages/config/freeswitch/libspandsp.so.1"); + exec("cp /usr/local/lib/libspandsp.so.1 /usr/local/lib/libspandsp.so.2"); + + //download xml package files + //exec("cd /usr/local/pkg/;fetch http://www.pfsense.com/packages/config/freeswitch/freeswitch.inc"); + //exec("cd /usr/local/pkg/;fetch http://www.pfsense.com/packages/config/freeswitch/freeswitch.xml"); + //exec("cd /usr/local/pkg/;fetch http://www.pfsense.com/packages/config/freeswitch/freeswitch_dialplan.xml"); + //exec("cd /usr/local/pkg/;fetch http://www.pfsense.com/packages/config/freeswitch/freeswitch_external.xml"); + //exec("cd /usr/local/pkg/;fetch http://www.pfsense.com/packages/config/freeswitch/freeswitch_internal.xml"); + exec("cd /usr/local/pkg/;fetch http://www.pfsense.com/packages/config/freeswitch/freeswitch_modules.xml"); + //exec("cd /usr/local/pkg/;fetch http://www.pfsense.com/packages/config/freeswitch/freeswitch_public.xml"); + //exec("cd /usr/local/pkg/;fetch http://www.pfsense.com/packages/config/freeswitch/freeswitch_vars.xml"); + + //misc files + if (!is_dir('/usr/local/www/edit_area/')) { + exec("cd /tmp/;fetch http://www.pfsense.com/packages/config/freeswitch/edit_area.tgz"); + system('cd /usr/local/www; tar xvpfz /tmp/edit_area.tgz edit_area'); + unlink_if_exists("/tmp/edit_area.tgz"); + } + + //rename PHP files from .tmp to .php + exec("cd /tmp/;fetch http://www.pfsense.com/packages/config/freeswitch/class.smtp.tmp"); + exec("cp /tmp/class.smtp.tmp /usr/local/www/packages/freeswitch/class.smtp.php"); + unlink_if_exists("/tmp/class.smtp.tmp"); + + exec("cd /tmp/;fetch http://www.pfsense.com/packages/config/freeswitch/class.phpmailer.tmp"); + exec("cp /tmp/class.phpmailer.tmp /usr/local/www/packages/freeswitch/class.phpmailer.php"); + unlink_if_exists("/tmp/class.phpmailer.tmp"); + + exec("cd /tmp/;fetch http://www.pfsense.com/packages/config/freeswitch/freeswitch_cmd.tmp"); + exec("cp /tmp/freeswitch_cmd.tmp /usr/local/www/packages/freeswitch/freeswitch_cmd.php"); + unlink_if_exists("/tmp/freeswitch_cmd.tmp"); + + exec("cd /tmp/;fetch http://www.pfsense.com/packages/config/freeswitch/freeswitch_dialplan.tmp"); + exec("cp /tmp/freeswitch_dialplan.tmp /usr/local/www/packages/freeswitch/freeswitch_dialplan.php"); + unlink_if_exists("/tmp/freeswitch_dialplan.tmp"); + + exec("cd /tmp/;fetch http://www.pfsense.com/packages/config/freeswitch/freeswitch_dialplan_includes_details.tmp"); + exec("cp /tmp/freeswitch_dialplan_includes_details.tmp /usr/local/www/packages/freeswitch/freeswitch_dialplan_includes_details.php"); + unlink_if_exists("/tmp/freeswitch_dialplan_includes_details.tmp"); + + exec("cd /tmp/;fetch http://www.pfsense.com/packages/config/freeswitch/freeswitch_dialplan_includes_details_edit.tmp"); + exec("cp /tmp/freeswitch_dialplan_includes_details_edit.tmp /usr/local/www/packages/freeswitch/freeswitch_dialplan_includes_details_edit.php"); + unlink_if_exists("/tmp/freeswitch_dialplan_includes_details_edit.tmp"); + + exec("cd /tmp/;fetch http://www.pfsense.com/packages/config/freeswitch/freeswitch_dialplan_includes.tmp"); + exec("cp /tmp/freeswitch_dialplan_includes.tmp /usr/local/www/packages/freeswitch/freeswitch_dialplan_includes.php"); + unlink_if_exists("/tmp/freeswitch_dialplan_includes.tmp"); + + exec("cd /tmp/;fetch http://www.pfsense.com/packages/config/freeswitch/freeswitch_dialplan_includes_edit.tmp"); + exec("cp /tmp/freeswitch_dialplan_includes_edit.tmp /usr/local/www/packages/freeswitch/freeswitch_dialplan_includes_edit.php"); + unlink_if_exists("/tmp/freeswitch_dialplan_includes_edit.tmp"); + + exec("cd /tmp/;fetch http://www.pfsense.com/packages/config/freeswitch/freeswitch_extensions.tmp"); + exec("cp /tmp/freeswitch_extensions.tmp /usr/local/www/packages/freeswitch/freeswitch_extensions.php"); + unlink_if_exists("/tmp/freeswitch_extensions.tmp"); + + exec("cd /tmp/;fetch http://www.pfsense.com/packages/config/freeswitch/freeswitch_extensions_edit.tmp"); + exec("cp /tmp/freeswitch_extensions_edit.tmp /usr/local/www/packages/freeswitch/freeswitch_extensions_edit.php"); + unlink_if_exists("/tmp/freeswitch_extensions_edit.tmp"); + + exec("cd /tmp/;fetch http://www.pfsense.com/packages/config/freeswitch/freeswitch_fax.tmp"); + exec("cp /tmp/freeswitch_fax.tmp /usr/local/www/packages/freeswitch/freeswitch_fax.php"); + unlink_if_exists("/tmp/freeswitch_fax.tmp"); + + exec("cd /tmp/;fetch http://www.pfsense.com/packages/config/freeswitch/freeswitch_fax_edit.tmp"); + exec("cp /tmp/freeswitch_fax_edit.tmp /usr/local/www/packages/freeswitch/freeswitch_fax_edit.php"); + unlink_if_exists("/tmp/freeswitch_fax_edit.tmp"); + + exec("cd /tmp/;fetch http://www.pfsense.com/packages/config/freeswitch/fax_to_email.tmp"); + exec("cp /tmp/fax_to_email.tmp /usr/local/www/packages/freeswitch/fax_to_email.php"); + unlink_if_exists("/tmp/fax_to_email.tmp"); + + exec("cd /tmp/;fetch http://www.pfsense.com/packages/config/freeswitch/freeswitch_features.tmp"); + exec("cp /tmp/freeswitch_features.tmp /usr/local/www/packages/freeswitch/freeswitch_features.php"); + unlink_if_exists("/tmp/freeswitch_features.tmp"); + + exec("cd /tmp/;fetch http://www.pfsense.com/packages/config/freeswitch/freeswitch_gateways.tmp"); + exec("cp /tmp/freeswitch_gateways.tmp /usr/local/www/packages/freeswitch/freeswitch_gateways.php"); + unlink_if_exists("/tmp/freeswitch_gateways.tmp"); + + exec("cd /tmp/;fetch http://www.pfsense.com/packages/config/freeswitch/freeswitch_gateways_edit.tmp"); + exec("cp /tmp/freeswitch_gateways_edit.tmp /usr/local/www/packages/freeswitch/freeswitch_gateways_edit.php"); + unlink_if_exists("/tmp/freeswitch_gateways_edit.tmp"); + + exec("cd /tmp/;fetch http://www.pfsense.com/packages/config/freeswitch/freeswitch_hunt_group.tmp"); + exec("cp /tmp/freeswitch_hunt_group.tmp /usr/local/www/packages/freeswitch/freeswitch_hunt_group.php"); + unlink_if_exists("/tmp/freeswitch_hunt_group.tmp"); + + exec("cd /tmp/;fetch http://www.pfsense.com/packages/config/freeswitch/freeswitch_hunt_group_edit.tmp"); + exec("cp /tmp/freeswitch_hunt_group_edit.tmp /usr/local/www/packages/freeswitch/freeswitch_hunt_group_edit.php"); + unlink_if_exists("/tmp/freeswitch_hunt_group_edit.tmp"); + + exec("cd /tmp/;fetch http://www.pfsense.com/packages/config/freeswitch/freeswitch_hunt_group_destinations.tmp"); + exec("cp /tmp/freeswitch_hunt_group_destinations.tmp /usr/local/www/packages/freeswitch/freeswitch_hunt_group_destinations.php"); + unlink_if_exists("/tmp/freeswitch_hunt_group_destinations.tmp"); + + exec("cd /tmp/;fetch http://www.pfsense.com/packages/config/freeswitch/freeswitch_hunt_group_destinations_edit.tmp"); + exec("cp /tmp/freeswitch_hunt_group_destinations_edit.tmp /usr/local/www/packages/freeswitch/freeswitch_hunt_group_destinations_edit.php"); + unlink_if_exists("/tmp/freeswitch_hunt_group_destinations_edit.tmp"); + + exec("cd /tmp/;fetch http://www.pfsense.com/packages/config/freeswitch/freeswitch_ivr.tmp"); + exec("cp /tmp/freeswitch_ivr.tmp /usr/local/www/packages/freeswitch/freeswitch_ivr.php"); + unlink_if_exists("/tmp/freeswitch_ivr.tmp"); + + exec("cd /tmp/;fetch http://www.pfsense.com/packages/config/freeswitch/freeswitch_ivr_edit.tmp"); + exec("cp /tmp/freeswitch_ivr_edit.tmp /usr/local/www/packages/freeswitch/freeswitch_ivr_edit.php"); + unlink_if_exists("/tmp/freeswitch_ivr_edit.tmp"); + + exec("cd /tmp/;fetch http://www.pfsense.com/packages/config/freeswitch/freeswitch_ivr_options.tmp"); + exec("cp /tmp/freeswitch_ivr_options.tmp /usr/local/www/packages/freeswitch/freeswitch_ivr_options.php"); + unlink_if_exists("/tmp/freeswitch_ivr_options.tmp"); + + exec("cd /tmp/;fetch http://www.pfsense.com/packages/config/freeswitch/freeswitch_ivr_options_edit.tmp"); + exec("cp /tmp/freeswitch_ivr_options_edit.tmp /usr/local/www/packages/freeswitch/freeswitch_ivr_options_edit.php"); + unlink_if_exists("/tmp/freeswitch_ivr_options_edit.tmp"); + + exec("cd /tmp/;fetch http://www.pfsense.com/packages/config/freeswitch/freeswitch_profiles.tmp"); + exec("cp /tmp/freeswitch_profiles.tmp /usr/local/www/packages/freeswitch/freeswitch_profiles.php"); + unlink_if_exists("/tmp/freeswitch_profiles.tmp"); + + exec("cd /tmp/;fetch http://www.pfsense.com/packages/config/freeswitch/freeswitch_profile_edit.tmp"); + exec("cp /tmp/freeswitch_profile_edit.tmp /usr/local/www/packages/freeswitch/freeswitch_profile_edit.php"); + unlink_if_exists("/tmp/freeswitch_profile_edit.tmp"); + + exec("cd /tmp/;fetch http://www.pfsense.com/packages/config/freeswitch/freeswitch_public.tmp"); + exec("cp /tmp/freeswitch_public.tmp /usr/local/www/packages/freeswitch/freeswitch_public.php"); + unlink_if_exists("/tmp/freeswitch_public.tmp"); + + exec("cd /tmp/;fetch http://www.pfsense.com/packages/config/freeswitch/freeswitch_public_includes.tmp"); + exec("cp /tmp/freeswitch_public_includes.tmp /usr/local/www/packages/freeswitch/freeswitch_public_includes.php"); + unlink_if_exists("/tmp/freeswitch_public_includes.tmp"); + + exec("cd /tmp/;fetch http://www.pfsense.com/packages/config/freeswitch/freeswitch_public_includes_edit.tmp"); + exec("cp /tmp/freeswitch_public_includes_edit.tmp /usr/local/www/packages/freeswitch/freeswitch_public_includes_edit.php"); + unlink_if_exists("/tmp/freeswitch_public_includes_edit.tmp"); + + exec("cd /tmp/;fetch http://www.pfsense.com/packages/config/freeswitch/freeswitch_public_includes_details.tmp"); + exec("cp /tmp/freeswitch_public_includes_details.tmp /usr/local/www/packages/freeswitch/freeswitch_public_includes_details.php"); + unlink_if_exists("/tmp/freeswitch_public_includes_details.tmp"); + + exec("cd /tmp/;fetch http://www.pfsense.com/packages/config/freeswitch/freeswitch_public_includes_details_edit.tmp"); + exec("cp /tmp/freeswitch_public_includes_details_edit.tmp /usr/local/www/packages/freeswitch/freeswitch_public_includes_details_edit.php"); + unlink_if_exists("/tmp/freeswitch_public_includes_details_edit.tmp"); + + exec("cd /tmp/;fetch http://www.pfsense.com/packages/config/freeswitch/freeswitch_mailto.tmp"); + exec("cp /tmp/freeswitch_mailto.tmp /usr/local/www/packages/freeswitch/freeswitch_mailto.php"); + unlink_if_exists("/tmp/freeswitch_mailto.tmp"); + + exec("cd /tmp/;fetch http://www.pfsense.com/packages/config/freeswitch/freeswitch_recordings.tmp"); + exec("cp /tmp/freeswitch_recordings.tmp /usr/local/www/packages/freeswitch/freeswitch_recordings.php"); + unlink_if_exists("/tmp/freeswitch_recordings.tmp"); + + exec("cd /tmp/;fetch http://www.pfsense.com/packages/config/freeswitch/freeswitch_recordings_edit.tmp"); + exec("cp /tmp/freeswitch_recordings_edit.tmp /usr/local/www/packages/freeswitch/freeswitch_recordings_edit.php"); + unlink_if_exists("/tmp/freeswitch_recordings_edit.tmp"); + + exec("cd /tmp/;fetch http://www.pfsense.com/packages/config/freeswitch/freeswitch_recordings_play.tmp"); + exec("cp /tmp/freeswitch_recordings_play.tmp /usr/local/www/packages/freeswitch/freeswitch_recordings_play.php"); + unlink_if_exists("/tmp/freeswitch_recordings_play.tmp"); + + exec("cd /tmp/;fetch http://www.pfsense.com/packages/config/freeswitch/freeswitch_status.tmp"); + exec("cp /tmp/freeswitch_status.tmp /usr/local/www/packages/freeswitch/freeswitch_status.php"); + unlink_if_exists("/tmp/freeswitch_status.tmp"); + + exec("cd /tmp/;fetch http://www.pfsense.com/packages/config/freeswitch/freeswitch_time_conditions.tmp"); + exec("cp /tmp/freeswitch_time_conditions.tmp /usr/local/www/packages/freeswitch/freeswitch_time_conditions.php"); + unlink_if_exists("/tmp/freeswitch_time_conditions.tmp"); + + exec("cd /tmp/;fetch http://www.pfsense.com/packages/config/freeswitch/freeswitch_time_conditions_edit.tmp"); + exec("cp /tmp/freeswitch_time_conditions_edit.tmp /usr/local/www/packages/freeswitch/freeswitch_time_conditions_edit.php"); + unlink_if_exists("/tmp/freeswitch_time_conditions_edit.tmp"); + + exec("cd /tmp/;fetch http://www.pfsense.com/packages/config/freeswitch/freeswitch_vars.tmp"); + exec("cp /tmp/freeswitch_vars.tmp /usr/local/www/packages/freeswitch/freeswitch_vars.php"); + unlink_if_exists("/tmp/freeswitch_vars.tmp"); + + exec("cd /usr/local/freeswitch/scripts/;fetch http://www.pfsense.com/packages/config/freeswitch/disa.js"); + exec("cp /usr/local/freeswitch/htdocs/slim.swf /usr/local/www/packages/freeswitch/slim.swf"); + + /* freeswitch settings defaults */ + if (strlen($config['installedpackages']['freeswitchsettings']['config'][0]['numbering_plan']) == 0) { + $config['installedpackages']['freeswitchsettings']['config'][0]['numbering_plan'] = "US"; + } + if(strlen($config['installedpackages']['freeswitchsettings']['config'][0]['event_socket_password']) == 0) { + $config['installedpackages']['freeswitchsettings']['config'][0]['event_socket_password'] = "ClueCon"; + } + if (strlen($config['installedpackages']['freeswitchsettings']['config'][0]['event_socket_port']) == 0) { + $config['installedpackages']['freeswitchsettings']['config'][0]['event_socket_port'] = "8021"; + } + if (strlen($config['installedpackages']['freeswitchsettings']['config'][0]['xml_rpc_http_port']) == 0) { + $config['installedpackages']['freeswitchsettings']['config'][0]['xml_rpc_http_port'] = "8787"; + } + if (strlen($config['installedpackages']['freeswitchsettings']['config'][0]['xml_rpc_auth_realm']) == 0) { + $config['installedpackages']['freeswitchsettings']['config'][0]['xml_rpc_auth_realm'] = "freeswitch"; + } + if (strlen($config['installedpackages']['freeswitchsettings']['config'][0]['xml_rpc_auth_user']) == 0) { + $config['installedpackages']['freeswitchsettings']['config'][0]['xml_rpc_auth_user'] = "freeswitch"; + } + if (strlen($config['installedpackages']['freeswitchsettings']['config'][0]['xml_rpc_auth_pass']) == 0) { + $config['installedpackages']['freeswitchsettings']['config'][0]['xml_rpc_auth_pass'] = "works"; + } + if (strlen($config['installedpackages']['freeswitchsettings']['config'][0]['admin_pin']) == 0) { + $config['installedpackages']['freeswitchsettings']['config'][0]['admin_pin'] = "7575"; + } + if (strlen($config['installedpackages']['freeswitchsettings']['config'][0]['mod_shout_decoder']) == 0) { + $config['installedpackages']['freeswitchsettings']['config'][0]['mod_shout_decoder'] = "i386"; + } + if (strlen($config['installedpackages']['freeswitchsettings']['config'][0]['mod_shout_volume']) == 0) { + $config['installedpackages']['freeswitchsettings']['config'][0]['mod_shout_volume'] = "0.3"; + } + + $numbering_plan = $config['installedpackages']['freeswitchsettings']['config'][0]['numbering_plan']; + $event_socket_password = $config['installedpackages']['freeswitchsettings']['config'][0]['event_socket_password']; + $event_socket_port = $config['installedpackages']['freeswitchsettings']['config'][0]['event_socket_port']; + $xml_rpc_http_port = $config['installedpackages']['freeswitchsettings']['config'][0]['xml_rpc_http_port']; + $xml_rpc_auth_realm = $config['installedpackages']['freeswitchsettings']['config'][0]['xml_rpc_auth_realm']; + $xml_rpc_auth_user = $config['installedpackages']['freeswitchsettings']['config'][0]['xml_rpc_auth_user']; + $xml_rpc_auth_pass = $config['installedpackages']['freeswitchsettings']['config'][0]['xml_rpc_auth_pass']; + $admin_pin = $config['installedpackages']['freeswitchsettings']['config'][0]['admin_pin']; + + //write the recording.js script + recording_js(); + + //add recording.js to the dialplan + $a_dialplan_includes = &$config['installedpackages']['freeswitchdialplanincludes']['config']; + $a_dialplan_include_details = &$config['installedpackages']['freeswitchdialplanincludedetails']['config']; + + //delete dialplan recording from the previous install + if (count($a_dialplan_includes) > 0) { + $i = 0; + foreach ($a_dialplan_includes as $ent) { + if ($ent['extensionname'] == "Recordings") { + unset($a_dialplan_includes[$i]); + } + $i++; + } + } + + //delete the recording dialplan details + if (count($a_dialplan_include_details) > 0) { + $i = 0; + foreach ($a_dialplan_include_details as $ent) { + if ($ent['fielddata'] == "^732673$") { + unset($a_dialplan_include_details[$i]); + } + if ($ent['fielddata'] == "recordings.js") { + unset($a_dialplan_include_details[$i]); + } + $i++; + } + } + + //add recording to the dialplan + $dialplanincludeid = guid(); + + $ent = array(); + $ent['dialplanincludeid'] = $dialplanincludeid; + $ent['extensionname'] = 'Recordings'; + $ent['order'] = '9000'; + $ent['context'] = 'default'; + $ent['enabled'] = 'true'; + $ent['descr'] = '*732673 Default system recordings tool'; + $a_dialplan_includes[] = $ent; + unset($ent); + + $ent = array(); + $ent['dialplanincludeid'] = $dialplanincludeid; + $ent['tag'] = 'condition'; //condition, action, antiaction + $ent['fieldtype'] = 'destination_number'; + $ent['fielddata'] = '^\*(732673)$'; + $a_dialplan_include_details[] = $ent; + unset($ent); + + $ent = array(); + $ent['dialplanincludeid'] = $dialplanincludeid; + $ent['tag'] = 'action'; //condition, action, antiaction + $ent['fieldtype'] = 'javascript'; + $ent['fielddata'] = 'recordings.js'; + $a_dialplan_include_details[] = $ent; + unset($ent); + + + //delete dialplan DISA from the previous install + $disa_enabled = 'false'; + if (count($a_dialplan_includes) > 0) { + $i = 0; + foreach ($a_dialplan_includes as $ent) { + if ($ent['extensionname'] == "DISA") { + $disa_enabled = $ent['enabled']; + unset($a_dialplan_includes[$i]); + } + $i++; + } + } + + //add the DISA to the dialplan + $dialplanincludeid = guid(); + + $ent = array(); + $ent['dialplanincludeid'] = $dialplanincludeid; + $ent['extensionname'] = 'DISA'; + $ent['order'] = '000'; + $ent['context'] = 'default'; + $ent['enabled'] = $disa_enabled; + $ent['descr'] = '*3472 Direct Inward System Access'; + $a_dialplan_includes[] = $ent; + unset($ent); + + $ent = array(); + $ent['dialplanincludeid'] = $dialplanincludeid; + $ent['tag'] = 'condition'; //condition, action, antiaction, set + $ent['fieldtype'] = 'destination_number'; + $ent['fielddata'] = '^\*(3472)$'; + $a_dialplan_include_details[] = $ent; + unset($ent); + + $ent = array(); + $ent['dialplanincludeid'] = $dialplanincludeid; + $ent['tag'] = 'action'; //condition, action, antiaction, set + $ent['fieldtype'] = 'javascript'; + $ent['fielddata'] = 'disa.js'; + $a_dialplan_include_details[] = $ent; + unset($ent); + + write_config(); + + //prepare switch.conf.xml for voicemail to email + $filename = "/usr/local/freeswitch/conf/autoload_configs/switch.conf.xml"; + $handle = fopen($filename,"rb"); + $contents = fread($handle, filesize($filename)); + fclose($handle); + + $handle = fopen($filename,"w"); + $contents = str_replace("", "", $contents); + $contents = str_replace("", "", $contents); + fwrite($handle, $contents); + unset($contents); + fclose($handle); + unset($filename); + + //prepare shout.conf.xml for mod_shout + $fout = fopen("/usr/local/freeswitch/conf/autoload_configs/shout.conf.xml","w"); + $tmpxml = "\n"; + $tmpxml .= " \n"; + $tmpxml .= " \n"; + $tmpxml .= " \n"; + $tmpxml .= " \n"; + $tmpxml .= " \n"; + $tmpxml .= " \n"; + $tmpxml .= ""; + fwrite($fout, $tmpxml); + unset($tmpxml); + fclose($fout); + + $fout = fopen("/usr/local/freeswitch/conf/autoload_configs/event_socket.conf.xml","w"); + $tmpxml = "\n"; + $tmpxml .= " \n"; + $tmpxml .= " \n"; + $tmpxml .= " \n"; + $tmpxml .= " \n"; + $tmpxml .= " \n"; + $tmpxml .= " \n"; + $tmpxml .= ""; + fwrite($fout, $tmpxml); + unset($tmpxml); + fclose($fout); + + /* freeswitch modules defaults */ + + if (strlen($config['installedpackages']['freeswitchmodules']['config'][0]['mod_console']) == 0) { + $config['installedpackages']['freeswitchmodules']['config'][0]['mod_console'] = "enable"; + } + if (strlen($config['installedpackages']['freeswitchmodules']['config'][0]['mod_logfile']) == 0) { + $config['installedpackages']['freeswitchmodules']['config'][0]['mod_logfile'] = "enable"; + } + if (strlen($config['installedpackages']['freeswitchmodules']['config'][0]['mod_syslog']) == 0) { + $config['installedpackages']['freeswitchmodules']['config'][0]['mod_syslog'] = "disable"; + } + if (strlen($config['installedpackages']['freeswitchmodules']['config'][0]['mod_yaml']) == 0) { + $config['installedpackages']['freeswitchmodules']['config'][0]['mod_yaml'] = "disable"; + } + if (strlen($config['installedpackages']['freeswitchmodules']['config'][0]['mod_enum']) == 0) { + $config['installedpackages']['freeswitchmodules']['config'][0]['mod_enum'] = "enable"; + } + if (strlen($config['installedpackages']['freeswitchmodules']['config'][0]['mod_xml_rpc']) == 0) { + $config['installedpackages']['freeswitchmodules']['config'][0]['mod_xml_rpc'] = "disable"; + } + if (strlen($config['installedpackages']['freeswitchmodules']['config'][0]['mod_xml_curl']) == 0) { + $config['installedpackages']['freeswitchmodules']['config'][0]['mod_xml_curl'] = "disable"; + } + if (strlen($config['installedpackages']['freeswitchmodules']['config'][0]['mod_xml_cdr']) == 0) { + $config['installedpackages']['freeswitchmodules']['config'][0]['mod_xml_cdr'] = "disable"; + } + if (strlen($config['installedpackages']['freeswitchmodules']['config'][0]['mod_cdr_csv']) == 0) { + $config['installedpackages']['freeswitchmodules']['config'][0]['mod_cdr_csv'] = "enable"; + } + if (strlen($config['installedpackages']['freeswitchmodules']['config'][0]['mod_event_multicast']) == 0) { + $config['installedpackages']['freeswitchmodules']['config'][0]['mod_event_multicast'] = "disable"; + } + if (strlen($config['installedpackages']['freeswitchmodules']['config'][0]['mod_event_socket']) == 0) { + $config['installedpackages']['freeswitchmodules']['config'][0]['mod_event_socket'] = "enable"; + } + if (strlen($config['installedpackages']['freeswitchmodules']['config'][0]['mod_zeroconf']) == 0) { + $config['installedpackages']['freeswitchmodules']['config'][0]['mod_zeroconf'] = "disable"; + } + if (strlen($config['installedpackages']['freeswitchmodules']['config'][0]['mod_ldap']) == 0) { + $config['installedpackages']['freeswitchmodules']['config'][0]['mod_ldap'] = "disable"; + } + if (strlen($config['installedpackages']['freeswitchmodules']['config'][0]['mod_dingaling']) == 0) { + $config['installedpackages']['freeswitchmodules']['config'][0]['mod_dingaling'] = "disable"; + } + if (strlen($config['installedpackages']['freeswitchmodules']['config'][0]['mod_iax']) == 0) { + $config['installedpackages']['freeswitchmodules']['config'][0]['mod_iax'] = "disable"; + } + if (strlen($config['installedpackages']['freeswitchmodules']['config'][0]['mod_portaudio']) == 0) { + $config['installedpackages']['freeswitchmodules']['config'][0]['mod_portaudio'] = "disable"; + } + if (strlen($config['installedpackages']['freeswitchmodules']['config'][0]['mod_alsa']) == 0) { + $config['installedpackages']['freeswitchmodules']['config'][0]['mod_alsa'] = "disable"; + } + if (strlen($config['installedpackages']['freeswitchmodules']['config'][0]['mod_sofia']) == 0) { + $config['installedpackages']['freeswitchmodules']['config'][0]['mod_sofia'] = "enable"; + } + if (strlen($config['installedpackages']['freeswitchmodules']['config'][0]['mod_loopback']) == 0) { + $config['installedpackages']['freeswitchmodules']['config'][0]['mod_loopback'] = "enable"; + } + if (strlen($config['installedpackages']['freeswitchmodules']['config'][0]['mod_wanpipe']) == 0) { + $config['installedpackages']['freeswitchmodules']['config'][0]['mod_wanpipe'] = "disable"; + } + if (strlen($config['installedpackages']['freeswitchmodules']['config'][0]['mod_woomera']) == 0) { + $config['installedpackages']['freeswitchmodules']['config'][0]['mod_woomera'] = "disable"; + } + if (strlen($config['installedpackages']['freeswitchmodules']['config'][0]['mod_openzap']) == 0) { + $config['installedpackages']['freeswitchmodules']['config'][0]['mod_openzap'] = "disable"; + } + if (strlen($config['installedpackages']['freeswitchmodules']['config'][0]['mod_commands']) == 0) { + $config['installedpackages']['freeswitchmodules']['config'][0]['mod_commands'] = "enable"; + } + if (strlen($config['installedpackages']['freeswitchmodules']['config'][0]['mod_conference']) == 0) { + $config['installedpackages']['freeswitchmodules']['config'][0]['mod_conference'] = "enable"; + } + if (strlen($config['installedpackages']['freeswitchmodules']['config'][0]['mod_dptools']) == 0) { + $config['installedpackages']['freeswitchmodules']['config'][0]['mod_dptools'] = "enable"; + } + if (strlen($config['installedpackages']['freeswitchmodules']['config'][0]['mod_expr']) == 0) { + $config['installedpackages']['freeswitchmodules']['config'][0]['mod_expr'] = "enable"; + } + if (strlen($config['installedpackages']['freeswitchmodules']['config'][0]['mod_fax']) == 0) { + $config['installedpackages']['freeswitchmodules']['config'][0]['mod_fax'] = "enable"; + } + if (strlen($config['installedpackages']['freeswitchmodules']['config'][0]['mod_fifo']) == 0) { + $config['installedpackages']['freeswitchmodules']['config'][0]['mod_fifo'] = "enable"; + } + if (strlen($config['installedpackages']['freeswitchmodules']['config'][0]['mod_voicemail']) == 0) { + $config['installedpackages']['freeswitchmodules']['config'][0]['mod_voicemail'] = "enable"; + } + if (strlen($config['installedpackages']['freeswitchmodules']['config'][0]['mod_limit']) == 0) { + $config['installedpackages']['freeswitchmodules']['config'][0]['mod_limit'] = "enable"; + } + if (strlen($config['installedpackages']['freeswitchmodules']['config'][0]['mod_esf']) == 0) { + $config['installedpackages']['freeswitchmodules']['config'][0]['mod_esf'] = "enable"; + } + if (strlen($config['installedpackages']['freeswitchmodules']['config'][0]['mod_fsv']) == 0) { + $config['installedpackages']['freeswitchmodules']['config'][0]['mod_fsv'] = "enable"; + } + if (strlen($config['installedpackages']['freeswitchmodules']['config'][0]['mod_snom']) == 0) { + $config['installedpackages']['freeswitchmodules']['config'][0]['mod_snom'] = "disable"; + } + if (strlen($config['installedpackages']['freeswitchmodules']['config'][0]['mod_dialplan_directory']) == 0) { + $config['installedpackages']['freeswitchmodules']['config'][0]['mod_dialplan_directory'] = "disable"; + } + if (strlen($config['installedpackages']['freeswitchmodules']['config'][0]['mod_dialplan_xml']) == 0) { + $config['installedpackages']['freeswitchmodules']['config'][0]['mod_dialplan_xml'] = "enable"; + } + if (strlen($config['installedpackages']['freeswitchmodules']['config'][0]['mod_dialplan_asterisk']) == 0) { + $config['installedpackages']['freeswitchmodules']['config'][0]['mod_dialplan_asterisk'] = "enable"; + } + if (strlen($config['installedpackages']['freeswitchmodules']['config'][0]['mod_voipcodecs']) == 0) { + $config['installedpackages']['freeswitchmodules']['config'][0]['mod_voipcodecs'] = "enable"; + } + if (strlen($config['installedpackages']['freeswitchmodules']['config'][0]['mod_g723_1']) == 0) { + $config['installedpackages']['freeswitchmodules']['config'][0]['mod_g723_1'] = "enable"; + } + if (strlen($config['installedpackages']['freeswitchmodules']['config'][0]['mod_g729']) == 0) { + $config['installedpackages']['freeswitchmodules']['config'][0]['mod_g729'] = "enable"; + } + if (strlen($config['installedpackages']['freeswitchmodules']['config'][0]['mod_amr']) == 0) { + $config['installedpackages']['freeswitchmodules']['config'][0]['mod_amr'] = "enable"; + } + if (strlen($config['installedpackages']['freeswitchmodules']['config'][0]['mod_ilbc']) == 0) { + $config['installedpackages']['freeswitchmodules']['config'][0]['mod_ilbc'] = "enable"; + } + if (strlen($config['installedpackages']['freeswitchmodules']['config'][0]['mod_speex']) == 0) { + $config['installedpackages']['freeswitchmodules']['config'][0]['mod_speex'] = "enable"; + } + if (strlen($config['installedpackages']['freeswitchmodules']['config'][0]['mod_siren']) == 0) { + $config['installedpackages']['freeswitchmodules']['config'][0]['mod_siren'] = "enable"; + } + if (strlen($config['installedpackages']['freeswitchmodules']['config'][0]['mod_celt']) == 0) { + $config['installedpackages']['freeswitchmodules']['config'][0]['mod_celt'] = "enable"; + } + if (strlen($config['installedpackages']['freeswitchmodules']['config'][0]['mod_h26x']) == 0) { + $config['installedpackages']['freeswitchmodules']['config'][0]['mod_h26x'] = "enable"; + } + if (strlen($config['installedpackages']['freeswitchmodules']['config'][0]['mod_sndfile']) == 0) { + $config['installedpackages']['freeswitchmodules']['config'][0]['mod_sndfile'] = "enable"; + } + if (strlen($config['installedpackages']['freeswitchmodules']['config'][0]['mod_native_file']) == 0) { + $config['installedpackages']['freeswitchmodules']['config'][0]['mod_native_file'] = "enable"; + } + if (strlen($config['installedpackages']['freeswitchmodules']['config'][0]['mod_shout']) == 0) { + $config['installedpackages']['freeswitchmodules']['config'][0]['mod_shout'] = "disable"; + } + if (strlen($config['installedpackages']['freeswitchmodules']['config'][0]['mod_local_stream']) == 0) { + $config['installedpackages']['freeswitchmodules']['config'][0]['mod_local_stream'] = "enable"; + } + if (strlen($config['installedpackages']['freeswitchmodules']['config'][0]['mod_tone_stream']) == 0) { + $config['installedpackages']['freeswitchmodules']['config'][0]['mod_tone_stream'] = "enable"; + } + if (strlen($config['installedpackages']['freeswitchmodules']['config'][0]['mod_spidermonkey']) == 0) { + $config['installedpackages']['freeswitchmodules']['config'][0]['mod_spidermonkey'] = "enable"; + } + if (strlen($config['installedpackages']['freeswitchmodules']['config'][0]['mod_spidermonkey_odbc']) == 0) { + $config['installedpackages']['freeswitchmodules']['config'][0]['mod_spidermonkey_odbc'] = "disable"; + } + if (strlen($config['installedpackages']['freeswitchmodules']['config'][0]['mod_perl']) == 0) { + $config['installedpackages']['freeswitchmodules']['config'][0]['mod_perl'] = "disable"; + } + if (strlen($config['installedpackages']['freeswitchmodules']['config'][0]['mod_python']) == 0) { + $config['installedpackages']['freeswitchmodules']['config'][0]['mod_python'] = "disable"; + } + if (strlen($config['installedpackages']['freeswitchmodules']['config'][0]['mod_java']) == 0) { + $config['installedpackages']['freeswitchmodules']['config'][0]['mod_java'] = "disable"; + } + if (strlen($config['installedpackages']['freeswitchmodules']['config'][0]['mod_lua']) == 0) { + $config['installedpackages']['freeswitchmodules']['config'][0]['mod_lua'] = "enable"; + } + if (strlen($config['installedpackages']['freeswitchmodules']['config'][0]['mod_flite']) == 0) { + $config['installedpackages']['freeswitchmodules']['config'][0]['mod_flite'] = "disable"; + } + if (strlen($config['installedpackages']['freeswitchmodules']['config'][0]['mod_pocketsphinx']) == 0) { + $config['installedpackages']['freeswitchmodules']['config'][0]['mod_pocketsphinx'] = "disable"; + } + if (strlen($config['installedpackages']['freeswitchmodules']['config'][0]['mod_cepstral']) == 0) { + $config['installedpackages']['freeswitchmodules']['config'][0]['mod_cepstral'] = "disable"; + } + if (strlen($config['installedpackages']['freeswitchmodules']['config'][0]['mod_openmrcp']) == 0) { + $config['installedpackages']['freeswitchmodules']['config'][0]['mod_openmrcp'] = "disable"; + } + if (strlen($config['installedpackages']['freeswitchmodules']['config'][0]['mod_rss']) == 0) { + $config['installedpackages']['freeswitchmodules']['config'][0]['mod_rss'] = "disable"; + } + if (strlen($config['installedpackages']['freeswitchmodules']['config'][0]['mod_say_en']) == 0) { + $config['installedpackages']['freeswitchmodules']['config'][0]['mod_say_en'] = "enable"; + } + if (strlen($config['installedpackages']['freeswitchmodules']['config'][0]['mod_say_de']) == 0) { + $config['installedpackages']['freeswitchmodules']['config'][0]['mod_say_de'] = "disable"; + } + if (strlen($config['installedpackages']['freeswitchmodules']['config'][0]['mod_say_es']) == 0) { + $config['installedpackages']['freeswitchmodules']['config'][0]['mod_say_es'] = "disable"; + } + if (strlen($config['installedpackages']['freeswitchmodules']['config'][0]['mod_say_fr']) == 0) { + $config['installedpackages']['freeswitchmodules']['config'][0]['mod_say_fr'] = "disable"; + } + if (strlen($config['installedpackages']['freeswitchmodules']['config'][0]['mod_say_it']) == 0) { + $config['installedpackages']['freeswitchmodules']['config'][0]['mod_say_it'] = "disable"; + } + if (strlen($config['installedpackages']['freeswitchmodules']['config'][0]['mod_say_nl']) == 0) { + $config['installedpackages']['freeswitchmodules']['config'][0]['mod_say_nl'] = "disable"; + } + if (strlen($config['installedpackages']['freeswitchmodules']['config'][0]['mod_say_ru']) == 0) { + $config['installedpackages']['freeswitchmodules']['config'][0]['mod_say_ru'] = "disable"; + } + if (strlen($config['installedpackages']['freeswitchmodules']['config'][0]['mod_say_zh']) == 0) { + $config['installedpackages']['freeswitchmodules']['config'][0]['mod_say_zh'] = "disable"; + } + + //create the backup directory + if (!is_dir('/root/backup/')) { + exec("mkdir /root/backup/"); + } + + //extract a specific directory to /usr/local/freeswitch + $filename = 'freeswitch.bak.tgz'; + if (file_exists('/root/backup/'.$filename)) { + //echo "The file $filename exists"; + + exec("rm -R /usr/local/freeswitch/conf/sip_profiles/"); + exec("rm -R /usr/local/freeswitch/sounds/music/"); + + //Recommended + system('cd /usr/local; tar xvpfz /root/backup/'.$filename.' freeswitch/db/'); + system('cd /usr/local; tar xvpfz /root/backup/'.$filename.' freeswitch/log/'); + system('cd /usr/local; tar xvpfz /root/backup/'.$filename.' freeswitch/recordings/'); + system('cd /usr/local; tar xvpfz /root/backup/'.$filename.' freeswitch/scripts/'); + system('cd /usr/local; tar xvpfz /root/backup/'.$filename.' freeswitch/storage/'); + system('cd /usr/local; tar xvpfz /root/backup/'.$filename.' freeswitch/sounds/custom/8000/'); + system('cd /usr/local; tar xvpfz /root/backup/'.$filename.' freeswitch/sounds/music/8000/'); + system('cd /usr/local; tar xvpfz /root/backup/'.$filename.' freeswitch/conf/ssl/'); + system('cd /usr/local; tar xvpfz /root/backup/'.$filename.' freeswitch/conf/sip_profiles/'); + system('cd /usr/local; tar xvpfz /root/backup/'.$filename.' freeswitch/conf/vars.xml'); + system('cd /usr/local; tar xvpfz /root/backup/'.$filename.' freeswitch/conf/dialplan/default.xml'); + system('cd /usr/local; tar xvpfz /root/backup/'.$filename.' freeswitch/conf/dialplan/public.xml'); + + //Optional + //system('cd /usr/local; tar xvpfz /root/backup/'.$filename.' freeswitch/conf/'); + //system('cd /usr/local; tar xvpfz /root/backup/'.$filename.' freeswitch/grammar/'); + //system('cd /usr/local; tar xvpfz /root/backup/'.$filename.' freeswitch/htdocs/'); + + unset($filename); + } + + + exec("rm -R /freeswitch"); + exec("cp /usr/local/freeswitch/conf/directory/default/brian.xml /usr/local/freeswitch/conf/directory/default/brian.xml.noload"); + unlink_if_exists("/usr/local/freeswitch/conf/directory/default/brian.xml"); + unlink_if_exists("/usr/local/freeswitch/conf/directory/default/example.com.xml"); + unlink_if_exists("/usr/local/freeswitch/conf/dialplan/default/99999_enum.xml"); + + write_rcfile(array( + "file" => "freeswitch.sh", + "start" => "/usr/local/freeswitch/bin/./freeswitch -nc", + "stop" => "/usr/local/freeswitch/bin/./freeswitch -stop" + ) + ); + + lan_sip_profile(); + + sync_package_freeswitch(); + $handle = popen("/usr/local/etc/rc.d/freeswitch.sh start", "r"); + pclose($handle); + + if (pkg_is_service_running('freeswitch')) { + sync_package_freeswitch_ivr(); + } + + $config['installedpackages']['freeswitchsettings']['config'][0]['freeswitch_version'] = $freeswitch_build_version." revision ".$freeswitch_build_revision."."; + $config['installedpackages']['freeswitchsettings']['config'][0]['freeswitch_package_version'] = $freeswitch_package_version; + + conf_mount_ro(); + config_unlock(); + +} + + +function freeswitch_deinstall_command() +{ + + conf_mount_rw(); + config_lock(); + + exec("killall -9 freeswitch"); + unlink_if_exists("/usr/local/pkg/freeswitch.xml"); + unlink_if_exists("/usr/local/pkg/freeswitch.inc"); + unlink_if_exists("/usr/local/pkg/freeswitch_dialplan.xml"); + unlink_if_exists("/usr/local/pkg/freeswitch_extensions.xml"); + unlink_if_exists("/usr/local/pkg/freeswitch_external.xml"); + unlink_if_exists("/usr/local/pkg/freeswitch_internal.xml"); + unlink_if_exists("/usr/local/pkg/freeswitch_modules.xml"); + unlink_if_exists("/usr/local/pkg/freeswitch_public.xml"); + unlink_if_exists("/usr/local/pkg/freeswitch_vars.xml"); + + unlink_if_exists("/usr/local/www/packages/freeswitch/class.smtp.php"); + unlink_if_exists("/usr/local/www/packages/freeswitch/class.phpmailer.php"); + unlink_if_exists("/usr/local/www/packages/freeswitch/freeswitch_cmd.php"); + unlink_if_exists("/usr/local/www/packages/freeswitch/freeswitch_dialplan_includes_details.php"); + unlink_if_exists("/usr/local/www/packages/freeswitch/freeswitch_dialplan_includes_edit.php"); + unlink_if_exists("/usr/local/www/packages/freeswitch/freeswitch_dialplan_includes.php"); + unlink_if_exists("/usr/local/www/packages/freeswitch/freeswitch_dialplan_includes_details_edit.php"); + unlink_if_exists("/usr/local/www/packages/freeswitch/freeswitch_extensions.php"); + unlink_if_exists("/usr/local/www/packages/freeswitch/freeswitch_extensions_edit.php"); + unlink_if_exists("/usr/local/www/packages/freeswitch/freeswitch_ivr.php"); + unlink_if_exists("/usr/local/www/packages/freeswitch/freeswitch_ivr_edit.php"); + unlink_if_exists("/usr/local/www/packages/freeswitch/freeswitch_ivr_options_edit.php"); + unlink_if_exists("/usr/local/www/packages/freeswitch/freeswitch_ivr_options.php"); + unlink_if_exists("/usr/local/www/packages/freeswitch/freeswitch_gateways.php"); + unlink_if_exists("/usr/local/www/packages/freeswitch/freeswitch_gateways_edit.php"); + unlink_if_exists("/usr/local/www/packages/freeswitch/freeswitch_mailto.php"); + unlink_if_exists("/usr/local/www/packages/freeswitch/freeswitch_public_includes_details.php"); + unlink_if_exists("/usr/local/www/packages/freeswitch/freeswitch_public_includes_edit.php"); + unlink_if_exists("/usr/local/www/packages/freeswitch/freeswitch_public_includes.php"); + unlink_if_exists("/usr/local/www/packages/freeswitch/freeswitch_public_includes_details_edit.php"); + unlink_if_exists("/usr/local/www/packages/freeswitch/freeswitch_recordings.php"); + unlink_if_exists("/usr/local/www/packages/freeswitch/freeswitch_recordings_edit.php"); + unlink_if_exists("/usr/local/www/packages/freeswitch/freeswitch_recordings_play.php"); + unlink_if_exists("/usr/local/www/packages/freeswitch/freeswitch_time_conditions.php"); + unlink_if_exists("/usr/local/www/packages/freeswitch/freeswitch_time_conditions_edit.php"); + unlink_if_exists("/usr/local/www/packages/freeswitch/freeswitch_status.php"); + unlink_if_exists("/usr/local/www/packages/freeswitch/slim.swf"); + + exec("rm -R /usr/local/freeswitch/"); + exec("rm -R /usr/local/www/packages/freeswitch/"); + unlink_if_exists("/usr/local/etc/rc.d/freeswitch.sh"); + unlink_if_exists("/tmp/freeswitch.tar.gz"); + unlink_if_exists("/tmp/pkg_mgr_FreeSWITCH.log"); + + conf_mount_ro(); + config_unlock(); + +} + +?> diff --git a/config/freeswitch_dev/freeswitch.xml b/config/freeswitch_dev/freeswitch.xml new file mode 100644 index 00000000..706d7c3c --- /dev/null +++ b/config/freeswitch_dev/freeswitch.xml @@ -0,0 +1,267 @@ + + + + + + + + FreeSWITCH is an open source telephony platform designed to facilitate the creation of voice and chat driven products scaling from a soft-phone up to a soft-switch. It can be used as a simple switching engine, a PBX, a media gateway or a media server to host IVR applications using simple scripts or XML to control the callflow. + Describe your package requirements here + Currently there are no FAQ items provided. + FreeSWITCH Settings + 0.9.4.4 + FreeSWITCH: Settings + /usr/local/pkg/freeswitch.inc + + FreeSWITCH + Modify FreeSWITCH settings. +
Services
+ freeswitch.xml + /pkg_edit.php?xml=freeswitch.xml&id=0 +
+ + freeswitch + freeswitch.sh + freeswitch + FreeSWITCH is an open source telephony platform designed to facilitate the creation of voice and chat driven products scaling from a soft-phone up to a soft-switch. It can be used as a simple switching engine, a PBX, a media gateway or a media server to host IVR applications using simple scripts or XML to control the callflow. + + + + Settings + /pkg_edit.php?xml=freeswitch.xml&id=0 + + + + Dialplan + /packages/freeswitch/freeswitch_dialplan_includes.php + + + Extensions + /packages/freeswitch/freeswitch_extensions.php + + + Features + /packages/freeswitch/freeswitch_features.php + + + Gateways + /packages/freeswitch/freeswitch_gateways.php + + + Profiles + /packages/freeswitch/freeswitch_profiles.php + + + Public + /packages/freeswitch/freeswitch_public_includes.php + + + Status + /packages/freeswitch/freeswitch_status.php + + + Vars + /packages/freeswitch/freeswitch_vars.php + + + installedpackages->package->$packagename->configuration->freeswitchsettings + + /tmp/ + 0755 + http://portableusbapps.com/packages/config/freeswitch/freeswitch.tgz + + + /usr/local/pkg/ + 0755 + http://www.pfsense.com/packages/config/freeswitch/freeswitch.inc + + + + Numbering Plan + numbering_plan + Enter the numbering plan here. example: US + input + + + Default Gateway + default_gateway + Enter the default gateway name here. + input + + + Default Area Code + default_area_code + Enter the area code here. example: 918 + input + + + Event Socket Port + event_socket_port + Enter the event socket port here. default: 8021 + input + + + Event Socket Password + event_socket_password + Enter the event socket password here. default: ClueCon + password + + + XML RPC HTTP Port + xml_rpc_http_port + Enter the XML RPC HTTP Port here. default: 8787 + input + + + XML RPC Auth Realm + xml_rpc_auth_realm + Enter the XML RPC Auth Realm here. default: freeswitch + input + + + XML RPC Auth User + xml_rpc_auth_user + Enter the XML RPC Auth User here. default: freeswitch + input + + + XML RPC Auth Password + xml_rpc_auth_pass + Enter the XML RPC Auth Password here. default: works + password + + + Admin PIN Number + admin_pin + Enter a admin pin number. Used to authenticate the admin from the phone. + password + + + SMTP Host + smtphost + Enter the SMTP host address. If you using a different port append it on the end with a colon. e.g. smtp.gmail.com:465 + input + + + SMTP Secure + smtpsecure + Select the SMTP security. None, TLS, SSL + select + + + + + + + + SMTP Auth + smtpauth + Use SMTP Authentication true or false. + select + + + + + + + SMTP Username + smtpusername + Enter the SMTP authentication username. + input + + + SMTP Password + smtppassword + Enter the SMTP authentication password. + password + + + SMTP From + smtpfrom + Enter the SMTP From email address. + input + + + SMTP From Name + smtpfromname + Enter the SMTP From Name. + input + + + Mod Shout Decoder + mod_shout_decoder + Enter the Decoder. default: i386 + input + + + Mod Shout Volume + mod_shout_volume + Enter the Volume. default: 0.3 + input + + + + + + sync_package_freeswitch_settings(); + + + sync_package_freeswitch_settings(); + + + freeswitch_php_install_command(); + + + freeswitch_deinstall_command(); + +
diff --git a/config/freeswitch_dev/freeswitch_cmd.tmp b/config/freeswitch_dev/freeswitch_cmd.tmp new file mode 100644 index 00000000..21dba508 --- /dev/null +++ b/config/freeswitch_dev/freeswitch_cmd.tmp @@ -0,0 +1,49 @@ + \ No newline at end of file diff --git a/config/freeswitch_dev/freeswitch_dialplan.tmp b/config/freeswitch_dev/freeswitch_dialplan.tmp new file mode 100644 index 00000000..fcfb3192 --- /dev/null +++ b/config/freeswitch_dev/freeswitch_dialplan.tmp @@ -0,0 +1,163 @@ + + + + + + + + + + +

FreeSWITCH: Dialplan

+ +
+ + +
+ +
+ + + + + + +
+ +
+ + + + + + +

Default Dialplan
+
+ The default dialplan is used to setup call destinations based on conditions and context. + You can use the dialplan to send calls to gateways, IVRs, external numbers, to scripts, or any destination. +

+
+
+
+ + +
+
+ + + + + + +
/usr/local/freeswitch/conf/dialplan/default.xml + + + "; + ?> +
+ +
+ +
+
+ +
+
+
+
+
+
+
+
+ +
+ +
+ + + + + + diff --git a/config/freeswitch_dev/freeswitch_dialplan_includes.tmp b/config/freeswitch_dev/freeswitch_dialplan_includes.tmp new file mode 100644 index 00000000..55379ea5 --- /dev/null +++ b/config/freeswitch_dev/freeswitch_dialplan_includes.tmp @@ -0,0 +1,278 @@ + 0) { + $i=0; + foreach($a_dialplan_includes_details as $row) { + if ($row["dialplanincludeid"] == $dialplanincludeid) { + //echo "child id: ".$i."
\n"; + unset($a_dialplan_includes_details[$i]); + } + $i++; + } + } + + //if the dialplan include xml file exists then delete it + if (file_exists("/usr/local/freeswitch/conf/dialplan/default/".$dialplanincludefilename)) { + unlink("/usr/local/freeswitch/conf/dialplan/default/".$dialplanincludefilename); + } + + unset($dialplanincludefilename); + unset($a_dialplan_includes[$_GET['id']]); + write_config(); + sync_package_freeswitch_dialplan_includes(); + header("Location: freeswitch_dialplan_includes.php"); + exit; + } + } +} + +include("head.inc"); + +?> + + + +

FreeSWITCH: Dialplan

+ +
+ + +
+ +
+ + + + + +
+ +
+"; +//print_r ($a_dialplan_includes); +//echo ""; + + +//if ($config_change == 1) { +// write_config(); +// $config_change = 0; +//} + +//if ($savemsg) print_info_box($savemsg); +//if (file_exists($d_hostsdirty_path)): echo"

"; +//print_info_box_np("This has been changed.
You must apply the changes in order for them to take effect."); +//echo"
"; +//endif; + +?> + +
+
+ + + + + + + + + + +
Dialplan + + + +
+ + The dialplan is used to setup call destinations based on conditions and context. You can use the dialplan to send calls to gateways, IVRs, external numbers, to scripts, or any destination. + +
+ +
+
+
+ + + + + + + + + + + 0) { + foreach ($a_dialplan_includes as $ent) { + $a_dialplan_includes[$i]['id'] = $i; + $i++; + } + } + + //order the array + function cmp_number($a, $b) { + if ($a["order"] > $b["order"]) { + return 1; + } + else { + return 0; + } + } + if (count($a_public_includes) > 0) { usort($a_dialplan_includes, "cmp_number"); } + + $i = 0; + if (count($a_dialplan_includes) > 0) { + foreach ($a_dialplan_includes as $ent) { + ?> + + + + + + + + + + + + + + + + + +
Extension NameOrderEnabledDescription + + + + + +
+
+ + + + +   + +   + + + + + + +
+
+ + + + + +
+
+ +

+ +/usr/local/freeswitch/conf/dialplan/default/ +
+
+
+
+
+
+ +
+ +
+ + + + + \ No newline at end of file diff --git a/config/freeswitch_dev/freeswitch_dialplan_includes_details.tmp b/config/freeswitch_dev/freeswitch_dialplan_includes_details.tmp new file mode 100755 index 00000000..1504d590 --- /dev/null +++ b/config/freeswitch_dev/freeswitch_dialplan_includes_details.tmp @@ -0,0 +1,53 @@ + \ No newline at end of file diff --git a/config/freeswitch_dev/freeswitch_dialplan_includes_details_edit.tmp b/config/freeswitch_dev/freeswitch_dialplan_includes_details_edit.tmp new file mode 100644 index 00000000..f3cbf71d --- /dev/null +++ b/config/freeswitch_dev/freeswitch_dialplan_includes_details_edit.tmp @@ -0,0 +1,389 @@ + + + + +

FreeSWITCH: Dialplan: Details: Edit

+ + + +
+ + +
+ +
+ + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + +
Tag + + \n"; + echo " \n"; + switch (htmlspecialchars($pconfig['tag'])) { + case "condition": + echo " \n"; + echo " \n"; + echo " \n"; + //echo " \n"; + break; + case "action": + echo " \n"; + echo " \n"; + echo " \n"; + //echo " \n"; + break; + case "anti-action": + echo " \n"; + echo " \n"; + echo " \n"; + //echo " \n"; + break; + case "param": + echo " \n"; + echo " \n"; + echo " \n"; + //echo " \n"; + break; + default: + echo " \n"; + echo " \n"; + echo " \n"; + //echo " \n"; + } + echo " \n"; + + //condition + //field expression + //action + //application + //data + //antiaction + //application + //data + //param + //name + //value + + ?> +
Type + +
Data + +
Order + \n"; + //echo " \n"; + if (strlen(htmlspecialchars($pconfig['fieldorder']))> 0) { + echo " \n"; + } + $i=0; + while($i<=999) { + if (strlen($i) == 1) { + echo " \n"; + } + if (strlen($i) == 2) { + echo " \n"; + } + if (strlen($i) == 3) { + echo " \n"; + } + + $i++; + } + echo " \n"; + ?> +
  + + + + + + +
+
+ +
+
+ Additional Information +
+
+ http://wiki.freeswitch.org/wiki/Dialplan_XML + +
+
+
+
+ + Conditions +
+
+ Conditions are pattern matching tags that help FreeSwitch decide if the current call should be processed in this extension or not. When matching conditions against the current call you have several fields that you can compare against. +
    +
  • context
  • +
  • rdnis Redirected Number, the directory number to which the call was last presented.
  • +
  • destination_number Called Number, the number this call is trying to reach (within a given context)
  • +
  • dialplan Name of the dialplan module that are used, the name is provided by each dialplan module. Example: XML
  • +
  • caller_id_name Name of the caller (provided by the User Agent that has called us).
  • +
  • caller_id_number Directory Number of the party who called (callee) -- can be masked (hidden)
  • +
  • ani Automatic Number Identification, the number of the calling party (callee) -- cannot be masked
  • +
  • ani2 The type of device placing the call [1]
  • +
  • uuid Unique identifier of the current call? (looks like a GUID)
  • +
  • source Name of the FreeSwitch module that received the call (e.g. PortAudio)
  • +
  • chan_name Name of the current channel (Example: PortAudio/1234). Give us examples when this one can be used.
  • +
  • network_addr IP address of the signalling source for a VoIP call.
  • +
+ In addition to the above you can also do variables using the syntax ${variable} or api functions using the syntax %{api} {args} +
+
+ Variables may be used in either the field or the expression, as follows + +
+
+
+
+ + Action and Anti-Actions +
+
+ Actions are executed when the condition matches. Anti-Actions are executed when the condition does NOT match. + Additional information on applications for Actions and Anti-Actions.
+ http://wiki.freeswitch.org/wiki/Modules#Applications +
+ http://wiki.freeswitch.org/wiki/Dialplan_Functions +
+
+
+ The following is a partial list of applications. +
    +
  • answer answer the call
  • +
  • bridge bridge the call
  • +
  • cond
  • +
  • db is a a runtime database either sqlite by default or odbc
  • +
  • global_set allows setting of global vars similar to the ones found in vars.xml
  • +
  • group allows grouping of several extensions for things like ring groups
  • +
  • expr
  • +
  • hangup hangs up the call
  • +
  • info sends call info to the console
  • +
  • javascript run javascript .js files
  • +
  • playback
  • +
  • reject reject the call
  • +
  • respond
  • +
  • ring_ready
  • +
  • set set a variable
  • +
  • set_user
  • +
  • sleep
  • +
  • sofia_contact
  • +
  • transfer transfer the call to another extension or number
  • +
  • voicemail send the call to voicemail
  • +
+ + +
+
+ + + + +
+
+
+
+
+ +
+ +
+ + + + diff --git a/config/freeswitch_dev/freeswitch_dialplan_includes_edit.tmp b/config/freeswitch_dev/freeswitch_dialplan_includes_edit.tmp new file mode 100644 index 00000000..a6118042 --- /dev/null +++ b/config/freeswitch_dev/freeswitch_dialplan_includes_edit.tmp @@ -0,0 +1,543 @@ + 0) { + //update + $ent['dialplanincludeid'] = $_POST['dialplanincludeid']; + } + else { + //add + $ent['dialplanincludeid'] = guid(); + } + $ent['extensionname'] = $_POST['extensionname']; + $ent['order'] = $_POST['order']; + //$ent['context'] = $_POST['context']; + $ent['context'] = 'default'; + $ent['enabled'] = $_POST['enabled']; + $ent['descr'] = $_POST['descr']; + $ent['opt1name'] = $_POST['opt1name']; + $ent['opt1value'] = $_POST['opt1value']; + + + if (isset($id) && $a_dialplan_includes[$id]) { + + if (count($a_dialplan_includes)>0) { + foreach($a_dialplan_includes as $rowhelper) { + + //$rowhelper['dialplanincludeid']; + //$rowhelper['extensionname']; + //$rowhelper['context']; + //$rowhelper['enabled']; + + $filenamechanged = false; + if ($rowhelper['dialplanincludeid'] == $_POST['dialplanincludeid']) { + + if ($rowhelper['extensionname'] != $_POST['extensionname']) { + //if the extension name has changed then remove the current dialplan xml file + //to prepare for the new file + $filenamechanged = true; + } + if ($rowhelper['order'] != $_POST['order']) { + //if the order has changed then remove the current dialplan xml file + //to prepare for the new file + $filenamechanged = true; + } + if ($_POST['enabled'] == "false") { + //if the extension name is disabled then remove the dialplan xml file + $filenamechanged = true; + } + if ($filenamechanged){ + $dialplanincludefilename = $rowhelper['order']."_".$rowhelper['extensionname'].".xml"; + if (file_exists("/usr/local/freeswitch/conf/dialplan/default/".$dialplanincludefilename)) { + unlink("/usr/local/freeswitch/conf/dialplan/default/".$dialplanincludefilename); + } + unset($dialplanincludefilename); + } + + } + unset($filenamechanged); + + } //end foreach + } //end count + + //update the config + $a_dialplan_includes[$id] = $ent; + } + else { + //add to the config + $a_dialplan_includes[] = $ent; + } + + + write_config(); + sync_package_freeswitch_dialplan_includes(); + + header("Location: freeswitch_dialplan_includes.php"); + exit; + } +} + +include("head.inc"); + +?> + + + +

FreeSWITCH: Dialplan: Edit

+ + + + +
+ + +
+ +
+ + + + +
+ + + + + +

Dialplan:
+
+ Dialplan Include general settings. +

+
+ +
+ + + + + + + + + + + + + + + + + + + + + + + + + +
Extension Name + +
+ Supported characters are 'a-z', 'A-Z', '0-9', underscore '_', and period '.'. +
Enabled + \n"; + echo " \n"; + switch (htmlspecialchars($pconfig['enabled'])) { + case "true": + echo " \n"; + echo " \n"; + break; + case "false": + echo " \n"; + echo " \n"; + + break; + default: + echo " \n"; + echo " \n"; + } + echo " \n"; + ?> +
Order + \n"; + //echo " \n"; + if (strlen(htmlspecialchars($pconfig['order']))> 0) { + echo " \n"; + } + $i=0; + while($i<=999) { + if (strlen($i) == 1) { + echo " \n"; + } + if (strlen($i) == 2) { + echo " \n"; + } + if (strlen($i) == 3) { + echo " \n"; + } + + $i++; + } + echo " \n"; + ?> +
+ Processing of each dialplan include is determined by this order. +
Description + +
You may enter a description here + for your reference (not parsed).
  + + 0 && $a_dialplan_includes[$id]) { + echo "\n"; + echo " \n"; + echo " \n"; + echo " \n"; + } + ?> + +
+
+ +
+
+ +
+ "; + //print_r ($a_dialplan_includes); + //echo ""; + + //if ($savemsg) print_info_box($savemsg); + //if (file_exists($d_hostsdirty_path)): echo"

"; + //print_info_box_np("The FreeSWITCH recordings have been changed.
You must apply the changes in order for them to take effect."); + //echo"
"; + //endif; + + //create a temporary id for the array + $i = 0; + if (count($a_dialplan_include_details) > 0) { + foreach ($a_dialplan_include_details as $ent) { + $a_dialplan_include_details[$i]['id'] = $i; + $i++; + } + } + + //order the array + function cmp_number($a, $b) { + if ($a["fieldorder"] > $b["fieldorder"]) { + return 1; + } + else { + return 0; + } + } + if (count($a_dialplan_include_details) > 0) { usort($a_dialplan_include_details, "cmp_number"); } + + ?> + + + + + + +

Conditions and Actions
+
+ The following conditions, actions and anti-actions are used in the dialplan to direct call flow. Each is processed in order until you reach the action tag which tells FreeSWITCH what action to perform. You are not limited to only one condition or action tag for a given extension. +

+
+ + + + + + + + + + + 0) { + + foreach ($a_dialplan_include_details as $ent) { + if ($ent['tag'] == "condition" && $dialplanincludeid == $ent['dialplanincludeid']) { + ?> + + + + + + + + 0) { + + foreach ($a_dialplan_include_details as $ent) { + if ($ent['tag'] == "action" && $dialplanincludeid == $ent['dialplanincludeid']) { + ?> + + + + + + + + 0) { + + foreach ($a_dialplan_include_details as $ent) { + if ($ent['tag'] == "anti-action" && $dialplanincludeid == $ent['dialplanincludeid']) { + ?> + + + + + + + + 0) { + + foreach ($a_dialplan_include_details as $ent) { + if ($ent['tag'] == "param" && $dialplanincludeid == $ent['dialplanincludeid']) { + ?> + + + + + + + + + + + + + + + + + + +
TagTypeDataOrder + + + + + +
+
+ + +   + +   + +   + + + + + + +
+
+ + +   + +   + +   + + + + + + +
+
+ + +   + +   + +   + + + + + + +
+
+ + +   + +   + +   + + + + + + +
+
+ + + + + +
+
+ +

+ + + + +
+
+ +
+ +
+ + + + diff --git a/config/freeswitch_dev/freeswitch_extensions.tmp b/config/freeswitch_dev/freeswitch_extensions.tmp new file mode 100644 index 00000000..b1db2702 --- /dev/null +++ b/config/freeswitch_dev/freeswitch_extensions.tmp @@ -0,0 +1,220 @@ + + + + + +

FreeSWITCH: Extensions

+ +
+ + +
+ +
+ + + + + +
+ +
+"; +//print_info_box_np("The FreeSWITCH extensions have been changed.
You must apply the changes in order for them to take effect."); +//echo"
"; +//endif; + +?> + + + + +

Extensions
+
+ Use this to configure your SIP extensions. +

+
+ + + + + + + + + + + + 0) { + foreach ($a_extensions as $ent) { + $a_extensions[$i]['id'] = $i; + $i++; + } + } + + //order the array + function cmp_number($a, $b) { + if ($a["extension"] > $b["extension"]) { + return 1; + } + else { + return 0; + } + } + if (count($a_extensions) > 0) { usort($a_extensions, "cmp_number"); } + + $i = 0; + if (count($a_extensions) > 0) { + + foreach ($a_extensions as $ent) { + + ?> + + + + + + + + + + + + + + + + + + + +
ExtensionMail ToCall GroupDescription + + + + + + +
+ +
+   + +   + +   + +   + + + + + + +
+
+ + + + + +
+
+ +
+ + +/usr/local/freeswitch/conf/directory/default/ +
+
+
+
+
+
+
+
+ +
+ +
+ + + + + \ No newline at end of file diff --git a/config/freeswitch_dev/freeswitch_extensions_edit.tmp b/config/freeswitch_dev/freeswitch_extensions_edit.tmp new file mode 100644 index 00000000..8e4a72dc --- /dev/null +++ b/config/freeswitch_dev/freeswitch_extensions_edit.tmp @@ -0,0 +1,417 @@ + + + + + + +

FreeSWITCH: Extensions: Edit

+ + + +
+ + +
+ +
+ + + + +
+ + + + + + +

Extension Setup
+
+ /usr/local/freeswitch/conf/directory/default/ +

+
+ +
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Extension + +
Enter the extension here. The default configuration 3 or 4 digit extensions.
+
Password + +
Enter the password here.
+
Mailbox + +
Enter the mailbox here. Example: extension 1001 then mailbox 1001
+
Voicemail Password + +
Enter the voicemail password here.
+
Account Code + +
Enter the account code here. Example: extension 1001 then accountcode 1001
+
Effective Caller ID Name + +
Enter the effective caller id name here.
+
Effective Caller ID Number + +
Enter the effective caller id number here.
+
Voicemail Mail To + +
Optional: Enter the email address to send voicemail to.
+
Voicemail Attach File + \n"; + echo " \n"; + switch (htmlspecialchars($pconfig['vm-attach-file'])) { + case "true": + echo " \n"; + echo " \n"; + break; + case "false": + echo " \n"; + echo " \n"; + + break; + default: + echo " \n"; + echo " \n"; + } + echo " \n"; + ?> + Choose whether to attach the file to the email. +
VM Keep Local After Email + \n"; + echo " \n"; + switch (htmlspecialchars($pconfig['vm-keep-local-after-email'])) { + case "true": + echo " \n"; + echo " \n"; + break; + case "false": + echo " \n"; + echo " \n"; + + break; + default: + echo " \n"; + echo " \n"; + } + echo " \n"; + ?> + Keep local file after sending the email. +
User Context + +
Enter the user context here. Example: default
+
Call Group + +
Enter the user call group here. Example: sales, support
+
+ +
+ + + + + +
Show Advanced + +
+
+ + + + + + + + + + + + + + + +
Enabled + \n"; + echo " \n"; + switch (htmlspecialchars($pconfig['enabled'])) { + case "true": + echo " \n"; + echo " \n"; + break; + case "false": + echo " \n"; + echo " \n"; + + break; + default: + echo " \n"; + echo " \n"; + } + echo " \n"; + ?> +
Extension Description + +
Enter the description of the extension here.
+
  + + + + +
+
+ +
+
+
+
+
+
+ +
+ +
+ + + + diff --git a/config/freeswitch_dev/freeswitch_fax.tmp b/config/freeswitch_dev/freeswitch_fax.tmp new file mode 100644 index 00000000..38992663 --- /dev/null +++ b/config/freeswitch_dev/freeswitch_fax.tmp @@ -0,0 +1,305 @@ + 0) { + $i=0; + foreach($a_dialplan_includes as $row) { + if ($row["dialplanincludeid"] == $faxid) { + $order = $row['order']; + unset($a_dialplan_includes[$i]); + } + $i++; + } + } + + //delete the dialplan include details. aka. child data + if (count($a_dialplan_includes_details) > 0) { + $i=0; + foreach($a_dialplan_includes_details as $row) { + if ($row["dialplanincludeid"] == $faxid) { + unset($a_dialplan_includes_details[$i]); + } + $i++; + } + } + + if (file_exists("/usr/local/freeswitch/conf/dialplan/default/".$order."_".$faxname.".xml")){ + unlink("/usr/local/freeswitch/conf/dialplan/default/".$order."_".$faxname.".xml"); + } + + //remove fax entries + unset($a_fax[$_GET['id']]); + + write_config(); + header("Location: freeswitch_fax.php"); + exit; + } + } +} + +if ($_GET['a'] == "download") { + + session_cache_limiter('public'); + + if ($_GET['type'] = "fax_file") { + if (file_exists($dir_fax.$_GET['filename'])) { + $fd = fopen($dir_fax.$_GET['filename'], "rb"); + if ($_GET['t'] == "bin") { + header("Content-Type: application/force-download"); + header("Content-Type: application/octet-stream"); + header("Content-Type: application/download"); + header("Content-Description: File Transfer"); + header('Content-Disposition: attachment; filename="'.$_GET['filename'].'"'); + } + else { + $file_ext = substr($_GET['filename'], -3); + if ($file_ext == "png") { + header("Content-Type: image/png"); + } + } + header("Cache-Control: no-cache, must-revalidate"); // HTTP/1.1 + header("Expires: Sat, 26 Jul 1997 05:00:00 GMT"); // Date in the past + header("Content-Length: " . filesize($dir_fax.$_GET['filename'])); + fpassthru($fd); + } + } + + exit; +} +else { + //echo $dir_fax.$_GET['filename']; +} + + +if ($_GET['act'] == "del") { + if ($_GET['type'] == 'fax_file') { + //if ($a_fax[$_GET['id']]) { + $tmp_file_array = split("\.",$_GET['filename']); + $file_name = $tmp_file_array[0]; + $file_ext = $tmp_file_array[1]; + unlink_if_exists($dir_fax.$file_name.".pdf"); + unlink_if_exists($dir_fax.$file_name.".png"); + unlink_if_exists($dir_fax.$file_name.".tif"); + //unset($a_fax[$_GET['id']]); + write_config(); + header("Location: freeswitch_fax.php"); + exit; + //} + } + +} + +include("head.inc"); + +?> + + + + +

FreeSWITCH: FAX

+ +
+ + +
+ +
+ + + + + +
+ +
+"; +//print_info_box_np("The FreeSWITCH fax have been changed.
You must apply the changes in order for them to take effect."); +//echo"
"; +//endif; + +?> + + + + +

FAX
+
+ To receive a FAX setup a fax extension and then direct the incoming FAX with a dedicated number or you can detect the FAX tone by using tone detection on the Public tab. +

+
+ + + + + + + + + + + + + 0) { + foreach ($a_fax as $ent) { + $a_fax[$i]['id'] = $i; + $i++; + } + } + + //order the array + function cmp_number($a, $b) { + if ($a["faxextension"] > $b["faxextension"]) { + return 1; + } + else { + return 0; + } + } + if (count($a_fax) > 0) { usort($a_fax, "cmp_number"); } + + $i = 0; + if (count($a_fax) > 0) { + + foreach ($a_fax as $ent) { + if (strlen($ent['faxextension']) > 0) { + ?> + + + + + + + + + + + + + + + + + + + + +
ExtensionNameEmailDomainDescription + + + + + + +
+ +
+   + +   + +   + +   + +   + + + + + + +
+
+ + + + + +
+
+ +
+ + +
+
+
+
+ + +
+ +
+ + + + + \ No newline at end of file diff --git a/config/freeswitch_dev/freeswitch_fax_edit.tmp b/config/freeswitch_dev/freeswitch_fax_edit.tmp new file mode 100644 index 00000000..43b22cf3 --- /dev/null +++ b/config/freeswitch_dev/freeswitch_fax_edit.tmp @@ -0,0 +1,723 @@ + 0) { + $i=0; + foreach($a_dialplan_includes as $row) { + if ($row["dialplanincludeid"] == $faxid) { + $order = $row['order']; + unset($a_dialplan_includes[$i]); + } + $i++; + } + } + + //delete the dialplan include details. aka. child data + if (count($a_dialplan_includes_details) > 0) { + $i=0; + foreach($a_dialplan_includes_details as $row) { + if ($row["dialplanincludeid"] == $faxid) { + unset($a_dialplan_includes_details[$i]); + } + $i++; + } + } + + if (file_exists("/usr/local/freeswitch/conf/dialplan/default/".$order."_".$faxname.".xml")){ + unlink("/usr/local/freeswitch/conf/dialplan/default/".$order."_".$faxname.".xml"); + } + + //remove fax entries + unset($a_fax[$_GET['id']]); + + write_config(); + header("Location: freeswitch_fax.php"); + exit; + } + } +} + +if (($_POST['type'] == "fax_send") && is_uploaded_file($_FILES['fax_file']['tmp_name'])) { + + $fax_number = $_POST['fax_number']; + $fax_name = $_FILES['fax_file']['name']; + $fax_name = str_replace(".tif", "", $fax_name); + $fax_name = str_replace(".tiff", "", $fax_name); + $fax_name = str_replace(".pdf", "", $fax_name); + $fax_gateway = $_POST['fax_gateway']; + + $password = $config['installedpackages']['freeswitchsettings']['config'][0]['event_socket_password']; + $port = $config['installedpackages']['freeswitchsettings']['config'][0]['event_socket_port']; + $host = $config['interfaces']['lan']['ipaddr']; + + //upload the file + move_uploaded_file($_FILES['fax_file']['tmp_name'], $dir_fax_temp.$_FILES['fax_file']['name']); + + $fax_file_extension = substr($dir_fax_temp.$_FILES['fax_file']['name'], -4); + if ($fax_file_extension == ".pdf") { + exec("cd ".$dir_fax_temp.";gs -q -sDEVICE=tiffg3 -r204x98 -dNOPAUSE -sOutputFile=".$fax_name.".tif -- ".$fax_name.".pdf -c quit"); + //exec("rm ".$dir_fax_temp.$fax_name.".pdf"); + } + if ($fax_file_extension == ".tiff") { + exec("cp ".$dir_fax_temp.$fax_name.".tiff ".$dir_fax_temp.$fax_name.".tif"); + exec("rm ".$dir_fax_temp.$fax_name.".tiff"); + } + + //send the fax + $fp = event_socket_create($host, $port, $password); + $cmd = "api originate [absolute_codec_string=PCMU]sofia/gateway/".$fax_gateway."/".$fax_number." &txfax(".$dir_fax_temp.$fax_name.".tif)"; + $response = event_socket_request($fp, $cmd); + $response = str_replace("\n", "", $response); + $uuid = str_replace("+OK ", "", $response); + fclose($fp); + + //if ($response >= 1) { + // $fp = event_socket_create($host, $port, $password); + // $cmd = "api uuid_getvar ".$uuid." fax_result_text"; + // echo $cmd."\n"; + // $response = event_socket_request($fp, $cmd); + // $response = trim($response); + // fclose($fp); + //} + + sleep(5); + + //copy the .tif to the sent directory + exec("cp ".$dir_fax_temp.$fax_name.".tif ".$dir_fax_sent.$fax_name.".tif"); + + //delete the .tif from the temp directory + //exec("rm ".$dir_fax_temp.$fax_name.".tif"); + + //convert the tif to pdf and png + exec("cd $dir_fax_sent; /usr/local/bin/tiff2png ".$dir_fax_sent.$fax_name.".tif"); + exec("cd $dir_fax_sent; /usr/local/bin/tiff2pdf -f -o ".$fax_name.".pdf ".$dir_fax_sent.$fax_name.".tif"); + + header("Location: freeswitch_fax_edit.php?id=".$id."&msg=".$response); + exit; +} + +if ($_GET['a'] == "download") { + + session_cache_limiter('public'); + + if ($_GET['type'] == "fax_inbox") { + + if (file_exists($dir_fax_inbox.$_GET['filename'])) { + + $fd = fopen($dir_fax_inbox.$_GET['filename'], "rb"); + if ($_GET['t'] == "bin") { + header("Content-Type: application/force-download"); + header("Content-Type: application/octet-stream"); + header("Content-Type: application/download"); + header("Content-Description: File Transfer"); + header('Content-Disposition: attachment; filename="'.$_GET['filename'].'"'); + } + else { + $file_ext = substr($_GET['filename'], -3); + if ($file_ext == "png") { + header("Content-Type: image/png"); + } + } + header("Cache-Control: no-cache, must-revalidate"); // HTTP/1.1 + header("Expires: Sat, 26 Jul 1997 05:00:00 GMT"); // Date in the past + header("Content-Length: " . filesize($dir_fax_inbox.$_GET['filename'])); + fpassthru($fd); + } + else { + echo "not found"; + } + exit; + } + +} +else { + //echo $dir_fax_inbox.$_GET['filename']; +} + + +if ($_GET['a'] == "download") { + + session_cache_limiter('public'); + + if ($_GET['type'] == "fax_sent") { + if (file_exists($dir_fax_sent.$_GET['filename'])) { + $fd = fopen($dir_fax_sent.$_GET['filename'], "rb"); + if ($_GET['t'] == "bin") { + header("Content-Type: application/force-download"); + header("Content-Type: application/octet-stream"); + header("Content-Type: application/download"); + header("Content-Description: File Transfer"); + header('Content-Disposition: attachment; filename="'.$_GET['filename'].'"'); + } + else { + $file_ext = substr($_GET['filename'], -3); + if ($file_ext == "png") { + header("Content-Type: image/png"); + } + } + header("Cache-Control: no-cache, must-revalidate"); // HTTP/1.1 + header("Expires: Sat, 26 Jul 1997 05:00:00 GMT"); // Date in the past + header("Content-Length: " . filesize($dir_fax_sent.$_GET['filename'])); + fpassthru($fd); + } + + } + + exit; +} +else { + //echo $dir_fax_inbox.$_GET['filename']; +} + + +if ($_GET['act'] == "del") { + if ($_GET['type'] == 'fax_inbox') { + //if ($a_fax[$_GET['id']]) { + $tmp_file_array = split("\.",$_GET['filename']); + $file_name = $tmp_file_array[0]; + $file_ext = $tmp_file_array[1]; + unlink_if_exists($dir_fax_inbox.$file_name.".pdf"); + unlink_if_exists($dir_fax_inbox.$file_name.".png"); + unlink_if_exists($dir_fax_inbox.$file_name.".tif"); + //unset($a_fax[$_GET['id']]); + write_config(); + header("Location: freeswitch_fax.php"); + exit; + //} + } +} + + +if ($_GET['act'] == "del") { + if ($_GET['type'] == 'fax_sent') { + //if ($a_fax[$_GET['id']]) { + $tmp_file_array = split("\.",$_GET['filename']); + $file_name = $tmp_file_array[0]; + $file_ext = $tmp_file_array[1]; + unlink_if_exists($dir_fax_sent.$file_name.".pdf"); + unlink_if_exists($dir_fax_sent.$file_name.".png"); + unlink_if_exists($dir_fax_sent.$file_name.".tif"); + //unset($a_fax[$_GET['id']]); + write_config(); + header("Location: freeswitch_fax.php"); + exit; + //} + } +} + + +if ($_POST) { + + unset($input_errors); + $pconfig = $_POST; + + if (!$input_errors) { + + $ent = array(); + if (strlen($_POST['faxid']) > 0) { + $ent['faxid'] = $_POST['faxid']; + } + else { + $ent['faxid'] = guid(); + } + $ent['faxextension'] = $_POST['faxextension']; + $ent['faxname'] = $_POST['faxname']; + $ent['faxemail'] = $_POST['faxemail']; + $ent['faxdomain'] = $_POST['faxdomain']; + $ent['faxdescription'] = $_POST['faxdescription']; + + if (isset($id) && $a_fax[$id]) { + //update + $a_fax[$id] = $ent; + } + else { + //add + $a_fax[] = $ent; + } + + if (!is_dir('/usr/local/freeswitch/storage/fax/')) { + exec("mkdir /usr/local/freeswitch/storage/fax/"); + } + + $faxfolder = '/usr/local/freeswitch/storage/fax/'.$_POST['faxextension']; + if (!is_dir($faxfolder)) { + exec('mkdir '.$faxfolder); + } + if (!is_dir($faxfolder.'/inbox/')) { + exec('mkdir '.$faxfolder.'/inbox/'); + } + if (!is_dir($faxfolder.'/sent/')) { + exec('mkdir '.$faxfolder.'/sent/'); + } + if (!is_dir($faxfolder.'/temp/')) { + exec('mkdir '.$faxfolder.'/temp/'); + } + write_config(); + sync_package_freeswitch_fax(); + + header("Location: freeswitch_fax.php"); + exit; + } +} + +include("head.inc"); + +?> + + + + + +

FreeSWITCH: FAX: Edit

+ + + +
+ + +
+ +
+ + + + +
+ + + + + + +

FAX Setup
+
+

+
+ +
+ + + + + + + + + + + + + + + + + + + +
Extension + +
Enter the fax extension here.
+
Name + +
Enter the name here.
+
Email + +
Optional: Enter the email address to send the FAX to.
+
Domain + +
Enter the domain here.
+
+ + + + + + + + +
Description + +
Enter the description here.
+
  + + + + + +
+
+ +
+
+
+
+ + + + + + + + + + + + +
+ Send +
+ To send a fax you can upload a .tif file or if ghost script has been installed then you can also send a fax by uploading a PDF. (pkg_add -r ghostscript8-nox11; rehash) + When sending a fax you can view status of the transmission by viewing the logs from the Status tab or by watching the response from the FreeSWITCH console. +
+
+ + + + + + + + + + +
+ Fax Number + + + Upload: + + + + + Gateway + + + 0) { + foreach ($a_gateways as $ent) { + $a_gateways[$i]['id'] = $i; + $i++; + } + } + + //order the array + function cmp_string($a, $b) { + return strcmp($a["gateway"], $b["gateway"]); + } + if (count($a_gateways) > 0) { usort($a_gateways, "cmp_string"); } + + echo "\n"; + + ?> + + +
+ +
+
+ + + +
+
+
+
+ + + + + + +
+ Inbox + + location: +
+ +
+ + + + + + + + + + \n"; + echo " \n"; + echo " \n"; + echo " \n"; + echo " \n"; + echo " \n"; + echo " \n"; + echo "\n"; + } + + } + } + closedir($handle); + } + ?> + + + + + +
File Name (download)DownloadViewLast ModifiedSize
\n"; + echo " \n"; + echo " $file"; + echo " "; + echo " \n"; + echo " \n"; + echo " pdf"; + echo " "; + echo " \n"; + echo " \n"; + echo " png"; + echo " "; + echo " \n"; + echo date ("F d Y H:i:s", filemtime($dir_fax_inbox.$file)); + echo " \n"; + echo " ".$tmp_filesize; + echo " \n"; + echo " \n"; + echo " \n"; + //echo " \n"; + echo " \n"; + echo " \n"; + echo "
\n"; + echo "
+ +
+
+
+
+ + + + + + +
+ Sent + + location: +
+ + + + + + + + + + + \n"; + echo " \n"; + echo " \n"; + echo " \n"; + echo " \n"; + echo " \n"; + echo " \n"; + echo "\n"; + } + + } + } + closedir($handle); + } + ?> + + + + + +
File Name (download)DownloadViewLast ModifiedSize
\n"; + echo " \n"; + echo " $file"; + echo " "; + echo " \n"; + echo " \n"; + echo " pdf"; + echo " "; + echo " \n"; + echo " \n"; + echo " png"; + echo " "; + echo " \n"; + echo date ("F d Y H:i:s", filemtime($dir_fax_sent.$file)); + echo " \n"; + echo " ".$tmp_filesize; + echo " \n"; + echo " \n"; + echo " \n"; + //echo " \n"; + echo " \n"; + echo " \n"; + echo "
\n"; + echo "
+ + +
+
+
+
+ + +
+ +
+ + + + diff --git a/config/freeswitch_dev/freeswitch_features.tmp b/config/freeswitch_dev/freeswitch_features.tmp new file mode 100644 index 00000000..1a2ed969 --- /dev/null +++ b/config/freeswitch_dev/freeswitch_features.tmp @@ -0,0 +1,216 @@ + + + + + +

FreeSWITCH: Extensions

+ +
+ + +
+ +
+ + + + + +
+ + +
+
+ + + + + + + + + +
Auto Attendant
Open + An interactive voice response (IVR) often refered to as an Auto Attendant. + It associates a recording to multiple options that can be used to direct + calls to extensions, voicemail, queues, other IVR applications, and external + phone numbers. +
+ +
+
+ + + + + + + + + +
Direct Inward System Access
+ Direct Inward System Access (DISA) allows inbound callers to make internal or external calls. For security reasons it is disabled by default. + To enable it first set a secure pin number from the Settings->Admin PIN Number. + Then go to Dialplan tab and find the DISA entry and edit it to set 'Enabled' to 'true'. + To use DISA dial *3427 (disa) enter the admin pin code and the extension or phone number you wish to call. +
+ +
+
+ + + + + + + + + +
FAX
Open + Transmit and View Received Faxes. +
+ +
+
+ + + + + + + + + +
Hunt Group
Open + Hunt Group is a group of destinations to call at once or in succession. +
+ +
+
+ + + + + + + + + +
Modules
Open + Modules add additional features and can be enabled or disabled to provide the desired features. +
+ +
+
+ + + + + + + + + +
Music on Hold
Open + Music on hold can be in WAV or MP3 format. To play an MP3 files you must have mod_shout enabled on the 'Modules' tab. + For best performance upload 16bit 8khz/16khz Mono WAV files. +
+ +
+
+ + + + + + + + + +
Recordings
Open + To make a recording dial *732673 (record) or you can make a 16bit 8khz/16khz + Mono WAV file then copy it to the following directory then refresh the page to play + it back. Click on the 'Filename' to download it or the 'Recording Name' to play the audio. +
+ +
+
+
+
+
+
+
+
+ +
+ +
+ + + + + diff --git a/config/freeswitch_dev/freeswitch_gateways.tmp b/config/freeswitch_dev/freeswitch_gateways.tmp new file mode 100644 index 00000000..16d933fd --- /dev/null +++ b/config/freeswitch_dev/freeswitch_gateways.tmp @@ -0,0 +1,214 @@ + + + + + +

FreeSWITCH: Gateways

+ +
+ + +
+ +
+ + + + + +
+ +
+"; +//print_info_box_np("The FreeSWITCH gateways have been changed.
You must apply the changes in order for them to take effect."); +//echo"
"; +//endif; + +?> + + + + +

Gateways
+
+ Use this to configure your SIP gateways also known as providers. +

+
+ + + + + + + + + + + + 0) { + foreach ($a_gateways as $ent) { + $a_gateways[$i]['id'] = $i; + $i++; + } + } + + //order the array + function cmp_string($a, $b) { + return strcmp($a["gateway"], $b["gateway"]); + } + if (count($a_gateways) > 0) { usort($a_gateways, "cmp_string"); } + + $i = 0; + if (count($a_gateways) > 0) { + + foreach ($a_gateways as $ent) { + + ?> + + + + + + + + + + + + + + + + + + + +
GatewayContextEnabledDescription + + + + + + +
+ +
+   + +   + +   + +   + + + + + + +
+
+ + + + + +
+
+ +
+ + +/usr/local/freeswitch/conf/sip_profiles/external/ +
+
+
+
+
+
+
+
+ +
+ +
+ + + + + \ No newline at end of file diff --git a/config/freeswitch_dev/freeswitch_gateways_edit.tmp b/config/freeswitch_dev/freeswitch_gateways_edit.tmp new file mode 100644 index 00000000..c51ad5fe --- /dev/null +++ b/config/freeswitch_dev/freeswitch_gateways_edit.tmp @@ -0,0 +1,685 @@ + 0) { + $ent['gatewayid'] = $_POST['ivrid']; + } + else { + $ent['gatewayid'] = guid(); + } + $ent['gateway'] = $_POST['gateway']; + $ent['username'] = $_POST['username']; + $ent['password'] = $_POST['password']; + $ent['realm'] = $_POST['realm']; + $ent['from-user'] = $_POST['from-user']; + $ent['from-domain'] = $_POST['from-domain']; + $ent['proxy'] = $_POST['proxy']; + $ent['expire-seconds'] = $_POST['expire-seconds']; + $ent['register'] = $_POST['register']; + $ent['register-transport'] = $_POST['register-transport']; + $ent['retry-seconds'] = $_POST['retry-seconds']; + $ent['extension'] = $_POST['extension']; + $ent['ping'] = $_POST['ping']; + $ent['caller-id-in-from'] = $_POST['caller-id-in-from']; + $ent['supress-cng'] = $_POST['supress-cng']; + + $ent['effective_caller_id_name'] = $_POST['effective_caller_id_name']; + $ent['effective_caller_id_number'] = $effective_caller_id_number; + $ent['outbound_caller_id_name'] = $_POST['outbound_caller_id_name']; + $ent['outbound_caller_id_number'] = $outbound_caller_id_number; + + $ent['context'] = $_POST['context']; + $ent['enabled'] = $_POST['enabled']; + $ent['description'] = $_POST['description']; + + if (isset($id) && $a_gateways[$id]) { + //update + $a_gateways[$id] = $ent; + } + else { + //add + $a_gateways[] = $ent; + } + + + if (strlen(trim($_POST['dialplan_expression']))> 0) { + + $gatewayid = $_POST['gatewayid']; + $gateway = $_POST['gateway']; + $context = $_POST['context']; + + $default_area_code = &$config['installedpackages']['freeswitchsettings']['config'][0]['default_area_code']; + $a_dialplan_includes = &$config['installedpackages']['freeswitchdialplanincludes']['config']; + $a_dialplan_include_details = &$config['installedpackages']['freeswitchdialplanincludedetails']['config']; + + + $tmp_array = split("\\\n", $_POST['dialplan_expression']); + + foreach($tmp_array as $dialplan_expression) { + + $dialplan_expression = trim($dialplan_expression); + if (strlen($dialplan_expression)>0) { + + switch ($dialplan_expression) { + case "^(\d{7})$": + $action_data = "sofia/gateway/".$gateway."/1".$default_area_code."\$1"; + $label = "7 digits"; + $abbrv = "7d"; + break; + case "^(\d{10})$": + $action_data = "sofia/gateway/".$gateway."/1\$1"; + $label = "10 digits"; + $abbrv = "10d"; + break; + case "^(\d{11})$": + $action_data = "sofia/gateway/".$gateway."/\$1"; + $label = "11 digits"; + $abbrv = "11d"; + break; + case "^(311)$": + $action_data = "sofia/gateway/".$gateway."/\$1"; + $label = "311"; + $abbrv = "311"; + break; + case "^(411)$": + $action_data = "sofia/gateway/".$gateway."/\$1"; + $label = "411"; + $abbrv = "411"; + break; + case "^(911)$": + $action_data = "sofia/gateway/".$gateway."/\$1"; + $label = "911"; + $abbrv = "911"; + break; + case "^9(\d{3})$": + $action_data = "sofia/gateway/".$gateway."/1".$default_area_code."\$1"; + $label = "dial 9, 3 digits"; + $abbrv = "9.3d"; + break; + case "^9(\d{4})$": + $action_data = "sofia/gateway/".$gateway."/1".$default_area_code."\$1"; + $label = "dial 9, 4 digits"; + $abbrv = "9.4d"; + break; + case "^9(\d{7})$": + $action_data = "sofia/gateway/".$gateway."/1".$default_area_code."\$1"; + $label = "dial 9, 7 digits"; + $abbrv = "9.7d"; + break; + case "^9(\d{10})$": + $action_data = "sofia/gateway/".$gateway."/\$1"; + $label = "dial 9, 10 digits"; + $abbrv = "9.10d"; + break; + case "^9(\d{11})$": + $action_data = "sofia/gateway/".$gateway."/\$1"; + $label = "dial 9, 11 digits"; + $abbrv = "9.11d"; + break; + case "^1?(8(00|55|66|77|88)[2-9]\d{6})$": + $action_data = "sofia/gateway/".$gateway."/\$1"; + $label = "toll free"; + $abbrv = "tollfree"; + break; + default: + $action_data = "sofia/gateway/".$gateway."/\$1"; + $label = $dialplan_expression; + $abbrv = $dialplan_expression; + } + + $dialplanincludeid = guid(); + $ent['dialplanincludeid'] = $dialplanincludeid; + $ent['extensionname'] = $gateway.".".$abbrv; + $ent['order'] = '9002'; //if update use the existing order number and extension name and desc + $ent['context'] = $context; + $ent['enabled'] = 'true'; + $ent['descr'] = $label.' '.$gateway; + $ent['opt1name'] = 'gatewayid'; + $ent['opt1value'] = $gatewayid; + $a_dialplan_includes[] = $ent; + unset($ent); + + $ent = array(); + $ent['dialplanincludeid'] = $dialplanincludeid; + $ent['tag'] = 'condition'; //condition, action, antiaction + $ent['fieldtype'] = 'destination_number'; + $ent['fielddata'] = $dialplan_expression; + $ent['fieldorder'] = '000'; + $a_dialplan_include_details[] = $ent; + unset($ent); + + if (strlen($effective_caller_id_name) > 0) { + $ent = array(); + $ent['dialplanincludeid'] = $dialplanincludeid; + $ent['tag'] = 'action'; //condition, action, antiaction + $ent['fieldtype'] = 'set'; + $ent['fielddata'] = 'effective_caller_id_name='.$effective_caller_id_name; + $ent['fieldorder'] = '001'; + $a_dialplan_include_details[] = $ent; + unset($ent); + } + if (strlen($effective_caller_id_number) > 0) { + $ent = array(); + $ent['dialplanincludeid'] = $dialplanincludeid; + $ent['tag'] = 'action'; //condition, action, antiaction + $ent['fieldtype'] = 'set'; + $ent['fielddata'] = 'effective_caller_id_number='.$effective_caller_id_number; + $ent['fieldorder'] = '001'; + $a_dialplan_include_details[] = $ent; + unset($ent); + } + if (strlen($outbound_caller_id_name) > 0) { + $ent = array(); + $ent['dialplanincludeid'] = $dialplanincludeid; + $ent['tag'] = 'action'; //condition, action, antiaction + $ent['fieldtype'] = 'set'; + $ent['fielddata'] = 'outbound_caller_id_name='.$outbound_caller_id_name; + $ent['fieldorder'] = '001'; + $a_dialplan_include_details[] = $ent; + unset($ent); + } + if (strlen($outbound_caller_id_number) > 0) { + $ent = array(); + $ent['dialplanincludeid'] = $dialplanincludeid; + $ent['tag'] = 'action'; //condition, action, antiaction + $ent['fieldtype'] = 'set'; + $ent['fielddata'] = 'outbound_caller_id_number='.$outbound_caller_id_number; + $ent['fieldorder'] = '001'; + $a_dialplan_include_details[] = $ent; + unset($ent); + } + + $ent = array(); + $ent['dialplanincludeid'] = $dialplanincludeid; + $ent['tag'] = 'action'; //condition, action, antiaction + $ent['fieldtype'] = 'bridge'; + $ent['fielddata'] = $action_data; + $ent['fieldorder'] = '001'; + $a_dialplan_include_details[] = $ent; + unset($ent); + + unset($label); + unset($abbrv); + unset($dialplan_expression); + unset($action_data); + } //if strlen + } //end for each + } + + write_config(); + sync_package_freeswitch_gateways(); + sync_package_freeswitch_dialplan_includes(); + + header("Location: freeswitch_gateways.php"); + exit; + } +} + +include("head.inc"); + +?> + + + + + + + +

FreeSWITCH: Gateways: Edit

+ + + +
+ + +
+ +
+ + + + +
+ + + + + + +

Gateway Setup
+
+ The 'SIP Provider Examples' from the FreeSWITCH wiki can be used as reference to get started.
+ http://wiki.freeswitch.org/wiki/SIP_Provider_Examples +

+
+ +
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Gateway + +
Enter the gateway name here.
+
Username + +
Enter the username here.
+
Password + +
Enter the password here.
+
From-user + +
Enter the from-user here.
+
From-domain + +
Enter the from-domain here.
+
Proxy + +
Enter the proxy here.
+
Realm + +
Enter the realm here.
+
Expire-seconds + +
Enter the expire-seconds here. Example: 600
+
Register + \n"; + echo " \n"; + switch (htmlspecialchars($pconfig['register'])) { + case "true": + echo " \n"; + echo " \n"; + break; + case "false": + echo " \n"; + echo " \n"; + + break; + default: + echo " \n"; + echo " \n"; + } + echo " \n"; + ?> + Choose whether to register. +
Retry-seconds + +
Enter the retry_seconds here. Example: 30
+
Effective Caller ID Name + +
Enter the effective caller ID name here.
+
Effective Caller ID Number + +
Enter the effective caller ID number here.
+
Outbound Caller ID Name + +
Enter the outbound caller ID name here.
+
Outbound Caller ID Number + +
Enter the outbound caller ID number here.
+
Context + +
Enter the context here. Example: public
+
+
+ + + + + +
Show Advanced + +
+
+ + + + + + + + + + + + + + + + + + + + + +
Enabled + \n"; + echo " \n"; + switch (htmlspecialchars($pconfig['enabled'])) { + case "true": + echo " \n"; + echo " \n"; + break; + case "false": + echo " \n"; + echo " \n"; + + break; + default: + echo " \n"; + echo " \n"; + } + echo " \n"; + ?> +
Dialplan Expression + \n"; + ?> +
+ + +
+ Shortcut to create the outbound dialplan entries for this Gateway. The entries are saved to and edited from the 'Dialplan' tab. +
Gateway Description + +
Enter the description of the gateway here.
  + + + + + +
+
+ +
+
+
+
+
+
+ +
+ +
+ + + + diff --git a/config/freeswitch_dev/freeswitch_hunt_group.tmp b/config/freeswitch_dev/freeswitch_hunt_group.tmp new file mode 100644 index 00000000..911b7d5b --- /dev/null +++ b/config/freeswitch_dev/freeswitch_hunt_group.tmp @@ -0,0 +1,176 @@ + + + + +

FreeSWITCH: Hunt Group

+ +
+ + +
+ +
+ + + + + +
+ +
+ + + + + +

Hunt Group
+
+ Hunt Group is a group of destinations to call at once or in succession. +

+
+ + + + + + + + + + 0) { + foreach ($a_hunt_group as $ent) { + if (strlen($ent['huntgroupid']) > 0) { + + $huntgroupid = str_replace(array("{", "}"), "", $ent['huntgroupid']); + + ?> + + + + + + + + + + + + + + + + +
ExtensionNameDescription + + + + + +
+
+ + +   + +   + + + + + + +
+
+ + + + + +
+
+ +
+ +
+
+/usr/local/freeswitch/scripts/ +
+
+
+
+ +
+ +
+ + + + + diff --git a/config/freeswitch_dev/freeswitch_hunt_group_destinations.tmp b/config/freeswitch_dev/freeswitch_hunt_group_destinations.tmp new file mode 100644 index 00000000..7f1adaf0 --- /dev/null +++ b/config/freeswitch_dev/freeswitch_hunt_group_destinations.tmp @@ -0,0 +1,52 @@ + \ No newline at end of file diff --git a/config/freeswitch_dev/freeswitch_hunt_group_destinations_edit.tmp b/config/freeswitch_dev/freeswitch_hunt_group_destinations_edit.tmp new file mode 100644 index 00000000..4d6d1c01 --- /dev/null +++ b/config/freeswitch_dev/freeswitch_hunt_group_destinations_edit.tmp @@ -0,0 +1,269 @@ + + + + +

FreeSWITCH: Hunt Group: Destinations: Edit

+ + +
+ + +
+ +
+ + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + +
Destination + +
+ + + extension: 1001
+ voicemail: 1001
+ sip uri (voicemail): sofia/internal/*98@${domain}
+ sip uri (external number): sofia/gateway/gatewayname/12081231234
+ sip uri (auto attendant): sofia/internal/5002@${domain}
+
+
Type + \n"; + echo " \n"; + if (htmlspecialchars($pconfig['destinationtype']) == "extension") { + echo " \n"; + } + else { + echo " \n"; + } + if (htmlspecialchars($pconfig['destinationtype']) == "voicemail") { + echo " \n"; + } + else { + echo " \n"; + } + if (htmlspecialchars($pconfig['destinationtype']) == "sip uri") { + echo " \n"; + } + else { + echo " \n"; + } + echo " \n"; + ?> +
Profile + \n"; + echo " \n"; + if (htmlspecialchars($pconfig['destinationprofile']) == "auto") { + echo " \n"; + } + else { + echo " \n"; + } + foreach (ListFiles('/usr/local/freeswitch/conf/sip_profiles') as $key=>$sip_profile_file){ + $sip_profile_name = str_replace(".xml", "", $sip_profile_file); + + if (htmlspecialchars($pconfig['destinationprofile']) == $sip_profile_name) { + echo " \n"; + } + else { + echo " \n"; + } + } + echo " \n"; + + + ?> +
Order + \n"; + //echo " \n"; + if (strlen(htmlspecialchars($pconfig['destinationorder']))> 0) { + echo " \n"; + } + $i=0; + while($i<=999) { + if (strlen($i) == 1) { + echo " \n"; + } + if (strlen($i) == 2) { + echo " \n"; + } + if (strlen($i) == 3) { + echo " \n"; + } + + $i++; + } + echo " \n"; + ?> +
+ Processing of each destination is determined by this order. + +
Description + +
You may enter a description here + for your reference (not parsed).
  + + + + + + +
+
+ +
+
+
+
+
+
+ +
+ +
+ + + + diff --git a/config/freeswitch_dev/freeswitch_hunt_group_edit.tmp b/config/freeswitch_dev/freeswitch_hunt_group_edit.tmp new file mode 100644 index 00000000..29915f67 --- /dev/null +++ b/config/freeswitch_dev/freeswitch_hunt_group_edit.tmp @@ -0,0 +1,471 @@ + 0) { + $huntgroupent['huntgroupid'] = $_POST['huntgroupid']; + } + else { + $huntgroupent['huntgroupid'] = guid(); + } + $huntgroupent['huntgroupextension'] = $_POST['huntgroupextension']; + $huntgroupent['huntgroupname'] = $_POST['huntgroupname']; + $huntgroupent['huntgrouptype'] = $_POST['huntgrouptype']; + $huntgroupent['huntgroupcontext'] = $_POST['huntgroupcontext']; + $huntgroupent['huntgrouptimeout'] = $_POST['huntgrouptimeout']; + $huntgroupent['huntgrouptimeoutdestination'] = $_POST['huntgrouptimeoutdestination']; + $huntgroupent['huntgrouptimeouttype'] = $_POST['huntgrouptimeouttype']; + $huntgroupent['huntgroupringback'] = $_POST['huntgroupringback']; + $huntgroupent['huntgroupcidnameprefix'] = $_POST['huntgroupcidnameprefix']; + $huntgroupent['huntgroupdescr'] = $_POST['huntgroupdescr']; + + if (isset($id) && $a_hunt_group[$id]) { + //update + $a_hunt_group[$id] = $huntgroupent; + } + else { + //add + $a_hunt_group[] = $huntgroupent; + } + + //touch($d_hostsdirty_path); + write_config(); + sync_package_freeswitch_hunt_group(); + + header("Location: freeswitch_hunt_group.php"); + exit; + } +} + +include("head.inc"); + +?> + + + +

FreeSWITCH: Hunt Group: Edit

+ + + +
+ + +
+ +
+ + + + + + + + + + +
+ + + + + +

General Settings:
+
+ Hunt Group general settings. +

+
+ +
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Extension + +
e.g. 7002
Hunt Group Name + +
Type + \n"; + echo " \n"; + if (htmlspecialchars($pconfig['huntgrouptype']) == "simultaneous") { + echo " \n"; + } + else { + echo " \n"; + } + if (htmlspecialchars($pconfig['huntgrouptype']) == "sequentially") { + echo " \n"; + } + else { + echo " \n"; + } + echo " \n"; + ?> +
Context + +
e.g. default
Timeout + +
+ + The timeout sets the time in seconds to continue to call before timing out. + +
Timeout Type + \n"; + echo " \n"; + if (htmlspecialchars($pconfig['huntgrouptimeouttype']) == "extension") { + echo " \n"; + } + else { + echo " \n"; + } + if (htmlspecialchars($pconfig['huntgrouptimeouttype']) == "voicemail") { + echo " \n"; + } + else { + echo " \n"; + } + if (htmlspecialchars($pconfig['huntgrouptimeouttype']) == "sip uri") { + echo " \n"; + } + else { + echo " \n"; + } + echo " \n"; + ?> +
Timeout Destination + +
Destination
+ e.g. 1001
Ring Back + \n"; + echo " \n"; + if (htmlspecialchars($pconfig['huntgroupringback']) == "ring") { + echo " \n"; + } + else { + echo " \n"; + } + if (htmlspecialchars($pconfig['huntgroupringback']) == "music") { + echo " \n"; + } + else { + echo " \n"; + } + echo " \n"; + ?> +
+ + Defines what the caller will hear while destination is being called. The choices are music + (music on hold) ring (ring tone.) default: music + +
CID Prefix + +
+ + Set a prefix on the caller ID name. (optional) + +
Description + +
+ + You may enter a description here for your reference (not parsed). + +
  + + + + + +
+
+ +
+
+ +
+ "; + //print_r ($a_hunt_group); + //echo ""; + + //if ($savemsg) print_info_box($savemsg); + //if (file_exists($d_hostsdirty_path)): echo"

"; + //print_info_box_np("The FreeSWITCH recordings have been changed.
You must apply the changes in order for them to take effect."); + //echo"
"; + //endif; + + ?> + + + + + +

Destinations
+
+ The following destinations will be called. +

+
+ + + + + + + + + + + + 0) { + foreach ($a_hunt_group_destinations as $ent) { + $a_hunt_group_destinations[$i]['id'] = $i; + $i++; + } + } + + //order the array + function cmp_number($a, $b) { + if ($a["destinationorder"] > $b["destinationorder"]) { + return 1; + } + else { + return 0; + } + } + if (count($a_hunt_group_destinations) > 0) { usort($a_hunt_group_destinations, "cmp_number"); } + + $i = 0; + if (count($a_hunt_group_destinations) > 0) { + foreach ($a_hunt_group_destinations as $ent) { + if ($huntgroupid == $ent['huntgroupid']) { + ?> + + + + + + + + + + + + + + + + + + + +
DestinationTypeProfileOrderDescription + + + + + + +
+ 1) { ?> +
+
+ + +   + +   + +   + +   + + 1) { + echo "\n"; + echo " \n"; + echo " \n"; + echo " \n"; + echo " \n"; + echo "
\n"; + } + ?> +
+ + + + + +
+ 1) { ?> + + +
+
+ +

+ + + + +
+ + + +
+
+ + + + + +
+ + + + diff --git a/config/freeswitch_dev/freeswitch_ivr.tmp b/config/freeswitch_dev/freeswitch_ivr.tmp new file mode 100644 index 00000000..c1e53dff --- /dev/null +++ b/config/freeswitch_dev/freeswitch_ivr.tmp @@ -0,0 +1,177 @@ + + + + +

FreeSWITCH: IVR

+ +
+ + +
+ +
+ + + + + +
+ +
+ + + + + +

IVR
+
+ An interactive voice response (IVR) often refered to as an Auto Attendant. + It associates a recording to multiple options that can be used to direct calls + to extensions, voicemail, queues, other IVR applications, and external + phone numbers. +

+
+ + + + + + + + + + 0) { + foreach ($a_ivr as $ent) { + if (strlen($ent['ivrid']) > 0) { + + $ivrid = str_replace(array("{", "}"), "", $ent['ivrid']); + + ?> + + + + + + + + + + + + + + + + +
ExtensionNameDescription + + + + + +
+
+ + +   + +   + + + + + + +
+
+ + + + + +
+
+ +
+ +
+
+/usr/local/freeswitch/scripts/ +
+
+
+
+ +
+ +
+ + + + + diff --git a/config/freeswitch_dev/freeswitch_ivr_edit.tmp b/config/freeswitch_dev/freeswitch_ivr_edit.tmp new file mode 100644 index 00000000..6b64994e --- /dev/null +++ b/config/freeswitch_dev/freeswitch_ivr_edit.tmp @@ -0,0 +1,697 @@ + 1 && Day < 7) {\n"; + $ivrconditionjs .= " return true;\n"; + $ivrconditionjs .= " }\n"; + $ivrconditionjs .= " else {\n"; + $ivrconditionjs .= " return false;\n"; + $ivrconditionjs .= " }\n"; + $ivrconditionjs .= "}\n"; + $ivrconditionjs .= "\n"; + $ivrconditionjs .= "function isweekend( Day ) {\n"; + $ivrconditionjs .= " if (Day > 1 && Day < 7) {\n"; + $ivrconditionjs .= " return false;\n"; + $ivrconditionjs .= " }\n"; + $ivrconditionjs .= " else {\n"; + $ivrconditionjs .= " return true;\n"; + $ivrconditionjs .= " }\n"; + $ivrconditionjs .= "}\n"; + $ivrconditionjs .= "\n"; + $ivrconditionjs .= "function isofficehours( Hours ) {\n"; + $ivrconditionjs .= " if (Hours >= 9 && Hours < 17) {\n"; + $ivrconditionjs .= " return true;\n"; + $ivrconditionjs .= " }\n"; + $ivrconditionjs .= " else {\n"; + $ivrconditionjs .= " return false;\n"; + $ivrconditionjs .= " }\n"; + $ivrconditionjs .= "}\n"; + $ivrconditionjs .= "\n"; + $ivrconditionjs .= "function isafterhours( Hours ) {\n"; + $ivrconditionjs .= " if (Hours >= 9 && Hours < 17) {\n"; + $ivrconditionjs .= " return false;\n"; + $ivrconditionjs .= " }\n"; + $ivrconditionjs .= " else {\n"; + $ivrconditionjs .= " return true;\n"; + $ivrconditionjs .= " }\n"; + $ivrconditionjs .= "}\n"; + $ivrconditionjs .= "\n"; + $ivrconditionjs .= "//set default\n"; + $ivrconditionjs .= "condition = true;\n"; + $ivrconditionjs .= "\n"; + $ivrconditionjs .= "//Holiday?\n"; + $ivrconditionjs .= "if (isholiday( Month, Date )) {\n"; + $ivrconditionjs .= " console_log( \"info\", \"holiday\\n\" );\n"; + $ivrconditionjs .= " condition = false;\n"; + $ivrconditionjs .= "}\n"; + $ivrconditionjs .= "\n"; + $ivrconditionjs .= "//Weekend?\n"; + $ivrconditionjs .= "if (isweekend( Day )) {\n"; + $ivrconditionjs .= " console_log( \"info\", \"weekend\\n\" );\n"; + $ivrconditionjs .= " condition = false;\n"; + $ivrconditionjs .= "}\n"; + $ivrconditionjs .= "\n"; + $ivrconditionjs .= "// After Hours?\n"; + $ivrconditionjs .= "if (isafterhours( Hours )) {\n"; + $ivrconditionjs .= " console_log( \"info\", \"after hours\\n\" );\n"; + $ivrconditionjs .= " condition = false;\n"; + $ivrconditionjs .= "}\n"; + $ivrconditionjs .= "\n"; + + +if (isset($id) && $a_ivr[$id]) { + $pconfig['ivrid'] = $a_ivr[$id]['ivrid']; + $ivrid = $a_ivr[$id]['ivrid']; + $pconfig['ivrextension'] = $a_ivr[$id]['ivrextension']; + $pconfig['ivrname'] = $a_ivr[$id]['ivrname']; + $pconfig['recordingidaction'] = $a_ivr[$id]['recordingidaction']; + $pconfig['recordingidantiaction'] = $a_ivr[$id]['recordingidantiaction']; + $pconfig['ivrtimeout'] = $a_ivr[$id]['ivrtimeout']; + $pconfig['ivrcalltimeout'] = $a_ivr[$id]['ivrcalltimeout']; + $pconfig['ivrcontext'] = $a_ivr[$id]['ivrcontext']; + $pconfig['ivrdirectdial'] = $a_ivr[$id]['ivrdirectdial']; + $pconfig['ivrringback'] = $a_ivr[$id]['ivrringback']; + $pconfig['ivrcidnameprefix'] = $a_ivr[$id]['ivrcidnameprefix']; + $pconfig['ivrconditionjs'] = ($a_ivr[$id]['ivrconditionjs']); + $pconfig['ivrdescr'] = $a_ivr[$id]['ivrdescr']; +} + +if ($_POST) { + + unset($input_errors); + $pconfig = $_POST; + + + if ($_GET['act'] == "del") { + if ($_GET['type'] == 'options') { + if ($a_ivroptions[$_GET['optionid']]) { + unset($a_ivr_options[$_GET['optionid']]); + write_config(); + sync_package_freeswitch_ivr(); + header("Location: freeswitch_ivr_edit.php?id=".$_GET['id']); + exit; + } + } + } + + + if (!$input_errors) { + + $ivrent = array(); + if (strlen($_POST['ivrid']) > 0) { + $ivrent['ivrid'] = $_POST['ivrid']; + } + else { + $ivrent['ivrid'] = guid(); + } + $ivrent['ivrextension'] = $_POST['ivrextension']; + $ivrent['ivrname'] = $_POST['ivrname']; + $ivrent['recordingidaction'] = $_POST['recordingidaction']; + $ivrent['recordingidantiaction'] = $_POST['recordingidantiaction']; + $ivrent['ivrtimeout'] = $_POST['ivrtimeout']; + $ivrent['ivrcalltimeout'] = $_POST['ivrcalltimeout']; + $ivrent['ivrcontext'] = $_POST['ivrcontext']; + $ivrent['ivrdirectdial'] = $_POST['ivrdirectdial']; + $ivrent['ivrringback'] = $_POST['ivrringback']; + $ivrent['ivrcidnameprefix'] = $_POST['ivrcidnameprefix']; + $ivrent['ivrconditionjs'] = base64_encode($_POST['ivrconditionjs']); + $ivrent['ivrdescr'] = $_POST['ivrdescr']; + + if (isset($id) && $a_ivr[$id]) { + //update + $a_ivr[$id] = $ivrent; + } + else { + //add + $a_ivr[] = $ivrent; + } + + //touch($d_hostsdirty_path); + write_config(); + sync_package_freeswitch_ivr(); + + header("Location: freeswitch_ivr.php"); + exit; + } +} + +include("head.inc"); + +?> + + + + + + +

FreeSWITCH: IVR: Edit

+ + + +
+ + +
+ +
+ + + + +
+ + + + + +

General Settings:
+
+ Interactive voice response general settings. +

+
+ +
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Extension + +
e.g. 5002
IVR Name + +
Recording Action + \n"; + echo " \n"; + if (count($a_recordings) > 0) { + foreach ($a_recordings as $ent) { + if (htmlspecialchars($pconfig['recordingidaction']) == $ent['recordingid']) { + echo " \n"; + } + else { + echo " \n"; + } + } + } + echo " \n"; + ?> +
Recording Anti-Action + \n"; + echo " \n"; + if (count($a_recordings) > 0) { + foreach ($a_recordings as $ent) { + if (htmlspecialchars($pconfig['recordingidantiaction']) == $ent['recordingid']) { + echo " \n"; + } + else { + echo " \n"; + } + } + } + echo " \n"; + ?> +
IVR Timeout + +
+ After the recording concludes the + timeout sets the time in seconds to continue to wait for DTMF. + If the DTMF is
not detected during that time the 't' + timeout option is executed. +
+
Call Timeout + +
+ + Call timeout is the time in seconds to ring the destination. After this time is exceeded calls + to extensions will be sent to voicemail. default: 30 seconds + +
Context + +
e.g. default
Direct Dial + \n"; + echo " \n"; + if (strlen($pconfig['ivrdirectdial']) == 0) { //set default + echo " \n"; + echo " \n"; + } + else { + if (htmlspecialchars($pconfig['ivrdirectdial']) == "true") { + echo " \n"; + } + else { + echo " \n"; + } + if (htmlspecialchars($pconfig['ivrdirectdial']) == "false") { + echo " \n"; + } + else { + echo " \n"; + } + } + + echo " \n"; + ?> +
Allows callers to dial directly to extensions and feature codes that are up to 5 digits in length. +
Ring Back + \n"; + echo " \n"; + if (htmlspecialchars($pconfig['ivrringback']) == "ring") { + echo " \n"; + } + else { + echo " \n"; + } + if (htmlspecialchars($pconfig['ivrringback']) == "music") { + echo " \n"; + } + else { + echo " \n"; + } + echo " \n"; + ?> +
+ + Defines what the caller will hear while destination is being called. The choices are music + (music on hold) ring (ring tone.) default: music + +
CID Prefix + +
Set a prefix on the caller ID name. (optional)
Description + +
+ + You may enter a description here for your reference (not parsed). + +
Javascript Condition + ".$ivrconditionjs."\n"; + } + else { + echo "\n"; + } + ?> +
A simple valid condition is: + condition=true; To re-populate the default simply empty the + textarea and click on save. The following javascript variables + have been defined: Hours, Mins, Seconds, Month, Date, Year, + and Day.
  + + + + + +
+
+ +
+
+ +
+ "; + //print_r ($a_ivr); + //echo ""; + + //if ($savemsg) print_info_box($savemsg); + //if (file_exists($d_hostsdirty_path)): echo"

"; + //print_info_box_np("The FreeSWITCH recordings have been changed.
You must apply the changes in order for them to take effect."); + //echo"
"; + //endif; + + ?> + + + + + +


+
+ Options are the choices that are available to the caller when they + are calling the auto attendant. If the caller presses 2 then the call + is directed to the corresponding destination. +

+ + + + + + +

Action
+
+ The options that are executed when the condition matches. +

+
+ + + + + + + + + + + + 0) { + foreach ($a_ivr_options as $ent) { + if ($ent['optionaction'] == "action" && $ivrid == $ent['ivrid']) { + ?> + + + + + + + + + + + + + + + + + + + +
OptionTypeProfileDestinationDescription + + + + + +
+ 1) { ?> + + +
+
+ + +   + +   + +   + +   + + + + + + +
+
+ + + + + +
+ 1) { ?> + + +
+
+ +

+ + + +
+ "; + //print_r ($a_ivr); + //echo ""; + + //if ($savemsg) print_info_box($savemsg); + //if (file_exists($d_hostsdirty_path)): echo"

"; + //print_info_box_np("The FreeSWITCH recordings have been changed.
You must apply the changes in order for them to take effect."); + //echo"
"; + //endif; + + ?> + + + + +

Anti-Action
+
+ The options that are executed when the condition does NOT match. +

+
+ + + + + + + + + + + + 0) { + foreach ($a_ivr_options as $ent) { + if ($ent['optionaction'] == "anti-action" && $ivrid == $ent['ivrid']) { + ?> + + + + + + + + + + + + + + + + + + + +
OptionTypeProfileDestinationDescription + + + + + +
+ 1) { ?> + + +
+
+ + +   + +   + +   + +   + + + + + + +
+
+ + + + + +
+ 1) { ?> + + +
+
+ +

+ +
+
+ +
+ +
+ + + + diff --git a/config/freeswitch_dev/freeswitch_ivr_options.tmp b/config/freeswitch_dev/freeswitch_ivr_options.tmp new file mode 100755 index 00000000..096e5b6e --- /dev/null +++ b/config/freeswitch_dev/freeswitch_ivr_options.tmp @@ -0,0 +1,52 @@ + \ No newline at end of file diff --git a/config/freeswitch_dev/freeswitch_ivr_options_edit.tmp b/config/freeswitch_dev/freeswitch_ivr_options_edit.tmp new file mode 100644 index 00000000..894064e3 --- /dev/null +++ b/config/freeswitch_dev/freeswitch_ivr_options_edit.tmp @@ -0,0 +1,248 @@ + + + + +

FreeSWITCH: IVR: Options: Edit

+ + +
+ + +
+ +
+ + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + +
Option Number + +
Option Number
+ e.g. 1
Type + \n"; + echo " \n"; + if (htmlspecialchars($pconfig['optiontype']) == "extension") { + echo " \n"; + } + else { + echo " \n"; + } + if (htmlspecialchars($pconfig['optiontype']) == "voicemail") { + echo " \n"; + } + else { + echo " \n"; + } + if (htmlspecialchars($pconfig['optiontype']) == "sip uri") { + echo " \n"; + } + else { + echo " \n"; + } + echo " \n"; + ?> +
Profile + \n"; + echo " \n"; + if (htmlspecialchars($pconfig['optionprofile']) == "auto") { + echo " \n"; + } + else { + echo " \n"; + } + foreach (ListFiles('/usr/local/freeswitch/conf/sip_profiles') as $key=>$sip_profile_file){ + $sip_profile_name = str_replace(".xml", "", $sip_profile_file); + + if (htmlspecialchars($pconfig['optionprofile']) == $sip_profile_name) { + echo " \n"; + } + else { + echo " \n"; + } + } + echo " \n"; + + ?> +
Destination + +
+ + + extension: 1001
+ voicemail: 1001
+ sip uri (voicemail): sofia/internal/*98@${domain}
+ sip uri (external number): sofia/gateway/gatewayname/12081231234
+ sip uri (auto attendant): sofia/internal/5002@${domain}
+
+
Description + +
You may enter a description here + for your reference (not parsed).
  + + + + + + + +
+
+ +
+
+
+
+
+
+ +
+ +
+ + + + diff --git a/config/freeswitch_dev/freeswitch_mailto.tmp b/config/freeswitch_dev/freeswitch_mailto.tmp new file mode 100644 index 00000000..fa27ff68 --- /dev/null +++ b/config/freeswitch_dev/freeswitch_mailto.tmp @@ -0,0 +1,243 @@ +", "", $var['To']); + + echo "To: ".$var['To']."\n"; + echo "From: ".$var['From']."\n"; + echo "Subject: ".$var['Subject']."\n"; + //print_r($var); + echo "\n\n"; + + +// split mime type multi-part into each part + $maincontent = str_replace($boundary."--", $boundary, $maincontent); + $tmparray = split("--".$boundary, $maincontent); + +// loop through each mime part + $i=0; + foreach ($tmparray as $mimepart) { + + $mimearray = split("\n\n", $mimepart); + $subheader = $mimearray[0]; + $headermimearray = split("\n", trim($subheader)); + + $x=0; + foreach ($headermimearray as $val) { + if(stristr($val, ':') === FALSE) { + $tmparray = split('=', $val); //':' not found + if (trim($tmparray[0]) == "boundary") { + $subboundary = $tmparray[1]; + $subboundary = trim($subboundary,'"'); + //echo "subboundary: ".$subboundary."\n"; + } + } + else { + $tmparray = split(':', $val); //':' found + } + + //print_r($tmparray); + $var[trim($tmparray[0])] = trim($tmparray[1]); + } + //print_r($var); + + + $contenttypearray = split(' ', $headermimearray[0]); + + if ($contenttypearray[0] == "Content-Type:") { + $contenttype = trim($contenttypearray[1]); + + switch ($contenttype) { + case "multipart/alternative;": + + //echo "type: ".$contenttype."\n"; + $content = trim(substr($mimepart, strlen($subheader), strlen($mimepart))); + + $content = str_replace($subboundary."--", $subboundary, $content); + $tmpsubarray = split("--".$subboundary, $content); + foreach ($tmpsubarray as $mimesubsubpart) { + + $mimesubsubarray = split("\n\n", $mimesubsubpart); + $subsubheader = $mimesubsubarray[0]; + + $headersubsubmimeearray = split("\n", trim($subsubheader)); + $subsubcontenttypearray = split(' ', $headersubsubmimeearray[0]); + //echo "subsubcontenttypearray[0] ".$subsubcontenttypearray[0]."\n"; + + if ($subsubcontenttypearray[0] == "Content-Type:") { + $subsubcontenttype = trim($subsubcontenttypearray[1]); + switch ($subsubcontenttype) { + case "text/plain;": + $textplain = trim(substr($mimesubsubpart, strlen($subsubheader), strlen($mimesubsubpart))); + //echo "text/plain: $textplain\n"; + break; + case "text/html;": + $texthtml = trim(substr($mimesubsubpart, strlen($subsubheader), strlen($mimesubsubpart))); + //echo "text/html: $texthtml\n"; + break; + } + } //end if + + + } //end foreach + + break; + case "audio/wav;": + //echo "type: ".$contenttype."\n"; + $strwav = trim(substr($mimepart, strlen($subheader), strlen($mimepart))); + //echo "\n*** begin wav ***\n".$strwav."\n*** end wav ***\n"; + break; + + }//end switch + } //end if + + $i++; + + } //end foreach + + +//send the email + + include "/usr/local/www/packages/freeswitch/class.phpmailer.php"; + include "/usr/local/www/packages/freeswitch/class.smtp.php"; // optional, gets called from within class.phpmailer.php if not already loaded + + $mail = new PHPMailer(); + + $mail->IsSMTP(); // set mailer to use SMTP + if ($tmp_smtpauth == "true") { + $mail->SMTPAuth = $tmp_smtpauth; // turn on/off SMTP authentication + } + $mail->Host = $tmp_smtphost; + if (strlen($tmp_smtpsecure)>0) { + $mail->SMTPSecure = $tmp_smtpsecure; + } + if ($tmp_smtpusername) { + $mail->Username = $tmp_smtpusername; + $mail->Password = $tmp_smtppassword; + } + $mail->SMTPDebug = 2; + + + $mail->From = $tmp_smtpfrom; + $mail->FromName = $tmp_smtpfromname; + $mail->Subject = $var['Subject']; + $mail->AltBody = $textplain; // optional, comment out and test + $mail->MsgHTML($texthtml); + + + $tmp_to = $var['To']; + $tmp_to = str_replace(";", ",", $tmp_to); + $tmp_to_array = split(",", $tmp_to); + foreach($tmp_to_array as $tmp_to_row) { + if (strlen($tmp_to_row) > 0) { + $mail->AddAddress($tmp_to_row); + } + } + + if (strlen($strwav) > 0) { + //$mail->AddAttachment("/usr/local/freeswitch/data/domain/example.wav"); // attachment + $filename='voicemail.wav'; $encoding = "base64"; $type = "audio/wav"; + $mail->AddStringAttachment(base64_decode($strwav),$filename,$encoding,$type); + } + unset($strwav); + + if(!$mail->Send()) { + echo "Mailer Error: " . $mail->ErrorInfo; + } + else { + echo "Message sent!"; + } + + +$content = ob_get_contents(); //get the output from the buffer +ob_end_clean(); //clean the buffer + +fwrite($fp, $content); +fclose($fp); + +?> \ No newline at end of file diff --git a/config/freeswitch_dev/freeswitch_modules.xml b/config/freeswitch_dev/freeswitch_modules.xml new file mode 100644 index 00000000..8c211820 --- /dev/null +++ b/config/freeswitch_dev/freeswitch_modules.xml @@ -0,0 +1,1203 @@ + + + + + . + All rights reserved. + */ +/* ========================================================================== */ +/* + Redistribution and use in source and binary forms, with or without + modification, are permitted provided that the following conditions are met: + + 1. Redistributions of source code must retain the above copyright notice, + this list of conditions and the following disclaimer. + + 2. Redistributions in binary form must reproduce the above copyright + notice, this list of conditions and the following disclaimer in the + documentation and/or other materials provided with the distribution. + + THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, + INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY + AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE + AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, + OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF + SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS + INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN + CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) + ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE + POSSIBILITY OF SUCH DAMAGE. + */ +/* ========================================================================== */ + ]]> + + FreeSWITCH is an open source telephony platform designed to facilitate the creation of voice and chat driven products scaling from a soft-phone up to a soft-switch. It can be used as a simple switching engine, a PBX, a media gateway or a media server to host IVR applications using simple scripts or XML to control the callflow. + Describe your package requirements here + Currently there are no FAQ items provided. + FreeSWITCH Modules + 0.2 + FreeSWITCH: Modules + /usr/local/pkg/freeswitch.inc + + FreeSWITCH + Modify FreeSWITCH Modules. +
Services
+ freeswitch.xml + /pkg_edit.php?xml=freeswitch.xml&id=0 +
+ + freeswitch + freeswitch.sh + freeswitch + FreeSWITCH is an open source telephony platform designed to facilitate the creation of voice and chat driven products scaling from a soft-phone up to a soft-switch. It can be used as a simple switching engine, a PBX, a media gateway or a media server to host IVR applications using simple scripts or XML to control the callflow. + + + + Settings + /pkg_edit.php?xml=freeswitch.xml&id=0 + + + Dialplan + /packages/freeswitch/freeswitch_dialplan_includes.php + + + Extensions + /packages/freeswitch/freeswitch_extensions.php + + + Features + /packages/freeswitch/freeswitch_features.php + + + Gateways + /packages/freeswitch/freeswitch_gateways.php + + + Profiles + /packages/freeswitch/freeswitch_profiles.php + + + Public + /packages/freeswitch/freeswitch_public_includes.php + + + Status + /packages/freeswitch/freeswitch_status.php + + + Vars + /packages/freeswitch/freeswitch_vars.php + + + installedpackages->package->$packagename->configuration->freeswitchmodules + + + <b>Loggers</b> + loggers + + listtopic + + + mod_console + mod_console + Send logs to the console. + select + + + + + + + mod_logfile + mod_logfile + Send logs to the local file system. + select + + + + + + + mod_syslog + mod_syslog + Send logs to a remote syslog server. + select + + + + + + + <b>Multi-Faceted</b> + multi-faceted + + listtopic + + + mod_enum + mod_enum + Route PSTN numbers over internet according to ENUM servers, such as e164.org. + select + + + + + + + <b>XML Interfaces</b> + xml_interfaces + + listtopic + + + mod_xml_rpc + mod_xml_rpc + XML Remote Procedure Calls. Issue commands from your web application. + select + + + + + + + mod_xml_curl + mod_xml_curl + XML Gateway Code. Configure FreeSWITCH from a web server on boot and on the fly. + select + + + + + + + mod_xml_cdr + mod_xml_cdr + XML based call detail record handler. + select + + + + + + + <b>Event Handlers</b> + event_handlers + + listtopic + + + mod_cdr_csv + mod_cdr_csv + CSV call detail record handler. + select + + + + + + + mod_event_multicast + mod_event_multicast + Broadcasts events to netmask. + select + + + + + + + mod_event_socket + mod_event_socket + Sends events via a single socket. + select + + + + + + + mod_zeroconf + mod_zeroconf + Support for zeroconf. + select + + + + + + + <b>Directory Interfaces</b> + directory_interfaces + + listtopic + + + mod_ldap + mod_ldap + LDAP module made to obtain dialplans, user accounts, etc. + select + + + + + + + <b>Endpoints</b> + endpoints + + listtopic + + + mod_dingaling + mod_dingaling + Jabber/GoogleTalk Talk integration module. + select + + + + + + + mod_iax + mod_iax + IAX2. + select + + + + + + + mod_portaudio + mod_portaudio + Voice through a local soundcard. + select + + + + + + + mod_alsa + mod_alsa + + select + + + + + + + mod_sofia + mod_sofia + SIP module. + select + + + + + + + mod_loopback + mod_loopback + A loopback channel driver to make an outbound call as an inbound call. + select + + + + + + + mod_wanpipe + mod_wanpipe + T1/E1 Sangoma Card module. + select + + + + + + + mod_woomera + mod_woomera + H.323/Woomera module. + select + + + + + + + mod_openzap + mod_openzap + Interface to Zaptel hardware. + select + + + + + + + <b>Applications</b> + applications + + listtopic + + + mod_commands + mod_commands + A mass plethora of API interface commands. + select + + + + + + + mod_conference + mod_conference + Conference room module. + select + + + + + + + mod_dptools + mod_dptools + Dialplan Tools: provides a number of apps and utilities for the dialplan. + select + + + + + + + mod_expr + mod_expr + Brian Allen Vanderburgs expression evaluation library. + select + + + + + + + mod_fax + mod_fax + FAX provides fax send and receive. + select + + + + + + + mod_fifo + mod_fifo + FIFO provides custom call queues including call park. + select + + + + + + + mod_voicemail + mod_voicemail + Full featured voicemail module. + select + + + + + + + mod_limit + mod_limit + Resource limitation module. + select + + + + + + + mod_esf + mod_esf + Holds the multi cast paging application for SIP. + select + + + + + + + mod_fsv + mod_fsv + FreeSWITCH Video application (Recording and playback). + select + + + + + + + <b>SNOM Module</b> + snom_module + + listtopic + + + mod_snom + mod_snom + + select + + + + + + + <b>Dialplan Interfaces</b> + dialplan_interfaces + + listtopic + + + mod_dialplan_directory + mod_dialplan_directory + Allows you to obtain a dialplan from a directory resource. + select + + + + + + + mod_dialplan_xml + mod_dialplan_xml + Allows you to program dialplans in XML format. + select + + + + + + + mod_dialplan_asterisk + mod_dialplan_asterisk + Allows you to create dialplans the old-fashioned way. + select + + + + + + + mod_yaml + mod_yaml + Allows you to program dialplans in YAML format. + select + + + + + + + <b>Codec Interfaces</b> + codec_interfaces + + listtopic + + + mod_voipcodecs + mod_voipcodecs + + select + + + + + + + mod_g723_1 + mod_g723_1 + G.723.1 codec. + select + + + + + + + mod_g729 + mod_g729 + G729 codec is only supported in passthrough mode. + select + + + + + + + mod_amr + mod_amr + amr codec. + select + + + + + + + mod_ilbc + mod_ilbc + ILBC codec. + select + + + + + + + mod_speex + mod_speex + Speex codec. + select + + + + + + + mod_siren + mod_siren + Siren codec. + select + + + + + + + mod_celt + mod_celt + Celt codec. + select + + + + + + + mod_h26x + mod_h26x + H26X signed linear codec. Video Pass-thru. + select + + + + + + + <b>File Format Interfaces</b> + file_format_interfaces + + listtopic + + + mod_sndfile + mod_sndfile + Multi-format file format transcoder (WAV, etc). + select + + + + + + + mod_native_file + mod_native_file + File interface for codec specific file formats. + select + + + + + + + <b>Streams/Files</b> + streams_files + + listtopic + + + mod_shout + mod_shout + mp3 files and shoutcast streams. + select + + + + + + + mod_local_stream + mod_local_stream + For local streams (play all the files in a directory). + select + + + + + + + mod_tone_stream + mod_tone_stream + Generate tone streams. + select + + + + + + + <b>Languages</b> + languages + + listtopic + + + mod_spidermonkey + mod_spidermonkey + JavaScript support. + select + + + + + + + mod_perl + mod_perl + Perl support. + select + + + + + + + mod_python + mod_python + Python support. + select + + + + + + + mod_java + mod_java + Java support. + select + + + + + + + mod_lua + mod_lua + Lua support. + select + + + + + + + <b>ASR /TTS</b> + asr_tts + + listtopic + + + mod_flite + mod_flite + Free open source Text to Speech. + select + + + + + + + mod_pocketsphinx + mod_pocketsphinx + Free open source Speech Recognition. + select + + + + + + + mod_cepstral + mod_cepstral + Links into Cepstral for dynamic sound output. Not available on this build. + select + + + + + + + mod_openmrcp + mod_openmrcp + Module for an open MRCP implementation. + select + + + + + + + mod_rss + mod_rss + Reads RSS feeds via a TTS engine. + select + + + + + + + <b>Say</b> + say + + listtopic + + + mod_say_en + mod_say_en + + select + + + + + + + mod_say_zh + mod_say_zh + + select + + + + + + + + + + sync_package_freeswitch_modules(); + + + sync_package_freeswitch_modules(); + + + +
\ No newline at end of file diff --git a/config/freeswitch_dev/freeswitch_profile_edit.tmp b/config/freeswitch_dev/freeswitch_profile_edit.tmp new file mode 100644 index 00000000..2466f115 --- /dev/null +++ b/config/freeswitch_dev/freeswitch_profile_edit.tmp @@ -0,0 +1,143 @@ + + + + + + + + + + +

FreeSWITCH: Edit Profile

+ +
+ + +
+ +
+ + + + + + +
+ +
+ + + + + + +

Edit Profile
+
+ Use this to configure your SIP profiles. +

+
Filename:
+
+
+ + +
+
+ + + + + + +
/usr/local/freeswitch/conf/sip_profiles/ + + "; + ?> +
+ +
+ +
+
+ +
+
+
+
+
+
+
+
+ +
+ +
+ + + + + + diff --git a/config/freeswitch_dev/freeswitch_profiles.tmp b/config/freeswitch_dev/freeswitch_profiles.tmp new file mode 100644 index 00000000..188619f4 --- /dev/null +++ b/config/freeswitch_dev/freeswitch_profiles.tmp @@ -0,0 +1,214 @@ + + + + + +

FreeSWITCH: Profiles

+ +
+ + +
+ +
+ + + + + + +
+ +
+ + + + +

Profiles
+
+ Use this to configure your SIP profiles. +

+
+ + + + + + + + + + + $file){ + ?> + + + + + + + + + + + + + + + + + +
NameDescription +
+   + + "; + echo "The Internal profile by default requires registration which is most often used for extensions. "; + echo "By default the Internal profile binds to the WAN IP which is accessible to the internal network. "; + echo "A rule can be set from PFSense -> Firewall -> Rules -> WAN to the the WAN IP for port 5060 which "; + echo "enables phones register from outside the network."; + echo ""; + echo ""; + echo " "; + break; + case "internal-ipv6.xml": + echo "The Internal IPV6 profile binds to the IP version 6 address and is similar to the Internal profile. "; + break; + case "external.xml": + echo ""; + echo "The External profile handles outbound registrations to a SIP provider or other SIP Server. The SIP provider sends calls to you, and you "; + echo "send calls to your provider, through the external profile. The external profile allows anonymous calling, which is "; + echo "required as your provider will never authenticate with you to send you a call. Calls can be sent using a SIP URL \"my.domain.com:5080\" "; + echo " "; + break; + case "lan.xml": + echo "The LAN profile is the same as the Internal profile except that it is bound to the LAN IP. "; + break; + default: + echo "default "; + } + ?> + + + + + + +
+
+ + + + + +
+
+ +
+ +
+
+/usr/local/freeswitch/conf/sip_profiles +
+
+
+
+
+
+
+
+ +
+ +
+ + + + + + diff --git a/config/freeswitch_dev/freeswitch_public.tmp b/config/freeswitch_dev/freeswitch_public.tmp new file mode 100644 index 00000000..0c05fe47 --- /dev/null +++ b/config/freeswitch_dev/freeswitch_public.tmp @@ -0,0 +1,162 @@ + + + + + + + + + + +

FreeSWITCH: Public

+ +
+ + +
+ +
+ + + + + + +
+ +
+ + + + + + +

Public
+
+ Directs inbound calls to extensions, IVRs, external numbers, and scripts. +

+
+
+
+ + +
+
+ + + + + + +
/usr/local/freeswitch/conf/dialplan/public.xml + + + "; + ?> +
+ +
+ +
+
+ +
+
+
+
+
+
+
+
+ +
+ +
+ + + + + + diff --git a/config/freeswitch_dev/freeswitch_public_includes.tmp b/config/freeswitch_dev/freeswitch_public_includes.tmp new file mode 100644 index 00000000..51a535d4 --- /dev/null +++ b/config/freeswitch_dev/freeswitch_public_includes.tmp @@ -0,0 +1,282 @@ + 0) { + $i=0; + if (count($a_public_includes_details) > 0) { + foreach($a_public_includes_details as $row) { + if ($row["publicincludeid"] == $publicincludeid) { + //echo "child id: ".$i."
\n"; + unset($a_public_includes_details[$i]); + } + $i++; + } + } + } + + //if the public include xml file exists then delete it + if (file_exists("/usr/local/freeswitch/conf/dialplan/public/".$publicincludefilename)) { + unlink("/usr/local/freeswitch/conf/dialplan/public/".$publicincludefilename); + } + + unset($publicincludefilename); + unset($a_public_includes[$_GET['id']]); + write_config(); + sync_package_freeswitch_public_includes(); + header("Location: freeswitch_public_includes.php"); + exit; + } + } +} + +include("head.inc"); + +?> + + + +

FreeSWITCH: Public

+ +
+ + +
+ +
+ + + + + +
+ +
+"; +//print_r ($a_public_includes); +//echo ""; + + +//if ($config_change == 1) { +// write_config(); +// $config_change = 0; +//} + +//if ($savemsg) print_info_box($savemsg); +//if (file_exists($d_hostsdirty_path)): echo"

"; +//print_info_box_np("The FreeSWITCH recordings have been changed.
You must apply the changes in order for them to take effect."); +//echo"
"; +//endif; + +?> + +
+
+ + + + + + + + + + +
Public + + + +
+ + The public dialplan is used to route incoming calls to destinations based on conditions and context. It can send incoming calls to IVRs, extensions, external numbers, and scripts. + +
+ +
+
+
+ + + + + + + + + + + 0) { + foreach ($a_public_includes as $ent) { + $a_public_includes[$i]['id'] = $i; + $i++; + } + } + + //order the array + function cmp_number($a, $b) { + if ($a["order"] > $b["order"]) { + return 1; + } + else { + return 0; + } + } + if (count($a_public_includes) > 0) { usort($a_public_includes, "cmp_number"); } + + $i = 0; + if (count($a_public_includes) > 0) { + foreach ($a_public_includes as $ent) { + if (strlen($ent['extensionname'].$ent['enabled']) > 0) { + ?> + + + + + + + + + + + + + + + + + +
Extension NameOrderEnabledDescription + + + + + +
+
+ + + + +   + +   + + + + + + +
+
+ + + + + +
+
+ +

+ +/usr/local/freeswitch/conf/dialplan/public/ +
+
+
+
+
+
+ +
+ +
+ + + + + \ No newline at end of file diff --git a/config/freeswitch_dev/freeswitch_public_includes_details.tmp b/config/freeswitch_dev/freeswitch_public_includes_details.tmp new file mode 100755 index 00000000..3b3130b0 --- /dev/null +++ b/config/freeswitch_dev/freeswitch_public_includes_details.tmp @@ -0,0 +1,53 @@ + \ No newline at end of file diff --git a/config/freeswitch_dev/freeswitch_public_includes_details_edit.tmp b/config/freeswitch_dev/freeswitch_public_includes_details_edit.tmp new file mode 100644 index 00000000..c6cba5be --- /dev/null +++ b/config/freeswitch_dev/freeswitch_public_includes_details_edit.tmp @@ -0,0 +1,419 @@ + + + + +

FreeSWITCH: Public: Details: Edit

+ + + +
+ + +
+ +
+ + + + +
+
+
+ + + + + + + + + + + + + + + + + + + + + +
Tag + + \n"; + echo " \n"; + switch (htmlspecialchars($pconfig['tag'])) { + case "condition": + echo " \n"; + echo " \n"; + echo " \n"; + //echo " \n"; + break; + case "action": + echo " \n"; + echo " \n"; + echo " \n"; + //echo " \n"; + break; + case "anti-action": + echo " \n"; + echo " \n"; + echo " \n"; + //echo " \n"; + break; + case "param": + echo " \n"; + echo " \n"; + echo " \n"; + //echo " \n"; + break; + default: + echo " \n"; + echo " \n"; + echo " \n"; + //echo " \n"; + } + echo " \n"; + + //condition + //field expression + //action + //application + //data + //antiaction + //application + //data + //param + //name + //value + + ?> +
Type + +
Data + +
Order + \n"; + //echo " \n"; + if (strlen(htmlspecialchars($pconfig['fieldorder']))> 0) { + echo " \n"; + } + $i=0; + while($i<=999) { + if (strlen($i) == 1) { + echo " \n"; + } + if (strlen($i) == 2) { + echo " \n"; + } + if (strlen($i) == 3) { + echo " \n"; + } + + $i++; + } + echo " \n"; + ?> +
  + + + + + + +
+
+ + +
+
+ Example +
+
+ If the inbound call matches the DID 12085551234 then proceed to the action. +
+
+ + + + +
Tag:condition
Type:destination_number
Data:^(12085551234)$
+ +
+
+ + Transfer the inbound call to an IVR with extension of 5000. +
+
+ + + + +
Tag:action
Application:transfer
Data:5000 XML default
+ +
+
+ + Or transfer the inbound call to extension 1001. +
+
+ + + + +
Tag:action
Application:transfer
Data:1001 XML default
+ + +
+
+
+
+ + + Conditions +
+
+ Conditions are pattern matching tags that help FreeSwitch decide if the current call should be processed in this extension or not. When matching conditions against the current call you have several fields that you can compare against. +
    +
  • context
  • +
  • rdnis Redirected Number, the directory number to which the call was last presented.
  • +
  • destination_number Called Number, the number this call is trying to reach (within a given context)
  • +
  • public Name of the public module that are used, the name is provided by each public module. Example: XML
  • +
  • caller_id_name Name of the caller (provided by the User Agent that has called us).
  • +
  • caller_id_number Directory Number of the party who called (callee) -- can be masked (hidden)
  • +
  • ani Automatic Number Identification, the number of the calling party (callee) -- cannot be masked
  • +
  • ani2 The type of device placing the call [1]
  • +
  • uuid Unique identifier of the current call? (looks like a GUID)
  • +
  • source Name of the FreeSwitch module that received the call (e.g. PortAudio)
  • +
  • chan_name Name of the current channel (Example: PortAudio/1234). Give us examples when this one can be used.
  • +
  • network_addr IP address of the signalling source for a VoIP call.
  • +
+ In addition to the above you can also do variables using the syntax ${variable} or api functions using the syntax %{api} {args} +
+
+ Variables may be used in either the field or the expression, as follows + +
+
+
+
+ + Action and Anti-Actions +
+
+ Actions are executed when the condition matches. Anti-Actions are executed when the condition does NOT match. + Additional information on applications for Actions and Anti-Actions.
+ http://wiki.freeswitch.org/wiki/Modules#Applications +
+ http://wiki.freeswitch.org/wiki/public_Functions +
+
+
+ The following is a partial list of applications. +
    +
  • answer answer the call
  • +
  • bridge bridge the call
  • +
  • cond
  • +
  • db is a a runtime database either sqlite by default or odbc
  • +
  • global_set allows setting of global vars similar to the ones found in vars.xml
  • +
  • group allows grouping of several extensions for things like ring groups
  • +
  • expr
  • +
  • hangup hangs up the call
  • +
  • info sends call info to the console
  • +
  • javascript run javascript .js files
  • +
  • playback
  • +
  • reject reject the call
  • +
  • respond
  • +
  • ring_ready
  • +
  • set set a variable
  • +
  • set_user
  • +
  • sleep
  • +
  • sofia_contact
  • +
  • transfer transfer the call to another extension or number
  • +
  • voicemail send the call to voicemail
  • +
+ + +
+
+ + + + +
+
+
+
+
+ +
+ +
+ + + + diff --git a/config/freeswitch_dev/freeswitch_public_includes_edit.tmp b/config/freeswitch_dev/freeswitch_public_includes_edit.tmp new file mode 100644 index 00000000..e98dedeb --- /dev/null +++ b/config/freeswitch_dev/freeswitch_public_includes_edit.tmp @@ -0,0 +1,543 @@ + 0) { + //update + $ent['publicincludeid'] = $_POST['publicincludeid']; + } + else { + //add + $ent['publicincludeid'] = guid(); + } + $ent['extensionname'] = $_POST['extensionname']; + $ent['order'] = $_POST['order']; + //$ent['context'] = $_POST['context']; + $ent['context'] = 'default'; + $ent['enabled'] = $_POST['enabled']; + $ent['descr'] = $_POST['descr']; + $ent['opt1name'] = $_POST['opt1name']; + $ent['opt1value'] = $_POST['opt1value']; + + + + if (isset($id) && $a_public_includes[$id]) { + $a_public_includes = $config['installedpackages']['freeswitchpublicincludes']['config']; + if (count($a_public_includes) > 0) { + foreach($a_public_includes as $rowhelper) { + + //$rowhelper['publicincludeid']; + //$rowhelper['extensionname']; + //$rowhelper['context']; + //$rowhelper['enabled']; + + $filenamechanged = false; + if ($rowhelper['publicincludeid'] == $_POST['publicincludeid']) { + + if ($rowhelper['extensionname'] != $_POST['extensionname']) { + //if the extension name has changed then remove the current public xml file + //to prepare for the new file + $filenamechanged = true; + } + if ($rowhelper['order'] != $_POST['order']) { + //if the order has changed then remove the current public xml file + //to prepare for the new file + $filenamechanged = true; + } + if ($_POST['enabled'] == "false") { + //if the extension name is disabled then remove the public xml file + $filenamechanged = true; + } + if ($filenamechanged){ + $publicincludefilename = $rowhelper['order']."_".$rowhelper['extensionname'].".xml"; + if (file_exists("/usr/local/freeswitch/conf/dialplan/public/".$publicincludefilename)) { + unlink("/usr/local/freeswitch/conf/dialplan/public/".$publicincludefilename); + } + unset($publicincludefilename); + } + + } + unset($filenamechanged); + + } //end foreach + } //end if count + + //update the config + $a_public_includes[$id] = $ent; + } + else { + //add to the config + $a_public_includes[] = $ent; + } + + + write_config(); + sync_package_freeswitch_public_includes(); + + header("Location: freeswitch_public_includes.php"); + exit; + } +} + +include("head.inc"); + +?> + + + +

FreeSWITCH: Public: Edit

+ + + +
+ + +
+ +
+ + + + +
+ + + + + +

Public:
+
+ Public Include general settings. +

+
+ +
+ + + + + + + + + + + + + + + + + + + + + + + + + +
Extension Name + +
+ Supported characters are 'a-z', 'A-Z', '0-9', underscore '_', and period '.'. +
Enabled + \n"; + echo " \n"; + switch (htmlspecialchars($pconfig['enabled'])) { + case "true": + echo " \n"; + echo " \n"; + break; + case "false": + echo " \n"; + echo " \n"; + + break; + default: + echo " \n"; + echo " \n"; + } + echo " \n"; + ?> +
Order + \n"; + echo " \n"; + if (strlen(htmlspecialchars($pconfig['order']))> 0) { + echo " \n"; + } + $i=0; + while($i<=999) { + if (strlen($i) == 1) { + echo " \n"; + } + if (strlen($i) == 2) { + echo " \n"; + } + if (strlen($i) == 3) { + echo " \n"; + } + + $i++; + } + echo " \n"; + ?> +
+ Processing of each public include is determined by this order. +
Description + +
You may enter a description here + for your reference (not parsed).
  + + 0 && $a_public_includes[$id]) { + echo "\n"; + echo " \n"; + echo " \n"; + echo " \n"; + } + ?> + +
+
+ +
+
+ +
+ "; + //print_r ($a_public_includes); + //echo ""; + + //if ($savemsg) print_info_box($savemsg); + //if (file_exists($d_hostsdirty_path)): echo"

"; + //print_info_box_np("The FreeSWITCH recordings have been changed.
You must apply the changes in order for them to take effect."); + //echo"
"; + //endif; + + //create a temporary id for the array + $i = 0; + if (count($a_public_include_details) > 0) { + foreach ($a_public_include_details as $ent) { + $a_public_include_details[$i]['id'] = $i; + $i++; + } + } + + //order the array + function cmp_number_public_details($a, $b) { + if ($a["fieldorder"] > $b["fieldorder"]) { + return 1; + } + else { + return 0; + } + } + if (count($a_public_include_details) > 0) { usort($a_public_include_details, "cmp_number_public_details"); } + + ?> + + + + + + +

Conditions and Actions
+
+ The following conditions, actions and anti-actions are used in the public to direct call flow. Each is processed in order until you reach the action tag which tells FreeSWITCH what action to perform. You are not limited to only one condition or action tag for a given extension. +

+
+ + + + + + + + + + + 0) { + + foreach ($a_public_include_details as $ent) { + if ($ent['tag'] == "condition" && $publicincludeid == $ent['publicincludeid']) { + ?> + + + + + + + + 0) { + + foreach ($a_public_include_details as $ent) { + if ($ent['tag'] == "action" && $publicincludeid == $ent['publicincludeid']) { + ?> + + + + + + + + 0) { + + foreach ($a_public_include_details as $ent) { + if ($ent['tag'] == "anti-action" && $publicincludeid == $ent['publicincludeid']) { + ?> + + + + + + + + 0) { + + foreach ($a_public_include_details as $ent) { + if ($ent['tag'] == "param" && $publicincludeid == $ent['publicincludeid']) { + ?> + + + + + + + + + + + + + + + + + + +
TagTypeDataOrder + + + + + +
+
+ + +   + +   + +   + + + + + + +
+
+ + +   + +   + +   + + + + + + +
+
+ + +   + +   + +   + + + + + + +
+
+ + +   + +   + +   + + + + + + +
+
+ + + + + +
+
+ +

+ + +
+
+ +
+ +
+ + + + diff --git a/config/freeswitch_dev/freeswitch_recordings.tmp b/config/freeswitch_dev/freeswitch_recordings.tmp new file mode 100644 index 00000000..7d504d15 --- /dev/null +++ b/config/freeswitch_dev/freeswitch_recordings.tmp @@ -0,0 +1,494 @@ + + + + + + +

FreeSWITCH: Recordings

+ +
+ + +
+ +
+ + + + + +
+ + 0) { + foreach ($a_recordings as $recordingent) { + $config_recording_list .= $recordingent['filename']."|"; + $i++; + } +} + + + +$config_change = 0; +if (is_dir($dir_recordings)) { + if ($dh = opendir($dir_recordings)) { + while (($file = readdir($dh)) !== false) { + if (filetype($dir_recordings . $file) == "file") { + + if (strpos($config_recording_list, $file) === false) { + + //$handle = fopen($dir_recordings.$file,'rb'); + //$file_content = fread($handle,filesize($dir_recordings.$file)); + //fclose($handle); + + $a_file = split("\.", $file); + + $recordingent = array(); + $recordingent['filename'] = $file; + $recordingent['recordingname'] = $a_file[0]; + $recordingent['recordingid'] = guid(); + //$recordingent['filecontent'] = base64_encode($file_content); + $recordingent['descr'] = 'Auto'; + + $a_recordings[] = $recordingent; + write_config(); + + unset($file_content); + + } + else { + //echo "The file was found.
"; + } + + } + } + closedir($dh); + } +} + + + +//saved for future use if and when config.xml scales well + //enough to save the files inside it +//$i = 0; +//if (count($a_recordings) > 0) { +// foreach ($a_recordings as $recordingent) { + +// if (!is_file($dir_recordings.$recordingent['filename'])) { + //echo "not found: ".$recordingent['filename']."
"; + + //recording not found restore the file from the config.xml + //$file_content = $recordingent['filecontent']; + //$handle = fopen($dir_recordings.$recordingent['filename'],'w'); + //fwrite ($handle, base64_decode($file_content)); + //unset($file_content); + //fclose($handle); + //$recordingent['filecontent'] = base64_encode($file_content); + + // loop through recordings in the config.xml + // if the file does not exist remove it from the file system. + //unset($a_recordings[$i]); + +// $config_change = 1; +// } +// else { + //echo "found: ".$recordingent['filename']."
"; +// } + +// $i++; +// } +//} + +if ($config_change == 1) { + write_config(); + $config_change = 0; +} + +//if ($savemsg) print_info_box($savemsg); +//if (file_exists($d_hostsdirty_path)): echo"

"; +//print_info_box_np("The FreeSWITCH recordings have been changed.
You must apply the changes in order for them to take effect."); +//echo"
"; +//endif; + +?> + + + + +

Recordings:
+
+ To make a recording dial *732673 (record) or you can make a + 16bit 8khz/16khz Mono WAV file then copy it to the + following directory then refresh the page to play it back. + Click on the 'Filename' to download it or the 'Recording Name' to + play the audio. +

+ +
+ +

+
+ + + + + + + +
location: + + File to upload: + + +
+
+ + + + + + + + + + + 0) { + foreach ($a_recordings as $recordingent) { + if (strlen($recordingent['filename']) > 0) { + ?> + + + + + + + + + + + + + + +
Filename (download)Recording Name (play)Description + +
+ + + + + +   + + +   + + + + + + +
+
+ + + +
+
+
+ + + + + +

Music on Hold:
+
+ Music on hold can be in WAV or MP3 format. To play an MP3 file you must have + mod_shout enabled on the 'Modules' tab. You can adjust the volume of the MP3 + audio from the 'Settings' tab. For best performance upload 16bit 8khz/16khz Mono WAV files. + +

+ +
+ +
+
+ + + + + + + +
location: + + File to upload: + + +
+
+ + + + + + + + + + + + \n"; + echo " \n"; + echo " \n"; + echo " \n"; + echo " \n"; + echo " \n"; + echo "\n"; + + } + } + closedir($handle); + } + ?> + + + + + +
File Name (download)Name (play)Last ModifiedSize
\n"; + echo " \n"; + echo " $file"; + echo " "; + echo " \n"; + echo " \n"; + $tmp_file_array = split("\.",$file); + echo " ".$tmp_file_array[0]; + echo " "; + echo " \n"; + echo date ("F d Y H:i:s", filemtime($dir_music_on_hold_8000.$file)); + echo " \n"; + echo " ".$tmp_filesize; + echo " \n"; + echo " \n"; + echo " \n"; + //echo " \n"; + echo " \n"; + echo " \n"; + echo "
\n"; + echo "
+ +
+
+
+
+
+
+ +
+ +
+ + + + + diff --git a/config/freeswitch_dev/freeswitch_recordings_edit.tmp b/config/freeswitch_dev/freeswitch_recordings_edit.tmp new file mode 100644 index 00000000..e53c44fc --- /dev/null +++ b/config/freeswitch_dev/freeswitch_recordings_edit.tmp @@ -0,0 +1,172 @@ + 0) { + $recordingent['recordingid'] = $_POST['recordingid']; + } + else { + $recordingent['recordingid'] = guid(); + } + + $recordingent['filename'] = $_POST['filename']; + + //if file name is not the same then rename the file + if ($_POST['filename'] != $_POST['filename_orig']) { + rename('/usr/local/freeswitch/recordings/'.$_POST['filename_orig'], '/usr/local/freeswitch/recordings/'.$_POST['filename']); + } + $a_recordings[$id] = $recordingent; + } + else { + //add + $recordingent['filename'] = $_POST['filename']; + $a_recordings[] = $recordingent; + } + + write_config(); + + header("Location: freeswitch_recordings.php"); + exit; + } +} + +include("head.inc"); + +?> + + + +

FreeSWITCH: Recordings: Edit

+ + + +
+ + +
+ +
+ + + + +
+
+
+ + + + + + + + + + + + + + + + + +
Filename + +
Name of the file
+ e.g. example.wav
Recording Name + +
Recording Name
+ e.g. recordingx
Description + +
You may enter a description here + for your reference (not parsed).
  + + + + + + +
+
+ +
+
+
+
+
+
+ +
+ +
+ + + + diff --git a/config/freeswitch_dev/freeswitch_recordings_play.tmp b/config/freeswitch_dev/freeswitch_recordings_play.tmp new file mode 100755 index 00000000..1c63b592 --- /dev/null +++ b/config/freeswitch_dev/freeswitch_recordings_play.tmp @@ -0,0 +1,70 @@ + + + + + + + + + + + + + +
+ file: +
+ \n"; + } + if ($file_ext == "mp3") { + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + } + + ?> +
+ + + diff --git a/config/freeswitch_dev/freeswitch_status.tmp b/config/freeswitch_dev/freeswitch_status.tmp new file mode 100644 index 00000000..4fa4181a --- /dev/null +++ b/config/freeswitch_dev/freeswitch_status.tmp @@ -0,0 +1,339 @@ + + + + + + + + +

FreeSWITCH: Status

+ + + +
+ + +
+ +
+ + + + +
+ +
\n\n"; + + +$fp = event_socket_create($host, $port, $password); +$cmd = "api sofia status"; +$response = event_socket_request($fp, $cmd); +echo "\n"; +echo "\n"; +echo "\n"; +echo "\n"; +echo "\n"; +echo "
\n"; +echo " sofia status \n"; +echo "\n"; +echo " \n"; +echo "
\n"; +echo "
\n";
+echo $response;
+echo "
\n"; +fclose($fp); +echo "

\n\n"; + +foreach (ListFiles('/usr/local/freeswitch/conf/sip_profiles') as $key=>$sip_profile_file){ + + $sip_profile_name = str_replace(".xml", "", $sip_profile_file); + $fp = event_socket_create($host, $port, $password); + $cmd = "api sofia status profile ".$sip_profile_name; + $response = event_socket_request($fp, $cmd); + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "\n"; + echo "
\n"; + echo " sofia status profile $sip_profile_name \n"; + echo "\n"; + echo " \n"; + echo " \n"; + echo " \n"; + if ($sip_profile_name == "external") { + echo " \n"; + } + else { + echo " \n"; + } + echo "
\n"; + echo "
\n";
+	echo $response;
+	echo "
\n"; + fclose($fp); + echo "

\n\n"; + +} + + +$fp = event_socket_create($host, $port, $password); +$cmd = "api status"; +$response = event_socket_request($fp, $cmd); +echo "status
\n"; +echo "
\n";
+echo $response;
+echo "
\n"; +fclose($fp); +echo "

\n\n"; + + +$fp = event_socket_create($host, $port, $password); +$cmd = "api show channels"; +$response = event_socket_request($fp, $cmd); +echo "show channels
\n"; +if (strlen($response) > 40) { + echo "\n"; +} +else { + echo "
\n";
+  echo $response;
+  echo "
\n"; +} +fclose($fp); +echo "

\n\n"; +echo "

\n\n"; + + +$fp = event_socket_create($host, $port, $password); +$cmd = "api show calls"; +$response = event_socket_request($fp, $cmd); +echo "show calls
\n"; +if (strlen($response) > 40) { + echo "\n"; +} +else { + echo "
\n";
+  echo $response;
+  echo "
\n"; +} +fclose($fp); +echo "

\n\n"; +echo "

\n\n"; + + +echo "\n"; +echo "\n"; +echo "\n"; +echo "\n"; +echo "\n"; +echo "
\n"; +echo "Backup / Restore
\n"; +echo "The 'backup' button will tar gzip /usr/local/freeswitch/ to /root/backup/freeswitch.bak.tgz it then presents a file to download. \n"; +echo "If the backup file does not exist in /root/backup/freeswitch.bak.tgz then the 'restore' button will be hidden. \n"; +echo "Use Diagnostics->Command->File to upload: to browse to the file and then click on upload it now ready to be restored. \n"; +echo "

\n"; +echo "
\n"; +echo " \n"; +if (file_exists('/root/backup/freeswitch.bak.tgz')) { + echo " \n"; +} +echo "
\n"; +echo "

\n\n"; + + +echo "\n"; +echo "\n"; +echo "\n"; +echo "\n"; +echo "\n"; +echo "
\n"; +echo "Call Detail Records
\n"; +echo "/usr/local/freeswitch/log/cdr-csv/Master.csv

\n"; +echo "
\n"; +echo " \n";echo "
\n"; +echo "

\n\n"; + + +echo "\n"; +echo "\n"; +echo "\n"; +echo "\n"; +echo "
\n"; +echo "Logs
\n"; +echo "/usr/local/freeswitch/log/cdr-csv/freeswitch.log

\n"; +echo "
\n"; +echo " \n"; +echo "
\n"; +echo "

\n\n"; + + +echo "tail -n 500 /usr/local/freeswitch/log/freeswitch.log
\n"; +echo "\n"; +echo "

\n\n"; + + +//$fp = event_socket_create($host, $port, $password); +//$cmd = "api sofia "; +//$response = event_socket_request($fp, $cmd); +//echo "api sofia
\n"; +//echo "
\n";
+//echo $response;
+//echo "
\n"; +//fclose($fp); +//echo "

\n\n"; + +?> + +
+ +
+ + + + diff --git a/config/freeswitch_dev/freeswitch_time_conditions.tmp b/config/freeswitch_dev/freeswitch_time_conditions.tmp new file mode 100644 index 00000000..17787ad3 --- /dev/null +++ b/config/freeswitch_dev/freeswitch_time_conditions.tmp @@ -0,0 +1,178 @@ + + + + +

FreeSWITCH: IVR: Options

+ +
+ + +
+ +
+ + + + + +
+ +
+"; +//print_r ($a_ivr); +//echo ""; + +//if ($savemsg) print_info_box($savemsg); +//if (file_exists($d_hostsdirty_path)): echo"

"; +//print_info_box_np("The FreeSWITCH recordings have been changed.
You must apply the changes in order for them to take effect."); +//echo"
"; +//endif; + +?> + + + + +

Note:
+
+ To make a recording dial extension 700 or you can make a + 16bit 8khz/16khz Mono WAV file then copy it to the + following directory then refresh the page to play it back. +

+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + +
FilenameNameDescription + + + + + +
+
+ + + + +   + +   + + + + + + +
+
+ + + + + +
+
+ +

+ +
+
+
+
+
+
+ +
+ +
+ + + + + diff --git a/config/freeswitch_dev/freeswitch_time_conditions_edit.tmp b/config/freeswitch_dev/freeswitch_time_conditions_edit.tmp new file mode 100644 index 00000000..45631929 --- /dev/null +++ b/config/freeswitch_dev/freeswitch_time_conditions_edit.tmp @@ -0,0 +1,201 @@ + + + + +

+ + +
+ + +
+ +
+ + + + +
+ +
+ + + + + + + + + + + + + + + + + + + + + +
Option Number + +
Option Number
+ e.g. 1
Type + \n"; + echo " \n"; + if (htmlspecialchars($pconfig['optiontype']) == "extension") { + echo " \n"; + } + else { + echo " \n"; + } + if (htmlspecialchars($pconfig['optiontype']) == "voicemail") { + echo " \n"; + } + else { + echo " \n"; + } + echo " \n"; + ?> +
Destination + +
Destination
+ e.g. 1001
Description + +
You may enter a description here + for your reference (not parsed).
  + + + + + + +
+
+ +
+
+
+
+
+
+ +
+ +
+ + + + diff --git a/config/freeswitch_dev/freeswitch_vars.tmp b/config/freeswitch_dev/freeswitch_vars.tmp new file mode 100644 index 00000000..5e7a5744 --- /dev/null +++ b/config/freeswitch_dev/freeswitch_vars.tmp @@ -0,0 +1,162 @@ + + + + + + + + + + +

FreeSWITCH: Variables

+ +
+ + +
+ +
+ + + + + + +
+ +
+ + + + + + +

Variables
+
+ Define preprocessor variables here. Can be accessed in the xml configation with $${var_name}. +

+
+
+
+ + +
+
+ + + + + + +
/usr/local/freeswitch/conf/vars.xml + + + "; + ?> +
+ +
+ +
+
+ +
+
+
+
+
+
+
+
+ +
+ +
+ + + + + + diff --git a/config/freeswitch_dev/libcurl.so.5 b/config/freeswitch_dev/libcurl.so.5 new file mode 100755 index 00000000..3d57856f Binary files /dev/null and b/config/freeswitch_dev/libcurl.so.5 differ diff --git a/config/freeswitch_dev/libiconv.so.3 b/config/freeswitch_dev/libiconv.so.3 new file mode 100755 index 00000000..f207e92c Binary files /dev/null and b/config/freeswitch_dev/libiconv.so.3 differ diff --git a/config/freeswitch_dev/libncurses.so.5.6 b/config/freeswitch_dev/libncurses.so.5.6 new file mode 100755 index 00000000..3b40374c Binary files /dev/null and b/config/freeswitch_dev/libncurses.so.5.6 differ diff --git a/config/freeswitch_dev/libncurses.so.5.7 b/config/freeswitch_dev/libncurses.so.5.7 new file mode 100755 index 00000000..3b40374c Binary files /dev/null and b/config/freeswitch_dev/libncurses.so.5.7 differ diff --git a/config/freeswitch_dev/libodbc.so.1 b/config/freeswitch_dev/libodbc.so.1 new file mode 100755 index 00000000..eb7cb3af Binary files /dev/null and b/config/freeswitch_dev/libodbc.so.1 differ diff --git a/config/freeswitch_dev/libogg.so.5.3 b/config/freeswitch_dev/libogg.so.5.3 new file mode 100755 index 00000000..d230b68e Binary files /dev/null and b/config/freeswitch_dev/libogg.so.5.3 differ diff --git a/config/freeswitch_dev/libspandsp.so.1 b/config/freeswitch_dev/libspandsp.so.1 new file mode 100755 index 00000000..177b8c22 Binary files /dev/null and b/config/freeswitch_dev/libspandsp.so.1 differ diff --git a/config/freeswitch_dev/libtinfo.so.5.6 b/config/freeswitch_dev/libtinfo.so.5.6 new file mode 100755 index 00000000..1263ec79 Binary files /dev/null and b/config/freeswitch_dev/libtinfo.so.5.6 differ diff --git a/config/freeswitch_dev/libvorbis.so.4 b/config/freeswitch_dev/libvorbis.so.4 new file mode 100755 index 00000000..ec91ac85 Binary files /dev/null and b/config/freeswitch_dev/libvorbis.so.4 differ diff --git a/config/freeswitch_dev/please_enter_the_extension_number.wav b/config/freeswitch_dev/please_enter_the_extension_number.wav new file mode 100644 index 00000000..d9384b0f Binary files /dev/null and b/config/freeswitch_dev/please_enter_the_extension_number.wav differ diff --git a/config/freeswitch_dev/please_enter_the_phone_number.wav b/config/freeswitch_dev/please_enter_the_phone_number.wav new file mode 100644 index 00000000..9cb4057b Binary files /dev/null and b/config/freeswitch_dev/please_enter_the_phone_number.wav differ diff --git a/config/freeswitch_dev/please_enter_the_pin_number.wav b/config/freeswitch_dev/please_enter_the_pin_number.wav new file mode 100644 index 00000000..107728a5 Binary files /dev/null and b/config/freeswitch_dev/please_enter_the_pin_number.wav differ diff --git a/config/freeswitch_dev/please_enter_your_pin_number.wav b/config/freeswitch_dev/please_enter_your_pin_number.wav new file mode 100755 index 00000000..46263917 Binary files /dev/null and b/config/freeswitch_dev/please_enter_your_pin_number.wav differ diff --git a/config/freeswitch_dev/your_pin_number_is_incorect_goodbye.wav b/config/freeswitch_dev/your_pin_number_is_incorect_goodbye.wav new file mode 100755 index 00000000..5683bb8e Binary files /dev/null and b/config/freeswitch_dev/your_pin_number_is_incorect_goodbye.wav differ -- cgit v1.2.3