put database/adodb related code into adodb.php

class ADOdb is now instantiated in global.php
This commit is contained in:
Michael Clemens 2009-05-12 20:20:18 +00:00
parent a22f2f312e
commit 53b848f605
5 changed files with 346 additions and 302 deletions

View File

@ -148,7 +148,7 @@ if (isset($_SESSION["logindata"]["user"]) && isset($_SESSION["logindata"]["pass"
// show Add New Entry Form
if ($_POST['Add'] == "Add") {
$sqlth = "SHOW COLUMNS from cfg_".$tsmmonitor->GETVars['qq'];
$sqlresth = $tsmmonitor->fetchArrayDB($sqlth, $tsmmonitor->conn);
$sqlresth = $adodb->fetchArrayDB($sqlth);
echo "<form action=".$_SERVER['PHP_SELF']."?q=".$tsmmonitor->GETVars['qq']."&m=".$tsmmonitor->GETVars['menu']." method='post'>";
echo "<table class='zebra'>";
echo "<tr><th>Key</th><th>Value</th></tr>";
@ -215,12 +215,12 @@ echo "TEST: ".$col['Field']." -> $colval<br>\n";
if ($_GET['action'] == "delete") {
echo $_POST['hidfield'];
$sql = "DELETE from cfg_".$_GET['q']." where id='".$_GET['id']."' LIMIT 1";
$tsmmonitor->execDB($sql, $tsmmonitor->conn);
$adodb->execDB($sql);
}
// Process update of an existing item or insert of a new one
} else if ($_POST['EditSave'] == "Save" || $_POST['AddSave'] == "Save") {
$sqlth = "SHOW COLUMNS from cfg_".$_GET['q'];
$sqlresth = $tsmmonitor->fetchArrayDB($sqlth, $tsmmonitor->conn);
$sqlresth = $adodb->fetchArrayDB($sqlth);
$colarray = array();
$colarray['id'] = $_POST['id'];
$set = "";
@ -261,7 +261,7 @@ echo "TEST: ".$col['Field']." -> $colval<br>\n";
} else if ($_POST['EditSave'] == "Save") {
$sql = "UPDATE cfg_".$_GET['q']." set ".$set." where id='".$_POST['id']."' LIMIT 1";
}
$tsmmonitor->updateDB("cfg_".$_GET['q'], $colarray, 'id', $tsmmonitor->conn);
$adodb->updateDB("cfg_".$_GET['q'], $colarray, 'id');
}
echo "<form action=".$_SERVER['PHP_SELF']."?q=".$tsmmonitor->GETVars['qq']."&m=".$tsmmonitor->GETVars['menu']." method='post'>";
echo "<table class='zebra'>";

239
includes/adodb.php Normal file
View File

@ -0,0 +1,239 @@
<?php
/*
************************************************************************
This file is part of TSM Monitor.
TSM Monitor is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
TSM Monitor 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 General Public License for more details.
You should have received a copy of the GNU General Public License
along with TSM Monitor. If not, see <http://www.gnu.org/licenses/>.
************************************************************************
*/
/**
*
* adodb.php, TSM Monitor
*
* DB Stuff for TSM Monitor
*
* @author Frank Fegert, Michael Clemens
* @package tsmmonitor
*/
/**
*
* Class ADOdb
*
*/
class ADOdb {
var $conn;
/**
* constructor - establishes a DB connection via ADODB
*
* @param string $host the hostname of the DB server
* @param string $port the portnumber for the DB connection
* @param string $user the username for the DB connection
* @param string $pass the password for the DB connection
* @param string $db_name the name of the DB
* @param string $db_type the type of the DB (currently only 'mysql')
* @param string $retr the number attempts for the DB connection before a failure is reported
* @return 0
*/
function ADOdb($host, $port = "3306", $user, $pass, $db_name, $db_type, $retr = 20) {
$try = 0;
$hostport = $host . ":" . $port;
$this->conn = NewADOConnection($db_type);
while ($try <= $retries) {
if ($this->conn->PConnect($hostport,$user,$pass,$db_name)) {
$this->conn = $this->conn;
return 0;
}
$try++;
usleep(50000);
}
die("FATAL: Cannot connect to database server on '$host':'$port'. Please make sure you have specified a valid database name in 'includes/config.php'\n");
return 0;
}
/**
* closeDB - close an open DB connection
*
* @return string
*/
function closeDB() {
if ($this->conn) {
return $this->conn->Close();
}
}
/**
* execDB - execute a SQL statement against the DB via ADODB
*
* @param string $sql SQL statement to execute
* @return ADORecordSet
*/
function execDB($sql) {
// $this->conn->debug = true;
$sql = $this->sanitizeSQL($sql);
$recordSet = &$this->conn->Execute($sql);
if (($recordSet) || ($this->conn->ErrorNo() == 0)) {
return($recordSet);
} else {
echo "<p style='font-size: 16px; font-weight: bold; color: red;'>Database Error (".$this->conn->ErrorNo().")</p>\n<p>".$this->conn->ErrorMsg()."</p>";
exit;
}
}
/**
* fetchCellDB - execute a SQL query against the DB via ADODB and
* return only the first column of the fist row found
* or a specified column of the fist row found
*
* @param string $sql SQL statement to execute
* @param $column_name Column name to use instead of the first column
* @return string Content of the cell as a single variable
*/
function fetchCellDB($sql, $column_name) {
//$this->conn->debug = true;
$sql = $this->sanitizeSQL($sql);
if ($column_name != '') {
$this->conn->SetFetchMode(ADODB_FETCH_ASSOC);
} else {
$this->conn->SetFetchMode(ADODB_FETCH_NUM);
}
$recordSet = $this->conn->Execute($sql);
if (($recordSet) || ($this->conn->ErrorNo() == 0)) {
if (!$recordSet->EOF) {
if ($column_name != '') {
$column = $recordSet->fields[$column_name];
}else{
$column = $recordSet->fields[0];
}
$recordSet->close();
return($column);
}
} else {
echo "<p style='font-size: 16px; font-weight: bold; color: red;'>Database Error (".$this->conn->ErrorNo().")</p>\n<p>".$this->conn->ErrorMsg()."</p>";
exit;
}
}
/**
* fetchRowDB - execute a SQL query against the DB via ADODB
* and return only the first row found
*
* @param string $sql SQL statement to execute
* @return array First row of results as an associative array
*/
function fetchRowDB($sql) {
//$this->conn->debug = true;
$sql = $this->sanitizeSQL($sql);
$this->conn->SetFetchMode(ADODB_FETCH_ASSOC);
$recordSet = $this->conn->Execute($sql);
if (($recordSet) || ($this->conn->ErrorNo() == 0)) {
if (!$recordSet->EOF) {
$recordFields = $recordSet->fields;
$recordSet->close();
return($recordFields);
}
} else {
echo "<p style='font-size: 16px; font-weight: bold; color: red;'>Database Error (".$this->conn->ErrorNo().")</p>\n<p>".$this->conn->ErrorMsg()."</p>";
exit;
}
}
/**
* fetchArrayDB - execute a SQL query against the DB via ADODB
* and return results in an associative array.
*
* @param string $sql SQL statement to execute
* @return array All results in an associative array
*/
function fetchArrayDB($sql) {
//$this->conn->debug = true;
$sql = $this->sanitizeSQL($sql);
$recordArray = array();
$this->conn->SetFetchMode(ADODB_FETCH_ASSOC);
$recordSet = &$this->conn->Execute($sql);
if (($recordSet) || ($this->conn->ErrorNo() == 0)) {
while ((!$recordSet->EOF) && ($recordSet)) {
$recordArray{sizeof($recordArray)} = $recordSet->fields;
$recordSet->MoveNext();
}
$recordSet->close();
return($recordArray);
} else {
echo "<p style='font-size: 16px; font-weight: bold; color: red;'>Database Error (".$this->conn->ErrorNo().")</p>\n<p>".$this->conn->ErrorMsg()."</p>";
exit;
}
}
/**
* updateDB - execute a SQL update statement against the DB via ADODB
* to update a record. If the record is not found, an insert
* statement is generated and executed.
*
* @param string $table The name of the table containing the record to be updated
* @param array $cells An array of columnname/value pairs of the record to be updated
* @param string $keys Name of the primary key
* @param boolean $autoquote Use intelligent auto-quoting
* @param ADOConnection $this->conn DB connection ID to run the SQL against
* @return string Auto-increment ID if insert was performed
*/
function updateDB($table, $cells, $keys, $autoquote = TRUE) {
//$this->conn->debug = true;
$this->conn->Replace($table, $cells, $keys, $autoquote);
return $this->conn->Insert_ID();
}
/**
* sanitizeSQL - removes unwanted chars in values passed for use in
* SQL statements
*
* @param string $sql SQL expression to sanitize
* @return string
*/
function sanitizeSQL($sql) {
$sql = str_replace(";", "\;", $sql);
$sql = str_replace("\n", "", $sql);
$sql = str_replace("\r", "", $sql);
$sql = str_replace("\t", " ", $sql);
return $sql;
}
}
?>

View File

@ -84,25 +84,25 @@ header("Pragma: no-cache");
// ** Include generic code and external libraries ** //
include ($config["library_path"] . "/adodb5/adodb.inc.php");
include_once($config["include_path"] . "/adodb.php");
include_once($config["include_path"] . "/tsmmonitor.php");
include_once($config["include_path"] . "/polld.php");
// ** instantiate TSMMonitor Class ** //
$tsmmonitor = new TSMMonitor();
// ** Connect to the database ** //
//$conn = connectDB($db_host, $db_port, $db_user, $db_password, $db_name, $db_type);
$tsmmonitor->conn = $tsmmonitor->connectDB($db_host, $db_port, $db_user, $db_password, $db_name, $db_type);
$adodb = new ADOdb($db_host, $db_port, $db_user, $db_password, $db_name, $db_type);
// ** instantiate TSMMonitor Class ** //
$tsmmonitor = new TSMMonitor($adodb);
// check to see if this is a new installation
$version = $tsmmonitor->fetchCellDB("select confval from cfg_config where confkey='version'", '', $tsmmonitor->conn);
$version = $adodb->fetchCellDB("select confval from cfg_config where confkey='version'", '', $tsmmonitor->conn);
if ($version != $config["tsm_monitor_version"] && basename($_SERVER['REQUEST_URI']) != 'install.php') {
header("Location: install.php");
exit;
}
// ** Initialize PHP session ** //
//initialize();
$tsmmonitor->initialize();
//$tsmmonitor->initialize();
// ** Include generic code and external libraries ** //
// ... more includes here

View File

@ -33,7 +33,7 @@
/**
*
* Class
* Class TSMMonitor
*
*/
@ -50,18 +50,19 @@ class TSMMonitor {
var $submenu;
var $adminmenu;
var $message;
var $conn;
var $adodb;
/**
* initialize - This function us called every time index.php is refreshed
* TSMMonitor - constructor
*
*/
function initialize() {
function TSMMonitor($adodb) {
$this->adodb = $adodb;
session_name("tsmmonitordev");
session_start();
@ -142,7 +143,7 @@ class TSMMonitor {
if (($_POST['Poll'] == "Poll Now!" || $_SESSION['timemachine']['date'] == "") && $this->queryarray[$this->GETVars['qq']]["polltype"]=="snapshot" || $_POST['s'] != "" && $this->GETVars['qq'] != "overview" && $this->GETVars['qq'] != "index") {
$qtable = $this->configarray["queryarray"][$this->GETVars['qq']]["name"];
$sql = "SELECT MAX(TimeStamp) FROM res_".$qtable."_".$this->GETVars["server"];
$res = $this->fetchArrayDB($sql, $this->conn);
$res = $this->adodb->fetchArrayDB($sql);
$resarr = (array)$res[0];
$_SESSION['timemachine']['date'] = $resarr["MAX(TimeStamp)"];
$_SESSION['timemachine']['time'] = $resarr["MAX(TimeStamp)"];
@ -163,6 +164,49 @@ class TSMMonitor {
/**
* $this->fetchSplitArrayDB - execute a SQL query against the DB via ADODB
* and return results in an associative array.
*
* @param string $sql SQL statement to execute
* @param string $rows_per_page number of rows per page a result will have
* @return array All results in an associative array
*/
function fetchSplitArrayDB($sql, $rows_per_page = '20') {
// $this->conn->debug = true;
$this->page = intval($_GET['page']);
$sql = $this->adodb->sanitizeSQL($sql);
$recordArray = array();
$this->adodb->conn->SetFetchMode(ADODB_FETCH_ASSOC);
$recordSet = $this->adodb->conn->Execute($sql);
if (($recordSet) || ($this->adodb->conn->ErrorNo() == 0)) {
$total_rows = $recordSet->RecordCount($recordSet);
$this->max_pages = ceil($total_rows/$rows_per_page);
if($this->page > $this->max_pages || $this->page <= 0) {
$this->page = 1;
}
$offset = $rows_per_page * ($this->page-1);
$endset = $offset + $rows_per_page;
$recordSet->Move($offset);
while (($recordSet->CurrentRow() < $endset) && ($recordSet->CurrentRow() < $total_rows) && ($recordSet)) {
$recordArray{sizeof($recordArray)} = $recordSet->fields;
$recordSet->MoveNext();
}
$recordSet->close();
return($recordArray);
} else {
echo "<p style='font-size: 16px; font-weight: bold; color: red;'>Database Error (".$this->conn->ErrorNo().")</p>\n<p>".$this->conn->ErrorMsg()."</p>";
exit;
}
}
/**
* showPageNavigation - generates a clickable navigation bar for sql results
* splitted by function fetchSplitArrayDB
@ -428,7 +472,7 @@ class TSMMonitor {
} else {
$sql = "SHOW COLUMNS FROM res_".$this->configarray["queryarray"][$this->GETVars['qq']]["name"]."_".$this->GETVars['server'];
}
$fieldnames = $this->fetchArrayDB($sql, $this->conn);
$fieldnames = $this->adodb->fetchArrayDB($sql);
// If table has more than one column
if (sizeof($fieldnames) > 1) {
@ -483,7 +527,7 @@ class TSMMonitor {
if ($user != "" && $pass != "") {
$sql = "SELECT password, role from cfg_users where username='".$user."'";
$ret = $this->fetchArrayDB($sql, $this->conn);
$ret = $this->adodb->fetchArrayDB($sql);
if ($ret[0] != "" && $ret[0]['password'] == md5($pass)) {
$_SESSION["logindata"]["role"] = $ret[0]['role'];
@ -561,7 +605,7 @@ class TSMMonitor {
$timestampquery = " WHERE timestamp between ".$startofday." and ".$endofday;
$sql = "SELECT distinct timestamp from res_".$qtable."_".$server.$timestampquery;
$ret = $this->fetchArrayDB($sql, $this->conn);
$ret = $this->adodb->fetchArrayDB($sql);
return $ret;
@ -582,7 +626,7 @@ class TSMMonitor {
$qtable = $this->configarray["queryarray"][$this->GETVars['qq']]["name"];
$sql = "SELECT MAX(TimeStamp) from res_".$qtable."_".$server;
$ret = $this->fetchArrayDB($sql, $this->conn);
$ret = $this->adodb->fetchArrayDB($sql);
$ret = (array)$ret[0];
return $ret["MAX(TimeStamp)"];
@ -601,7 +645,7 @@ class TSMMonitor {
$sqlth = "SELECT * from ".$tablename." LIMIT 1";
$sqlresth = $this->fetchArrayDB($sqlth, $this->conn);
$sqlresth = $this->adodb->fetchArrayDB($sqlth);
$columnnames = "";
// get all table fields to be selected
@ -644,7 +688,7 @@ class TSMMonitor {
if ($sqlres) $this->message = $sql;
$i = 1;
$rs = $this->fetchArrayDB($sql, $this->conn);
$rs = $this->adodb->fetchArrayDB($sql);
foreach ($rs as $row) {
if ($type=="list") {
@ -669,7 +713,7 @@ class TSMMonitor {
$outp .= "</tr>\n";
} else {
$outp = $this->fetchArrayDB($sql, $this->conn);
$outp = $this->adodb->fetchArrayDB($sql);
var_dump($outp);
}
}
@ -752,7 +796,7 @@ class TSMMonitor {
if ($bContinue) {
if ($type == "table") {
$i = 1;
$rs = $this->fetchSplitArrayDB($sql,$this->conn,20);
$rs = $this->fetchSplitArrayDB($sql,20);
foreach ($rs as $row) {
$color = "";
@ -791,10 +835,10 @@ class TSMMonitor {
}
}
else if ($type == "verticaltable") {
$outp = $this->fetchArrayDB($sql, $this->conn);
$outp = $this->adodb->fetchArrayDB($sql);
}
else if ($type == "timetable") {
$sqlres = $this->fetchArrayDB($sql, $this->conn);
$sqlres = $this->adodb->fetchArrayDB($sql);
$outp = array();;
foreach ($sqlres as $row) {
$rowarray2 = array();
@ -838,7 +882,7 @@ class TSMMonitor {
$arrop = $searcharr["op"];
}
$sql = "SHOW COLUMNS FROM res_".$this->configarray["queryarray"][$this->GETVars['qq']]["name"]."_".$this->GETVars['server'];
$fieldnames = $this->fetchArrayDB($sql, $this->conn);
$fieldnames = $this->adodb->fetchArrayDB($sql);
// Build Field Name Combobox
$fieldbox = "<select name='wcfield' size=1 onChange='' class='button'>";
@ -923,7 +967,7 @@ class TSMMonitor {
$outp .= "<tr><th>Status</th><th>Last Run</th><th>Next Run</th></tr>";
$sql = "SELECT enabled, status, lastrun, nextrun from log_polldstat";
$sqlres = $this->fetchArrayDB($sql, $this->conn);
$sqlres = $this->adodb->fetchArrayDB($sql);
foreach ($sqlres as $row) {
if ($row['enabled'] == "1") {
if ($row['status'] == "running") {
@ -949,7 +993,7 @@ class TSMMonitor {
$sql = "SELECT * from log_polldlog where timestamp > '".(time()-86400)."' order by timestamp desc";
$_SESSION["lastsql"] = $sql;
$rs = $this->fetchSplitArrayDB($sql,$this->conn,20);
$rs = $this->fetchSplitArrayDB($sql,20);
foreach ($rs as $row) {
if ($i % 2 == 0) {
$outp = $outp."<tr class='d1'>";
@ -1001,7 +1045,7 @@ class TSMMonitor {
} else {
$res = '';
$sql = "SELECT name, result from res_overview_".$this->GETVars['server']." where name='".$subindexqueryarray[$key]["name"]."'";
$sqlres = $this->fetchArrayDB($sql, $this->conn);
$sqlres = $this->adodb->fetchArrayDB($sql);
foreach ($sqlres as $row) {
$res .= $row['name']."§§§".$row['result'];
}
@ -1212,6 +1256,24 @@ class TSMMonitor {
/**
* findPath - find a external program in the search path
*
* @param string $binary the external program to search for
* @param string $search_path the search path in which to look for the external program
* @return string the full path to the external program or empty string if not found
*/
function findPath($binary, $search_path) {
foreach ($search_path as $path) {
if ((file_exists($path . "/" . $binary)) && (is_readable($path . "/" . $binary))) {
return($path . "/" . $binary);
}
}
}
/**
* getConfigArray - queries the DB and generates the global config array
*
@ -1224,7 +1286,7 @@ class TSMMonitor {
// Navigation
$query = "SELECT * from cfg_mainmenu";
$mainmenutablerows = $this->fetchArrayDB($query, $this->conn);
$mainmenutablerows = $this->adodb->fetchArrayDB($query);
$ret = array();
@ -1248,9 +1310,9 @@ class TSMMonitor {
$menuarray["main"] = $mainmenuarray;
$query = "SELECT * from cfg_mainmenu";
$mainmenutablerows = $this->fetchArrayDB($query, $this->conn);
$mainmenutablerows = $this->adodb->fetchArrayDB($query);
$query = "SELECT * from cfg_queries";
$querytablerows = $this->fetchArrayDB($query, $this->conn);
$querytablerows = $this->adodb->fetchArrayDB($query);
while (list ($key, $val) = each ($mainmenutablerows)) {
@ -1259,7 +1321,7 @@ class TSMMonitor {
$submenuarray = array();
$submenuarray[""] = "<---";
$query = "SELECT * from cfg_queries where parent='".$menuname."'";
$querytablerows = $this->fetchArrayDB($query, $this->conn);
$querytablerows = $this->adodb->fetchArrayDB($query);
while (list ($subkey, $submenuitem) = each ($querytablerows)) {
$submenuitem_name = $submenuitem['name'];
$submenuitem_label = $submenuitem['label'];
@ -1295,10 +1357,10 @@ class TSMMonitor {
$ret = array();
$query = "SELECT * from cfg_overviewboxes order by sortorder asc";
$queryoverviewboxes = $this->fetchArrayDB($query, $this->conn);
$queryoverviewboxes = $this->adodb->fetchArrayDB($query);
while (list ($subkey, $box) = each ($queryoverviewboxes)) {
$query = "SELECT * from cfg_overviewqueries where parent='".$box['name']."' order by sortorder asc";
$queryoverview = $this->fetchArrayDB($query, $this->conn);
$queryoverview = $this->adodb->fetchArrayDB($query);
$temp = array ();
//print_r($queryoverview);
while (list ($subkey, $ovquery) = each ($queryoverview)) {
@ -1312,7 +1374,7 @@ class TSMMonitor {
// Queries
$dbret = array();
$query = "SELECT * from cfg_queries";
$querytablerows = $this->fetchArrayDB($query, $this->conn);
$querytablerows = $this->adodb->fetchArrayDB($query);
while (list ($subkey, $queryrow) = each ($querytablerows)) {
$dbret[$queryrow['name']] = (array)$queryrow;
}
@ -1320,7 +1382,7 @@ class TSMMonitor {
// General settings
$query = "SELECT * from cfg_config";
$rows = $this->fetchArrayDB($query, $this->conn);
$rows = $this->adodb->fetchArrayDB($query);
$ret = array();
foreach ($rows as $key => $val) {
$ret[$val['confkey']] = $val['confval'];
@ -1329,12 +1391,12 @@ class TSMMonitor {
// Set Stylesheet
$query = "SELECT stylesheet from cfg_users where username='".$_SESSION["logindata"]["user"]."'";
$row = $this->fetchArrayDB($query, $this->conn);
$row = $this->adodb->fetchArrayDB($query);
$retArray["stylesheet"] = $row[0]['stylesheet'];
// Colors
$query = "SELECT * from cfg_colors";
$rows = $this->fetchArrayDB($query, $this->conn);
$rows = $this->adodb->fetchArrayDB($query);
$ret = array();
while (list ($key, $val) = each ($rows)) {
@ -1344,7 +1406,7 @@ class TSMMonitor {
// Servers
$query = "SELECT * from cfg_servers";
$rows = $this->fetchArrayDB($query, $this->conn);
$rows = $this->adodb->fetchArrayDB($query);
$ret = array();
while (list ($key, $val) = each ($rows)) {
@ -1358,263 +1420,6 @@ class TSMMonitor {
return $retArray;
}
/**
* findPath - find a external program in the search path
*
* @param string $binary the external program to search for
* @param string $search_path the search path in which to look for the external program
* @return string the full path to the external program or empty string if not found
*/
function findPath($binary, $search_path) {
foreach ($search_path as $path) {
if ((file_exists($path . "/" . $binary)) && (is_readable($path . "/" . $binary))) {
return($path . "/" . $binary);
}
}
}
/**
* connectDB - establish a DB connection via ADODB
*
* @param string $host the hostname of the DB server
* @param string $port the portnumber for the DB connection
* @param string $user the username for the DB connection
* @param string $pass the password for the DB connection
* @param string $db_name the name of the DB
* @param string $db_type the type of the DB (currently only 'mysql')
* @param string $retr the number attempts for the DB connection before a failure is reported
* @return ADOConnection DB connection ID or error code if connection failed
*/
function connectDB($host, $port = "3306", $user, $pass, $db_name, $db_type, $retr = 20) {
$try = 0;
$hostport = $host . ":" . $port;
$this->conn = NewADOConnection($db_type);
while ($try <= $retries) {
if ($this->conn->PConnect($hostport,$user,$pass,$db_name)) {
return($this->conn);
}
$try++;
usleep(50000);
}
die("FATAL: Cannot connect to database server on '$host':'$port'. Please make sure you have specified a valid database name in 'includes/config.php'\n");
return 0;
}
/**
* closeDB - close an open DB connection
*
* @param ADOConnection $DBconn DB connection ID to be closed
* @return string
*/
function closeDB($DBconn = FALSE) {
if ($DBconn) {
return $DBconn->Close();
}
}
/**
* execDB - execute a SQL statement against the DB via ADODB
*
* @param string $sql SQL statement to execute
* @param ADOConnection $DBconn DB connection ID to run the SQL against
* @return ADORecordSet
*/
function execDB($sql, $DBconn = FALSE) {
// $DBconn->debug = true;
$sql = $this->sanitizeSQL($sql);
$recordSet = &$DBconn->Execute($sql);
if (($recordSet) || ($DBconn->ErrorNo() == 0)) {
return($recordSet);
} else {
echo "<p style='font-size: 16px; font-weight: bold; color: red;'>Database Error (".$DBconn->ErrorNo().")</p>\n<p>".$DBconn->ErrorMsg()."</p>";
exit;
}
}
/**
* fetchCellDB - execute a SQL query against the DB via ADODB and
* return only the first column of the fist row found
* or a specified column of the fist row found
*
* @param string $sql SQL statement to execute
* @param $column_name Column name to use instead of the first column
* @param ADOConnection $DBconn DB connection ID to run the SQL against
* @return string Content of the cell as a single variable
*/
function fetchCellDB($sql, $column_name, $DBconn = FALSE) {
//$DBconn->debug = true;
$sql = $this->sanitizeSQL($sql);
if ($column_name != '') {
$DBconn->SetFetchMode(ADODB_FETCH_ASSOC);
} else {
$DBconn->SetFetchMode(ADODB_FETCH_NUM);
}
$recordSet = $DBconn->Execute($sql);
if (($recordSet) || ($DBconn->ErrorNo() == 0)) {
if (!$recordSet->EOF) {
if ($column_name != '') {
$column = $recordSet->fields[$column_name];
}else{
$column = $recordSet->fields[0];
}
$recordSet->close();
return($column);
}
} else {
echo "<p style='font-size: 16px; font-weight: bold; color: red;'>Database Error (".$DBconn->ErrorNo().")</p>\n<p>".$DBconn->ErrorMsg()."</p>";
exit;
}
}
/**
* fetchRowDB - execute a SQL query against the DB via ADODB
* and return only the first row found
*
* @param string $sql SQL statement to execute
* @param ADOConnection $DBconn DB connection ID to run the SQL against
* @return array First row of results as an associative array
*/
function fetchRowDB($sql, $DBconn = FALSE) {
//$DBconn->debug = true;
$sql = $this->sanitizeSQL($sql);
$DBconn->SetFetchMode(ADODB_FETCH_ASSOC);
$recordSet = $DBconn->Execute($sql);
if (($recordSet) || ($DBconn->ErrorNo() == 0)) {
if (!$recordSet->EOF) {
$recordFields = $recordSet->fields;
$recordSet->close();
return($recordFields);
}
} else {
echo "<p style='font-size: 16px; font-weight: bold; color: red;'>Database Error (".$DBconn->ErrorNo().")</p>\n<p>".$DBconn->ErrorMsg()."</p>";
exit;
}
}
/**
* fetchArrayDB - execute a SQL query against the DB via ADODB
* and return results in an associative array.
*
* @param string $sql SQL statement to execute
* @param ADOConnection $DBconn DB connection ID to run the SQL against
* @return array All results in an associative array
*/
function fetchArrayDB($sql, $DBconn = FALSE) {
//$DBconn->debug = true;
$sql = $this->sanitizeSQL($sql);
$recordArray = array();
$DBconn->SetFetchMode(ADODB_FETCH_ASSOC);
$recordSet = &$DBconn->Execute($sql);
if (($recordSet) || ($DBconn->ErrorNo() == 0)) {
while ((!$recordSet->EOF) && ($recordSet)) {
$recordArray{sizeof($recordArray)} = $recordSet->fields;
$recordSet->MoveNext();
}
$recordSet->close();
return($recordArray);
} else {
echo "<p style='font-size: 16px; font-weight: bold; color: red;'>Database Error (".$DBconn->ErrorNo().")</p>\n<p>".$DBconn->ErrorMsg()."</p>";
exit;
}
}
/**
* $this->fetchSplitArrayDB - execute a SQL query against the DB via ADODB
* and return results in an associative array.
*
* @param string $sql SQL statement to execute
* @param ADOConnection $DBconn DB connection ID to run the SQL against
* @param string $rows_per_page number of rows per page a result will have
* @return array All results in an associative array
*/
function fetchSplitArrayDB($sql, $DBconn = FALSE, $rows_per_page = '20') {
// $DBconn->debug = true;
$this->page = intval($_GET['page']);
$sql = $this->sanitizeSQL($sql);
$recordArray = array();
$DBconn->SetFetchMode(ADODB_FETCH_ASSOC);
$recordSet = &$DBconn->Execute($sql);
if (($recordSet) || ($DBconn->ErrorNo() == 0)) {
$total_rows = $recordSet->RecordCount($recordSet);
$this->max_pages = ceil($total_rows/$rows_per_page);
if($this->page > $this->max_pages || $this->page <= 0) {
$this->page = 1;
}
$offset = $rows_per_page * ($this->page-1);
$endset = $offset + $rows_per_page;
$recordSet->Move($offset);
while (($recordSet->CurrentRow() < $endset) && ($recordSet->CurrentRow() < $total_rows) && ($recordSet)) {
$recordArray{sizeof($recordArray)} = $recordSet->fields;
$recordSet->MoveNext();
}
$recordSet->close();
return($recordArray);
} else {
echo "<p style='font-size: 16px; font-weight: bold; color: red;'>Database Error (".$DBconn->ErrorNo().")</p>\n<p>".$DBconn->ErrorMsg()."</p>";
exit;
}
}
/**
* updateDB - execute a SQL update statement against the DB via ADODB
* to update a record. If the record is not found, an insert
* statement is generated and executed.
*
* @param string $table The name of the table containing the record to be updated
* @param array $cells An array of columnname/value pairs of the record to be updated
* @param string $keys Name of the primary key
* @param boolean $autoquote Use intelligent auto-quoting
* @param ADOConnection $DBconn DB connection ID to run the SQL against
* @return string Auto-increment ID if insert was performed
*/
function updateDB($table, $cells, $keys, $DBconn = FALSE, $autoquote = TRUE) {
//$DBconn->debug = true;
$DBconn->Replace($table, $cells, $keys, $autoquote);
return $DBconn->Insert_ID();
}
/**
* sanitizeSQL - removes unwanted chars in values passed for use in
* SQL statements
*
* @param string $sql SQL expression to sanitize
* @return string
*/
function sanitizeSQL($sql) {
$sql = str_replace(";", "\;", $sql);
$sql = str_replace("\n", "", $sql);
$sql = str_replace("\r", "", $sql);
$sql = str_replace("\t", " ", $sql);
return $sql;
}
}
?>

View File

@ -62,7 +62,7 @@ $ext_miss
$tsm_monitor_versions = array("0.1.0", "0.1.1");
$old_tsm_monitor_version = $tsmmonitor->fetchCellDB("select confval from cfg_config where confkey='version'", '', $tsmmonitor->conn);
$old_tsm_monitor_version = $adodb->fetchCellDB("select confval from cfg_config where confkey='version'", '');
// try to find current (old) version in the array
$old_version_index = array_search($old_tsm_monitor_version, $tsm_monitor_versions);
@ -173,11 +173,11 @@ if ($_REQUEST["step"] == "90") {
// Flush updated data to DB
foreach ($input as $name => $array) {
if (isset($_POST[$name])) {
$tsmmonitor->updateDB('cfg_config', array(confkey => "$name", confval => $_POST[$name], description => $array['name']), 'confkey', $tsmmonitor->conn);
$adodb->updateDB('cfg_config', array(confkey => "$name", confval => $_POST[$name], description => $array['name']), 'confkey');
}
}
$tsmmonitor->updateDB('cfg_config', array(confkey => 'version', confval => $config['tsm_monitor_version']), 'confkey', $tsmmonitor->conn);
$tsmmonitor->closeDB($tsmmonitor->conn);
$adodb->updateDB('cfg_config', array(confkey => 'version', confval => $config['tsm_monitor_version']), 'confkey');
$adodb->closeDB();
header("Location: index.php");
exit;
} elseif (($_REQUEST["step"] == "40") && ($_REQUEST["install_type"] == "20")) {