NAME
OSDial - Perl extension for interfacing with OSDial
SYNOPSIS
use strict;
use OSDial;
my $osdial = OSDial->new('DB'=>1);
# Database example
while ( my $rec = $osdial->sql_query("SELECT * FROM servers;") ) {
print $rec->{server_ip} . ": " . $rec->{server_name} . "\n";
# Secondary connection and query
while ( my $rec2 = $osdial->sql_query( sprintf('SELECT * FROM osdial_log WHERE server_ip=%s;', $rec->quote($rec->{server_ip}) ) ) {
print " " . $rec2->{lead_id} . ": " . $rec2->{call_date} . ": " . $rec2->{status} . "\n";
}
}
# Asterisk::AGI example
$osdial->AGI('myscript.pl');
$osdial->AGI->verbose("OSDial Rocks",1);
$osdial->AGI->hangup();
DESCRIPTION
This module is inteded to provided quick and easy access to common functions in OSDial. The module will read existing configuration files, connect to the OSDial database, and interface with Asterisk as needed.
CONSTRUCTOR
- new() - create a new OSDial object.
-
Creates a new
OSDial
object.new
optionally takes arguments in the form of key value pairs.Examples:
$osdial = OSDial->new( DB => 1); $osdial = new OSDial( DB => 1); $osdial = OSDial->new( VARDB_server => '127.0.0.1', VARDB_database => 'osdial', VARDB_user => 'osdial', VARDB_pass => 'osdial1234' );
Contructor Arguments and Defaults
DB => '0'
PATHconf => '/etc/osdial.conf'
PATHdocs => '/usr/share/doc/osdial-3.0.2.124'
PATHhome => '/opt/osdial/bin'
PATHlogs => '/var/log/osdial'
PATHagi => '/var/lib/asterisk/agi-bin'
PATHweb => '/opt/osdial/html'
PATHsounds => '/var/lib/asterisk/sounds'
PATHmonitor => '/var/spool/asterisk/VDmonitor'
PATHDONEmonitor => '/var/spool/asterisk/VDmonitor'
PATHarchive_home => '/opt/osdial/recordings'
PATHarchive_unmixed => 'processing/unmixed'
PATHarchive_mixed => 'processing/mixed'
PATHarchive_sorted => 'completed'
PATHarchive_backup => '/opt/osdial/backups/recordings'
VARserver_ip => '127.0.0.1'
VARactive_keepalives => 'X'
VARDB_server => '127.0.0.1'
VARDB_database => 'osdial'
VARDB_user => 'osdial'
VARDB_pass => 'osdial1234'
VARDB_port => '3306'
VARfastagi_log_min_servers => '3'
VARfastagi_log_max_servers => '16'
VARfastagi_log_min_spare_servers => '2'
VARfastagi_log_max_spare_servers => '8'
VARfastagi_log_max_requests => '1000'
VARfastagi_log_checkfordead => '30'
VARfastagi_log_checkforwait => '60'
VARFTP_host => '127.0.0.1'
VARFTP_user => 'osdial'
VARFTP_pass => 'osdialftp1234'
VARFTP_port => '21'
VARFTP_dir => 'recordings/processing/unmixed'
VARHTTP_path => '/'
VARREPORT_host => '127.0.0.1'
VARREPORT_user => 'osdial'
VARREPORT_pass => 'osdialftp1234'
VARREPORT_port => '21'
VARREPORT_dir => 'reports'
VARcps => '9'
VARadapt_min_level => '1.5'
VARadapt_overlimit_mod => '20'
VARflush_hopper_each_run => '0'
VARflush_hopper_manual => '1'
- load_config() - load configuration.
-
Loads in the configuration from /etc/osdial.conf, global and server specific database settings.
# Read /etc/osdial.conf setting. $osdial->{VARserver_ip} # Read setting from system_settings table. $osdial->{settings}{company_name} # Read setting for this specific server. $osdial->{server}{server_id} # Read a setting in from the configuration table. $osdial->{configuration}{ArchiveHost}
METHODS - AGI
This method overloads the Asterisk::AGI
module, parsing AGI
variable into the OSDial object and allowing direct access to AGI
functions.
The AGI() method must first be called with the name of the current script or instance. After the initial call, AGI() will return the AGI
object for execution of AGI
events.
- AGI( [script_name] ) - starts the AGI component.
-
When called the first time, it will initialize the
AGI
obeject.$osdial = new OSDial; $osdial->AGI('agi-script_name.agi');
Subsequent calls to AGI() will return a reference to the
AGI
object. This reference can be used to callAsterisk::AGI
functions or be assigned to another variable to be called.$osdial->AGI->verbose("OSDial Rocks",1); $osdial->AGI->hangup(); $AGI = $osdial->AGI(); $AGI->verbose("OSDial Rocks",1); $AGI->hangup();
- agi_output($string, [$extended_info]) - AGI logging method.
-
This method outputs a given $string to the
AGI
log file ifAGI
logging is enabled for the server as defined by VARserver_ip. The file is stored in the directory specified by the OSDial object variable PATHlogs in a file called agiout.YYYY-MM-DD. The $extended_info variable is an optional boolean flag which instructs the routine to log the channel, extension, priority, type, and account_codeAGI
channel variables;$osdial->agi_output("An AGI event occurred"); $osdial->agi_output("Event occurred with additional channel variables",1);
METHODS - SQL
These methods provide quick and easy access to the OSDial Database by way of its configuration files.
Every method has a definable $DBhandle scalar variable. This variable is a text representation of the handle being accessed. If not given, this always defaults to "A". This is very useful for running nested queries, as you only need to call the nested statement with a different $DBhandle. Every SQL method will first check to see if the $DBhandle exists and a connection to that database has already been established. If a $DBhandle, has not yet been opened, sql_connect will automatically be called.
# Create a connection to DBhandle "A".
$osdial->sql_connect();
# Run given query against DBhandle "A".
$row = $osdial->sql_query("SELECT * FROM servers LIMIT 1;");
print $row->{"server_ip"} . "\n";
# Create a connection to DBhandle "SVR".
$osdial->sql_connect("SVR");
# Run given query against DBhandle "SVR".
while ($row = $osdial->sql_query("SELECT * FROM servers;","SVR")) {
# Run given query against DBhandle "OSDL", automatically connecting to handle.
$subrow = $osdial->sql_query("SELECT * FROM osdial_log WHERE server_ip='" . $row->{"server_ip"} . "';","OSDL");
print $subrow->{"call_date"} . "\n";
}
- sql_connect( [$DBhandle], [$DBname, [$DBserver]. [$DBport], [$DBuser], [$DBpass]] ) - connect to SQL server.
-
Connects to SQL server using sting label in $DBhandle, if not given default to "A". If $DBname is given, sql_connect will allow you to override the respective default server values for this connection.
$osdial->sql_connect("B");
- sql_disconnect( [$DBhandle] ) - disconnect from SQL server.
-
Disconnects from the database connection referenced by $DBhandle. If $DBhandle is not given, it defaults to "A".
$osdial->sql_disconnect("B");
- sql_query( $query, [$DBhandle] ) - Issues an SQL query.
-
The sql_query() method allows you to execute SQL statments. The result is a HASHREF containing the key value pairs of a queried row. This method will retain its iterative position within the running current running query and will output each row on subsequent calls. If it is run with a new and different query, while a previous query is currently buffered, it will flush the buffer and start the new query. Just be mindful to start sub-queries with a different $DBhandle to avoid clearing the current buffer of the parent query.
# Called in a single iteration, yeilds row #1. $row = $osdial->sql_query('SELECT * FROM servers;'); # Called again with same query, yeilds row #2. $row = $osdial->sql_query('SELECT * FROM servers;'); # Called again with diffent query, flushes buffer and yeilds row #1. $row = $osdial->sql_query('SELECT * FROM server_stats;'); # Called in while loop, will cycle through all rows returned by query. while ($row = $osdial->sql_query('SELECT * FROM servers;')) { print $row->{"server_ip"} . "\n"; }
If an
INSERT
,UPDATE
, orDELETE
query is given, options will automatically be passed to sql_execute().If $DBhandle does not reference a current active database connection, sql_connect() will automatically by called.
- sql_execute( $query, [$DBhandle] ) - disconnect from SQL server.
-
Execute the given statement in $query.
# Example Insert. $osdial->sql_execute("INSERT INTO table SET row='value';"); # Example Update. $osdial->sql_execute("UPDATE table SET row='value' WHERE key='id';"); # Example Delete. $osdial->sql_execute("DELETE FROM table WHERE key='id';");
If an
SELECT
orSHOW
query is given, options will automatically be passed to sql_query().If $DBhandle does not reference a current active database connection, sql_connect() will automatically by called.
- sql_quote( $string ) - returns properly escaped string in single-quotes.
-
Returns escaped strings for inclusion in queries. Returned string is already enclosed within single-quotes.
$test = $osdial->sql_quote("Here's a test."); # Result: $test = "'Here\'s a test.'";
Aliases for sql_quote( $string ) include quote( $string ) and mres( $string ).
- sql_dbh( $dbh ) - returns the dbh handle.
-
Returns the maximum allowed packet size that the SQL server will except.
$dbhandle = $osdial->sql_dbh($dbh);
- sql_last_insert_id( $dbh ) - returns the last insert id. =item sql_last_insertid( $dbh ) - returns the last insert id. =item sql_last_id( $dbh ) - returns the last insert id. =item sql_insert_id( $dbh ) - returns the last insert id.
-
Returns the last insert ID.
$insertid = $osdial->sql_last_insert_id($dbh); $insertid = $osdial->sql_last_insertid($dbh); $insertid = $osdial->sql_last_id($dbh); $insertid = $osdial->sql_insert_id($dbh);
- sql_max_packet( ) - returns maximum packet allowed.
-
Returns the maximum allowed packet size that the SQL server will except.
$max_packet = $osdial->sql_max_packet();
METHODS - OSDial
General methods for OSDial that help with everyday functions.
- debug( $level, $module, $sprintf_string, @sprintf_params ) - Send debug output to STDERR.
-
If $level matches the current Debug Level set by DB, then output a debug statement to STDERR. The name of the calling module should be specified in $module. The outputted string is taken in the same format as sprintf() in the form of $sprintf_string and @sprintf_params.
$osdial->debug(1,'main', 'The %s function failed!', $var);
- event_logger( $logname, $string ) - Send event to logfile.
-
Sends an event, $string, to the logfile in
PATHlogs
, named $logfile.YYYY-MM-DD.$osdial->event_logger('eventlog','An event was triggered.');
- get_datetime( [$time] )
-
Returns time() or $time, if given, in the format: YYYY-MM-DD HH:MM:SS
$osdial->get_datetime();
- media_add_files( $directory, [$pattern], [$update_data] )
-
All files in $directory are scaned and loaded into the databsae if they do not already exist in it.
The $pattern variable allows for a regex expression to be applied against the filename. The default $patter is
.*
.If the file exists in the database and $update_data is true, the data is updated. The default action is to skip files which are already present.
- media_add_file( $filepath, [$mimetype], [$description], [$extension], [$update_data] )
-
This function opens the media file $filepath and splits the binary data into segments which are small enough to be sent to the SQL server without exceeding the
max_allowed_packet
size.If $mimetype is not given, it will be guessed using the extension of $filepath.
g722 => 'audio/G722' g729 => 'audio/G729' gsm => 'audio/GSM' ogg => 'audio/ogg' ulaw => 'audio/PCMU' alaw => 'audio/PCMA' siren7 => 'audio/siren7' siren14 => 'audio/siren14' sln => 'audio/sln' sln16 => 'audio/sln-16' mp3 => 'audio/mpeg' wav => 'audio/x-wav'
If $description is not given, the filename is stripped off of $filepath and used.
If $extension is not given and the filename is not numeric, it is left blank. If the filename will be used if it is numeric.
If the file exists in the database and $update_data is true, the data is updated. The default action is to skip files which are already present.
- media_delete_filedata( $filename )
-
Removes all entries in the
osdial_media_data
table associated with $filename.
- media_get_filedata( $filename )
-
Combines all of the entries in the
osdial_media_data
table associated with $filename and returns the binary data.
- media_save_file( $directory, $filename, [$overwrite] )
-
Export entry matching $filename and save into the given $directory. File is skipped and is not overwitten unless $overwrite is true.
- media_save_files( $directory, [$pattern], [$overwrite] )
-
All files matching the regex $patten are exported and saved into the given $directory. The default $pattern is
.*
. Files are skipped and not overwitten unless $overwrite is true.
- send_email( $host, $port, $user, $pass, $to, $from, $subject, $html, $text ) =item send_email({ host=$host, port=>$port, user=>$user, pass=>$pass, to=>$to, from=>$from, subject=>$subject, $html=>$html, text=>$text })>
-
Sends out an email using the given parameters. Returns 1 on success, 0 on failure.
- osdevent({ server_ip=$server_ip, unqiueid=>$unqiueid, callerid=>$callerid, user=>$user, campaign_id=>$campaign_id, group_id=>$group_id, lead_id=>$lead_id, event=>$event, data1=>$data1, data2=>$data2, data3=>$data3, data4=>$data4, data5=>$data5, data6=>$data6 })>
-
Records the given data into the osdial_events table.
SEE ALSO
Official OSDial support is available through Call Center Service Group: http://www.callcentersg.com/
OSDial website: http://www.osdial.org/ OSDial at SourceForce: http://sourceforge.net/projects/osdial/
RPMs available through the Fugitol RPM Repository: http://rpm.fugitol.com/
The definitive AGI Module: Asterisk::AGI Website: http://asterisk.gnuinter.net/
DBI Module: DBI Website: http://dbi.perl.org/
MySQL Module: DBD::mysql
AUTHOR
Lott Caskey, <lottcaskey@gmail.com>
COPYRIGHT
Copyright (c) 2010-2011 Lott Caskey <lottcaskey@gmail.com>
LICENSE
AGPLv3
This file is part of OSDial.
OSDial is free software: you can redistribute it and/or modify it under the terms of the GNU Affero General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.
OSDial is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more details.
You should have received a copy of the GNU Affero General Public License along with OSDial. If not, see http://www.gnu.org/licenses/.
4 POD Errors
The following errors were encountered while parsing the POD:
- Around line 124:
You forgot a '=back' before '=head2'
- Around line 180:
=back without =over
- Around line 259:
'=item' outside of any '=over'
- Around line 317:
You forgot a '=back' before '=head1'