public
Description: Git mirror of the CMS Made Simple 2.0 rewrite
Homepage: http://cmsmadesimple.org
Clone URL: git://github.com/tedkulp/cmsmadesimple-2-0.git
cmsmadesimple-2-0 / lib / adodb5 / adodb-errorhandler.inc.php
100644 80 lines (70 sloc) 2.75 kb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
<?php
/**
* @version V5.04 13 Feb 2008 (c) 2000-2008 John Lim (jlim#natsoft.com.my). All rights reserved.
* Released under both BSD license and Lesser GPL library license.
* Whenever there is any discrepancy between the two licenses,
* the BSD license will take precedence.
*
* Set tabs to 4 for best viewing.
*
* Latest version is available at http://php.weblogs.com
*
*/
 
 
// added Claudio Bustos clbustos#entelchile.net
if (!defined('ADODB_ERROR_HANDLER_TYPE')) define('ADODB_ERROR_HANDLER_TYPE',E_USER_ERROR);
 
if (!defined('ADODB_ERROR_HANDLER')) define('ADODB_ERROR_HANDLER','ADODB_Error_Handler');
 
/**
* Default Error Handler. This will be called with the following params
*
* @param $dbms    the RDBMS you are connecting to
* @param $fn    the name of the calling function (in uppercase)
* @param $errno    the native error number from the database
* @param $errmsg  the native error msg from the database
* @param $p1    $fn specific parameter - see below
* @param $p2    $fn specific parameter - see below
* @param $thisConn  $current connection object - can be false if no connection object created
*/
function ADODB_Error_Handler($dbms, $fn, $errno, $errmsg, $p1, $p2, &$thisConnection)
{
  if (error_reporting() == 0) return; // obey @ protocol
  switch($fn) {
  case 'EXECUTE':
    $sql = $p1;
    $inputparams = $p2;
 
    $s = "$dbms error: [$errno: $errmsg] in $fn(\"$sql\")\n";
    break;
 
  case 'PCONNECT':
  case 'CONNECT':
    $host = $p1;
    $database = $p2;
 
    $s = "$dbms error: [$errno: $errmsg] in $fn($host, '****', '****', $database)\n";
    break;
  default:
    $s = "$dbms error: [$errno: $errmsg] in $fn($p1, $p2)\n";
    break;
  }
  /*
  * Log connection error somewhere
  *  0 message is sent to PHP's system logger, using the Operating System's system
  *    logging mechanism or a file, depending on what the error_log configuration
  *    directive is set to.
  *  1 message is sent by email to the address in the destination parameter.
  *    This is the only message type where the fourth parameter, extra_headers is used.
  *    This message type uses the same internal function as mail() does.
  *  2 message is sent through the PHP debugging connection.
  *    This option is only available if remote debugging has been enabled.
  *    In this case, the destination parameter specifies the host name or IP address
  *    and optionally, port number, of the socket receiving the debug information.
  *  3 message is appended to the file destination
  */
  if (defined('ADODB_ERROR_LOG_TYPE')) {
    $t = date('Y-m-d H:i:s');
    if (defined('ADODB_ERROR_LOG_DEST'))
      error_log("($t) $s", ADODB_ERROR_LOG_TYPE, ADODB_ERROR_LOG_DEST);
    else
      error_log("($t) $s", ADODB_ERROR_LOG_TYPE);
  }
 
 
  //print "<p>$s</p>";
  trigger_error($s,ADODB_ERROR_HANDLER_TYPE);
}
?>