These configuration files act as a skeleton for a simple Asterisk PBX deployment using a SIP trunk to provide one DID, with two internal extensions. The majority of the configuration files are documented inline and are self explanatory.
This configuration has been tested on the following Linux distributions:
* Ubuntu Server 18.04 | Asterisk 13.18.3
The following SIP providers were used to construct these configuration files:
* [Twilio](https://www.twilio.com/sip-trunking)
## Installation
1. Install the latest version of Asterisk from your distribution's repositories.
```bash
$ sudo apt install asterisk -y
```
2. Remove the distribution's configuration files from `/etc/asterisk/`.
```bash
$ sudo rm -rf /etc/asterisk/*
```
3. Download these configuration files to `/etc/asterisk/`.
4. Modify the configuration to suit your needs. Refer to the configuration hints for more details.
## Configuration hints
### Configuration files
*`sip.conf`
This file's primary purpose is to define how Asterisk, trunks and extensions communicate and authenticate with one another.
Two templates are provided, each containing the common properties required to create either a new trunk or extension.
*`extensions.conf`
This configuration file details how calls should move through Asterisk.
Contexts are used to namespace internal extensions, incoming calls and outgoing calls. This prevents abuse and makes future modifications easier to integrate.
*`modules.conf`
This file is required to load Asterisk's modules. Asterisk is able to automatically load modules, so this file shouldn't need touching.
*`voicemail.conf`
The voicemail configuration file details how voicemails work.
### Configuration modifications
#### Create a new trunk
In `sip.conf`, create a new trunk which inherits from the `trunk` template.
Provide at the very least, a `context` and a `host`. Optionally, provide a `fromuser`.
*`context`: Incoming calls will be redirected to this context.
*`fromuser`: This is the caller ID which will appear when placing outbound calls (N.B. Twilio requires this parameter).
*`host`: This defines how Asterisk connects to the trunk.
If authentication is used by your SIP provider, the credentials should also be inserted into this trunk definition.
This `exten` line states: "For all incoming calls whose caller ID starts with a '+' and is of any length, dial extension `0` in the `internal` context."
To use this trunk for outbound calls, add a new context in `extensions.conf` and reference it within the `internal` context's dialplan.
```
[outgoing_newtrunk]
exten => _X.,1,Dial(SIP/newtrunk/+${EXTEN})
same => n,Hangup
```
This `exten` line states: "For all outgoing calls whose caller ID is of any length, prepend the caller ID with a '+' and then call it using the `newtrunk` SIP trunk."