Wanpipe, para Sangoma en trixbox
Lo que necesitamos saber primero y basados en la matris de instalacion es si nuestras versiones de software son las correctas y claro si las tenemos en nuestro Linux/Trixbox

Definamos con encontrar las versiones que tenemos instaladas (Asterisk, Dahdi/Zaptel) ademas del kernel que estamos usando:
1) version del kernel ??
#> uname -r
2.6.18-164.11.1.el5
2) Version de Asterisk ??
#> asterisk -V
Asterisk 1.6.0.22
3) Version de dahdi/zaptel ??
Para Dahdi
#> dahdi_cfg -vvv
DAHDI Tools Version - 2.2.0
DAHDI Version: 2.2.0
Para Zaptel
#> ztcfg -vvv
Zaptel Version: 1.4.12.9.svn.r4590-Xorcom-trunk-r7049
Para la descarga de los RPMs necesarios tan solo utilizaremos el comando “wget X” donde X representa la URL del rpm
Ej:
wget -c ftp://ftp.sangoma.com/linux/custom/shaunt/Trixbox%202.8.0.4/Stock/wanpipe-util-3.5.11.8-0.i686.rpm
Ahora la instalacion :
#> rpm -i wanpipe-modules-2.6.18-128.1.1.el5-3.5.11-0.i686.rpm
#> rpm -i wanpipe-util-3.5.11-0.i686.rpm
Para verificar que todo esta bien instalado podemos utilizar:
#> wanrouter hwprobe verbose
Tendriamos que obtener algo asi: (los resultados pueden variar dependiendo de la tarjeta que tengamos)
----------------------------------------- | Wanpipe Hardware Probe Info (verbose) | ----------------------------------------- 1 . AFT-A200-SH : SLOT=4 : BUS=5 : IRQ=169 : CPU=A : PORT=PRI : HWEC=32 : V=12 +01:FXO: PCIe: PLX1 +02:FXO: PCIe: PLX1 +03:FXS: PCIe: PLX1 +04:FXS: PCIe: PLX1
Link | Descargar los RPM
UPGRADE VicidialNOW 1.3 a asterisk 1.4
![]()
Algo que me ha traido con bastante curiosidad desde hace un par de dias, es como actualizar el asterisk que contiene la distro VicidialNOW, un dialer para Contact Center bastante recomendable.
ahora bien vamos a los que nos trae a este post, actualizar este asterisk bastante viejo 1.2 a la version mas decente 1.4.
rpm -e zaptel-modules-1.2.27-2.2.6.18_164.el5.vnow rpm -e zaptel-devel-1.2.27-1 rpm -e zaptel-1.2.27-1 --nodeps rpm -e asterisk-devel-1.2.30.2-2.vnow rpm -e asterisk-1.2.30.2-2.vnow --nodeps
.
mkdir /usr/src/asterisk-1.4 cd /usr/src/asterisk-1.4 wget http://downloads.asterisk.org/pub/telephony/asterisk/old-releases/asterisk-1.4.21.2.tar.gz wget http://downloads.asterisk.org/pub/telephony/zaptel/zaptel-1.4.12.1.tar.gz wget http://downloads.asterisk.org/pub/telephony/libpri/libpri-1.4.11.3.tar.gz tar xzf asterisk-1.4.21.2.tar.gz tar xzf zaptel-1.4.12.1.tar.gz tar xzf libpri-1.4.11.3.tar.gz
Ahora compilaremos los mas facil libpri y zaptel
cd libpri-1.4.11.3 make clean; make; make install cd ../zaptel-1.4.12.1 ./configure; make clean; make; make install
Ahora si el core de todo Asterisk 1.4
cd ../asterisk-1.4.21.2 wget http://www.eflo.net/files/enter.h wget http://www.eflo.net/files/leave.h mv -f enter.h apps/enter.h mv -f leave.h apps/leave.h wget http://download.vicidial.com/asterisk-patches/1.4-gsm-gcc4.2.patch patch -p1 ./codecs/gsm/Makefile 1.4-gsm-gcc4.2.patch wget http://download.vicidial.com/conf/res_agi_defunct.patch patch -p1 < res_agi_defunct.patch File to patch: res/res_agi.c cd apps/ rm -f app_waitforsilence.c wget http://download.vicidial.com/conf/app_waitforsilence.c cd ../channels/ rm chan_sip.c wget http://download.vicidial.com/conf/chan_sip.c cd ../ ./configure; make clean; make; make install
Listo ahora tenemos nuestro vicidial con Asterisk 1.4.21.2
Coesys 2010 – Telefonia en linux
Contenido del DVD
GoAutodial
2600Hz (openswitch)
Ubuntu 10.04
debugging IAX en Asterisk 1.4
Debido a algunos problemas con un carrier de Voip que me provee sus enlaces via IAX2 he tenido que aprender a tomar la investigación por mi propia cuenta, en realidad voy a describir un poco las herramientas que he utilizado hasta el momento para tratar de encontrar el error.
Primero y lo mas basico vamos a habilitar los logs de asterisk a su mayor capacidad, para esto modificaremos el archivo Logger.conf
[root@srv-pbx asterisk]# pwd /etc/asterisk [root@srv-pbx asterisk]# ls -lha logger.conf -rw-r--r-- 1 root root 144 Sep 9 11:23 logger.conf
En este archivo asterisk define tanto el nivel de reportes, como el nombre de los archivos generados para guardar los mismos.
- debug
- notice
- warning
- error
- verbose
- dtmf
Ejemplos:
debug => debug
console => notice,warning,error
messages => notice,warning,error
full => notice,warning,error,verbose
syslog.local0 => notice,warning,error
[root@srv-pbx asterisk]# cat logger.conf [logfiles] debug => debug console => notice,warning,error messages => notice,warning,error,debug,verbose full => notice,warning,error,verbose
Luego de realizadas estas modificaciones desde nuestro CLI vamos a ejecutar “logger reload” para poner a funcionar los nuevos logs
para no perdernos entre tanta información que a veces asterisk despliega en su consola vamos a colocar un “mute”
srv-pbx*CLI> set verbose 0 Verbosity is now OFF
Seguido esto podemos iniciar a tomar trazas de nuestra actividad IAX2
srv-pbx*CLI> iax2 set debug IAX2 Debugging Enabled
De esto podremos obtener un poco de información que esta relacionada con nuestro trafico/registro/identificación
Rx-Frame Retry[ No] -- OSeqno: 000 ISeqno: 000 Type: IAX Subclass: POKE Timestamp: 00017ms SCall: 03132 DCall: 00000 [172.20.1.141:4569] Rx-Frame Retry[ No] -- OSeqno: 000 ISeqno: 001 Type: IAX Subclass: ACK Timestamp: 00023ms SCall: 03132 DCall: 00001 [172.20.1.141:4569] Tx-Frame Retry[000] -- OSeqno: 000 ISeqno: 000 Type: IAX Subclass: POKE Timestamp: 00004ms SCall: 11911 DCall: 00000 [127.0.0.1:39767] Tx-Frame Retry[000] -- OSeqno: 000 ISeqno: 000 Type: IAX Subclass: POKE Timestamp: 00004ms SCall: 07223 DCall: 00000 [172.20.1.169:4569] Tx-Frame Retry[000] -- OSeqno: 000 ISeqno: 000 Type: IAX Subclass: POKE Timestamp: 00004ms SCall: 13976 DCall: 00000 [127.0.0.1:40726] Tx-Frame Retry[000] -- OSeqno: 000 ISeqno: 000 Type: IAX Subclass: POKE Rx-Frame Retry[ No] -- OSeqno: 000 ISeqno: 000 Type: IAX Subclass: POKE Rx-Frame Retry[ No] -- OSeqno: 000 ISeqno: 000 Type: IAX Subclass: POKE Timestamp: 00004ms SCall: 07951 DCall: 00000 [172.20.1.141:4569] Timestamp: 00004ms SCall: 13976 DCall: 00000 [127.0.0.1:40569]
si esta información no bastara vamos a bajar un poco mas de nivel utilizando tcpdump tanto en el puerto como protocolo
tcpdump -w trace.cap -p -n -s 0 "udp" tcpdump -w trace.cap -p -n -s 0 port 4569
* -p : no iniciar en modo promiscuo y solo los paquetes de asterisk in/out seran capturados
* -n : no utilizar la resolución de DNS para evitarnos nombres innecesarios en nuestra traza
* -s 0 : aqui capturaremos todo el contenido de los paquetes tanto SIP como RTP debido a que nos interesa todo el trafico.
0 significa la información completa del frame.
* -w : con esto mandaremos a escribir la información a un archivo especifico
* 4569 es el puerto estandard en el cual se conecta asterisk via IAX2
ahora el archivo resultante lo podremos analizar mucho mejor con el Wireshark y sus plugs de telefonia
Asterisk, migracion de Master CSV a Mysql
Luego de aprender como guardar todos nuestros CDRs dentro de mysql, me ha surgido la duda de como migrar los ya existentes en el master.csv a la base de datos nueva, bueno primero explico algo de como y porque.
Por que:
Esto corriendo asterisk 1.4 y manejandolo con Vicidial (contact center app) pero este utiliza el custom_cdr.conf en donde el guardado en CVS esta definido de la siguiente forma:
Master.csv => "${CDR(clid)}","${CDR(src)}","${CDR(dst)}","${CDR(dcontext)}",
"${CDR(channel)}","${CDR(dstchannel)}","${CDR(lastapp)}",
"${CDR(lastdata)}","${CDR(start)}","${CDR(answer)}","${CDR(end)}",
"${CDR(duration)}","${CDR(billsec)}","${CDR(disposition)}",
"${CDR(amaflags)}",
"${CDR(accountcode)}","${CDR(uniqueid)}","${CDR(userfield)}"
Que significa esto ?? http://www.voip-info.org/wiki/view/Asterisk+billing
ahora bien he encontrado algunos scripts que dicen ser la herramienta mas util para este tipo de migracion lo cual luego de probarlos ha resultado falso!! jejeje
aqui les dejo el que yo modifique y utilize para que migrara de forma transparente los datos del Master.csv con la configuracion cdr_custom de vicidial.
<?php
/*** process asterisk cdr file (Master.csv) insert usage
* values into a mysql database which is created for use
* with the Asterisk_addons cdr_addon_mysql.so
* The script will only insert NEW records so it is safe
* to run on the same log over-and-over.
*
* Author: John Lange (john@johnlange.ca)
* Date: Version 2 Released July 8, 2008
*
*
* Here is what the script does:
*
* Parse each row from the text log and insert it into the database after testing for a
* matching "calldate, src, duration" record in the database. Note that not all fields are
* tested.
*
* If you have a large existing database it is recomended that you add an index to the calldate
* field which will greatly speed up this import.
*
*/
/*
* Modified by Leif Madsen, July 29, 2009 to add additional columns.
* Original post and code by John Lange: http://www.johnlange.ca/tech-tips/asterisk/asterisk-cdr-csv-mysql-import-v20/
*/
/*
* Modified by Paulo Alvarado, Nov. 09 2009 to run with the custom master.cvs from vicidial now
* Original post and code by John Lange: http://www.johnlange.ca/tech-tips/asterisk/asterisk-cdr-csv-mysql-import-v20/
*/
$locale_db_host = 'localhost';
$locale_db_name = 'asterisk';
$locale_db_login = 'root';
$locale_db_pass = 'vicidialnow';
if($argc == 2) {
$logfile = $argv[1];
} else {
print("Usage ".$argv[0]." <filename>\n");
print("Where filename is the path to the Asterisk csv file to import (Master.csv)\n");
print("This script is safe to run multiple times on a growing log file as it only imports records that are newer than the database\n");
exit(0);
}
// connect to db
$linkmb = mysql_connect($locale_db_host, $locale_db_login, $locale_db_pass) or die("Could not connect : " . mysql_error());
mysql_select_db($locale_db_name, $linkmb) or die("Could not select database $locale_db_name");
//** 1) Find records in the asterisk log file. **
$rows = 0;
$handle = fopen($logfile, "r");
while (($data = fgetcsv($handle, 1000, ",")) !== FALSE) {
// NOTE: the fields in Master.csv can vary. This should work by default on all installations but you may have to edit the next line to match your configuration
list($clid, $src, $dst, $dcontext, $channel, $dstchannel, $lastapp, $lastdata, $start, $answer, $end, $duration, $billsec, $disposition, $amaflag, $accountcode,$uniqueid, $userfield ) = $data;
/** 2) Test to see if the entry is unique **/
$sql="SELECT calldate, src, duration".
" FROM cdr".
" WHERE calldate='$end'".
" AND src='$src'".
" AND duration='$duration'".
" LIMIT 1";
if(!($result = mysql_query($sql, $linkmb))) {
print("Invalid query: " . mysql_error()."\n");
print("SQL: $sql\n");
die();
}
if(mysql_num_rows($result) == 0) { // we found a new record so add it to the DB
// 3) insert each row in the database
$sql = "INSERT INTO cdr (calldate, answerdate, hangupdate, clid, src, dst, dcontext, channel, dstchannel, lastapp, lastdata, duration, billsec, disposition, amaflag, accountcode, uniqueid, userfield)
VALUES('$start', '$answer', '$end', '$clid', '$src', '$dst', '$dcontext', '$channel', '$dstchannel','$lastapp', '$lastdata', '$duration', '$billsec', '$disposition', '$amaflag', '$accountcode', '$uniqueid', '$userfield')";
if(!($result2 = mysql_query($sql, $linkmb))) {
print("Invalid query: " . mysql_error()."\n");
print("SQL: $sql\n");
die();
}
print("Inserted: $end $src $duration\n");
$rows++;
} else {
print("Not unique: $end $src $duration\n");
}
}
fclose($handle);
print("$rows imported\n");
?>
ahora la parte mas dificil, como ejecutarlo:
php import.php Master.csv
Nota: si por algun motivo no funciona el comando php, eso significa que no tienen el paquete php-cli para ejecutar sentencias php en linea de comando.
Asterisk, CDR en mysql
Call Detail Records
Las centrales telefónicas generan los llamados Call Detail Records (CDR) que son archivos o logs que contienen información detallada acerca de las llamadas tanto de donde fueron originadas, terminadas o que pasa por el intercambio de las mismas. Y claro no es sorprendente que los CDR se utilizan para la facturación. Fuente: http://www.voip-info.org/wiki/view/CDR
Ahora bien Asterisk es una central telefonica en la que podemos variar tipo de informacion y almacenamiento que este sistema va a recolectar para sus CDRs
Asterisk puede trabajar sus CDR de las siguientes formas:
-
Csv – archivos de texto con valores separados coma
-
Cdr SQLite – logs de CDR en la base de datos de SQLite
-
Pgsql – logs de CDR en las bases de datos de PostgreSQL
-
Odbc – logs de CDR a cualquier base de datos con soporte unixODBC
-
Mysql – logs de CDR en las bases de datos de MySQL
-
Cdr FreeTDS – logs CDR en MS SQL o a la base de datos de Sybase a través de los conductores de FreeTDS
-
Yada – logs de CDR registrados en cualquier base de datos con soporte yada.
Pero lo que veremos por el momento es como conectar nuestro mysql para guardar los CDRs
Primero vamos a crear la tabla que guardara nuestros datos en el Mysql
CREATE DATABASE asterisk; GRANT INSERT ON asterisk.* TO asterisk@localhost IDENTIFIED BY 'tu_clave'; USE asterisk; CREATE TABLE cdr ( calldate datetime NOT NULL default '0000-00-00 00:00:00', clid varchar(80) NOT NULL default '', src varchar(80) NOT NULL default '', dst varchar(80) NOT NULL default '', dcontext varchar(80) NOT NULL default '', channel varchar(80) NOT NULL default '', dstchannel varchar(80) NOT NULL default '', lastapp varchar(80) NOT NULL default '', lastdata varchar(80) NOT NULL default '', duration int(11) NOT NULL default '0', billsec int(11) NOT NULL default '0', disposition varchar(45) NOT NULL default '', amaflags int(11) NOT NULL default '0', accountcode varchar(20) NOT NULL default '', uniqueid varchar(32) NOT NULL default '', userfield varchar(255) NOT NULL default '' );
Segundo tenemos que contar con soporte cdr_mysql en nuestro sistema asterisk, como verificamos esto:
dentro del CLI de asterisk corremos
show modules
…. y la salida tendria que ser algo asi
app_addon_sql_mysql.so Simple Mysql Interface 0 cdr_addon_mysql.so MySQL CDR Backend 0 134 modules loaded
si por alguna razon no los tenemos cargados, podemos compilar los add-ons de asterisk y luego cargarlos
load app_addon_sql_mysql.so load cdr_addon_mysql.so
por ultimo crearemos la conexion entre estos 2 sistemas modificaremos el archivo cdr_mysql.conf
[root@SRV-ASTERISK asterisk]# nano /etc/asterisk/cdr_mysql.conf [global] hostname=127.0.0.1 dbname=asterisk table=cdr password=usuario user=password port=3306 ;sock=/tmp/mysql.sock ;userfield=1
bueno luego de estos 3 pasos quedara listo nuestros CDRs en Mysql para la central telefonica Asterisk.