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

Входящий номер при поступление звонка, способы получения

Раздел для разработчиков для обсуждения программных и аппаратных продуктов и их реализации.

Модератор: april22

Re: Входящий номер при поступление звонка, способы получения

Сообщение Aven » 07 янв 2016, 13:26

Я когда-то тожеписал софтинку.
Версия не последняя, к сожалению исходники утеряны :(
Решения телефонии на базе Asterisk || http://it-need.ru
Аватар пользователя
Aven
 
Сообщений: 798
Зарегистрирован: 28 янв 2011, 17:20

Re: Входящий номер при поступление звонка, способы получения

Сообщение le7o » 07 янв 2016, 21:46

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

Если получится что то более менее дельно выложу в свободный доступ.
le7o
 
Сообщений: 11
Зарегистрирован: 07 авг 2015, 20:19

Re: Входящий номер при поступление звонка, способы получения

Сообщение whoim » 14 янв 2016, 18:29

А что за crm? Узкозаточенная?

Вообще в планах у меня написать "прослойку", для связки через http api с множеством различных вещей. Точнее, это уже есть - в рабочем виде.

Перевести с ami на ajam, причесать, натыкать хуков, настроечных файлов. Но нехватает пока:
1) реальной задачи, которая финансово отобъет мое время хоть немного
2) заинтересованного партнера со стороны каких-либо crm-систем.

Первая задача сегодня минимально решилась. Появился клиент, ему нужна минимальная связь с 1С.
Теперь нужен 1Сник, способный работать с http из 1Ски.
Условие: партнерство 50/50 с получившимся продуктом.
облачные и локальные сервера asterisk/freepbx/a2billing/crm с полной техподдержкой. skype: whoim2, sipuri: whoim@asterisk.ru
Аватар пользователя
whoim
 
Сообщений: 727
Зарегистрирован: 26 ноя 2013, 23:25
Откуда: Краснодар

Re: Входящий номер при поступление звонка, способы получения

Сообщение Aven » 14 янв 2016, 22:49

А зачем на ajam переводить? Имхо это более медленно... и как то не в реальном времени.
Решения телефонии на базе Asterisk || http://it-need.ru
Аватар пользователя
Aven
 
Сообщений: 798
Зарегистрирован: 28 янв 2011, 17:20

Re: Входящий номер при поступление звонка, способы получения

Сообщение whoim » 15 янв 2016, 03:29

С асинхронными запросами и периодическим вылавливанием евентов - вполне достаточно, при более простой установке модуля на сервер.
облачные и локальные сервера asterisk/freepbx/a2billing/crm с полной техподдержкой. skype: whoim2, sipuri: whoim@asterisk.ru
Аватар пользователя
whoim
 
Сообщений: 727
Зарегистрирован: 26 ноя 2013, 23:25
Откуда: Краснодар

Re: Входящий номер при поступление звонка, способы получения

Сообщение whoim » 12 июл 2016, 14:19

отказался короче от ajam, нуего на. Тормоз. Могу, если кому интересно, скинуть php-код для него.

[Показать] Спойлер:
Код: выделить все
<?php
//settings
$ajam_url = "http://127.0.0.1:8088/asterisk/";
$ajam_username = 'admin';
$ajam_secret = "amipasswd";

$basic_auth_users = array(
  //user admin
  'admin' => array(
    'password' => "adminpasswd",
    'access' => "all",
   ),
  //user don
  'don' => array(
    'password' => "userpasswd",
    'access' => array('donglesendsms', 'donglesendussd', 'dongleshowdevices'),
    'dongle_access' => array('dongle0'),
   ),
);


