VoIP Phones - Asterisk: Difference between revisions

Back up to the VoIP Configuring page
From AAISP Support Site
No edit summary
m (Link is dead)
(14 intermediate revisions by 5 users not shown)
Line 1: Line 1:
<indicator name="VoIPConfiguring">[[File:menu-voip.svg|link=:Category:VoIP Phones|30px|Back up to the VoIP Configuring page]]</indicator>
[[File:Asterisk_logo.png]]
[[File:Asterisk_logo.png]]


Line 6: Line 7:


= Configuration =
= Configuration =
Asterisk has two methods to configure SIP connections. The legacy "sip.conf" (SIP) and the more modern "pjsip.conf" (PJSIP).

Newer installations of Asterisk should be configured to use PJSIP as it will be more supported as Asterisk development continues. It isn't a good idea to have an installation that mixes sip.conf with pjsip.conf.

When reading the instructions below be aware which are for sip.conf and which are for pjsip.conf. PJSIP examples are below the SIP examples on this page.

=sip.conf (SIP)=

== Incoming Calls ==
== Incoming Calls ==
=== Peer Section ===
=== User Section ===
*Accept authenticated calls and route them to a context.
*Accept authenticated calls and route them to a context.
sip.conf:
sip.conf:
<syntaxhighlight>
<syntaxhighlight lang="ini">
[aaisp-incoming-username]
[aaisp-incoming-username]
type=peer
type=user
context=aaisp-incoming-context
context=aaisp-incoming-context
secret=aaisp-incoming-password
secret=aaisp-incoming-password
Line 19: Line 28:
allow=alaw
allow=alaw
trustrpid=yes
trustrpid=yes
directmedia=no
</syntaxhighlight>
</syntaxhighlight>
*We send Remote-Party-Id with the privacy and screen settings, setting trustrpid=yes in the incoming SIP config will allow asterisk to pass withheld/unknown on.
*We send Remote-Party-Id with the privacy and screen settings, setting '''trustrpid=yes''' in the incoming SIP config will allow Asterisk to pass withheld/unknown on.


=== Authentication ===
=== Authentication ===
*Voiceless must authenticated so that calls are recognised as the above peer section.
*Voiceless must authenticate so that calls are recognised as the above peer section.
*You need to use the '''match_auth_username=yes''' setting otherwise Asterisk will not recognise Voiceless' initial requests.
*You need to use the '''match_auth_username=yes''' setting otherwise Asterisk will not recognise Voiceless' initial requests.


sip.conf:
sip.conf:
<syntaxhighlight>
<syntaxhighlight lang="ini">
[general]
[general]
match_auth_username=yes
match_auth_username=yes
</syntaxhighlight>
</syntaxhighlight>
*We initially send an Authorization header with only a username, allowing Asterisk to identify Voiceless by username instead of by IP. By default Asterisk ignores the username when identifying peers.




== Outgoing Calls ==
== Outgoing Calls ==
*Either use a separate '''type=user''' section or combine incoming and outgoing in one '''type=friend''' section
*Either use a separate '''type=peer''' section or combine incoming and outgoing in one '''type=friend''' section


=== Separate Section ===
=== Separate Section ===
sip.conf:
sip.conf:
<syntaxhighlight>
<syntaxhighlight lang="ini">
[aaisp-outgoing-account]
[aaisp-outgoing-account]
type=user
type=peer
host=voiceless.aa.net.uk
host=voiceless.aa.net.uk
defaultip=81.187.30.111
defaultip=81.187.30.111
username=aaisp-phone-number
defaultuser=aaisp-phone-number
remotesecret=aaisp-outgoing-password
remotesecret=aaisp-outgoing-password
transport=udp
transport=udp
disallow=all
disallow=all
allow=alaw
allow=alaw
directmedia=no
</syntaxhighlight>
</syntaxhighlight>


