From 90faf20801aac44daca7315665a7ad681f16143d Mon Sep 17 00:00:00 2001 From: Ralf Becker Date: Sun, 5 Oct 2003 10:42:07 +0000 Subject: [PATCH] added some db-unspecific functions to deal with db-results-sets as associative arrays and form new querys from column/value arrays with automatical addslash/intval based on the column-type --- phpgwapi/inc/class.db.inc.php | 555 ++++++++++++++++++++-------------- 1 file changed, 328 insertions(+), 227 deletions(-) diff --git a/phpgwapi/inc/class.db.inc.php b/phpgwapi/inc/class.db.inc.php index 619496427d..9c83bef6c4 100644 --- a/phpgwapi/inc/class.db.inc.php +++ b/phpgwapi/inc/class.db.inc.php @@ -1,19 +1,19 @@ - hacked on by phpGW - * @copyright © 1998-2000 NetUSE AG Boris Erdmann, Kristian Koehntopp
2003 FreeSoftware Foundation - * @license LGPL - * @link http://www.sanisoft.com/phplib/manual/DB_sql.php - */ + * Database abstraction library + * + * This allows phpGroupWare to use multiple database backends + * + * @package phpgwapi + * @subpackage db + * @abstract + * @author NetUSE AG Boris Erdmann, Kristian Koehntopp
hacked on by phpGW + * @copyright © 1998-2000 NetUSE AG Boris Erdmann, Kristian Koehntopp
2003 FreeSoftware Foundation + * @license LGPL + * @link http://www.sanisoft.com/phplib/manual/DB_sql.php + */ class db_ { /** - * @var string $Host database host to connect to - */ + * @var string $Host database host to connect to + */ var $Host = ''; - /** - * @var string $Database name of database to use - */ + /** + * @var string $Database name of database to use + */ var $Database = ''; - /** - * @var string $User name of database user - */ + /** + * @var string $User name of database user + */ var $User = ''; - /** - * @var string $Password password for database user - */ + /** + * @var string $Password password for database user + */ var $Password = ''; /** - * @var bool $auto_stripslashes automatically remove slashes when returning field values - default False - */ + * @var bool $auto_stripslashes automatically remove slashes when returning field values - default False + */ var $auto_stripslashes = False; - /** - * @var int $Auto_Free automatically free results - 0 no, 1 yes - */ + /** + * @var int $Auto_Free automatically free results - 0 no, 1 yes + */ var $Auto_Free = 0; - /** - * @var int $Debug enable debuging - 0 no, 1 yes - */ + /** + * @var int $Debug enable debuging - 0 no, 1 yes + */ var $Debug = 0; - /** - * @var string $Halt_On_Error "yes" (halt with message), "no" (ignore errors quietly), "report" (ignore errror, but spit a warning) - */ + /** + * @var string $Halt_On_Error "yes" (halt with message), "no" (ignore errors quietly), "report" (ignore errror, but spit a warning) + */ var $Halt_On_Error = 'yes'; - /** - * @var string $Seq_Table table for storing sequences ???? - */ + /** + * @var string $Seq_Table table for storing sequences ???? + */ var $Seq_Table = 'db_sequence'; /** - * @var array $Record current record - */ + * @var array $Record current record + */ var $Record = array(); - /** - * @var int row number for current record - */ + /** + * @var int row number for current record + */ var $Row; /** - * @var int $Errno internal rdms error number for last error - */ + * @var int $Errno internal rdms error number for last error + */ var $Errno = 0; - /** - * @var string descriptive text from last error - */ + /** + * @var string descriptive text from last error + */ var $Error = ''; //i am not documenting private vars - skwashd :) @@ -106,54 +106,54 @@ var $soap = False; /** - * @param string $query query to be executed (optional) - */ - + * @param string $query query to be executed (optional) + */ + function db_($query = '') { $this->query($query); } /** - * @return int current connection id - */ + * @return int current connection id + */ function link_id() { return $this->Link_ID; } /** - * @return int id of current query - */ - function query_id() + * @return int id of current query + */ + function query_id() { return $this->Query_ID; } /** - * Open a connection to a database - * - * @param string $Database name of database to use (optional) - * @param string $Host database host to connect to (optional) - * @param string $User name of database user (optional) - * @var string $Password password for database user (optional) - */ + * Open a connection to a database + * + * @param string $Database name of database to use (optional) + * @param string $Host database host to connect to (optional) + * @param string $User name of database user (optional) + * @var string $Password password for database user (optional) + */ function connect($Database = '', $Host = '', $User = '', $Password = '') {} /** - * Close a connection to a database - only needed for persistent connections - */ + * Close a connection to a database - only needed for persistent connections + */ function disconnect() {} /** - * Escape strings before sending them to the database - * - * @param string $str the string to be escaped - * @return string escaped sting - */ - function db_addslashes($str) + * Escape strings before sending them to the database + * + * @param string $str the string to be escaped + * @return string escaped sting + */ + function db_addslashes($str) { if (!isset($str) || $str == '') { @@ -164,33 +164,33 @@ } /** - * Convert a unix timestamp to a rdms specific timestamp - * - * @param int unix timestamp - * @return string rdms specific timestamp - */ - function to_timestamp($epoch) + * Convert a unix timestamp to a rdms specific timestamp + * + * @param int unix timestamp + * @return string rdms specific timestamp + */ + function to_timestamp($epoch) {} /** - * Convert a rdms specific timestamp to a unix timestamp - * - * @param string rdms specific timestamp - * @return int unix timestamp - */ - function from_timestamp($timestamp) + * Convert a rdms specific timestamp to a unix timestamp + * + * @param string rdms specific timestamp + * @return int unix timestamp + */ + function from_timestamp($timestamp) {} - /** - * @deprecated - * @see limit_query() - */ + /** + * @deprecated + * @see limit_query() + */ function limit($start) {} /** - * Discard the current query result - */ + * Discard the current query result + */ function free() { @mysql_free_result($this->Query_ID); @@ -198,153 +198,153 @@ } /** - * Execute a query - * - * @param string $Query_String the query to be executed - * @param mixed $line the line method was called from - use __LINE__ - * @param string $file the file method was called from - use __FILE__ - * @return int current query id if sucesful and null if fails - */ + * Execute a query + * + * @param string $Query_String the query to be executed + * @param mixed $line the line method was called from - use __LINE__ + * @param string $file the file method was called from - use __FILE__ + * @return int current query id if sucesful and null if fails + */ function query($Query_String, $line = '', $file = '') {} /** - * Execute a query with limited result set - * - * @param string $Query_String the query to be executed - * @param int $offset row to start from - * @param mixed $line the line method was called from - use __LINE__ - * @param string $file the file method was called from - use __FILE__ - * @param int $num_rows number of rows to return (optional), if unset will use $GLOBALS['phpgw_info']['user']['preferences']['common']['maxmatchs'] - * @return int current query id if sucesful and null if fails - */ + * Execute a query with limited result set + * + * @param string $Query_String the query to be executed + * @param int $offset row to start from + * @param mixed $line the line method was called from - use __LINE__ + * @param string $file the file method was called from - use __FILE__ + * @param int $num_rows number of rows to return (optional), if unset will use $GLOBALS['phpgw_info']['user']['preferences']['common']['maxmatchs'] + * @return int current query id if sucesful and null if fails + */ function limit_query($Query_String, $offset, $line = '', $file = '', $num_rows = '') {} - /** - * Move to the next row in the results set - * - * @return bool was another row found? - */ + /** + * Move to the next row in the results set + * + * @return bool was another row found? + */ function next_record() {} /** - * Move to position in result set - * - * @param int $pos required row (optional), default first row - * @return int 1 if sucessful or 0 if not found - */ + * Move to position in result set + * + * @param int $pos required row (optional), default first row + * @return int 1 if sucessful or 0 if not found + */ function seek($pos = 0) {} /** - * Begin Transaction - * - * @return int current transaction id - */ - function transaction_begin() + * Begin Transaction + * + * @return int current transaction id + */ + function transaction_begin() { return True; } - /** - * Complete the transaction - * - * @return bool True if sucessful, False if fails - */ + /** + * Complete the transaction + * + * @return bool True if sucessful, False if fails + */ function transaction_commit() { return True; } - /** - * Rollback the current transaction - * - * @return bool True if sucessful, False if fails - */ + /** + * Rollback the current transaction + * + * @return bool True if sucessful, False if fails + */ function transaction_abort() { return True; } /** - * Find the primary key of the last insertion on the current db connection - * - * @param string $table name of table the insert was performed on - * @param string $field the autoincrement primary key of the table - * @return int the id, -1 if fails - */ - function get_last_insert_id($table, $field) + * Find the primary key of the last insertion on the current db connection + * + * @param string $table name of table the insert was performed on + * @param string $field the autoincrement primary key of the table + * @return int the id, -1 if fails + */ + function get_last_insert_id($table, $field) {} /** - * Lock a table - * - * @param string $table name of table to lock - * @param string $mode type of lock required (optional), default write - * @return bool True if sucessful, False if fails - */ + * Lock a table + * + * @param string $table name of table to lock + * @param string $mode type of lock required (optional), default write + * @return bool True if sucessful, False if fails + */ function lock($table, $mode='write') {} - /** - * Unlock a table - * - * @return bool True if sucessful, False if fails - */ + /** + * Unlock a table + * + * @return bool True if sucessful, False if fails + */ function unlock() {} /** - * Get the number of rows affected by last update - * - * @return int number of rows - */ + * Get the number of rows affected by last update + * + * @return int number of rows + */ function affected_rows() {} - /** - * Number of rows in current result set - * - * @return int number of rows - */ + /** + * Number of rows in current result set + * + * @return int number of rows + */ function num_rows() {} /** - * Number of fields in current row - * - * @return int number of fields - */ - function num_fields() + * Number of fields in current row + * + * @return int number of fields + */ + function num_fields() {} /** - * short hand for @see num_rows() - */ + * short hand for @see num_rows() + */ function nf() { return $this->num_rows(); } /** - * short hand for print @see num_rows - */ - function np() + * short hand for print @see num_rows + */ + function np() { print $this->num_rows(); } - /** - * Return the value of a filed - * - * @param string $String name of field - * @param bool $strip_slashes string escape chars from field(optional), default false - * @return string the field value - */ + /** + * Return the value of a column + * + * @param string/integer $Name name of field or positional index starting from 0 + * @param bool $strip_slashes string escape chars from field(optional), default false + * @return string the field value + */ function f($Name, $strip_slashes = False) { if ($strip_slashes || ($this->auto_stripslashes && ! $strip_slashes)) @@ -358,32 +358,55 @@ } /** - * Print the value of a field - * - * @param string $Name name of field to print - * @param bool $strip_slashes string escape chars from field(optional), default false - */ - function p($Name, $strip_slashes = True) + * Print the value of a field + * + * @param string $Name name of field to print + * @param bool $strip_slashes string escape chars from field(optional), default false + */ + function p($Name, $strip_slashes = True) { print $this->f($Name, $strip_slashes); } /** - * Get the id for the next sequence - not implemented! - * - * @param string $seq_name name of the sequence - * @return int sequence id - */ + * Returns a query-result-row as an associative array (no numerical keys !!!) + * + * @param bool $do_next_record should next_record() be called or not (default not) + * @return array/bool the associative array or False if no (more) result-row is availible + */ + function row($do_next_record=False) + { + if ($do_next_record && !$this->next_record() || !is_array($this->Record)) + { + return False; + } + $result = array(); + foreach($this->Record as $column => $value) + { + if (!is_numeric($column)) + { + $result[$column] = $value; + } + } + return $result; + } + + /** + * Get the id for the next sequence - not implemented! + * + * @param string $seq_name name of the sequence + * @return int sequence id + */ function nextid($seq_name) {} /** - * Get description of a table - * - * @param string $table name of table to describe - * @param bool $full optional, default False summary information, True full information - * @return array table meta data - */ + * Get description of a table + * + * @param string $table name of table to describe + * @param bool $full optional, default False summary information, True full information + * @return array table meta data + */ function metadata($table='',$full=false) { /* @@ -414,41 +437,119 @@ } /** - * Error handler - * - * @param string $msg error message - * @param int $line line of calling method/function (optional) - * @param string $file file of calling method/function (optional) - */ + * Error handler + * + * @param string $msg error message + * @param int $line line of calling method/function (optional) + * @param string $file file of calling method/function (optional) + */ function halt($msg, $line = '', $file = '') {} - /** - * Get a list of table names in the current database - * - * @return array list of the tables - */ + /** + * Get a list of table names in the current database + * + * @return array list of the tables + */ function table_names() { } - /** - * Return a list of indexes in current database - * - * @return array list of indexes - */ + /** + * Return a list of indexes in current database + * + * @return array list of indexes + */ function index_names() { return array(); } - /** - * Create a new database - * - * @param string $adminname name of database administrator user (optional) - * @param string $adminpasswd password for the database administrator user (optional) - */ + /** + * Create a new database + * + * @param string $adminname name of database administrator user (optional) + * @param string $adminpasswd password for the database administrator user (optional) + */ function create_database($adminname = '', $adminpasswd = '') {} + + /** + * Implodes an array of column-value pairs for the use in sql-querys. + * All data is either run through addslashes() or intval(). + * + * @author RalfBeckeroutdoor-training.de + * + * @param string $glue in most cases this will be either ',' or ' AND ', depending you your query + * @param array $array column-value pairs + * @param boolean $use_key should a "$key=" prefix each value, typicaly set to False for insert querys + * @param array/boolean $only if set to an array only colums which are set (as data !!!) are written + * typicaly used to form a WHERE-clause from the primary keys + * @param array/boolean $column_definitions this can be set to the column-definitions-array + * of your table ($tables_baseline[$table]['fd'] of the setup/tables_current.inc.php file). + * If its set, the column-type-data determinates if intval() or addslashes is used. + */ + function column_data_implode($glue,$array,$use_key=True,$only=False,$column_definitions=False) + { + if (!$column_definitions) + { + $column_definitions = $this->column_definitions; + } + $pairs = array(); + foreach($array as $key => $data) + { + if (!$only || in_array($key,$only)) + { + $column_type = is_array($column_definitions) ? @$colum_definitions[$key]['type'] : False; + $values[] = ($use_key ? $key.'=' : ''). + ($column_type == 'int' || $colum_type == 'auto' ? + intval($data) : "'".$this->db_addslashes($data)."'"); + } + } + return implode($glue,$values); + } + + /** + * Sets the default column-definitions for use with column_data_implode() + * + * @author RalfBeckeroutdoor-training.de + * + * @param array/boolean $column_definitions this can be set to the column-definitions-array + * of your table ($tables_baseline[$table]['fd'] of the setup/tables_current.inc.php file). + * If its set, the column-type-data determinates if intval() or addslashes is used. + */ + function set_column_definitions($column_definitions=False) + { + $this->column_definitions=$column_definitions; + } + + /** + * reads the table-definitions from the app's setup/tables_current.inc.php file + * + * @author RalfBeckeroutdoor-training.de + * + * @param string $app name of the app + * @param bool/string $table if set return only defintions of that table, else return all defintions + * @return the table-defintions or False if file not found + */ + function get_table_definitions($app,$table=False) + { + if (!isset($this->table_definitions[$app])) + { + $tables_current = PHPGW_INCLUDE_ROOT . "/$app/setup/tables_current.inc.php"; + + if (!@file_exists($tables_current)) + { + return $this->table_definitions[$app] = False; + } + include($tables_current); + $this->table_definitions[$app] = $phpgw_baseline; + } + if ($table && (!$this->table_definitions[$app] || !isset($this->table_definitions[$app][$table]))) + { + return False; + } + return $table ? $this->table_definitions[$app][$table] : $this->table_definitions[$app]; + } } ?>