//basic auth protection
if (!isset($_SERVER['PHP_AUTH_USER'])) {
    header('WWW-Authenticate: Basic realm="My Realm"');
    header('HTTP/1.0 401 Unauthorized');
    die(json_encode(array('response' => "Error", 'message' => "Basic authentication failed")));
} else {
    //check username
    if(!array_key_exists($_SERVER['PHP_AUTH_USER'], $basic_auth_users)) die(json_encode(array('response' => "Error", 'message' => "Basic authentication failed")));
    //check password
    if($basic_auth_users[$_SERVER['PHP_AUTH_USER']]['password'] <> $_SERVER['PHP_AUTH_PW']) die(json_encode(array('response' => "Error", 'message' => "Basic authentication failed")));
    //check access
    if($basic_auth_users[$_SERVER['PHP_AUTH_USER']]['access'] <> "all")
        if(!in_array($_GET['action'], $basic_auth_users[$_SERVER['PHP_AUTH_USER']]['access']))
           die(json_encode(array('response' => "Error", 'message' => "No access to action: {$_GET['action']}")));
    //check dongle access
    if(is_array($basic_auth_users[$_SERVER['PHP_AUTH_USER']]['dongle_access']))
        if(isset($_GET['device']))
          if(!in_array($_GET['device'], $basic_auth_users[$_SERVER['PHP_AUTH_USER']]['dongle_access']))
            die(json_encode(array('response' => "Error", 'message' => "No access to device: {$_GET['device']}")));
}

//auth
list($result, $coo) = ajam("action=Login&username=$ajam_username&secret=$ajam_secret", $coo);
if($result['response'] <> "Success") die(json_encode($result));

//
list($result, $coo) = ajam(http_build_query($_GET), $coo);

if(is_array($basic_auth_users[$_SERVER['PHP_AUTH_USER']]['dongle_access']))
    foreach($result as $key => $val)
      if($val['event'] == "DongleDeviceEntry")
        if(!in_array($val['device'], $basic_auth_users[$_SERVER['PHP_AUTH_USER']]['dongle_access']))
            unset($result[$key]);
     
//die(base64_encode(json_encode($result)));
//die(json_encode($result));
print "<pre>"; print_r($result); die();

function ajam($params, $cookie){
  global $ajam_url;
  $url = "{$ajam_url}mxml?{$params}";
  if(!empty($cookie)) {
      $opts = stream_context_create(array(
         'http'=>array(
         'method'=>"GET",
         'header'=>"User-Agent : Opera/9.80 (X11; Linux i686; U; ru) Presto/2.7.62 Version/11.00 \r\n".
      "Cookie: ".$cookie."\r\n",
         'verify_peer'=>false,
      'verify_peer_name'=>false,         
         ),
         'ssl'=>array(
        "verify_peer"=>false,
        "verify_peer_name"=>false,
      ),
         ));
  } else {
      $opts = stream_context_create(array(
         'http'=>array(
         'method'=>"GET",
         'header'=>"User-Agent : Opera/9.80 (X11; Linux i686; U; ru) Presto/2.7.62 Version/11.00 \r\n",
         'verify_peer'=>false,
      'verify_peer_name'=>false,
         ),
         'ssl'=>array(
        "verify_peer"=>false,
        "verify_peer_name"=>false,
      ),
         )); 
  }
  $response = json_decode(json_encode(simplexml_load_string(file_get_contents($url, false, $opts), "SimpleXMLElement", LIBXML_NOCDATA)), true);
  $return_array = array();
  if(isset($response['response']['generic']['@attributes'])){
    $return_array = $response['response']['generic']['@attributes'];
  }
  else {
    foreach ($response['response'] as $key => $val)
      $return_array[] = $val['generic']['@attributes'];
  }
  if(empty($cookie)) {
     $cookie = Array();
     foreach( $http_response_header as $head){
     if(stristr($head, 'Set-Cookie:' )) $cookie[] = (str_ireplace('Set-Cookie:', '', $head ));
     }
     $cookie = implode('; ',$cookie);
  }
  return array($return_array, $cookie); //['response']['generic']['@attributes']
}

?>
облачные и локальные сервера asterisk/freepbx/a2billing/crm с полной техподдержкой. skype: whoim2, sipuri: whoim@asterisk.ru
Аватар пользователя
whoim
 
Сообщений: 727
Зарегистрирован: 26 ноя 2013, 23:25
Откуда: Краснодар

Пред.

Вернуться в Разработка

Кто сейчас на форуме

Сейчас этот форум просматривают: нет зарегистрированных пользователей и гости: 0

© 2008 — 2018 Asterisk.ru
Digium, Asterisk and AsteriskNOW are registered trademarks of Digium, Inc.
Design and development by PostMet-Netzwerk GmbH