B Establishment of the VoIP link » History » Version 5
VEILLARD GAROZ, Loïc, 03/20/2015 07:05 PM
1 | 1 | piat, charles ugo | h1. B Establishment of the VoIP link |
---|---|---|---|
2 | 1 | piat, charles ugo | |
3 | 2 | VEILLARD GAROZ, Loïc | h3. Asterisk IP PBX |
4 | 2 | VEILLARD GAROZ, Loïc | |
5 | 2 | VEILLARD GAROZ, Loïc | We had implemented as explained before, a working server running Asterisk 13.2.0 over Ubuntu Server 14.04.2. In order to connect to the asterisk server we can choose one of the following procedures: |
6 | 2 | VEILLARD GAROZ, Loïc | |
7 | 5 | VEILLARD GAROZ, Loïc | * Link through the router |
8 | 5 | VEILLARD GAROZ, Loïc | |
9 | 1 | piat, charles ugo | Any component in the local LAN generated by the mikrotik server (by Ethernet or WiFi) may be able to connect to the asterisk server by ssh. For example with a computer running linux we can just type the following: |
10 | 4 | VEILLARD GAROZ, Loïc | |
11 | 1 | piat, charles ugo | shh kasat@192.168.88.242 |
12 | 4 | VEILLARD GAROZ, Loïc | |
13 | 1 | piat, charles ugo | The credentials for our case are the following: |
14 | 2 | VEILLARD GAROZ, Loïc | |
15 | 4 | VEILLARD GAROZ, Loïc | Server IP: 192.168.88.242: This address can be changed in the DCHP server of the mikrotik router. A local static address can be configured, while we discourage it |
16 | 2 | VEILLARD GAROZ, Loïc | Client: kasat |
17 | 2 | VEILLARD GAROZ, Loïc | Password: gogolgogol |
18 | 2 | VEILLARD GAROZ, Loïc | |
19 | 1 | piat, charles ugo | In order to get root privileges during the session we can add "sudo" to the command that we want to run, or type the following command: |
20 | 3 | VEILLARD GAROZ, Loïc | |
21 | 2 | VEILLARD GAROZ, Loïc | sudo -i |
22 | 1 | piat, charles ugo | |
23 | 1 | piat, charles ugo | Which will grant to kasat root privileges during all the ssh session. |
24 | 1 | piat, charles ugo | |
25 | 5 | VEILLARD GAROZ, Loïc | * Direct configuration |
26 | 5 | VEILLARD GAROZ, Loïc | |
27 | 2 | VEILLARD GAROZ, Loïc | The server can be configured directly with a screen and a keyboard connected to the Intel NUC. |
28 | 1 | piat, charles ugo | |
29 | 1 | piat, charles ugo | h3. Configuration of the internal call |
30 | 1 | piat, charles ugo | |
31 | 1 | piat, charles ugo | The configuration of the asterisk for the 3 handsets is implemented in the files sip.conf and extensions.conf. We register the 3 handsets in the file sip.conf and we build the channels in the extensions.conf. We had the choice to configure asterisk through the web interface or directly in the configuration files. We had chosen the second options because the first one generates errors in the handset registering. |
32 | 1 | piat, charles ugo | |
33 | 1 | piat, charles ugo | _sip.conf_ |
34 | 1 | piat, charles ugo | |
35 | 1 | piat, charles ugo | <pre> |
36 | 1 | piat, charles ugo | [general] |
37 | 1 | piat, charles ugo | context=unauthenticated |
38 | 1 | piat, charles ugo | allowguest=no |
39 | 1 | piat, charles ugo | srvlookup=no |
40 | 1 | piat, charles ugo | udpbindaddr=0.0.0.0 |
41 | 1 | piat, charles ugo | tcpenable=no |
42 | 1 | piat, charles ugo | </pre> |
43 | 1 | piat, charles ugo | |
44 | 1 | piat, charles ugo | We have set the default context to "unauthenticated" to ensure that unauthenticated guest calls will enter the dialplan. It will be useful for external call since we don't always know the caller. We have set allowguest to "no" to exclusively allow phone call from registered device in our local network. We put the udpbindaddr field equal to 0.0.0.0 to be sure that the VoIP server listen to all interfaces (nevertheless we could have udpbindaddr=192.168.35.0/24). We wanted to cancel the more restrictions as possible. |
45 | 1 | piat, charles ugo | |
46 | 1 | piat, charles ugo | In the same file we have created the template for our devices. |
47 | 1 | piat, charles ugo | |
48 | 1 | piat, charles ugo | <pre> |
49 | 1 | piat, charles ugo | [office-phone](!) |
50 | 1 | piat, charles ugo | type=friend |
51 | 1 | piat, charles ugo | context=LocalSets |
52 | 1 | piat, charles ugo | host=dynamic |
53 | 1 | piat, charles ugo | nat=force_rport,comedia |
54 | 1 | piat, charles ugo | dtmfmode=auto |
55 | 1 | piat, charles ugo | disallow=all |
56 | 1 | piat, charles ugo | allow=g722 |
57 | 1 | piat, charles ugo | allow=ulaw |
58 | 1 | piat, charles ugo | allow=alaw |
59 | 1 | piat, charles ugo | </pre> |
60 | 1 | piat, charles ugo | |
61 | 1 | piat, charles ugo | We have set the type to friend so that the channel driver will match on the username and the IP. Next we have register the context as "LocalSets", this is where, calls from the device will enter the dialplan (it is not a default value, it is chosen by the user. It will correspond to the name of the template in the extensions.conf). The host parameter defines the IP address of the far end for this channel; we define the value as dynamic so we let Asterisk know that the phones will tell him where they are on the network. The NAT filed meaning network address translation; it is needed when the remote device is behind a firewall. The rport parameter signal to the far end that it should respond to the source IP and port the request originated from and respectively the comedia parameter is used to instruct Asterisk to send media (RTP) to the address and port that the far-end media came from. |
62 | 1 | piat, charles ugo | |
63 | 1 | piat, charles ugo | <pre> |
64 | 1 | piat, charles ugo | [1001](office-phone) |
65 | 1 | piat, charles ugo | secret=1001 |
66 | 1 | piat, charles ugo | [1003](office-phone) |
67 | 1 | piat, charles ugo | secret=1002 |
68 | 1 | piat, charles ugo | [1003](office-phone) |
69 | 1 | piat, charles ugo | secret=1003 |
70 | 1 | piat, charles ugo | </pre> |
71 | 1 | piat, charles ugo | |
72 | 1 | piat, charles ugo | Here we have defined the device name and its secret's code for the 3 handsets. |
73 | 1 | piat, charles ugo | |
74 | 1 | piat, charles ugo | |
75 | 1 | piat, charles ugo | _extensions.conf_ |
76 | 1 | piat, charles ugo | |
77 | 1 | piat, charles ugo | <pre> |
78 | 1 | piat, charles ugo | [LocalSets] |
79 | 1 | piat, charles ugo | exten => 1001,1,Dial(SIP/1001) |
80 | 1 | piat, charles ugo | exten => 1002,1,Dial(SIP/1002) |
81 | 1 | piat, charles ugo | exten => 1003,1,Dial(SIP/1003) |
82 | 1 | piat, charles ugo | </pre> |
83 | 1 | piat, charles ugo | |
84 | 1 | piat, charles ugo | In the file extensions.conf we create a template call "LocalSets" corresponding to the value of the context field in the sip.conf. The field “exten” means when the number 1001 (for instance in the second code line) is dial, asterisk will call the SIP/1001. The number 1 between commas corresponds to the priority. |
85 | 1 | piat, charles ugo | |
86 | 1 | piat, charles ugo | h3. Configuration of the External call |
87 | 1 | piat, charles ugo | |
88 | 1 | piat, charles ugo | In our configuration we differentiate the InComing call from the OutGoing call. Likewise the internal call, we implement the configuration in the sip.conf to register our line from our provider and the extensions.conf to manage the calls. |
89 | 1 | piat, charles ugo | |
90 | 1 | piat, charles ugo | *InComing Call* |
91 | 1 | piat, charles ugo | |
92 | 1 | piat, charles ugo | _sip.conf_ |
93 | 1 | piat, charles ugo | |
94 | 1 | piat, charles ugo | <pre> |
95 | 1 | piat, charles ugo | [general] |
96 | 1 | piat, charles ugo | register => 0033XXXXXXXXX:password@sip.ovh.fr |
97 | 1 | piat, charles ugo | </pre> |
98 | 1 | piat, charles ugo | |
99 | 1 | piat, charles ugo | We register our phone line with our phone number, our password and the domain provided from ovh. |
100 | 1 | piat, charles ugo | |
101 | 1 | piat, charles ugo | |
102 | 1 | piat, charles ugo | <pre> |
103 | 1 | piat, charles ugo | [forfait-ovh] |
104 | 1 | piat, charles ugo | type=peer |
105 | 1 | piat, charles ugo | host=sip.ovh.fr |
106 | 1 | piat, charles ugo | context=ovh-sip |
107 | 1 | piat, charles ugo | defaultuser=0033XXXXXXXXX |
108 | 1 | piat, charles ugo | fromuser=0033XXXXXXXXX |
109 | 1 | piat, charles ugo | secret=password |
110 | 1 | piat, charles ugo | directmedia=no |
111 | 1 | piat, charles ugo | nat=force_rport,comedia |
112 | 1 | piat, charles ugo | canreinvite=no |
113 | 1 | piat, charles ugo | qualify=yes |
114 | 1 | piat, charles ugo | dtmfmode=auto |
115 | 1 | piat, charles ugo | </pre> |
116 | 1 | piat, charles ugo | |
117 | 1 | piat, charles ugo | Here we have save information corresponding to our line. The context field refers to the template in the dialplan. We retrieve almost the same filed than those presented in the internal call. |
118 | 1 | piat, charles ugo | |
119 | 1 | piat, charles ugo | _extensions.conf_ |
120 | 1 | piat, charles ugo | |
121 | 1 | piat, charles ugo | <pre> |
122 | 1 | piat, charles ugo | [ovh-sip] ; nom du plan |
123 | 1 | piat, charles ugo | exten => s,1,Ringing(1) |
124 | 1 | piat, charles ugo | exten => s,2,Answer |
125 | 1 | piat, charles ugo | exten => s,3,Dial(SIP/1001,30,tm) |
126 | 1 | piat, charles ugo | exten => s,4,Hangup(16) |
127 | 1 | piat, charles ugo | </pre> |
128 | 1 | piat, charles ugo | |
129 | 1 | piat, charles ugo | In the file extensions.conf we create a template call "ovh-sip" corresponding to the value of the context field in the sip.conf. In The field “exten” we replace the number dialed by "s" which means asterisk will answer to all incoming call and the device SIP/1001 will received all the external calls. Here we can see in more details the priority rules, first Ringing, Answering, Dial and Hang-up. |
130 | 1 | piat, charles ugo | |
131 | 1 | piat, charles ugo | |
132 | 1 | piat, charles ugo | *OutGoing Call* |
133 | 1 | piat, charles ugo | |
134 | 1 | piat, charles ugo | In this part, we will just modified the file extensions.conf. |
135 | 1 | piat, charles ugo | |
136 | 1 | piat, charles ugo | _extensions.conf_ |
137 | 1 | piat, charles ugo | |
138 | 1 | piat, charles ugo | <pre> |
139 | 1 | piat, charles ugo | [external] |
140 | 1 | piat, charles ugo | exten => _0.,1,Dial(SIP/${EXTEN}@forfait-ovh) |
141 | 1 | piat, charles ugo | [LocalSets] |
142 | 1 | piat, charles ugo | include => external |
143 | 1 | piat, charles ugo | </pre> |
144 | 1 | piat, charles ugo | |
145 | 4 | VEILLARD GAROZ, Loïc | In the LocalSets we have included the template external to authorize external call to the handsets. The template “external” calls on the section [forfait-ovh] to provide the outgoing call. Only calls begining by zero (the aim is to block the international call but can be remove depending of the situation) are allowed by our configuration. |