mirror of
https://github.com/kamilwylegala/cakephp2-php8.git
synced 2024-11-16 03:48:24 +00:00
d62b9ec65e
[1079] Merged [1005] committed by nate but not added to core prior to release. Merged [1078] prior to modifying all developers sandboxes. [1081] adding view and template directories [1082] adding base files for view generator [1083] correcting all package and sub package tags for in doc blocks. Making sure every file in the core has doc block in them [1084] renaming working copy of latest release [1093] Added fix for associations using underscores if var $useTable is set in the associated models. This closes ticket #11. [1094] Fix for Ticket #24. The problem was tracked to a variable in View::_render(); $loadedHelpers was being assigned a reference when it when it should not have been. [1096] Initial work on controller components needs testing. Also added a work around for the basics.php uses(). Using the define DS where the files from the original version are now located in deeper libs directories. [1097] committing a few typos in the code I added [1098] reformatting code in component.php [1104] changed the test route and corrected a regex in inflector. [1111] removing the contructor from dispatcher, it is not needed [1112] Changes made for errors when a file is not present in webroot. Fixed the regex used in Router::parse(). Change the error layout template. [1113] Changes to Folder class to allow setting the permissions mode when constructing. This class needs to be refactored and move everything that is in the contructor out. The constructor should set the vars for use in other Folder::"methods"(). Will work on this at a later time. git-svn-id: https://svn.cakephp.org/repo/trunk/cake@1114 3807eeeb-6ff5-0310-8944-8be069107fe0
258 lines
No EOL
6.4 KiB
PHP
258 lines
No EOL
6.4 KiB
PHP
<?php
|
|
/* SVN FILE: $Id$ */
|
|
|
|
/**
|
|
* {@link http://pear.php.net/package/DB PEAR::DB} layer for DBO.
|
|
*
|
|
* Long description for file
|
|
*
|
|
* PHP versions 4 and 5
|
|
*
|
|
* CakePHP : Rapid Development Framework <http://www.cakephp.org/>
|
|
* Copyright (c) 2005, CakePHP Authors/Developers
|
|
*
|
|
* Author(s): Michal Tatarynowicz aka Pies <tatarynowicz@gmail.com>
|
|
* Larry E. Masters aka PhpNut <nut@phpnut.com>
|
|
* Kamil Dzielinski aka Brego <brego.dk@gmail.com>
|
|
*
|
|
* Licensed under The MIT License
|
|
* Redistributions of files must retain the above copyright notice.
|
|
*
|
|
* @filesource
|
|
* @author CakePHP Authors/Developers
|
|
* @copyright Copyright (c) 2005, CakePHP Authors/Developers
|
|
* @link https://trac.cakephp.org/wiki/Authors Authors/Developers
|
|
* @package cake
|
|
* @subpackage cake.cake.libs.model.dbo
|
|
* @since CakePHP v 0.2.9
|
|
* @version $Revision$
|
|
* @modifiedby $LastChangedBy$
|
|
* @lastmodified $Date$
|
|
* @license http://www.opensource.org/licenses/mit-license.php The MIT License
|
|
*/
|
|
|
|
/**
|
|
* Create an include path required PEAR libraries.
|
|
*/
|
|
uses('model'.DS.'dbo'.DS.'dbo');
|
|
ini_set('include_path', ini_get('include_path') . PATH_SEPARATOR . PEAR);
|
|
vendor('Pear/DB');
|
|
|
|
/**
|
|
* {@link http://pear.php.net/package/DB PEAR::DB} layer for DBO.
|
|
*
|
|
* Long description for class
|
|
*
|
|
* @package cake
|
|
* @subpackage cake.cake.libs.model.dbo
|
|
* @since CakePHP v 0.2.9
|
|
*/
|
|
class DBO_Pear extends DBO
|
|
{
|
|
|
|
/**
|
|
* PEAR::DB object with which we connect.
|
|
*
|
|
* @var DB The connection object.
|
|
* @access private
|
|
*/
|
|
var $_pear = null;
|
|
|
|
/**
|
|
* Connects to the database using options in the given configuration array.
|
|
*
|
|
* @param array $config Configuration array for connecting
|
|
* @return boolean True if the database could be connected, else false
|
|
*/
|
|
function connect ($config)
|
|
{
|
|
$this->config = $config;
|
|
|
|
$dsn = $config['driver'].'://'.$config['login'].':'.$config['password'].'@'.$config['host'].'/'.$config['database'];
|
|
$options = array(
|
|
'debug' => DEBUG-1,
|
|
'portability' => DB_PORTABILITY_ALL,
|
|
);
|
|
|
|
$this->_pear =& DB::connect($dsn, $options);
|
|
$this->connected = $this->_pear? true: false;
|
|
|
|
return !(PEAR::isError($this->_pear));
|
|
|
|
}
|
|
|
|
/**
|
|
* Disconnects from database.
|
|
*
|
|
* @return boolean True if the database could be disconnected, else false
|
|
*/
|
|
function disconnect ()
|
|
{
|
|
die('Please implement DBO::disconnect() first.');
|
|
}
|
|
|
|
/**
|
|
* Executes given SQL statement.
|
|
*
|
|
* @param string $sql SQL statement
|
|
* @return resource Result resource identifier
|
|
*/
|
|
function execute ($sql)
|
|
{
|
|
return $this->_pear->query($sql);
|
|
}
|
|
|
|
/**
|
|
* Returns a row from given resultset as an array .
|
|
*
|
|
* @return array The fetched row as an array
|
|
*/
|
|
function fetchRow ()
|
|
{
|
|
return $this->_result->fetchRow(DB_FETCHMODE_ASSOC);
|
|
}
|
|
|
|
/**
|
|
* Returns an array of tables in the database. If there are no tables, an error is raised and the application exits.
|
|
* :WARNING: :TODO: POSTGRESQL & MYSQL ONLY! PEAR::DB doesn't support universal table listing.
|
|
*
|
|
* @return array Array of tablenames in the database
|
|
*/
|
|
function tablesList ()
|
|
{
|
|
$driver = $this->config['driver'];
|
|
$tables = array();
|
|
|
|
if ('postgres' == $driver)
|
|
{
|
|
$sql = "SELECT a.relname AS name
|
|
FROM pg_class a, pg_user b
|
|
WHERE ( relkind = 'r') and relname !~ '^pg_' AND relname !~ '^sql_'
|
|
AND relname !~ '^xin[vx][0-9]+' AND b.usesysid = a.relowner
|
|
AND NOT (EXISTS (SELECT viewname FROM pg_views WHERE viewname=a.relname));";
|
|
|
|
$result = $this->all($sql);
|
|
foreach ($result as $item)
|
|
{
|
|
$tables[] = $item['name'];
|
|
}
|
|
}
|
|
elseif ('mysql' == $driver)
|
|
{
|
|
$result = array();
|
|
|
|
$result = mysql_list_tables($this->config['database']);
|
|
while ($item = mysql_fetch_array($result))
|
|
{
|
|
$tables[] = $item[0];
|
|
}
|
|
}
|
|
else
|
|
{
|
|
die('Please implement DBO_Pear::tablesList() for your database driver.');
|
|
}
|
|
|
|
|
|
if (!$result)
|
|
{
|
|
trigger_error(ERROR_NO_TABLE_LIST, E_USER_ERROR);
|
|
exit;
|
|
}
|
|
else
|
|
{
|
|
return $tables;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Returns an array of the fields in given table name.
|
|
*
|
|
* @param string $tableName Name of database table to inspect
|
|
* @return array Fields in table. Keys are name and type
|
|
*/
|
|
function fields ($tableName)
|
|
{
|
|
$data = $this->_pear->tableInfo($tableName);
|
|
$fields = false;
|
|
|
|
foreach ($data as $item)
|
|
$fields[] = array('name'=>$item['name'], 'type'=>$item['type']);
|
|
|
|
return $fields;
|
|
}
|
|
|
|
/**
|
|
* Returns a quoted and escaped string of $data for use in an SQL statement.
|
|
*
|
|
* @param string $data String to be prepared for use in an SQL statement
|
|
* @return string Quoted and escaped
|
|
*/
|
|
function prepareValue ($data)
|
|
{
|
|
return $this->_pear->quoteSmart($data);
|
|
}
|
|
|
|
/**
|
|
* Returns a formatted error message from previous database operation.
|
|
*
|
|
* @return string Error message
|
|
*/
|
|
function lastError ()
|
|
{
|
|
return PEAR::isError($this->_result)? $this->_result->getMessage(): null;
|
|
}
|
|
|
|
/**
|
|
* Returns number of affected rows in previous database operation. If no previous operation exists, this returns false.
|
|
*
|
|
* @return int Number of affected rows
|
|
*/
|
|
function lastAffected ()
|
|
{
|
|
return $this->_pear->affectedRows();
|
|
}
|
|
|
|
/**
|
|
* Returns number of rows in previous resultset. If no previous resultset exists,
|
|
* this returns false.
|
|
*
|
|
* @return int Number of rows in resultset
|
|
*/
|
|
function lastNumRows ()
|
|
{
|
|
if (method_exists($this->_result, 'numRows'))
|
|
{
|
|
return $this->_result->numRows();
|
|
}
|
|
else
|
|
{
|
|
return false;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Returns the ID generated from the previous INSERT operation.
|
|
*
|
|
* @param string $table Name of the database table
|
|
* @return int
|
|
*/
|
|
function lastInsertId ($table)
|
|
{
|
|
return $this->field('id', "SELECT MAX(id) FROM {$table}");
|
|
}
|
|
|
|
/**
|
|
* Returns a limit statement in the correct format for the particular database.
|
|
*
|
|
* @param int $limit Limit of results returned
|
|
* @param int $offset Offset from which to start results
|
|
* @return string SQL limit/offset statement
|
|
*/
|
|
function selectLimit ($limit, $offset='0')
|
|
{
|
|
return ' ' . $this->_pear->modifyLimitQuery('', $offset, $limit);
|
|
}
|
|
|
|
}
|
|
|
|
?>
|