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];
+ }
}
?>