Страница 68 из 193

Re: Модуль "Telegram"

Добавлено: Вс фев 11, 2018 10:37 am
Eraser
yden писал(а):
отправьте боту /start, должен зарегистрироваться пользователь[/quote]

Старт отправлял - тишина. Т.е бот не прислал приветственное сообщение.[/quote]Что в логе модуля после отправки /start

Отправлено с моего MX_Base через Tapatalk

Re: Модуль "Telegram"

Добавлено: Вс фев 11, 2018 10:56 am
directman66
Друзья, 2 вопроса:
1) можно ли в текстовую переменную вставлять перевод строки, который бы определял модуль? <br> дает ошибку. (уже нашел \n работает )
2) можно ли отправлять таблицы (не картинки)

Re: Модуль "Telegram"

Добавлено: Вс фев 11, 2018 11:09 am
directman66
Куда как не в эту тему постить интересные сценарии.
В общем готовый сценарий отправляет все значения объекта и дату измения (или прошедшее время с даты измения). Для добавление новой кнопки просто добавьте в команды телеграмм. 

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

$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);
callback:

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

//$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; 
не забывайте про клавишу спасибо.
SPOILERSPOILER_SHOW
Безымянный.png
Безымянный.png (29.92 КБ) 7988 просмотров

Re: Модуль "Telegram"

Добавлено: Вс фев 11, 2018 1:00 pm
directman66
2Eraser, если сообщение больше 4096 символов, падает цикл. Думаю надо обрабатывать эту ситуацию. Или парсить на куски или обрезать нафик.

Re: Модуль "Telegram"

Добавлено: Вс фев 11, 2018 3:26 pm
Eraser
directman66 писал(а):Друзья, 2 вопроса:
1) можно ли в текстовую переменную вставлять перевод строки, который бы определял модуль? <br> дает ошибку. (уже нашел \n работает )
2) можно ли отправлять таблицы (не картинки)
можно только то что тут прописано
https://core.telegram.org/bots/api#html-style

Re: Модуль "Telegram"

Добавлено: Вс фев 11, 2018 4:05 pm
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;}

Re: Модуль "Telegram"

Добавлено: Вс фев 11, 2018 6:11 pm
directman66
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 символов, падает цикл. Думаю надо обрабатывать эту ситуацию. Или парсить на куски или обрезать нафик.

Re: Модуль

Добавлено: Пн фев 12, 2018 7:44 am
yden
Eraser писал(а):
yden писал(а):
отправьте боту /start, должен зарегистрироваться пользователь
Старт отправлял - тишина. Т.е бот не прислал приветственное сообщение.[/quote]Что в логе модуля после отправки /start

Отправлено с моего MX_Base через Tapatalk[/quote]
Хм, вчера прилетело обновление Телеграмма, все начало отправляться\получать.

Если так оперативно исправляются проблемы, то мне с mjd по пути.

Re: Модуль "Telegram"

Добавлено: Вт фев 13, 2018 10:54 am
directman66
Теперь я напишу, что цикл телеграма падает по любому случаю. Иногда работает тот же самый код, иногда нет. Зависимости уловить не могу. В логах ничего инетерсного не видно.

Re: Модуль "Telegram"

Добавлено: Вт фев 13, 2018 11:13 am
Logrus
раза три падал и не стартовал, причину не понял, в икс рей поставил галку рестарт, пока падений не было