How to Build a Call Forwarding App in PHP Using Laravel and Plivo

Businesses use call forwarding all the time to route incoming calls to available agents, extensions, or departments that cater to the caller’s needs. Creating a call forwarding app is simple when you use Plivo’s PHP SDK. This guide shows you how to receive incoming calls on Plivo numbers and manage the call flow once a call reaches the Plivo voice platform. To see how to do this, we’ll build a Laravel application to forward the call to a mobile number using the Dial XML element.

Prerequisites

Before you get started, you’ll need:

  • A Plivo account — sign up for one for free if you don’t have one already.
  • A voice-enabled Plivo phone number if you want to receive incoming calls. To search for and buy an available number, go to Phone Numbers > Buy Numbers on the Plivo console. Buy a New Plivo Number

  • Laravel and Plivo PHP packages.
  • ngrok — a utility that exposes your local development server to the internet over secure tunnels.

Create a Laravel application to forward incoming calls

First, you need to install Laravel if you haven’t installed it already. We suggest using Composer to install it. Add a new Laravel project with boilerplate code with the command composer create-project laravel/laravel forward_calls --prefer-dist. This will create a forward_calls directory with the necessary folders and files for development. Then change to the newly created “forward_calls” project directory and install the Plivo PHP package (composer require plivo/plivo-php).

Once you’ve installed Laravel and the Plivo PHP SDK, run php artisan make:controller ForwardcallController to create a Laravel controller to handle incoming calls on a Plivo number. To handle an incoming call, you need to return an XML document from the URL configured as the answer URL in the application assigned to the Plivo number. The PHP SDK can manage the XML document generation, and you can use the Dial XML element to forward the call to a mobile number. Use this code:

<?php

namespace App\Http\Controllers;
require '../../vendor/autoload.php';
use Plivo\RestClient;
use Plivo\XML\Response;
use Illuminate\Http\Request;

class ForwardcallController extends Controller
{
    // Dial XML to forward the incoming call
    public function forwardCalls()
    {
        $response = new Response();
        $params = array(
            'action' => "https://www.foo.com/dial_status/",
            'method' => "POST",
            'redirect' => "true"
        );
        $dial = $response->addDial($params);
        $number = "14153336666";  // call will be forwarded to this number
        $dial->addNumber($number);
        $xml_response = $response->toXML();
        return response($xml_response, 200)->header('Content-Type', 'application/xml');
    }
}

Now, you need to add a route for the “forwardCalls” function in the ForwardcallController class. Open the routes/web.php file and add this line at the end of the file:

Route::match(['get', 'post'], '/forward_calls', 'App\Http\Controllers\ForwardcallController@forwardCalls');

Note: We need to add the route of the app to the “except” array to disable CSRF verification - app/Http/Middleware/VerifyCsrfToken.php`

<?php

namespace App\Http\Middleware;

use Illuminate\Foundation\Http\Middleware\VerifyCsrfToken as Middleware;

class VerifyCsrfToken extends Middleware
{
    /**
     * The URIs that should be excluded from CSRF verification.
     *
     * @var array
     */
    protected $except = [
        '/forward_calls'
    ];
}

Test the code locally

Now the ForwardcallController is ready to handle incoming calls to your Plivo number by forwarding them to a mobile number configured in the Laravel application using Plivo PHP SDK. To run the code on the Laravel server, use the command

$ php artisan serve

You should see your basic server application in action on http://127.0.0.1:8000/forward_calls.

Expose the local server to the internet using ngrok

Once you see the application working locally, the next step is to connect the application to the internet to return the XML document to process the incoming call. For that, we recommend using ngrok, which exposes local servers behind NATs and firewalls to the public internet over secure tunnels. Install it and run ngrok on the command line, specifying the port that hosts the application on which you want to forward incoming calls (8000 in this case, as our local Laravel application is running there):

$ ./ngrok http 8000

Ngrok CLI

Ngrok will display a forwarding link that you can use as a webhook to access your local server over the public network. Test the link by opening the ngrok URL (https://c872a224048b.ngrok.io/forward_calls/) in a browser or use HTTPie to check the XML response from the ngrok URL.

XML document with Dial XML element

Connect the Laravel application to a Plivo number

The final step is to configure the application as a Plivo voice application and assign it to a Plivo number on which you want to forward incoming calls.

Go to the Plivo console and navigate to Voice > Applications > XML, then click on the Add New Application button in the upper right.

Provide a friendly name for the application — we used “App-call-forward” — and configured the ngrok URL https://c872a224048b.ngrok.io/forward_calls/ as the Answer URL. Select the HTTP verb as POST, then click Create Application.

Create Plivo App to forward incoming calls

Now go to Phone Numbers > Your Numbers and click on the number to which you want to assign the application. From the Plivo Application drop-down, choose the voice application you just created. Finally, click Update Number.

Assign the call forward Plivo App to a Plivo Number

Test the application

Make a phone call to the Plivo number you selected. You should see that the Laravel application automatically forwards the call to the phone number configured in the call forwarding app.

And that’s how simple it is to receive an incoming call on a Plivo number and forward it using XML documents using Plivo’s PHP SDK and a Laravel application. You can implement other use cases on the Plivo Voice platform, such as phone system IVR, receive DTMF/Speech inputs, and number masking, as your business requires.

Haven’t tried Plivo yet? Getting started is easy and only takes five minutes. Sign up today.

comments powered by Disqus

By submitting this form, you agree we may contact you in the manner described in our Privacy Policy.