=== Combined Section ===
=== Combined Section ===
sip.conf:
sip.conf:
<syntaxhighlight>
<syntaxhighlight lang="ini">
[aaisp-incoming-username]
[aaisp-incoming-username]
type=friend
type=friend
Line 58: Line 70:
disallow=all
disallow=all
allow=alaw
allow=alaw
directmedia=no
; incoming
; incoming
context=aaisp-incoming-context
context=aaisp-incoming-context
Line 65: Line 78:
host=voiceless.aa.net.uk
host=voiceless.aa.net.uk
defaultip=81.187.30.111
defaultip=81.187.30.111
username=aaisp-phone-number
defaultuser=aaisp-phone-number
remotesecret=aaisp-outgoing-password
remotesecret=aaisp-outgoing-password
</syntaxhighlight>
</syntaxhighlight>
Line 72: Line 85:
==Note: Order of sip.conf is important==
==Note: Order of sip.conf is important==
In sip.conf, ensure that your incoming config is before the config for the outgoing.
In sip.conf, ensure that your incoming config is before the config for the outgoing.



==Note: Asterisk and IPv6 SLAAC addresses==
==Note: Asterisk and IPv6 SLAAC addresses==
Line 81: Line 93:
If you're behind NAT it is helpful to make Asterisk register. It re-registers every 120 seconds by default anyway so should keep NAT sessions open.
If you're behind NAT it is helpful to make Asterisk register. It re-registers every 120 seconds by default anyway so should keep NAT sessions open.
You can register (and tell Asterisk that it's behind NAT) with these settings under the [general] section:
You can register (and tell Asterisk that it's behind NAT) with these settings under the [general] section:
<syntaxhighlight>
<syntaxhighlight lang="ini">
localnet=10.0.0.0/8
localnet=10.0.0.0/8
register => +441234567980:outgoingpass@voiceless.aa.net.uk/extn
register => +441234567980:outgoingpass@voiceless.aa.net.uk/extn
Line 87: Line 99:
In this example, extn is the extension that Asterisk will pass the call to.
In this example, extn is the extension that Asterisk will pass the call to.
Localnet should of course be set to whatever RFC1918 range you are using on your LAN.
Localnet should of course be set to whatever RFC1918 range you are using on your LAN.



==Dialplan==
==Dialplan==
Line 93: Line 104:
See Asterisk's included example sip.conf for examples of how to send the call to different contexts etc.
See Asterisk's included example sip.conf for examples of how to send the call to different contexts etc.
For outbound calls:
For outbound calls:
<syntaxhighlight>
<syntaxhighlight lang="ini">
exten => _X.,1,Dial(SIP/voiceless-out/${EXTEN})
exten => _X.,1,Dial(SIP/voiceless-out/${EXTEN})
</syntaxhighlight>
</syntaxhighlight>
For inbound calls (assuming you're routing call to a registered Snom):
For inbound calls (assuming you're routing call to a registered Snom):
<syntaxhighlight>
<syntaxhighlight lang="ini">
[voiceless-in]
[voiceless-in]
exten => _X.,1,Dial(SIP/snom)
exten => _X.,1,Dial(SIP/snom)
</syntaxhighlight>
</syntaxhighlight>


=pjsip.conf (PJSIP)=


==PJSIP: Trunk registration==
=Further Help=
Here is an example of a working pjsip.conf setup where Asterisk will register with A&A to receive calls.
Customers using Asterisk and AAISP have created a website and IRC channel especially for this!
*http://www.aa-asterisk.org.uk/
*irc://z.je/a&a-asterisk


In pjsip.conf:
[reg_442082881111]
type = registration
retry_interval = 20
fatal_retry_interval = 20
forbidden_retry_interval = 20
max_retries = 9999
auth_rejection_permanent = no
contact_user = maininbound
expiration = 120
outbound_auth = auth_reg_442082881111
client_uri = sip:+442082881111@voiceless.aa.net.uk
server_uri = sip:voiceless.aa.net.uk
[auth_reg_442082881111]
type = auth
password = BusinessPaidGrewCome
username = +442082881111
[aaisptrunk]
type = aor
contact = sip:+442082881111@voiceless.aa.net.uk
qualify_frequency=20
[aaisptrunk]
type = identify
endpoint = aaisptrunk
match = voiceless.aa.net.uk
[aaisptrunk]
type = endpoint
context = maininbound
dtmf_mode = rfc4733
disallow = all
allow = alaw
allow = ulaw
direct_media = no
aors = aaisptrunk
outbound_auth=auth_reg_442082881111


Calls come into the context "maininbound" in extensions.conf - in this example calls get sent onto extension 222 and 205 for 20 seconds and then go to voicemail.
[maininbound]
exten = maininbound,1,Dial(PJSIP/222&PJSIP/205,20)
exten = maininbound,n,Voicemail(222@default,us)

In extensions.conf you can dial out via the trunk with:
exten => _X.,1,Dial(PJSIP/${EXTEN}@aaisptrunk,,)

==PJSIP: Keep-Alive / Anti-Idle==
If you are using a firewall or NAT router with short timeouts on UDP sessions you can force packets to be sent over the connection to keep it alive.

Set qualify_frequency in the aor section; This triggers an OPTIONS message every X (as set) seconds.
An example of the aor section follows:
[aaisptrunk]
type = aor
contact = sip:+442082881111@voiceless.aa.net.uk
qualify_frequency=20

==Status and Commands==
A good command within the asterisk software is the show registration command:
asterisk*CLI> pjsip show registrations
<Registration/ServerURI..............................> <Auth..........> <Status.......>
==========================================================================================
reg_442082881111/sip:voiceless.aa.net.uk auth_reg_442082881111 Registered
Objects found: 1
In this example it shows that the Asterisk server is successfully registered with the Andrews & Arnold SIP server.

=Further Help=
Customers using Asterisk and AAISP have created a website and IRC channel especially for this!
*http://www.aa-asterisk.org.uk/ [ Dead link @ Dec 2020 ]
*irc://irc.aachat.net/a&a-asterisk


=Firewall & Security=
=Firewall & Security=

Revision as of 14:47, 27 December 2020

Asterisk logo.png

Asterisk is extremely flexible and covering different uses for it is outside the scope of this example as the setup used here was very basic. You should read through the included documentation, especially the security documentation, before configuring Asterisk for the first time.

Configuration

Asterisk has two methods to configure SIP connections. The legacy "sip.conf" (SIP) and the more modern "pjsip.conf" (PJSIP).

Newer installations of Asterisk should be configured to use PJSIP as it will be more supported as Asterisk development continues. It isn't a good idea to have an installation that mixes sip.conf with pjsip.conf.

When reading the instructions below be aware which are for sip.conf and which are for pjsip.conf. PJSIP examples are below the SIP examples on this page.

sip.conf (SIP)

Incoming Calls

User Section

  • Accept authenticated calls and route them to a context.

sip.conf:

[aaisp-incoming-username]
type=user
context=aaisp-incoming-context
secret=aaisp-incoming-password
transport=udp
disallow=all
allow=alaw
trustrpid=yes
directmedia=no
  • We send Remote-Party-Id with the privacy and screen settings, setting trustrpid=yes in the incoming SIP config will allow Asterisk to pass withheld/unknown on.

Authentication

  • Voiceless must authenticate so that calls are recognised as the above peer section.
  • You need to use the match_auth_username=yes setting otherwise Asterisk will not recognise Voiceless' initial requests.

sip.conf:

[general]
match_auth_username=yes
  • We initially send an Authorization header with only a username, allowing Asterisk to identify Voiceless by username instead of by IP. By default Asterisk ignores the username when identifying peers.


Outgoing Calls

  • Either use a separate type=peer section or combine incoming and outgoing in one type=friend section

Separate Section

sip.conf:

[aaisp-outgoing-account]
type=peer
host=voiceless.aa.net.uk
defaultip=81.187.30.111
defaultuser=aaisp-phone-number
remotesecret=aaisp-outgoing-password
transport=udp
disallow=all
allow=alaw
directmedia=no

Combined Section

sip.conf:

[aaisp-incoming-username]
type=friend
transport=udp
disallow=all
allow=alaw
directmedia=no
; incoming
context=aaisp-incoming-context
secret=aaisp-incoming-password
trustrpid=yes
; outgoing
host=voiceless.aa.net.uk
defaultip=81.187.30.111
defaultuser=aaisp-phone-number
remotesecret=aaisp-outgoing-password


Note: Order of sip.conf is important

In sip.conf, ensure that your incoming config is before the config for the outgoing.

Note: Asterisk and IPv6 SLAAC addresses

Asterisk will bind to all IPv6 addresses if it is set to use IPv6. This means that if you have a static IP and a SLAAC IP, Asterisk sometimes replies to invites sent to the static IP from the SLAAC IP instead which breaks things. We recommend using static IP addresses and disabling SLAAC (and privacy extensions) on the box running Asterisk until its IPv6 support is more mature.


Registration

If you're behind NAT it is helpful to make Asterisk register. It re-registers every 120 seconds by default anyway so should keep NAT sessions open. You can register (and tell Asterisk that it's behind NAT) with these settings under the [general] section:

localnet=10.0.0.0/8
register => +441234567980:outgoingpass@voiceless.aa.net.uk/extn

In this example, extn is the extension that Asterisk will pass the call to. Localnet should of course be set to whatever RFC1918 range you are using on your LAN.

Dialplan

To make this work in a real dialplan you will want something like the following examples in extensions.conf. See Asterisk's included example sip.conf for examples of how to send the call to different contexts etc. For outbound calls:

exten => _X.,1,Dial(SIP/voiceless-out/${EXTEN})

For inbound calls (assuming you're routing call to a registered Snom):

[voiceless-in]
exten => _X.,1,Dial(SIP/snom)

pjsip.conf (PJSIP)

PJSIP: Trunk registration

Here is an example of a working pjsip.conf setup where Asterisk will register with A&A to receive calls.

In pjsip.conf:

   [reg_442082881111]
   type = registration
   retry_interval = 20
   fatal_retry_interval = 20
   forbidden_retry_interval = 20
   max_retries = 9999
   auth_rejection_permanent = no
   contact_user = maininbound
   expiration = 120
   outbound_auth = auth_reg_442082881111
   client_uri = sip:+442082881111@voiceless.aa.net.uk
   server_uri = sip:voiceless.aa.net.uk
   
   [auth_reg_442082881111]
   type = auth
   password = BusinessPaidGrewCome
   username = +442082881111
   
   [aaisptrunk]
   type = aor
   contact = sip:+442082881111@voiceless.aa.net.uk
   qualify_frequency=20
   
   [aaisptrunk]
   type = identify
   endpoint = aaisptrunk
   match = voiceless.aa.net.uk
   
   [aaisptrunk]
   type = endpoint
   context = maininbound
   dtmf_mode = rfc4733
   disallow = all
   allow = alaw
   allow = ulaw
   direct_media = no
   aors = aaisptrunk
   outbound_auth=auth_reg_442082881111

Calls come into the context "maininbound" in extensions.conf - in this example calls get sent onto extension 222 and 205 for 20 seconds and then go to voicemail.

[maininbound]
exten = maininbound,1,Dial(PJSIP/222&PJSIP/205,20)
exten = maininbound,n,Voicemail(222@default,us)

In extensions.conf you can dial out via the trunk with:

exten => _X.,1,Dial(PJSIP/${EXTEN}@aaisptrunk,,)

PJSIP: Keep-Alive / Anti-Idle

If you are using a firewall or NAT router with short timeouts on UDP sessions you can force packets to be sent over the connection to keep it alive.

Set qualify_frequency in the aor section; This triggers an OPTIONS message every X (as set) seconds. An example of the aor section follows:

[aaisptrunk]
type = aor
contact = sip:+442082881111@voiceless.aa.net.uk
qualify_frequency=20

Status and Commands

A good command within the asterisk software is the show registration command:

asterisk*CLI> pjsip show registrations

 <Registration/ServerURI..............................>  <Auth..........>  <Status.......>
==========================================================================================

 reg_442082881111/sip:voiceless.aa.net.uk                auth_reg_442082881111  Registered

Objects found: 1

In this example it shows that the Asterisk server is successfully registered with the Andrews & Arnold SIP server.

Further Help

Customers using Asterisk and AAISP have created a website and IRC channel especially for this!

Firewall & Security

  • You will also want to set up firewall rules, as per the VoIP Firewall page.
  • Also see the VoIP Security page for information about securing your VoIP service.