Unlocking your VoIP Success one step at a time
Setting up FreePBX for the first time can seem daunting, but with a step-by-step approach, you can easily get your PBX system up and running. FreePBX is a free, open-source interface that manages Asterisk, a powerful and flexible voice-over IP (VoIP) server. In the rest of this tutorial, we shall look at the critical steps of the setup process that a user needs to go through to reap the benefits of FreePBX.
Installing FreePBX
First and foremost, to proceed with this guide, ensure you have a fully installed and updated FreePBX system. For a quick and hassle-free start, we provide pre-configured Cloud Images, offering a reliable and production-ready FreePBX installation. The best part? These images are readily accessible on your favourite cloud platforms. Use the links below to set up your FreePBX system, and once that’s complete, return to this tutorial to continue.
Step 1: Accessing the FreePBX Administration Interface
After installation, you will be presented with the IP address of your FreePBX system. This can be obtained from the cloud portal of your chosen provider. Type this IP address into a web browser on a computer connected to the internet. You will be directed to the FreePBX initial set-up screen. On this page, you will be allowed to set up administrator information. Please note the username and password, as you will be using those in the next sections.
If you have connectivity issues at this point, it is worth looking at security groups on your FreePBX instance and be sure the ports 80/TCP and 443/TCP are accessible to you.
When you finish the initial setup, you should be returned to the screen below, where you can log into your FreePBX system for the first time.
Apply Configuration Changes
As you make changes in the FreePBX UI, those changes are staged but not applied automatically. Look for the “Apply Config” button at the top of the screen. Clicking this will apply your configuration changes. It’s a good practice to apply changes to avoid a pile-up of unapplied settings.
Step 2: Setting Up Users (Extensions)
In FreePBX and Asterisk, extensions serve as individual endpoints, acting like internal phone lines for users within your organization. It’s important to note that as you navigate through FreePBX and Asterisk documentation or forums, you might notice the terms “users” and “extensions” being used somewhat interchangeably. This terminology overlap stems from the system’s flexibility in handling internal call routing and identification. An extension is a specific endpoint within the PBX system, typically associated with a device or software client. On the other hand, a user is often considered the individual utilizing the phone or device. However, in the context of FreePBX and Asterisk, an extension can directly represent a user, hence the interchangeable use of these terms. Understanding this will help you better navigate the setup process and any documentation you encounter.
To set up an extension in FreePBX:
- Navigate to the “Applications” menu and select “Extensions”
- Click on “Add New Extension” and choose the type of device you’re setting up — For this tutorial, we shall set up a PJSIP (Session Initiation Protocol) extension. Fill in the necessary details for your extension. Key fields include;
- “User Extension,” which is the number assigned to this endpoint
- The “Display Name” for easy identification
- The “Secret” which is essentially the password for this extension. The “Secret” is critical for registering your device with the PBX and ensuring secure communication.
Remember to apply your configuration changes immediately after setting up or modifying extensions. This action updates the system’s running configuration and activates your configured extensions.
At this point, you should be able to use a SIP client to connect to FreePBX. The details you will require are the IP or Domain name of the FreePBX system along with the “User Extension” as username and “Secret” as the Password.
Step 3: Outbound and Inbound Routes
What purpose does a phone system serve without contacts to reach out to? Presumably, the goal behind setting up FreePBX is to enable interactions with people internally and externally outside your immediate network. To make this possible, it’s essential to establish both outbound and inbound routes for communication.
Outbound Routes
Outbound routes are a fundamental component of your FreePBX system, as they are the bridge connecting your internal network to the external telephone network. By configuring outbound routes, you define the rules and paths your calls will follow to reach destinations outside your organization. To begin setting up outbound routes, navigate to Connectivity > Outbound Routes to set this up.
To configure an Outbound Route, you need;
Route Name: This name helps you identify the route’s purpose or the type of calls it handles, such as local, long-distance, or international calls.
Dial Patterns: Dial patterns are critical to outbound routing as they determine which numbers will be routed through this path. These patterns can include wildcards and specific digit sequences to match various phone numbers. For example, you might set a dial pattern that captures all numbers starting with a particular country or area code, directing these calls through a specified route.
Trunk Selection: A trunk is a physical or virtual line connecting your PBX to the external phone network. When setting up an outbound route, you must specify which trunk(s) the calls matching your dial patterns should use. If you have multiple trunks, you can prioritize them, so if the primary trunk is unavailable, the call will attempt to go through the next available trunk in your list.
Inbound Routes
Inbound Routes are equally crucial to the functionality of your FreePBX system, serving as the gatekeepers for calls coming into your organization from the external world. These routes dictate how incoming calls are handled and directed within your network, ensuring callers reach the intended recipient or department. To configure your inbound routes, you will navigate to “Connectivity” and then select “Inbound Routes.” This area allows you to manage the rules and paths for incoming calls, setting the stage for how your system interacts with the outside world.
To set an Inbound route, the following needs to be set as a minimum
DID Number: The Direct Inward Dialing (DID) number is a unique number callers use to reach your PBX system. You can specify one or more DID numbers when setting up an inbound route. This tells the PBX system that calls to these numbers should be handled according to the route’s configuration.
Caller ID: Optionally, you can specify Caller ID information to create more targeted routing rules. For example, you might route calls from specific numbers or area codes to different destinations within your organization.
Destination: The most critical part of setting up an inbound route is defining its destination. This could be an extension, ring group, call queue, auto attendant (IVR), or any other destination within your FreePBX system. The destination determines where the call will be directed once it reaches your PBX.
Step 4: Trunks
In telecommunication terms, a trunk is a line or link designed to carry multiple signals simultaneously to provide network access between two points. Trunks are pivotal in bridging your FreePBX system with the external telephony world, serving as the primary conduits for incoming and outgoing calls. They are the backbone of your communication system, connecting your FreePBX to service providers via the internet (VoIP) or conventional phone lines. Here’s a deeper look into what trunks are and how to add them to your FreePBX setup:
Types of Trunk
SIP Trunks: Session Initiation Protocol (SIP) trunks use the internet to connect your FreePBX with a Voice communication vendor. SIP trunks are flexible, scalable, and often more cost-effective than traditional lines, making them a popular choice for modern businesses.
Analog Trunks: These traditional phone lines connect to FreePBX using physical wires. While less common in new installations due to the prevalence of VoIP solutions, they are still used in specific scenarios, especially where internet connectivity is unreliable.
PRI Trunks: Primary Rate Interface (PRI) trunks are digital trunk lines that provide multiple channels for voice and data transmission over a single line. They are typically used by larger organizations with higher call volumes.
Adding a Trunk in FreePBX
To integrate a trunk with your FreePBX system, navigate to “Connectivity” > “Trunks.” and follow these general steps:
Add New Trunk: Click on the “Add Trunk” option. You will be prompted to select the type of trunk you wish to add, such as SIP, IAX (Inter-Asterisk eXchange), or DAHDI for analog lines.
Configure Trunk Settings: For SIP trunks, you’ll need to input the trunk name and the SIP settings (PJSIP Settings tab) provided by your VoIP provider. These settings typically include the trunk’s hostname or IP address (SIP server), the username and password for authentication, and possibly a registration string if your provider requires it. Accurate configuration is crucial for establishing a reliable connection.
Dial Patterns and Routes: After setting up the trunk, you need to configure dial patterns and assign outbound/inbound routes to it. This tells the PBX how to use this trunk for placing or receiving calls.
Apply Changes: Remember to apply the changes once you’ve configured the trunk and associated routes. It’s advisable to test the trunk by making inbound and outbound calls to ensure it’s functioning correctly.
Step 5: Testing Your Setup
Finally, test your setup to ensure everything is working correctly. Make internal calls between extensions, place outbound calls, and check that inbound calls reach their intended destination.
Conclusion
Setting up FreePBX requires careful attention to detail but is not beyond the reach of beginners willing to learn. By following this guide, you’ll have a basic but operational PBX system set up. Remember, the VoIP world is vast and complex, so continue to explore FreePBX features and configurations to tailor your system to your needs.
Did You Just Read Gibberish?
Our Tech Support Staff understand gibberish and would love to work with you. Your business needs you, lets take care of the backend stuff.
Gibberish Helpline