VIDEOCHAT  ::   FAQ  ::   Поиск  ::   Регистрация  ::   Вход

CallerID на русском

Проблемы Asterisk без вэб-оболочек и их решения

Модераторы: april22, Zavr2008

joe
Сообщения: 17
Зарегистрирован: 20 июн 2013, 19:46
Откуда: Kiev
Контактная информация:

Re: CallerID на русском

Сообщение joe »

Ура, вопрос закрыт. Чуть не сдох пока разобрался.
Оказывается я сам себе навредил.
Когда-то на сервак заводил очень сельско-киргизский сип - мучался кстати, что пипец. Тогда помогла вот эта опция
http://www.voip-info.org/wiki/view/Aste ... P+pedantic
установил pedantic=yes и тот сучий сип заработал
Знал бы я что из-за нее сойдет сума астериск - в жизни б не ставил.
Как только поставил pedantic=no все ок, но теперь не пашит тот сип чертов.
Так что палка в двух концах, но очень рад, что победил.
Так что с хедерами и с кодировкой все ок было, просто я давно намутил с конфигом и забыл.
chubaka
Сообщения: 43
Зарегистрирован: 25 июн 2013, 14:05

Re: CallerID на русском

Сообщение chubaka »

FreePBX к сожалению по умолчанию не хочет сохранять CallerID на языках отличных от английского.
Чтобы это исправить нужно удалить !isAlphaNumeric в файле /var/www/html/admin/modules/core/functions.inc.php:6850 (позиция строки может различаться)
Итоговый вид такой:
$currentcomponent->addguielem($section, new gui_textbox('name', $name, _("Display Name"), _("The CallerID name for calls from this user will be set to this name. Only enter the name, NOT the number."), 'isWhitespace()', $msgInvalidDispName, false));

После этого станет возможным ввод русских символов и станет отображаться русский CallerID, однако в самой GUI эти символы станут отображаться кракозяблями.
Решение - или обновить PHP до версии 5.4+ или подправить libraries/components.class.php:619 до вида:
$this->html_input = "<input type=\"text\" name=\"$this->_elemname\" id=\"$this->_elemname\" size=\"35\" $disable_state $maxlength tabindex=\"$tabindex\" value=\"" . htmlentities($this->currentvalue, ENT_COMPAT | ENT_HTML401, 'UTF-8') . "\"
ded
Сообщения: 15619
Зарегистрирован: 26 авг 2010, 19:00

Re: CallerID на русском

Сообщение ded »

maxmen77
Сообщения: 34
Зарегистрирован: 17 окт 2010, 15:50

Re: CallerID на русском

Сообщение maxmen77 »

Переезжаю на новый астериск Asterisk 1.8.10.1, собранный с"0" со старого elastixa и пользуясь случаем, пытаюсь опять решить проблему с кодировкой, но уже хочется сделать все правильно и без костылей.
Я в этой теме во время прошлых своих "изысканий" изложил все подробно, но на всякий случай резюмирую. Ситуация следующая.
Есть модуль, который определяет номера через http-запрос, номера с именами хранятся в MYsql в UTF-8, но почему-то до консоли астера они не доходят.
Проверяю в консоли запросом через curl:

Код: Выделить всё

curl http://127.0.0.1/html/admin/modules/superfecta/bin/callerid.php?thenumber=НОМЕР ЗАНЕСЕННЫЙ В БД С ИМЕНЕМ "ТЕСТОВЫЙ КОНТРАГЕНТ"
и получаю в консоли вполне читабельный ответ:

Код: Выделить всё

Тестовый контрагент
Судя по записи в extensions_additional.conf

Код: Выделить всё

