Upgrade 3CX to v18 and get it hosted free!

Asterisk abbreviated dialing using Horde Turba

Author image

This script complements the Asterisk simple php lookup up callerid name from Horde Turba. I needed a way to implement a system of abbreviated or speed dialing in Asterisk – using Horde Turba address book as a back-end, in order to replace similar functionality of a proprietary PBX system. Horde is a great, free web-based suite of groupware applications, such as an address book, an email client, a calendar client and so on. My Horde installation uses PostgreSQL – hence this script uses connects to a PostgreSQL backend. I had to add two extra columns in the “turba_objects” table – “object_abbdialphone” and “object_abbdialcode”.

The way the script works is as follows:

1. User dials a three digit extension on their phone (the speed dial or abbreviated dial number).
2. Asterisk scans the Turba address book to see if any record has that extension number in the the “object_abbdialcode” column.
3. If one of the address book entries matches, then the AGI script returns the number found in the “object_abbdialphone” to be dialed out instead.
4. If not address book record matches, the script returns zero – and the dialplan plays and error message instead.

First extensions.conf:

exten => _XXX,1,NoOp(Run agi script to find abb dial in Horde Turba)
exten => _XXX,n,AGI(/var/lib/asterisk/agi-bin/abbdial.php)
exten => _XXX,n,GoToIf(${abbphonenumber}?:20)
exten => _XXX,n,Dial(IAX2/outgoing1/${abbphonenumber},,T)
exten => _XXX,n,HangUp()

exten => _XXX,20,Playback(/etc/asterisk/prompts/this_speed_dial_does_not_exist2)
exten => _XXX,n,HangUp()

Then the AGI script – I have mine at /var/lib/asterisk/agi-bin/abbdial.php:


#!/usr/bin/php
<?php
require 'phpagi.php';

$agi = new AGI();

/* Connect to Horde database */

$db = 'horde';
$dbuser = 'asterisk';
$dbpass = '';
$dbhost = 'localhost';

$dbconn = pg_connect("host=" . $dbhost . " " . "dbname=" . $db . " " . 
    "user=" . $dbuser . " " . "password=" . $dbpass);
if (!$dbconn) {
    echo "Can't connect to database.\n";
    exit;
}

$abbdialcode = $agi->request[agi_extension];

$sql = "SELECT object_abbdialphone FROM turba_objects WHERE " .
    "object_abbdialcode LIKE '%$abbdialcode%' LIMIT 1";

$result = pg_query($dbconn, $sql);
if (!$result) {
    echo "An error occurred running the query.\n";
    exit;
}

//if found number
if (pg_num_rows($result)==1){
    $row = pg_fetch_array($result);
    //check if full phone field is not null
    if ($row[object_abbdialphone]) {
        $phone_no = $row[object_abbdialphone];
    }
    //if full number field is empty, set phone number to 0
    else $phone_no = "0";
}

//if we can't find a record which matches the abb code, set phone number to 0
else $phone_no = "0";
;

$agi->set_variable("abbphonenumber", $phone_no);

exit;

?>


Article Reviews

Write a Review

Your email address will not be published. Required fields are marked *

Required Field. Minimum 5 characters.

Required Field. Minimum 5 characters, maximum 50.

Required field.There is an error with this field.

Required Field.

This site uses Akismet to reduce spam. Learn how your comment data is processed.

There are no reviews for this article. Be the first one to write a review.

Related Posts:

Get 3CX - Absolutely Free!
Link up your team and customers Phone System Live Chat Video Conferencing

Hosted or Self-managed. Up to 10 users free forever. No credit card. Try risk free.

3CX
A 3CX Account with that email already exists. You will be redirected to the Customer Portal to sign in or reset your password if you've forgotten it.