отправьте боту /start, должен зарегистрироваться пользователь[/quote]yden писал(а):
Старт отправлял - тишина. Т.е бот не прислал приветственное сообщение.[/quote]Что в логе модуля после отправки /start
Отправлено с моего MX_Base через Tapatalk
Модератор: immortal
отправьте боту /start, должен зарегистрироваться пользователь[/quote]yden писал(а):
Код: Выделить всё
$telegram_module->buildInlineKeyboardButton($text="имя объекта","", "Callback_sensor_имя объекта","")
Код: Выделить всё
include_once(DIR_MODULES . 'telegram/telegram.class.php');
$telegram_module = new telegram();
// $option[] = $telegram_module->buildInlineKeyboardButton($text=$state." ".$obj,"","Callback_fm_".$dir."/".$obj,"");
$option = array(
$telegram_module->buildInlineKeyboardButton($text="all_in_one","", "Callback_sensor_all_in_one",""),
$telegram_module->buildInlineKeyboardButton($text="current","", "Callback_sensor_current","")
) ;
$count_row = 3;
$option = array_chunk($option, $count_row);
$keyb = $telegram_module->buildInlineKeyBoard($option);
$content = array('chat_id' => $chat_id, 'text' => "Датчики: ".$dir, 'reply_markup' => $keyb, 'parse_mode' => 'HTML');
$telegram_module->sendContent($content);
Код: Выделить всё
//$telegram_module->sendMessageToAll($callback);
//$telegram_module->sendMessageToAll(substr($callback,9,6));
//$telegram_module->sendMessageToAll(substr($callback,16));
if (substr($callback,9,6) == 'sensor')
{
include_once(DIR_MODULES . 'telegram/telegram.class.php');
$telegram_module = new telegram();
rs('sensor2telega', array('zapros' =>substr($callback,16)));
}
Код: Выделить всё
function get_dt($prop)
{
$sql='SELECT max(h.added ) dt, unix_timestamp(h.added) unx FROM `phistory` h WHERE h.value_ID = (SELECT `ID` FROM `pvalues` WHERE `PROPERTY_NAME` = "'.$prop.'")';
$rec = SQLSelect($sql);
return $rec[0][dt];
}
function get_props($obj)
{
//$sql='SELECT title FROM `properties` where object_id = (SELECT id FROM `objects` where title="'.$obj.'")';
$sql='SELECT substring(PROPERTY_NAME, POSITION("." in PROPERTY_NAME)+1) title FROM `pvalues` where PROPERTY_NAME like "'.$obj.'%"';
$rec = SQLSelect($sql);
foreach ($rec as $prop)
{
//print_r($prop)[title];
$ar2[] = $prop[title];
}
return $ar2;
}
function get_unx($prop)
{
$sql='SELECT max(h.added ) dt, unix_timestamp(h.added) unx FROM `phistory` h WHERE h.value_ID = (SELECT `ID` FROM `pvalues` WHERE `PROPERTY_NAME` = "'.$prop.'")';
$rec = SQLSelect($sql);
return $rec[0][unx];
}
include_once(DIR_MODULES . 'telegram/telegram.class.php');
$telegram_module = new telegram();
$obj=$params['zapros'];
if ($obj==""){$obj="all_in_one";}
$text='';
//$obj="current";
//$objprops=getObjectsByProperty($obj,">","0");
$objprops=get_props($obj);
//print_r($objprops);
foreach ($objprops as $prop)
{
if (is_numeric (gg($obj.".".$prop ))) {$value=round(gg($obj.".".$prop),2);}
else {$value=gg($obj.".".$prop);}
if (gmdate('i',trim(time()-get_unx($obj.".".$prop)))<120)
{$text.=$obj.".".$prop.":".$value." (".preg_replace("|\b[0]+([1-9][\d]*)|is", "\\1", (gmdate('i',trim(time()-get_unx($obj.".".$prop)))))." минут назад)\n";}
else
{$text.=$obj.".".$prop.":".$value." ".preg_replace("|\b[0]+([1-9][\d]*)|is", "\\1", (gmdate('i',trim(time()-get_unx($obj.".".$prop)))))." минут назад (".get_dt($obj.'.'.$prop).")\n";}
}
$text=substr($text,0,4090);
$telegram_module->sendMessageToAll($text);
echo $text;
можно только то что тут прописаноdirectman66 писал(а):Друзья, 2 вопроса:
1) можно ли в текстовую переменную вставлять перевод строки, который бы определял модуль? <br> дает ошибку. (уже нашел \n работает )
2) можно ли отправлять таблицы (не картинки)
burano писал(а):Вопрос разработчику
Прошу пояснить как разобраться почему модуль иногда падает.
Подозреваю что не может что-то в файл c debug сохранить, я пытался разобраться почему сообщения из чата Алисы не отправляются, вот включил даже настроил и сообщения приходят, но теперь падает Telegramm
Возможно баг нашел.
15:33:09 0.26480300 Closing thread: exec php -q ./scripts/cycle_telegram.php --params "a:0:{}">>/var/www/debmes/log_2018-02-11-cycle_telegram.php.txt
15:33:08 0.70601500 External context response: a:1:{s:15:"MATCHED_CONTEXT";i:0;}
15:31:48 0.47571000 Closing thread: exec php -q ./scripts/cycle_telegram.php --params "a:0:{}">>/var/www/debmes/log_2018-02-11-cycle_telegram.php.txt
15:31:47 0.61112300 External context response: a:1:{s:15:"MATCHED_CONTEXT";i:0;}
directman66 писал(а):2Eraser, если сообщение больше 4096 символов, падает цикл. Думаю надо обрабатывать эту ситуацию. Или парсить на куски или обрезать нафик.
Старт отправлял - тишина. Т.е бот не прислал приветственное сообщение.[/quote]Что в логе модуля после отправки /startEraser писал(а):отправьте боту /start, должен зарегистрироваться пользовательyden писал(а):