exten => cidlookup_1,n,Set(CALLERID(name)=${CURL(http://localhost:80/html/admin/modules/superfecta/bin/callerid.php?thenumber=${CALLERID(num)})})
,
asterisk номер должен тоже получить читабельный, но в консоли, а соответственно, и в логах, и на телефоне мы видим просто номер без результата его определения.
Сейчас пользуюсь этим модулем, но через старый костыль в виде добавки к тексту "-", что приводит к тому, что на телефонах с небольшим экраном (у нас yealink t-20) показывается только костыль, а само определенное имя прячется за пределами экрана (на yealink t-22 видно нормально и костыль и определенное имя). Во вложении код модуля с комментариями в тех местах, которые на мой взгляд могли повлиять на кодировки. Но получается, что модуль выдает все правильно, а астер где-то еще сам перекодирует уже после того как получает ответ из определителя. Где искать???
PRIME_BBCODE_SPOILER_SHOW PRIME_BBCODE_SPOILER:

Код: Выделить всё

<?php
/*** Original script by Nerd Vittles. (Google for Caller Id Trifecta)
    3/12/2009  	Put into module format by Tony Shiffer & Jerry Swordsteel
			commented out fixed variables.  Added db code to get values from db.
	3/30/2009  	New SugarCRM by jpeterman is now included.
	4/8/2009  	Removed dependancy on default id/pw for db connection. now parses amportal.conf
	5-8-2009	Version 2.0.0 Major update - Tickets: Tickets: #7, #10, #15, #17, #36, and #19.(projects.colsolgrp.net)(jjacobs)
	8-18-2009	Version 2.2.0  CID Schemes and online update for data sources (projects.colsolgrp.net)(jjacobs)
	10-26-2009  Version 2.2.2  http://projects.colsolgrp.net/versions/show/55 (projects.colsolgrp.net) (patrick_elx)
***/

$debug_val = (isset($_REQUEST['debug'])) ? $_REQUEST['debug'] : '';
$debug = ($debug_val == 'yes') ? true : false;
if($debug){
	// If debugging, report all errors
	error_reporting(-1);
	ini_set('display_errors', '1');
}

$caller_id = '';
$charsetIA5 = false;
$first_caller_id = '';
$prefix = '';
$cache_found = false;
$spam = false;
$winning_source = '';
$usage_mode = 'get caller id';
$src_array = array();
$thenumber_orig = (isset($_REQUEST['thenumber'])) ? trim($_REQUEST['thenumber']) : '';
if(($thenumber_orig == '') && isset($argv[1])){
	$thenumber_orig = $argv[1];
}
$testdid = (isset($_REQUEST['testdid'])) ? trim($_REQUEST['testdid']) : '';
if(($testdid == '') && isset($argv[2])){
	$testdid = $argv[2];
}
$scheme = (isset($_REQUEST['scheme'])) ? trim($_REQUEST['scheme']) : '';
//$thenumber_orig = ereg_replace('[^0-9]+', '', $thenumber_orig);

if($debug)
{
	//Report all errors, FreePBX hides them
    error_reporting(E_ALL & E_NOTICE); // -1 was not letting me see the wood for the trees.
    ini_set('display_errors', 1);
	$start_time_whole = mctime_float();
	$end_time_whole = 0;
}

require('../config.php');

$param = array();
$query = "SELECT * FROM superfectaconfig";
$res = $db->query($query);
while ($row = $res->fetchRow(DB_FETCHMODE_ASSOC))
{
	$param[$row['source']][$row['field']] = $row['value'];
}

if($debug)
{
	print "Debugging Enabled, will not stop after first result.<br>\n";
}

//loop through schemes
$query = "SELECT source	FROM superfectaconfig WHERE field = 'order' AND value > 0";

if($debug && ($scheme != ""))
{
	$query .= " AND		source = '$scheme'";
}
$query .= " ORDER BY value";
$res = $db->query($query);
if(DB::isError($res) && $debug)
{
	print 'The database query of:<br>'.$query.'<br>failed with an error of:<br>'.$res->getMessage();
}
else
{

	//get the DID for this call using the PHP Asterisk Manager
	$DID = "";
	$value = $astman->command('core show channels concise');
	$chan_array = preg_split("/\n/",$value['data']);
	foreach($chan_array as $val)
	{
		$this_chan_array = explode("!",$val);
		if(isset($this_chan_array[7]))
		{
			$this_chan_array[7]=trim($this_chan_array[7]);
	//		if($thenumber_orig == substr($this_chan_array[7],-10))
			if($thenumber_orig == $this_chan_array[7])
			{
				$value = $astman->command('core show channel '.$this_chan_array[0]);
				$this_array = preg_split("/\n/",$value['data']);
				foreach($this_array as $val2)
				{
					if(strpos($val2,'FROM_DID=') !== false)
					{
						$DID = trim(str_replace('FROM_DID=','',$val2));
						break;
					}
				}
	
				//break out if the value is set.
				if($DID != '')
				{
					break;
				}
			}
		}
	}
	// If a test DID number has been specified, and we're in debug mode, use it.
	if((strlen(trim($testdid))) && ($debug)){
		$DID = $testdid;
	}

	// Loop over each scheme
	while ($res && ($row = $res->fetchRow(DB_FETCHMODE_ASSOC)))
	{
		$this_scheme = $row['source'];
		$run_this_scheme = true;
		$thenumber = ereg_replace('[^0-9]+', '', $thenumber_orig);

		if($debug)
		{
			print "<hr>Processing ".substr($this_scheme,5)." Scheme.<br>\n";
		}
		//trying to push some info to the CLI
		$astman->command('VERBOSE "Processing '.substr($this_scheme,5).' Scheme." 3');


		// Determine if this is the correct DID, if this scheme is limited to a DID.

		$rule_match = match_pattern_all( (isset($param[$this_scheme]['DID'])) ? $param[$this_scheme]['DID'] : '', $DID );
		if($rule_match['number']){
			if($debug){print "Matched DID Rule: '".$rule_match['pattern']."' with '".$rule_match['number']."'<br>\n";}
		}elseif($rule_match['status']){
			if($debug){print "No matching DID rules.<br>\n";}
			$run_this_scheme = false;
		}


		// Determine if the CID matches any patterns defined for this scheme

		$rule_match = match_pattern_all((isset($param[$this_scheme]['CID_rules']))?$param[$this_scheme]['CID_rules']:'', $thenumber );
		if($rule_match['number'] && $run_this_scheme){
			if($debug){print "Matched CID Rule: '".$rule_match['pattern']."' with '".$rule_match['number']."'<br>\n";}
			$thenumber = $rule_match['number'];
		}elseif($rule_match['status'] && $run_this_scheme){
			if($debug){print "No matching CID rules.<br>\n";}
			$run_this_scheme = false;
		}

		// Run the scheme
		
		if($run_this_scheme)
		{
			$curl_timeout = $param[$this_scheme]['Curl_Timeout'];

			//if a prefix lookup is enabled, look it up, and truncate the result to 10 characters
			if( (isset($param[$this_scheme]['Prefix_URL'])) && (trim($param[$this_scheme]['Prefix_URL']) != ''))
			{
				if($debug)
				{
					$start_time = mctime_float();
				}

				$prefix = get_url_contents(str_replace("[thenumber]",$thenumber,$param[$this_scheme]['Prefix_URL']));

				if($debug)
				{
					print "Prefix Url defined ...\n";
					if($prefix !='')
					{
						print 'returned: '.$prefix."<br>\n";
					}
					else
					{
						print "result was empty<br>\n";
					}
					print "result <img src='images/scrollup.gif'> took ".number_format((mctime_float()-$start_time),4)." seconds.<br>\n<br>\n";
				}
			}

			//run through the specified sources
			$src_array = explode(',',$param[$this_scheme]['sources']);
			$theoriginalnumber = $thenumber;
			if ($theoriginalnumber !='')
			{
			   foreach($src_array as $source_name)
			   {
				$thenumber = $theoriginalnumber;
				if($debug)
				{
					$start_time = mctime_float();
				}
				$caller_id = '';
				$run_param = isset($param[substr($this_scheme,5).'_'.$source_name]) ? $param[substr($this_scheme,5).'_'.$source_name] : array();

				eval('include("source-'.$source_name.'.php");');
				$caller_id = _utf8_decode($caller_id);
				if(($first_caller_id == '') && ($caller_id != ''))
				{
					$first_caller_id = $caller_id;
					$winning_source = $source_name;
					if($debug)
					{
						$end_time_whole = mctime_float();
					}
				}

				if($debug)
				{
					if($caller_id != '')
					{
						print "'" . utf8_encode($caller_id)."'<br>\nresult <img src='images/scrollup.gif'> took ".number_format((mctime_float()-$start_time),4)." seconds.<br>\n<br>\n";
					}
					else
					{
						print "result <img src='images/scrollup.gif'> took ".number_format((mctime_float()-$start_time),4)." seconds.<br>\n<br>\n";
					}
				}
				else if($caller_id != '')
				{
					break;
				}
			   }
			} else
			{
			  if($debug)
				{
					print "The caller IDnumber '".$thenumber_orig."' did not contain number. Lookup stopped <br>";
				}
			}


			$prefix = ($prefix != '') ? $prefix.':' : '';
			if($spam)
			{
				if(isset($param[$this_scheme]['SPAM_Text_Substitute']) && $param[$this_scheme]['SPAM_Text_Substitute'] == 'Y')
				{
					$first_caller_id = $param[$this_scheme]['SPAM_Text'];
				}
				else
				{
					$first_caller_id = "{$param[$this_scheme]['SPAM_Text']}:".str_replace("{$param[$this_scheme]['SPAM_Text']}:", '', $first_caller_id);
				}
			}
		}

		if($first_caller_id != '')
		{
			break;
		}
	}
}

//post-processing
if($debug)
{
	print "Post CID retrieval processing.<br>\n<br>\n";
}

//remove unauthorized character in the caller id
if ($first_caller_id !='')
	{
		//$first_caller_id = _utf8_decode($first_caller_id);
		$first_caller_id = strip_tags($first_caller_id );
		$first_caller_id = trim ($first_caller_id);
		if ($charsetIA5)
		{
			$first_caller_id = stripAccents($first_caller_id);
		}
		$first_caller_id = preg_replace ( "/[\";']/", "", $first_caller_id);
		//limit caller id to the first 60 char
		$first_caller_id = substr($first_caller_id,0,60);
	}

$usage_mode = 'post processing';
foreach($src_array as $source_name)
{
	$thenumber = $theoriginalnumber;
	$run_param = isset($param[substr($this_scheme,5).'_'.$source_name]) ? $param[substr($this_scheme,5).'_'.$source_name] : array();
	eval('include("source-'.$source_name.'.php");');
}

if($debug)
{
	print "<b>Returned Result would be: ";
	$first_caller_id = utf8_encode($first_caller_id);
}
print $prefix.$first_caller_id;
print "-"; 
// Если раскомментировать предыдущую строку, то определитель работает, добавляется к имени текст из кавычек и на некоторых телефонах типа yealink t-20 с маленьким экраном видим только этот текст)
if($debug)
{
	$end_time_whole = ($end_time_whole == 0) ? mctime_float() : $end_time_whole;
	print "<br>\nresult <img src='images/scrollup.gif'> took ".number_format(($end_time_whole-$start_time_whole),4)." seconds.</b>";
}

$astman->disconnect();


/**
Search an array of area codes against phone number to find one that matches.
Return an array with the area code, area name and remaining phone number
*/
function cisf_find_area ($area_array, $full_number)
{
	$largest_match = 0;
	$match = false;
        foreach ($area_array as $area => $area_code) {
		$area_length = strlen($area_code);
                if((substr($full_number,0,$area_length)==$area_code) && ($area_length > $largest_match)) {
                        $match = array(
				'area'=>$area,
				'area_code'=>$area_code,
				'number'=>substr($full_number,$area_length)
			);
			$largest_match = $area_length;
                }
        }
        return $match;
}

/**
Encode an array for transmission in http request
*/
function cisf_url_encode_array($arr){
	$string = "";
	foreach ($arr as $key => $value) {
		$string .= $key . "=" . urlencode($value) . "&";
	}
	trim($string,"&");
	return $string;
}

/**
Returns the content of a URL.
*/
function get_url_contents($url,$post_data=false,$referrer=false,$cookie_file=false,$useragent=false)
{
	global $debug,$curl_timeout;
	$crl = curl_init();
	if(!$useragent){
		// Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US; rv:1.9.2.6) Gecko/20100625 Firefox/3.6.6 ( .NET CLR 3.5.30729)
		$useragent="Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US; rv:1.8.1.1) Gecko/20061204 Firefox/2.0.0.1";
	}
	if($referrer){
		curl_setopt ($crl, CURLOPT_REFERER, $referrer);
	}
	curl_setopt($crl,CURLOPT_USERAGENT,$useragent);
	curl_setopt($crl,CURLOPT_URL,$url);
	curl_setopt($crl,CURLOPT_RETURNTRANSFER,true);
	curl_setopt($crl,CURLOPT_CONNECTTIMEOUT,$curl_timeout);
	curl_setopt($crl,CURLOPT_FAILONERROR,true);
	curl_setopt($crl,CURLOPT_TIMEOUT,$curl_timeout);
	if($cookie_file){
		curl_setopt($crl, CURLOPT_COOKIEJAR, $cookie_file);
		curl_setopt($crl, CURLOPT_COOKIEFILE, $cookie_file);
	}
	if($post_data){
		curl_setopt($crl, CURLOPT_POST, 1); // set POST method
		curl_setopt($crl, CURLOPT_POSTFIELDS, cisf_url_encode_array($post_data)); // add POST fields
	}

	$ret = trim(curl_exec($crl));
	if(curl_error($crl) && $debug)
	{
		print ' '.curl_error($crl).' ';
	}

	//if debug is turned on, return the error number if the page fails.
	if($ret === false)
	{
		$ret = '';
	}
	//something in curl is causing a return of "1" if the page being called is valid, but completely empty.
	//to get rid of this, I'm doing a nasty hack of just killing results of "1".
	if($ret == '1')
	{
		$ret = '';
	}
	curl_close($crl);
	return $ret;
}

function mctime_float()
{
	 list($usec, $sec) = explode(" ", microtime());
	 return ((float)$usec + (float)$sec);
}

/** 
	Match a phone number against an array of patterns
	return array containing
	'pattern' = the pattern that matched
	'number' = the number that matched, after applying rules
	'status' = true if a valid array was supplied, false if not
	
*/

function match_pattern_all($array, $number){

	// If we did not get an array, it's probably a list. Convert it to an array.
	if(!is_array($array)){
		$array =  explode("\n",trim($array));		
	}

	$match = false;
	$pattern = false;
	
	// Search for a match
	foreach($array as $pattern){
		// Strip off any leading underscore
		$pattern = (substr($pattern,0,1) == "_")?trim(substr($pattern,1)):trim($pattern);
		if($match = match_pattern($pattern,$number)){
			break;
		}elseif($pattern == $number){
			$match = $number;
			break;
		}
	}

	// Return an array with our results
	return array(
		'pattern' => $pattern,
		'number' => $match,
		'status' => (isset($array[0]) && (strlen($array[0])>0))
	);
}

/**
	Parses Asterisk dial patterns and produces a resulting number if the match is successful or false if there is no match.
*/

function match_pattern($pattern, $number)
{
	global $debug;
	$pattern = trim($pattern);
	$p_array = str_split($pattern);
	$tmp = "";
	$expression = "";
	$new_number = false;
	$remove = NULL;
	$insert = "";
	$error = false;
	$wildcard = false;
	$match = $pattern?true:false;
	$regx_num = "/^\[[0-9]+(\-*[0-9])[0-9]*\]/i";
	$regx_alp = "/^\[[a-z]+(\-*[a-z])[a-z]*\]/i";

	// Try to build a Regular Expression from the dial pattern
	$i = 0;
	while (($i < strlen($pattern)) && (!$error) && ($pattern))
	{
		switch(strtolower($p_array[$i]))
		{
			case 'x':
				// Match any number between 0 and 9
				$expression .= $tmp."[0-9]";
				$tmp = "";
				break;
			case 'z':
				// Match any number between 1 and 9
				$expression .= $tmp."[1-9]";
				$tmp = "";
				break;
			case 'n':
				// Match any number between 2 and 9
				$expression .= $tmp."[2-9]";
				$tmp = "";
				break;
			case '[':
				// Find out if what's between the brackets is a valid expression.
				// If so, add it to the regular expression.
				if(preg_match($regx_num,substr($pattern,$i),$matches)
					||preg_match($regx_alp,substr(strtolower($pattern),$i),$matches))
				{
					$expression .= $tmp."".$matches[0];
					$i = $i + (strlen($matches[0])-1);
					$tmp = "";
				}
				else
				{
					$error = "Invalid character class";
				}
				break;
			case '.':
			case '!':
				// Match and number, and any amount of them
				if(!$wildcard){
					$wildcard = true;
					$expression .= $tmp."[0-9]+";
					$tmp = "";
				}else{
					$error = "Cannot have more than one wildcard";
				}
				break;
			case '+':
				// Prepend any numbers before the '+' to the final match
                                // Store the numbers that will be prepended for later use
				if(!$wildcard){
					if($insert){
						$error = "Cannot have more than one '+'";
					}elseif($expression){
						$error = "Cannot use '+' after X,Z,N or []'s";
					}else{
						$insert = $tmp;
						$tmp = "";
					}
				}else{
					$error = "Cannot have '+' after wildcard";
				}
				break;
			case '|':
				// Any numbers/expression before the '|' will be stripped
				if(!$wildcard){
					if($remove){
						$error = "Cannot have more than one '|'";
					}else{
						// Move any existing expression to the "remove" expression
						$remove = $tmp."".$expression;
						$tmp = "";
						$expression = "";
					}
				}else{
					$error = "Cannot have '|' after wildcard";
				}
				break;
			default:
				// If it's not any of the above, is it a number betwen 0 and 9?
				// If so, store in a temp buffer.  Depending on what comes next
				// we may use in in an expression, or a prefix, or a removal expression
				if(preg_match("/[0-9]/i",strtoupper($p_array[$i]))){
					$tmp .= strtoupper($p_array[$i]);
				}else{
					$error = "Invalid character '".$p_array[$i]."' in pattern";
				}
		}
		$i++;
	}
	$expression .= $tmp;
	$tmp = "";
	if($error){
		// If we had any error, report them
		$match = false;
		if($debug){print $error." - position $i<br>\n";}
	}else{
		// Else try out the regular expressions we built
		if(isset($remove)){
			// If we had a removal expression, se if it works
			if(preg_match("/^".$remove."/i",$number,$matches)){
				$number = substr($number,strlen($matches[0]));
			}else{
				$match = false;
			}
		}
		// Check the expression for the rest of the number
		if(preg_match("/^".$expression."$/i",$number,$matches)){
			$new_number = $matches[0];
		}else{
			$match = false;
		}
		// If there was a prefix defined, add it.
		$new_number = $insert . "" . $new_number;
		
	}
	if(!$match){
		// If our match failed, return false
		$new_number = false;
	}
	return $new_number;

}
// Заменяет символы из первых кавычек символами из вторых кавычек
function stripAccents($string)
{
	$string = html_entity_decode($string);
	$string = strtr($string,"ЉЊЋљњћџҐµАБВГДЕЖЗИЙКЛМНОПРСТУФХЦШЩЪЫЬЭЯабвгдежзийклмнопрстуфхцшщъыьэя","SOZsozYYuAAAAAAACEEEEIIIIDNOOOOOOUUUUYsaaaaaaaceeeeiiiionoooooouuuuyy");
	$string = str_replace(chr(160), ' ', $string);
	return $string;
}
// mb_detect_encoding — Определение кодировки символов
function isutf8($string)
{
	if (!function_exists('mb_detect_encoding')) {
		return false;
	} else {
		return (mb_detect_encoding($string."e")=="UTF-8");// added a character to the string to avoid the mb detect bug
	}
}
// utf8_decode - конвертирует строку с символами ISO-8859-1, кодированную с UTF-8, в однобайтные ISO-8859-1
function _utf8_decode($string)
{
  	$string= html_entity_decode($string);
  	$tmp = $string;
	$count = 0;
	while (isutf8($tmp))
  	{
  		$tmp = utf8_decode($tmp);
		$count++;
	}

  	for ($i = 0; $i < $count-1 ; $i++)
  	{
    		$string = utf8_decode($string);
  	}
  	return $string;
}
?>
awsswa
Сообщения: 2390
Зарегистрирован: 09 июн 2012, 10:52
Откуда: Россия, Пермь skype: yarick_perm

Re: CallerID на русском

Сообщение awsswa »

Читать лень. Мне в своё время помогло вот это
mysql_query ("SET NAMES utf8");
Это при условии что база в utf8 и mysql тоже настроен на utf8

вот тут http://asteriskforum.ru/viewtopic.php?t=6716&start=25 в самом низу работа с базой в utf8 - на экране все по русски.
платный суппорт по мере возможностей
maxmen77
Сообщения: 34
Зарегистрирован: 17 окт 2010, 15:50

Re: CallerID на русском

Сообщение maxmen77 »

Спасибо за вариант, но это не мой случай, мне кажется.
pitach
Сообщения: 1
Зарегистрирован: 01 ноя 2013, 16:57

Re: CallerID на русском

Сообщение pitach »

Мне в Elastix помогли такие настройки:
В /var/www/html/admin/modules/cidlookup/functions.inc.php
добавить строку:
$ext->add('cidlookup', 'cidlookup_'.$item['cidlookup_id'], '', new ext_mysql_query('resultid', 'connid', 'SET NAMES utf8'));
перед:
$ext->add('cidlookup', 'cidlookup_'.$item['cidlookup_id'], '', new ext_mysql_query('resultid', 'connid', $query));

P.S. При применении изменений в веб-морде Elastix настройки не слетают.
maxmen77
Сообщения: 34
Зарегистрирован: 17 окт 2010, 15:50

Re: CallerID на русском

Сообщение maxmen77 »

Всем спасибо!
После долгих мучений выяснилось, что если callerid происходит через curl, то UTF-8 без костылей (добавлять какой-нить символ дополнительно к определенному имени) не работает, о чем была найдена даже запись аж 2011 года http://lists.digium.com/pipermail/aster ... 66163.html (также описан костыль "if i stick in a ascii char after the name like a period then it will work", к которому я в итоге и пришел).
Так что этот баг до сих пор живее всех живых. Может, это кому-то сэкономит время.
Аватара пользователя
SolarW
Сообщения: 1331
Зарегистрирован: 01 сен 2010, 14:21
Откуда: Днепропетровск, Украина

Re: CallerID на русском

Сообщение SolarW »

chubaka писал(а):FreePBX к сожалению по умолчанию не хочет сохранять CallerID на языках отличных от английского.
Чтобы это исправить нужно удалить !isAlphaNumeric в файле /var/www/html/admin/modules/core/functions.inc.php:6850 (позиция строки может различаться)
Не прошло и ста лет как после какого-то из очередных обновлений в FreePBX 2.11 / 2.12 стало можно вводить Display name на русском языке.
Проверил в версиях актуальных на сегодняшний день.
Stone
Сообщения: 34
Зарегистрирован: 17 фев 2011, 12:13

Re: CallerID на русском

Сообщение Stone »

maxmen77 писал(а):Всем спасибо!
если callerid происходит через curl, то UTF-8 без костылей (добавлять какой-нить символ дополнительно к определенному имени) не работает
Тоже недавно столкнулся. :)
Оказалось, можно без костылей. Достаточно вместо функции CURL использовать SHELL. Все остальное без изменений.
exten => cidlookup,n,Set(CALLERID(name)=${SHELL(curl http://domain.com/api_path/script.php?p ... LERID(num)})})

Может и это кому-то сэкономит время. :D
Ответить
© 2008 — 2024 Asterisk.ru
Digium, Asterisk and AsteriskNOW are registered trademarks of Digium, Inc.
Design and development by PostMet-Netzwerk GmbH