{"id":225837,"date":"2014-06-10T14:38:02","date_gmt":"2014-06-10T10:38:02","guid":{"rendered":"http:\/\/savepearlharbor.com\/?p=225837"},"modified":"-0001-11-30T00:00:00","modified_gmt":"-0001-11-29T21:00:00","slug":"","status":"publish","type":"post","link":"https:\/\/savepearlharbor.com\/?p=225837","title":{"rendered":"<span class=\"post_title\">\u0423\u0432\u0435\u0434\u043e\u043c\u043b\u0435\u043d\u0438\u0435 \u043f\u0440\u0438 \u043f\u0435\u0440\u0435\u0445\u0432\u0430\u0442\u0435 \u0432\u044b\u0437\u043e\u0432\u0430 \u0432 Asterisk<\/span>"},"content":{"rendered":"<div class=\"content html_format\">\n<h4>\u041d\u0435 \u0431\u043e\u043b\u044c\u0448\u0430\u044f \u043f\u0440\u0435\u0434\u044b\u0441\u0442\u043e\u0440\u0438\u044f<\/h4>\n<p>  \u041d\u0430 \u0440\u0430\u0431\u043e\u0442\u0435 \u043f\u0435\u0440\u0438\u043e\u0434\u0438\u0447\u0435\u0441\u043a\u0438 \u043f\u0440\u0438\u0445\u043e\u0434\u0438\u0442\u0441\u044f \u043f\u0435\u0440\u0435\u0445\u0432\u0430\u0442\u044b\u0432\u0430\u0442\u044c \u0432\u044b\u0437\u043e\u0432\u044b, \u0447\u0442\u043e \u0432 \u043f\u0440\u0438\u043d\u0446\u0438\u043f\u0435 \u043d\u0435 \u0431\u0435\u0434\u0430. \u041d\u043e \u0431\u044b\u0432\u0430\u0435\u0442, \u0447\u0442\u043e \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e \u043f\u043e\u0442\u043e\u043c \u043f\u0435\u0440\u0435\u0437\u0432\u043e\u043d\u0438\u0442\u044c \u0442\u043e\u043c\u0443, \u043a\u0442\u043e \u0437\u0432\u043e\u043d\u0438\u043b.<br \/>  \u041d\u043e\u043c\u0435\u0440 \u0441\u043e\u043e\u0442\u0432\u0435\u0442\u0441\u0442\u0432\u0435\u043d\u043d\u043e \u0443 \u043c\u0435\u043d\u044f \u043d\u0435 \u0432\u044b\u0441\u0432\u0435\u0442\u0438\u043b\u0441\u044f \u0438 \u043e\u0431\u044b\u0447\u043d\u043e \u043f\u0440\u0438\u0445\u043e\u0434\u0438\u0442\u0441\u044f \u043b\u0435\u0437\u0442\u044c \u0432 cdr&#8217;\u043a\u0438 \u0432 mysql \u0438\u043b\u0438 \u043f\u043e\u0434\u043e\u0439\u0442\u0438 \u043a \u0442\u0435\u043b\u0435\u0444\u043e\u043d\u0443 \u043d\u0430\u043f\u0430\u0440\u043d\u0438\u043a\u0430 \u0438 \u0438\u0441\u043a\u0430\u0442\u044c \u043d\u043e\u043c\u0435\u0440 \u0442\u0435\u043b\u0435\u0444\u043e\u043d\u0430.<br \/>  \u041c\u043e\u0436\u043d\u043e \u0432 \u043f\u0440\u0438\u043d\u0446\u0438\u043f\u0435 \u043f\u043e\u043f\u0440\u043e\u0441\u0438\u0442\u044c \u043d\u0430\u043f\u0430\u0440\u043d\u0438\u043a\u0430 \u0432\u043a\u043b\u044e\u0447\u0430\u0442\u044c \u043f\u0435\u0440\u0435\u0430\u0434\u0440\u0435\u0441\u0430\u0446\u0438\u044e \u043d\u0430 \u0442\u0435\u043b\u0435\u0444\u043e\u043d\u043d\u043e\u043c \u0430\u043f\u043f\u0430\u0440\u0430\u0442\u0435, \u043d\u043e \u0443\u0445\u043e\u0434\u0438\u0442 \u043e\u043d \u043d\u0430 \u043f\u0430\u0440\u0443 \u043c\u0438\u043d\u0443\u0442, \u0434\u0430 \u0438 \u043c\u044b \u043d\u0435 \u0438\u0449\u0435\u043c \u043b\u0435\u0433\u043a\u0438\u0445 \u043f\u0443\u0442\u0435\u0439.<\/p>\n<p>  \u0418\u0442\u0430\u043a, \u0447\u0442\u043e \u043c\u044b \u0438\u043c\u0435\u0435\u043c: \u043e\u0444\u0438\u0441\u043d\u0430\u044f \u0410\u0422\u0421 \u043d\u0430 Asterisk (\u0432\u0435\u0440\u0441\u0438\u044f = 1.8.15.1), \u0440\u0435\u0430\u043b\u0438\u0437\u043e\u0432\u0430\u043d\u0430 \u0444\u0443\u043d\u043a\u0446\u0438\u044f \u043f\u0435\u0440\u0435\u0445\u0432\u0430\u0442\u0430 \u0432\u044b\u0437\u043e\u0432\u0430 \u0438 \u0443\u0432\u0435\u0434\u043e\u043c\u043b\u0435\u043d\u0438\u0439 \u043e \u0437\u0432\u043e\u043d\u043a\u0435 \u0447\u0435\u0440\u0435\u0437 jabber.<\/p>\n<p>  \u0418\u043d\u0444\u043e\u0440\u043c\u0430\u0446\u0438\u0438 \u043f\u043e \u043f\u043e\u0432\u043e\u0434\u0443 \u043d\u0430\u0441\u0442\u0440\u043e\u0439\u043a\u0438 \u043f\u0435\u0440\u0435\u0445\u0432\u0430\u0442\u0430 \u0432\u044b\u0437\u043e\u0432\u0430, \u043e\u0442\u043f\u0440\u0430\u0432\u043a\u0438 \u0443\u0432\u0435\u0434\u043e\u043c\u043b\u0435\u043d\u0438\u0439 c \u043f\u043e\u043c\u043e\u0449\u044c\u044e jabber \u0434\u043e\u0441\u0442\u0430\u0442\u043e\u0447\u043d\u043e \u0432 \u043f\u0440\u043e\u0441\u0442\u043e\u0440\u0430\u0445 \u0438\u043d\u0442\u0435\u0440\u043d\u0435\u0442\u0430, \u0442\u0430\u043a \u0447\u0442\u043e \u0441\u0440\u0430\u0437\u0443 \u043e\u043f\u0438\u0448\u0443 \u043e \u0440\u0435\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u0438 \u043f\u043e\u043b\u0443\u0447\u0435\u043d\u0438\u044f \u0443\u0432\u0435\u0434\u043e\u043c\u043b\u0435\u043d\u0438\u044f \u043f\u0440\u0438 \u043f\u0435\u0440\u0435\u0445\u0432\u0430\u0442\u0435 \u0432\u044b\u0437\u043e\u0432\u0430.<br \/>  <a name=\"habracut\"><\/a>  <\/p>\n<h4>\u041d\u0430\u0447\u043d\u0435\u043c \u0441 Mysql (\u0432\u0435\u0440\u0441\u0438\u044f = Server version: 5.5.31-0+wheezy1 (Debian)):<\/h4>\n<p>  \u0412 \u0431\u0430\u0437\u0435 asteriskcdrdb \u0441\u043e\u0437\u0434\u0430\u0434\u0438\u043c 2 \u0442\u0430\u0431\u043b\u0438\u0446\u044b pickup_message \u0438 pickup_group.<br \/>  \u0412 \u0442\u0430\u0431\u043b\u0438\u0446\u0435 pickup_message, \u0443 \u043d\u0430\u0441 \u0431\u0443\u0434\u0435\u0442 \u0432\u0441\u0435\u0433\u043e 2 \u0441\u0442\u043e\u043b\u0431\u0446\u0430 pg_id \u0438 message:<br \/>  pg_id \u2014 id pickup \u0433\u0440\u0443\u043f\u043f\u044b \u0432 Asterisk;<br \/>  message \u2014 \u043f\u043e\u043b\u0435 \u043a\u0443\u0434\u0430 \u0431\u0443\u0434\u0443\u0442 \u0437\u0430\u043f\u0438\u0441\u044b\u0432\u0430\u0442\u044c\u0441\u044f \u0443\u0432\u0435\u0434\u043e\u043c\u043b\u0435\u043d\u0438\u044f;<\/p>\n<pre><code class=\"bash\">mysql&gt; CREATE TABLE pickup_message     -&gt; (pg_id smallint unsigned, <\/code><\/pre>\n<p>  \u041f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u044b SMALLINT \u0438 UNSIGNED \u0434\u043b\u044f \u0441\u0442\u043e\u043b\u0431\u0446\u0430 pg_id, \u0432\u044b\u0431\u0440\u0430\u043b \u0442.\u043a. \u043f\u043b\u0430\u043d\u0438\u0440\u0443\u044e\u0442\u0441\u044f \u0442\u043e\u043b\u044c\u043a\u043e \u043a\u043e\u0440\u043e\u0442\u043a\u0438\u0435, \u0446\u0435\u043b\u044b\u0435 \u0447\u0438\u0441\u043b\u0430. \u0425\u043e\u0442\u044f \u043c\u043e\u0436\u043d\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u0438 \u0438\u043c\u0435\u043d\u0430 \u0434\u043b\u044f \u0433\u0440\u0443\u043f\u043f \u043f\u0435\u0440\u0435\u0445\u0432\u0430\u0442\u0430.  <\/p>\n<pre><code class=\"bash\">  -&gt; message varchar(128),   -&gt; CONSTRAINT pk_pg_id PRIMARY KEY (pg_id) <\/code><\/pre>\n<p>  \u0412 \u0441\u0442\u043e\u043b\u0431\u0446\u0435 pg_id \u0443 \u043d\u0430\u0441 \u0431\u0443\u0434\u0443\u0442 \u0442\u043e\u043b\u044c\u043a\u043e \u0443\u043d\u0438\u043a\u0430\u043b\u044c\u043d\u044b\u0435 \u0437\u0430\u043f\u0438\u0441\u0438, \u0438 \u0441\u0442\u043e\u043b\u0431\u0435\u0446 \u0431\u0443\u0434\u0435\u0442 \u0441\u043b\u0443\u0436\u0438\u0442\u044c \u0434\u043b\u044f \u0441\u0432\u044f\u0437\u043a\u0438 2-\u0445 \u0442\u0430\u0431\u043b\u0438\u0446.<\/p>\n<pre><code class=\"bash\"> -&gt; ); Query OK, 0 rows affected (0.09 sec) <\/code><\/pre>\n<p>  \u0422\u0430\u0431\u043b\u0438\u0446\u0430 pickup_group \u0441\u043e\u0434\u0435\u0440\u0436\u0438\u0442 \u0438\u043d\u0444\u043e\u0440\u043c\u0430\u0446\u0438\u044e \u043e \u043f\u0440\u0438\u043d\u0430\u0434\u043b\u0435\u0436\u043d\u043e\u0441\u0442\u0438 \u0432\u043d\u0443\u0442\u0440\u0435\u043d\u043d\u0435\u0433\u043e \u043d\u043e\u043c\u0435\u0440\u0430 (peer) \u043a \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u0435\u043d\u043d\u043e\u0439 \u0433\u0440\u0443\u043f\u043f\u0435 \u043f\u0435\u0440\u0435\u0445\u0432\u0430\u0442\u0430 (pg_id). <br \/>  \u0422\u0430\u043a \u0436\u0435 \u0434\u043b\u044f \u0441\u0432\u044f\u0437\u043a\u0438 2 \u0442\u0430\u0431\u043b\u0438\u0446 \u0434\u043e\u0431\u0430\u0432\u0438\u043c FOREIGN KEY () \u0438 REFERENCES.  <\/p>\n<pre><code class=\"bash\">mysql&gt; CREATE TABLE pickup_group     -&gt; (pg_id SMALLINT UNSIGNED,     -&gt; peer SMALLINT UNSIGNED,     -&gt; CONSTRAINT fk_pg_id FOREIGN KEY (pg_id)     -&gt; REFERENCES pickup_message (pg_id)     -&gt; ); Query OK, 0 rows affected (0.08 sec) <\/code><\/pre>\n<p>  \u0417\u0430\u043f\u043e\u043b\u043d\u0438\u043c \u0434\u043b\u044f \u0442\u0435\u0441\u0442\u0430 \u043e\u0431\u0435 \u0442\u0430\u0431\u043b\u0438\u0446\u044b \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0439 \u0438\u043d\u0444\u043e\u0440\u043c\u0430\u0446\u0438\u0435\u0439 \u0433\u0440\u0443\u043f\u043f\u0430 \u043f\u0435\u0440\u0435\u0445\u0432\u0430\u0442\u0430 1, \u0432\u043d\u0443\u0442\u0440\u0435\u043d\u043d\u0438\u0435 \u043d\u043e\u043c\u0435\u0440\u0430 309 \u0438 373:  <\/p>\n<pre><code class=\"bash\">mysql&gt; insert into pickup_message values (1, NULL); Query OK, 1 row affected (0.05 sec)  mysql&gt; insert into pickup_group values (1, 309); Query OK, 1 row affected (0.06 sec)  mysql&gt; insert into pickup_group values (1, 373); Query OK, 1 row affected (0.04 sec)  mysql&gt; select * from pickup_message; +-------+---------+ | pg_id | message | +-------+---------+ |     1 | NULL    | |    33 | NULL    | +-------+---------+ 2 rows in set (0.00 sec)  mysql&gt; select * from pickup_group; +-------+------+ | pg_id | peer | +-------+------+ |     1 |  309 | |     1 |  373 | +-------+------+ 2 rows in set (0.00 sec) <\/code><\/pre>\n<h4>\u041f\u0435\u0440\u0435\u0445\u043e\u0434\u0438\u043c \u043a \u043d\u0430\u0441\u0442\u0440\u043e\u0439\u043a\u0430\u043c Asterisk, \u043e\u0442\u0440\u0435\u0434\u0430\u043a\u0442\u0438\u0440\u0443\u0435\u043c extensions.conf:<\/h4>\n<p>  \u0412 \u043a\u043e\u043d\u0442\u0435\u043a\u0441\u0442\u0435 \u0433\u0434\u0435 \u043e\u0431\u0440\u0430\u0431\u0430\u0442\u044b\u0432\u0430\u0435\u0442\u0441\u044f \u043d\u0430\u0431\u043e\u0440 \u0432\u043d\u0443\u0442\u0440\u0435\u043d\u043d\u0438\u0445 \u043d\u043e\u043c\u0435\u0440\u043e\u0432:<\/p>\n<pre><code class=\"bash\">exten =&gt; _ZXX,1,Macro(jabb-personal-pickup,${EXTEN}) same =&gt; n,Dial(SIP\/${EXTEN},120,t) same =&gt; n,Hangup <\/code><\/pre>\n<p>  \u041c\u0430\u043a\u0440\u043e\u0441 \u0434\u043b\u044f \u043e\u0442\u043f\u0440\u0430\u0432\u043a\u0438 \u0443\u0432\u0435\u0434\u043e\u043c\u043b\u0435\u043d\u0438\u0439 (\u0432 \u043c\u0430\u043a\u0440\u043e\u0441 \u043f\u0435\u0440\u0435\u0434\u0430\u0435\u0442\u0441\u044f \u043e\u0434\u043d\u0430 \u043f\u0435\u0440\u0435\u043c\u0435\u043d\u043d\u0430\u044f ${ARG1}, \u043d\u043e\u043c\u0435\u0440 \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043d\u0430\u0431\u0440\u0430\u043b\u0438):<\/p>\n<pre><code class=\"bash\">[macro-jabb-personal-pickup] exten =&gt; s,1,Set(text=\u0412\u0445\u043e\u0434\u044f\u0449\u0438\u0439 \u0432\u044b\u0437\u043e\u0432 \u043e\u0442 ${CALLERID(number)})   same =&gt; n,MYSQL(Connect connid 127.0.0.1 root PASSWORD asteriskcdrdb)         same =&gt; n,MYSQL(Query resultid ${connid} select pickup_message.pg_id from pickup_message inner join pickup_group where peer = '${ARG1}';) ; #\u0432 \u0434\u0430\u043d\u043d\u043e\u043c \u0437\u0430\u043f\u0440\u043e\u0441\u0435 \u0438\u0449\u0435\u043c \u043a \u043a\u0430\u043a\u043e\u0439 \u0433\u0440\u0443\u043f\u043f\u0435 \u043e\u0442\u043d\u043e\u0441\u0438\u0442\u0441\u044f \u043d\u043e\u043c\u0435\u0440 \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043d\u0430\u0431\u0440\u0430\u043b\u0438 same =&gt; n,MYSQL(Fetch fetchid ${resultid} pg_id) same =&gt; n,GotoIf($[&quot;${fetchid}&quot;=&quot;1&quot;]?yes:no)  same =&gt; n(yes),MYSQL(Query resultid ${connid} update pickup_message set message ='${text}' where pg_id = '${pg_id}') ; #\u0435\u0441\u043b\u0438 \u043d\u043e\u043c\u0435\u0440 \u0435\u0441\u0442\u044c \u0432 \u0433\u0440\u0443\u043f\u043f\u0435, \u0442\u043e \u0437\u0430\u043f\u0438\u0448\u0435\u043c \u0432 \u044f\u0447\u0435\u0439\u043a\u0443 \u0433\u0440\u0443\u043f\u043f\u044b message \u043f\u0435\u0440\u0435\u043c\u0435\u043d\u043d\u0443\u044e text same =&gt; n(no),MYSQL(Clear ${resultid}) same =&gt; n,MYSQL(Query resultid ${connid} select jabb_id from jabber where number=${ARG1}) same =&gt; n,MYSQL(Fetch fetchid ${resultid} jabb_id) same =&gt; n,GotoIf($[&quot;${fetchid}&quot;=&quot;1&quot;]?ok:bad) same =&gt; n(ok),JabberSend(asterisk,${jabb_id},${text}) same =&gt; n(bad),MYSQL(Clear ${resultid}) same =&gt; n,MYSQL(Disconnect ${connid}) <\/code><\/pre>\n<p>  \u0418 \u0441\u043e\u0431\u0441\u0442\u0432\u0435\u043d\u043d\u043e \u043a\u043e\u043d\u0442\u0435\u043a\u0441\u0442 \u043f\u0440\u0438 \u043f\u0435\u0440\u0435\u0445\u0432\u0430\u0442\u0435 \u0437\u0432\u043e\u043d\u043a\u0430 (*8). \u0417\u0434\u0435\u0441\u044c \u043c\u044b \u043f\u0440\u043e\u0432\u0435\u0440\u044f\u0435\u043c \u043a \u043a\u0430\u043a\u043e\u0439 \u0433\u0440\u0443\u043f\u043f\u0435 \u043c\u044b \u043e\u0442\u043d\u043e\u0441\u0438\u043c\u0441\u044f \u0438 \u0435\u0441\u0442\u044c \u043b\u0438 \u0441\u043e\u043e\u0431\u0449\u0435\u043d\u0438\u044f \u0432 \u043d\u0430\u0448\u0435\u0439 \u0433\u0440\u0443\u043f\u043f\u0435.<br \/>  \u0422.\u0435. \u043f\u0440\u0438 \u0432\u0445\u043e\u0434\u044f\u0449\u0435\u043c \u0437\u0432\u043e\u043d\u043a\u0435 \u043d\u0430 \u0432\u043d\u0443\u0442\u0440\u0435\u043d\u043d\u0438\u0439 \u043d\u043e\u043c\u0435\u0440, \u0432 \u044f\u0447\u0435\u0439\u043a\u0443 \u0433\u0440\u0443\u043f\u043f\u044b \u0437\u0430\u043f\u0438\u0441\u044b\u0432\u0430\u0435\u0442\u0441\u044f \u0438\u043d\u0444\u043e\u0440\u043c\u0430\u0446\u0438\u044f \u043e \u0437\u0432\u043e\u043d\u044f\u0449\u0435\u043c, \u0430 \u043f\u0435\u0440\u0435\u0445\u0432\u0430\u0442\u043e\u043c \u043c\u044b \u044d\u0442\u0443 \u0438\u043d\u0444\u043e\u0440\u043c\u0430\u0446\u0438\u044e \u0437\u0430\u0431\u0438\u0440\u0430\u0435\u043c.<br \/>  \u0412 \u043f\u0440\u0438\u043d\u0446\u0438\u043f\u0435 \u0432\u0441\u0435 \u043f\u0440\u043e\u0441\u0442\u043e:  <\/p>\n<pre><code class=\"bash\">exten =&gt; *8,1,NoOp(pickup) same =&gt; n,MYSQL(Connect connid 127.0.0.1 root PASSWORD asteriskcdrdb) same =&gt; n,MYSQL(Query resultid ${connid} select pickup_message.message from pickup_message inner join pickup_group where peer = ${CALLERID(number)}) ; #\u0437\u0430\u043f\u0440\u043e\u0441 \u043d\u0430 \u043f\u0440\u043e\u0432\u0435\u0440\u043a\u0443 \u043a \u043a\u0430\u043a\u043e\u0439 \u0433\u0440\u0443\u043f\u043f\u0435 \u043f\u0435\u0440\u0435\u0445\u0432\u0430\u0442\u0430 \u043c\u044b \u043e\u0442\u043d\u043e\u0441\u0438\u043c\u0441\u044f same =&gt; n,MYSQL(Fetch fetchid ${resultid} message)  same =&gt; n,GotoIf($[&quot;${fetchid}&quot;=&quot;1&quot;]?message:no)  ; #\u043f\u0440\u043e\u0432\u0435\u0440\u044f\u0435\u043c \u0447\u0442\u043e \u0432 \u0437\u0430\u043f\u0440\u043e\u0441\u0435 \u0435\u0441\u0442\u044c \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442          same =&gt; n(message),Set(text=\u041f\u0435\u0440\u0435\u0445\u0432\u0430\u0442 \u0432\u044b\u0437\u043e\u0432\u0430. ${message}) ;# \u0432 \u043f\u0435\u0440\u0435\u043c\u0435\u043d\u043d\u0443\u044e text \u0437\u0430\u043f\u0438\u0448\u0435\u043c \u0434\u0430\u043d\u043d\u044b\u0435 \u0438\u0437 \u044f\u0447\u0435\u0439\u043a\u0438 \u043d\u0430\u0448\u0435\u0439 \u0433\u0440\u0443\u043f\u043f\u044b same =&gt; n,MYSQL(Clear ${resultid}) same =&gt; n,MYSQL(Query resultid ${connid} select jabb_id from jabber where number=${CALLERID(number)})  ;# \u0438\u0449\u0435\u043c id jabber \u0434\u043b\u044f peer'a, \u0442.\u043a. \u043d\u0435 \u0432\u0441\u0435 \u0435\u0433\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044e\u0442  same =&gt; n,MYSQL(Fetch fetchid ${resultid} jabb_id)  same =&gt; n,GotoIf($[&quot;${fetchid}&quot;=&quot;1&quot;]?yes:no)   ; # \u043f\u0440\u043e\u0432\u0435\u0440\u044f\u0435\u043c \u0447\u0442\u043e \u0432 \u0437\u0430\u043f\u0440\u043e\u0441\u0435 \u0435\u0441\u0442\u044c \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442 same =&gt; n(yes),JabberSend(asterisk,${jabb_id},${text}) same =&gt; n(no),MYSQL(Clear ${resultid}) same =&gt; n,MYSQL(Query resultid ${connid} update pickup_message set message ='NULL' where message = '${message}') same =&gt; n,MYSQL(Disconnect ${connid}) same =&gt; n,PickUP() <\/code><\/pre>\n<p>  \u0412 \u0438\u0442\u043e\u0433\u0435, \u043f\u0440\u0438 \u043f\u0435\u0440\u0435\u0445\u0432\u0430\u0442\u0435 \u0432\u044b\u0437\u043e\u0432\u0430, \u0432 jabber \u043f\u0440\u0438\u0445\u043e\u0434\u044f\u0442 \u0441\u043e\u043e\u0431\u0449\u0435\u043d\u0438\u044f \u0442\u0430\u043a\u043e\u0433\u043e \u0440\u043e\u0434\u0430:  <\/p>\n<pre><code class=\"bash\">[15:09:07] &lt;Office Manager&gt; \u041f\u0435\u0440\u0435\u0445\u0432\u0430\u0442 \u0432\u044b\u0437\u043e\u0432\u0430. \u041f\u0435\u0440\u0441\u043e\u043d\u0430\u043b\u044c\u043d\u044b\u0439 \u0437\u0432\u043e\u043d\u043e\u043a. 302 [15:12:08] &lt;Office Manager&gt; \u041f\u0435\u0440\u0435\u0445\u0432\u0430\u0442 \u0432\u044b\u0437\u043e\u0432\u0430. \u041f\u0435\u0440\u0441\u043e\u043d\u0430\u043b\u044c\u043d\u044b\u0439 \u0437\u0432\u043e\u043d\u043e\u043a. 226 [15:25:47] &lt;Office Manager&gt; \u041f\u0435\u0440\u0435\u0445\u0432\u0430\u0442 \u0432\u044b\u0437\u043e\u0432\u0430. \u041f\u0435\u0440\u0441\u043e\u043d\u0430\u043b\u044c\u043d\u044b\u0439 \u0437\u0432\u043e\u043d\u043e\u043a. 106 [15:32:40] &lt;Office Manager&gt; \u041f\u0435\u0440\u0441\u043e\u043d\u0430\u043b\u044c\u043d\u044b\u0439 \u0437\u0432\u043e\u043d\u043e\u043a. 116 <\/code><\/pre>\n<p>  \u041d\u0430\u0434\u0435\u044e\u0441\u044c, \u0434\u043b\u044f \u043a\u043e\u0433\u043e-\u0442\u043e \u0434\u0430\u043d\u043d\u0430\u044f \u0438\u043d\u0444\u043e\u0440\u043c\u0430\u0446\u0438\u044f \u0431\u0443\u0434\u0435\u0442 \u043f\u043e\u043b\u0435\u0437\u043d\u043e\u0439. \t\t\t<\/p>\n<div class=\"clear\"><\/div>\n<\/p><\/div>\n<p> \u0441\u0441\u044b\u043b\u043a\u0430 \u043d\u0430 \u043e\u0440\u0438\u0433\u0438\u043d\u0430\u043b \u0441\u0442\u0430\u0442\u044c\u0438 <a href=\"http:\/\/habrahabr.ru\/post\/225837\/\"> http:\/\/habrahabr.ru\/post\/225837\/<\/a><\/p>\n","protected":false},"excerpt":{"rendered":"<div class=\"content html_format\">\n<h4>\u041d\u0435 \u0431\u043e\u043b\u044c\u0448\u0430\u044f \u043f\u0440\u0435\u0434\u044b\u0441\u0442\u043e\u0440\u0438\u044f<\/h4>\n<p>  \u041d\u0430 \u0440\u0430\u0431\u043e\u0442\u0435 \u043f\u0435\u0440\u0438\u043e\u0434\u0438\u0447\u0435\u0441\u043a\u0438 \u043f\u0440\u0438\u0445\u043e\u0434\u0438\u0442\u0441\u044f \u043f\u0435\u0440\u0435\u0445\u0432\u0430\u0442\u044b\u0432\u0430\u0442\u044c \u0432\u044b\u0437\u043e\u0432\u044b, \u0447\u0442\u043e \u0432 \u043f\u0440\u0438\u043d\u0446\u0438\u043f\u0435 \u043d\u0435 \u0431\u0435\u0434\u0430. \u041d\u043e \u0431\u044b\u0432\u0430\u0435\u0442, \u0447\u0442\u043e \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e \u043f\u043e\u0442\u043e\u043c \u043f\u0435\u0440\u0435\u0437\u0432\u043e\u043d\u0438\u0442\u044c \u0442\u043e\u043c\u0443, \u043a\u0442\u043e \u0437\u0432\u043e\u043d\u0438\u043b.<br \/>  \u041d\u043e\u043c\u0435\u0440 \u0441\u043e\u043e\u0442\u0432\u0435\u0442\u0441\u0442\u0432\u0435\u043d\u043d\u043e \u0443 \u043c\u0435\u043d\u044f \u043d\u0435 \u0432\u044b\u0441\u0432\u0435\u0442\u0438\u043b\u0441\u044f \u0438 \u043e\u0431\u044b\u0447\u043d\u043e \u043f\u0440\u0438\u0445\u043e\u0434\u0438\u0442\u0441\u044f \u043b\u0435\u0437\u0442\u044c \u0432 cdr&#8217;\u043a\u0438 \u0432 mysql \u0438\u043b\u0438 \u043f\u043e\u0434\u043e\u0439\u0442\u0438 \u043a \u0442\u0435\u043b\u0435\u0444\u043e\u043d\u0443 \u043d\u0430\u043f\u0430\u0440\u043d\u0438\u043a\u0430 \u0438 \u0438\u0441\u043a\u0430\u0442\u044c \u043d\u043e\u043c\u0435\u0440 \u0442\u0435\u043b\u0435\u0444\u043e\u043d\u0430.<br \/>  \u041c\u043e\u0436\u043d\u043e \u0432 \u043f\u0440\u0438\u043d\u0446\u0438\u043f\u0435 \u043f\u043e\u043f\u0440\u043e\u0441\u0438\u0442\u044c \u043d\u0430\u043f\u0430\u0440\u043d\u0438\u043a\u0430 \u0432\u043a\u043b\u044e\u0447\u0430\u0442\u044c \u043f\u0435\u0440\u0435\u0430\u0434\u0440\u0435\u0441\u0430\u0446\u0438\u044e \u043d\u0430 \u0442\u0435\u043b\u0435\u0444\u043e\u043d\u043d\u043e\u043c \u0430\u043f\u043f\u0430\u0440\u0430\u0442\u0435, \u043d\u043e \u0443\u0445\u043e\u0434\u0438\u0442 \u043e\u043d \u043d\u0430 \u043f\u0430\u0440\u0443 \u043c\u0438\u043d\u0443\u0442, \u0434\u0430 \u0438 \u043c\u044b \u043d\u0435 \u0438\u0449\u0435\u043c \u043b\u0435\u0433\u043a\u0438\u0445 \u043f\u0443\u0442\u0435\u0439.<\/p>\n<p>  \u0418\u0442\u0430\u043a, \u0447\u0442\u043e \u043c\u044b \u0438\u043c\u0435\u0435\u043c: \u043e\u0444\u0438\u0441\u043d\u0430\u044f \u0410\u0422\u0421 \u043d\u0430 Asterisk (\u0432\u0435\u0440\u0441\u0438\u044f = 1.8.15.1), \u0440\u0435\u0430\u043b\u0438\u0437\u043e\u0432\u0430\u043d\u0430 \u0444\u0443\u043d\u043a\u0446\u0438\u044f \u043f\u0435\u0440\u0435\u0445\u0432\u0430\u0442\u0430 \u0432\u044b\u0437\u043e\u0432\u0430 \u0438 \u0443\u0432\u0435\u0434\u043e\u043c\u043b\u0435\u043d\u0438\u0439 \u043e \u0437\u0432\u043e\u043d\u043a\u0435 \u0447\u0435\u0440\u0435\u0437 jabber.<\/p>\n<p>  \u0418\u043d\u0444\u043e\u0440\u043c\u0430\u0446\u0438\u0438 \u043f\u043e \u043f\u043e\u0432\u043e\u0434\u0443 \u043d\u0430\u0441\u0442\u0440\u043e\u0439\u043a\u0438 \u043f\u0435\u0440\u0435\u0445\u0432\u0430\u0442\u0430 \u0432\u044b\u0437\u043e\u0432\u0430, \u043e\u0442\u043f\u0440\u0430\u0432\u043a\u0438 \u0443\u0432\u0435\u0434\u043e\u043c\u043b\u0435\u043d\u0438\u0439 c \u043f\u043e\u043c\u043e\u0449\u044c\u044e jabber \u0434\u043e\u0441\u0442\u0430\u0442\u043e\u0447\u043d\u043e \u0432 \u043f\u0440\u043e\u0441\u0442\u043e\u0440\u0430\u0445 \u0438\u043d\u0442\u0435\u0440\u043d\u0435\u0442\u0430, \u0442\u0430\u043a \u0447\u0442\u043e \u0441\u0440\u0430\u0437\u0443 \u043e\u043f\u0438\u0448\u0443 \u043e \u0440\u0435\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u0438 \u043f\u043e\u043b\u0443\u0447\u0435\u043d\u0438\u044f \u0443\u0432\u0435\u0434\u043e\u043c\u043b\u0435\u043d\u0438\u044f \u043f\u0440\u0438 \u043f\u0435\u0440\u0435\u0445\u0432\u0430\u0442\u0435 \u0432\u044b\u0437\u043e\u0432\u0430.  <\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[],"tags":[],"class_list":["post-225837","post","type-post","status-publish","format-standard","hentry"],"_links":{"self":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/225837","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=225837"}],"version-history":[{"count":0,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/225837\/revisions"}],"wp:attachment":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=225837"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=225837"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=225837"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}