First time here? Check out the FAQ!

Пожалуйста, войдите здесь. Часто задаваемые вопросы О нас
Задайте Ваш вопрос

Queue log => CURL

0

Доброго времени суток!

FreePBX 13.0.195.18

Asterisk 13.17.0

Есть необходимость передавать queue_log через curl на сторонний сервер для дальнейшей обработки. В таблицу mysql пишется без проблем:

extconfig.conf

[settings]
queue_log
=> mysql,general

Пробуем завернуть на CURL, как-то так:

[settings]
#queue_log => mysql,general
queue_log
=> curl,https://my.server.com/testcurl

Не работает. Модуль есть:

dahua-security*CLI> module show like res_config_curl
Module                         Description                              Use Count  Status      Support Level
res_config_curl
.so             Realtime Curl configuration              0          Running              core
1 modules loaded

Подскажите, пожалуйста, это возможно? В какую сторону копать?

спросил Oct 31 '18

rukit Gravatar rukit
85 9 5

1 Ответ

1

возможно.

платите 50 долларов фрилансеру, вам пишут простой скрипт, который в цикле проверяет, не появилися ли в базе новые строчки и отправляет их вам по curl

Ну это раз вы сами не можете.

или пишите простой odbc драйвер, который умеет только insert и делает curl запрос.

realtime curl тоже работает, но там надо писать фактически драйвер в веб интерфейсе. в частности, вам надо начать с require запроса. и да, все запросы - POST

вот смотрите

pro-sip*CLI> realtime  store queue_log test test
Failed to store record. Check the debug log for possible SQL related entries.
Command 'realtime  store queue_log test test' failed.
[Oct 31 21:38:25] DEBUG[22446]: func_curl.c:534 WriteMemoryCallback: Called with data=0x7f0ffc170800, str=0x7f0fe0000e30, realsize=207, len=16, used=0
[Oct 31 21:38:25] DEBUG[22446]: func_curl.c:538 WriteMemoryCallback: Now, len=256, used=207
[Oct 31 21:38:25] DEBUG[22446]: func_curl.c:709 acf_curl_helper: str='<!DOCTYPE HTML PUBLIC "-//IETF//DTD HTML 2.0//EN">
<html><head>
<title>404 Not Found</title>
</head><body>
<h1>Not Found</h1>
<p>The requested URL /log/store was not found on this server.</p>
</body></html>'

[Oct 31 21:38:25] DEBUG[22446]: pbx_variables.c:544 ast_str_substitute_variables_full: Function CURL(http://pro-sip.net:80/log/store,test=test) result is '<!DOCTYPE HTML PUBLIC "-//IETF//DTD HTML 2.0//EN">
<html><head>
<title>404 Not Found</title>
</
head><body>
<h1>Not Found</h1>
<p>The requested URL /
log/store was not found on this server.</p>
</
body></html>'
pro-sip*CLI>


78.47.159.180 - - [31/Oct/2018:21:37:50 +0100] "POST /
log/require HTTP/1.1" 404 209 "-" "asterisk-libcurl-agent/1.0"
78.47.159.180 - - [31/Oct/2018:21:37:50 +0100] "
POST /log/require HTTP/1.1" 404 209 "-" "asterisk-libcurl-agent/1.0"
78.47.159.180 - - [31/Oct/2018:21:37:50 +0100] "
POST /log/store HTTP/1.1" 404 207 "-" "asterisk-libcurl-agent/1.0"
78.47.159.180 - - [31/Oct/2018:21:38:01 +0100] "
POST /log/store HTTP/1.1" 404 207 "-" "asterisk-libcurl-agent/1.0"
ссылка удалить спам редактировать

ответил Oct 31 '18

meral Gravatar meral flag of Ukraine
23347 24 20 177
http://pro-sip.net/

обновил Oct 31 '18

Comments

"Ну это раз вы сами не можете." проверять в цикле наличие новых записей в таблице сами можем. Но решение не годится, т.к. данные нужно оперативно получить. Не запускать же цикл проверки каждую секунду.

По "надо писать фактически драйвер в веб интерфейсе" не совсем понятно. Веб технологиями владеем, можем написать скрипт. Подскажите, как завернуть queue_log на эту штуку?

rukit (Nov 1 '18)edit
1

Так будет оперативно. С задержкой меньше секунды(ну как настроите). Конечно, подскажу. ОТКРЫТЬ ДОКУМЕНТАЦИЮ и почитать.

meral (Nov 1 '18)edit

Временно нашел способ решения проблемы через membermacro, пока читаем документацию

rukit (Nov 7 '18)edit

да там работы на полдня. что там читать. ее ровно две странички, той документации.

meral (Nov 7 '18)edit

ну Вы же понимаете, что кажется все очень простым, когда знаешь что и как)

rukit (Nov 8 '18)edit

Ну вы же понимаете, что это opensource. Прочитайте исходники и все. Или наймите когото, кто может прочитать и заплатите ему за улучшение документации. Я вот первый раз об этом услышал от вас. Прочитал, попробывал, все ок. 10 минут у меня заняло. А вообще я это всегда и везде решал через скрипт в цикле, так надежнее.

meral (Nov 9 '18)edit

Ваш ответ

Please start posting your answer anonymously - your answer will be saved within the current session and published after you log in or create a new account. Please try to give a substantial answer, for discussions, please use comments and please do remember to vote (after you log in)!
[скрыть предварительный просмотр]

Закладки и информация

Добавить закладку

подписаться на rss ленту новостей

Статистика

Задан: Oct 31 '18

Просмотрен: 752 раз

Обновлен: Nov 01 '18

Проект компании "АТС Дизайн"
Asterisk® и Digium® являются зарегистрированными торговыми марками компании Digium, Inc., США.
IP АТС Asterisk распространяется под лицензией GNU GPL.