The open-source telephony development world has been changing drastically over the last 2 years. Projects like FreeSWITCH allow you to create simple phone applications with XML files, but until recently, advanced applications required a solid knowledge of the Erlang language. Then enters Twilio— which allows any web developer to make advanced telephony apps in the web language of their choice. But with Twilio’s pricing structure, you are looking at anywhere from 2 to 4 cents per minute IN ADDITION to your VOIP service while also being locked-in to their cloud. Must I learn Erlang if I want to make cool telephony apps for free?
Then on May 26, 2011, the Plivo project was announced. Plivo is essentially an open source Twilio extension that works with FreeSWITCH. What does it mean? It means you can build advanced telephony apps using whatever web programming language you want via the Plivo Framework… FOR FREE! Yes, that is right, you can build a simple PBX system for your company’s phone system with PHP. You can create a skill-based routing server in python. And my personal favorite, you can create real-time web-phones with NodeJS. It truly is amazing. Read more about Plivo. But enough of my babbling. Let’s get to the good stuff.
I have encountered a few people on the #plivo IRC chat having trouble getting Plivo going. They usually are web developers, new to FreeSWITCH like me. The beautiful part about Plivo is you don’t need to be a FreeSWITCH expert (although it doesn’t hurt).
You need a place to install FreeSWITCH and Plivo. If you don’t have an extra box lying around I recommend using a virtual Ubuntu Linux machine for development. I prefer to use the free program Virtual Box to power my virtual machines. I also suggest grabbing the Turnkey linux ISO which is a basic Ubuntu ISO image ready to go. If you need extra help getting your virtual machine setup, follow these instructions: How to Setup Turnkey Linux on Virtual Box.
If you are planning to give public access to your app then I recommend using VPS.net for a cheaper entry into cloud hosting.
A big thanks to the guys at Plivo for providing a simple shell script for installing FreeSWITCH. Switch to your home directory and enter these commands into your shell (taken directly from Plivo website):
wget --no-check-certificate https://github.com/plivo/plivoframework/raw/master/freeswitch/install.sh
Let it run for a few minutes and you will have a working copy of FreeSWITCH ready to go.
[box type=”note” style=”rounded” border=”full”]Keep in mind that this install script will only work for CentOS 5.5+ and Debian-based Distros (Ubuntu)[/box]
Yet another easy installation thanks to the Plivo guys…
wget --no-check-certificate https://github.com/plivo/plivoframework/raw/master/scripts/plivo_install.sh
bash plivo_install.sh /usr/local/plivo
Again, it should run for a bit and when it is done it should be ready to go.
Since most web developers don’t come from a Telephony background, the whole FreeSWITCH thing is new. On the #plivo IRC channel, I see new people, usually web developers like me, getting stuck at this spot all the time.
The dialplan in freeswitch essentially tells freeswitch how to route calls when they come in. An out-of-the box freeswitch setup installs 20 extensions (just like an office phone system) with passwords to login. The extensions are 1000-1020 and all have the same password – 1234. With the Plivo FreeSWITCH installer, the default dialplan is overwritten to intercept all calls and those extensions don’t work very well anymore. If you are just getting started with the whole freeswitch thing, I have provided an alternate version of the dialplan file to allow you to do testing of your freeswitch install as well as develop Plivo apps.
Copy that dialplan into the freeswitch/conf/dialplan directory. This dialplan is the same as the out of the box FreeSWITCH dialplan, except I added the plivo config and restricted it to extension 1005. This means the rest of your extensions will work like normal so you can see how awesome freeswitch is. Restart freeswitch by typing ‘shutdown’ in the freeswitch terminal.
Now things start to get fun. Get a free soft phone. For osx I got Blink Lite. Once you get a free soft phone you can login to your FreeSWITCH install by extension and IP address. If you installed freeswitch on 192.168.1.5 then for your credentials on your softphone you would use [email protected] as the user, and 1234 as the password. You should get logged right in and now you can call any other extension. Try dialing 1001 and you should get taken to voicemail. Pretty sweet right? Try dialing 1005 and right now you should get nothing but a disconnected call, since 1005 is now connected to plivo.
The last step before you take over the world with your new telephony app is configuring plivo. This is extremely easy. Go to your plivo install directory (typically /usr/local/plivo) and go to the etc/plivo directory. Open the default.conf file and look for these directives:
DEFAULT_ANSWER_URL = http://127.0.0.1:3000/answer/ DEFAULT_HANGUP_URL = http://127.0.0.1:3000/hangup/
Typically your web server won’t be tied to port 3000. You need to change these values to point to your web server IP address and port (typically 80). Also, change the URL to point wherever your app will be. I will leave mine pointing to /answer. Then make sure FreeSWITCH is started and go ahead and start plivo:
FINALLY, TIME FOR AN AWESOME PHONE APP! Your system is all setup, and plivo will be answering all calls on extension 1005. Let’s write our first app. I will make this first app in PHP, but I won’t be doing anything special, it will work on any web language that can serve an xml file. Since plivo is pointing to answer/ I will create answer/index.php and inside that file I will put plivo response xml code:
<?xml version="1.0" encoding="UTF-8" ?> <Response> <Speak>Hello World</Speak> </Response>
Now open your soft phone and dial 1005. You should hear a pleasant voice, saying “hello world”. It should be an exciting moment for you.
Now your limits are endless. Write some amazing telephony apps in a web language and let me know some of the cool projects you are building. I’ve got several more posts planned about building plivo apps coming in the next few weeks, so be ready for some exciting developments.