Soporte & Consultoria
Soporte Remoto y Consultoria skype : ambiorixg12.
Nota no se brinda ningun tipo de consulta o soporte fuera del blog de forma gratuita
martes, 8 de octubre de 2019
ExecIf
ExecIf($["${FROM_DID}"!= ""]?Set(direction=t)
ExecIf($["${FROM_DID}"= ""]?Set(direction=r)
Mixmonitor(,${direction}(/path/filname.wav))
jueves, 3 de octubre de 2019
DAHDI 3.0
DAHDI 3.0 will only compile on kernels 4.15 or newer.
"The setup_timer functions were removed in upstream kernel v4.15, and therefore
this change is needed in order to compile DAHDI for kernels >= 4.15."
this change is needed in order to compile DAHDI for kernels >= 4.15."
Use DAHDI 2.11.1 for older kernel
lunes, 5 de agosto de 2019
Gosub recording
exten=>_x.,1,Set(__type=outbound) | |
exten=>_x.,n,Set(__src=${CALLERID(num)}) | |
exten=>_x.,n,Gosub(monitor,${EXTEN},1) | |
exten=>_x.,n,goto(out${CALLERID(num):0:1},${EXTEN},1) | |
[out3] | |
exten=>_x.,1,Set(CALLERID(num)=40014369) | |
same=>n,Dial(SIP/GrupoEuroAmericano/${EXTEN}) | |
[out2] | |
exten=>_x.,1,Set(CALLERID(num)=40012964) | |
same=>n,Dial(SIP/CrediClick/${EXTEN}) | |
[out1] | |
exten=>_x.,1,Set(CALLERID(num)=40016987) | |
same=>n,Dial(SIP/JuriCobros/${EXTEN}) | |
[monitor] | |
exten=>_x.,1,set(path=/root/recordings/) | |
same=>n,Mixmonitor(${path}${STRFTIME(${EPOCH},,%Y-%m-%d_%H-%M-%S)}-${EXTEN}_${type}_${src}.wav) | |
same=>n,return() | |
viernes, 2 de agosto de 2019
auto dial with dtmf
[autodial] | |
exten=>_x.,1,Noop(${code0} ${code1} ${code2} ${code3} ${code4} ${code5} /${d0} ${d1} ${d2} ${d3} ${d4} ${d5} ${d6} ${d7} ${d8} ${d9}) | |
same=>n,Dial(SIP/commpeak/022001${EXTEN},,M(dtmf)) | |
[macro-dtmf] | |
exten => s,1,Wait(9) | |
same=>n,SendDTMF(${code0}) | |
same=>n,SendDTMF(${code1}) | |
same=>n,SendDTMF(${code2}) | |
same=>n,SendDTMF(${code3}) | |
same=>n,SendDTMF(${code4}) | |
same=>n,SendDTMF(${code5}) | |
same=>n,Wait(9) | |
same=>n,SendDTMF(${d0}) | |
same=>n,SendDTMF(${d1}) | |
same=>n,SendDTMF(${d2}) | |
same=>n,SendDTMF(${d3}) | |
same=>n,SendDTMF(${d4}) | |
same=>n,SendDTMF(${d5}) | |
same=>n,SendDTMF(${d6}) | |
same=>n,SendDTMF(${d7}) | |
same=>n,SendDTMF(${d8}) | |
same=>n,SendDTMF(${d9}) | |
;;;;;;;;;;;;;; | |
<?php | |
/*parameters */ | |
$param= array("host"=>"localhost","port"=>5038,"trunk"=>"tw0","timeout"=>45); | |
/*form variables */ | |
$src=$_GET['src']; | |
$cid=$_GET['cid']; | |
$num=$_GET['num']; | |
/* clean data to accept only numbers*/ | |
function clean($data){ | |
$data=preg_replace('/[^0-9]+/', '', $data); | |
$data = str_split($data); | |
return $data; | |
} | |
$code=clean($_GET['code']); | |
$custnum=clean($_GET['custnum']); | |
$socket = fsockopen($param['host'],$param['port'], $errno, $errstr,$param['timeout']); | |
fputs($socket, "Action: Login\r\n"); | |
fputs($socket, "UserName: admin\r\n"); // | |
fputs($socket, "Secret:ezrerta\r\n\r\n"); // | |
$wrets=fgets($socket,128); | |
echo $wrets; | |
fputs($socket, "Action: Originate\r\n" ); | |
fputs($socket, "Channel: Local/$src@from-internal\r\n" ); | |
fputs($socket, "Exten: $num\r\n" ); | |
fputs($socket, "Context: autodial\r\n" ); | |
fputs($socket, "Priority: 1\r\n" ); | |
fputs($socket, "CallerID: $cid\r\n" ); //No used here | |
fputs($socket, "Variable: __cid=$cid\r\n" ); | |
fputs($socket, "Variable: __code0=$code[0]\r\n" ); | |
fputs($socket, "Variable: __code1=$code[1]\r\n" ); | |
fputs($socket, "Variable: __code2=$code[2]\r\n" ); | |
fputs($socket, "Variable: __code3=$code[3]\r\n" ); | |
fputs($socket, "Variable: __code4=$code[4]\r\n" ); | |
fputs($socket, "Variable: __code5=$code[5]\r\n" ); | |
fputs($socket, "Variable: __d0=$custnum[0]\r\n" ); | |
fputs($socket, "Variable: __d1=$custnum[1]\r\n" ); | |
fputs($socket, "Variable: __d2=$custnum[2]\r\n" ); | |
fputs($socket, "Variable: __d3=$custnum[3]\r\n" ); | |
fputs($socket, "Variable: __d4=$custnum[4]\r\n" ); | |
fputs($socket, "Variable: __d5=$custnum[5]\r\n" ); | |
fputs($socket, "Variable: __d6=$custnum[6]\r\n" ); | |
fputs($socket, "Variable: __d7=$custnum[7]\r\n" ); | |
fputs($socket, "Variable: __d8=$custnum[8]\r\n" ); | |
fputs($socket, "Variable: __d9=$custnum[9]\r\n" ); | |
fputs($socket, "Async: yes\r\n\r\n" ); | |
fputs($socket, "Action: Logoff\r\n\r\n"); | |
sleep (1); | |
$wrets=fgets($socket,128); | |
?> | |
URL | |
http://SERVER-IP-ADDRESS/dial.php?src=6991&num=33488809690&code=125252&custnum=2065274949 |
viernes, 28 de junio de 2019
getting Asterisk variables on agi
#!/usr/bin/php -q
<?php
include ("/var/www/html/agi/phpagi-svn/phpagi.php");
/*
$agi = new AGI();
$agi->answer();
$agi->stream_file("im-sorry");
$dstatus=$agi->get_variable("CHANNEL");
$agi->verbose($dstatus['data'])
?>
<?php
include ("/var/www/html/agi/phpagi-svn/phpagi.php");
/*
$agi->answer();
$agi->stream_file("im-sorry");
$dstatus=$agi->get_variable("CHANNEL");
$agi->verbose($dstatus['data'])
?>
sábado, 20 de abril de 2019
What is the main difference between SIP Proxy and B2BUA?
Knowing that an INVITE request is used to create a SIP session is important, but that only paints half the picture. To make sense of SIP, it’s necessary to understand how to use its protocol elements to create a services infrastructure.Andrew Prokop
SIP Proxy
So, let’s begin with the SIP Proxy. Proxy functionality (stateful and stateless) is defined in RFC3261.
A proxy server relays requests and responses, that means, it accepts request from the UAC, and then forward, or proxy it to the approriate destination, or to another proxy closer to the destination.
A proxy most of the times just acts as a middle man between the client and the terminating server.
A proxy also interprets, and, if necessary, rewrites specific parts of a request, response message before forwarding it.
Stop yawning, I’m going to give you an example.
As usual,
As usual,
192.168.X.X: Caller
192.168.X.P: Proxy
192.168.X.Y: Callee
192.168.X.P: Proxy
192.168.X.Y: Callee
Just focus on INVITE requests (F1, F2) and the most important responses to them (F3, F4).
####################################################
/* F1 */
INVITE sip:callee@192.168.X.P SIP/2.0.
Via: SIP/2.0/UDP 192.168.X.X;branch=z9hG4bK.72ccKTzfG.
Call-ID: ~OsELfLaIG.
Contact: <sip:caller@192.168.X.X>.
Via: SIP/2.0/UDP 192.168.X.X;branch=z9hG4bK.72ccKTzfG.
Call-ID: ~OsELfLaIG.
Contact: <sip:caller@192.168.X.X>.
/* F2 */
INVITE sip:callee@192.168.X.P SIP/2.0.
Record-Route: <sip:192.168.X.P;lr>.
Via: SIP/2.0/UDP 192.168.X.P;branch=z9hG4bKb234.aea6.
Via: SIP/2.0/UDP 192.168.X.X;branch=z9hG4bK.72ccKTzfG.
Call-ID: ~OsELfLaIG.
Contact: <sip:caller@192.168.X.X>.
Record-Route: <sip:192.168.X.P;lr>.
Via: SIP/2.0/UDP 192.168.X.P;branch=z9hG4bKb234.aea6.
Via: SIP/2.0/UDP 192.168.X.X;branch=z9hG4bK.72ccKTzfG.
Call-ID: ~OsELfLaIG.
Contact: <sip:caller@192.168.X.X>.
/* F3 */
SIP/2.0 200 OK.
Via: SIP/2.0/UDP 192.168.X.P;branch=z9hG4bKb234.aea6.
Via: SIP/2.0/UDP 192.168.X.X;branch=z9hG4bK.72ccKTzfG.
Record-Route: <sip:192.168.X.P;lr>.
Call-ID: ~OsELfLaIG.
Contact: <sip:callee@192.168.X.Y>.
Via: SIP/2.0/UDP 192.168.X.P;branch=z9hG4bKb234.aea6.
Via: SIP/2.0/UDP 192.168.X.X;branch=z9hG4bK.72ccKTzfG.
Record-Route: <sip:192.168.X.P;lr>.
Call-ID: ~OsELfLaIG.
Contact: <sip:callee@192.168.X.Y>.
/* F4 */
SIP/2.0 200 OK.
Via: SIP/2.0/UDP 192.168.X.X;branch=z9hG4bK.72ccKTzfG.
Record-Route: <sip:192.168.X.P;lr>.
Call-ID: ~OsELfLaIG.
Contact: <sip:callee@192.168.X.Y>.
Via: SIP/2.0/UDP 192.168.X.X;branch=z9hG4bK.72ccKTzfG.
Record-Route: <sip:192.168.X.P;lr>.
Call-ID: ~OsELfLaIG.
Contact: <sip:callee@192.168.X.Y>.
####################################################
As you can see, all the messages have the same Call-ID header, that means, they’re on the SAME call.
When Caller initiates her INVITE (F1), she puts her location URI into Contact header. Proxy modifies that INVITE (by putting additional Record-Route and Via header), and then forwards it to Callee (F2). Callee accepts that call, and then put his location URI into Contact header in 200 OK response (F3). Proxy forwards 200 OK back to Callee (F4).
Another note, SIP Proxy presents the actual caller in the bottom most Via header to the callee. That behavior is defined in RFC3261, section 16.6.
In this case, later requests within the same dialog, e.g: ACK, BYE are still relayed on Proxy, but it’s not mandatory, since caller/callee knows each other’s location, they could send SIP messages directly. We’ll talk about this in another post, soon.
SIP B2BUA
B2BUA stands for Back-to-Back User Agent. It’s not a standard definition in any RFC, but considered playing roles of both UAS and UAC.
Why would I said that? Because back-to-back user agent operates between both end points of a communication session, and divides the communication channel into two call legs.
B2BUA acts as an UAS in the originating call leg, when receives a call from the caller (UAC), and acts as an UAC in the other leg, by calling the callee (UAS).
192.168.X.X: Caller
192.168.X.B: B2BUA
192.168.X.Y: Callee
####################################################
/* F1 */
INVITE sip:callee@192.168.X.B SIP/2.0
Via: SIP/2.0/UDP 192.168.X.X;branch=z9hG4bKyyH5584Hm48De
Call-ID: 75f09e68-a1e0-1235-bb85-00155d011c0d
Contact: <sip:192.168.X.X>
Via: SIP/2.0/UDP 192.168.X.X;branch=z9hG4bKyyH5584Hm48De
Call-ID: 75f09e68-a1e0-1235-bb85-00155d011c0d
Contact: <sip:192.168.X.X>
/* F2 */
INVITE sip:callee@192.168.X.Y SIP/2.0
Via: SIP/2.0/UDP 192.168.X.B;branch=z9hG4bK1969739b
Contact: <sip:192.168.X.B>
Call-ID: 3dc4f44941bc1b5674b4794d345e2a3c
Via: SIP/2.0/UDP 192.168.X.B;branch=z9hG4bK1969739b
Contact: <sip:192.168.X.B>
Call-ID: 3dc4f44941bc1b5674b4794d345e2a3c
/* F7 */
SIP/2.0 200 OK
Via: SIP/2.0/UDP 192.168.X.B;branch=z9hG4bK1969739b
Call-ID: 3dc4f44941bc1b5674b4794d345e2a3c
Contact: <sip:192.168.X.Y>
Via: SIP/2.0/UDP 192.168.X.B;branch=z9hG4bK1969739b
Call-ID: 3dc4f44941bc1b5674b4794d345e2a3c
Contact: <sip:192.168.X.Y>
/* F8 */
SIP/2.0 200 OK
Via: SIP/2.0/UDP 192.168.X.X;branch=z9hG4bKyyH5584Hm48De
Call-ID: 75f09e68-a1e0-1235-bb85-00155d011c0d
Contact: <sip:192.168.X.B>
Via: SIP/2.0/UDP 192.168.X.X;branch=z9hG4bKyyH5584Hm48De
Call-ID: 75f09e68-a1e0-1235-bb85-00155d011c0d
Contact: <sip:192.168.X.B>
####################################################
So, as you notice, F1 and F8 have the same Call-ID, but they’re different from F2’s and F7’s. That say, F1 and F8 are in the same call, while F2 and F7 are in … hmm, just another call.
That’s the point I want to talk about today, technically, B2BUA consider these two calls are different, but bridged together.
Not like SIP Proxy, no request/response is forwarded from the caller to the callee, or vice versa. When B2BUA receives a message, it creates (or not) a corresponding message, and send it to the bridged call leg. So the endpoints have no idea who’s the actual other endpoint (no footprint on Via, Contact header), because they just communicate to the B2BUA.
That is how topology hiding works.
Okay, that’s enough for today. I hope you’re as thrilled as I am.
References:
Advertisements
REPORT THIS AD
Suscribirse a:
Entradas (Atom)