init
This commit is contained in:
		
							
								
								
									
										405
									
								
								system/database/drivers/cubrid/cubrid_driver.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										405
									
								
								system/database/drivers/cubrid/cubrid_driver.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,405 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/) | ||||
|  * @license	https://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 2.1.0 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * CUBRID Database Adapter Class | ||||
|  * | ||||
|  * Note: _DB is an extender class that the app controller | ||||
|  * creates dynamically based on whether the query builder | ||||
|  * class is being used or not. | ||||
|  * | ||||
|  * @package		CodeIgniter | ||||
|  * @subpackage	Drivers | ||||
|  * @category	Database | ||||
|  * @author		Esen Sagynov | ||||
|  * @link		https://codeigniter.com/user_guide/database/ | ||||
|  */ | ||||
| class CI_DB_cubrid_driver extends CI_DB { | ||||
|  | ||||
| 	/** | ||||
| 	 * Database driver | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	public $dbdriver = 'cubrid'; | ||||
|  | ||||
| 	/** | ||||
| 	 * Auto-commit flag | ||||
| 	 * | ||||
| 	 * @var	bool | ||||
| 	 */ | ||||
| 	public $auto_commit = TRUE; | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Identifier escape character | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_escape_char = '`'; | ||||
|  | ||||
| 	/** | ||||
| 	 * ORDER BY random keyword | ||||
| 	 * | ||||
| 	 * @var	array | ||||
| 	 */ | ||||
| 	protected $_random_keyword = array('RANDOM()', 'RANDOM(%d)'); | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Class constructor | ||||
| 	 * | ||||
| 	 * @param	array	$params | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	public function __construct($params) | ||||
| 	{ | ||||
| 		parent::__construct($params); | ||||
|  | ||||
| 		if (preg_match('/^CUBRID:[^:]+(:[0-9][1-9]{0,4})?:[^:]+:[^:]*:[^:]*:(\?.+)?$/', $this->dsn, $matches)) | ||||
| 		{ | ||||
| 			if (stripos($matches[2], 'autocommit=off') !== FALSE) | ||||
| 			{ | ||||
| 				$this->auto_commit = FALSE; | ||||
| 			} | ||||
| 		} | ||||
| 		else | ||||
| 		{ | ||||
| 			// If no port is defined by the user, use the default value | ||||
| 			empty($this->port) OR $this->port = 33000; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Non-persistent database connection | ||||
| 	 * | ||||
| 	 * @param	bool	$persistent | ||||
| 	 * @return	resource | ||||
| 	 */ | ||||
| 	public function db_connect($persistent = FALSE) | ||||
| 	{ | ||||
| 		if (preg_match('/^CUBRID:[^:]+(:[0-9][1-9]{0,4})?:[^:]+:([^:]*):([^:]*):(\?.+)?$/', $this->dsn, $matches)) | ||||
| 		{ | ||||
| 			$func = ($persistent !== TRUE) ? 'cubrid_connect_with_url' : 'cubrid_pconnect_with_url'; | ||||
| 			return ($matches[2] === '' && $matches[3] === '' && $this->username !== '' && $this->password !== '') | ||||
| 				? $func($this->dsn, $this->username, $this->password) | ||||
| 				: $func($this->dsn); | ||||
| 		} | ||||
|  | ||||
| 		$func = ($persistent !== TRUE) ? 'cubrid_connect' : 'cubrid_pconnect'; | ||||
| 		return ($this->username !== '') | ||||
| 			? $func($this->hostname, $this->port, $this->database, $this->username, $this->password) | ||||
| 			: $func($this->hostname, $this->port, $this->database); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Reconnect | ||||
| 	 * | ||||
| 	 * Keep / reestablish the db connection if no queries have been | ||||
| 	 * sent for a length of time exceeding the server's idle timeout | ||||
| 	 * | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	public function reconnect() | ||||
| 	{ | ||||
| 		if (cubrid_ping($this->conn_id) === FALSE) | ||||
| 		{ | ||||
| 			$this->conn_id = FALSE; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Database version number | ||||
| 	 * | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	public function version() | ||||
| 	{ | ||||
| 		if (isset($this->data_cache['version'])) | ||||
| 		{ | ||||
| 			return $this->data_cache['version']; | ||||
| 		} | ||||
|  | ||||
| 		return ( ! $this->conn_id OR ($version = cubrid_get_server_info($this->conn_id)) === FALSE) | ||||
| 			? FALSE | ||||
| 			: $this->data_cache['version'] = $version; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Execute the query | ||||
| 	 * | ||||
| 	 * @param	string	$sql	an SQL query | ||||
| 	 * @return	resource | ||||
| 	 */ | ||||
| 	protected function _execute($sql) | ||||
| 	{ | ||||
| 		return cubrid_query($sql, $this->conn_id); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Begin Transaction | ||||
| 	 * | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	protected function _trans_begin() | ||||
| 	{ | ||||
| 		if (($autocommit = cubrid_get_autocommit($this->conn_id)) === NULL) | ||||
| 		{ | ||||
| 			return FALSE; | ||||
| 		} | ||||
| 		elseif ($autocommit === TRUE) | ||||
| 		{ | ||||
| 			return cubrid_set_autocommit($this->conn_id, CUBRID_AUTOCOMMIT_FALSE); | ||||
| 		} | ||||
|  | ||||
| 		return TRUE; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Commit Transaction | ||||
| 	 * | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	protected function _trans_commit() | ||||
| 	{ | ||||
| 		if ( ! cubrid_commit($this->conn_id)) | ||||
| 		{ | ||||
| 			return FALSE; | ||||
| 		} | ||||
|  | ||||
| 		if ($this->auto_commit && ! cubrid_get_autocommit($this->conn_id)) | ||||
| 		{ | ||||
| 			return cubrid_set_autocommit($this->conn_id, CUBRID_AUTOCOMMIT_TRUE); | ||||
| 		} | ||||
|  | ||||
| 		return TRUE; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Rollback Transaction | ||||
| 	 * | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	protected function _trans_rollback() | ||||
| 	{ | ||||
| 		if ( ! cubrid_rollback($this->conn_id)) | ||||
| 		{ | ||||
| 			return FALSE; | ||||
| 		} | ||||
|  | ||||
| 		if ($this->auto_commit && ! cubrid_get_autocommit($this->conn_id)) | ||||
| 		{ | ||||
| 			cubrid_set_autocommit($this->conn_id, CUBRID_AUTOCOMMIT_TRUE); | ||||
| 		} | ||||
|  | ||||
| 		return TRUE; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Platform-dependent string escape | ||||
| 	 * | ||||
| 	 * @param	string | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _escape_str($str) | ||||
| 	{ | ||||
| 		return cubrid_real_escape_string($str, $this->conn_id); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Affected Rows | ||||
| 	 * | ||||
| 	 * @return	int | ||||
| 	 */ | ||||
| 	public function affected_rows() | ||||
| 	{ | ||||
| 		return cubrid_affected_rows(); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Insert ID | ||||
| 	 * | ||||
| 	 * @return	int | ||||
| 	 */ | ||||
| 	public function insert_id() | ||||
| 	{ | ||||
| 		return cubrid_insert_id($this->conn_id); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * List table query | ||||
| 	 * | ||||
| 	 * Generates a platform-specific query string so that the table names can be fetched | ||||
| 	 * | ||||
| 	 * @param	bool	$prefix_limit | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _list_tables($prefix_limit = FALSE) | ||||
| 	{ | ||||
| 		$sql = 'SHOW TABLES'; | ||||
|  | ||||
| 		if ($prefix_limit !== FALSE && $this->dbprefix !== '') | ||||
| 		{ | ||||
| 			return $sql." LIKE '".$this->escape_like_str($this->dbprefix)."%'"; | ||||
| 		} | ||||
|  | ||||
| 		return $sql; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Show column query | ||||
| 	 * | ||||
| 	 * Generates a platform-specific query string so that the column names can be fetched | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _list_columns($table = '') | ||||
| 	{ | ||||
| 		return 'SHOW COLUMNS FROM '.$this->protect_identifiers($table, TRUE, NULL, FALSE); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Returns an object with field data | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	public function field_data($table) | ||||
| 	{ | ||||
| 		if (($query = $this->query('SHOW COLUMNS FROM '.$this->protect_identifiers($table, TRUE, NULL, FALSE))) === FALSE) | ||||
| 		{ | ||||
| 			return FALSE; | ||||
| 		} | ||||
| 		$query = $query->result_object(); | ||||
|  | ||||
| 		$retval = array(); | ||||
| 		for ($i = 0, $c = count($query); $i < $c; $i++) | ||||
| 		{ | ||||
| 			$retval[$i]			= new stdClass(); | ||||
| 			$retval[$i]->name		= $query[$i]->Field; | ||||
|  | ||||
| 			sscanf($query[$i]->Type, '%[a-z](%d)', | ||||
| 				$retval[$i]->type, | ||||
| 				$retval[$i]->max_length | ||||
| 			); | ||||
|  | ||||
| 			$retval[$i]->default		= $query[$i]->Default; | ||||
| 			$retval[$i]->primary_key	= (int) ($query[$i]->Key === 'PRI'); | ||||
| 		} | ||||
|  | ||||
| 		return $retval; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Error | ||||
| 	 * | ||||
| 	 * Returns an array containing code and message of the last | ||||
| 	 * database error that has occurred. | ||||
| 	 * | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	public function error() | ||||
| 	{ | ||||
| 		return array('code' => cubrid_errno($this->conn_id), 'message' => cubrid_error($this->conn_id)); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * FROM tables | ||||
| 	 * | ||||
| 	 * Groups tables in FROM clauses if needed, so there is no confusion | ||||
| 	 * about operator precedence. | ||||
| 	 * | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _from_tables() | ||||
| 	{ | ||||
| 		if ( ! empty($this->qb_join) && count($this->qb_from) > 1) | ||||
| 		{ | ||||
| 			return '('.implode(', ', $this->qb_from).')'; | ||||
| 		} | ||||
|  | ||||
| 		return implode(', ', $this->qb_from); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Close DB Connection | ||||
| 	 * | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	protected function _close() | ||||
| 	{ | ||||
| 		cubrid_close($this->conn_id); | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										230
									
								
								system/database/drivers/cubrid/cubrid_forge.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										230
									
								
								system/database/drivers/cubrid/cubrid_forge.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,230 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/) | ||||
|  * @license	https://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 2.1.0 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * CUBRID Forge Class | ||||
|  * | ||||
|  * @category	Database | ||||
|  * @author		Esen Sagynov | ||||
|  * @link		https://codeigniter.com/user_guide/database/ | ||||
|  */ | ||||
| class CI_DB_cubrid_forge extends CI_DB_forge { | ||||
|  | ||||
| 	/** | ||||
| 	 * CREATE DATABASE statement | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_create_database	= FALSE; | ||||
|  | ||||
| 	/** | ||||
| 	 * CREATE TABLE keys flag | ||||
| 	 * | ||||
| 	 * Whether table keys are created from within the | ||||
| 	 * CREATE TABLE statement. | ||||
| 	 * | ||||
| 	 * @var	bool | ||||
| 	 */ | ||||
| 	protected $_create_table_keys	= TRUE; | ||||
|  | ||||
| 	/** | ||||
| 	 * DROP DATABASE statement | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_drop_database	= FALSE; | ||||
|  | ||||
| 	/** | ||||
| 	 * CREATE TABLE IF statement | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_create_table_if	= FALSE; | ||||
|  | ||||
| 	/** | ||||
| 	 * UNSIGNED support | ||||
| 	 * | ||||
| 	 * @var	array | ||||
| 	 */ | ||||
| 	protected $_unsigned		= array( | ||||
| 		'SHORT'		=> 'INTEGER', | ||||
| 		'SMALLINT'	=> 'INTEGER', | ||||
| 		'INT'		=> 'BIGINT', | ||||
| 		'INTEGER'	=> 'BIGINT', | ||||
| 		'BIGINT'	=> 'NUMERIC', | ||||
| 		'FLOAT'		=> 'DOUBLE', | ||||
| 		'REAL'		=> 'DOUBLE' | ||||
| 	); | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * ALTER TABLE | ||||
| 	 * | ||||
| 	 * @param	string	$alter_type	ALTER type | ||||
| 	 * @param	string	$table		Table name | ||||
| 	 * @param	mixed	$field		Column definition | ||||
| 	 * @return	string|string[] | ||||
| 	 */ | ||||
| 	protected function _alter_table($alter_type, $table, $field) | ||||
| 	{ | ||||
| 		if (in_array($alter_type, array('DROP', 'ADD'), TRUE)) | ||||
| 		{ | ||||
| 			return parent::_alter_table($alter_type, $table, $field); | ||||
| 		} | ||||
|  | ||||
| 		$sql = 'ALTER TABLE '.$this->db->escape_identifiers($table); | ||||
| 		$sqls = array(); | ||||
| 		for ($i = 0, $c = count($field); $i < $c; $i++) | ||||
| 		{ | ||||
| 			if ($field[$i]['_literal'] !== FALSE) | ||||
| 			{ | ||||
| 				$sqls[] = $sql.' CHANGE '.$field[$i]['_literal']; | ||||
| 			} | ||||
| 			else | ||||
| 			{ | ||||
| 				$alter_type = empty($field[$i]['new_name']) ? ' MODIFY ' : ' CHANGE '; | ||||
| 				$sqls[] = $sql.$alter_type.$this->_process_column($field[$i]); | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		return $sqls; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Process column | ||||
| 	 * | ||||
| 	 * @param	array	$field | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _process_column($field) | ||||
| 	{ | ||||
| 		$extra_clause = isset($field['after']) | ||||
| 			? ' AFTER '.$this->db->escape_identifiers($field['after']) : ''; | ||||
|  | ||||
| 		if (empty($extra_clause) && isset($field['first']) && $field['first'] === TRUE) | ||||
| 		{ | ||||
| 			$extra_clause = ' FIRST'; | ||||
| 		} | ||||
|  | ||||
| 		return $this->db->escape_identifiers($field['name']) | ||||
| 			.(empty($field['new_name']) ? '' : ' '.$this->db->escape_identifiers($field['new_name'])) | ||||
| 			.' '.$field['type'].$field['length'] | ||||
| 			.$field['unsigned'] | ||||
| 			.$field['null'] | ||||
| 			.$field['default'] | ||||
| 			.$field['auto_increment'] | ||||
| 			.$field['unique'] | ||||
| 			.$extra_clause; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Field attribute TYPE | ||||
| 	 * | ||||
| 	 * Performs a data type mapping between different databases. | ||||
| 	 * | ||||
| 	 * @param	array	&$attributes | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	protected function _attr_type(&$attributes) | ||||
| 	{ | ||||
| 		switch (strtoupper($attributes['TYPE'])) | ||||
| 		{ | ||||
| 			case 'TINYINT': | ||||
| 				$attributes['TYPE'] = 'SMALLINT'; | ||||
| 				$attributes['UNSIGNED'] = FALSE; | ||||
| 				return; | ||||
| 			case 'MEDIUMINT': | ||||
| 				$attributes['TYPE'] = 'INTEGER'; | ||||
| 				$attributes['UNSIGNED'] = FALSE; | ||||
| 				return; | ||||
| 			case 'LONGTEXT': | ||||
| 				$attributes['TYPE'] = 'STRING'; | ||||
| 				return; | ||||
| 			default: return; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Process indexes | ||||
| 	 * | ||||
| 	 * @param	string	$table	(ignored) | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _process_indexes($table) | ||||
| 	{ | ||||
| 		$sql = ''; | ||||
|  | ||||
| 		for ($i = 0, $c = count($this->keys); $i < $c; $i++) | ||||
| 		{ | ||||
| 			if (is_array($this->keys[$i])) | ||||
| 			{ | ||||
| 				for ($i2 = 0, $c2 = count($this->keys[$i]); $i2 < $c2; $i2++) | ||||
| 				{ | ||||
| 					if ( ! isset($this->fields[$this->keys[$i][$i2]])) | ||||
| 					{ | ||||
| 						unset($this->keys[$i][$i2]); | ||||
| 						continue; | ||||
| 					} | ||||
| 				} | ||||
| 			} | ||||
| 			elseif ( ! isset($this->fields[$this->keys[$i]])) | ||||
| 			{ | ||||
| 				unset($this->keys[$i]); | ||||
| 				continue; | ||||
| 			} | ||||
|  | ||||
| 			is_array($this->keys[$i]) OR $this->keys[$i] = array($this->keys[$i]); | ||||
|  | ||||
| 			$sql .= ",\n\tKEY ".$this->db->escape_identifiers(implode('_', $this->keys[$i])) | ||||
| 				.' ('.implode(', ', $this->db->escape_identifiers($this->keys[$i])).')'; | ||||
| 		} | ||||
|  | ||||
| 		$this->keys = array(); | ||||
|  | ||||
| 		return $sql; | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										177
									
								
								system/database/drivers/cubrid/cubrid_result.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										177
									
								
								system/database/drivers/cubrid/cubrid_result.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,177 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/) | ||||
|  * @license	https://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 2.1.0 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * CUBRID Result Class | ||||
|  * | ||||
|  * This class extends the parent result class: CI_DB_result | ||||
|  * | ||||
|  * @category	Database | ||||
|  * @author		Esen Sagynov | ||||
|  * @link		https://codeigniter.com/user_guide/database/ | ||||
|  */ | ||||
| class CI_DB_cubrid_result extends CI_DB_result { | ||||
|  | ||||
| 	/** | ||||
| 	 * Number of rows in the result set | ||||
| 	 * | ||||
| 	 * @return	int | ||||
| 	 */ | ||||
| 	public function num_rows() | ||||
| 	{ | ||||
| 		return is_int($this->num_rows) | ||||
| 			? $this->num_rows | ||||
| 			: $this->num_rows = cubrid_num_rows($this->result_id); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Number of fields in the result set | ||||
| 	 * | ||||
| 	 * @return	int | ||||
| 	 */ | ||||
| 	public function num_fields() | ||||
| 	{ | ||||
| 		return cubrid_num_fields($this->result_id); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Fetch Field Names | ||||
| 	 * | ||||
| 	 * Generates an array of column names | ||||
| 	 * | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	public function list_fields() | ||||
| 	{ | ||||
| 		return cubrid_column_names($this->result_id); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Field data | ||||
| 	 * | ||||
| 	 * Generates an array of objects containing field meta-data | ||||
| 	 * | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	public function field_data() | ||||
| 	{ | ||||
| 		$retval = array(); | ||||
|  | ||||
| 		for ($i = 0, $c = $this->num_fields(); $i < $c; $i++) | ||||
| 		{ | ||||
| 			$retval[$i]			= new stdClass(); | ||||
| 			$retval[$i]->name		= cubrid_field_name($this->result_id, $i); | ||||
| 			$retval[$i]->type		= cubrid_field_type($this->result_id, $i); | ||||
| 			$retval[$i]->max_length		= cubrid_field_len($this->result_id, $i); | ||||
| 			$retval[$i]->primary_key	= (int) (strpos(cubrid_field_flags($this->result_id, $i), 'primary_key') !== FALSE); | ||||
| 		} | ||||
|  | ||||
| 		return $retval; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Free the result | ||||
| 	 * | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	public function free_result() | ||||
| 	{ | ||||
| 		if (is_resource($this->result_id) OR | ||||
| 			(get_resource_type($this->result_id) === 'Unknown' && preg_match('/Resource id #/', strval($this->result_id)))) | ||||
| 		{ | ||||
| 			cubrid_close_request($this->result_id); | ||||
| 			$this->result_id = FALSE; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Data Seek | ||||
| 	 * | ||||
| 	 * Moves the internal pointer to the desired offset. We call | ||||
| 	 * this internally before fetching results to make sure the | ||||
| 	 * result set starts at zero. | ||||
| 	 * | ||||
| 	 * @param	int	$n | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	public function data_seek($n = 0) | ||||
| 	{ | ||||
| 		return cubrid_data_seek($this->result_id, $n); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Result - associative array | ||||
| 	 * | ||||
| 	 * Returns the result set as an array | ||||
| 	 * | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	protected function _fetch_assoc() | ||||
| 	{ | ||||
| 		return cubrid_fetch_assoc($this->result_id); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Result - object | ||||
| 	 * | ||||
| 	 * Returns the result set as an object | ||||
| 	 * | ||||
| 	 * @param	string	$class_name | ||||
| 	 * @return	object | ||||
| 	 */ | ||||
| 	protected function _fetch_object($class_name = 'stdClass') | ||||
| 	{ | ||||
| 		return cubrid_fetch_object($this->result_id, $class_name); | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										79
									
								
								system/database/drivers/cubrid/cubrid_utility.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										79
									
								
								system/database/drivers/cubrid/cubrid_utility.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,79 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/) | ||||
|  * @license	https://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 2.1.0 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * CUBRID Utility Class | ||||
|  * | ||||
|  * @category	Database | ||||
|  * @author		Esen Sagynov | ||||
|  * @link		https://codeigniter.com/user_guide/database/ | ||||
|  */ | ||||
| class CI_DB_cubrid_utility extends CI_DB_utility { | ||||
|  | ||||
| 	/** | ||||
| 	 * List databases | ||||
| 	 * | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	public function list_databases() | ||||
| 	{ | ||||
| 		if (isset($this->db->data_cache['db_names'])) | ||||
| 		{ | ||||
| 			return $this->db->data_cache['db_names']; | ||||
| 		} | ||||
|  | ||||
| 		return $this->db->data_cache['db_names'] = cubrid_list_dbs($this->db->conn_id); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * CUBRID Export | ||||
| 	 * | ||||
| 	 * @param	array	Preferences | ||||
| 	 * @return	mixed | ||||
| 	 */ | ||||
| 	protected function _backup($params = array()) | ||||
| 	{ | ||||
| 		// No SQL based support in CUBRID as of version 8.4.0. Database or | ||||
| 		// table backup can be performed using CUBRID Manager | ||||
| 		// database administration tool. | ||||
| 		return $this->db->display_error('db_unsupported_feature'); | ||||
| 	} | ||||
| } | ||||
							
								
								
									
										11
									
								
								system/database/drivers/cubrid/index.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								system/database/drivers/cubrid/index.html
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,11 @@ | ||||
| <!DOCTYPE html> | ||||
| <html> | ||||
| <head> | ||||
| 	<title>403 Forbidden</title> | ||||
| </head> | ||||
| <body> | ||||
|  | ||||
| <p>Directory access is forbidden.</p> | ||||
|  | ||||
| </body> | ||||
| </html> | ||||
							
								
								
									
										413
									
								
								system/database/drivers/ibase/ibase_driver.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										413
									
								
								system/database/drivers/ibase/ibase_driver.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,413 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/) | ||||
|  * @license	https://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 3.0.0 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * Firebird/Interbase Database Adapter Class | ||||
|  * | ||||
|  * Note: _DB is an extender class that the app controller | ||||
|  * creates dynamically based on whether the query builder | ||||
|  * class is being used or not. | ||||
|  * | ||||
|  * @package		CodeIgniter | ||||
|  * @subpackage	Drivers | ||||
|  * @category	Database | ||||
|  * @author		EllisLab Dev Team | ||||
|  * @link		https://codeigniter.com/user_guide/database/ | ||||
|  */ | ||||
| class CI_DB_ibase_driver extends CI_DB { | ||||
|  | ||||
| 	/** | ||||
| 	 * Database driver | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	public $dbdriver = 'ibase'; | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * ORDER BY random keyword | ||||
| 	 * | ||||
| 	 * @var	array | ||||
| 	 */ | ||||
| 	protected $_random_keyword = array('RAND()', 'RAND()'); | ||||
|  | ||||
| 	/** | ||||
| 	 * IBase Transaction status flag | ||||
| 	 * | ||||
| 	 * @var	resource | ||||
| 	 */ | ||||
| 	protected $_ibase_trans; | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Non-persistent database connection | ||||
| 	 * | ||||
| 	 * @param	bool	$persistent | ||||
| 	 * @return	resource | ||||
| 	 */ | ||||
| 	public function db_connect($persistent = FALSE) | ||||
| 	{ | ||||
| 		return ($persistent === TRUE) | ||||
| 			? ibase_pconnect($this->hostname.':'.$this->database, $this->username, $this->password, $this->char_set) | ||||
| 			: ibase_connect($this->hostname.':'.$this->database, $this->username, $this->password, $this->char_set); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Database version number | ||||
| 	 * | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	public function version() | ||||
| 	{ | ||||
| 		if (isset($this->data_cache['version'])) | ||||
| 		{ | ||||
| 			return $this->data_cache['version']; | ||||
| 		} | ||||
|  | ||||
| 		if (($service = ibase_service_attach($this->hostname, $this->username, $this->password))) | ||||
| 		{ | ||||
| 			$this->data_cache['version'] = ibase_server_info($service, IBASE_SVC_SERVER_VERSION); | ||||
|  | ||||
| 			// Don't keep the service open | ||||
| 			ibase_service_detach($service); | ||||
| 			return $this->data_cache['version']; | ||||
| 		} | ||||
|  | ||||
| 		return FALSE; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Execute the query | ||||
| 	 * | ||||
| 	 * @param	string	$sql	an SQL query | ||||
| 	 * @return	resource | ||||
| 	 */ | ||||
| 	protected function _execute($sql) | ||||
| 	{ | ||||
| 		return ibase_query(isset($this->_ibase_trans) ? $this->_ibase_trans : $this->conn_id, $sql); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Begin Transaction | ||||
| 	 * | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	protected function _trans_begin() | ||||
| 	{ | ||||
| 		if (($trans_handle = ibase_trans($this->conn_id)) === FALSE) | ||||
| 		{ | ||||
| 			return FALSE; | ||||
| 		} | ||||
|  | ||||
| 		$this->_ibase_trans = $trans_handle; | ||||
| 		return TRUE; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Commit Transaction | ||||
| 	 * | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	protected function _trans_commit() | ||||
| 	{ | ||||
| 		if (ibase_commit($this->_ibase_trans)) | ||||
| 		{ | ||||
| 			$this->_ibase_trans = NULL; | ||||
| 			return TRUE; | ||||
| 		} | ||||
|  | ||||
| 		return FALSE; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Rollback Transaction | ||||
| 	 * | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	protected function _trans_rollback() | ||||
| 	{ | ||||
| 		if (ibase_rollback($this->_ibase_trans)) | ||||
| 		{ | ||||
| 			$this->_ibase_trans = NULL; | ||||
| 			return TRUE; | ||||
| 		} | ||||
|  | ||||
| 		return FALSE; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Affected Rows | ||||
| 	 * | ||||
| 	 * @return	int | ||||
| 	 */ | ||||
| 	public function affected_rows() | ||||
| 	{ | ||||
| 		return ibase_affected_rows($this->conn_id); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Insert ID | ||||
| 	 * | ||||
| 	 * @param	string	$generator_name | ||||
| 	 * @param	int	$inc_by | ||||
| 	 * @return	int | ||||
| 	 */ | ||||
| 	public function insert_id($generator_name, $inc_by = 0) | ||||
| 	{ | ||||
| 		//If a generator hasn't been used before it will return 0 | ||||
| 		return ibase_gen_id('"'.$generator_name.'"', $inc_by); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * List table query | ||||
| 	 * | ||||
| 	 * Generates a platform-specific query string so that the table names can be fetched | ||||
| 	 * | ||||
| 	 * @param	bool	$prefix_limit | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _list_tables($prefix_limit = FALSE) | ||||
| 	{ | ||||
| 		$sql = 'SELECT TRIM("RDB$RELATION_NAME") AS TABLE_NAME FROM "RDB$RELATIONS" WHERE "RDB$RELATION_NAME" NOT LIKE \'RDB$%\' AND "RDB$RELATION_NAME" NOT LIKE \'MON$%\''; | ||||
|  | ||||
| 		if ($prefix_limit !== FALSE && $this->dbprefix !== '') | ||||
| 		{ | ||||
| 			return $sql.' AND TRIM("RDB$RELATION_NAME") AS TABLE_NAME LIKE \''.$this->escape_like_str($this->dbprefix)."%' " | ||||
| 				.sprintf($this->_like_escape_str, $this->_like_escape_chr); | ||||
| 		} | ||||
|  | ||||
| 		return $sql; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Show column query | ||||
| 	 * | ||||
| 	 * Generates a platform-specific query string so that the column names can be fetched | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _list_columns($table = '') | ||||
| 	{ | ||||
| 		return 'SELECT TRIM("RDB$FIELD_NAME") AS COLUMN_NAME FROM "RDB$RELATION_FIELDS" WHERE "RDB$RELATION_NAME" = '.$this->escape($table); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Returns an object with field data | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	public function field_data($table) | ||||
| 	{ | ||||
| 		$sql = 'SELECT "rfields"."RDB$FIELD_NAME" AS "name", | ||||
| 				CASE "fields"."RDB$FIELD_TYPE" | ||||
| 					WHEN 7 THEN \'SMALLINT\' | ||||
| 					WHEN 8 THEN \'INTEGER\' | ||||
| 					WHEN 9 THEN \'QUAD\' | ||||
| 					WHEN 10 THEN \'FLOAT\' | ||||
| 					WHEN 11 THEN \'DFLOAT\' | ||||
| 					WHEN 12 THEN \'DATE\' | ||||
| 					WHEN 13 THEN \'TIME\' | ||||
| 					WHEN 14 THEN \'CHAR\' | ||||
| 					WHEN 16 THEN \'INT64\' | ||||
| 					WHEN 27 THEN \'DOUBLE\' | ||||
| 					WHEN 35 THEN \'TIMESTAMP\' | ||||
| 					WHEN 37 THEN \'VARCHAR\' | ||||
| 					WHEN 40 THEN \'CSTRING\' | ||||
| 					WHEN 261 THEN \'BLOB\' | ||||
| 					ELSE NULL | ||||
| 				END AS "type", | ||||
| 				"fields"."RDB$FIELD_LENGTH" AS "max_length", | ||||
| 				"rfields"."RDB$DEFAULT_VALUE" AS "default" | ||||
| 			FROM "RDB$RELATION_FIELDS" "rfields" | ||||
| 				JOIN "RDB$FIELDS" "fields" ON "rfields"."RDB$FIELD_SOURCE" = "fields"."RDB$FIELD_NAME" | ||||
| 			WHERE "rfields"."RDB$RELATION_NAME" = '.$this->escape($table).' | ||||
| 			ORDER BY "rfields"."RDB$FIELD_POSITION"'; | ||||
|  | ||||
| 		return (($query = $this->query($sql)) !== FALSE) | ||||
| 			? $query->result_object() | ||||
| 			: FALSE; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Error | ||||
| 	 * | ||||
| 	 * Returns an array containing code and message of the last | ||||
| 	 * database error that has occurred. | ||||
| 	 * | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	public function error() | ||||
| 	{ | ||||
| 		return array('code' => ibase_errcode(), 'message' => ibase_errmsg()); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Update statement | ||||
| 	 * | ||||
| 	 * Generates a platform-specific update string from the supplied data | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @param	array	$values | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _update($table, $values) | ||||
| 	{ | ||||
| 		$this->qb_limit = FALSE; | ||||
| 		return parent::_update($table, $values); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Truncate statement | ||||
| 	 * | ||||
| 	 * Generates a platform-specific truncate string from the supplied data | ||||
| 	 * | ||||
| 	 * If the database does not support the TRUNCATE statement, | ||||
| 	 * then this method maps to 'DELETE FROM table' | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _truncate($table) | ||||
| 	{ | ||||
| 		return 'DELETE FROM '.$table; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Delete statement | ||||
| 	 * | ||||
| 	 * Generates a platform-specific delete string from the supplied data | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _delete($table) | ||||
| 	{ | ||||
| 		$this->qb_limit = FALSE; | ||||
| 		return parent::_delete($table); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * LIMIT | ||||
| 	 * | ||||
| 	 * Generates a platform-specific LIMIT clause | ||||
| 	 * | ||||
| 	 * @param	string	$sql	SQL Query | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _limit($sql) | ||||
| 	{ | ||||
| 		// Limit clause depends on if Interbase or Firebird | ||||
| 		if (stripos($this->version(), 'firebird') !== FALSE) | ||||
| 		{ | ||||
| 			$select = 'FIRST '.$this->qb_limit | ||||
| 				.($this->qb_offset ? ' SKIP '.$this->qb_offset : ''); | ||||
| 		} | ||||
| 		else | ||||
| 		{ | ||||
| 			$select = 'ROWS ' | ||||
| 				.($this->qb_offset ? $this->qb_offset.' TO '.($this->qb_limit + $this->qb_offset) : $this->qb_limit); | ||||
| 		} | ||||
|  | ||||
| 		return preg_replace('`SELECT`i', 'SELECT '.$select, $sql, 1); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Insert batch statement | ||||
| 	 * | ||||
| 	 * Generates a platform-specific insert string from the supplied data. | ||||
| 	 * | ||||
| 	 * @param	string	$table	Table name | ||||
| 	 * @param	array	$keys	INSERT keys | ||||
| 	 * @param	array	$values	INSERT values | ||||
| 	 * @return	string|bool | ||||
| 	 */ | ||||
| 	protected function _insert_batch($table, $keys, $values) | ||||
| 	{ | ||||
| 		return ($this->db_debug) ? $this->display_error('db_unsupported_feature') : FALSE; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Close DB Connection | ||||
| 	 * | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	protected function _close() | ||||
| 	{ | ||||
| 		ibase_close($this->conn_id); | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										251
									
								
								system/database/drivers/ibase/ibase_forge.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										251
									
								
								system/database/drivers/ibase/ibase_forge.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,251 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/) | ||||
|  * @license	https://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 3.0.0 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * Interbase/Firebird Forge Class | ||||
|  * | ||||
|  * @category	Database | ||||
|  * @author		EllisLab Dev Team | ||||
|  * @link		https://codeigniter.com/user_guide/database/ | ||||
|  */ | ||||
| class CI_DB_ibase_forge extends CI_DB_forge { | ||||
|  | ||||
| 	/** | ||||
| 	 * CREATE TABLE IF statement | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_create_table_if	= FALSE; | ||||
|  | ||||
| 	/** | ||||
| 	 * RENAME TABLE statement | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_rename_table	= FALSE; | ||||
|  | ||||
| 	/** | ||||
| 	 * DROP TABLE IF statement | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_drop_table_if	= FALSE; | ||||
|  | ||||
| 	/** | ||||
| 	 * UNSIGNED support | ||||
| 	 * | ||||
| 	 * @var	array | ||||
| 	 */ | ||||
| 	protected $_unsigned		= array( | ||||
| 		'SMALLINT'	=> 'INTEGER', | ||||
| 		'INTEGER'	=> 'INT64', | ||||
| 		'FLOAT'		=> 'DOUBLE PRECISION' | ||||
| 	); | ||||
|  | ||||
| 	/** | ||||
| 	 * NULL value representation in CREATE/ALTER TABLE statements | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_null		= 'NULL'; | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Create database | ||||
| 	 * | ||||
| 	 * @param	string	$db_name | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	public function create_database($db_name) | ||||
| 	{ | ||||
| 		// Firebird databases are flat files, so a path is required | ||||
|  | ||||
| 		// Hostname is needed for remote access | ||||
| 		empty($this->db->hostname) OR $db_name = $this->hostname.':'.$db_name; | ||||
|  | ||||
| 		return parent::create_database('"'.$db_name.'"'); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Drop database | ||||
| 	 * | ||||
| 	 * @param	string	$db_name	(ignored) | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	public function drop_database($db_name) | ||||
| 	{ | ||||
| 		if ( ! ibase_drop_db($this->conn_id)) | ||||
| 		{ | ||||
| 			return ($this->db->db_debug) ? $this->db->display_error('db_unable_to_drop') : FALSE; | ||||
| 		} | ||||
| 		elseif ( ! empty($this->db->data_cache['db_names'])) | ||||
| 		{ | ||||
| 			$key = array_search(strtolower($this->db->database), array_map('strtolower', $this->db->data_cache['db_names']), TRUE); | ||||
| 			if ($key !== FALSE) | ||||
| 			{ | ||||
| 				unset($this->db->data_cache['db_names'][$key]); | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		return TRUE; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * ALTER TABLE | ||||
| 	 * | ||||
| 	 * @param	string	$alter_type	ALTER type | ||||
| 	 * @param	string	$table		Table name | ||||
| 	 * @param	mixed	$field		Column definition | ||||
| 	 * @return	string|string[] | ||||
| 	 */ | ||||
| 	protected function _alter_table($alter_type, $table, $field) | ||||
|  	{ | ||||
| 		if (in_array($alter_type, array('DROP', 'ADD'), TRUE)) | ||||
| 		{ | ||||
| 			return parent::_alter_table($alter_type, $table, $field); | ||||
| 		} | ||||
|  | ||||
| 		$sql = 'ALTER TABLE '.$this->db->escape_identifiers($table); | ||||
| 		$sqls = array(); | ||||
| 		for ($i = 0, $c = count($field); $i < $c; $i++) | ||||
| 		{ | ||||
| 			if ($field[$i]['_literal'] !== FALSE) | ||||
| 			{ | ||||
| 				return FALSE; | ||||
| 			} | ||||
|  | ||||
| 			if (isset($field[$i]['type'])) | ||||
| 			{ | ||||
| 				$sqls[] = $sql.' ALTER COLUMN '.$this->db->escape_identififers($field[$i]['name']) | ||||
| 					.' TYPE '.$field[$i]['type'].$field[$i]['length']; | ||||
| 			} | ||||
|  | ||||
| 			if ( ! empty($field[$i]['default'])) | ||||
| 			{ | ||||
| 				$sqls[] = $sql.' ALTER COLUMN '.$this->db->escape_identifiers($field[$i]['name']) | ||||
| 					.' SET DEFAULT '.$field[$i]['default']; | ||||
| 			} | ||||
|  | ||||
| 			if (isset($field[$i]['null'])) | ||||
| 			{ | ||||
| 				$sqls[] = 'UPDATE "RDB$RELATION_FIELDS" SET "RDB$NULL_FLAG" = ' | ||||
| 					.($field[$i]['null'] === TRUE ? 'NULL' : '1') | ||||
| 					.' WHERE "RDB$FIELD_NAME" = '.$this->db->escape($field[$i]['name']) | ||||
| 					.' AND "RDB$RELATION_NAME" = '.$this->db->escape($table); | ||||
| 			} | ||||
|  | ||||
| 			if ( ! empty($field[$i]['new_name'])) | ||||
| 			{ | ||||
| 				$sqls[] = $sql.' ALTER COLUMN '.$this->db->escape_identifiers($field[$i]['name']) | ||||
| 					.' TO '.$this->db->escape_identifiers($field[$i]['new_name']); | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		return $sqls; | ||||
|  	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Process column | ||||
| 	 * | ||||
| 	 * @param	array	$field | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _process_column($field) | ||||
| 	{ | ||||
| 		return $this->db->escape_identifiers($field['name']) | ||||
| 			.' '.$field['type'].$field['length'] | ||||
| 			.$field['null'] | ||||
| 			.$field['unique'] | ||||
| 			.$field['default']; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Field attribute TYPE | ||||
| 	 * | ||||
| 	 * Performs a data type mapping between different databases. | ||||
| 	 * | ||||
| 	 * @param	array	&$attributes | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	protected function _attr_type(&$attributes) | ||||
| 	{ | ||||
| 		switch (strtoupper($attributes['TYPE'])) | ||||
| 		{ | ||||
| 			case 'TINYINT': | ||||
| 				$attributes['TYPE'] = 'SMALLINT'; | ||||
| 				$attributes['UNSIGNED'] = FALSE; | ||||
| 				return; | ||||
| 			case 'MEDIUMINT': | ||||
| 				$attributes['TYPE'] = 'INTEGER'; | ||||
| 				$attributes['UNSIGNED'] = FALSE; | ||||
| 				return; | ||||
| 			case 'INT': | ||||
| 				$attributes['TYPE'] = 'INTEGER'; | ||||
| 				return; | ||||
| 			case 'BIGINT': | ||||
| 				$attributes['TYPE'] = 'INT64'; | ||||
| 				return; | ||||
| 			default: return; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Field attribute AUTO_INCREMENT | ||||
| 	 * | ||||
| 	 * @param	array	&$attributes | ||||
| 	 * @param	array	&$field | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	protected function _attr_auto_increment(&$attributes, &$field) | ||||
| 	{ | ||||
| 		// Not supported | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										161
									
								
								system/database/drivers/ibase/ibase_result.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										161
									
								
								system/database/drivers/ibase/ibase_result.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,161 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/) | ||||
|  * @license	https://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 3.0.0 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * Interbase/Firebird Result Class | ||||
|  * | ||||
|  * This class extends the parent result class: CI_DB_result | ||||
|  * | ||||
|  * @category	Database | ||||
|  * @author		EllisLab Dev Team | ||||
|  * @link		https://codeigniter.com/user_guide/database/ | ||||
|  */ | ||||
| class CI_DB_ibase_result extends CI_DB_result { | ||||
|  | ||||
| 	/** | ||||
| 	 * Number of fields in the result set | ||||
| 	 * | ||||
| 	 * @return	int | ||||
| 	 */ | ||||
| 	public function num_fields() | ||||
| 	{ | ||||
| 		return ibase_num_fields($this->result_id); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Fetch Field Names | ||||
| 	 * | ||||
| 	 * Generates an array of column names | ||||
| 	 * | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	public function list_fields() | ||||
| 	{ | ||||
| 		$field_names = array(); | ||||
| 		for ($i = 0, $num_fields = $this->num_fields(); $i < $num_fields; $i++) | ||||
| 		{ | ||||
| 			$info = ibase_field_info($this->result_id, $i); | ||||
| 			$field_names[] = $info['name']; | ||||
| 		} | ||||
|  | ||||
| 		return $field_names; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Field data | ||||
| 	 * | ||||
| 	 * Generates an array of objects containing field meta-data | ||||
| 	 * | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	public function field_data() | ||||
| 	{ | ||||
| 		$retval = array(); | ||||
| 		for ($i = 0, $c = $this->num_fields(); $i < $c; $i++) | ||||
| 		{ | ||||
| 			$info = ibase_field_info($this->result_id, $i); | ||||
|  | ||||
| 			$retval[$i]			= new stdClass(); | ||||
| 			$retval[$i]->name		= $info['name']; | ||||
| 			$retval[$i]->type		= $info['type']; | ||||
| 			$retval[$i]->max_length		= $info['length']; | ||||
| 		} | ||||
|  | ||||
| 		return $retval; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Free the result | ||||
| 	 * | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	public function free_result() | ||||
| 	{ | ||||
| 		ibase_free_result($this->result_id); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Result - associative array | ||||
| 	 * | ||||
| 	 * Returns the result set as an array | ||||
| 	 * | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	protected function _fetch_assoc() | ||||
| 	{ | ||||
| 		return ibase_fetch_assoc($this->result_id, IBASE_FETCH_BLOBS); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Result - object | ||||
| 	 * | ||||
| 	 * Returns the result set as an object | ||||
| 	 * | ||||
| 	 * @param	string	$class_name | ||||
| 	 * @return	object | ||||
| 	 */ | ||||
| 	protected function _fetch_object($class_name = 'stdClass') | ||||
| 	{ | ||||
| 		$row = ibase_fetch_object($this->result_id, IBASE_FETCH_BLOBS); | ||||
|  | ||||
| 		if ($class_name === 'stdClass' OR ! $row) | ||||
| 		{ | ||||
| 			return $row; | ||||
| 		} | ||||
|  | ||||
| 		$class_name = new $class_name(); | ||||
| 		foreach ($row as $key => $value) | ||||
| 		{ | ||||
| 			$class_name->$key = $value; | ||||
| 		} | ||||
|  | ||||
| 		return $class_name; | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										69
									
								
								system/database/drivers/ibase/ibase_utility.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										69
									
								
								system/database/drivers/ibase/ibase_utility.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,69 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/) | ||||
|  * @license	https://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 3.0.0 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * Interbase/Firebird Utility Class | ||||
|  * | ||||
|  * @category	Database | ||||
|  * @author		EllisLab Dev Team | ||||
|  * @link		https://codeigniter.com/user_guide/database/ | ||||
|  */ | ||||
| class CI_DB_ibase_utility extends CI_DB_utility { | ||||
|  | ||||
| 	/** | ||||
| 	 * Export | ||||
| 	 * | ||||
| 	 * @param	string	$filename | ||||
| 	 * @return	mixed | ||||
| 	 */ | ||||
| 	protected function _backup($filename) | ||||
| 	{ | ||||
| 		if ($service = ibase_service_attach($this->db->hostname, $this->db->username, $this->db->password)) | ||||
| 		{ | ||||
| 			$res = ibase_backup($service, $this->db->database, $filename.'.fbk'); | ||||
|  | ||||
| 			// Close the service connection | ||||
| 			ibase_service_detach($service); | ||||
| 			return $res; | ||||
| 		} | ||||
|  | ||||
| 		return FALSE; | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										11
									
								
								system/database/drivers/ibase/index.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								system/database/drivers/ibase/index.html
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,11 @@ | ||||
| <!DOCTYPE html> | ||||
| <html> | ||||
| <head> | ||||
| 	<title>403 Forbidden</title> | ||||
| </head> | ||||
| <body> | ||||
|  | ||||
| <p>Directory access is forbidden.</p> | ||||
|  | ||||
| </body> | ||||
| </html> | ||||
							
								
								
									
										11
									
								
								system/database/drivers/index.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								system/database/drivers/index.html
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,11 @@ | ||||
| <!DOCTYPE html> | ||||
| <html> | ||||
| <head> | ||||
| 	<title>403 Forbidden</title> | ||||
| </head> | ||||
| <body> | ||||
|  | ||||
| <p>Directory access is forbidden.</p> | ||||
|  | ||||
| </body> | ||||
| </html> | ||||
							
								
								
									
										11
									
								
								system/database/drivers/mssql/index.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								system/database/drivers/mssql/index.html
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,11 @@ | ||||
| <!DOCTYPE html> | ||||
| <html> | ||||
| <head> | ||||
| 	<title>403 Forbidden</title> | ||||
| </head> | ||||
| <body> | ||||
|  | ||||
| <p>Directory access is forbidden.</p> | ||||
|  | ||||
| </body> | ||||
| </html> | ||||
							
								
								
									
										518
									
								
								system/database/drivers/mssql/mssql_driver.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										518
									
								
								system/database/drivers/mssql/mssql_driver.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,518 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/) | ||||
|  * @license	https://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 1.3.0 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * MS SQL Database Adapter Class | ||||
|  * | ||||
|  * Note: _DB is an extender class that the app controller | ||||
|  * creates dynamically based on whether the query builder | ||||
|  * class is being used or not. | ||||
|  * | ||||
|  * @package		CodeIgniter | ||||
|  * @subpackage	Drivers | ||||
|  * @category	Database | ||||
|  * @author		EllisLab Dev Team | ||||
|  * @link		https://codeigniter.com/user_guide/database/ | ||||
|  */ | ||||
| class CI_DB_mssql_driver extends CI_DB { | ||||
|  | ||||
| 	/** | ||||
| 	 * Database driver | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	public $dbdriver = 'mssql'; | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * ORDER BY random keyword | ||||
| 	 * | ||||
| 	 * @var	array | ||||
| 	 */ | ||||
| 	protected $_random_keyword = array('NEWID()', 'RAND(%d)'); | ||||
|  | ||||
| 	/** | ||||
| 	 * Quoted identifier flag | ||||
| 	 * | ||||
| 	 * Whether to use SQL-92 standard quoted identifier | ||||
| 	 * (double quotes) or brackets for identifier escaping. | ||||
| 	 * | ||||
| 	 * @var	bool | ||||
| 	 */ | ||||
| 	protected $_quoted_identifier = TRUE; | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Class constructor | ||||
| 	 * | ||||
| 	 * Appends the port number to the hostname, if needed. | ||||
| 	 * | ||||
| 	 * @param	array	$params | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	public function __construct($params) | ||||
| 	{ | ||||
| 		parent::__construct($params); | ||||
|  | ||||
| 		if ( ! empty($this->port)) | ||||
| 		{ | ||||
| 			$this->hostname .= (DIRECTORY_SEPARATOR === '\\' ? ',' : ':').$this->port; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Non-persistent database connection | ||||
| 	 * | ||||
| 	 * @param	bool	$persistent | ||||
| 	 * @return	resource | ||||
| 	 */ | ||||
| 	public function db_connect($persistent = FALSE) | ||||
| 	{ | ||||
| 		$this->conn_id = ($persistent) | ||||
| 				? mssql_pconnect($this->hostname, $this->username, $this->password) | ||||
| 				: mssql_connect($this->hostname, $this->username, $this->password); | ||||
|  | ||||
| 		if ( ! $this->conn_id) | ||||
| 		{ | ||||
| 			return FALSE; | ||||
| 		} | ||||
|  | ||||
| 		// ---------------------------------------------------------------- | ||||
|  | ||||
| 		// Select the DB... assuming a database name is specified in the config file | ||||
| 		if ($this->database !== '' && ! $this->db_select()) | ||||
| 		{ | ||||
| 			log_message('error', 'Unable to select database: '.$this->database); | ||||
|  | ||||
| 			return ($this->db_debug === TRUE) | ||||
| 				? $this->display_error('db_unable_to_select', $this->database) | ||||
| 				: FALSE; | ||||
| 		} | ||||
|  | ||||
| 		// Determine how identifiers are escaped | ||||
| 		$query = $this->query('SELECT CASE WHEN (@@OPTIONS | 256) = @@OPTIONS THEN 1 ELSE 0 END AS qi'); | ||||
| 		$query = $query->row_array(); | ||||
| 		$this->_quoted_identifier = empty($query) ? FALSE : (bool) $query['qi']; | ||||
| 		$this->_escape_char = ($this->_quoted_identifier) ? '"' : array('[', ']'); | ||||
|  | ||||
| 		return $this->conn_id; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Select the database | ||||
| 	 * | ||||
| 	 * @param	string	$database | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	public function db_select($database = '') | ||||
| 	{ | ||||
| 		if ($database === '') | ||||
| 		{ | ||||
| 			$database = $this->database; | ||||
| 		} | ||||
|  | ||||
| 		// Note: Escaping is required in the event that the DB name | ||||
| 		// contains reserved characters. | ||||
| 		if (mssql_select_db('['.$database.']', $this->conn_id)) | ||||
| 		{ | ||||
| 			$this->database = $database; | ||||
| 			$this->data_cache = array(); | ||||
| 			return TRUE; | ||||
| 		} | ||||
|  | ||||
| 		return FALSE; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Execute the query | ||||
| 	 * | ||||
| 	 * @param	string	$sql	an SQL query | ||||
| 	 * @return	mixed	resource if rows are returned, bool otherwise | ||||
| 	 */ | ||||
| 	protected function _execute($sql) | ||||
| 	{ | ||||
| 		return mssql_query($sql, $this->conn_id); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Begin Transaction | ||||
| 	 * | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	protected function _trans_begin() | ||||
| 	{ | ||||
| 		return $this->simple_query('BEGIN TRAN'); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Commit Transaction | ||||
| 	 * | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	protected function _trans_commit() | ||||
| 	{ | ||||
| 		return $this->simple_query('COMMIT TRAN'); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Rollback Transaction | ||||
| 	 * | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	protected function _trans_rollback() | ||||
| 	{ | ||||
| 		return $this->simple_query('ROLLBACK TRAN'); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Affected Rows | ||||
| 	 * | ||||
| 	 * @return	int | ||||
| 	 */ | ||||
| 	public function affected_rows() | ||||
| 	{ | ||||
| 		return mssql_rows_affected($this->conn_id); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Insert ID | ||||
| 	 * | ||||
| 	 * Returns the last id created in the Identity column. | ||||
| 	 * | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	public function insert_id() | ||||
| 	{ | ||||
| 		$query = version_compare($this->version(), '8', '>=') | ||||
| 			? 'SELECT SCOPE_IDENTITY() AS last_id' | ||||
| 			: 'SELECT @@IDENTITY AS last_id'; | ||||
|  | ||||
| 		$query = $this->query($query); | ||||
| 		$query = $query->row(); | ||||
| 		return $query->last_id; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Set client character set | ||||
| 	 * | ||||
| 	 * @param	string	$charset | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	protected function _db_set_charset($charset) | ||||
| 	{ | ||||
| 		return (ini_set('mssql.charset', $charset) !== FALSE); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Version number query string | ||||
| 	 * | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _version() | ||||
| 	{ | ||||
| 		return "SELECT SERVERPROPERTY('ProductVersion') AS ver"; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * List table query | ||||
| 	 * | ||||
| 	 * Generates a platform-specific query string so that the table names can be fetched | ||||
| 	 * | ||||
| 	 * @param	bool	$prefix_limit | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _list_tables($prefix_limit = FALSE) | ||||
| 	{ | ||||
| 		$sql = 'SELECT '.$this->escape_identifiers('name') | ||||
| 			.' FROM '.$this->escape_identifiers('sysobjects') | ||||
| 			.' WHERE '.$this->escape_identifiers('type')." = 'U'"; | ||||
|  | ||||
| 		if ($prefix_limit !== FALSE && $this->dbprefix !== '') | ||||
| 		{ | ||||
| 			$sql .= ' AND '.$this->escape_identifiers('name')." LIKE '".$this->escape_like_str($this->dbprefix)."%' " | ||||
| 				.sprintf($this->_like_escape_str, $this->_like_escape_chr); | ||||
| 		} | ||||
|  | ||||
| 		return $sql.' ORDER BY '.$this->escape_identifiers('name'); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * List column query | ||||
| 	 * | ||||
| 	 * Generates a platform-specific query string so that the column names can be fetched | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _list_columns($table = '') | ||||
| 	{ | ||||
| 		return 'SELECT COLUMN_NAME | ||||
| 			FROM INFORMATION_SCHEMA.Columns | ||||
| 			WHERE UPPER(TABLE_NAME) = '.$this->escape(strtoupper($table)); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Returns an object with field data | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	public function field_data($table) | ||||
| 	{ | ||||
| 		$sql = 'SELECT COLUMN_NAME, DATA_TYPE, CHARACTER_MAXIMUM_LENGTH, NUMERIC_PRECISION, COLUMN_DEFAULT | ||||
| 			FROM INFORMATION_SCHEMA.Columns | ||||
| 			WHERE UPPER(TABLE_NAME) = '.$this->escape(strtoupper($table)); | ||||
|  | ||||
| 		if (($query = $this->query($sql)) === FALSE) | ||||
| 		{ | ||||
| 			return FALSE; | ||||
| 		} | ||||
| 		$query = $query->result_object(); | ||||
|  | ||||
| 		$retval = array(); | ||||
| 		for ($i = 0, $c = count($query); $i < $c; $i++) | ||||
| 		{ | ||||
| 			$retval[$i]			= new stdClass(); | ||||
| 			$retval[$i]->name		= $query[$i]->COLUMN_NAME; | ||||
| 			$retval[$i]->type		= $query[$i]->DATA_TYPE; | ||||
| 			$retval[$i]->max_length		= ($query[$i]->CHARACTER_MAXIMUM_LENGTH > 0) ? $query[$i]->CHARACTER_MAXIMUM_LENGTH : $query[$i]->NUMERIC_PRECISION; | ||||
| 			$retval[$i]->default		= $query[$i]->COLUMN_DEFAULT; | ||||
| 		} | ||||
|  | ||||
| 		return $retval; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Error | ||||
| 	 * | ||||
| 	 * Returns an array containing code and message of the last | ||||
| 	 * database error that has occurred. | ||||
| 	 * | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	public function error() | ||||
| 	{ | ||||
| 		// We need this because the error info is discarded by the | ||||
| 		// server the first time you request it, and query() already | ||||
| 		// calls error() once for logging purposes when a query fails. | ||||
| 		static $error = array('code' => 0, 'message' => NULL); | ||||
|  | ||||
| 		$message = mssql_get_last_message(); | ||||
| 		if ( ! empty($message)) | ||||
| 		{ | ||||
| 			$error['code']    = $this->query('SELECT @@ERROR AS code')->row()->code; | ||||
| 			$error['message'] = $message; | ||||
| 		} | ||||
|  | ||||
| 		return $error; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Update statement | ||||
| 	 * | ||||
| 	 * Generates a platform-specific update string from the supplied data | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @param	array	$values | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _update($table, $values) | ||||
| 	{ | ||||
| 		$this->qb_limit = FALSE; | ||||
| 		$this->qb_orderby = array(); | ||||
| 		return parent::_update($table, $values); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Truncate statement | ||||
| 	 * | ||||
| 	 * Generates a platform-specific truncate string from the supplied data | ||||
| 	 * | ||||
| 	 * If the database does not support the TRUNCATE statement, | ||||
| 	 * then this method maps to 'DELETE FROM table' | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _truncate($table) | ||||
| 	{ | ||||
| 		return 'TRUNCATE TABLE '.$table; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Delete statement | ||||
| 	 * | ||||
| 	 * Generates a platform-specific delete string from the supplied data | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _delete($table) | ||||
| 	{ | ||||
| 		if ($this->qb_limit) | ||||
| 		{ | ||||
| 			return 'WITH ci_delete AS (SELECT TOP '.$this->qb_limit.' * FROM '.$table.$this->_compile_wh('qb_where').') DELETE FROM ci_delete'; | ||||
| 		} | ||||
|  | ||||
| 		return parent::_delete($table); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * LIMIT | ||||
| 	 * | ||||
| 	 * Generates a platform-specific LIMIT clause | ||||
| 	 * | ||||
| 	 * @param	string	$sql	SQL Query | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _limit($sql) | ||||
| 	{ | ||||
| 		$limit = $this->qb_offset + $this->qb_limit; | ||||
|  | ||||
| 		// As of SQL Server 2005 (9.0.*) ROW_NUMBER() is supported, | ||||
| 		// however an ORDER BY clause is required for it to work | ||||
| 		if (version_compare($this->version(), '9', '>=') && $this->qb_offset && ! empty($this->qb_orderby)) | ||||
| 		{ | ||||
| 			$orderby = $this->_compile_order_by(); | ||||
|  | ||||
| 			// We have to strip the ORDER BY clause | ||||
| 			$sql = trim(substr($sql, 0, strrpos($sql, $orderby))); | ||||
|  | ||||
| 			// Get the fields to select from our subquery, so that we can avoid CI_rownum appearing in the actual results | ||||
| 			if (count($this->qb_select) === 0 OR strpos(implode(',', $this->qb_select), '*') !== FALSE) | ||||
| 			{ | ||||
| 				$select = '*'; // Inevitable | ||||
| 			} | ||||
| 			else | ||||
| 			{ | ||||
| 				// Use only field names and their aliases, everything else is out of our scope. | ||||
| 				$select = array(); | ||||
| 				$field_regexp = ($this->_quoted_identifier) | ||||
| 					? '("[^\"]+")' : '(\[[^\]]+\])'; | ||||
| 				for ($i = 0, $c = count($this->qb_select); $i < $c; $i++) | ||||
| 				{ | ||||
| 					$select[] = preg_match('/(?:\s|\.)'.$field_regexp.'$/i', $this->qb_select[$i], $m) | ||||
| 						? $m[1] : $this->qb_select[$i]; | ||||
| 				} | ||||
| 				$select = implode(', ', $select); | ||||
| 			} | ||||
|  | ||||
| 			return 'SELECT '.$select." FROM (\n\n" | ||||
| 				.preg_replace('/^(SELECT( DISTINCT)?)/i', '\\1 ROW_NUMBER() OVER('.trim($orderby).') AS '.$this->escape_identifiers('CI_rownum').', ', $sql) | ||||
| 				."\n\n) ".$this->escape_identifiers('CI_subquery') | ||||
| 				."\nWHERE ".$this->escape_identifiers('CI_rownum').' BETWEEN '.($this->qb_offset + 1).' AND '.$limit; | ||||
| 		} | ||||
|  | ||||
| 		return preg_replace('/(^\SELECT (DISTINCT)?)/i','\\1 TOP '.$limit.' ', $sql); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Insert batch statement | ||||
| 	 * | ||||
| 	 * Generates a platform-specific insert string from the supplied data. | ||||
| 	 * | ||||
| 	 * @param	string	$table	Table name | ||||
| 	 * @param	array	$keys	INSERT keys | ||||
| 	 * @param	array	$values	INSERT values | ||||
| 	 * @return	string|bool | ||||
| 	 */ | ||||
| 	protected function _insert_batch($table, $keys, $values) | ||||
| 	{ | ||||
| 		// Multiple-value inserts are only supported as of SQL Server 2008 | ||||
| 		if (version_compare($this->version(), '10', '>=')) | ||||
| 		{ | ||||
| 			return parent::_insert_batch($table, $keys, $values); | ||||
| 		} | ||||
|  | ||||
| 		return ($this->db_debug) ? $this->display_error('db_unsupported_feature') : FALSE; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Close DB Connection | ||||
| 	 * | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	protected function _close() | ||||
| 	{ | ||||
| 		mssql_close($this->conn_id); | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										151
									
								
								system/database/drivers/mssql/mssql_forge.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										151
									
								
								system/database/drivers/mssql/mssql_forge.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,151 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/) | ||||
|  * @license	https://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 1.3.0 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * MS SQL Forge Class | ||||
|  * | ||||
|  * @package		CodeIgniter | ||||
|  * @subpackage	Drivers | ||||
|  * @category	Database | ||||
|  * @author		EllisLab Dev Team | ||||
|  * @link		https://codeigniter.com/user_guide/database/ | ||||
|  */ | ||||
| class CI_DB_mssql_forge extends CI_DB_forge { | ||||
|  | ||||
| 	/** | ||||
| 	 * CREATE TABLE IF statement | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_create_table_if	= "IF NOT EXISTS (SELECT * FROM sysobjects WHERE ID = object_id(N'%s') AND OBJECTPROPERTY(id, N'IsUserTable') = 1)\nCREATE TABLE"; | ||||
|  | ||||
| 	/** | ||||
| 	 * DROP TABLE IF statement | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_drop_table_if	= "IF EXISTS (SELECT * FROM sysobjects WHERE ID = object_id(N'%s') AND OBJECTPROPERTY(id, N'IsUserTable') = 1)\nDROP TABLE"; | ||||
|  | ||||
| 	/** | ||||
| 	 * UNSIGNED support | ||||
| 	 * | ||||
| 	 * @var	array | ||||
| 	 */ | ||||
| 	protected $_unsigned		= array( | ||||
| 		'TINYINT'	=> 'SMALLINT', | ||||
| 		'SMALLINT'	=> 'INT', | ||||
| 		'INT'		=> 'BIGINT', | ||||
| 		'REAL'		=> 'FLOAT' | ||||
| 	); | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * ALTER TABLE | ||||
| 	 * | ||||
| 	 * @param	string	$alter_type	ALTER type | ||||
| 	 * @param	string	$table		Table name | ||||
| 	 * @param	mixed	$field		Column definition | ||||
| 	 * @return	string|string[] | ||||
| 	 */ | ||||
| 	protected function _alter_table($alter_type, $table, $field) | ||||
| 	{ | ||||
| 		if (in_array($alter_type, array('ADD', 'DROP'), TRUE)) | ||||
| 		{ | ||||
| 			return parent::_alter_table($alter_type, $table, $field); | ||||
| 		} | ||||
|  | ||||
| 		$sql = 'ALTER TABLE '.$this->db->escape_identifiers($table).' ALTER COLUMN '; | ||||
| 		$sqls = array(); | ||||
| 		for ($i = 0, $c = count($field); $i < $c; $i++) | ||||
| 		{ | ||||
| 			$sqls[] = $sql.$this->_process_column($field[$i]); | ||||
| 		} | ||||
|  | ||||
| 		return $sqls; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Field attribute TYPE | ||||
| 	 * | ||||
| 	 * Performs a data type mapping between different databases. | ||||
| 	 * | ||||
| 	 * @param	array	&$attributes | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	protected function _attr_type(&$attributes) | ||||
| 	{ | ||||
| 		if (isset($attributes['CONSTRAINT']) && strpos($attributes['TYPE'], 'INT') !== FALSE) | ||||
| 		{ | ||||
| 			unset($attributes['CONSTRAINT']); | ||||
| 		} | ||||
|  | ||||
| 		switch (strtoupper($attributes['TYPE'])) | ||||
| 		{ | ||||
| 			case 'MEDIUMINT': | ||||
| 				$attributes['TYPE'] = 'INTEGER'; | ||||
| 				$attributes['UNSIGNED'] = FALSE; | ||||
| 				return; | ||||
| 			case 'INTEGER': | ||||
| 				$attributes['TYPE'] = 'INT'; | ||||
| 				return; | ||||
| 			default: return; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Field attribute AUTO_INCREMENT | ||||
| 	 * | ||||
| 	 * @param	array	&$attributes | ||||
| 	 * @param	array	&$field | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	protected function _attr_auto_increment(&$attributes, &$field) | ||||
| 	{ | ||||
| 		if ( ! empty($attributes['AUTO_INCREMENT']) && $attributes['AUTO_INCREMENT'] === TRUE && stripos($field['type'], 'int') !== FALSE) | ||||
| 		{ | ||||
| 			$field['auto_increment'] = ' IDENTITY(1,1)'; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										198
									
								
								system/database/drivers/mssql/mssql_result.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										198
									
								
								system/database/drivers/mssql/mssql_result.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,198 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/) | ||||
|  * @license	https://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 1.3.0 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * MSSQL Result Class | ||||
|  * | ||||
|  * This class extends the parent result class: CI_DB_result | ||||
|  * | ||||
|  * @package		CodeIgniter | ||||
|  * @subpackage	Drivers | ||||
|  * @category	Database | ||||
|  * @author		EllisLab Dev Team | ||||
|  * @link		https://codeigniter.com/user_guide/database/ | ||||
|  */ | ||||
| class CI_DB_mssql_result extends CI_DB_result { | ||||
|  | ||||
| 	/** | ||||
| 	 * Number of rows in the result set | ||||
| 	 * | ||||
| 	 * @return	int | ||||
| 	 */ | ||||
| 	public function num_rows() | ||||
| 	{ | ||||
| 		return is_int($this->num_rows) | ||||
| 			? $this->num_rows | ||||
| 			: $this->num_rows = mssql_num_rows($this->result_id); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Number of fields in the result set | ||||
| 	 * | ||||
| 	 * @return	int | ||||
| 	 */ | ||||
| 	public function num_fields() | ||||
| 	{ | ||||
| 		return mssql_num_fields($this->result_id); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Fetch Field Names | ||||
| 	 * | ||||
| 	 * Generates an array of column names | ||||
| 	 * | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	public function list_fields() | ||||
| 	{ | ||||
| 		$field_names = array(); | ||||
| 		mssql_field_seek($this->result_id, 0); | ||||
| 		while ($field = mssql_fetch_field($this->result_id)) | ||||
| 		{ | ||||
| 			$field_names[] = $field->name; | ||||
| 		} | ||||
|  | ||||
| 		return $field_names; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Field data | ||||
| 	 * | ||||
| 	 * Generates an array of objects containing field meta-data | ||||
| 	 * | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	public function field_data() | ||||
| 	{ | ||||
| 		$retval = array(); | ||||
| 		for ($i = 0, $c = $this->num_fields(); $i < $c; $i++) | ||||
| 		{ | ||||
| 			$field = mssql_fetch_field($this->result_id, $i); | ||||
|  | ||||
| 			$retval[$i]		= new stdClass(); | ||||
| 			$retval[$i]->name	= $field->name; | ||||
| 			$retval[$i]->type	= $field->type; | ||||
| 			$retval[$i]->max_length	= $field->max_length; | ||||
| 		} | ||||
|  | ||||
| 		return $retval; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Free the result | ||||
| 	 * | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	public function free_result() | ||||
| 	{ | ||||
| 		if (is_resource($this->result_id)) | ||||
| 		{ | ||||
| 			mssql_free_result($this->result_id); | ||||
| 			$this->result_id = FALSE; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Data Seek | ||||
| 	 * | ||||
| 	 * Moves the internal pointer to the desired offset. We call | ||||
| 	 * this internally before fetching results to make sure the | ||||
| 	 * result set starts at zero. | ||||
| 	 * | ||||
| 	 * @param	int	$n | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	public function data_seek($n = 0) | ||||
| 	{ | ||||
| 		return mssql_data_seek($this->result_id, $n); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Result - associative array | ||||
| 	 * | ||||
| 	 * Returns the result set as an array | ||||
| 	 * | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	protected function _fetch_assoc() | ||||
| 	{ | ||||
| 		return mssql_fetch_assoc($this->result_id); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Result - object | ||||
| 	 * | ||||
| 	 * Returns the result set as an object | ||||
| 	 * | ||||
| 	 * @param	string	$class_name | ||||
| 	 * @return	object | ||||
| 	 */ | ||||
| 	protected function _fetch_object($class_name = 'stdClass') | ||||
| 	{ | ||||
| 		$row = mssql_fetch_object($this->result_id); | ||||
|  | ||||
| 		if ($class_name === 'stdClass' OR ! $row) | ||||
| 		{ | ||||
| 			return $row; | ||||
| 		} | ||||
|  | ||||
| 		$class_name = new $class_name(); | ||||
| 		foreach ($row as $key => $value) | ||||
| 		{ | ||||
| 			$class_name->$key = $value; | ||||
| 		} | ||||
|  | ||||
| 		return $class_name; | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										77
									
								
								system/database/drivers/mssql/mssql_utility.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										77
									
								
								system/database/drivers/mssql/mssql_utility.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,77 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/) | ||||
|  * @license	https://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 1.3.0 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * MS SQL Utility Class | ||||
|  * | ||||
|  * @package		CodeIgniter | ||||
|  * @subpackage	Drivers | ||||
|  * @category	Database | ||||
|  * @author		EllisLab Dev Team | ||||
|  * @link		https://codeigniter.com/user_guide/database/ | ||||
|  */ | ||||
| class CI_DB_mssql_utility extends CI_DB_utility { | ||||
|  | ||||
| 	/** | ||||
| 	 * List databases statement | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_list_databases	= 'EXEC sp_helpdb'; // Can also be: EXEC sp_databases | ||||
|  | ||||
| 	/** | ||||
| 	 * OPTIMIZE TABLE statement | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_optimize_table	= 'ALTER INDEX all ON %s REORGANIZE'; | ||||
|  | ||||
| 	/** | ||||
| 	 * Export | ||||
| 	 * | ||||
| 	 * @param	array	$params	Preferences | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	protected function _backup($params = array()) | ||||
| 	{ | ||||
| 		// Currently unsupported | ||||
| 		return $this->db->display_error('db_unsupported_feature'); | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										11
									
								
								system/database/drivers/mysql/index.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								system/database/drivers/mysql/index.html
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,11 @@ | ||||
| <!DOCTYPE html> | ||||
| <html> | ||||
| <head> | ||||
| 	<title>403 Forbidden</title> | ||||
| </head> | ||||
| <body> | ||||
|  | ||||
| <p>Directory access is forbidden.</p> | ||||
|  | ||||
| </body> | ||||
| </html> | ||||
							
								
								
									
										494
									
								
								system/database/drivers/mysql/mysql_driver.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										494
									
								
								system/database/drivers/mysql/mysql_driver.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,494 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/) | ||||
|  * @license	https://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 1.0.0 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * MySQL Database Adapter Class | ||||
|  * | ||||
|  * Note: _DB is an extender class that the app controller | ||||
|  * creates dynamically based on whether the query builder | ||||
|  * class is being used or not. | ||||
|  * | ||||
|  * @package		CodeIgniter | ||||
|  * @subpackage	Drivers | ||||
|  * @category	Database | ||||
|  * @author		EllisLab Dev Team | ||||
|  * @link		https://codeigniter.com/user_guide/database/ | ||||
|  */ | ||||
| class CI_DB_mysql_driver extends CI_DB { | ||||
|  | ||||
| 	/** | ||||
| 	 * Database driver | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	public $dbdriver = 'mysql'; | ||||
|  | ||||
| 	/** | ||||
| 	 * Compression flag | ||||
| 	 * | ||||
| 	 * @var	bool | ||||
| 	 */ | ||||
| 	public $compress = FALSE; | ||||
|  | ||||
| 	/** | ||||
| 	 * DELETE hack flag | ||||
| 	 * | ||||
| 	 * Whether to use the MySQL "delete hack" which allows the number | ||||
| 	 * of affected rows to be shown. Uses a preg_replace when enabled, | ||||
| 	 * adding a bit more processing to all queries. | ||||
| 	 * | ||||
| 	 * @var	bool | ||||
| 	 */ | ||||
| 	public $delete_hack = TRUE; | ||||
|  | ||||
| 	/** | ||||
| 	 * Strict ON flag | ||||
| 	 * | ||||
| 	 * Whether we're running in strict SQL mode. | ||||
| 	 * | ||||
| 	 * @var	bool | ||||
| 	 */ | ||||
| 	public $stricton; | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Identifier escape character | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_escape_char = '`'; | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Class constructor | ||||
| 	 * | ||||
| 	 * @param	array	$params | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	public function __construct($params) | ||||
| 	{ | ||||
| 		parent::__construct($params); | ||||
|  | ||||
| 		if ( ! empty($this->port)) | ||||
| 		{ | ||||
| 			$this->hostname .= ':'.$this->port; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Non-persistent database connection | ||||
| 	 * | ||||
| 	 * @param	bool	$persistent | ||||
| 	 * @return	resource | ||||
| 	 */ | ||||
| 	public function db_connect($persistent = FALSE) | ||||
| 	{ | ||||
| 		$client_flags = ($this->compress === FALSE) ? 0 : MYSQL_CLIENT_COMPRESS; | ||||
|  | ||||
| 		if ($this->encrypt === TRUE) | ||||
| 		{ | ||||
| 			$client_flags = $client_flags | MYSQL_CLIENT_SSL; | ||||
| 		} | ||||
|  | ||||
| 		// Error suppression is necessary mostly due to PHP 5.5+ issuing E_DEPRECATED messages | ||||
| 		$this->conn_id = ($persistent === TRUE) | ||||
| 			? mysql_pconnect($this->hostname, $this->username, $this->password, $client_flags) | ||||
| 			: mysql_connect($this->hostname, $this->username, $this->password, TRUE, $client_flags); | ||||
|  | ||||
| 		// ---------------------------------------------------------------- | ||||
|  | ||||
| 		// Select the DB... assuming a database name is specified in the config file | ||||
| 		if ($this->database !== '' && ! $this->db_select()) | ||||
| 		{ | ||||
| 			log_message('error', 'Unable to select database: '.$this->database); | ||||
|  | ||||
| 			return ($this->db_debug === TRUE) | ||||
| 				? $this->display_error('db_unable_to_select', $this->database) | ||||
| 				: FALSE; | ||||
| 		} | ||||
|  | ||||
| 		if (isset($this->stricton) && is_resource($this->conn_id)) | ||||
| 		{ | ||||
| 			if ($this->stricton) | ||||
| 			{ | ||||
| 				$this->simple_query('SET SESSION sql_mode = CONCAT(@@sql_mode, ",", "STRICT_ALL_TABLES")'); | ||||
| 			} | ||||
| 			else | ||||
| 			{ | ||||
| 				$this->simple_query( | ||||
| 					'SET SESSION sql_mode = | ||||
| 					REPLACE(REPLACE(REPLACE(REPLACE(REPLACE(REPLACE( | ||||
| 					@@sql_mode, | ||||
| 					"STRICT_ALL_TABLES,", ""), | ||||
| 					",STRICT_ALL_TABLES", ""), | ||||
| 					"STRICT_ALL_TABLES", ""), | ||||
| 					"STRICT_TRANS_TABLES,", ""), | ||||
| 					",STRICT_TRANS_TABLES", ""), | ||||
| 					"STRICT_TRANS_TABLES", "")' | ||||
| 				); | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		return $this->conn_id; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Reconnect | ||||
| 	 * | ||||
| 	 * Keep / reestablish the db connection if no queries have been | ||||
| 	 * sent for a length of time exceeding the server's idle timeout | ||||
| 	 * | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	public function reconnect() | ||||
| 	{ | ||||
| 		if (mysql_ping($this->conn_id) === FALSE) | ||||
| 		{ | ||||
| 			$this->conn_id = FALSE; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Select the database | ||||
| 	 * | ||||
| 	 * @param	string	$database | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	public function db_select($database = '') | ||||
| 	{ | ||||
| 		if ($database === '') | ||||
| 		{ | ||||
| 			$database = $this->database; | ||||
| 		} | ||||
|  | ||||
| 		if (mysql_select_db($database, $this->conn_id)) | ||||
| 		{ | ||||
| 			$this->database = $database; | ||||
| 			$this->data_cache = array(); | ||||
| 			return TRUE; | ||||
| 		} | ||||
|  | ||||
| 		return FALSE; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Set client character set | ||||
| 	 * | ||||
| 	 * @param	string	$charset | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	protected function _db_set_charset($charset) | ||||
| 	{ | ||||
| 		return mysql_set_charset($charset, $this->conn_id); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Database version number | ||||
| 	 * | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	public function version() | ||||
| 	{ | ||||
| 		if (isset($this->data_cache['version'])) | ||||
| 		{ | ||||
| 			return $this->data_cache['version']; | ||||
| 		} | ||||
|  | ||||
| 		if ( ! $this->conn_id OR ($version = mysql_get_server_info($this->conn_id)) === FALSE) | ||||
| 		{ | ||||
| 			return FALSE; | ||||
| 		} | ||||
|  | ||||
| 		return $this->data_cache['version'] = $version; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Execute the query | ||||
| 	 * | ||||
| 	 * @param	string	$sql	an SQL query | ||||
| 	 * @return	mixed | ||||
| 	 */ | ||||
| 	protected function _execute($sql) | ||||
| 	{ | ||||
| 		return mysql_query($this->_prep_query($sql), $this->conn_id); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Prep the query | ||||
| 	 * | ||||
| 	 * If needed, each database adapter can prep the query string | ||||
| 	 * | ||||
| 	 * @param	string	$sql	an SQL query | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _prep_query($sql) | ||||
| 	{ | ||||
| 		// mysql_affected_rows() returns 0 for "DELETE FROM TABLE" queries. This hack | ||||
| 		// modifies the query so that it a proper number of affected rows is returned. | ||||
| 		if ($this->delete_hack === TRUE && preg_match('/^\s*DELETE\s+FROM\s+(\S+)\s*$/i', $sql)) | ||||
| 		{ | ||||
| 			return trim($sql).' WHERE 1=1'; | ||||
| 		} | ||||
|  | ||||
| 		return $sql; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Begin Transaction | ||||
| 	 * | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	protected function _trans_begin() | ||||
| 	{ | ||||
| 		$this->simple_query('SET AUTOCOMMIT=0'); | ||||
| 		return $this->simple_query('START TRANSACTION'); // can also be BEGIN or BEGIN WORK | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Commit Transaction | ||||
| 	 * | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	protected function _trans_commit() | ||||
| 	{ | ||||
| 		if ($this->simple_query('COMMIT')) | ||||
| 		{ | ||||
| 			$this->simple_query('SET AUTOCOMMIT=1'); | ||||
| 			return TRUE; | ||||
| 		} | ||||
|  | ||||
| 		return FALSE; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Rollback Transaction | ||||
| 	 * | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	protected function _trans_rollback() | ||||
| 	{ | ||||
| 		if ($this->simple_query('ROLLBACK')) | ||||
| 		{ | ||||
| 			$this->simple_query('SET AUTOCOMMIT=1'); | ||||
| 			return TRUE; | ||||
| 		} | ||||
|  | ||||
| 		return FALSE; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Platform-dependent string escape | ||||
| 	 * | ||||
| 	 * @param	string | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _escape_str($str) | ||||
| 	{ | ||||
| 		return mysql_real_escape_string($str, $this->conn_id); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Affected Rows | ||||
| 	 * | ||||
| 	 * @return	int | ||||
| 	 */ | ||||
| 	public function affected_rows() | ||||
| 	{ | ||||
| 		return mysql_affected_rows($this->conn_id); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Insert ID | ||||
| 	 * | ||||
| 	 * @return	int | ||||
| 	 */ | ||||
| 	public function insert_id() | ||||
| 	{ | ||||
| 		return mysql_insert_id($this->conn_id); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * List table query | ||||
| 	 * | ||||
| 	 * Generates a platform-specific query string so that the table names can be fetched | ||||
| 	 * | ||||
| 	 * @param	bool	$prefix_limit | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _list_tables($prefix_limit = FALSE) | ||||
| 	{ | ||||
| 		$sql = 'SHOW TABLES FROM '.$this->_escape_char.$this->database.$this->_escape_char; | ||||
|  | ||||
| 		if ($prefix_limit !== FALSE && $this->dbprefix !== '') | ||||
| 		{ | ||||
| 			return $sql." LIKE '".$this->escape_like_str($this->dbprefix)."%'"; | ||||
| 		} | ||||
|  | ||||
| 		return $sql; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Show column query | ||||
| 	 * | ||||
| 	 * Generates a platform-specific query string so that the column names can be fetched | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _list_columns($table = '') | ||||
| 	{ | ||||
| 		return 'SHOW COLUMNS FROM '.$this->protect_identifiers($table, TRUE, NULL, FALSE); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Returns an object with field data | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	public function field_data($table) | ||||
| 	{ | ||||
| 		if (($query = $this->query('SHOW COLUMNS FROM '.$this->protect_identifiers($table, TRUE, NULL, FALSE))) === FALSE) | ||||
| 		{ | ||||
| 			return FALSE; | ||||
| 		} | ||||
| 		$query = $query->result_object(); | ||||
|  | ||||
| 		$retval = array(); | ||||
| 		for ($i = 0, $c = count($query); $i < $c; $i++) | ||||
| 		{ | ||||
| 			$retval[$i]			= new stdClass(); | ||||
| 			$retval[$i]->name		= $query[$i]->Field; | ||||
|  | ||||
| 			sscanf($query[$i]->Type, '%[a-z](%d)', | ||||
| 				$retval[$i]->type, | ||||
| 				$retval[$i]->max_length | ||||
| 			); | ||||
|  | ||||
| 			$retval[$i]->default		= $query[$i]->Default; | ||||
| 			$retval[$i]->primary_key	= (int) ($query[$i]->Key === 'PRI'); | ||||
| 		} | ||||
|  | ||||
| 		return $retval; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Error | ||||
| 	 * | ||||
| 	 * Returns an array containing code and message of the last | ||||
| 	 * database error that has occurred. | ||||
| 	 * | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	public function error() | ||||
| 	{ | ||||
| 		return array('code' => mysql_errno($this->conn_id), 'message' => mysql_error($this->conn_id)); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * FROM tables | ||||
| 	 * | ||||
| 	 * Groups tables in FROM clauses if needed, so there is no confusion | ||||
| 	 * about operator precedence. | ||||
| 	 * | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _from_tables() | ||||
| 	{ | ||||
| 		if ( ! empty($this->qb_join) && count($this->qb_from) > 1) | ||||
| 		{ | ||||
| 			return '('.implode(', ', $this->qb_from).')'; | ||||
| 		} | ||||
|  | ||||
| 		return implode(', ', $this->qb_from); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Close DB Connection | ||||
| 	 * | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	protected function _close() | ||||
| 	{ | ||||
| 		// Error suppression to avoid annoying E_WARNINGs in cases | ||||
| 		// where the connection has already been closed for some reason. | ||||
| 		@mysql_close($this->conn_id); | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										243
									
								
								system/database/drivers/mysql/mysql_forge.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										243
									
								
								system/database/drivers/mysql/mysql_forge.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,243 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/) | ||||
|  * @license	https://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 1.0.0 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * MySQL Forge Class | ||||
|  * | ||||
|  * @category	Database | ||||
|  * @author		EllisLab Dev Team | ||||
|  * @link		https://codeigniter.com/user_guide/database/ | ||||
|  */ | ||||
| class CI_DB_mysql_forge extends CI_DB_forge { | ||||
|  | ||||
| 	/** | ||||
| 	 * CREATE DATABASE statement | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_create_database	= 'CREATE DATABASE %s CHARACTER SET %s COLLATE %s'; | ||||
|  | ||||
| 	/** | ||||
| 	 * CREATE TABLE keys flag | ||||
| 	 * | ||||
| 	 * Whether table keys are created from within the | ||||
| 	 * CREATE TABLE statement. | ||||
| 	 * | ||||
| 	 * @var	bool | ||||
| 	 */ | ||||
| 	protected $_create_table_keys	= TRUE; | ||||
|  | ||||
| 	/** | ||||
| 	 * UNSIGNED support | ||||
| 	 * | ||||
| 	 * @var	array | ||||
| 	 */ | ||||
| 	protected $_unsigned		= array( | ||||
| 		'TINYINT', | ||||
| 		'SMALLINT', | ||||
| 		'MEDIUMINT', | ||||
| 		'INT', | ||||
| 		'INTEGER', | ||||
| 		'BIGINT', | ||||
| 		'REAL', | ||||
| 		'DOUBLE', | ||||
| 		'DOUBLE PRECISION', | ||||
| 		'FLOAT', | ||||
| 		'DECIMAL', | ||||
| 		'NUMERIC' | ||||
| 	); | ||||
|  | ||||
| 	/** | ||||
| 	 * NULL value representation in CREATE/ALTER TABLE statements | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_null = 'NULL'; | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * CREATE TABLE attributes | ||||
| 	 * | ||||
| 	 * @param	array	$attributes	Associative array of table attributes | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _create_table_attr($attributes) | ||||
| 	{ | ||||
| 		$sql = ''; | ||||
|  | ||||
| 		foreach (array_keys($attributes) as $key) | ||||
| 		{ | ||||
| 			if (is_string($key)) | ||||
| 			{ | ||||
| 				$sql .= ' '.strtoupper($key).' = '.$attributes[$key]; | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		if ( ! empty($this->db->char_set) && ! strpos($sql, 'CHARACTER SET') && ! strpos($sql, 'CHARSET')) | ||||
| 		{ | ||||
| 			$sql .= ' DEFAULT CHARACTER SET = '.$this->db->char_set; | ||||
| 		} | ||||
|  | ||||
| 		if ( ! empty($this->db->dbcollat) && ! strpos($sql, 'COLLATE')) | ||||
| 		{ | ||||
| 			$sql .= ' COLLATE = '.$this->db->dbcollat; | ||||
| 		} | ||||
|  | ||||
| 		return $sql; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * ALTER TABLE | ||||
| 	 * | ||||
| 	 * @param	string	$alter_type	ALTER type | ||||
| 	 * @param	string	$table		Table name | ||||
| 	 * @param	mixed	$field		Column definition | ||||
| 	 * @return	string|string[] | ||||
| 	 */ | ||||
| 	protected function _alter_table($alter_type, $table, $field) | ||||
| 	{ | ||||
| 		if ($alter_type === 'DROP') | ||||
| 		{ | ||||
| 			return parent::_alter_table($alter_type, $table, $field); | ||||
| 		} | ||||
|  | ||||
| 		$sql = 'ALTER TABLE '.$this->db->escape_identifiers($table); | ||||
| 		for ($i = 0, $c = count($field); $i < $c; $i++) | ||||
| 		{ | ||||
| 			if ($field[$i]['_literal'] !== FALSE) | ||||
| 			{ | ||||
| 				$field[$i] = ($alter_type === 'ADD') | ||||
| 						? "\n\tADD ".$field[$i]['_literal'] | ||||
| 						: "\n\tMODIFY ".$field[$i]['_literal']; | ||||
| 			} | ||||
| 			else | ||||
| 			{ | ||||
| 				if ($alter_type === 'ADD') | ||||
| 				{ | ||||
| 					$field[$i]['_literal'] = "\n\tADD "; | ||||
| 				} | ||||
| 				else | ||||
| 				{ | ||||
| 					$field[$i]['_literal'] = empty($field[$i]['new_name']) ? "\n\tMODIFY " : "\n\tCHANGE "; | ||||
| 				} | ||||
|  | ||||
| 				$field[$i] = $field[$i]['_literal'].$this->_process_column($field[$i]); | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		return array($sql.implode(',', $field)); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Process column | ||||
| 	 * | ||||
| 	 * @param	array	$field | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _process_column($field) | ||||
| 	{ | ||||
| 		$extra_clause = isset($field['after']) | ||||
| 			? ' AFTER '.$this->db->escape_identifiers($field['after']) : ''; | ||||
|  | ||||
| 		if (empty($extra_clause) && isset($field['first']) && $field['first'] === TRUE) | ||||
| 		{ | ||||
| 			$extra_clause = ' FIRST'; | ||||
| 		} | ||||
|  | ||||
|  | ||||
| 		return $this->db->escape_identifiers($field['name']) | ||||
| 			.(empty($field['new_name']) ? '' : ' '.$this->db->escape_identifiers($field['new_name'])) | ||||
| 			.' '.$field['type'].$field['length'] | ||||
| 			.$field['unsigned'] | ||||
| 			.$field['null'] | ||||
| 			.$field['default'] | ||||
| 			.$field['auto_increment'] | ||||
| 			.$field['unique'] | ||||
| 			.(empty($field['comment']) ? '' : ' COMMENT '.$field['comment']) | ||||
| 			.$extra_clause; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Process indexes | ||||
| 	 * | ||||
| 	 * @param	string	$table	(ignored) | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _process_indexes($table) | ||||
| 	{ | ||||
| 		$sql = ''; | ||||
|  | ||||
| 		for ($i = 0, $c = count($this->keys); $i < $c; $i++) | ||||
| 		{ | ||||
| 			if (is_array($this->keys[$i])) | ||||
| 			{ | ||||
| 				for ($i2 = 0, $c2 = count($this->keys[$i]); $i2 < $c2; $i2++) | ||||
| 				{ | ||||
| 					if ( ! isset($this->fields[$this->keys[$i][$i2]])) | ||||
| 					{ | ||||
| 						unset($this->keys[$i][$i2]); | ||||
| 						continue; | ||||
| 					} | ||||
| 				} | ||||
| 			} | ||||
| 			elseif ( ! isset($this->fields[$this->keys[$i]])) | ||||
| 			{ | ||||
| 				unset($this->keys[$i]); | ||||
| 				continue; | ||||
| 			} | ||||
|  | ||||
| 			is_array($this->keys[$i]) OR $this->keys[$i] = array($this->keys[$i]); | ||||
|  | ||||
| 			$sql .= ",\n\tKEY ".$this->db->escape_identifiers(implode('_', $this->keys[$i])) | ||||
| 				.' ('.implode(', ', $this->db->escape_identifiers($this->keys[$i])).')'; | ||||
| 		} | ||||
|  | ||||
| 		$this->keys = array(); | ||||
|  | ||||
| 		return $sql; | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										199
									
								
								system/database/drivers/mysql/mysql_result.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										199
									
								
								system/database/drivers/mysql/mysql_result.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,199 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/) | ||||
|  * @license	https://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 1.0.0 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * MySQL Result Class | ||||
|  * | ||||
|  * This class extends the parent result class: CI_DB_result | ||||
|  * | ||||
|  * @category	Database | ||||
|  * @author		EllisLab Dev Team | ||||
|  * @link		https://codeigniter.com/user_guide/database/ | ||||
|  */ | ||||
| class CI_DB_mysql_result extends CI_DB_result { | ||||
|  | ||||
| 	/** | ||||
| 	 * Class constructor | ||||
| 	 * | ||||
| 	 * @param	object	&$driver_object | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	public function __construct(&$driver_object) | ||||
| 	{ | ||||
| 		parent::__construct($driver_object); | ||||
|  | ||||
| 		// Required, due to mysql_data_seek() causing nightmares | ||||
| 		// with empty result sets | ||||
| 		$this->num_rows = mysql_num_rows($this->result_id); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Number of rows in the result set | ||||
| 	 * | ||||
| 	 * @return	int | ||||
| 	 */ | ||||
| 	public function num_rows() | ||||
| 	{ | ||||
| 		return $this->num_rows; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Number of fields in the result set | ||||
| 	 * | ||||
| 	 * @return	int | ||||
| 	 */ | ||||
| 	public function num_fields() | ||||
| 	{ | ||||
| 		return mysql_num_fields($this->result_id); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Fetch Field Names | ||||
| 	 * | ||||
| 	 * Generates an array of column names | ||||
| 	 * | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	public function list_fields() | ||||
| 	{ | ||||
| 		$field_names = array(); | ||||
| 		mysql_field_seek($this->result_id, 0); | ||||
| 		while ($field = mysql_fetch_field($this->result_id)) | ||||
| 		{ | ||||
| 			$field_names[] = $field->name; | ||||
| 		} | ||||
|  | ||||
| 		return $field_names; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Field data | ||||
| 	 * | ||||
| 	 * Generates an array of objects containing field meta-data | ||||
| 	 * | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	public function field_data() | ||||
| 	{ | ||||
| 		$retval = array(); | ||||
| 		for ($i = 0, $c = $this->num_fields(); $i < $c; $i++) | ||||
| 		{ | ||||
| 			$retval[$i]			= new stdClass(); | ||||
| 			$retval[$i]->name		= mysql_field_name($this->result_id, $i); | ||||
| 			$retval[$i]->type		= mysql_field_type($this->result_id, $i); | ||||
| 			$retval[$i]->max_length		= mysql_field_len($this->result_id, $i); | ||||
| 			$retval[$i]->primary_key	= (int) (strpos(mysql_field_flags($this->result_id, $i), 'primary_key') !== FALSE); | ||||
| 		} | ||||
|  | ||||
| 		return $retval; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Free the result | ||||
| 	 * | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	public function free_result() | ||||
| 	{ | ||||
| 		if (is_resource($this->result_id)) | ||||
| 		{ | ||||
| 			mysql_free_result($this->result_id); | ||||
| 			$this->result_id = FALSE; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Data Seek | ||||
| 	 * | ||||
| 	 * Moves the internal pointer to the desired offset. We call | ||||
| 	 * this internally before fetching results to make sure the | ||||
| 	 * result set starts at zero. | ||||
| 	 * | ||||
| 	 * @param	int	$n | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	public function data_seek($n = 0) | ||||
| 	{ | ||||
| 		return $this->num_rows | ||||
| 			? mysql_data_seek($this->result_id, $n) | ||||
| 			: FALSE; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Result - associative array | ||||
| 	 * | ||||
| 	 * Returns the result set as an array | ||||
| 	 * | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	protected function _fetch_assoc() | ||||
| 	{ | ||||
| 		return mysql_fetch_assoc($this->result_id); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Result - object | ||||
| 	 * | ||||
| 	 * Returns the result set as an object | ||||
| 	 * | ||||
| 	 * @param	string	$class_name | ||||
| 	 * @return	object | ||||
| 	 */ | ||||
| 	protected function _fetch_object($class_name = 'stdClass') | ||||
| 	{ | ||||
| 		return mysql_fetch_object($this->result_id, $class_name); | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										211
									
								
								system/database/drivers/mysql/mysql_utility.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										211
									
								
								system/database/drivers/mysql/mysql_utility.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,211 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/) | ||||
|  * @license	https://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 1.0.0 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * MySQL Utility Class | ||||
|  * | ||||
|  * @category	Database | ||||
|  * @author		EllisLab Dev Team | ||||
|  * @link		https://codeigniter.com/user_guide/database/ | ||||
|  */ | ||||
| class CI_DB_mysql_utility extends CI_DB_utility { | ||||
|  | ||||
| 	/** | ||||
| 	 * List databases statement | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_list_databases	= 'SHOW DATABASES'; | ||||
|  | ||||
| 	/** | ||||
| 	 * OPTIMIZE TABLE statement | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_optimize_table	= 'OPTIMIZE TABLE %s'; | ||||
|  | ||||
| 	/** | ||||
| 	 * REPAIR TABLE statement | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_repair_table	= 'REPAIR TABLE %s'; | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Export | ||||
| 	 * | ||||
| 	 * @param	array	$params	Preferences | ||||
| 	 * @return	mixed | ||||
| 	 */ | ||||
| 	protected function _backup($params = array()) | ||||
| 	{ | ||||
| 		if (count($params) === 0) | ||||
| 		{ | ||||
| 			return FALSE; | ||||
| 		} | ||||
|  | ||||
| 		// Extract the prefs for simplicity | ||||
| 		extract($params); | ||||
|  | ||||
| 		// Build the output | ||||
| 		$output = ''; | ||||
|  | ||||
| 		// Do we need to include a statement to disable foreign key checks? | ||||
| 		if ($foreign_key_checks === FALSE) | ||||
| 		{ | ||||
| 			$output .= 'SET foreign_key_checks = 0;'.$newline; | ||||
| 		} | ||||
|  | ||||
| 		foreach ( (array) $tables as $table) | ||||
| 		{ | ||||
| 			// Is the table in the "ignore" list? | ||||
| 			if (in_array($table, (array) $ignore, TRUE)) | ||||
| 			{ | ||||
| 				continue; | ||||
| 			} | ||||
|  | ||||
| 			// Get the table schema | ||||
| 			$query = $this->db->query('SHOW CREATE TABLE '.$this->db->escape_identifiers($this->db->database.'.'.$table)); | ||||
|  | ||||
| 			// No result means the table name was invalid | ||||
| 			if ($query === FALSE) | ||||
| 			{ | ||||
| 				continue; | ||||
| 			} | ||||
|  | ||||
| 			// Write out the table schema | ||||
| 			$output .= '#'.$newline.'# TABLE STRUCTURE FOR: '.$table.$newline.'#'.$newline.$newline; | ||||
|  | ||||
| 			if ($add_drop === TRUE) | ||||
| 			{ | ||||
| 				$output .= 'DROP TABLE IF EXISTS '.$this->db->protect_identifiers($table).';'.$newline.$newline; | ||||
| 			} | ||||
|  | ||||
| 			$i = 0; | ||||
| 			$result = $query->result_array(); | ||||
| 			foreach ($result[0] as $val) | ||||
| 			{ | ||||
| 				if ($i++ % 2) | ||||
| 				{ | ||||
| 					$output .= $val.';'.$newline.$newline; | ||||
| 				} | ||||
| 			} | ||||
|  | ||||
| 			// If inserts are not needed we're done... | ||||
| 			if ($add_insert === FALSE) | ||||
| 			{ | ||||
| 				continue; | ||||
| 			} | ||||
|  | ||||
| 			// Grab all the data from the current table | ||||
| 			$query = $this->db->query('SELECT * FROM '.$this->db->protect_identifiers($table)); | ||||
|  | ||||
| 			if ($query->num_rows() === 0) | ||||
| 			{ | ||||
| 				continue; | ||||
| 			} | ||||
|  | ||||
| 			// Fetch the field names and determine if the field is an | ||||
| 			// integer type. We use this info to decide whether to | ||||
| 			// surround the data with quotes or not | ||||
|  | ||||
| 			$i = 0; | ||||
| 			$field_str = ''; | ||||
| 			$is_int = array(); | ||||
| 			while ($field = mysql_fetch_field($query->result_id)) | ||||
| 			{ | ||||
| 				// Most versions of MySQL store timestamp as a string | ||||
| 				$is_int[$i] = in_array(strtolower(mysql_field_type($query->result_id, $i)), | ||||
| 							array('tinyint', 'smallint', 'mediumint', 'int', 'bigint'), //, 'timestamp'), | ||||
| 							TRUE); | ||||
|  | ||||
| 				// Create a string of field names | ||||
| 				$field_str .= $this->db->escape_identifiers($field->name).', '; | ||||
| 				$i++; | ||||
| 			} | ||||
|  | ||||
| 			// Trim off the end comma | ||||
| 			$field_str = preg_replace('/, $/' , '', $field_str); | ||||
|  | ||||
| 			// Build the insert string | ||||
| 			foreach ($query->result_array() as $row) | ||||
| 			{ | ||||
| 				$val_str = ''; | ||||
|  | ||||
| 				$i = 0; | ||||
| 				foreach ($row as $v) | ||||
| 				{ | ||||
| 					// Is the value NULL? | ||||
| 					if ($v === NULL) | ||||
| 					{ | ||||
| 						$val_str .= 'NULL'; | ||||
| 					} | ||||
| 					else | ||||
| 					{ | ||||
| 						// Escape the data if it's not an integer | ||||
| 						$val_str .= ($is_int[$i] === FALSE) ? $this->db->escape($v) : $v; | ||||
| 					} | ||||
|  | ||||
| 					// Append a comma | ||||
| 					$val_str .= ', '; | ||||
| 					$i++; | ||||
| 				} | ||||
|  | ||||
| 				// Remove the comma at the end of the string | ||||
| 				$val_str = preg_replace('/, $/' , '', $val_str); | ||||
|  | ||||
| 				// Build the INSERT string | ||||
| 				$output .= 'INSERT INTO '.$this->db->protect_identifiers($table).' ('.$field_str.') VALUES ('.$val_str.');'.$newline; | ||||
| 			} | ||||
|  | ||||
| 			$output .= $newline.$newline; | ||||
| 		} | ||||
|  | ||||
| 		// Do we need to include a statement to re-enable foreign key checks? | ||||
| 		if ($foreign_key_checks === FALSE) | ||||
| 		{ | ||||
| 			$output .= 'SET foreign_key_checks = 1;'.$newline; | ||||
| 		} | ||||
|  | ||||
| 		return $output; | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										11
									
								
								system/database/drivers/mysqli/index.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								system/database/drivers/mysqli/index.html
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,11 @@ | ||||
| <!DOCTYPE html> | ||||
| <html> | ||||
| <head> | ||||
| 	<title>403 Forbidden</title> | ||||
| </head> | ||||
| <body> | ||||
|  | ||||
| <p>Directory access is forbidden.</p> | ||||
|  | ||||
| </body> | ||||
| </html> | ||||
							
								
								
									
										546
									
								
								system/database/drivers/mysqli/mysqli_driver.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										546
									
								
								system/database/drivers/mysqli/mysqli_driver.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,546 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/) | ||||
|  * @license	https://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 1.3.0 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * MySQLi Database Adapter Class | ||||
|  * | ||||
|  * Note: _DB is an extender class that the app controller | ||||
|  * creates dynamically based on whether the query builder | ||||
|  * class is being used or not. | ||||
|  * | ||||
|  * @package		CodeIgniter | ||||
|  * @subpackage	Drivers | ||||
|  * @category	Database | ||||
|  * @author		EllisLab Dev Team | ||||
|  * @link		https://codeigniter.com/user_guide/database/ | ||||
|  */ | ||||
| class CI_DB_mysqli_driver extends CI_DB { | ||||
|  | ||||
| 	/** | ||||
| 	 * Database driver | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	public $dbdriver = 'mysqli'; | ||||
|  | ||||
| 	/** | ||||
| 	 * Compression flag | ||||
| 	 * | ||||
| 	 * @var	bool | ||||
| 	 */ | ||||
| 	public $compress = FALSE; | ||||
|  | ||||
| 	/** | ||||
| 	 * DELETE hack flag | ||||
| 	 * | ||||
| 	 * Whether to use the MySQL "delete hack" which allows the number | ||||
| 	 * of affected rows to be shown. Uses a preg_replace when enabled, | ||||
| 	 * adding a bit more processing to all queries. | ||||
| 	 * | ||||
| 	 * @var	bool | ||||
| 	 */ | ||||
| 	public $delete_hack = TRUE; | ||||
|  | ||||
| 	/** | ||||
| 	 * Strict ON flag | ||||
| 	 * | ||||
| 	 * Whether we're running in strict SQL mode. | ||||
| 	 * | ||||
| 	 * @var	bool | ||||
| 	 */ | ||||
| 	public $stricton; | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Identifier escape character | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_escape_char = '`'; | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * MySQLi object | ||||
| 	 * | ||||
| 	 * Has to be preserved without being assigned to $conn_id. | ||||
| 	 * | ||||
| 	 * @var	MySQLi | ||||
| 	 */ | ||||
| 	protected $_mysqli; | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Database connection | ||||
| 	 * | ||||
| 	 * @param	bool	$persistent | ||||
| 	 * @return	object | ||||
| 	 */ | ||||
| 	public function db_connect($persistent = FALSE) | ||||
| 	{ | ||||
| 		// Do we have a socket path? | ||||
| 		if ($this->hostname[0] === '/') | ||||
| 		{ | ||||
| 			$hostname = NULL; | ||||
| 			$port = NULL; | ||||
| 			$socket = $this->hostname; | ||||
| 		} | ||||
| 		else | ||||
| 		{ | ||||
| 			$hostname = ($persistent === TRUE) | ||||
| 				? 'p:'.$this->hostname : $this->hostname; | ||||
| 			$port = empty($this->port) ? NULL : $this->port; | ||||
| 			$socket = NULL; | ||||
| 		} | ||||
|  | ||||
| 		$client_flags = ($this->compress === TRUE) ? MYSQLI_CLIENT_COMPRESS : 0; | ||||
| 		$this->_mysqli = mysqli_init(); | ||||
|  | ||||
| 		$this->_mysqli->options(MYSQLI_OPT_CONNECT_TIMEOUT, 10); | ||||
|  | ||||
| 		if (isset($this->stricton)) | ||||
| 		{ | ||||
| 			if ($this->stricton) | ||||
| 			{ | ||||
| 				$this->_mysqli->options(MYSQLI_INIT_COMMAND, 'SET SESSION sql_mode = CONCAT(@@sql_mode, ",", "STRICT_ALL_TABLES")'); | ||||
| 			} | ||||
| 			else | ||||
| 			{ | ||||
| 				$this->_mysqli->options(MYSQLI_INIT_COMMAND, | ||||
| 					'SET SESSION sql_mode = | ||||
| 					REPLACE(REPLACE(REPLACE(REPLACE(REPLACE(REPLACE( | ||||
| 					@@sql_mode, | ||||
| 					"STRICT_ALL_TABLES,", ""), | ||||
| 					",STRICT_ALL_TABLES", ""), | ||||
| 					"STRICT_ALL_TABLES", ""), | ||||
| 					"STRICT_TRANS_TABLES,", ""), | ||||
| 					",STRICT_TRANS_TABLES", ""), | ||||
| 					"STRICT_TRANS_TABLES", "")' | ||||
| 				); | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		if (is_array($this->encrypt)) | ||||
| 		{ | ||||
| 			$ssl = array(); | ||||
| 			empty($this->encrypt['ssl_key'])    OR $ssl['key']    = $this->encrypt['ssl_key']; | ||||
| 			empty($this->encrypt['ssl_cert'])   OR $ssl['cert']   = $this->encrypt['ssl_cert']; | ||||
| 			empty($this->encrypt['ssl_ca'])     OR $ssl['ca']     = $this->encrypt['ssl_ca']; | ||||
| 			empty($this->encrypt['ssl_capath']) OR $ssl['capath'] = $this->encrypt['ssl_capath']; | ||||
| 			empty($this->encrypt['ssl_cipher']) OR $ssl['cipher'] = $this->encrypt['ssl_cipher']; | ||||
|  | ||||
| 			if (isset($this->encrypt['ssl_verify'])) | ||||
| 			{ | ||||
| 				$client_flags |= MYSQLI_CLIENT_SSL; | ||||
|  | ||||
| 				if ($this->encrypt['ssl_verify']) | ||||
| 				{ | ||||
| 					defined('MYSQLI_OPT_SSL_VERIFY_SERVER_CERT') && $this->_mysqli->options(MYSQLI_OPT_SSL_VERIFY_SERVER_CERT, TRUE); | ||||
| 				} | ||||
| 				// Apparently (when it exists), setting MYSQLI_OPT_SSL_VERIFY_SERVER_CERT | ||||
| 				// to FALSE didn't do anything, so PHP 5.6.16 introduced yet another | ||||
| 				// constant ... | ||||
| 				// | ||||
| 				// https://secure.php.net/ChangeLog-5.php#5.6.16 | ||||
| 				// https://bugs.php.net/bug.php?id=68344 | ||||
| 				elseif (defined('MYSQLI_CLIENT_SSL_DONT_VERIFY_SERVER_CERT')) | ||||
| 				{ | ||||
| 					$client_flags |= MYSQLI_CLIENT_SSL_DONT_VERIFY_SERVER_CERT; | ||||
| 				} | ||||
| 			} | ||||
|  | ||||
| 			if ( ! empty($ssl)) | ||||
| 			{ | ||||
| 				$client_flags |= MYSQLI_CLIENT_SSL; | ||||
| 				$this->_mysqli->ssl_set( | ||||
| 					isset($ssl['key'])    ? $ssl['key']    : NULL, | ||||
| 					isset($ssl['cert'])   ? $ssl['cert']   : NULL, | ||||
| 					isset($ssl['ca'])     ? $ssl['ca']     : NULL, | ||||
| 					isset($ssl['capath']) ? $ssl['capath'] : NULL, | ||||
| 					isset($ssl['cipher']) ? $ssl['cipher'] : NULL | ||||
| 				); | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		if ($this->_mysqli->real_connect($hostname, $this->username, $this->password, $this->database, $port, $socket, $client_flags)) | ||||
| 		{ | ||||
| 			// Prior to version 5.7.3, MySQL silently downgrades to an unencrypted connection if SSL setup fails | ||||
| 			if ( | ||||
| 				($client_flags & MYSQLI_CLIENT_SSL) | ||||
| 				&& version_compare($this->_mysqli->client_info, '5.7.3', '<=') | ||||
| 				&& empty($this->_mysqli->query("SHOW STATUS LIKE 'ssl_cipher'")->fetch_object()->Value) | ||||
| 			) | ||||
| 			{ | ||||
| 				$this->_mysqli->close(); | ||||
| 				$message = 'MySQLi was configured for an SSL connection, but got an unencrypted connection instead!'; | ||||
| 				log_message('error', $message); | ||||
| 				return ($this->db_debug) ? $this->display_error($message, '', TRUE) : FALSE; | ||||
| 			} | ||||
|  | ||||
| 			return $this->_mysqli; | ||||
| 		} | ||||
|  | ||||
| 		return FALSE; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Reconnect | ||||
| 	 * | ||||
| 	 * Keep / reestablish the db connection if no queries have been | ||||
| 	 * sent for a length of time exceeding the server's idle timeout | ||||
| 	 * | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	public function reconnect() | ||||
| 	{ | ||||
| 		if ($this->conn_id !== FALSE && $this->conn_id->ping() === FALSE) | ||||
| 		{ | ||||
| 			$this->conn_id = FALSE; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Select the database | ||||
| 	 * | ||||
| 	 * @param	string	$database | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	public function db_select($database = '') | ||||
| 	{ | ||||
| 		if ($database === '') | ||||
| 		{ | ||||
| 			$database = $this->database; | ||||
| 		} | ||||
|  | ||||
| 		if ($this->conn_id->select_db($database)) | ||||
| 		{ | ||||
| 			$this->database = $database; | ||||
| 			$this->data_cache = array(); | ||||
| 			return TRUE; | ||||
| 		} | ||||
|  | ||||
| 		return FALSE; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Set client character set | ||||
| 	 * | ||||
| 	 * @param	string	$charset | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	protected function _db_set_charset($charset) | ||||
| 	{ | ||||
| 		return $this->conn_id->set_charset($charset); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Database version number | ||||
| 	 * | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	public function version() | ||||
| 	{ | ||||
| 		if (isset($this->data_cache['version'])) | ||||
| 		{ | ||||
| 			return $this->data_cache['version']; | ||||
| 		} | ||||
|  | ||||
| 		return $this->data_cache['version'] = $this->conn_id->server_info; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Execute the query | ||||
| 	 * | ||||
| 	 * @param	string	$sql	an SQL query | ||||
| 	 * @return	mixed | ||||
| 	 */ | ||||
| 	protected function _execute($sql) | ||||
| 	{ | ||||
| 		return $this->conn_id->query($this->_prep_query($sql)); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Prep the query | ||||
| 	 * | ||||
| 	 * If needed, each database adapter can prep the query string | ||||
| 	 * | ||||
| 	 * @param	string	$sql	an SQL query | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _prep_query($sql) | ||||
| 	{ | ||||
| 		// mysqli_affected_rows() returns 0 for "DELETE FROM TABLE" queries. This hack | ||||
| 		// modifies the query so that it a proper number of affected rows is returned. | ||||
| 		if ($this->delete_hack === TRUE && preg_match('/^\s*DELETE\s+FROM\s+(\S+)\s*$/i', $sql)) | ||||
| 		{ | ||||
| 			return trim($sql).' WHERE 1=1'; | ||||
| 		} | ||||
|  | ||||
| 		return $sql; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Begin Transaction | ||||
| 	 * | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	protected function _trans_begin() | ||||
| 	{ | ||||
| 		$this->conn_id->autocommit(FALSE); | ||||
| 		return is_php('5.5') | ||||
| 			? $this->conn_id->begin_transaction() | ||||
| 			: $this->simple_query('START TRANSACTION'); // can also be BEGIN or BEGIN WORK | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Commit Transaction | ||||
| 	 * | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	protected function _trans_commit() | ||||
| 	{ | ||||
| 		if ($this->conn_id->commit()) | ||||
| 		{ | ||||
| 			$this->conn_id->autocommit(TRUE); | ||||
| 			return TRUE; | ||||
| 		} | ||||
|  | ||||
| 		return FALSE; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Rollback Transaction | ||||
| 	 * | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	protected function _trans_rollback() | ||||
| 	{ | ||||
| 		if ($this->conn_id->rollback()) | ||||
| 		{ | ||||
| 			$this->conn_id->autocommit(TRUE); | ||||
| 			return TRUE; | ||||
| 		} | ||||
|  | ||||
| 		return FALSE; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Platform-dependent string escape | ||||
| 	 * | ||||
| 	 * @param	string | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _escape_str($str) | ||||
| 	{ | ||||
| 		return $this->conn_id->real_escape_string($str); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Affected Rows | ||||
| 	 * | ||||
| 	 * @return	int | ||||
| 	 */ | ||||
| 	public function affected_rows() | ||||
| 	{ | ||||
| 		return $this->conn_id->affected_rows; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Insert ID | ||||
| 	 * | ||||
| 	 * @return	int | ||||
| 	 */ | ||||
| 	public function insert_id() | ||||
| 	{ | ||||
| 		return $this->conn_id->insert_id; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * List table query | ||||
| 	 * | ||||
| 	 * Generates a platform-specific query string so that the table names can be fetched | ||||
| 	 * | ||||
| 	 * @param	bool	$prefix_limit | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _list_tables($prefix_limit = FALSE) | ||||
| 	{ | ||||
| 		$sql = 'SHOW TABLES FROM '.$this->_escape_char.$this->database.$this->_escape_char; | ||||
|  | ||||
| 		if ($prefix_limit !== FALSE && $this->dbprefix !== '') | ||||
| 		{ | ||||
| 			return $sql." LIKE '".$this->escape_like_str($this->dbprefix)."%'"; | ||||
| 		} | ||||
|  | ||||
| 		return $sql; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Show column query | ||||
| 	 * | ||||
| 	 * Generates a platform-specific query string so that the column names can be fetched | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _list_columns($table = '') | ||||
| 	{ | ||||
| 		return 'SHOW COLUMNS FROM '.$this->protect_identifiers($table, TRUE, NULL, FALSE); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Returns an object with field data | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	public function field_data($table) | ||||
| 	{ | ||||
| 		if (($query = $this->query('SHOW COLUMNS FROM '.$this->protect_identifiers($table, TRUE, NULL, FALSE))) === FALSE) | ||||
| 		{ | ||||
| 			return FALSE; | ||||
| 		} | ||||
| 		$query = $query->result_object(); | ||||
|  | ||||
| 		$retval = array(); | ||||
| 		for ($i = 0, $c = count($query); $i < $c; $i++) | ||||
| 		{ | ||||
| 			$retval[$i]			= new stdClass(); | ||||
| 			$retval[$i]->name		= $query[$i]->Field; | ||||
|  | ||||
| 			sscanf($query[$i]->Type, '%[a-z](%d)', | ||||
| 				$retval[$i]->type, | ||||
| 				$retval[$i]->max_length | ||||
| 			); | ||||
|  | ||||
| 			$retval[$i]->default		= $query[$i]->Default; | ||||
| 			$retval[$i]->primary_key	= (int) ($query[$i]->Key === 'PRI'); | ||||
| 		} | ||||
|  | ||||
| 		return $retval; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Error | ||||
| 	 * | ||||
| 	 * Returns an array containing code and message of the last | ||||
| 	 * database error that has occurred. | ||||
| 	 * | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	public function error() | ||||
| 	{ | ||||
| 		if ( ! empty($this->_mysqli->connect_errno)) | ||||
| 		{ | ||||
| 			return array( | ||||
| 				'code'    => $this->_mysqli->connect_errno, | ||||
| 				'message' => $this->_mysqli->connect_error | ||||
| 			); | ||||
| 		} | ||||
|  | ||||
| 		return array('code' => $this->conn_id->errno, 'message' => $this->conn_id->error); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * FROM tables | ||||
| 	 * | ||||
| 	 * Groups tables in FROM clauses if needed, so there is no confusion | ||||
| 	 * about operator precedence. | ||||
| 	 * | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _from_tables() | ||||
| 	{ | ||||
| 		if ( ! empty($this->qb_join) && count($this->qb_from) > 1) | ||||
| 		{ | ||||
| 			return '('.implode(', ', $this->qb_from).')'; | ||||
| 		} | ||||
|  | ||||
| 		return implode(', ', $this->qb_from); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Close DB Connection | ||||
| 	 * | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	protected function _close() | ||||
| 	{ | ||||
| 		$this->conn_id->close(); | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										244
									
								
								system/database/drivers/mysqli/mysqli_forge.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										244
									
								
								system/database/drivers/mysqli/mysqli_forge.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,244 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/) | ||||
|  * @license	https://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 1.3.0 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * MySQLi Forge Class | ||||
|  * | ||||
|  * @package		CodeIgniter | ||||
|  * @subpackage	Drivers | ||||
|  * @category	Database | ||||
|  * @author		EllisLab Dev Team | ||||
|  * @link		https://codeigniter.com/user_guide/database/ | ||||
|  */ | ||||
| class CI_DB_mysqli_forge extends CI_DB_forge { | ||||
|  | ||||
| 	/** | ||||
| 	 * CREATE DATABASE statement | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_create_database	= 'CREATE DATABASE %s CHARACTER SET %s COLLATE %s'; | ||||
|  | ||||
| 	/** | ||||
| 	 * CREATE TABLE keys flag | ||||
| 	 * | ||||
| 	 * Whether table keys are created from within the | ||||
| 	 * CREATE TABLE statement. | ||||
| 	 * | ||||
| 	 * @var	bool | ||||
| 	 */ | ||||
| 	protected $_create_table_keys	= TRUE; | ||||
|  | ||||
| 	/** | ||||
| 	 * UNSIGNED support | ||||
| 	 * | ||||
| 	 * @var	array | ||||
| 	 */ | ||||
| 	protected $_unsigned		= array( | ||||
| 		'TINYINT', | ||||
| 		'SMALLINT', | ||||
| 		'MEDIUMINT', | ||||
| 		'INT', | ||||
| 		'INTEGER', | ||||
| 		'BIGINT', | ||||
| 		'REAL', | ||||
| 		'DOUBLE', | ||||
| 		'DOUBLE PRECISION', | ||||
| 		'FLOAT', | ||||
| 		'DECIMAL', | ||||
| 		'NUMERIC' | ||||
| 	); | ||||
|  | ||||
| 	/** | ||||
| 	 * NULL value representation in CREATE/ALTER TABLE statements | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_null = 'NULL'; | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * CREATE TABLE attributes | ||||
| 	 * | ||||
| 	 * @param	array	$attributes	Associative array of table attributes | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _create_table_attr($attributes) | ||||
| 	{ | ||||
| 		$sql = ''; | ||||
|  | ||||
| 		foreach (array_keys($attributes) as $key) | ||||
| 		{ | ||||
| 			if (is_string($key)) | ||||
| 			{ | ||||
| 				$sql .= ' '.strtoupper($key).' = '.$attributes[$key]; | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		if ( ! empty($this->db->char_set) && ! strpos($sql, 'CHARACTER SET') && ! strpos($sql, 'CHARSET')) | ||||
| 		{ | ||||
| 			$sql .= ' DEFAULT CHARACTER SET = '.$this->db->char_set; | ||||
| 		} | ||||
|  | ||||
| 		if ( ! empty($this->db->dbcollat) && ! strpos($sql, 'COLLATE')) | ||||
| 		{ | ||||
| 			$sql .= ' COLLATE = '.$this->db->dbcollat; | ||||
| 		} | ||||
|  | ||||
| 		return $sql; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * ALTER TABLE | ||||
| 	 * | ||||
| 	 * @param	string	$alter_type	ALTER type | ||||
| 	 * @param	string	$table		Table name | ||||
| 	 * @param	mixed	$field		Column definition | ||||
| 	 * @return	string|string[] | ||||
| 	 */ | ||||
| 	protected function _alter_table($alter_type, $table, $field) | ||||
| 	{ | ||||
| 		if ($alter_type === 'DROP') | ||||
| 		{ | ||||
| 			return parent::_alter_table($alter_type, $table, $field); | ||||
| 		} | ||||
|  | ||||
| 		$sql = 'ALTER TABLE '.$this->db->escape_identifiers($table); | ||||
| 		for ($i = 0, $c = count($field); $i < $c; $i++) | ||||
| 		{ | ||||
| 			if ($field[$i]['_literal'] !== FALSE) | ||||
| 			{ | ||||
| 				$field[$i] = ($alter_type === 'ADD') | ||||
| 						? "\n\tADD ".$field[$i]['_literal'] | ||||
| 						: "\n\tMODIFY ".$field[$i]['_literal']; | ||||
| 			} | ||||
| 			else | ||||
| 			{ | ||||
| 				if ($alter_type === 'ADD') | ||||
| 				{ | ||||
| 					$field[$i]['_literal'] = "\n\tADD "; | ||||
| 				} | ||||
| 				else | ||||
| 				{ | ||||
| 					$field[$i]['_literal'] = empty($field[$i]['new_name']) ? "\n\tMODIFY " : "\n\tCHANGE "; | ||||
| 				} | ||||
|  | ||||
| 				$field[$i] = $field[$i]['_literal'].$this->_process_column($field[$i]); | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		return array($sql.implode(',', $field)); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Process column | ||||
| 	 * | ||||
| 	 * @param	array	$field | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _process_column($field) | ||||
| 	{ | ||||
| 		$extra_clause = isset($field['after']) | ||||
| 			? ' AFTER '.$this->db->escape_identifiers($field['after']) : ''; | ||||
|  | ||||
| 		if (empty($extra_clause) && isset($field['first']) && $field['first'] === TRUE) | ||||
| 		{ | ||||
| 			$extra_clause = ' FIRST'; | ||||
| 		} | ||||
|  | ||||
| 		return $this->db->escape_identifiers($field['name']) | ||||
| 			.(empty($field['new_name']) ? '' : ' '.$this->db->escape_identifiers($field['new_name'])) | ||||
| 			.' '.$field['type'].$field['length'] | ||||
| 			.$field['unsigned'] | ||||
| 			.$field['null'] | ||||
| 			.$field['default'] | ||||
| 			.$field['auto_increment'] | ||||
| 			.$field['unique'] | ||||
| 			.(empty($field['comment']) ? '' : ' COMMENT '.$field['comment']) | ||||
| 			.$extra_clause; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Process indexes | ||||
| 	 * | ||||
| 	 * @param	string	$table	(ignored) | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _process_indexes($table) | ||||
| 	{ | ||||
| 		$sql = ''; | ||||
|  | ||||
| 		for ($i = 0, $c = count($this->keys); $i < $c; $i++) | ||||
| 		{ | ||||
| 			if (is_array($this->keys[$i])) | ||||
| 			{ | ||||
| 				for ($i2 = 0, $c2 = count($this->keys[$i]); $i2 < $c2; $i2++) | ||||
| 				{ | ||||
| 					if ( ! isset($this->fields[$this->keys[$i][$i2]])) | ||||
| 					{ | ||||
| 						unset($this->keys[$i][$i2]); | ||||
| 						continue; | ||||
| 					} | ||||
| 				} | ||||
| 			} | ||||
| 			elseif ( ! isset($this->fields[$this->keys[$i]])) | ||||
| 			{ | ||||
| 				unset($this->keys[$i]); | ||||
| 				continue; | ||||
| 			} | ||||
|  | ||||
| 			is_array($this->keys[$i]) OR $this->keys[$i] = array($this->keys[$i]); | ||||
|  | ||||
| 			$sql .= ",\n\tKEY ".$this->db->escape_identifiers(implode('_', $this->keys[$i])) | ||||
| 				.' ('.implode(', ', $this->db->escape_identifiers($this->keys[$i])).')'; | ||||
| 		} | ||||
|  | ||||
| 		$this->keys = array(); | ||||
|  | ||||
| 		return $sql; | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										232
									
								
								system/database/drivers/mysqli/mysqli_result.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										232
									
								
								system/database/drivers/mysqli/mysqli_result.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,232 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/) | ||||
|  * @license	https://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 1.3.0 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * MySQLi Result Class | ||||
|  * | ||||
|  * This class extends the parent result class: CI_DB_result | ||||
|  * | ||||
|  * @package		CodeIgniter | ||||
|  * @subpackage	Drivers | ||||
|  * @category	Database | ||||
|  * @author		EllisLab Dev Team | ||||
|  * @link		https://codeigniter.com/user_guide/database/ | ||||
|  */ | ||||
| class CI_DB_mysqli_result extends CI_DB_result { | ||||
|  | ||||
| 	/** | ||||
| 	 * Number of rows in the result set | ||||
| 	 * | ||||
| 	 * @return	int | ||||
| 	 */ | ||||
| 	public function num_rows() | ||||
| 	{ | ||||
| 		return is_int($this->num_rows) | ||||
| 			? $this->num_rows | ||||
| 			: $this->num_rows = $this->result_id->num_rows; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Number of fields in the result set | ||||
| 	 * | ||||
| 	 * @return	int | ||||
| 	 */ | ||||
| 	public function num_fields() | ||||
| 	{ | ||||
| 		return $this->result_id->field_count; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Fetch Field Names | ||||
| 	 * | ||||
| 	 * Generates an array of column names | ||||
| 	 * | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	public function list_fields() | ||||
| 	{ | ||||
| 		$field_names = array(); | ||||
| 		$this->result_id->field_seek(0); | ||||
| 		while ($field = $this->result_id->fetch_field()) | ||||
| 		{ | ||||
| 			$field_names[] = $field->name; | ||||
| 		} | ||||
|  | ||||
| 		return $field_names; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Field data | ||||
| 	 * | ||||
| 	 * Generates an array of objects containing field meta-data | ||||
| 	 * | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	public function field_data() | ||||
| 	{ | ||||
| 		$retval = array(); | ||||
| 		$field_data = $this->result_id->fetch_fields(); | ||||
| 		for ($i = 0, $c = count($field_data); $i < $c; $i++) | ||||
| 		{ | ||||
| 			$retval[$i]			= new stdClass(); | ||||
| 			$retval[$i]->name		= $field_data[$i]->name; | ||||
| 			$retval[$i]->type		= static::_get_field_type($field_data[$i]->type); | ||||
| 			$retval[$i]->max_length		= $field_data[$i]->max_length; | ||||
| 			$retval[$i]->primary_key	= (int) ($field_data[$i]->flags & MYSQLI_PRI_KEY_FLAG); | ||||
| 			$retval[$i]->default		= $field_data[$i]->def; | ||||
| 		} | ||||
|  | ||||
| 		return $retval; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Get field type | ||||
| 	 * | ||||
| 	 * Extracts field type info from the bitflags returned by | ||||
| 	 * mysqli_result::fetch_fields() | ||||
| 	 * | ||||
| 	 * @used-by	CI_DB_mysqli_result::field_data() | ||||
| 	 * @param	int	$type | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	private static function _get_field_type($type) | ||||
| 	{ | ||||
| 		static $map; | ||||
| 		isset($map) OR $map = array( | ||||
| 			MYSQLI_TYPE_DECIMAL     => 'decimal', | ||||
| 			MYSQLI_TYPE_BIT         => 'bit', | ||||
| 			MYSQLI_TYPE_TINY        => 'tinyint', | ||||
| 			MYSQLI_TYPE_SHORT       => 'smallint', | ||||
| 			MYSQLI_TYPE_INT24       => 'mediumint', | ||||
| 			MYSQLI_TYPE_LONG        => 'int', | ||||
| 			MYSQLI_TYPE_LONGLONG    => 'bigint', | ||||
| 			MYSQLI_TYPE_FLOAT       => 'float', | ||||
| 			MYSQLI_TYPE_DOUBLE      => 'double', | ||||
| 			MYSQLI_TYPE_TIMESTAMP   => 'timestamp', | ||||
| 			MYSQLI_TYPE_DATE        => 'date', | ||||
| 			MYSQLI_TYPE_TIME        => 'time', | ||||
| 			MYSQLI_TYPE_DATETIME    => 'datetime', | ||||
| 			MYSQLI_TYPE_YEAR        => 'year', | ||||
| 			MYSQLI_TYPE_NEWDATE     => 'date', | ||||
| 			MYSQLI_TYPE_INTERVAL    => 'interval', | ||||
| 			MYSQLI_TYPE_ENUM        => 'enum', | ||||
| 			MYSQLI_TYPE_SET         => 'set', | ||||
| 			MYSQLI_TYPE_TINY_BLOB   => 'tinyblob', | ||||
| 			MYSQLI_TYPE_MEDIUM_BLOB => 'mediumblob', | ||||
| 			MYSQLI_TYPE_BLOB        => 'blob', | ||||
| 			MYSQLI_TYPE_LONG_BLOB   => 'longblob', | ||||
| 			MYSQLI_TYPE_STRING      => 'char', | ||||
| 			MYSQLI_TYPE_VAR_STRING  => 'varchar', | ||||
| 			MYSQLI_TYPE_GEOMETRY    => 'geometry' | ||||
| 		); | ||||
|  | ||||
| 		return isset($map[$type]) ? $map[$type] : $type; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Free the result | ||||
| 	 * | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	public function free_result() | ||||
| 	{ | ||||
| 		if (is_object($this->result_id)) | ||||
| 		{ | ||||
| 			$this->result_id->free(); | ||||
| 			$this->result_id = FALSE; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Data Seek | ||||
| 	 * | ||||
| 	 * Moves the internal pointer to the desired offset. We call | ||||
| 	 * this internally before fetching results to make sure the | ||||
| 	 * result set starts at zero. | ||||
| 	 * | ||||
| 	 * @param	int	$n | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	public function data_seek($n = 0) | ||||
| 	{ | ||||
| 		return $this->result_id->data_seek($n); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Result - associative array | ||||
| 	 * | ||||
| 	 * Returns the result set as an array | ||||
| 	 * | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	protected function _fetch_assoc() | ||||
| 	{ | ||||
| 		return $this->result_id->fetch_assoc(); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Result - object | ||||
| 	 * | ||||
| 	 * Returns the result set as an object | ||||
| 	 * | ||||
| 	 * @param	string	$class_name | ||||
| 	 * @return	object | ||||
| 	 */ | ||||
| 	protected function _fetch_object($class_name = 'stdClass') | ||||
| 	{ | ||||
| 		return $this->result_id->fetch_object($class_name); | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										211
									
								
								system/database/drivers/mysqli/mysqli_utility.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										211
									
								
								system/database/drivers/mysqli/mysqli_utility.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,211 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/) | ||||
|  * @license	https://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 1.3.0 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * MySQLi Utility Class | ||||
|  * | ||||
|  * @package		CodeIgniter | ||||
|  * @subpackage	Drivers | ||||
|  * @category	Database | ||||
|  * @author		EllisLab Dev Team | ||||
|  * @link		https://codeigniter.com/user_guide/database/ | ||||
|  */ | ||||
| class CI_DB_mysqli_utility extends CI_DB_utility { | ||||
|  | ||||
| 	/** | ||||
| 	 * List databases statement | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_list_databases	= 'SHOW DATABASES'; | ||||
|  | ||||
| 	/** | ||||
| 	 * OPTIMIZE TABLE statement | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_optimize_table	= 'OPTIMIZE TABLE %s'; | ||||
|  | ||||
| 	/** | ||||
| 	 * REPAIR TABLE statement | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_repair_table	= 'REPAIR TABLE %s'; | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Export | ||||
| 	 * | ||||
| 	 * @param	array	$params	Preferences | ||||
| 	 * @return	mixed | ||||
| 	 */ | ||||
| 	protected function _backup($params = array()) | ||||
| 	{ | ||||
| 		if (count($params) === 0) | ||||
| 		{ | ||||
| 			return FALSE; | ||||
| 		} | ||||
|  | ||||
| 		// Extract the prefs for simplicity | ||||
| 		extract($params); | ||||
|  | ||||
| 		// Build the output | ||||
| 		$output = ''; | ||||
|  | ||||
| 		// Do we need to include a statement to disable foreign key checks? | ||||
| 		if ($foreign_key_checks === FALSE) | ||||
| 		{ | ||||
| 			$output .= 'SET foreign_key_checks = 0;'.$newline; | ||||
| 		} | ||||
|  | ||||
| 		foreach ( (array) $tables as $table) | ||||
| 		{ | ||||
| 			// Is the table in the "ignore" list? | ||||
| 			if (in_array($table, (array) $ignore, TRUE)) | ||||
| 			{ | ||||
| 				continue; | ||||
| 			} | ||||
|  | ||||
| 			// Get the table schema | ||||
| 			$query = $this->db->query('SHOW CREATE TABLE '.$this->db->escape_identifiers($this->db->database.'.'.$table)); | ||||
|  | ||||
| 			// No result means the table name was invalid | ||||
| 			if ($query === FALSE) | ||||
| 			{ | ||||
| 				continue; | ||||
| 			} | ||||
|  | ||||
| 			// Write out the table schema | ||||
| 			$output .= '#'.$newline.'# TABLE STRUCTURE FOR: '.$table.$newline.'#'.$newline.$newline; | ||||
|  | ||||
| 			if ($add_drop === TRUE) | ||||
| 			{ | ||||
| 				$output .= 'DROP TABLE IF EXISTS '.$this->db->protect_identifiers($table).';'.$newline.$newline; | ||||
| 			} | ||||
|  | ||||
| 			$i = 0; | ||||
| 			$result = $query->result_array(); | ||||
| 			foreach ($result[0] as $val) | ||||
| 			{ | ||||
| 				if ($i++ % 2) | ||||
| 				{ | ||||
| 					$output .= $val.';'.$newline.$newline; | ||||
| 				} | ||||
| 			} | ||||
|  | ||||
| 			// If inserts are not needed we're done... | ||||
| 			if ($add_insert === FALSE) | ||||
| 			{ | ||||
| 				continue; | ||||
| 			} | ||||
|  | ||||
| 			// Grab all the data from the current table | ||||
| 			$query = $this->db->query('SELECT * FROM '.$this->db->protect_identifiers($table)); | ||||
|  | ||||
| 			if ($query->num_rows() === 0) | ||||
| 			{ | ||||
| 				continue; | ||||
| 			} | ||||
|  | ||||
| 			// Fetch the field names and determine if the field is an | ||||
| 			// integer type. We use this info to decide whether to | ||||
| 			// surround the data with quotes or not | ||||
|  | ||||
| 			$i = 0; | ||||
| 			$field_str = ''; | ||||
| 			$is_int = array(); | ||||
| 			while ($field = $query->result_id->fetch_field()) | ||||
| 			{ | ||||
| 				// Most versions of MySQL store timestamp as a string | ||||
| 				$is_int[$i] = in_array($field->type, array(MYSQLI_TYPE_TINY, MYSQLI_TYPE_SHORT, MYSQLI_TYPE_INT24, MYSQLI_TYPE_LONG), TRUE); | ||||
|  | ||||
| 				// Create a string of field names | ||||
| 				$field_str .= $this->db->escape_identifiers($field->name).', '; | ||||
| 				$i++; | ||||
| 			} | ||||
|  | ||||
| 			// Trim off the end comma | ||||
| 			$field_str = preg_replace('/, $/' , '', $field_str); | ||||
|  | ||||
| 			// Build the insert string | ||||
| 			foreach ($query->result_array() as $row) | ||||
| 			{ | ||||
| 				$val_str = ''; | ||||
|  | ||||
| 				$i = 0; | ||||
| 				foreach ($row as $v) | ||||
| 				{ | ||||
| 					// Is the value NULL? | ||||
| 					if ($v === NULL) | ||||
| 					{ | ||||
| 						$val_str .= 'NULL'; | ||||
| 					} | ||||
| 					else | ||||
| 					{ | ||||
| 						// Escape the data if it's not an integer | ||||
| 						$val_str .= ($is_int[$i] === FALSE) ? $this->db->escape($v) : $v; | ||||
| 					} | ||||
|  | ||||
| 					// Append a comma | ||||
| 					$val_str .= ', '; | ||||
| 					$i++; | ||||
| 				} | ||||
|  | ||||
| 				// Remove the comma at the end of the string | ||||
| 				$val_str = preg_replace('/, $/' , '', $val_str); | ||||
|  | ||||
| 				// Build the INSERT string | ||||
| 				$output .= 'INSERT INTO '.$this->db->protect_identifiers($table).' ('.$field_str.') VALUES ('.$val_str.');'.$newline; | ||||
| 			} | ||||
|  | ||||
| 			$output .= $newline.$newline; | ||||
| 		} | ||||
|  | ||||
| 		// Do we need to include a statement to re-enable foreign key checks? | ||||
| 		if ($foreign_key_checks === FALSE) | ||||
| 		{ | ||||
| 			$output .= 'SET foreign_key_checks = 1;'.$newline; | ||||
| 		} | ||||
|  | ||||
| 		return $output; | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										11
									
								
								system/database/drivers/oci8/index.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								system/database/drivers/oci8/index.html
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,11 @@ | ||||
| <!DOCTYPE html> | ||||
| <html> | ||||
| <head> | ||||
| 	<title>403 Forbidden</title> | ||||
| </head> | ||||
| <body> | ||||
|  | ||||
| <p>Directory access is forbidden.</p> | ||||
|  | ||||
| </body> | ||||
| </html> | ||||
							
								
								
									
										701
									
								
								system/database/drivers/oci8/oci8_driver.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										701
									
								
								system/database/drivers/oci8/oci8_driver.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,701 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/) | ||||
|  * @license	https://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 1.4.1 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * oci8 Database Adapter Class | ||||
|  * | ||||
|  * Note: _DB is an extender class that the app controller | ||||
|  * creates dynamically based on whether the query builder | ||||
|  * class is being used or not. | ||||
|  * | ||||
|  * @package		CodeIgniter | ||||
|  * @subpackage  Drivers | ||||
|  * @category	Database | ||||
|  * @author		EllisLab Dev Team | ||||
|  * @link		https://codeigniter.com/user_guide/database/ | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * oci8 Database Adapter Class | ||||
|  * | ||||
|  * This is a modification of the DB_driver class to | ||||
|  * permit access to oracle databases | ||||
|  * | ||||
|  * @author	  Kelly McArdle | ||||
|  */ | ||||
| class CI_DB_oci8_driver extends CI_DB { | ||||
|  | ||||
| 	/** | ||||
| 	 * Database driver | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	public $dbdriver = 'oci8'; | ||||
|  | ||||
| 	/** | ||||
| 	 * Statement ID | ||||
| 	 * | ||||
| 	 * @var	resource | ||||
| 	 */ | ||||
| 	public $stmt_id; | ||||
|  | ||||
| 	/** | ||||
| 	 * Cursor ID | ||||
| 	 * | ||||
| 	 * @var	resource | ||||
| 	 */ | ||||
| 	public $curs_id; | ||||
|  | ||||
| 	/** | ||||
| 	 * Commit mode flag | ||||
| 	 * | ||||
| 	 * @var	int | ||||
| 	 */ | ||||
| 	public $commit_mode = OCI_COMMIT_ON_SUCCESS; | ||||
|  | ||||
| 	/** | ||||
| 	 * Limit used flag | ||||
| 	 * | ||||
| 	 * If we use LIMIT, we'll add a field that will | ||||
| 	 * throw off num_fields later. | ||||
| 	 * | ||||
| 	 * @var	bool | ||||
| 	 */ | ||||
| 	public $limit_used = FALSE; | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Reset $stmt_id flag | ||||
| 	 * | ||||
| 	 * Used by stored_procedure() to prevent _execute() from | ||||
| 	 * re-setting the statement ID. | ||||
| 	 */ | ||||
| 	protected $_reset_stmt_id = TRUE; | ||||
|  | ||||
| 	/** | ||||
| 	 * List of reserved identifiers | ||||
| 	 * | ||||
| 	 * Identifiers that must NOT be escaped. | ||||
| 	 * | ||||
| 	 * @var	string[] | ||||
| 	 */ | ||||
| 	protected $_reserved_identifiers = array('*', 'rownum'); | ||||
|  | ||||
| 	/** | ||||
| 	 * ORDER BY random keyword | ||||
| 	 * | ||||
| 	 * @var	array | ||||
| 	 */ | ||||
| 	protected $_random_keyword = array('ASC', 'ASC'); // not currently supported | ||||
|  | ||||
| 	/** | ||||
| 	 * COUNT string | ||||
| 	 * | ||||
| 	 * @used-by	CI_DB_driver::count_all() | ||||
| 	 * @used-by	CI_DB_query_builder::count_all_results() | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_count_string = 'SELECT COUNT(1) AS '; | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Class constructor | ||||
| 	 * | ||||
| 	 * @param	array	$params | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	public function __construct($params) | ||||
| 	{ | ||||
| 		parent::__construct($params); | ||||
|  | ||||
| 		$valid_dsns = array( | ||||
| 			'tns'	=> '/^\(DESCRIPTION=(\(.+\)){2,}\)$/', // TNS | ||||
| 			// Easy Connect string (Oracle 10g+) | ||||
| 			'ec'	=> '/^(\/\/)?[a-z0-9.:_-]+(:[1-9][0-9]{0,4})?(\/[a-z0-9$_]+)?(:[^\/])?(\/[a-z0-9$_]+)?$/i', | ||||
| 			'in'	=> '/^[a-z0-9$_]+$/i' // Instance name (defined in tnsnames.ora) | ||||
| 		); | ||||
|  | ||||
| 		/* Space characters don't have any effect when actually | ||||
| 		 * connecting, but can be a hassle while validating the DSN. | ||||
| 		 */ | ||||
| 		$this->dsn = str_replace(array("\n", "\r", "\t", ' '), '', $this->dsn); | ||||
|  | ||||
| 		if ($this->dsn !== '') | ||||
| 		{ | ||||
| 			foreach ($valid_dsns as $regexp) | ||||
| 			{ | ||||
| 				if (preg_match($regexp, $this->dsn)) | ||||
| 				{ | ||||
| 					return; | ||||
| 				} | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		// Legacy support for TNS in the hostname configuration field | ||||
| 		$this->hostname = str_replace(array("\n", "\r", "\t", ' '), '', $this->hostname); | ||||
| 		if (preg_match($valid_dsns['tns'], $this->hostname)) | ||||
| 		{ | ||||
| 			$this->dsn = $this->hostname; | ||||
| 			return; | ||||
| 		} | ||||
| 		elseif ($this->hostname !== '' && strpos($this->hostname, '/') === FALSE && strpos($this->hostname, ':') === FALSE | ||||
| 			&& (( ! empty($this->port) && ctype_digit($this->port)) OR $this->database !== '')) | ||||
| 		{ | ||||
| 			/* If the hostname field isn't empty, doesn't contain | ||||
| 			 * ':' and/or '/' and if port and/or database aren't | ||||
| 			 * empty, then the hostname field is most likely indeed | ||||
| 			 * just a hostname. Therefore we'll try and build an | ||||
| 			 * Easy Connect string from these 3 settings, assuming | ||||
| 			 * that the database field is a service name. | ||||
| 			 */ | ||||
| 			$this->dsn = $this->hostname | ||||
| 				.(( ! empty($this->port) && ctype_digit($this->port)) ? ':'.$this->port : '') | ||||
| 				.($this->database !== '' ? '/'.ltrim($this->database, '/') : ''); | ||||
|  | ||||
| 			if (preg_match($valid_dsns['ec'], $this->dsn)) | ||||
| 			{ | ||||
| 				return; | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		/* At this point, we can only try and validate the hostname and | ||||
| 		 * database fields separately as DSNs. | ||||
| 		 */ | ||||
| 		if (preg_match($valid_dsns['ec'], $this->hostname) OR preg_match($valid_dsns['in'], $this->hostname)) | ||||
| 		{ | ||||
| 			$this->dsn = $this->hostname; | ||||
| 			return; | ||||
| 		} | ||||
|  | ||||
| 		$this->database = str_replace(array("\n", "\r", "\t", ' '), '', $this->database); | ||||
| 		foreach ($valid_dsns as $regexp) | ||||
| 		{ | ||||
| 			if (preg_match($regexp, $this->database)) | ||||
| 			{ | ||||
| 				return; | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		/* Well - OK, an empty string should work as well. | ||||
| 		 * PHP will try to use environment variables to | ||||
| 		 * determine which Oracle instance to connect to. | ||||
| 		 */ | ||||
| 		$this->dsn = ''; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Non-persistent database connection | ||||
| 	 * | ||||
| 	 * @param	bool	$persistent | ||||
| 	 * @return	resource | ||||
| 	 */ | ||||
| 	public function db_connect($persistent = FALSE) | ||||
| 	{ | ||||
| 		$func = ($persistent === TRUE) ? 'oci_pconnect' : 'oci_connect'; | ||||
| 		return empty($this->char_set) | ||||
| 			? $func($this->username, $this->password, $this->dsn) | ||||
| 			: $func($this->username, $this->password, $this->dsn, $this->char_set); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Database version number | ||||
| 	 * | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	public function version() | ||||
| 	{ | ||||
| 		if (isset($this->data_cache['version'])) | ||||
| 		{ | ||||
| 			return $this->data_cache['version']; | ||||
| 		} | ||||
|  | ||||
| 		if ( ! $this->conn_id OR ($version_string = oci_server_version($this->conn_id)) === FALSE) | ||||
| 		{ | ||||
| 			return FALSE; | ||||
| 		} | ||||
| 		elseif (preg_match('#Release\s(\d+(?:\.\d+)+)#', $version_string, $match)) | ||||
| 		{ | ||||
| 			return $this->data_cache['version'] = $match[1]; | ||||
| 		} | ||||
|  | ||||
| 		return FALSE; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Execute the query | ||||
| 	 * | ||||
| 	 * @param	string	$sql	an SQL query | ||||
| 	 * @return	resource | ||||
| 	 */ | ||||
| 	protected function _execute($sql) | ||||
| 	{ | ||||
| 		/* Oracle must parse the query before it is run. All of the actions with | ||||
| 		 * the query are based on the statement id returned by oci_parse(). | ||||
| 		 */ | ||||
| 		if ($this->_reset_stmt_id === TRUE) | ||||
| 		{ | ||||
| 			$this->stmt_id = oci_parse($this->conn_id, $sql); | ||||
| 		} | ||||
|  | ||||
| 		oci_set_prefetch($this->stmt_id, 1000); | ||||
| 		return oci_execute($this->stmt_id, $this->commit_mode); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Get cursor. Returns a cursor from the database | ||||
| 	 * | ||||
| 	 * @return	resource | ||||
| 	 */ | ||||
| 	public function get_cursor() | ||||
| 	{ | ||||
| 		return $this->curs_id = oci_new_cursor($this->conn_id); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Stored Procedure.  Executes a stored procedure | ||||
| 	 * | ||||
| 	 * @param	string	package name in which the stored procedure is in | ||||
| 	 * @param	string	stored procedure name to execute | ||||
| 	 * @param	array	parameters | ||||
| 	 * @return	mixed | ||||
| 	 * | ||||
| 	 * params array keys | ||||
| 	 * | ||||
| 	 * KEY      OPTIONAL  NOTES | ||||
| 	 * name     no        the name of the parameter should be in :<param_name> format | ||||
| 	 * value    no        the value of the parameter.  If this is an OUT or IN OUT parameter, | ||||
| 	 *                    this should be a reference to a variable | ||||
| 	 * type     yes       the type of the parameter | ||||
| 	 * length   yes       the max size of the parameter | ||||
| 	 */ | ||||
| 	public function stored_procedure($package, $procedure, array $params) | ||||
| 	{ | ||||
| 		if ($package === '' OR $procedure === '') | ||||
| 		{ | ||||
| 			log_message('error', 'Invalid query: '.$package.'.'.$procedure); | ||||
| 			return ($this->db_debug) ? $this->display_error('db_invalid_query') : FALSE; | ||||
| 		} | ||||
|  | ||||
| 		// Build the query string | ||||
| 		$sql = 'BEGIN '.$package.'.'.$procedure.'('; | ||||
|  | ||||
| 		$have_cursor = FALSE; | ||||
| 		foreach ($params as $param) | ||||
| 		{ | ||||
| 			$sql .= $param['name'].','; | ||||
|  | ||||
| 			if (isset($param['type']) && $param['type'] === OCI_B_CURSOR) | ||||
| 			{ | ||||
| 				$have_cursor = TRUE; | ||||
| 			} | ||||
| 		} | ||||
| 		$sql = trim($sql, ',').'); END;'; | ||||
|  | ||||
| 		$this->_reset_stmt_id = FALSE; | ||||
| 		$this->stmt_id = oci_parse($this->conn_id, $sql); | ||||
| 		$this->_bind_params($params); | ||||
| 		$result = $this->query($sql, FALSE, $have_cursor); | ||||
| 		$this->_reset_stmt_id = TRUE; | ||||
| 		return $result; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Bind parameters | ||||
| 	 * | ||||
| 	 * @param	array	$params | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	protected function _bind_params($params) | ||||
| 	{ | ||||
| 		if ( ! is_array($params) OR ! is_resource($this->stmt_id)) | ||||
| 		{ | ||||
| 			return; | ||||
| 		} | ||||
|  | ||||
| 		foreach ($params as $param) | ||||
| 		{ | ||||
| 			foreach (array('name', 'value', 'type', 'length') as $val) | ||||
| 			{ | ||||
| 				if ( ! isset($param[$val])) | ||||
| 				{ | ||||
| 					$param[$val] = ''; | ||||
| 				} | ||||
| 			} | ||||
|  | ||||
| 			oci_bind_by_name($this->stmt_id, $param['name'], $param['value'], $param['length'], $param['type']); | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Begin Transaction | ||||
| 	 * | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	protected function _trans_begin() | ||||
| 	{ | ||||
| 		$this->commit_mode = OCI_NO_AUTO_COMMIT; | ||||
| 		return TRUE; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Commit Transaction | ||||
| 	 * | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	protected function _trans_commit() | ||||
| 	{ | ||||
| 		$this->commit_mode = OCI_COMMIT_ON_SUCCESS; | ||||
|  | ||||
| 		return oci_commit($this->conn_id); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Rollback Transaction | ||||
| 	 * | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	protected function _trans_rollback() | ||||
| 	{ | ||||
| 		$this->commit_mode = OCI_COMMIT_ON_SUCCESS; | ||||
| 		return oci_rollback($this->conn_id); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Affected Rows | ||||
| 	 * | ||||
| 	 * @return	int | ||||
| 	 */ | ||||
| 	public function affected_rows() | ||||
| 	{ | ||||
| 		return oci_num_rows($this->stmt_id); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Insert ID | ||||
| 	 * | ||||
| 	 * @return	int | ||||
| 	 */ | ||||
| 	public function insert_id() | ||||
| 	{ | ||||
| 		// not supported in oracle | ||||
| 		return $this->display_error('db_unsupported_function'); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Show table query | ||||
| 	 * | ||||
| 	 * Generates a platform-specific query string so that the table names can be fetched | ||||
| 	 * | ||||
| 	 * @param	bool	$prefix_limit | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _list_tables($prefix_limit = FALSE) | ||||
| 	{ | ||||
| 		$sql = 'SELECT "TABLE_NAME" FROM "ALL_TABLES"'; | ||||
|  | ||||
| 		if ($prefix_limit !== FALSE && $this->dbprefix !== '') | ||||
| 		{ | ||||
| 			return $sql.' WHERE "TABLE_NAME" LIKE \''.$this->escape_like_str($this->dbprefix)."%' " | ||||
| 				.sprintf($this->_like_escape_str, $this->_like_escape_chr); | ||||
| 		} | ||||
|  | ||||
| 		return $sql; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Show column query | ||||
| 	 * | ||||
| 	 * Generates a platform-specific query string so that the column names can be fetched | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _list_columns($table = '') | ||||
| 	{ | ||||
| 		if (strpos($table, '.') !== FALSE) | ||||
| 		{ | ||||
| 			sscanf($table, '%[^.].%s', $owner, $table); | ||||
| 		} | ||||
| 		else | ||||
| 		{ | ||||
| 			$owner = $this->username; | ||||
| 		} | ||||
|  | ||||
| 		return 'SELECT COLUMN_NAME FROM ALL_TAB_COLUMNS | ||||
| 			WHERE UPPER(OWNER) = '.$this->escape(strtoupper($owner)).' | ||||
| 				AND UPPER(TABLE_NAME) = '.$this->escape(strtoupper($table)); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Returns an object with field data | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	public function field_data($table) | ||||
| 	{ | ||||
| 		if (strpos($table, '.') !== FALSE) | ||||
| 		{ | ||||
| 			sscanf($table, '%[^.].%s', $owner, $table); | ||||
| 		} | ||||
| 		else | ||||
| 		{ | ||||
| 			$owner = $this->username; | ||||
| 		} | ||||
|  | ||||
| 		$sql = 'SELECT COLUMN_NAME, DATA_TYPE, CHAR_LENGTH, DATA_PRECISION, DATA_LENGTH, DATA_DEFAULT, NULLABLE | ||||
| 			FROM ALL_TAB_COLUMNS | ||||
| 			WHERE UPPER(OWNER) = '.$this->escape(strtoupper($owner)).' | ||||
| 				AND UPPER(TABLE_NAME) = '.$this->escape(strtoupper($table)); | ||||
|  | ||||
| 		if (($query = $this->query($sql)) === FALSE) | ||||
| 		{ | ||||
| 			return FALSE; | ||||
| 		} | ||||
| 		$query = $query->result_object(); | ||||
|  | ||||
| 		$retval = array(); | ||||
| 		for ($i = 0, $c = count($query); $i < $c; $i++) | ||||
| 		{ | ||||
| 			$retval[$i]			= new stdClass(); | ||||
| 			$retval[$i]->name		= $query[$i]->COLUMN_NAME; | ||||
| 			$retval[$i]->type		= $query[$i]->DATA_TYPE; | ||||
|  | ||||
| 			$length = ($query[$i]->CHAR_LENGTH > 0) | ||||
| 				? $query[$i]->CHAR_LENGTH : $query[$i]->DATA_PRECISION; | ||||
| 			if ($length === NULL) | ||||
| 			{ | ||||
| 				$length = $query[$i]->DATA_LENGTH; | ||||
| 			} | ||||
| 			$retval[$i]->max_length		= $length; | ||||
|  | ||||
| 			$default = $query[$i]->DATA_DEFAULT; | ||||
| 			if ($default === NULL && $query[$i]->NULLABLE === 'N') | ||||
| 			{ | ||||
| 				$default = ''; | ||||
| 			} | ||||
| 			$retval[$i]->default = $default; | ||||
| 		} | ||||
|  | ||||
| 		return $retval; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Error | ||||
| 	 * | ||||
| 	 * Returns an array containing code and message of the last | ||||
| 	 * database error that has occurred. | ||||
| 	 * | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	public function error() | ||||
| 	{ | ||||
| 		// oci_error() returns an array that already contains | ||||
| 		// 'code' and 'message' keys, but it can return false | ||||
| 		// if there was no error .... | ||||
| 		if (is_resource($this->curs_id)) | ||||
| 		{ | ||||
| 			$error = oci_error($this->curs_id); | ||||
| 		} | ||||
| 		elseif (is_resource($this->stmt_id)) | ||||
| 		{ | ||||
| 			$error = oci_error($this->stmt_id); | ||||
| 		} | ||||
| 		elseif (is_resource($this->conn_id)) | ||||
| 		{ | ||||
| 			$error = oci_error($this->conn_id); | ||||
| 		} | ||||
| 		else | ||||
| 		{ | ||||
| 			$error = oci_error(); | ||||
| 		} | ||||
|  | ||||
| 		return is_array($error) | ||||
| 			? $error | ||||
| 			: array('code' => '', 'message' => ''); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Insert batch statement | ||||
| 	 * | ||||
| 	 * Generates a platform-specific insert string from the supplied data | ||||
| 	 * | ||||
| 	 * @param	string	$table	Table name | ||||
| 	 * @param	array	$keys	INSERT keys | ||||
| 	 * @param 	array	$values	INSERT values | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _insert_batch($table, $keys, $values) | ||||
| 	{ | ||||
| 		$keys = implode(', ', $keys); | ||||
| 		$sql = "INSERT ALL\n"; | ||||
|  | ||||
| 		for ($i = 0, $c = count($values); $i < $c; $i++) | ||||
| 		{ | ||||
| 			$sql .= '	INTO '.$table.' ('.$keys.') VALUES '.$values[$i]."\n"; | ||||
| 		} | ||||
|  | ||||
| 		return $sql.'SELECT * FROM dual'; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Truncate statement | ||||
| 	 * | ||||
| 	 * Generates a platform-specific truncate string from the supplied data | ||||
| 	 * | ||||
| 	 * If the database does not support the TRUNCATE statement, | ||||
| 	 * then this method maps to 'DELETE FROM table' | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _truncate($table) | ||||
| 	{ | ||||
| 		return 'TRUNCATE TABLE '.$table; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Delete statement | ||||
| 	 * | ||||
| 	 * Generates a platform-specific delete string from the supplied data | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _delete($table) | ||||
| 	{ | ||||
| 		if ($this->qb_limit) | ||||
| 		{ | ||||
| 			$this->where('rownum <= ',$this->qb_limit, FALSE); | ||||
| 			$this->qb_limit = FALSE; | ||||
| 		} | ||||
|  | ||||
| 		return parent::_delete($table); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * LIMIT | ||||
| 	 * | ||||
| 	 * Generates a platform-specific LIMIT clause | ||||
| 	 * | ||||
| 	 * @param	string	$sql	SQL Query | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _limit($sql) | ||||
| 	{ | ||||
| 		if (version_compare($this->version(), '12.1', '>=')) | ||||
| 		{ | ||||
| 			// OFFSET-FETCH can be used only with the ORDER BY clause | ||||
| 			empty($this->qb_orderby) && $sql .= ' ORDER BY 1'; | ||||
|  | ||||
| 			return $sql.' OFFSET '.(int) $this->qb_offset.' ROWS FETCH NEXT '.$this->qb_limit.' ROWS ONLY'; | ||||
| 		} | ||||
|  | ||||
| 		$this->limit_used = TRUE; | ||||
| 		return 'SELECT * FROM (SELECT inner_query.*, rownum rnum FROM ('.$sql.') inner_query WHERE rownum < '.($this->qb_offset + $this->qb_limit + 1).')' | ||||
| 			.($this->qb_offset ? ' WHERE rnum >= '.($this->qb_offset + 1) : ''); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Close DB Connection | ||||
| 	 * | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	protected function _close() | ||||
| 	{ | ||||
| 		oci_close($this->conn_id); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * We need to reset our $limit_used hack flag, so it doesn't propagate | ||||
| 	 * to subsequent queries. | ||||
| 	 * | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	protected function _reset_select() | ||||
| 	{ | ||||
| 		$this->limit_used = FALSE; | ||||
| 		parent::_reset_select(); | ||||
| 	} | ||||
| } | ||||
							
								
								
									
										194
									
								
								system/database/drivers/oci8/oci8_forge.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										194
									
								
								system/database/drivers/oci8/oci8_forge.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,194 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/) | ||||
|  * @license	https://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 1.4.1 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * Oracle Forge Class | ||||
|  * | ||||
|  * @category	Database | ||||
|  * @author		EllisLab Dev Team | ||||
|  * @link		https://codeigniter.com/user_guide/database/ | ||||
|  */ | ||||
| class CI_DB_oci8_forge extends CI_DB_forge { | ||||
|  | ||||
| 	/** | ||||
| 	 * CREATE DATABASE statement | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_create_database	= FALSE; | ||||
|  | ||||
| 	/** | ||||
| 	 * CREATE TABLE IF statement | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_create_table_if	= FALSE; | ||||
|  | ||||
| 	/** | ||||
| 	 * DROP DATABASE statement | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_drop_database	= FALSE; | ||||
|  | ||||
| 	/** | ||||
| 	 * DROP TABLE IF statement | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_drop_table_if	= FALSE; | ||||
|  | ||||
| 	/** | ||||
| 	 * UNSIGNED support | ||||
| 	 * | ||||
| 	 * @var	bool|array | ||||
| 	 */ | ||||
| 	protected $_unsigned		= FALSE; | ||||
|  | ||||
| 	/** | ||||
| 	 * NULL value representation in CREATE/ALTER TABLE statements | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_null		= 'NULL'; | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * ALTER TABLE | ||||
| 	 * | ||||
| 	 * @param	string	$alter_type	ALTER type | ||||
| 	 * @param	string	$table		Table name | ||||
| 	 * @param	mixed	$field		Column definition | ||||
| 	 * @return	string|string[] | ||||
| 	 */ | ||||
| 	protected function _alter_table($alter_type, $table, $field) | ||||
| 	{ | ||||
| 		if ($alter_type === 'DROP') | ||||
| 		{ | ||||
| 			return parent::_alter_table($alter_type, $table, $field); | ||||
| 		} | ||||
| 		elseif ($alter_type === 'CHANGE') | ||||
| 		{ | ||||
| 			$alter_type = 'MODIFY'; | ||||
| 		} | ||||
|  | ||||
| 		$sql = 'ALTER TABLE '.$this->db->escape_identifiers($table); | ||||
| 		$sqls = array(); | ||||
| 		for ($i = 0, $c = count($field); $i < $c; $i++) | ||||
| 		{ | ||||
| 			if ($field[$i]['_literal'] !== FALSE) | ||||
| 			{ | ||||
| 				$field[$i] = "\n\t".$field[$i]['_literal']; | ||||
| 			} | ||||
| 			else | ||||
| 			{ | ||||
| 				$field[$i]['_literal'] = "\n\t".$this->_process_column($field[$i]); | ||||
|  | ||||
| 				if ( ! empty($field[$i]['comment'])) | ||||
| 				{ | ||||
| 					$sqls[] = 'COMMENT ON COLUMN ' | ||||
| 						.$this->db->escape_identifiers($table).'.'.$this->db->escape_identifiers($field[$i]['name']) | ||||
| 						.' IS '.$field[$i]['comment']; | ||||
| 				} | ||||
|  | ||||
| 				if ($alter_type === 'MODIFY' && ! empty($field[$i]['new_name'])) | ||||
| 				{ | ||||
| 					$sqls[] = $sql.' RENAME COLUMN '.$this->db->escape_identifiers($field[$i]['name']) | ||||
| 						.' TO '.$this->db->escape_identifiers($field[$i]['new_name']); | ||||
| 				} | ||||
|  | ||||
| 				$field[$i] = "\n\t".$field[$i]['_literal']; | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		$sql .= ' '.$alter_type.' '; | ||||
| 		$sql .= (count($field) === 1) | ||||
| 				? $field[0] | ||||
| 				: '('.implode(',', $field).')'; | ||||
|  | ||||
| 		// RENAME COLUMN must be executed after MODIFY | ||||
| 		array_unshift($sqls, $sql); | ||||
| 		return $sqls; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Field attribute AUTO_INCREMENT | ||||
| 	 * | ||||
| 	 * @param	array	&$attributes | ||||
| 	 * @param	array	&$field | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	protected function _attr_auto_increment(&$attributes, &$field) | ||||
| 	{ | ||||
| 		// Not supported - sequences and triggers must be used instead | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Field attribute TYPE | ||||
| 	 * | ||||
| 	 * Performs a data type mapping between different databases. | ||||
| 	 * | ||||
| 	 * @param	array	&$attributes | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	protected function _attr_type(&$attributes) | ||||
| 	{ | ||||
| 		switch (strtoupper($attributes['TYPE'])) | ||||
| 		{ | ||||
| 			case 'TINYINT': | ||||
| 				$attributes['TYPE'] = 'NUMBER'; | ||||
| 				return; | ||||
| 			case 'MEDIUMINT': | ||||
| 				$attributes['TYPE'] = 'NUMBER'; | ||||
| 				return; | ||||
| 			case 'INT': | ||||
| 				$attributes['TYPE'] = 'NUMBER'; | ||||
| 				return; | ||||
| 			case 'BIGINT': | ||||
| 				$attributes['TYPE'] = 'NUMBER'; | ||||
| 				return; | ||||
| 			default: return; | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
							
								
								
									
										229
									
								
								system/database/drivers/oci8/oci8_result.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										229
									
								
								system/database/drivers/oci8/oci8_result.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,229 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/) | ||||
|  * @license	https://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 1.4.1 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * oci8 Result Class | ||||
|  * | ||||
|  * This class extends the parent result class: CI_DB_result | ||||
|  * | ||||
|  * @category	Database | ||||
|  * @author		EllisLab Dev Team | ||||
|  * @link		https://codeigniter.com/user_guide/database/ | ||||
|  */ | ||||
| class CI_DB_oci8_result extends CI_DB_result { | ||||
|  | ||||
| 	/** | ||||
| 	 * Statement ID | ||||
| 	 * | ||||
| 	 * @var	resource | ||||
| 	 */ | ||||
| 	public $stmt_id; | ||||
|  | ||||
| 	/** | ||||
| 	 * Cursor ID | ||||
| 	 * | ||||
| 	 * @var	resource | ||||
| 	 */ | ||||
| 	public $curs_id; | ||||
|  | ||||
| 	/** | ||||
| 	 * Limit used flag | ||||
| 	 * | ||||
| 	 * @var	bool | ||||
| 	 */ | ||||
| 	public $limit_used; | ||||
|  | ||||
| 	/** | ||||
| 	 * Commit mode flag | ||||
| 	 * | ||||
| 	 * @var	int | ||||
| 	 */ | ||||
| 	public $commit_mode; | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Class constructor | ||||
| 	 * | ||||
| 	 * @param	object	&$driver_object | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	public function __construct(&$driver_object) | ||||
| 	{ | ||||
| 		parent::__construct($driver_object); | ||||
|  | ||||
| 		$this->stmt_id = $driver_object->stmt_id; | ||||
| 		$this->curs_id = $driver_object->curs_id; | ||||
| 		$this->limit_used = $driver_object->limit_used; | ||||
| 		$this->commit_mode =& $driver_object->commit_mode; | ||||
| 		$driver_object->stmt_id = FALSE; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Number of fields in the result set | ||||
| 	 * | ||||
| 	 * @return	int | ||||
| 	 */ | ||||
| 	public function num_fields() | ||||
| 	{ | ||||
| 		$count = oci_num_fields($this->stmt_id); | ||||
|  | ||||
| 		// if we used a limit we subtract it | ||||
| 		return ($this->limit_used) ? $count - 1 : $count; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Fetch Field Names | ||||
| 	 * | ||||
| 	 * Generates an array of column names | ||||
| 	 * | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	public function list_fields() | ||||
| 	{ | ||||
| 		$field_names = array(); | ||||
| 		for ($c = 1, $fieldCount = $this->num_fields(); $c <= $fieldCount; $c++) | ||||
| 		{ | ||||
| 			$field_names[] = oci_field_name($this->stmt_id, $c); | ||||
| 		} | ||||
| 		return $field_names; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Field data | ||||
| 	 * | ||||
| 	 * Generates an array of objects containing field meta-data | ||||
| 	 * | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	public function field_data() | ||||
| 	{ | ||||
| 		$retval = array(); | ||||
| 		for ($c = 1, $fieldCount = $this->num_fields(); $c <= $fieldCount; $c++) | ||||
| 		{ | ||||
| 			$F		= new stdClass(); | ||||
| 			$F->name	= oci_field_name($this->stmt_id, $c); | ||||
| 			$F->type	= oci_field_type($this->stmt_id, $c); | ||||
| 			$F->max_length	= oci_field_size($this->stmt_id, $c); | ||||
|  | ||||
| 			$retval[] = $F; | ||||
| 		} | ||||
|  | ||||
| 		return $retval; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Free the result | ||||
| 	 * | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	public function free_result() | ||||
| 	{ | ||||
| 		if (is_resource($this->result_id)) | ||||
| 		{ | ||||
| 			oci_free_statement($this->result_id); | ||||
| 			$this->result_id = FALSE; | ||||
| 		} | ||||
|  | ||||
| 		if (is_resource($this->stmt_id)) | ||||
| 		{ | ||||
| 			oci_free_statement($this->stmt_id); | ||||
| 		} | ||||
|  | ||||
| 		if (is_resource($this->curs_id)) | ||||
| 		{ | ||||
| 			oci_cancel($this->curs_id); | ||||
| 			$this->curs_id = NULL; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Result - associative array | ||||
| 	 * | ||||
| 	 * Returns the result set as an array | ||||
| 	 * | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	protected function _fetch_assoc() | ||||
| 	{ | ||||
| 		$id = ($this->curs_id) ? $this->curs_id : $this->stmt_id; | ||||
| 		return oci_fetch_assoc($id); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Result - object | ||||
| 	 * | ||||
| 	 * Returns the result set as an object | ||||
| 	 * | ||||
| 	 * @param	string	$class_name | ||||
| 	 * @return	object | ||||
| 	 */ | ||||
| 	protected function _fetch_object($class_name = 'stdClass') | ||||
| 	{ | ||||
| 		$row = ($this->curs_id) | ||||
| 			? oci_fetch_object($this->curs_id) | ||||
| 			: oci_fetch_object($this->stmt_id); | ||||
|  | ||||
| 		if ($class_name === 'stdClass' OR ! $row) | ||||
| 		{ | ||||
| 			return $row; | ||||
| 		} | ||||
|  | ||||
| 		$class_name = new $class_name(); | ||||
| 		foreach ($row as $key => $value) | ||||
| 		{ | ||||
| 			$class_name->$key = $value; | ||||
| 		} | ||||
|  | ||||
| 		return $class_name; | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										68
									
								
								system/database/drivers/oci8/oci8_utility.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										68
									
								
								system/database/drivers/oci8/oci8_utility.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,68 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/) | ||||
|  * @license	https://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 1.4.1 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * Oracle Utility Class | ||||
|  * | ||||
|  * @category	Database | ||||
|  * @author		EllisLab Dev Team | ||||
|  * @link		https://codeigniter.com/user_guide/database/ | ||||
|  */ | ||||
| class CI_DB_oci8_utility extends CI_DB_utility { | ||||
|  | ||||
| 	/** | ||||
| 	 * List databases statement | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_list_databases	= 'SELECT username FROM dba_users'; // Schemas are actual usernames | ||||
|  | ||||
| 	/** | ||||
| 	 * Export | ||||
| 	 * | ||||
| 	 * @param	array	$params	Preferences | ||||
| 	 * @return	mixed | ||||
| 	 */ | ||||
| 	protected function _backup($params = array()) | ||||
| 	{ | ||||
| 		// Currently unsupported | ||||
| 		return $this->db->display_error('db_unsupported_feature'); | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										11
									
								
								system/database/drivers/odbc/index.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								system/database/drivers/odbc/index.html
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,11 @@ | ||||
| <!DOCTYPE html> | ||||
| <html> | ||||
| <head> | ||||
| 	<title>403 Forbidden</title> | ||||
| </head> | ||||
| <body> | ||||
|  | ||||
| <p>Directory access is forbidden.</p> | ||||
|  | ||||
| </body> | ||||
| </html> | ||||
							
								
								
									
										425
									
								
								system/database/drivers/odbc/odbc_driver.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										425
									
								
								system/database/drivers/odbc/odbc_driver.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,425 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/) | ||||
|  * @license	https://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 1.3.0 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * ODBC Database Adapter Class | ||||
|  * | ||||
|  * Note: _DB is an extender class that the app controller | ||||
|  * creates dynamically based on whether the query builder | ||||
|  * class is being used or not. | ||||
|  * | ||||
|  * @package		CodeIgniter | ||||
|  * @subpackage	Drivers | ||||
|  * @category	Database | ||||
|  * @author		EllisLab Dev Team | ||||
|  * @link		https://codeigniter.com/user_guide/database/ | ||||
|  */ | ||||
| class CI_DB_odbc_driver extends CI_DB_driver { | ||||
|  | ||||
| 	/** | ||||
| 	 * Database driver | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	public $dbdriver = 'odbc'; | ||||
|  | ||||
| 	/** | ||||
| 	 * Database schema | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	public $schema = 'public'; | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Identifier escape character | ||||
| 	 * | ||||
| 	 * Must be empty for ODBC. | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_escape_char = ''; | ||||
|  | ||||
| 	/** | ||||
| 	 * ESCAPE statement string | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_like_escape_str = " {escape '%s'} "; | ||||
|  | ||||
| 	/** | ||||
| 	 * ORDER BY random keyword | ||||
| 	 * | ||||
| 	 * @var	array | ||||
| 	 */ | ||||
| 	protected $_random_keyword = array('RND()', 'RND(%d)'); | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * ODBC result ID resource returned from odbc_prepare() | ||||
| 	 * | ||||
| 	 * @var	resource | ||||
| 	 */ | ||||
| 	private $odbc_result; | ||||
|  | ||||
| 	/** | ||||
| 	 * Values to use with odbc_execute() for prepared statements | ||||
| 	 * | ||||
| 	 * @var	array | ||||
| 	 */ | ||||
| 	private $binds = array(); | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Class constructor | ||||
| 	 * | ||||
| 	 * @param	array	$params | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	public function __construct($params) | ||||
| 	{ | ||||
| 		parent::__construct($params); | ||||
|  | ||||
| 		// Legacy support for DSN in the hostname field | ||||
| 		if (empty($this->dsn)) | ||||
| 		{ | ||||
| 			$this->dsn = $this->hostname; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Non-persistent database connection | ||||
| 	 * | ||||
| 	 * @param	bool	$persistent | ||||
| 	 * @return	resource | ||||
| 	 */ | ||||
| 	public function db_connect($persistent = FALSE) | ||||
| 	{ | ||||
| 		return ($persistent === TRUE) | ||||
| 			? odbc_pconnect($this->dsn, $this->username, $this->password) | ||||
| 			: odbc_connect($this->dsn, $this->username, $this->password); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Compile Bindings | ||||
| 	 * | ||||
| 	 * @param	string	$sql	SQL statement | ||||
| 	 * @param	array	$binds	An array of values to bind | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	public function compile_binds($sql, $binds) | ||||
| 	{ | ||||
| 		if (empty($binds) OR empty($this->bind_marker) OR strpos($sql, $this->bind_marker) === FALSE) | ||||
| 		{ | ||||
| 			return $sql; | ||||
| 		} | ||||
| 		elseif ( ! is_array($binds)) | ||||
| 		{ | ||||
| 			$binds = array($binds); | ||||
| 			$bind_count = 1; | ||||
| 		} | ||||
| 		else | ||||
| 		{ | ||||
| 			// Make sure we're using numeric keys | ||||
| 			$binds = array_values($binds); | ||||
| 			$bind_count = count($binds); | ||||
| 		} | ||||
|  | ||||
| 		// We'll need the marker length later | ||||
| 		$ml = strlen($this->bind_marker); | ||||
|  | ||||
| 		// Make sure not to replace a chunk inside a string that happens to match the bind marker | ||||
| 		if ($c = preg_match_all("/'[^']*'|\"[^\"]*\"/i", $sql, $matches)) | ||||
| 		{ | ||||
| 			$c = preg_match_all('/'.preg_quote($this->bind_marker, '/').'/i', | ||||
| 				str_replace($matches[0], | ||||
| 					str_replace($this->bind_marker, str_repeat(' ', $ml), $matches[0]), | ||||
| 					$sql, $c), | ||||
| 				$matches, PREG_OFFSET_CAPTURE); | ||||
|  | ||||
| 			// Bind values' count must match the count of markers in the query | ||||
| 			if ($bind_count !== $c) | ||||
| 			{ | ||||
| 				return $sql; | ||||
| 			} | ||||
| 		} | ||||
| 		elseif (($c = preg_match_all('/'.preg_quote($this->bind_marker, '/').'/i', $sql, $matches, PREG_OFFSET_CAPTURE)) !== $bind_count) | ||||
| 		{ | ||||
| 			return $sql; | ||||
| 		} | ||||
|  | ||||
| 		if ($this->bind_marker !== '?') | ||||
| 		{ | ||||
| 			do | ||||
| 			{ | ||||
| 				$c--; | ||||
| 				$sql = substr_replace($sql, '?', $matches[0][$c][1], $ml); | ||||
| 			} | ||||
| 			while ($c !== 0); | ||||
| 		} | ||||
|  | ||||
| 		if (FALSE !== ($this->odbc_result = odbc_prepare($this->conn_id, $sql))) | ||||
| 		{ | ||||
| 			$this->binds = array_values($binds); | ||||
| 		} | ||||
|  | ||||
| 		return $sql; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Execute the query | ||||
| 	 * | ||||
| 	 * @param	string	$sql	an SQL query | ||||
| 	 * @return	resource | ||||
| 	 */ | ||||
| 	protected function _execute($sql) | ||||
| 	{ | ||||
| 		if ( ! isset($this->odbc_result)) | ||||
| 		{ | ||||
| 			return odbc_exec($this->conn_id, $sql); | ||||
| 		} | ||||
| 		elseif ($this->odbc_result === FALSE) | ||||
| 		{ | ||||
| 			return FALSE; | ||||
| 		} | ||||
|  | ||||
| 		if (TRUE === ($success = odbc_execute($this->odbc_result, $this->binds))) | ||||
| 		{ | ||||
| 			// For queries that return result sets, return the result_id resource on success | ||||
| 			$this->is_write_type($sql) OR $success = $this->odbc_result; | ||||
| 		} | ||||
|  | ||||
| 		$this->odbc_result = NULL; | ||||
| 		$this->binds       = array(); | ||||
|  | ||||
| 		return $success; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Begin Transaction | ||||
| 	 * | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	protected function _trans_begin() | ||||
| 	{ | ||||
| 		return odbc_autocommit($this->conn_id, FALSE); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Commit Transaction | ||||
| 	 * | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	protected function _trans_commit() | ||||
| 	{ | ||||
| 		if (odbc_commit($this->conn_id)) | ||||
| 		{ | ||||
| 			odbc_autocommit($this->conn_id, TRUE); | ||||
| 			return TRUE; | ||||
| 		} | ||||
|  | ||||
| 		return FALSE; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Rollback Transaction | ||||
| 	 * | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	protected function _trans_rollback() | ||||
| 	{ | ||||
| 		if (odbc_rollback($this->conn_id)) | ||||
| 		{ | ||||
| 			odbc_autocommit($this->conn_id, TRUE); | ||||
| 			return TRUE; | ||||
| 		} | ||||
|  | ||||
| 		return FALSE; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Determines if a query is a "write" type. | ||||
| 	 * | ||||
| 	 * @param	string	An SQL query string | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	public function is_write_type($sql) | ||||
| 	{ | ||||
| 		if (preg_match('#^(INSERT|UPDATE).*RETURNING\s.+(\,\s?.+)*$#is', $sql)) | ||||
| 		{ | ||||
| 			return FALSE; | ||||
| 		} | ||||
|  | ||||
| 		return parent::is_write_type($sql); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Platform-dependent string escape | ||||
| 	 * | ||||
| 	 * @param	string | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _escape_str($str) | ||||
| 	{ | ||||
| 		$this->display_error('db_unsupported_feature'); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Affected Rows | ||||
| 	 * | ||||
| 	 * @return	int | ||||
| 	 */ | ||||
| 	public function affected_rows() | ||||
| 	{ | ||||
| 		return odbc_num_rows($this->result_id); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Insert ID | ||||
| 	 * | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	public function insert_id() | ||||
| 	{ | ||||
| 		return ($this->db_debug) ? $this->display_error('db_unsupported_feature') : FALSE; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Show table query | ||||
| 	 * | ||||
| 	 * Generates a platform-specific query string so that the table names can be fetched | ||||
| 	 * | ||||
| 	 * @param	bool	$prefix_limit | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _list_tables($prefix_limit = FALSE) | ||||
| 	{ | ||||
| 		$sql = "SELECT table_name FROM information_schema.tables WHERE table_schema = '".$this->schema."'"; | ||||
|  | ||||
| 		if ($prefix_limit !== FALSE && $this->dbprefix !== '') | ||||
| 		{ | ||||
| 			return $sql." AND table_name LIKE '".$this->escape_like_str($this->dbprefix)."%' " | ||||
| 				.sprintf($this->_like_escape_str, $this->_like_escape_chr); | ||||
| 		} | ||||
|  | ||||
| 		return $sql; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Show column query | ||||
| 	 * | ||||
| 	 * Generates a platform-specific query string so that the column names can be fetched | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _list_columns($table = '') | ||||
| 	{ | ||||
| 		return 'SHOW COLUMNS FROM '.$table; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Field data query | ||||
| 	 * | ||||
| 	 * Generates a platform-specific query so that the column data can be retrieved | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _field_data($table) | ||||
| 	{ | ||||
| 		return 'SELECT TOP 1 FROM '.$table; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Error | ||||
| 	 * | ||||
| 	 * Returns an array containing code and message of the last | ||||
| 	 * database error that has occurred. | ||||
| 	 * | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	public function error() | ||||
| 	{ | ||||
| 		return array('code' => odbc_error($this->conn_id), 'message' => odbc_errormsg($this->conn_id)); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Close DB Connection | ||||
| 	 * | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	protected function _close() | ||||
| 	{ | ||||
| 		odbc_close($this->conn_id); | ||||
| 	} | ||||
| } | ||||
							
								
								
									
										86
									
								
								system/database/drivers/odbc/odbc_forge.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										86
									
								
								system/database/drivers/odbc/odbc_forge.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,86 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/) | ||||
|  * @license	https://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 1.3.0 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * ODBC Forge Class | ||||
|  * | ||||
|  * @package		CodeIgniter | ||||
|  * @subpackage	Drivers | ||||
|  * @category	Database | ||||
|  * @author		EllisLab Dev Team | ||||
|  * @link		https://codeigniter.com/database/ | ||||
|  */ | ||||
| class CI_DB_odbc_forge extends CI_DB_forge { | ||||
|  | ||||
| 	/** | ||||
| 	 * CREATE TABLE IF statement | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_create_table_if	= FALSE; | ||||
|  | ||||
| 	/** | ||||
| 	 * DROP TABLE IF statement | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_drop_table_if	= FALSE; | ||||
|  | ||||
| 	/** | ||||
| 	 * UNSIGNED support | ||||
| 	 * | ||||
| 	 * @var	bool|array | ||||
| 	 */ | ||||
| 	protected $_unsigned		= FALSE; | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Field attribute AUTO_INCREMENT | ||||
| 	 * | ||||
| 	 * @param	array	&$attributes | ||||
| 	 * @param	array	&$field | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	protected function _attr_auto_increment(&$attributes, &$field) | ||||
| 	{ | ||||
| 		// Not supported (in most databases at least) | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										268
									
								
								system/database/drivers/odbc/odbc_result.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										268
									
								
								system/database/drivers/odbc/odbc_result.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,268 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/) | ||||
|  * @license	https://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 1.3.0 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * ODBC Result Class | ||||
|  * | ||||
|  * This class extends the parent result class: CI_DB_result | ||||
|  * | ||||
|  * @package		CodeIgniter | ||||
|  * @subpackage	Drivers | ||||
|  * @category	Database | ||||
|  * @author		EllisLab Dev Team | ||||
|  * @link		https://codeigniter.com/user_guide/database/ | ||||
|  */ | ||||
| class CI_DB_odbc_result extends CI_DB_result { | ||||
|  | ||||
| 	/** | ||||
| 	 * Number of rows in the result set | ||||
| 	 * | ||||
| 	 * @return	int | ||||
| 	 */ | ||||
| 	public function num_rows() | ||||
| 	{ | ||||
| 		if (is_int($this->num_rows)) | ||||
| 		{ | ||||
| 			return $this->num_rows; | ||||
| 		} | ||||
| 		elseif (($this->num_rows = odbc_num_rows($this->result_id)) !== -1) | ||||
| 		{ | ||||
| 			return $this->num_rows; | ||||
| 		} | ||||
|  | ||||
| 		// Work-around for ODBC subdrivers that don't support num_rows() | ||||
| 		if (count($this->result_array) > 0) | ||||
| 		{ | ||||
| 			return $this->num_rows = count($this->result_array); | ||||
| 		} | ||||
| 		elseif (count($this->result_object) > 0) | ||||
| 		{ | ||||
| 			return $this->num_rows = count($this->result_object); | ||||
| 		} | ||||
|  | ||||
| 		return $this->num_rows = count($this->result_array()); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Number of fields in the result set | ||||
| 	 * | ||||
| 	 * @return	int | ||||
| 	 */ | ||||
| 	public function num_fields() | ||||
| 	{ | ||||
| 		return odbc_num_fields($this->result_id); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Fetch Field Names | ||||
| 	 * | ||||
| 	 * Generates an array of column names | ||||
| 	 * | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	public function list_fields() | ||||
| 	{ | ||||
| 		$field_names = array(); | ||||
| 		$num_fields = $this->num_fields(); | ||||
|  | ||||
| 		if ($num_fields > 0) | ||||
| 		{ | ||||
| 			for ($i = 1; $i <= $num_fields; $i++) | ||||
| 			{ | ||||
| 				$field_names[] = odbc_field_name($this->result_id, $i); | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		return $field_names; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Field data | ||||
| 	 * | ||||
| 	 * Generates an array of objects containing field meta-data | ||||
| 	 * | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	public function field_data() | ||||
| 	{ | ||||
| 		$retval = array(); | ||||
| 		for ($i = 0, $odbc_index = 1, $c = $this->num_fields(); $i < $c; $i++, $odbc_index++) | ||||
| 		{ | ||||
| 			$retval[$i]			= new stdClass(); | ||||
| 			$retval[$i]->name		= odbc_field_name($this->result_id, $odbc_index); | ||||
| 			$retval[$i]->type		= odbc_field_type($this->result_id, $odbc_index); | ||||
| 			$retval[$i]->max_length		= odbc_field_len($this->result_id, $odbc_index); | ||||
| 			$retval[$i]->primary_key	= 0; | ||||
| 			$retval[$i]->default		= ''; | ||||
| 		} | ||||
|  | ||||
| 		return $retval; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Free the result | ||||
| 	 * | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	public function free_result() | ||||
| 	{ | ||||
| 		if (is_resource($this->result_id)) | ||||
| 		{ | ||||
| 			odbc_free_result($this->result_id); | ||||
| 			$this->result_id = FALSE; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Result - associative array | ||||
| 	 * | ||||
| 	 * Returns the result set as an array | ||||
| 	 * | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	protected function _fetch_assoc() | ||||
| 	{ | ||||
| 		return odbc_fetch_array($this->result_id); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Result - object | ||||
| 	 * | ||||
| 	 * Returns the result set as an object | ||||
| 	 * | ||||
| 	 * @param	string	$class_name | ||||
| 	 * @return	object | ||||
| 	 */ | ||||
| 	protected function _fetch_object($class_name = 'stdClass') | ||||
| 	{ | ||||
| 		$row = odbc_fetch_object($this->result_id); | ||||
|  | ||||
| 		if ($class_name === 'stdClass' OR ! $row) | ||||
| 		{ | ||||
| 			return $row; | ||||
| 		} | ||||
|  | ||||
| 		$class_name = new $class_name(); | ||||
| 		foreach ($row as $key => $value) | ||||
| 		{ | ||||
| 			$class_name->$key = $value; | ||||
| 		} | ||||
|  | ||||
| 		return $class_name; | ||||
| 	} | ||||
|  | ||||
| } | ||||
|  | ||||
| // -------------------------------------------------------------------- | ||||
|  | ||||
| if ( ! function_exists('odbc_fetch_array')) | ||||
| { | ||||
| 	/** | ||||
| 	 * ODBC Fetch array | ||||
| 	 * | ||||
| 	 * Emulates the native odbc_fetch_array() function when | ||||
| 	 * it is not available (odbc_fetch_array() requires unixODBC) | ||||
| 	 * | ||||
| 	 * @param	resource	&$result | ||||
| 	 * @param	int		$rownumber | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	function odbc_fetch_array(&$result, $rownumber = 1) | ||||
| 	{ | ||||
| 		$rs = array(); | ||||
| 		if ( ! odbc_fetch_into($result, $rs, $rownumber)) | ||||
| 		{ | ||||
| 			return FALSE; | ||||
| 		} | ||||
|  | ||||
| 		$rs_assoc = array(); | ||||
| 		foreach ($rs as $k => $v) | ||||
| 		{ | ||||
| 			$field_name = odbc_field_name($result, $k+1); | ||||
| 			$rs_assoc[$field_name] = $v; | ||||
| 		} | ||||
|  | ||||
| 		return $rs_assoc; | ||||
| 	} | ||||
| } | ||||
|  | ||||
| // -------------------------------------------------------------------- | ||||
|  | ||||
| if ( ! function_exists('odbc_fetch_object')) | ||||
| { | ||||
| 	/** | ||||
| 	 * ODBC Fetch object | ||||
| 	 * | ||||
| 	 * Emulates the native odbc_fetch_object() function when | ||||
| 	 * it is not available. | ||||
| 	 * | ||||
| 	 * @param	resource	&$result | ||||
| 	 * @param	int		$rownumber | ||||
| 	 * @return	object | ||||
| 	 */ | ||||
| 	function odbc_fetch_object(&$result, $rownumber = 1) | ||||
| 	{ | ||||
| 		$rs = array(); | ||||
| 		if ( ! odbc_fetch_into($result, $rs, $rownumber)) | ||||
| 		{ | ||||
| 			return FALSE; | ||||
| 		} | ||||
|  | ||||
| 		$rs_object = new stdClass(); | ||||
| 		foreach ($rs as $k => $v) | ||||
| 		{ | ||||
| 			$field_name = odbc_field_name($result, $k+1); | ||||
| 			$rs_object->$field_name = $v; | ||||
| 		} | ||||
|  | ||||
| 		return $rs_object; | ||||
| 	} | ||||
| } | ||||
							
								
								
									
										63
									
								
								system/database/drivers/odbc/odbc_utility.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										63
									
								
								system/database/drivers/odbc/odbc_utility.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,63 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/) | ||||
|  * @license	https://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 1.3.0 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * ODBC Utility Class | ||||
|  * | ||||
|  * @package		CodeIgniter | ||||
|  * @subpackage	Drivers | ||||
|  * @category	Database | ||||
|  * @author		EllisLab Dev Team | ||||
|  * @link		https://codeigniter.com/database/ | ||||
|  */ | ||||
| class CI_DB_odbc_utility extends CI_DB_utility { | ||||
|  | ||||
| 	/** | ||||
| 	 * Export | ||||
| 	 * | ||||
| 	 * @param	array	$params	Preferences | ||||
| 	 * @return	mixed | ||||
| 	 */ | ||||
| 	protected function _backup($params = array()) | ||||
| 	{ | ||||
| 		// Currently unsupported | ||||
| 		return $this->db->display_error('db_unsupported_feature'); | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										11
									
								
								system/database/drivers/pdo/index.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								system/database/drivers/pdo/index.html
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,11 @@ | ||||
| <!DOCTYPE html> | ||||
| <html> | ||||
| <head> | ||||
| 	<title>403 Forbidden</title> | ||||
| </head> | ||||
| <body> | ||||
|  | ||||
| <p>Directory access is forbidden.</p> | ||||
|  | ||||
| </body> | ||||
| </html> | ||||
							
								
								
									
										329
									
								
								system/database/drivers/pdo/pdo_driver.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										329
									
								
								system/database/drivers/pdo/pdo_driver.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,329 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/) | ||||
|  * @license	https://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 2.1.0 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * PDO Database Adapter Class | ||||
|  * | ||||
|  * Note: _DB is an extender class that the app controller | ||||
|  * creates dynamically based on whether the query builder | ||||
|  * class is being used or not. | ||||
|  * | ||||
|  * @package		CodeIgniter | ||||
|  * @subpackage	Drivers | ||||
|  * @category	Database | ||||
|  * @author		EllisLab Dev Team | ||||
|  * @link		https://codeigniter.com/user_guide/database/ | ||||
|  */ | ||||
| class CI_DB_pdo_driver extends CI_DB { | ||||
|  | ||||
| 	/** | ||||
| 	 * Database driver | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	public $dbdriver = 'pdo'; | ||||
|  | ||||
| 	/** | ||||
| 	 * PDO Options | ||||
| 	 * | ||||
| 	 * @var	array | ||||
| 	 */ | ||||
| 	public $options = array(); | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Class constructor | ||||
| 	 * | ||||
| 	 * Validates the DSN string and/or detects the subdriver. | ||||
| 	 * | ||||
| 	 * @param	array	$params | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	public function __construct($params) | ||||
| 	{ | ||||
| 		parent::__construct($params); | ||||
|  | ||||
| 		if (preg_match('/([^:]+):/', $this->dsn, $match) && count($match) === 2) | ||||
| 		{ | ||||
| 			// If there is a minimum valid dsn string pattern found, we're done | ||||
| 			// This is for general PDO users, who tend to have a full DSN string. | ||||
| 			$this->subdriver = $match[1]; | ||||
| 			return; | ||||
| 		} | ||||
| 		// Legacy support for DSN specified in the hostname field | ||||
| 		elseif (preg_match('/([^:]+):/', $this->hostname, $match) && count($match) === 2) | ||||
| 		{ | ||||
| 			$this->dsn = $this->hostname; | ||||
| 			$this->hostname = NULL; | ||||
| 			$this->subdriver = $match[1]; | ||||
| 			return; | ||||
| 		} | ||||
| 		elseif (in_array($this->subdriver, array('mssql', 'sybase'), TRUE)) | ||||
| 		{ | ||||
| 			$this->subdriver = 'dblib'; | ||||
| 		} | ||||
| 		elseif ($this->subdriver === '4D') | ||||
| 		{ | ||||
| 			$this->subdriver = '4d'; | ||||
| 		} | ||||
| 		elseif ( ! in_array($this->subdriver, array('4d', 'cubrid', 'dblib', 'firebird', 'ibm', 'informix', 'mysql', 'oci', 'odbc', 'pgsql', 'sqlite', 'sqlsrv'), TRUE)) | ||||
| 		{ | ||||
| 			log_message('error', 'PDO: Invalid or non-existent subdriver'); | ||||
|  | ||||
| 			if ($this->db_debug) | ||||
| 			{ | ||||
| 				show_error('Invalid or non-existent PDO subdriver'); | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		$this->dsn = NULL; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Database connection | ||||
| 	 * | ||||
| 	 * @param	bool	$persistent | ||||
| 	 * @return	object | ||||
| 	 */ | ||||
| 	public function db_connect($persistent = FALSE) | ||||
| 	{ | ||||
| 		if ($persistent === TRUE) | ||||
| 		{ | ||||
| 			$this->options[PDO::ATTR_PERSISTENT] = TRUE; | ||||
| 		} | ||||
|  | ||||
| 		try | ||||
| 		{ | ||||
| 			return new PDO($this->dsn, $this->username, $this->password, $this->options); | ||||
| 		} | ||||
| 		catch (PDOException $e) | ||||
| 		{ | ||||
| 			if ($this->db_debug && empty($this->failover)) | ||||
| 			{ | ||||
| 				$this->display_error($e->getMessage(), '', TRUE); | ||||
| 			} | ||||
|  | ||||
| 			return FALSE; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Database version number | ||||
| 	 * | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	public function version() | ||||
| 	{ | ||||
| 		if (isset($this->data_cache['version'])) | ||||
| 		{ | ||||
| 			return $this->data_cache['version']; | ||||
| 		} | ||||
|  | ||||
| 		// Not all subdrivers support the getAttribute() method | ||||
| 		try | ||||
| 		{ | ||||
| 			return $this->data_cache['version'] = $this->conn_id->getAttribute(PDO::ATTR_SERVER_VERSION); | ||||
| 		} | ||||
| 		catch (PDOException $e) | ||||
| 		{ | ||||
| 			return parent::version(); | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Execute the query | ||||
| 	 * | ||||
| 	 * @param	string	$sql	SQL query | ||||
| 	 * @return	mixed | ||||
| 	 */ | ||||
| 	protected function _execute($sql) | ||||
| 	{ | ||||
| 		return $this->conn_id->query($sql); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Begin Transaction | ||||
| 	 * | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	protected function _trans_begin() | ||||
| 	{ | ||||
| 		return $this->conn_id->beginTransaction(); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Commit Transaction | ||||
| 	 * | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	protected function _trans_commit() | ||||
| 	{ | ||||
| 		return $this->conn_id->commit(); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Rollback Transaction | ||||
| 	 * | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	protected function _trans_rollback() | ||||
| 	{ | ||||
| 		return $this->conn_id->rollBack(); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Platform-dependent string escape | ||||
| 	 * | ||||
| 	 * @param	string | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _escape_str($str) | ||||
| 	{ | ||||
| 		// Escape the string | ||||
| 		$str = $this->conn_id->quote($str); | ||||
|  | ||||
| 		// If there are duplicated quotes, trim them away | ||||
| 		return ($str[0] === "'") | ||||
| 			? substr($str, 1, -1) | ||||
| 			: $str; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Affected Rows | ||||
| 	 * | ||||
| 	 * @return	int | ||||
| 	 */ | ||||
| 	public function affected_rows() | ||||
| 	{ | ||||
| 		return is_object($this->result_id) ? $this->result_id->rowCount() : 0; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Insert ID | ||||
| 	 * | ||||
| 	 * @param	string	$name | ||||
| 	 * @return	int | ||||
| 	 */ | ||||
| 	public function insert_id($name = NULL) | ||||
| 	{ | ||||
| 		return $this->conn_id->lastInsertId($name); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Field data query | ||||
| 	 * | ||||
| 	 * Generates a platform-specific query so that the column data can be retrieved | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _field_data($table) | ||||
| 	{ | ||||
| 		return 'SELECT TOP 1 * FROM '.$this->protect_identifiers($table); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Error | ||||
| 	 * | ||||
| 	 * Returns an array containing code and message of the last | ||||
| 	 * database error that has occurred. | ||||
| 	 * | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	public function error() | ||||
| 	{ | ||||
| 		$error = array('code' => '00000', 'message' => ''); | ||||
| 		$pdo_error = $this->conn_id->errorInfo(); | ||||
|  | ||||
| 		if (empty($pdo_error[0])) | ||||
| 		{ | ||||
| 			return $error; | ||||
| 		} | ||||
|  | ||||
| 		$error['code'] = isset($pdo_error[1]) ? $pdo_error[0].'/'.$pdo_error[1] : $pdo_error[0]; | ||||
| 		if (isset($pdo_error[2])) | ||||
| 		{ | ||||
| 			 $error['message'] = $pdo_error[2]; | ||||
| 		} | ||||
|  | ||||
| 		return $error; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Truncate statement | ||||
| 	 * | ||||
| 	 * Generates a platform-specific truncate string from the supplied data | ||||
| 	 * | ||||
| 	 * If the database does not support the TRUNCATE statement, | ||||
| 	 * then this method maps to 'DELETE FROM table' | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _truncate($table) | ||||
| 	{ | ||||
| 		return 'TRUNCATE TABLE '.$table; | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										65
									
								
								system/database/drivers/pdo/pdo_forge.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										65
									
								
								system/database/drivers/pdo/pdo_forge.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,65 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/) | ||||
|  * @license	https://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 2.1.0 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * PDO Forge Class | ||||
|  * | ||||
|  * @package		CodeIgniter | ||||
|  * @subpackage	Drivers | ||||
|  * @category	Database | ||||
|  * @author		EllisLab Dev Team | ||||
|  * @link		https://codeigniter.com/database/ | ||||
|  */ | ||||
| class CI_DB_pdo_forge extends CI_DB_forge { | ||||
|  | ||||
| 	/** | ||||
| 	 * CREATE TABLE IF statement | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_create_table_if	= FALSE; | ||||
|  | ||||
| 	/** | ||||
| 	 * DROP TABLE IF statement | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_drop_table_if	= FALSE; | ||||
|  | ||||
| } | ||||
							
								
								
									
										198
									
								
								system/database/drivers/pdo/pdo_result.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										198
									
								
								system/database/drivers/pdo/pdo_result.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,198 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/) | ||||
|  * @license	https://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 2.1.0 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * PDO Result Class | ||||
|  * | ||||
|  * This class extends the parent result class: CI_DB_result | ||||
|  * | ||||
|  * @package		CodeIgniter | ||||
|  * @subpackage	Drivers | ||||
|  * @category	Database | ||||
|  * @author		EllisLab Dev Team | ||||
|  * @link		https://codeigniter.com/user_guide/database/ | ||||
|  */ | ||||
| class CI_DB_pdo_result extends CI_DB_result { | ||||
|  | ||||
| 	/** | ||||
| 	 * Number of rows in the result set | ||||
| 	 * | ||||
| 	 * @return	int | ||||
| 	 */ | ||||
| 	public function num_rows() | ||||
| 	{ | ||||
| 		if (is_int($this->num_rows)) | ||||
| 		{ | ||||
| 			return $this->num_rows; | ||||
| 		} | ||||
| 		elseif (count($this->result_array) > 0) | ||||
| 		{ | ||||
| 			return $this->num_rows = count($this->result_array); | ||||
| 		} | ||||
| 		elseif (count($this->result_object) > 0) | ||||
| 		{ | ||||
| 			return $this->num_rows = count($this->result_object); | ||||
| 		} | ||||
| 		elseif (($num_rows = $this->result_id->rowCount()) > 0) | ||||
| 		{ | ||||
| 			return $this->num_rows = $num_rows; | ||||
| 		} | ||||
|  | ||||
| 		return $this->num_rows = count($this->result_array()); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Number of fields in the result set | ||||
| 	 * | ||||
| 	 * @return	int | ||||
| 	 */ | ||||
| 	public function num_fields() | ||||
| 	{ | ||||
| 		return $this->result_id->columnCount(); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Fetch Field Names | ||||
| 	 * | ||||
| 	 * Generates an array of column names | ||||
| 	 * | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	public function list_fields() | ||||
| 	{ | ||||
| 		$field_names = array(); | ||||
| 		for ($i = 0, $c = $this->num_fields(); $i < $c; $i++) | ||||
| 		{ | ||||
| 			// Might trigger an E_WARNING due to not all subdrivers | ||||
| 			// supporting getColumnMeta() | ||||
| 			$field_names[$i] = @$this->result_id->getColumnMeta($i); | ||||
| 			$field_names[$i] = $field_names[$i]['name']; | ||||
| 		} | ||||
|  | ||||
| 		return $field_names; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Field data | ||||
| 	 * | ||||
| 	 * Generates an array of objects containing field meta-data | ||||
| 	 * | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	public function field_data() | ||||
| 	{ | ||||
| 		try | ||||
| 		{ | ||||
| 			$retval = array(); | ||||
|  | ||||
| 			for ($i = 0, $c = $this->num_fields(); $i < $c; $i++) | ||||
| 			{ | ||||
| 				$field = $this->result_id->getColumnMeta($i); | ||||
|  | ||||
| 				$retval[$i]			= new stdClass(); | ||||
| 				$retval[$i]->name		= $field['name']; | ||||
| 				$retval[$i]->type		= isset($field['native_type']) ? $field['native_type'] : null; | ||||
| 				$retval[$i]->max_length		= ($field['len'] > 0) ? $field['len'] : NULL; | ||||
| 				$retval[$i]->primary_key	= (int) ( ! empty($field['flags']) && in_array('primary_key', $field['flags'], TRUE)); | ||||
| 			} | ||||
|  | ||||
| 			return $retval; | ||||
| 		} | ||||
| 		catch (Exception $e) | ||||
| 		{ | ||||
| 			if ($this->db->db_debug) | ||||
| 			{ | ||||
| 				return $this->db->display_error('db_unsupported_feature'); | ||||
| 			} | ||||
|  | ||||
| 			return FALSE; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Free the result | ||||
| 	 * | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	public function free_result() | ||||
| 	{ | ||||
| 		if (is_object($this->result_id)) | ||||
| 		{ | ||||
| 			$this->result_id = FALSE; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Result - associative array | ||||
| 	 * | ||||
| 	 * Returns the result set as an array | ||||
| 	 * | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	protected function _fetch_assoc() | ||||
| 	{ | ||||
| 		return $this->result_id->fetch(PDO::FETCH_ASSOC); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Result - object | ||||
| 	 * | ||||
| 	 * Returns the result set as an object | ||||
| 	 * | ||||
| 	 * @param	string	$class_name | ||||
| 	 * @return	object | ||||
| 	 */ | ||||
| 	protected function _fetch_object($class_name = 'stdClass') | ||||
| 	{ | ||||
| 		return $this->result_id->fetchObject($class_name); | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										63
									
								
								system/database/drivers/pdo/pdo_utility.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										63
									
								
								system/database/drivers/pdo/pdo_utility.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,63 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/) | ||||
|  * @license	https://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 2.1.0 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * PDO Utility Class | ||||
|  * | ||||
|  * @package		CodeIgniter | ||||
|  * @subpackage	Drivers | ||||
|  * @category	Database | ||||
|  * @author		EllisLab Dev Team | ||||
|  * @link		https://codeigniter.com/database/ | ||||
|  */ | ||||
| class CI_DB_pdo_utility extends CI_DB_utility { | ||||
|  | ||||
| 	/** | ||||
| 	 * Export | ||||
| 	 * | ||||
| 	 * @param	array	$params	Preferences | ||||
| 	 * @return	mixed | ||||
| 	 */ | ||||
| 	protected function _backup($params = array()) | ||||
| 	{ | ||||
| 		// Currently unsupported | ||||
| 		return $this->db->display_error('db_unsupported_feature'); | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										11
									
								
								system/database/drivers/pdo/subdrivers/index.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								system/database/drivers/pdo/subdrivers/index.html
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,11 @@ | ||||
| <!DOCTYPE html> | ||||
| <html> | ||||
| <head> | ||||
| 	<title>403 Forbidden</title> | ||||
| </head> | ||||
| <body> | ||||
|  | ||||
| <p>Directory access is forbidden.</p> | ||||
|  | ||||
| </body> | ||||
| </html> | ||||
							
								
								
									
										200
									
								
								system/database/drivers/pdo/subdrivers/pdo_4d_driver.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										200
									
								
								system/database/drivers/pdo/subdrivers/pdo_4d_driver.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,200 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/) | ||||
|  * @license	https://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 3.0.0 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * PDO 4D Database Adapter Class | ||||
|  * | ||||
|  * Note: _DB is an extender class that the app controller | ||||
|  * creates dynamically based on whether the query builder | ||||
|  * class is being used or not. | ||||
|  * | ||||
|  * @package		CodeIgniter | ||||
|  * @subpackage	Drivers | ||||
|  * @category	Database | ||||
|  * @author		EllisLab Dev Team | ||||
|  * @link		https://codeigniter.com/user_guide/database/ | ||||
|  */ | ||||
| class CI_DB_pdo_4d_driver extends CI_DB_pdo_driver { | ||||
|  | ||||
| 	/** | ||||
| 	 * Sub-driver | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	public $subdriver = '4d'; | ||||
|  | ||||
| 	/** | ||||
| 	 * Identifier escape character | ||||
| 	 * | ||||
| 	 * @var	string[] | ||||
| 	 */ | ||||
| 	protected $_escape_char = array('[', ']'); | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Class constructor | ||||
| 	 * | ||||
| 	 * Builds the DSN if not already set. | ||||
| 	 * | ||||
| 	 * @param	array	$params | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	public function __construct($params) | ||||
| 	{ | ||||
| 		parent::__construct($params); | ||||
|  | ||||
| 		if (empty($this->dsn)) | ||||
| 		{ | ||||
| 			$this->dsn = '4D:host='.(empty($this->hostname) ? '127.0.0.1' : $this->hostname); | ||||
|  | ||||
| 			empty($this->port) OR $this->dsn .= ';port='.$this->port; | ||||
| 			empty($this->database) OR $this->dsn .= ';dbname='.$this->database; | ||||
| 			empty($this->char_set) OR $this->dsn .= ';charset='.$this->char_set; | ||||
| 		} | ||||
| 		elseif ( ! empty($this->char_set) && strpos($this->dsn, 'charset=', 3) === FALSE) | ||||
| 		{ | ||||
| 			$this->dsn .= ';charset='.$this->char_set; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Show table query | ||||
| 	 * | ||||
| 	 * Generates a platform-specific query string so that the table names can be fetched | ||||
| 	 * | ||||
| 	 * @param	bool	$prefix_limit | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _list_tables($prefix_limit = FALSE) | ||||
| 	{ | ||||
| 		$sql = 'SELECT '.$this->escape_identifiers('TABLE_NAME').' FROM '.$this->escape_identifiers('_USER_TABLES'); | ||||
|  | ||||
| 		if ($prefix_limit === TRUE && $this->dbprefix !== '') | ||||
| 		{ | ||||
| 			$sql .= ' WHERE '.$this->escape_identifiers('TABLE_NAME')." LIKE '".$this->escape_like_str($this->dbprefix)."%' " | ||||
| 				.sprintf($this->_like_escape_str, $this->_like_escape_chr); | ||||
| 		} | ||||
|  | ||||
| 		return $sql; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Show column query | ||||
| 	 * | ||||
| 	 * Generates a platform-specific query string so that the column names can be fetched | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _list_columns($table = '') | ||||
| 	{ | ||||
| 		return 'SELECT '.$this->escape_identifiers('COLUMN_NAME').' FROM '.$this->escape_identifiers('_USER_COLUMNS') | ||||
| 			.' WHERE '.$this->escape_identifiers('TABLE_NAME').' = '.$this->escape($table); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Field data query | ||||
| 	 * | ||||
| 	 * Generates a platform-specific query so that the column data can be retrieved | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _field_data($table) | ||||
| 	{ | ||||
| 		return 'SELECT * FROM '.$this->protect_identifiers($table, TRUE, NULL, FALSE).' LIMIT 1'; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Update statement | ||||
| 	 * | ||||
| 	 * Generates a platform-specific update string from the supplied data | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @param	array	$values | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _update($table, $values) | ||||
| 	{ | ||||
| 		$this->qb_limit = FALSE; | ||||
| 		$this->qb_orderby = array(); | ||||
| 		return parent::_update($table, $values); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Delete statement | ||||
| 	 * | ||||
| 	 * Generates a platform-specific delete string from the supplied data | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _delete($table) | ||||
| 	{ | ||||
| 		$this->qb_limit = FALSE; | ||||
| 		return parent::_delete($table); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * LIMIT | ||||
| 	 * | ||||
| 	 * Generates a platform-specific LIMIT clause | ||||
| 	 * | ||||
| 	 * @param	string	$sql	SQL Query | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _limit($sql) | ||||
| 	{ | ||||
| 		return $sql.' LIMIT '.$this->qb_limit.($this->qb_offset ? ' OFFSET '.$this->qb_offset : ''); | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										217
									
								
								system/database/drivers/pdo/subdrivers/pdo_4d_forge.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										217
									
								
								system/database/drivers/pdo/subdrivers/pdo_4d_forge.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,217 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/) | ||||
|  * @license	https://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 3.0.0 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * PDO 4D Forge Class | ||||
|  * | ||||
|  * @category	Database | ||||
|  * @author		EllisLab Dev Team | ||||
|  * @link		https://codeigniter.com/user_guide/database/ | ||||
|  */ | ||||
| class CI_DB_pdo_4d_forge extends CI_DB_pdo_forge { | ||||
|  | ||||
| 	/** | ||||
| 	 * CREATE DATABASE statement | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_create_database	= 'CREATE SCHEMA %s'; | ||||
|  | ||||
| 	/** | ||||
| 	 * DROP DATABASE statement | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_drop_database	= 'DROP SCHEMA %s'; | ||||
|  | ||||
| 	/** | ||||
| 	 * CREATE TABLE IF statement | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_create_table_if	= 'CREATE TABLE IF NOT EXISTS'; | ||||
|  | ||||
| 	/** | ||||
| 	 * RENAME TABLE statement | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_rename_table	= FALSE; | ||||
|  | ||||
| 	/** | ||||
| 	 * DROP TABLE IF statement | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_drop_table_if	= 'DROP TABLE IF EXISTS'; | ||||
|  | ||||
| 	/** | ||||
| 	 * UNSIGNED support | ||||
| 	 * | ||||
| 	 * @var	array | ||||
| 	 */ | ||||
| 	protected $_unsigned		= array( | ||||
| 		'INT16'		=> 'INT', | ||||
| 		'SMALLINT'	=> 'INT', | ||||
| 		'INT'		=> 'INT64', | ||||
| 		'INT32'		=> 'INT64' | ||||
| 	); | ||||
|  | ||||
| 	/** | ||||
| 	 * DEFAULT value representation in CREATE/ALTER TABLE statements | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_default		= FALSE; | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * ALTER TABLE | ||||
| 	 * | ||||
| 	 * @param	string	$alter_type	ALTER type | ||||
| 	 * @param	string	$table		Table name | ||||
| 	 * @param	mixed	$field		Column definition | ||||
| 	 * @return	string|string[] | ||||
| 	 */ | ||||
| 	protected function _alter_table($alter_type, $table, $field) | ||||
| 	{ | ||||
| 		if (in_array($alter_type, array('ADD', 'DROP'), TRUE)) | ||||
| 		{ | ||||
| 			return parent::_alter_table($alter_type, $table, $field); | ||||
| 		} | ||||
|  | ||||
| 		// No method of modifying columns is supported | ||||
| 		return FALSE; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Process column | ||||
| 	 * | ||||
| 	 * @param	array	$field | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _process_column($field) | ||||
| 	{ | ||||
| 		return $this->db->escape_identifiers($field['name']) | ||||
| 			.' '.$field['type'].$field['length'] | ||||
| 			.$field['null'] | ||||
| 			.$field['unique'] | ||||
| 			.$field['auto_increment']; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Field attribute TYPE | ||||
| 	 * | ||||
| 	 * Performs a data type mapping between different databases. | ||||
| 	 * | ||||
| 	 * @param	array	&$attributes | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	protected function _attr_type(&$attributes) | ||||
| 	{ | ||||
| 		switch (strtoupper($attributes['TYPE'])) | ||||
| 		{ | ||||
| 			case 'TINYINT': | ||||
| 				$attributes['TYPE'] = 'SMALLINT'; | ||||
| 				$attributes['UNSIGNED'] = FALSE; | ||||
| 				return; | ||||
| 			case 'MEDIUMINT': | ||||
| 				$attributes['TYPE'] = 'INTEGER'; | ||||
| 				$attributes['UNSIGNED'] = FALSE; | ||||
| 				return; | ||||
| 			case 'INTEGER': | ||||
| 				$attributes['TYPE'] = 'INT'; | ||||
| 				return; | ||||
| 			case 'BIGINT': | ||||
| 				$attributes['TYPE'] = 'INT64'; | ||||
| 				return; | ||||
| 			default: return; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Field attribute UNIQUE | ||||
| 	 * | ||||
| 	 * @param	array	&$attributes | ||||
| 	 * @param	array	&$field | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	protected function _attr_unique(&$attributes, &$field) | ||||
| 	{ | ||||
| 		if ( ! empty($attributes['UNIQUE']) && $attributes['UNIQUE'] === TRUE) | ||||
| 		{ | ||||
| 			$field['unique'] = ' UNIQUE'; | ||||
|  | ||||
| 			// UNIQUE must be used with NOT NULL | ||||
| 			$field['null'] = ' NOT NULL'; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Field attribute AUTO_INCREMENT | ||||
| 	 * | ||||
| 	 * @param	array	&$attributes | ||||
| 	 * @param	array	&$field | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	protected function _attr_auto_increment(&$attributes, &$field) | ||||
| 	{ | ||||
| 		if ( ! empty($attributes['AUTO_INCREMENT']) && $attributes['AUTO_INCREMENT'] === TRUE) | ||||
| 		{ | ||||
| 			if (stripos($field['type'], 'int') !== FALSE) | ||||
| 			{ | ||||
| 				$field['auto_increment'] = ' AUTO_INCREMENT'; | ||||
| 			} | ||||
| 			elseif (strcasecmp($field['type'], 'UUID') === 0) | ||||
| 			{ | ||||
| 				$field['auto_increment'] = ' AUTO_GENERATE'; | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										209
									
								
								system/database/drivers/pdo/subdrivers/pdo_cubrid_driver.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										209
									
								
								system/database/drivers/pdo/subdrivers/pdo_cubrid_driver.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,209 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/) | ||||
|  * @license	https://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 3.0.0 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * PDO CUBRID Database Adapter Class | ||||
|  * | ||||
|  * Note: _DB is an extender class that the app controller | ||||
|  * creates dynamically based on whether the query builder | ||||
|  * class is being used or not. | ||||
|  * | ||||
|  * @package		CodeIgniter | ||||
|  * @subpackage	Drivers | ||||
|  * @category	Database | ||||
|  * @author		EllisLab Dev Team | ||||
|  * @link		https://codeigniter.com/user_guide/database/ | ||||
|  */ | ||||
| class CI_DB_pdo_cubrid_driver extends CI_DB_pdo_driver { | ||||
|  | ||||
| 	/** | ||||
| 	 * Sub-driver | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	public $subdriver = 'cubrid'; | ||||
|  | ||||
| 	/** | ||||
| 	 * Identifier escape character | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_escape_char = '`'; | ||||
|  | ||||
| 	/** | ||||
| 	 * ORDER BY random keyword | ||||
| 	 * | ||||
| 	 * @var array | ||||
| 	 */ | ||||
| 	protected $_random_keyword = array('RANDOM()', 'RANDOM(%d)'); | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Class constructor | ||||
| 	 * | ||||
| 	 * Builds the DSN if not already set. | ||||
| 	 * | ||||
| 	 * @param	array	$params | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	public function __construct($params) | ||||
| 	{ | ||||
| 		parent::__construct($params); | ||||
|  | ||||
| 		if (empty($this->dsn)) | ||||
| 		{ | ||||
| 			$this->dsn = 'cubrid:host='.(empty($this->hostname) ? '127.0.0.1' : $this->hostname); | ||||
|  | ||||
| 			empty($this->port) OR $this->dsn .= ';port='.$this->port; | ||||
| 			empty($this->database) OR $this->dsn .= ';dbname='.$this->database; | ||||
| 			empty($this->char_set) OR $this->dsn .= ';charset='.$this->char_set; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Show table query | ||||
| 	 * | ||||
| 	 * Generates a platform-specific query string so that the table names can be fetched | ||||
| 	 * | ||||
| 	 * @param	bool	$prefix_limit | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _list_tables($prefix_limit = FALSE) | ||||
| 	{ | ||||
| 		$sql = 'SHOW TABLES'; | ||||
|  | ||||
| 		if ($prefix_limit === TRUE && $this->dbprefix !== '') | ||||
| 		{ | ||||
| 			return $sql." LIKE '".$this->escape_like_str($this->dbprefix)."%'"; | ||||
| 		} | ||||
|  | ||||
| 		return $sql; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Show column query | ||||
| 	 * | ||||
| 	 * Generates a platform-specific query string so that the column names can be fetched | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _list_columns($table = '') | ||||
| 	{ | ||||
| 		return 'SHOW COLUMNS FROM '.$this->protect_identifiers($table, TRUE, NULL, FALSE); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Returns an object with field data | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	public function field_data($table) | ||||
| 	{ | ||||
| 		if (($query = $this->query('SHOW COLUMNS FROM '.$this->protect_identifiers($table, TRUE, NULL, FALSE))) === FALSE) | ||||
| 		{ | ||||
| 			return FALSE; | ||||
| 		} | ||||
| 		$query = $query->result_object(); | ||||
|  | ||||
| 		$retval = array(); | ||||
| 		for ($i = 0, $c = count($query); $i < $c; $i++) | ||||
| 		{ | ||||
| 			$retval[$i]			= new stdClass(); | ||||
| 			$retval[$i]->name		= $query[$i]->Field; | ||||
|  | ||||
| 			sscanf($query[$i]->Type, '%[a-z](%d)', | ||||
| 				$retval[$i]->type, | ||||
| 				$retval[$i]->max_length | ||||
| 			); | ||||
|  | ||||
| 			$retval[$i]->default		= $query[$i]->Default; | ||||
| 			$retval[$i]->primary_key	= (int) ($query[$i]->Key === 'PRI'); | ||||
| 		} | ||||
|  | ||||
| 		return $retval; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Truncate statement | ||||
| 	 * | ||||
| 	 * Generates a platform-specific truncate string from the supplied data | ||||
| 	 * | ||||
| 	 * If the database does not support the TRUNCATE statement, | ||||
| 	 * then this method maps to 'DELETE FROM table' | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _truncate($table) | ||||
| 	{ | ||||
| 		return 'TRUNCATE '.$table; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * FROM tables | ||||
| 	 * | ||||
| 	 * Groups tables in FROM clauses if needed, so there is no confusion | ||||
| 	 * about operator precedence. | ||||
| 	 * | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _from_tables() | ||||
| 	{ | ||||
| 		if ( ! empty($this->qb_join) && count($this->qb_from) > 1) | ||||
| 		{ | ||||
| 			return '('.implode(', ', $this->qb_from).')'; | ||||
| 		} | ||||
|  | ||||
| 		return implode(', ', $this->qb_from); | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										230
									
								
								system/database/drivers/pdo/subdrivers/pdo_cubrid_forge.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										230
									
								
								system/database/drivers/pdo/subdrivers/pdo_cubrid_forge.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,230 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/) | ||||
|  * @license	https://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 3.0.0 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * PDO CUBRID Forge Class | ||||
|  * | ||||
|  * @category	Database | ||||
|  * @author		EllisLab Dev Team | ||||
|  * @link		https://codeigniter.com/user_guide/database/ | ||||
|  */ | ||||
| class CI_DB_pdo_cubrid_forge extends CI_DB_pdo_forge { | ||||
|  | ||||
| 	/** | ||||
| 	 * CREATE DATABASE statement | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_create_database	= FALSE; | ||||
|  | ||||
| 	/** | ||||
| 	 * DROP DATABASE statement | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_drop_database	= FALSE; | ||||
|  | ||||
| 	/** | ||||
| 	 * CREATE TABLE keys flag | ||||
| 	 * | ||||
| 	 * Whether table keys are created from within the | ||||
| 	 * CREATE TABLE statement. | ||||
| 	 * | ||||
| 	 * @var	bool | ||||
| 	 */ | ||||
| 	protected $_create_table_keys	= TRUE; | ||||
|  | ||||
| 	/** | ||||
| 	 * DROP TABLE IF statement | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_drop_table_if	= 'DROP TABLE IF EXISTS'; | ||||
|  | ||||
| 	/** | ||||
| 	 * UNSIGNED support | ||||
| 	 * | ||||
| 	 * @var	array | ||||
| 	 */ | ||||
| 	protected $_unsigned		= array( | ||||
| 		'SHORT'		=> 'INTEGER', | ||||
| 		'SMALLINT'	=> 'INTEGER', | ||||
| 		'INT'		=> 'BIGINT', | ||||
| 		'INTEGER'	=> 'BIGINT', | ||||
| 		'BIGINT'	=> 'NUMERIC', | ||||
| 		'FLOAT'		=> 'DOUBLE', | ||||
| 		'REAL'		=> 'DOUBLE' | ||||
| 	); | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * ALTER TABLE | ||||
| 	 * | ||||
| 	 * @param	string	$alter_type	ALTER type | ||||
| 	 * @param	string	$table		Table name | ||||
| 	 * @param	mixed	$field		Column definition | ||||
| 	 * @return	string|string[] | ||||
| 	 */ | ||||
| 	protected function _alter_table($alter_type, $table, $field) | ||||
| 	{ | ||||
| 		if (in_array($alter_type, array('DROP', 'ADD'), TRUE)) | ||||
| 		{ | ||||
| 			return parent::_alter_table($alter_type, $table, $field); | ||||
| 		} | ||||
|  | ||||
| 		$sql = 'ALTER TABLE '.$this->db->escape_identifiers($table); | ||||
| 		$sqls = array(); | ||||
| 		for ($i = 0, $c = count($field); $i < $c; $i++) | ||||
| 		{ | ||||
| 			if ($field[$i]['_literal'] !== FALSE) | ||||
| 			{ | ||||
| 				$sqls[] = $sql.' CHANGE '.$field[$i]['_literal']; | ||||
| 			} | ||||
| 			else | ||||
| 			{ | ||||
| 				$alter_type = empty($field[$i]['new_name']) ? ' MODIFY ' : ' CHANGE '; | ||||
| 				$sqls[] = $sql.$alter_type.$this->_process_column($field[$i]); | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		return $sqls; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Process column | ||||
| 	 * | ||||
| 	 * @param	array	$field | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _process_column($field) | ||||
| 	{ | ||||
| 		$extra_clause = isset($field['after']) | ||||
| 			? ' AFTER '.$this->db->escape_identifiers($field['after']) : ''; | ||||
|  | ||||
| 		if (empty($extra_clause) && isset($field['first']) && $field['first'] === TRUE) | ||||
| 		{ | ||||
| 			$extra_clause = ' FIRST'; | ||||
| 		} | ||||
|  | ||||
| 		return $this->db->escape_identifiers($field['name']) | ||||
| 			.(empty($field['new_name']) ? '' : ' '.$this->db->escape_identifiers($field['new_name'])) | ||||
| 			.' '.$field['type'].$field['length'] | ||||
| 			.$field['unsigned'] | ||||
| 			.$field['null'] | ||||
| 			.$field['default'] | ||||
| 			.$field['auto_increment'] | ||||
| 			.$field['unique'] | ||||
| 			.$extra_clause; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Field attribute TYPE | ||||
| 	 * | ||||
| 	 * Performs a data type mapping between different databases. | ||||
| 	 * | ||||
| 	 * @param	array	&$attributes | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	protected function _attr_type(&$attributes) | ||||
| 	{ | ||||
| 		switch (strtoupper($attributes['TYPE'])) | ||||
| 		{ | ||||
| 			case 'TINYINT': | ||||
| 				$attributes['TYPE'] = 'SMALLINT'; | ||||
| 				$attributes['UNSIGNED'] = FALSE; | ||||
| 				return; | ||||
| 			case 'MEDIUMINT': | ||||
| 				$attributes['TYPE'] = 'INTEGER'; | ||||
| 				$attributes['UNSIGNED'] = FALSE; | ||||
| 				return; | ||||
| 			case 'LONGTEXT': | ||||
| 				$attributes['TYPE'] = 'STRING'; | ||||
| 				return; | ||||
| 			default: return; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Process indexes | ||||
| 	 * | ||||
| 	 * @param	string	$table	(ignored) | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _process_indexes($table) | ||||
| 	{ | ||||
| 		$sql = ''; | ||||
|  | ||||
| 		for ($i = 0, $c = count($this->keys); $i < $c; $i++) | ||||
| 		{ | ||||
| 			if (is_array($this->keys[$i])) | ||||
| 			{ | ||||
| 				for ($i2 = 0, $c2 = count($this->keys[$i]); $i2 < $c2; $i2++) | ||||
| 				{ | ||||
| 					if ( ! isset($this->fields[$this->keys[$i][$i2]])) | ||||
| 					{ | ||||
| 						unset($this->keys[$i][$i2]); | ||||
| 						continue; | ||||
| 					} | ||||
| 				} | ||||
| 			} | ||||
| 			elseif ( ! isset($this->fields[$this->keys[$i]])) | ||||
| 			{ | ||||
| 				unset($this->keys[$i]); | ||||
| 				continue; | ||||
| 			} | ||||
|  | ||||
| 			is_array($this->keys[$i]) OR $this->keys[$i] = array($this->keys[$i]); | ||||
|  | ||||
| 			$sql .= ",\n\tKEY ".$this->db->escape_identifiers(implode('_', $this->keys[$i])) | ||||
| 				.' ('.implode(', ', $this->db->escape_identifiers($this->keys[$i])).')'; | ||||
| 		} | ||||
|  | ||||
| 		$this->keys = array(); | ||||
|  | ||||
| 		return $sql; | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										353
									
								
								system/database/drivers/pdo/subdrivers/pdo_dblib_driver.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										353
									
								
								system/database/drivers/pdo/subdrivers/pdo_dblib_driver.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,353 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/) | ||||
|  * @license	https://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 3.0.0 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * PDO DBLIB Database Adapter Class | ||||
|  * | ||||
|  * Note: _DB is an extender class that the app controller | ||||
|  * creates dynamically based on whether the query builder | ||||
|  * class is being used or not. | ||||
|  * | ||||
|  * @package		CodeIgniter | ||||
|  * @subpackage	Drivers | ||||
|  * @category	Database | ||||
|  * @author		EllisLab Dev Team | ||||
|  * @link		https://codeigniter.com/user_guide/database/ | ||||
|  */ | ||||
| class CI_DB_pdo_dblib_driver extends CI_DB_pdo_driver { | ||||
|  | ||||
| 	/** | ||||
| 	 * Sub-driver | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	public $subdriver = 'dblib'; | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * ORDER BY random keyword | ||||
| 	 * | ||||
| 	 * @var	array | ||||
| 	 */ | ||||
| 	protected $_random_keyword = array('NEWID()', 'RAND(%d)'); | ||||
|  | ||||
| 	/** | ||||
| 	 * Quoted identifier flag | ||||
| 	 * | ||||
| 	 * Whether to use SQL-92 standard quoted identifier | ||||
| 	 * (double quotes) or brackets for identifier escaping. | ||||
| 	 * | ||||
| 	 * @var	bool | ||||
| 	 */ | ||||
| 	protected $_quoted_identifier; | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Class constructor | ||||
| 	 * | ||||
| 	 * Builds the DSN if not already set. | ||||
| 	 * | ||||
| 	 * @param	array	$params | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	public function __construct($params) | ||||
| 	{ | ||||
| 		parent::__construct($params); | ||||
|  | ||||
| 		if (empty($this->dsn)) | ||||
| 		{ | ||||
| 			$this->dsn = $params['subdriver'].':host='.(empty($this->hostname) ? '127.0.0.1' : $this->hostname); | ||||
|  | ||||
| 			if ( ! empty($this->port)) | ||||
| 			{ | ||||
| 				$this->dsn .= (DIRECTORY_SEPARATOR === '\\' ? ',' : ':').$this->port; | ||||
| 			} | ||||
|  | ||||
| 			empty($this->database) OR $this->dsn .= ';dbname='.$this->database; | ||||
| 			empty($this->char_set) OR $this->dsn .= ';charset='.$this->char_set; | ||||
| 			empty($this->appname) OR $this->dsn .= ';appname='.$this->appname; | ||||
| 		} | ||||
| 		else | ||||
| 		{ | ||||
| 			if ( ! empty($this->char_set) && strpos($this->dsn, 'charset=', 6) === FALSE) | ||||
| 			{ | ||||
| 				$this->dsn .= ';charset='.$this->char_set; | ||||
| 			} | ||||
|  | ||||
| 			$this->subdriver = 'dblib'; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Database connection | ||||
| 	 * | ||||
| 	 * @param	bool	$persistent | ||||
| 	 * @return	object | ||||
| 	 */ | ||||
| 	public function db_connect($persistent = FALSE) | ||||
| 	{ | ||||
| 		if ($persistent === TRUE) | ||||
| 		{ | ||||
| 			log_message('debug', "dblib driver doesn't support persistent connections"); | ||||
| 		} | ||||
|  | ||||
| 		$this->conn_id = parent::db_connect(FALSE); | ||||
|  | ||||
| 		if ( ! is_object($this->conn_id)) | ||||
| 		{ | ||||
| 			return $this->conn_id; | ||||
| 		} | ||||
|  | ||||
| 		// Determine how identifiers are escaped | ||||
| 		$query = $this->query('SELECT CASE WHEN (@@OPTIONS | 256) = @@OPTIONS THEN 1 ELSE 0 END AS qi'); | ||||
| 		$query = $query->row_array(); | ||||
| 		$this->_quoted_identifier = empty($query) ? FALSE : (bool) $query['qi']; | ||||
| 		$this->_escape_char = ($this->_quoted_identifier) ? '"' : array('[', ']'); | ||||
|  | ||||
| 		return $this->conn_id; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Show table query | ||||
| 	 * | ||||
| 	 * Generates a platform-specific query string so that the table names can be fetched | ||||
| 	 * | ||||
| 	 * @param	bool	$prefix_limit | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _list_tables($prefix_limit = FALSE) | ||||
| 	{ | ||||
| 		$sql = 'SELECT '.$this->escape_identifiers('name') | ||||
| 			.' FROM '.$this->escape_identifiers('sysobjects') | ||||
| 			.' WHERE '.$this->escape_identifiers('type')." = 'U'"; | ||||
|  | ||||
| 		if ($prefix_limit === TRUE && $this->dbprefix !== '') | ||||
| 		{ | ||||
| 			$sql .= ' AND '.$this->escape_identifiers('name')." LIKE '".$this->escape_like_str($this->dbprefix)."%' " | ||||
| 				.sprintf($this->_like_escape_str, $this->_like_escape_chr); | ||||
| 		} | ||||
|  | ||||
| 		return $sql.' ORDER BY '.$this->escape_identifiers('name'); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Show column query | ||||
| 	 * | ||||
| 	 * Generates a platform-specific query string so that the column names can be fetched | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _list_columns($table = '') | ||||
| 	{ | ||||
| 		return 'SELECT COLUMN_NAME | ||||
| 			FROM INFORMATION_SCHEMA.Columns | ||||
| 			WHERE UPPER(TABLE_NAME) = '.$this->escape(strtoupper($table)); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Returns an object with field data | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	public function field_data($table) | ||||
| 	{ | ||||
| 		$sql = 'SELECT COLUMN_NAME, DATA_TYPE, CHARACTER_MAXIMUM_LENGTH, NUMERIC_PRECISION, COLUMN_DEFAULT | ||||
| 			FROM INFORMATION_SCHEMA.Columns | ||||
| 			WHERE UPPER(TABLE_NAME) = '.$this->escape(strtoupper($table)); | ||||
|  | ||||
| 		if (($query = $this->query($sql)) === FALSE) | ||||
| 		{ | ||||
| 			return FALSE; | ||||
| 		} | ||||
| 		$query = $query->result_object(); | ||||
|  | ||||
| 		$retval = array(); | ||||
| 		for ($i = 0, $c = count($query); $i < $c; $i++) | ||||
| 		{ | ||||
| 			$retval[$i]			= new stdClass(); | ||||
| 			$retval[$i]->name		= $query[$i]->COLUMN_NAME; | ||||
| 			$retval[$i]->type		= $query[$i]->DATA_TYPE; | ||||
| 			$retval[$i]->max_length		= ($query[$i]->CHARACTER_MAXIMUM_LENGTH > 0) ? $query[$i]->CHARACTER_MAXIMUM_LENGTH : $query[$i]->NUMERIC_PRECISION; | ||||
| 			$retval[$i]->default		= $query[$i]->COLUMN_DEFAULT; | ||||
| 		} | ||||
|  | ||||
| 		return $retval; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Update statement | ||||
| 	 * | ||||
| 	 * Generates a platform-specific update string from the supplied data | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @param	array	$values | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _update($table, $values) | ||||
| 	{ | ||||
| 		$this->qb_limit = FALSE; | ||||
| 		$this->qb_orderby = array(); | ||||
| 		return parent::_update($table, $values); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Delete statement | ||||
| 	 * | ||||
| 	 * Generates a platform-specific delete string from the supplied data | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _delete($table) | ||||
| 	{ | ||||
| 		if ($this->qb_limit) | ||||
| 		{ | ||||
| 			return 'WITH ci_delete AS (SELECT TOP '.$this->qb_limit.' * FROM '.$table.$this->_compile_wh('qb_where').') DELETE FROM ci_delete'; | ||||
| 		} | ||||
|  | ||||
| 		return parent::_delete($table); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * LIMIT | ||||
| 	 * | ||||
| 	 * Generates a platform-specific LIMIT clause | ||||
| 	 * | ||||
| 	 * @param	string	$sql	SQL Query | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _limit($sql) | ||||
| 	{ | ||||
| 		$limit = $this->qb_offset + $this->qb_limit; | ||||
|  | ||||
| 		// As of SQL Server 2005 (9.0.*) ROW_NUMBER() is supported, | ||||
| 		// however an ORDER BY clause is required for it to work | ||||
| 		if (version_compare($this->version(), '9', '>=') && $this->qb_offset && ! empty($this->qb_orderby)) | ||||
| 		{ | ||||
| 			$orderby = $this->_compile_order_by(); | ||||
|  | ||||
| 			// We have to strip the ORDER BY clause | ||||
| 			$sql = trim(substr($sql, 0, strrpos($sql, $orderby))); | ||||
|  | ||||
| 			// Get the fields to select from our subquery, so that we can avoid CI_rownum appearing in the actual results | ||||
| 			if (count($this->qb_select) === 0 OR strpos(implode(',', $this->qb_select), '*') !== FALSE) | ||||
| 			{ | ||||
| 				$select = '*'; // Inevitable | ||||
| 			} | ||||
| 			else | ||||
| 			{ | ||||
| 				// Use only field names and their aliases, everything else is out of our scope. | ||||
| 				$select = array(); | ||||
| 				$field_regexp = ($this->_quoted_identifier) | ||||
| 					? '("[^\"]+")' : '(\[[^\]]+\])'; | ||||
| 				for ($i = 0, $c = count($this->qb_select); $i < $c; $i++) | ||||
| 				{ | ||||
| 					$select[] = preg_match('/(?:\s|\.)'.$field_regexp.'$/i', $this->qb_select[$i], $m) | ||||
| 						? $m[1] : $this->qb_select[$i]; | ||||
| 				} | ||||
| 				$select = implode(', ', $select); | ||||
| 			} | ||||
|  | ||||
| 			return 'SELECT '.$select." FROM (\n\n" | ||||
| 				.preg_replace('/^(SELECT( DISTINCT)?)/i', '\\1 ROW_NUMBER() OVER('.trim($orderby).') AS '.$this->escape_identifiers('CI_rownum').', ', $sql) | ||||
| 				."\n\n) ".$this->escape_identifiers('CI_subquery') | ||||
| 				."\nWHERE ".$this->escape_identifiers('CI_rownum').' BETWEEN '.($this->qb_offset + 1).' AND '.$limit; | ||||
| 		} | ||||
|  | ||||
| 		return preg_replace('/(^\SELECT (DISTINCT)?)/i','\\1 TOP '.$limit.' ', $sql); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Insert batch statement | ||||
| 	 * | ||||
| 	 * Generates a platform-specific insert string from the supplied data. | ||||
| 	 * | ||||
| 	 * @param	string	$table	Table name | ||||
| 	 * @param	array	$keys	INSERT keys | ||||
| 	 * @param	array	$values	INSERT values | ||||
| 	 * @return	string|bool | ||||
| 	 */ | ||||
| 	protected function _insert_batch($table, $keys, $values) | ||||
| 	{ | ||||
| 		// Multiple-value inserts are only supported as of SQL Server 2008 | ||||
| 		if (version_compare($this->version(), '10', '>=')) | ||||
| 		{ | ||||
| 			return parent::_insert_batch($table, $keys, $values); | ||||
| 		} | ||||
|  | ||||
| 		return ($this->db_debug) ? $this->display_error('db_unsupported_feature') : FALSE; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Database version number | ||||
| 	 * | ||||
| 	 * @return      string | ||||
| 	 */ | ||||
| 	public function version() | ||||
| 	{ | ||||
| 		if (isset($this->data_cache['version'])) | ||||
| 		{ | ||||
| 			return $this->data_cache['version']; | ||||
| 		} | ||||
|  | ||||
| 		return $this->data_cache['version'] = $this->conn_id->query("SELECT SERVERPROPERTY('ProductVersion') AS ver")->fetchColumn(0); | ||||
| 	} | ||||
| } | ||||
							
								
								
									
										149
									
								
								system/database/drivers/pdo/subdrivers/pdo_dblib_forge.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										149
									
								
								system/database/drivers/pdo/subdrivers/pdo_dblib_forge.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,149 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/) | ||||
|  * @license	https://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 3.0.0 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * PDO DBLIB Forge Class | ||||
|  * | ||||
|  * @category	Database | ||||
|  * @author		EllisLab Dev Team | ||||
|  * @link		https://codeigniter.com/user_guide/database/ | ||||
|  */ | ||||
| class CI_DB_pdo_dblib_forge extends CI_DB_pdo_forge { | ||||
|  | ||||
| 	/** | ||||
| 	 * CREATE TABLE IF statement | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_create_table_if	= "IF NOT EXISTS (SELECT * FROM sysobjects WHERE ID = object_id(N'%s') AND OBJECTPROPERTY(id, N'IsUserTable') = 1)\nCREATE TABLE"; | ||||
|  | ||||
| 	/** | ||||
| 	 * DROP TABLE IF statement | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_drop_table_if	= "IF EXISTS (SELECT * FROM sysobjects WHERE ID = object_id(N'%s') AND OBJECTPROPERTY(id, N'IsUserTable') = 1)\nDROP TABLE"; | ||||
|  | ||||
| 	/** | ||||
| 	 * UNSIGNED support | ||||
| 	 * | ||||
| 	 * @var	array | ||||
| 	 */ | ||||
| 	protected $_unsigned		= array( | ||||
| 		'TINYINT'	=> 'SMALLINT', | ||||
| 		'SMALLINT'	=> 'INT', | ||||
| 		'INT'		=> 'BIGINT', | ||||
| 		'REAL'		=> 'FLOAT' | ||||
| 	); | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * ALTER TABLE | ||||
| 	 * | ||||
| 	 * @param	string	$alter_type	ALTER type | ||||
| 	 * @param	string	$table		Table name | ||||
| 	 * @param	mixed	$field		Column definition | ||||
| 	 * @return	string|string[] | ||||
| 	 */ | ||||
| 	protected function _alter_table($alter_type, $table, $field) | ||||
| 	{ | ||||
| 		if (in_array($alter_type, array('ADD', 'DROP'), TRUE)) | ||||
| 		{ | ||||
| 			return parent::_alter_table($alter_type, $table, $field); | ||||
| 		} | ||||
|  | ||||
| 		$sql = 'ALTER TABLE '.$this->db->escape_identifiers($table).' ALTER COLUMN '; | ||||
| 		$sqls = array(); | ||||
| 		for ($i = 0, $c = count($field); $i < $c; $i++) | ||||
| 		{ | ||||
| 			$sqls[] = $sql.$this->_process_column($field[$i]); | ||||
| 		} | ||||
|  | ||||
| 		return $sqls; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Field attribute TYPE | ||||
| 	 * | ||||
| 	 * Performs a data type mapping between different databases. | ||||
| 	 * | ||||
| 	 * @param	array	&$attributes | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	protected function _attr_type(&$attributes) | ||||
| 	{ | ||||
| 		if (isset($attributes['CONSTRAINT']) && strpos($attributes['TYPE'], 'INT') !== FALSE) | ||||
| 		{ | ||||
| 			unset($attributes['CONSTRAINT']); | ||||
| 		} | ||||
|  | ||||
| 		switch (strtoupper($attributes['TYPE'])) | ||||
| 		{ | ||||
| 			case 'MEDIUMINT': | ||||
| 				$attributes['TYPE'] = 'INTEGER'; | ||||
| 				$attributes['UNSIGNED'] = FALSE; | ||||
| 				return; | ||||
| 			case 'INTEGER': | ||||
| 				$attributes['TYPE'] = 'INT'; | ||||
| 				return; | ||||
| 			default: return; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Field attribute AUTO_INCREMENT | ||||
| 	 * | ||||
| 	 * @param	array	&$attributes | ||||
| 	 * @param	array	&$field | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	protected function _attr_auto_increment(&$attributes, &$field) | ||||
| 	{ | ||||
| 		if ( ! empty($attributes['AUTO_INCREMENT']) && $attributes['AUTO_INCREMENT'] === TRUE && stripos($field['type'], 'int') !== FALSE) | ||||
| 		{ | ||||
| 			$field['auto_increment'] = ' IDENTITY(1,1)'; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										279
									
								
								system/database/drivers/pdo/subdrivers/pdo_firebird_driver.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										279
									
								
								system/database/drivers/pdo/subdrivers/pdo_firebird_driver.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,279 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/) | ||||
|  * @license	https://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 3.0.0 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * PDO Firebird Database Adapter Class | ||||
|  * | ||||
|  * Note: _DB is an extender class that the app controller | ||||
|  * creates dynamically based on whether the query builder | ||||
|  * class is being used or not. | ||||
|  * | ||||
|  * @package		CodeIgniter | ||||
|  * @subpackage	Drivers | ||||
|  * @category	Database | ||||
|  * @author		EllisLab Dev Team | ||||
|  * @link		https://codeigniter.com/user_guide/database/ | ||||
|  */ | ||||
| class CI_DB_pdo_firebird_driver extends CI_DB_pdo_driver { | ||||
|  | ||||
| 	/** | ||||
| 	 * Sub-driver | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	public $subdriver = 'firebird'; | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * ORDER BY random keyword | ||||
| 	 * | ||||
| 	 * @var	array | ||||
| 	 */ | ||||
| 	protected $_random_keyword = array('RAND()', 'RAND()'); | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Class constructor | ||||
| 	 * | ||||
| 	 * Builds the DSN if not already set. | ||||
| 	 * | ||||
| 	 * @param	array	$params | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	public function __construct($params) | ||||
| 	{ | ||||
| 		parent::__construct($params); | ||||
|  | ||||
| 		if (empty($this->dsn)) | ||||
| 		{ | ||||
| 			$this->dsn = 'firebird:'; | ||||
|  | ||||
| 			if ( ! empty($this->database)) | ||||
| 			{ | ||||
| 				$this->dsn .= 'dbname='.$this->database; | ||||
| 			} | ||||
| 			elseif ( ! empty($this->hostname)) | ||||
| 			{ | ||||
| 				$this->dsn .= 'dbname='.$this->hostname; | ||||
| 			} | ||||
|  | ||||
| 			empty($this->char_set) OR $this->dsn .= ';charset='.$this->char_set; | ||||
| 			empty($this->role) OR $this->dsn .= ';role='.$this->role; | ||||
| 		} | ||||
| 		elseif ( ! empty($this->char_set) && strpos($this->dsn, 'charset=', 9) === FALSE) | ||||
| 		{ | ||||
| 			$this->dsn .= ';charset='.$this->char_set; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Show table query | ||||
| 	 * | ||||
| 	 * Generates a platform-specific query string so that the table names can be fetched | ||||
| 	 * | ||||
| 	 * @param	bool	$prefix_limit | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _list_tables($prefix_limit = FALSE) | ||||
| 	{ | ||||
| 		$sql = 'SELECT "RDB$RELATION_NAME" FROM "RDB$RELATIONS" WHERE "RDB$RELATION_NAME" NOT LIKE \'RDB$%\' AND "RDB$RELATION_NAME" NOT LIKE \'MON$%\''; | ||||
|  | ||||
| 		if ($prefix_limit === TRUE && $this->dbprefix !== '') | ||||
| 		{ | ||||
| 			return $sql.' AND "RDB$RELATION_NAME" LIKE \''.$this->escape_like_str($this->dbprefix)."%' " | ||||
| 				.sprintf($this->_like_escape_str, $this->_like_escape_chr); | ||||
| 		} | ||||
|  | ||||
| 		return $sql; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Show column query | ||||
| 	 * | ||||
| 	 * Generates a platform-specific query string so that the column names can be fetched | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _list_columns($table = '') | ||||
| 	{ | ||||
| 		return 'SELECT "RDB$FIELD_NAME" FROM "RDB$RELATION_FIELDS" WHERE "RDB$RELATION_NAME" = '.$this->escape($table); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Returns an object with field data | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	public function field_data($table) | ||||
| 	{ | ||||
| 		$sql = 'SELECT "rfields"."RDB$FIELD_NAME" AS "name", | ||||
| 				CASE "fields"."RDB$FIELD_TYPE" | ||||
| 					WHEN 7 THEN \'SMALLINT\' | ||||
| 					WHEN 8 THEN \'INTEGER\' | ||||
| 					WHEN 9 THEN \'QUAD\' | ||||
| 					WHEN 10 THEN \'FLOAT\' | ||||
| 					WHEN 11 THEN \'DFLOAT\' | ||||
| 					WHEN 12 THEN \'DATE\' | ||||
| 					WHEN 13 THEN \'TIME\' | ||||
| 					WHEN 14 THEN \'CHAR\' | ||||
| 					WHEN 16 THEN \'INT64\' | ||||
| 					WHEN 27 THEN \'DOUBLE\' | ||||
| 					WHEN 35 THEN \'TIMESTAMP\' | ||||
| 					WHEN 37 THEN \'VARCHAR\' | ||||
| 					WHEN 40 THEN \'CSTRING\' | ||||
| 					WHEN 261 THEN \'BLOB\' | ||||
| 					ELSE NULL | ||||
| 				END AS "type", | ||||
| 				"fields"."RDB$FIELD_LENGTH" AS "max_length", | ||||
| 				"rfields"."RDB$DEFAULT_VALUE" AS "default" | ||||
| 			FROM "RDB$RELATION_FIELDS" "rfields" | ||||
| 				JOIN "RDB$FIELDS" "fields" ON "rfields"."RDB$FIELD_SOURCE" = "fields"."RDB$FIELD_NAME" | ||||
| 			WHERE "rfields"."RDB$RELATION_NAME" = '.$this->escape($table).' | ||||
| 			ORDER BY "rfields"."RDB$FIELD_POSITION"'; | ||||
|  | ||||
| 		return (($query = $this->query($sql)) !== FALSE) | ||||
| 			? $query->result_object() | ||||
| 			: FALSE; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Update statement | ||||
| 	 * | ||||
| 	 * Generates a platform-specific update string from the supplied data | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @param	array	$values | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _update($table, $values) | ||||
| 	{ | ||||
| 		$this->qb_limit = FALSE; | ||||
| 		return parent::_update($table, $values); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Truncate statement | ||||
| 	 * | ||||
| 	 * Generates a platform-specific truncate string from the supplied data | ||||
| 	 * | ||||
| 	 * If the database does not support the TRUNCATE statement, | ||||
| 	 * then this method maps to 'DELETE FROM table' | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _truncate($table) | ||||
| 	{ | ||||
| 		return 'DELETE FROM '.$table; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Delete statement | ||||
| 	 * | ||||
| 	 * Generates a platform-specific delete string from the supplied data | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _delete($table) | ||||
| 	{ | ||||
| 		$this->qb_limit = FALSE; | ||||
| 		return parent::_delete($table); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * LIMIT | ||||
| 	 * | ||||
| 	 * Generates a platform-specific LIMIT clause | ||||
| 	 * | ||||
| 	 * @param	string	$sql	SQL Query | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _limit($sql) | ||||
| 	{ | ||||
| 		// Limit clause depends on if Interbase or Firebird | ||||
| 		if (stripos($this->version(), 'firebird') !== FALSE) | ||||
| 		{ | ||||
| 			$select = 'FIRST '.$this->qb_limit | ||||
| 				.($this->qb_offset > 0 ? ' SKIP '.$this->qb_offset : ''); | ||||
| 		} | ||||
| 		else | ||||
| 		{ | ||||
| 			$select = 'ROWS ' | ||||
| 				.($this->qb_offset > 0 ? $this->qb_offset.' TO '.($this->qb_limit + $this->qb_offset) : $this->qb_limit); | ||||
| 		} | ||||
|  | ||||
| 		return preg_replace('`SELECT`i', 'SELECT '.$select, $sql); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Insert batch statement | ||||
| 	 * | ||||
| 	 * Generates a platform-specific insert string from the supplied data. | ||||
| 	 * | ||||
| 	 * @param	string	$table	Table name | ||||
| 	 * @param	array	$keys	INSERT keys | ||||
| 	 * @param	array	$values	INSERT values | ||||
| 	 * @return	string|bool | ||||
| 	 */ | ||||
| 	protected function _insert_batch($table, $keys, $values) | ||||
| 	{ | ||||
| 		return ($this->db_debug) ? $this->display_error('db_unsupported_feature') : FALSE; | ||||
| 	} | ||||
| } | ||||
							
								
								
									
										237
									
								
								system/database/drivers/pdo/subdrivers/pdo_firebird_forge.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										237
									
								
								system/database/drivers/pdo/subdrivers/pdo_firebird_forge.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,237 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/) | ||||
|  * @license	https://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 3.0.0 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * PDO Firebird Forge Class | ||||
|  * | ||||
|  * @category	Database | ||||
|  * @author		EllisLab Dev Team | ||||
|  * @link		https://codeigniter.com/user_guide/database/ | ||||
|  */ | ||||
| class CI_DB_pdo_firebird_forge extends CI_DB_pdo_forge { | ||||
|  | ||||
| 	/** | ||||
| 	 * RENAME TABLE statement | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_rename_table	= FALSE; | ||||
|  | ||||
| 	/** | ||||
| 	 * UNSIGNED support | ||||
| 	 * | ||||
| 	 * @var	array | ||||
| 	 */ | ||||
| 	protected $_unsigned		= array( | ||||
| 		'SMALLINT'	=> 'INTEGER', | ||||
| 		'INTEGER'	=> 'INT64', | ||||
| 		'FLOAT'		=> 'DOUBLE PRECISION' | ||||
| 	); | ||||
|  | ||||
| 	/** | ||||
| 	 * NULL value representation in CREATE/ALTER TABLE statements | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_null		= 'NULL'; | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Create database | ||||
| 	 * | ||||
| 	 * @param	string	$db_name | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	public function create_database($db_name) | ||||
| 	{ | ||||
| 		// Firebird databases are flat files, so a path is required | ||||
|  | ||||
| 		// Hostname is needed for remote access | ||||
| 		empty($this->db->hostname) OR $db_name = $this->hostname.':'.$db_name; | ||||
|  | ||||
| 		return parent::create_database('"'.$db_name.'"'); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Drop database | ||||
| 	 * | ||||
| 	 * @param	string	$db_name	(ignored) | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	public function drop_database($db_name) | ||||
| 	{ | ||||
| 		if ( ! ibase_drop_db($this->conn_id)) | ||||
| 		{ | ||||
| 			return ($this->db->db_debug) ? $this->db->display_error('db_unable_to_drop') : FALSE; | ||||
| 		} | ||||
| 		elseif ( ! empty($this->db->data_cache['db_names'])) | ||||
| 		{ | ||||
| 			$key = array_search(strtolower($this->db->database), array_map('strtolower', $this->db->data_cache['db_names']), TRUE); | ||||
| 			if ($key !== FALSE) | ||||
| 			{ | ||||
| 				unset($this->db->data_cache['db_names'][$key]); | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		return TRUE; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * ALTER TABLE | ||||
| 	 * | ||||
| 	 * @param	string	$alter_type	ALTER type | ||||
| 	 * @param	string	$table		Table name | ||||
| 	 * @param	mixed	$field		Column definition | ||||
| 	 * @return	string|string[] | ||||
| 	 */ | ||||
| 	protected function _alter_table($alter_type, $table, $field) | ||||
|  	{ | ||||
| 		if (in_array($alter_type, array('DROP', 'ADD'), TRUE)) | ||||
| 		{ | ||||
| 			return parent::_alter_table($alter_type, $table, $field); | ||||
| 		} | ||||
|  | ||||
| 		$sql = 'ALTER TABLE '.$this->db->escape_identifiers($table); | ||||
| 		$sqls = array(); | ||||
| 		for ($i = 0, $c = count($field); $i < $c; $i++) | ||||
| 		{ | ||||
| 			if ($field[$i]['_literal'] !== FALSE) | ||||
| 			{ | ||||
| 				return FALSE; | ||||
| 			} | ||||
|  | ||||
| 			if (isset($field[$i]['type'])) | ||||
| 			{ | ||||
| 				$sqls[] = $sql.' ALTER COLUMN '.$this->db->escape_identifiers($field[$i]['name']) | ||||
| 					.' TYPE '.$field[$i]['type'].$field[$i]['length']; | ||||
| 			} | ||||
|  | ||||
| 			if ( ! empty($field[$i]['default'])) | ||||
| 			{ | ||||
| 				$sqls[] = $sql.' ALTER COLUMN '.$this->db->escape_identifiers($field[$i]['name']) | ||||
| 					.' SET '.$field[$i]['default']; | ||||
| 			} | ||||
|  | ||||
| 			if (isset($field[$i]['null'])) | ||||
| 			{ | ||||
| 				$sqls[] = 'UPDATE "RDB$RELATION_FIELDS" SET "RDB$NULL_FLAG" = ' | ||||
| 					.($field[$i]['null'] === TRUE ? 'NULL' : '1') | ||||
| 					.' WHERE "RDB$FIELD_NAME" = '.$this->db->escape($field[$i]['name']) | ||||
| 					.' AND "RDB$RELATION_NAME" = '.$this->db->escape($table); | ||||
| 			} | ||||
|  | ||||
| 			if ( ! empty($field[$i]['new_name'])) | ||||
| 			{ | ||||
| 				$sqls[] = $sql.' ALTER COLUMN '.$this->db->escape_identifiers($field[$i]['name']) | ||||
| 					.' TO '.$this->db->escape_identifiers($field[$i]['new_name']); | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		return $sqls; | ||||
|  	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Process column | ||||
| 	 * | ||||
| 	 * @param	array	$field | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _process_column($field) | ||||
| 	{ | ||||
| 		return $this->db->escape_identifiers($field['name']) | ||||
| 			.' '.$field['type'].$field['length'] | ||||
| 			.$field['null'] | ||||
| 			.$field['unique'] | ||||
| 			.$field['default']; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Field attribute TYPE | ||||
| 	 * | ||||
| 	 * Performs a data type mapping between different databases. | ||||
| 	 * | ||||
| 	 * @param	array	&$attributes | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	protected function _attr_type(&$attributes) | ||||
| 	{ | ||||
| 		switch (strtoupper($attributes['TYPE'])) | ||||
| 		{ | ||||
| 			case 'TINYINT': | ||||
| 				$attributes['TYPE'] = 'SMALLINT'; | ||||
| 				$attributes['UNSIGNED'] = FALSE; | ||||
| 				return; | ||||
| 			case 'MEDIUMINT': | ||||
| 				$attributes['TYPE'] = 'INTEGER'; | ||||
| 				$attributes['UNSIGNED'] = FALSE; | ||||
| 				return; | ||||
| 			case 'INT': | ||||
| 				$attributes['TYPE'] = 'INTEGER'; | ||||
| 				return; | ||||
| 			case 'BIGINT': | ||||
| 				$attributes['TYPE'] = 'INT64'; | ||||
| 				return; | ||||
| 			default: return; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Field attribute AUTO_INCREMENT | ||||
| 	 * | ||||
| 	 * @param	array	&$attributes | ||||
| 	 * @param	array	&$field | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	protected function _attr_auto_increment(&$attributes, &$field) | ||||
| 	{ | ||||
| 		// Not supported | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										244
									
								
								system/database/drivers/pdo/subdrivers/pdo_ibm_driver.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										244
									
								
								system/database/drivers/pdo/subdrivers/pdo_ibm_driver.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,244 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/) | ||||
|  * @license	https://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 3.0.0 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * PDO IBM DB2 Database Adapter Class | ||||
|  * | ||||
|  * Note: _DB is an extender class that the app controller | ||||
|  * creates dynamically based on whether the query builder | ||||
|  * class is being used or not. | ||||
|  * | ||||
|  * @package		CodeIgniter | ||||
|  * @subpackage	Drivers | ||||
|  * @category	Database | ||||
|  * @author		EllisLab Dev Team | ||||
|  * @link		https://codeigniter.com/user_guide/database/ | ||||
|  */ | ||||
| class CI_DB_pdo_ibm_driver extends CI_DB_pdo_driver { | ||||
|  | ||||
| 	/** | ||||
| 	 * Sub-driver | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	public $subdriver = 'ibm'; | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Class constructor | ||||
| 	 * | ||||
| 	 * Builds the DSN if not already set. | ||||
| 	 * | ||||
| 	 * @param	array	$params | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	public function __construct($params) | ||||
| 	{ | ||||
| 		parent::__construct($params); | ||||
|  | ||||
| 		if (empty($this->dsn)) | ||||
| 		{ | ||||
| 			$this->dsn = 'ibm:'; | ||||
|  | ||||
| 			// Pre-defined DSN | ||||
| 			if (empty($this->hostname) && empty($this->HOSTNAME) && empty($this->port) && empty($this->PORT)) | ||||
| 			{ | ||||
| 				if (isset($this->DSN)) | ||||
| 				{ | ||||
| 					$this->dsn .= 'DSN='.$this->DSN; | ||||
| 				} | ||||
| 				elseif ( ! empty($this->database)) | ||||
| 				{ | ||||
| 					$this->dsn .= 'DSN='.$this->database; | ||||
| 				} | ||||
|  | ||||
| 				return; | ||||
| 			} | ||||
|  | ||||
| 			$this->dsn .= 'DRIVER='.(isset($this->DRIVER) ? '{'.$this->DRIVER.'}' : '{IBM DB2 ODBC DRIVER}').';'; | ||||
|  | ||||
| 			if (isset($this->DATABASE)) | ||||
| 			{ | ||||
| 				$this->dsn .= 'DATABASE='.$this->DATABASE.';'; | ||||
| 			} | ||||
| 			elseif ( ! empty($this->database)) | ||||
| 			{ | ||||
| 				$this->dsn .= 'DATABASE='.$this->database.';'; | ||||
| 			} | ||||
|  | ||||
| 			if (isset($this->HOSTNAME)) | ||||
| 			{ | ||||
| 				$this->dsn .= 'HOSTNAME='.$this->HOSTNAME.';'; | ||||
| 			} | ||||
| 			else | ||||
| 			{ | ||||
| 				$this->dsn .= 'HOSTNAME='.(empty($this->hostname) ? '127.0.0.1;' : $this->hostname.';'); | ||||
| 			} | ||||
|  | ||||
| 			if (isset($this->PORT)) | ||||
| 			{ | ||||
| 				$this->dsn .= 'PORT='.$this->port.';'; | ||||
| 			} | ||||
| 			elseif ( ! empty($this->port)) | ||||
| 			{ | ||||
| 				$this->dsn .= ';PORT='.$this->port.';'; | ||||
| 			} | ||||
|  | ||||
| 			$this->dsn .= 'PROTOCOL='.(isset($this->PROTOCOL) ? $this->PROTOCOL.';' : 'TCPIP;'); | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Show table query | ||||
| 	 * | ||||
| 	 * Generates a platform-specific query string so that the table names can be fetched | ||||
| 	 * | ||||
| 	 * @param	bool	$prefix_limit | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _list_tables($prefix_limit = FALSE) | ||||
| 	{ | ||||
| 		$sql = 'SELECT "tabname" FROM "syscat"."tables" | ||||
| 			WHERE "type" = \'T\' AND LOWER("tabschema") = '.$this->escape(strtolower($this->database)); | ||||
|  | ||||
| 		if ($prefix_limit === TRUE && $this->dbprefix !== '') | ||||
| 		{ | ||||
| 			$sql .= ' AND "tabname" LIKE \''.$this->escape_like_str($this->dbprefix)."%' " | ||||
| 				.sprintf($this->_like_escape_str, $this->_like_escape_chr); | ||||
| 		} | ||||
|  | ||||
| 		return $sql; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Show column query | ||||
| 	 * | ||||
| 	 * Generates a platform-specific query string so that the column names can be fetched | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	protected function _list_columns($table = '') | ||||
| 	{ | ||||
| 		return 'SELECT "colname" FROM "syscat"."columns" | ||||
| 			WHERE LOWER("tabschema") = '.$this->escape(strtolower($this->database)).' | ||||
| 				AND LOWER("tabname") = '.$this->escape(strtolower($table)); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Returns an object with field data | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	public function field_data($table) | ||||
| 	{ | ||||
| 		$sql = 'SELECT "colname" AS "name", "typename" AS "type", "default" AS "default", "length" AS "max_length", | ||||
| 				CASE "keyseq" WHEN NULL THEN 0 ELSE 1 END AS "primary_key" | ||||
| 			FROM "syscat"."columns" | ||||
| 			WHERE LOWER("tabschema") = '.$this->escape(strtolower($this->database)).' | ||||
| 				AND LOWER("tabname") = '.$this->escape(strtolower($table)).' | ||||
| 			ORDER BY "colno"'; | ||||
|  | ||||
| 		return (($query = $this->query($sql)) !== FALSE) | ||||
| 			? $query->result_object() | ||||
| 			: FALSE; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Update statement | ||||
| 	 * | ||||
| 	 * Generates a platform-specific update string from the supplied data | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @param	array	$values | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _update($table, $values) | ||||
| 	{ | ||||
| 		$this->qb_limit = FALSE; | ||||
| 		$this->qb_orderby = array(); | ||||
| 		return parent::_update($table, $values); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Delete statement | ||||
| 	 * | ||||
| 	 * Generates a platform-specific delete string from the supplied data | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _delete($table) | ||||
| 	{ | ||||
| 		$this->qb_limit = FALSE; | ||||
| 		return parent::_delete($table); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * LIMIT | ||||
| 	 * | ||||
| 	 * Generates a platform-specific LIMIT clause | ||||
| 	 * | ||||
| 	 * @param	string	$sql	SQL Query | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _limit($sql) | ||||
| 	{ | ||||
| 		$sql .= ' FETCH FIRST '.($this->qb_limit + $this->qb_offset).' ROWS ONLY'; | ||||
|  | ||||
| 		return ($this->qb_offset) | ||||
| 			? 'SELECT * FROM ('.$sql.') WHERE rownum > '.$this->qb_offset | ||||
| 			: $sql; | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										154
									
								
								system/database/drivers/pdo/subdrivers/pdo_ibm_forge.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										154
									
								
								system/database/drivers/pdo/subdrivers/pdo_ibm_forge.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,154 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/) | ||||
|  * @license	https://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 3.0.0 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * PDO IBM DB2 Forge Class | ||||
|  * | ||||
|  * @category	Database | ||||
|  * @author		EllisLab Dev Team | ||||
|  * @link		https://codeigniter.com/user_guide/database/ | ||||
|  */ | ||||
| class CI_DB_pdo_ibm_forge extends CI_DB_pdo_forge { | ||||
|  | ||||
| 	/** | ||||
| 	 * RENAME TABLE IF statement | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_rename_table	= 'RENAME TABLE %s TO %s'; | ||||
|  | ||||
| 	/** | ||||
| 	 * UNSIGNED support | ||||
| 	 * | ||||
| 	 * @var	array | ||||
| 	 */ | ||||
| 	protected $_unsigned		= array( | ||||
| 		'SMALLINT'	=> 'INTEGER', | ||||
| 		'INT'		=> 'BIGINT', | ||||
| 		'INTEGER'	=> 'BIGINT' | ||||
| 	); | ||||
|  | ||||
| 	/** | ||||
| 	 * DEFAULT value representation in CREATE/ALTER TABLE statements | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_default		= FALSE; | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * ALTER TABLE | ||||
| 	 * | ||||
| 	 * @param	string	$alter_type	ALTER type | ||||
| 	 * @param	string	$table		Table name | ||||
| 	 * @param	mixed	$field		Column definition | ||||
| 	 * @return	string|string[] | ||||
| 	 */ | ||||
| 	protected function _alter_table($alter_type, $table, $field) | ||||
| 	{ | ||||
| 		if ($alter_type === 'CHANGE') | ||||
| 		{ | ||||
| 			$alter_type = 'MODIFY'; | ||||
| 		} | ||||
|  | ||||
| 		return parent::_alter_table($alter_type, $table, $field); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Field attribute TYPE | ||||
| 	 * | ||||
| 	 * Performs a data type mapping between different databases. | ||||
| 	 * | ||||
| 	 * @param	array	&$attributes | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	protected function _attr_type(&$attributes) | ||||
| 	{ | ||||
| 		switch (strtoupper($attributes['TYPE'])) | ||||
| 		{ | ||||
| 			case 'TINYINT': | ||||
| 				$attributes['TYPE'] = 'SMALLINT'; | ||||
| 				$attributes['UNSIGNED'] = FALSE; | ||||
| 				return; | ||||
| 			case 'MEDIUMINT': | ||||
| 				$attributes['TYPE'] = 'INTEGER'; | ||||
| 				$attributes['UNSIGNED'] = FALSE; | ||||
| 				return; | ||||
| 			default: return; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Field attribute UNIQUE | ||||
| 	 * | ||||
| 	 * @param	array	&$attributes | ||||
| 	 * @param	array	&$field | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	protected function _attr_unique(&$attributes, &$field) | ||||
| 	{ | ||||
| 		if ( ! empty($attributes['UNIQUE']) && $attributes['UNIQUE'] === TRUE) | ||||
| 		{ | ||||
| 			$field['unique'] = ' UNIQUE'; | ||||
|  | ||||
| 			// UNIQUE must be used with NOT NULL | ||||
| 			$field['null'] = ' NOT NULL'; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Field attribute AUTO_INCREMENT | ||||
| 	 * | ||||
| 	 * @param	array	&$attributes | ||||
| 	 * @param	array	&$field | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	protected function _attr_auto_increment(&$attributes, &$field) | ||||
| 	{ | ||||
| 		// Not supported | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										309
									
								
								system/database/drivers/pdo/subdrivers/pdo_informix_driver.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										309
									
								
								system/database/drivers/pdo/subdrivers/pdo_informix_driver.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,309 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/) | ||||
|  * @license	https://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 3.0.0 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * PDO Informix Database Adapter Class | ||||
|  * | ||||
|  * Note: _DB is an extender class that the app controller | ||||
|  * creates dynamically based on whether the query builder | ||||
|  * class is being used or not. | ||||
|  * | ||||
|  * @package		CodeIgniter | ||||
|  * @subpackage	Drivers | ||||
|  * @category	Database | ||||
|  * @author		EllisLab Dev Team | ||||
|  * @link		https://codeigniter.com/user_guide/database/ | ||||
|  */ | ||||
| class CI_DB_pdo_informix_driver extends CI_DB_pdo_driver { | ||||
|  | ||||
| 	/** | ||||
| 	 * Sub-driver | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	public $subdriver = 'informix'; | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * ORDER BY random keyword | ||||
| 	 * | ||||
| 	 * @var	array | ||||
| 	 */ | ||||
| 	protected $_random_keyword = array('ASC', 'ASC'); // Currently not supported | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Class constructor | ||||
| 	 * | ||||
| 	 * Builds the DSN if not already set. | ||||
| 	 * | ||||
| 	 * @param	array	$params | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	public function __construct($params) | ||||
| 	{ | ||||
| 		parent::__construct($params); | ||||
|  | ||||
| 		if (empty($this->dsn)) | ||||
| 		{ | ||||
| 			$this->dsn = 'informix:'; | ||||
|  | ||||
| 			// Pre-defined DSN | ||||
| 			if (empty($this->hostname) && empty($this->host) && empty($this->port) && empty($this->service)) | ||||
| 			{ | ||||
| 				if (isset($this->DSN)) | ||||
| 				{ | ||||
| 					$this->dsn .= 'DSN='.$this->DSN; | ||||
| 				} | ||||
| 				elseif ( ! empty($this->database)) | ||||
| 				{ | ||||
| 					$this->dsn .= 'DSN='.$this->database; | ||||
| 				} | ||||
|  | ||||
| 				return; | ||||
| 			} | ||||
|  | ||||
| 			if (isset($this->host)) | ||||
| 			{ | ||||
| 				$this->dsn .= 'host='.$this->host; | ||||
| 			} | ||||
| 			else | ||||
| 			{ | ||||
| 				$this->dsn .= 'host='.(empty($this->hostname) ? '127.0.0.1' : $this->hostname); | ||||
| 			} | ||||
|  | ||||
| 			if (isset($this->service)) | ||||
| 			{ | ||||
| 				$this->dsn .= '; service='.$this->service; | ||||
| 			} | ||||
| 			elseif ( ! empty($this->port)) | ||||
| 			{ | ||||
| 				$this->dsn .= '; service='.$this->port; | ||||
| 			} | ||||
|  | ||||
| 			empty($this->database) OR $this->dsn .= '; database='.$this->database; | ||||
| 			empty($this->server) OR $this->dsn .= '; server='.$this->server; | ||||
|  | ||||
| 			$this->dsn .= '; protocol='.(isset($this->protocol) ? $this->protocol : 'onsoctcp') | ||||
| 				.'; EnableScrollableCursors=1'; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Show table query | ||||
| 	 * | ||||
| 	 * Generates a platform-specific query string so that the table names can be fetched | ||||
| 	 * | ||||
| 	 * @param	bool	$prefix_limit | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _list_tables($prefix_limit = FALSE) | ||||
| 	{ | ||||
| 		$sql = 'SELECT "tabname" FROM "systables" | ||||
| 			WHERE "tabid" > 99 AND "tabtype" = \'T\' AND LOWER("owner") = '.$this->escape(strtolower($this->username)); | ||||
|  | ||||
| 		if ($prefix_limit === TRUE && $this->dbprefix !== '') | ||||
| 		{ | ||||
| 			$sql .= ' AND "tabname" LIKE \''.$this->escape_like_str($this->dbprefix)."%' " | ||||
| 				.sprintf($this->_like_escape_str, $this->_like_escape_chr); | ||||
| 		} | ||||
|  | ||||
| 		return $sql; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Show column query | ||||
| 	 * | ||||
| 	 * Generates a platform-specific query string so that the column names can be fetched | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _list_columns($table = '') | ||||
| 	{ | ||||
| 		if (strpos($table, '.') !== FALSE) | ||||
| 		{ | ||||
| 			sscanf($table, '%[^.].%s', $owner, $table); | ||||
| 		} | ||||
| 		else | ||||
| 		{ | ||||
| 			$owner = $this->username; | ||||
| 		} | ||||
|  | ||||
| 		return 'SELECT "colname" FROM "systables", "syscolumns" | ||||
| 			WHERE "systables"."tabid" = "syscolumns"."tabid" | ||||
| 				AND "systables"."tabtype" = \'T\' | ||||
| 				AND LOWER("systables"."owner") = '.$this->escape(strtolower($owner)).' | ||||
| 				AND LOWER("systables"."tabname") = '.$this->escape(strtolower($table)); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Returns an object with field data | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	public function field_data($table) | ||||
| 	{ | ||||
| 		$sql = 'SELECT "syscolumns"."colname" AS "name", | ||||
| 				CASE "syscolumns"."coltype" | ||||
| 					WHEN 0 THEN \'CHAR\' | ||||
| 					WHEN 1 THEN \'SMALLINT\' | ||||
| 					WHEN 2 THEN \'INTEGER\' | ||||
| 					WHEN 3 THEN \'FLOAT\' | ||||
| 					WHEN 4 THEN \'SMALLFLOAT\' | ||||
| 					WHEN 5 THEN \'DECIMAL\' | ||||
| 					WHEN 6 THEN \'SERIAL\' | ||||
| 					WHEN 7 THEN \'DATE\' | ||||
| 					WHEN 8 THEN \'MONEY\' | ||||
| 					WHEN 9 THEN \'NULL\' | ||||
| 					WHEN 10 THEN \'DATETIME\' | ||||
| 					WHEN 11 THEN \'BYTE\' | ||||
| 					WHEN 12 THEN \'TEXT\' | ||||
| 					WHEN 13 THEN \'VARCHAR\' | ||||
| 					WHEN 14 THEN \'INTERVAL\' | ||||
| 					WHEN 15 THEN \'NCHAR\' | ||||
| 					WHEN 16 THEN \'NVARCHAR\' | ||||
| 					WHEN 17 THEN \'INT8\' | ||||
| 					WHEN 18 THEN \'SERIAL8\' | ||||
| 					WHEN 19 THEN \'SET\' | ||||
| 					WHEN 20 THEN \'MULTISET\' | ||||
| 					WHEN 21 THEN \'LIST\' | ||||
| 					WHEN 22 THEN \'Unnamed ROW\' | ||||
| 					WHEN 40 THEN \'LVARCHAR\' | ||||
| 					WHEN 41 THEN \'BLOB/CLOB/BOOLEAN\' | ||||
| 					WHEN 4118 THEN \'Named ROW\' | ||||
| 					ELSE "syscolumns"."coltype" | ||||
| 				END AS "type", | ||||
| 				"syscolumns"."collength" as "max_length", | ||||
| 				CASE "sysdefaults"."type" | ||||
| 					WHEN \'L\' THEN "sysdefaults"."default" | ||||
| 					ELSE NULL | ||||
| 				END AS "default" | ||||
| 			FROM "syscolumns", "systables", "sysdefaults" | ||||
| 			WHERE "syscolumns"."tabid" = "systables"."tabid" | ||||
| 				AND "systables"."tabid" = "sysdefaults"."tabid" | ||||
| 				AND "syscolumns"."colno" = "sysdefaults"."colno" | ||||
| 				AND "systables"."tabtype" = \'T\' | ||||
| 				AND LOWER("systables"."owner") = '.$this->escape(strtolower($this->username)).' | ||||
| 				AND LOWER("systables"."tabname") = '.$this->escape(strtolower($table)).' | ||||
| 			ORDER BY "syscolumns"."colno"'; | ||||
|  | ||||
| 		return (($query = $this->query($sql)) !== FALSE) | ||||
| 			? $query->result_object() | ||||
| 			: FALSE; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Update statement | ||||
| 	 * | ||||
| 	 * Generates a platform-specific update string from the supplied data | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @param	array	$values | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _update($table, $values) | ||||
| 	{ | ||||
| 		$this->qb_limit = FALSE; | ||||
| 		$this->qb_orderby = array(); | ||||
| 		return parent::_update($table, $values); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Truncate statement | ||||
| 	 * | ||||
| 	 * Generates a platform-specific truncate string from the supplied data | ||||
| 	 * | ||||
| 	 * If the database does not support the TRUNCATE statement, | ||||
| 	 * then this method maps to 'DELETE FROM table' | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _truncate($table) | ||||
| 	{ | ||||
| 		return 'TRUNCATE TABLE ONLY '.$table; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Delete statement | ||||
| 	 * | ||||
| 	 * Generates a platform-specific delete string from the supplied data | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _delete($table) | ||||
| 	{ | ||||
| 		$this->qb_limit = FALSE; | ||||
| 		return parent::_delete($table); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * LIMIT | ||||
| 	 * | ||||
| 	 * Generates a platform-specific LIMIT clause | ||||
| 	 * | ||||
| 	 * @param	string	$sql	$SQL Query | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _limit($sql) | ||||
| 	{ | ||||
| 		$select = 'SELECT '.($this->qb_offset ? 'SKIP '.$this->qb_offset : '').'FIRST '.$this->qb_limit.' '; | ||||
| 		return preg_replace('/^(SELECT\s)/i', $select, $sql, 1); | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										163
									
								
								system/database/drivers/pdo/subdrivers/pdo_informix_forge.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										163
									
								
								system/database/drivers/pdo/subdrivers/pdo_informix_forge.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,163 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/) | ||||
|  * @license	https://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 3.0.0 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * PDO Informix Forge Class | ||||
|  * | ||||
|  * @category	Database | ||||
|  * @author		EllisLab Dev Team | ||||
|  * @link		https://codeigniter.com/user_guide/database/ | ||||
|  */ | ||||
| class CI_DB_pdo_informix_forge extends CI_DB_pdo_forge { | ||||
|  | ||||
| 	/** | ||||
| 	 * RENAME TABLE statement | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_rename_table	= 'RENAME TABLE %s TO %s'; | ||||
|  | ||||
| 	/** | ||||
| 	 * UNSIGNED support | ||||
| 	 * | ||||
| 	 * @var	array | ||||
| 	 */ | ||||
| 	protected $_unsigned		= array( | ||||
| 		'SMALLINT'	=> 'INTEGER', | ||||
| 		'INT'		=> 'BIGINT', | ||||
| 		'INTEGER'	=> 'BIGINT', | ||||
| 		'REAL'		=> 'DOUBLE PRECISION', | ||||
| 		'SMALLFLOAT'	=> 'DOUBLE PRECISION' | ||||
| 	); | ||||
|  | ||||
| 	/** | ||||
| 	 * DEFAULT value representation in CREATE/ALTER TABLE statements | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_default		= ', '; | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * ALTER TABLE | ||||
| 	 * | ||||
| 	 * @param	string	$alter_type	ALTER type | ||||
| 	 * @param	string	$table		Table name | ||||
| 	 * @param	mixed	$field		Column definition | ||||
| 	 * @return	string|string[] | ||||
| 	 */ | ||||
| 	protected function _alter_table($alter_type, $table, $field) | ||||
| 	{ | ||||
| 		if ($alter_type === 'CHANGE') | ||||
| 		{ | ||||
| 			$alter_type = 'MODIFY'; | ||||
| 		} | ||||
|  | ||||
| 		return parent::_alter_table($alter_type, $table, $field); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Field attribute TYPE | ||||
| 	 * | ||||
| 	 * Performs a data type mapping between different databases. | ||||
| 	 * | ||||
| 	 * @param	array	&$attributes | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	protected function _attr_type(&$attributes) | ||||
| 	{ | ||||
| 		switch (strtoupper($attributes['TYPE'])) | ||||
| 		{ | ||||
| 			case 'TINYINT': | ||||
| 				$attributes['TYPE'] = 'SMALLINT'; | ||||
| 				$attributes['UNSIGNED'] = FALSE; | ||||
| 				return; | ||||
| 			case 'MEDIUMINT': | ||||
| 				$attributes['TYPE'] = 'INTEGER'; | ||||
| 				$attributes['UNSIGNED'] = FALSE; | ||||
| 				return; | ||||
| 			case 'BYTE': | ||||
| 			case 'TEXT': | ||||
| 			case 'BLOB': | ||||
| 			case 'CLOB': | ||||
| 				$attributes['UNIQUE'] = FALSE; | ||||
| 				if (isset($attributes['DEFAULT'])) | ||||
| 				{ | ||||
| 					unset($attributes['DEFAULT']); | ||||
| 				} | ||||
| 				return; | ||||
| 			default: return; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Field attribute UNIQUE | ||||
| 	 * | ||||
| 	 * @param	array	&$attributes | ||||
| 	 * @param	array	&$field | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	protected function _attr_unique(&$attributes, &$field) | ||||
| 	{ | ||||
| 		if ( ! empty($attributes['UNIQUE']) && $attributes['UNIQUE'] === TRUE) | ||||
| 		{ | ||||
| 			$field['unique'] = ' UNIQUE CONSTRAINT '.$this->db->escape_identifiers($field['name']); | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Field attribute AUTO_INCREMENT | ||||
| 	 * | ||||
| 	 * @param	array	&$attributes | ||||
| 	 * @param	array	&$field | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	protected function _attr_auto_increment(&$attributes, &$field) | ||||
| 	{ | ||||
| 		// Not supported | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										379
									
								
								system/database/drivers/pdo/subdrivers/pdo_mysql_driver.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										379
									
								
								system/database/drivers/pdo/subdrivers/pdo_mysql_driver.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,379 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/) | ||||
|  * @license	https://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 3.0.0 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * PDO MySQL Database Adapter Class | ||||
|  * | ||||
|  * Note: _DB is an extender class that the app controller | ||||
|  * creates dynamically based on whether the query builder | ||||
|  * class is being used or not. | ||||
|  * | ||||
|  * @package		CodeIgniter | ||||
|  * @subpackage	Drivers | ||||
|  * @category	Database | ||||
|  * @author		EllisLab Dev Team | ||||
|  * @link		https://codeigniter.com/user_guide/database/ | ||||
|  */ | ||||
| class CI_DB_pdo_mysql_driver extends CI_DB_pdo_driver { | ||||
|  | ||||
| 	/** | ||||
| 	 * Sub-driver | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	public $subdriver = 'mysql'; | ||||
|  | ||||
| 	/** | ||||
| 	 * Compression flag | ||||
| 	 * | ||||
| 	 * @var	bool | ||||
| 	 */ | ||||
| 	public $compress = FALSE; | ||||
|  | ||||
| 	/** | ||||
| 	 * Strict ON flag | ||||
| 	 * | ||||
| 	 * Whether we're running in strict SQL mode. | ||||
| 	 * | ||||
| 	 * @var	bool | ||||
| 	 */ | ||||
| 	public $stricton; | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Identifier escape character | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_escape_char = '`'; | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Class constructor | ||||
| 	 * | ||||
| 	 * Builds the DSN if not already set. | ||||
| 	 * | ||||
| 	 * @param	array	$params | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	public function __construct($params) | ||||
| 	{ | ||||
| 		parent::__construct($params); | ||||
|  | ||||
| 		if (empty($this->dsn)) | ||||
| 		{ | ||||
| 			$this->dsn = 'mysql:host='.(empty($this->hostname) ? '127.0.0.1' : $this->hostname); | ||||
|  | ||||
| 			empty($this->port) OR $this->dsn .= ';port='.$this->port; | ||||
| 			empty($this->database) OR $this->dsn .= ';dbname='.$this->database; | ||||
| 			empty($this->char_set) OR $this->dsn .= ';charset='.$this->char_set; | ||||
| 		} | ||||
| 		elseif ( ! empty($this->char_set) && strpos($this->dsn, 'charset=', 6) === FALSE) | ||||
| 		{ | ||||
| 			$this->dsn .= ';charset='.$this->char_set; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Database connection | ||||
| 	 * | ||||
| 	 * @param	bool	$persistent | ||||
| 	 * @return	object | ||||
| 	 */ | ||||
| 	public function db_connect($persistent = FALSE) | ||||
| 	{ | ||||
| 		if (isset($this->stricton)) | ||||
| 		{ | ||||
| 			if ($this->stricton) | ||||
| 			{ | ||||
| 				$sql = 'CONCAT(@@sql_mode, ",", "STRICT_ALL_TABLES")'; | ||||
| 			} | ||||
| 			else | ||||
| 			{ | ||||
| 				$sql = 'REPLACE(REPLACE(REPLACE(REPLACE(REPLACE(REPLACE( | ||||
|                                         @@sql_mode, | ||||
|                                         "STRICT_ALL_TABLES,", ""), | ||||
|                                         ",STRICT_ALL_TABLES", ""), | ||||
|                                         "STRICT_ALL_TABLES", ""), | ||||
|                                         "STRICT_TRANS_TABLES,", ""), | ||||
|                                         ",STRICT_TRANS_TABLES", ""), | ||||
|                                         "STRICT_TRANS_TABLES", "")'; | ||||
| 			} | ||||
|  | ||||
| 			if ( ! empty($sql)) | ||||
| 			{ | ||||
| 				if (empty($this->options[PDO::MYSQL_ATTR_INIT_COMMAND])) | ||||
| 				{ | ||||
| 					$this->options[PDO::MYSQL_ATTR_INIT_COMMAND] = 'SET SESSION sql_mode = '.$sql; | ||||
| 				} | ||||
| 				else | ||||
| 				{ | ||||
| 					$this->options[PDO::MYSQL_ATTR_INIT_COMMAND] .= ', @@session.sql_mode = '.$sql; | ||||
| 				} | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		if ($this->compress === TRUE) | ||||
| 		{ | ||||
| 			$this->options[PDO::MYSQL_ATTR_COMPRESS] = TRUE; | ||||
| 		} | ||||
|  | ||||
| 		if (is_array($this->encrypt)) | ||||
| 		{ | ||||
| 			$ssl = array(); | ||||
| 			empty($this->encrypt['ssl_key'])    OR $ssl[PDO::MYSQL_ATTR_SSL_KEY]    = $this->encrypt['ssl_key']; | ||||
| 			empty($this->encrypt['ssl_cert'])   OR $ssl[PDO::MYSQL_ATTR_SSL_CERT]   = $this->encrypt['ssl_cert']; | ||||
| 			empty($this->encrypt['ssl_ca'])     OR $ssl[PDO::MYSQL_ATTR_SSL_CA]     = $this->encrypt['ssl_ca']; | ||||
| 			empty($this->encrypt['ssl_capath']) OR $ssl[PDO::MYSQL_ATTR_SSL_CAPATH] = $this->encrypt['ssl_capath']; | ||||
| 			empty($this->encrypt['ssl_cipher']) OR $ssl[PDO::MYSQL_ATTR_SSL_CIPHER] = $this->encrypt['ssl_cipher']; | ||||
|  | ||||
| 			if (defined('PDO::MYSQL_ATTR_SSL_VERIFY_SERVER_CERT') && isset($this->encrypt['ssl_verify'])) | ||||
| 			{ | ||||
| 				$ssl[PDO::MYSQL_ATTR_SSL_VERIFY_SERVER_CERT] = $this->encrypt['ssl_verify']; | ||||
| 			} | ||||
|  | ||||
| 			// DO NOT use array_merge() here! | ||||
| 			// It re-indexes numeric keys and the PDO_MYSQL_ATTR_SSL_* constants are integers. | ||||
| 			empty($ssl) OR $this->options += $ssl; | ||||
| 		} | ||||
|  | ||||
| 		// Prior to version 5.7.3, MySQL silently downgrades to an unencrypted connection if SSL setup fails | ||||
| 		if ( | ||||
| 			($pdo = parent::db_connect($persistent)) !== FALSE | ||||
| 			&& ! empty($ssl) | ||||
| 			&& version_compare($pdo->getAttribute(PDO::ATTR_CLIENT_VERSION), '5.7.3', '<=') | ||||
| 			&& empty($pdo->query("SHOW STATUS LIKE 'ssl_cipher'")->fetchObject()->Value) | ||||
| 		) | ||||
| 		{ | ||||
| 			$message = 'PDO_MYSQL was configured for an SSL connection, but got an unencrypted connection instead!'; | ||||
| 			log_message('error', $message); | ||||
| 			return ($this->db_debug) ? $this->display_error($message, '', TRUE) : FALSE; | ||||
| 		} | ||||
|  | ||||
| 		return $pdo; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Select the database | ||||
| 	 * | ||||
| 	 * @param	string	$database | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	public function db_select($database = '') | ||||
| 	{ | ||||
| 		if ($database === '') | ||||
| 		{ | ||||
| 			$database = $this->database; | ||||
| 		} | ||||
|  | ||||
| 		if (FALSE !== $this->simple_query('USE '.$this->escape_identifiers($database))) | ||||
| 		{ | ||||
| 			$this->database = $database; | ||||
| 			$this->data_cache = array(); | ||||
| 			return TRUE; | ||||
| 		} | ||||
|  | ||||
| 		return FALSE; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Begin Transaction | ||||
| 	 * | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	protected function _trans_begin() | ||||
| 	{ | ||||
| 		$this->conn_id->setAttribute(PDO::ATTR_AUTOCOMMIT, FALSE); | ||||
| 		return $this->conn_id->beginTransaction(); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Commit Transaction | ||||
| 	 * | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	protected function _trans_commit() | ||||
| 	{ | ||||
| 		if ($this->conn_id->commit()) | ||||
| 		{ | ||||
| 			$this->conn_id->setAttribute(PDO::ATTR_AUTOCOMMIT, TRUE); | ||||
| 			return TRUE; | ||||
| 		} | ||||
|  | ||||
| 		return FALSE; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Rollback Transaction | ||||
| 	 * | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	protected function _trans_rollback() | ||||
| 	{ | ||||
| 		if ($this->conn_id->rollBack()) | ||||
| 		{ | ||||
| 			$this->conn_id->setAttribute(PDO::ATTR_AUTOCOMMIT, TRUE); | ||||
| 			return TRUE; | ||||
| 		} | ||||
|  | ||||
| 		return FALSE; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Show table query | ||||
| 	 * | ||||
| 	 * Generates a platform-specific query string so that the table names can be fetched | ||||
| 	 * | ||||
| 	 * @param	bool	$prefix_limit | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _list_tables($prefix_limit = FALSE) | ||||
| 	{ | ||||
| 		$sql = 'SHOW TABLES FROM '.$this->_escape_char.$this->database.$this->_escape_char; | ||||
|  | ||||
| 		if ($prefix_limit === TRUE && $this->dbprefix !== '') | ||||
| 		{ | ||||
| 			return $sql." LIKE '".$this->escape_like_str($this->dbprefix)."%'"; | ||||
| 		} | ||||
|  | ||||
| 		return $sql; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Show column query | ||||
| 	 * | ||||
| 	 * Generates a platform-specific query string so that the column names can be fetched | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _list_columns($table = '') | ||||
| 	{ | ||||
| 		return 'SHOW COLUMNS FROM '.$this->protect_identifiers($table, TRUE, NULL, FALSE); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Returns an object with field data | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	public function field_data($table) | ||||
| 	{ | ||||
| 		if (($query = $this->query('SHOW COLUMNS FROM '.$this->protect_identifiers($table, TRUE, NULL, FALSE))) === FALSE) | ||||
| 		{ | ||||
| 			return FALSE; | ||||
| 		} | ||||
| 		$query = $query->result_object(); | ||||
|  | ||||
| 		$retval = array(); | ||||
| 		for ($i = 0, $c = count($query); $i < $c; $i++) | ||||
| 		{ | ||||
| 			$retval[$i]			= new stdClass(); | ||||
| 			$retval[$i]->name		= $query[$i]->Field; | ||||
|  | ||||
| 			sscanf($query[$i]->Type, '%[a-z](%d)', | ||||
| 				$retval[$i]->type, | ||||
| 				$retval[$i]->max_length | ||||
| 			); | ||||
|  | ||||
| 			$retval[$i]->default		= $query[$i]->Default; | ||||
| 			$retval[$i]->primary_key	= (int) ($query[$i]->Key === 'PRI'); | ||||
| 		} | ||||
|  | ||||
| 		return $retval; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Truncate statement | ||||
| 	 * | ||||
| 	 * Generates a platform-specific truncate string from the supplied data | ||||
| 	 * | ||||
| 	 * If the database does not support the TRUNCATE statement, | ||||
| 	 * then this method maps to 'DELETE FROM table' | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _truncate($table) | ||||
| 	{ | ||||
| 		return 'TRUNCATE '.$table; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * FROM tables | ||||
| 	 * | ||||
| 	 * Groups tables in FROM clauses if needed, so there is no confusion | ||||
| 	 * about operator precedence. | ||||
| 	 * | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _from_tables() | ||||
| 	{ | ||||
| 		if ( ! empty($this->qb_join) && count($this->qb_from) > 1) | ||||
| 		{ | ||||
| 			return '('.implode(', ', $this->qb_from).')'; | ||||
| 		} | ||||
|  | ||||
| 		return implode(', ', $this->qb_from); | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										256
									
								
								system/database/drivers/pdo/subdrivers/pdo_mysql_forge.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										256
									
								
								system/database/drivers/pdo/subdrivers/pdo_mysql_forge.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,256 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/) | ||||
|  * @license	https://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 3.0.0 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * PDO MySQL Forge Class | ||||
|  * | ||||
|  * @category	Database | ||||
|  * @author		EllisLab Dev Team | ||||
|  * @link		https://codeigniter.com/user_guide/database/ | ||||
|  */ | ||||
| class CI_DB_pdo_mysql_forge extends CI_DB_pdo_forge { | ||||
|  | ||||
| 	/** | ||||
| 	 * CREATE DATABASE statement | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_create_database	= 'CREATE DATABASE %s CHARACTER SET %s COLLATE %s'; | ||||
|  | ||||
| 	/** | ||||
| 	 * CREATE TABLE IF statement | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_create_table_if	= 'CREATE TABLE IF NOT EXISTS'; | ||||
|  | ||||
| 	/** | ||||
| 	 * CREATE TABLE keys flag | ||||
| 	 * | ||||
| 	 * Whether table keys are created from within the | ||||
| 	 * CREATE TABLE statement. | ||||
| 	 * | ||||
| 	 * @var	bool | ||||
| 	 */ | ||||
| 	protected $_create_table_keys	= TRUE; | ||||
|  | ||||
| 	/** | ||||
| 	 * DROP TABLE IF statement | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_drop_table_if	= 'DROP TABLE IF EXISTS'; | ||||
|  | ||||
| 	/** | ||||
| 	 * UNSIGNED support | ||||
| 	 * | ||||
| 	 * @var	array | ||||
| 	 */ | ||||
| 	protected $_unsigned		= array( | ||||
| 		'TINYINT', | ||||
| 		'SMALLINT', | ||||
| 		'MEDIUMINT', | ||||
| 		'INT', | ||||
| 		'INTEGER', | ||||
| 		'BIGINT', | ||||
| 		'REAL', | ||||
| 		'DOUBLE', | ||||
| 		'DOUBLE PRECISION', | ||||
| 		'FLOAT', | ||||
| 		'DECIMAL', | ||||
| 		'NUMERIC' | ||||
| 	); | ||||
|  | ||||
| 	/** | ||||
| 	 * NULL value representation in CREATE/ALTER TABLE statements | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_null = 'NULL'; | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * CREATE TABLE attributes | ||||
| 	 * | ||||
| 	 * @param	array	$attributes	Associative array of table attributes | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _create_table_attr($attributes) | ||||
| 	{ | ||||
| 		$sql = ''; | ||||
|  | ||||
| 		foreach (array_keys($attributes) as $key) | ||||
| 		{ | ||||
| 			if (is_string($key)) | ||||
| 			{ | ||||
| 				$sql .= ' '.strtoupper($key).' = '.$attributes[$key]; | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		if ( ! empty($this->db->char_set) && ! strpos($sql, 'CHARACTER SET') && ! strpos($sql, 'CHARSET')) | ||||
| 		{ | ||||
| 			$sql .= ' DEFAULT CHARACTER SET = '.$this->db->char_set; | ||||
| 		} | ||||
|  | ||||
| 		if ( ! empty($this->db->dbcollat) && ! strpos($sql, 'COLLATE')) | ||||
| 		{ | ||||
| 			$sql .= ' COLLATE = '.$this->db->dbcollat; | ||||
| 		} | ||||
|  | ||||
| 		return $sql; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * ALTER TABLE | ||||
| 	 * | ||||
| 	 * @param	string	$alter_type	ALTER type | ||||
| 	 * @param	string	$table		Table name | ||||
| 	 * @param	mixed	$field		Column definition | ||||
| 	 * @return	string|string[] | ||||
| 	 */ | ||||
| 	protected function _alter_table($alter_type, $table, $field) | ||||
| 	{ | ||||
| 		if ($alter_type === 'DROP') | ||||
| 		{ | ||||
| 			return parent::_alter_table($alter_type, $table, $field); | ||||
| 		} | ||||
|  | ||||
| 		$sql = 'ALTER TABLE '.$this->db->escape_identifiers($table); | ||||
| 		for ($i = 0, $c = count($field); $i < $c; $i++) | ||||
| 		{ | ||||
| 			if ($field[$i]['_literal'] !== FALSE) | ||||
| 			{ | ||||
| 				$field[$i] = ($alter_type === 'ADD') | ||||
| 						? "\n\tADD ".$field[$i]['_literal'] | ||||
| 						: "\n\tMODIFY ".$field[$i]['_literal']; | ||||
| 			} | ||||
| 			else | ||||
| 			{ | ||||
| 				if ($alter_type === 'ADD') | ||||
| 				{ | ||||
| 					$field[$i]['_literal'] = "\n\tADD "; | ||||
| 				} | ||||
| 				else | ||||
| 				{ | ||||
| 					$field[$i]['_literal'] = empty($field[$i]['new_name']) ? "\n\tMODIFY " : "\n\tCHANGE "; | ||||
| 				} | ||||
|  | ||||
| 				$field[$i] = $field[$i]['_literal'].$this->_process_column($field[$i]); | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		return array($sql.implode(',', $field)); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Process column | ||||
| 	 * | ||||
| 	 * @param	array	$field | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _process_column($field) | ||||
| 	{ | ||||
| 		$extra_clause = isset($field['after']) | ||||
| 			? ' AFTER '.$this->db->escape_identifiers($field['after']) : ''; | ||||
|  | ||||
| 		if (empty($extra_clause) && isset($field['first']) && $field['first'] === TRUE) | ||||
| 		{ | ||||
| 			$extra_clause = ' FIRST'; | ||||
| 		} | ||||
|  | ||||
| 		return $this->db->escape_identifiers($field['name']) | ||||
| 			.(empty($field['new_name']) ? '' : ' '.$this->db->escape_identifiers($field['new_name'])) | ||||
| 			.' '.$field['type'].$field['length'] | ||||
| 			.$field['unsigned'] | ||||
| 			.$field['null'] | ||||
| 			.$field['default'] | ||||
| 			.$field['auto_increment'] | ||||
| 			.$field['unique'] | ||||
| 			.(empty($field['comment']) ? '' : ' COMMENT '.$field['comment']) | ||||
| 			.$extra_clause; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Process indexes | ||||
| 	 * | ||||
| 	 * @param	string	$table	(ignored) | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _process_indexes($table) | ||||
| 	{ | ||||
| 		$sql = ''; | ||||
|  | ||||
| 		for ($i = 0, $c = count($this->keys); $i < $c; $i++) | ||||
| 		{ | ||||
| 			if (is_array($this->keys[$i])) | ||||
| 			{ | ||||
| 				for ($i2 = 0, $c2 = count($this->keys[$i]); $i2 < $c2; $i2++) | ||||
| 				{ | ||||
| 					if ( ! isset($this->fields[$this->keys[$i][$i2]])) | ||||
| 					{ | ||||
| 						unset($this->keys[$i][$i2]); | ||||
| 						continue; | ||||
| 					} | ||||
| 				} | ||||
| 			} | ||||
| 			elseif ( ! isset($this->fields[$this->keys[$i]])) | ||||
| 			{ | ||||
| 				unset($this->keys[$i]); | ||||
| 				continue; | ||||
| 			} | ||||
|  | ||||
| 			is_array($this->keys[$i]) OR $this->keys[$i] = array($this->keys[$i]); | ||||
|  | ||||
| 			$sql .= ",\n\tKEY ".$this->db->escape_identifiers(implode('_', $this->keys[$i])) | ||||
| 				.' ('.implode(', ', $this->db->escape_identifiers($this->keys[$i])).')'; | ||||
| 		} | ||||
|  | ||||
| 		$this->keys = array(); | ||||
|  | ||||
| 		return $sql; | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										326
									
								
								system/database/drivers/pdo/subdrivers/pdo_oci_driver.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										326
									
								
								system/database/drivers/pdo/subdrivers/pdo_oci_driver.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,326 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/) | ||||
|  * @license	https://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 3.0.0 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * PDO Oracle Database Adapter Class | ||||
|  * | ||||
|  * Note: _DB is an extender class that the app controller | ||||
|  * creates dynamically based on whether the query builder | ||||
|  * class is being used or not. | ||||
|  * | ||||
|  * @package		CodeIgniter | ||||
|  * @subpackage	Drivers | ||||
|  * @category	Database | ||||
|  * @author		EllisLab Dev Team | ||||
|  * @link		https://codeigniter.com/user_guide/database/ | ||||
|  */ | ||||
| class CI_DB_pdo_oci_driver extends CI_DB_pdo_driver { | ||||
|  | ||||
| 	/** | ||||
| 	 * Sub-driver | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	public $subdriver = 'oci'; | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * List of reserved identifiers | ||||
| 	 * | ||||
| 	 * Identifiers that must NOT be escaped. | ||||
| 	 * | ||||
| 	 * @var	string[] | ||||
| 	 */ | ||||
| 	protected $_reserved_identifiers = array('*', 'rownum'); | ||||
|  | ||||
| 	/** | ||||
| 	 * ORDER BY random keyword | ||||
| 	 * | ||||
| 	 * @var	array | ||||
| 	 */ | ||||
| 	protected $_random_keyword = array('ASC', 'ASC'); // Currently not supported | ||||
|  | ||||
| 	/** | ||||
| 	 * COUNT string | ||||
| 	 * | ||||
| 	 * @used-by	CI_DB_driver::count_all() | ||||
| 	 * @used-by	CI_DB_query_builder::count_all_results() | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_count_string = 'SELECT COUNT(1) AS '; | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Class constructor | ||||
| 	 * | ||||
| 	 * Builds the DSN if not already set. | ||||
| 	 * | ||||
| 	 * @param	array	$params | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	public function __construct($params) | ||||
| 	{ | ||||
| 		parent::__construct($params); | ||||
|  | ||||
| 		if (empty($this->dsn)) | ||||
| 		{ | ||||
| 			$this->dsn = 'oci:dbname='; | ||||
|  | ||||
| 			// Oracle has a slightly different PDO DSN format (Easy Connect), | ||||
| 			// which also supports pre-defined DSNs. | ||||
| 			if (empty($this->hostname) && empty($this->port)) | ||||
| 			{ | ||||
| 				$this->dsn .= $this->database; | ||||
| 			} | ||||
| 			else | ||||
| 			{ | ||||
| 				$this->dsn .= '//'.(empty($this->hostname) ? '127.0.0.1' : $this->hostname) | ||||
| 					.(empty($this->port) ? '' : ':'.$this->port).'/'; | ||||
|  | ||||
| 				empty($this->database) OR $this->dsn .= $this->database; | ||||
| 			} | ||||
|  | ||||
| 			empty($this->char_set) OR $this->dsn .= ';charset='.$this->char_set; | ||||
| 		} | ||||
| 		elseif ( ! empty($this->char_set) && strpos($this->dsn, 'charset=', 4) === FALSE) | ||||
| 		{ | ||||
| 			$this->dsn .= ';charset='.$this->char_set; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Database version number | ||||
| 	 * | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	public function version() | ||||
| 	{ | ||||
| 		if (isset($this->data_cache['version'])) | ||||
| 		{ | ||||
| 			return $this->data_cache['version']; | ||||
| 		} | ||||
|  | ||||
| 		$version_string = parent::version(); | ||||
| 		if (preg_match('#Release\s(?<version>\d+(?:\.\d+)+)#', $version_string, $match)) | ||||
| 		{ | ||||
| 			return $this->data_cache['version'] = $match[1]; | ||||
| 		} | ||||
|  | ||||
| 		return FALSE; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Show table query | ||||
| 	 * | ||||
| 	 * Generates a platform-specific query string so that the table names can be fetched | ||||
| 	 * | ||||
| 	 * @param	bool	$prefix_limit | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _list_tables($prefix_limit = FALSE) | ||||
| 	{ | ||||
| 		$sql = 'SELECT "TABLE_NAME" FROM "ALL_TABLES"'; | ||||
|  | ||||
| 		if ($prefix_limit === TRUE && $this->dbprefix !== '') | ||||
| 		{ | ||||
| 			return $sql.' WHERE "TABLE_NAME" LIKE \''.$this->escape_like_str($this->dbprefix)."%' " | ||||
| 				.sprintf($this->_like_escape_str, $this->_like_escape_chr); | ||||
| 		} | ||||
|  | ||||
| 		return $sql; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Show column query | ||||
| 	 * | ||||
| 	 * Generates a platform-specific query string so that the column names can be fetched | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _list_columns($table = '') | ||||
| 	{ | ||||
| 		if (strpos($table, '.') !== FALSE) | ||||
| 		{ | ||||
| 			sscanf($table, '%[^.].%s', $owner, $table); | ||||
| 		} | ||||
| 		else | ||||
| 		{ | ||||
| 			$owner = $this->username; | ||||
| 		} | ||||
|  | ||||
| 		return 'SELECT COLUMN_NAME FROM ALL_TAB_COLUMNS | ||||
| 			WHERE UPPER(OWNER) = '.$this->escape(strtoupper($owner)).' | ||||
| 				AND UPPER(TABLE_NAME) = '.$this->escape(strtoupper($table)); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Returns an object with field data | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	public function field_data($table) | ||||
| 	{ | ||||
| 		if (strpos($table, '.') !== FALSE) | ||||
| 		{ | ||||
| 			sscanf($table, '%[^.].%s', $owner, $table); | ||||
| 		} | ||||
| 		else | ||||
| 		{ | ||||
| 			$owner = $this->username; | ||||
| 		} | ||||
|  | ||||
| 		$sql = 'SELECT COLUMN_NAME, DATA_TYPE, CHAR_LENGTH, DATA_PRECISION, DATA_LENGTH, DATA_DEFAULT, NULLABLE | ||||
| 			FROM ALL_TAB_COLUMNS | ||||
| 			WHERE UPPER(OWNER) = '.$this->escape(strtoupper($owner)).' | ||||
| 				AND UPPER(TABLE_NAME) = '.$this->escape(strtoupper($table)); | ||||
|  | ||||
| 		if (($query = $this->query($sql)) === FALSE) | ||||
| 		{ | ||||
| 			return FALSE; | ||||
| 		} | ||||
| 		$query = $query->result_object(); | ||||
|  | ||||
| 		$retval = array(); | ||||
| 		for ($i = 0, $c = count($query); $i < $c; $i++) | ||||
| 		{ | ||||
| 			$retval[$i]			= new stdClass(); | ||||
| 			$retval[$i]->name		= $query[$i]->COLUMN_NAME; | ||||
| 			$retval[$i]->type		= $query[$i]->DATA_TYPE; | ||||
|  | ||||
| 			$length = ($query[$i]->CHAR_LENGTH > 0) | ||||
| 				? $query[$i]->CHAR_LENGTH : $query[$i]->DATA_PRECISION; | ||||
| 			if ($length === NULL) | ||||
| 			{ | ||||
| 				$length = $query[$i]->DATA_LENGTH; | ||||
| 			} | ||||
| 			$retval[$i]->max_length		= $length; | ||||
|  | ||||
| 			$default = $query[$i]->DATA_DEFAULT; | ||||
| 			if ($default === NULL && $query[$i]->NULLABLE === 'N') | ||||
| 			{ | ||||
| 				$default = ''; | ||||
| 			} | ||||
| 			$retval[$i]->default		= $query[$i]->COLUMN_DEFAULT; | ||||
| 		} | ||||
|  | ||||
| 		return $retval; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Insert batch statement | ||||
| 	 * | ||||
| 	 * @param	string	$table	Table name | ||||
| 	 * @param	array	$keys	INSERT keys | ||||
| 	 * @param	array	$values	INSERT values | ||||
| 	 * @return 	string | ||||
| 	 */ | ||||
| 	protected function _insert_batch($table, $keys, $values) | ||||
| 	{ | ||||
| 		$keys = implode(', ', $keys); | ||||
| 		$sql = "INSERT ALL\n"; | ||||
|  | ||||
| 		for ($i = 0, $c = count($values); $i < $c; $i++) | ||||
| 		{ | ||||
| 			$sql .= '	INTO '.$table.' ('.$keys.') VALUES '.$values[$i]."\n"; | ||||
| 		} | ||||
|  | ||||
| 		return $sql.'SELECT * FROM dual'; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Delete statement | ||||
| 	 * | ||||
| 	 * Generates a platform-specific delete string from the supplied data | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _delete($table) | ||||
| 	{ | ||||
| 		if ($this->qb_limit) | ||||
| 		{ | ||||
| 			$this->where('rownum <= ',$this->qb_limit, FALSE); | ||||
| 			$this->qb_limit = FALSE; | ||||
| 		} | ||||
|  | ||||
| 		return parent::_delete($table); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * LIMIT | ||||
| 	 * | ||||
| 	 * Generates a platform-specific LIMIT clause | ||||
| 	 * | ||||
| 	 * @param	string	$sql	SQL Query | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _limit($sql) | ||||
| 	{ | ||||
| 		if (version_compare($this->version(), '12.1', '>=')) | ||||
| 		{ | ||||
| 			// OFFSET-FETCH can be used only with the ORDER BY clause | ||||
| 			empty($this->qb_orderby) && $sql .= ' ORDER BY 1'; | ||||
|  | ||||
| 			return $sql.' OFFSET '.(int) $this->qb_offset.' ROWS FETCH NEXT '.$this->qb_limit.' ROWS ONLY'; | ||||
| 		} | ||||
|  | ||||
| 		return 'SELECT * FROM (SELECT inner_query.*, rownum rnum FROM ('.$sql.') inner_query WHERE rownum < '.($this->qb_offset + $this->qb_limit + 1).')' | ||||
| 			.($this->qb_offset ? ' WHERE rnum >= '.($this->qb_offset + 1): ''); | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										183
									
								
								system/database/drivers/pdo/subdrivers/pdo_oci_forge.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										183
									
								
								system/database/drivers/pdo/subdrivers/pdo_oci_forge.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,183 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/) | ||||
|  * @license	https://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 3.0.0 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * PDO Oracle Forge Class | ||||
|  * | ||||
|  * @category	Database | ||||
|  * @author		EllisLab Dev Team | ||||
|  * @link		https://codeigniter.com/user_guide/database/ | ||||
|  */ | ||||
| class CI_DB_pdo_oci_forge extends CI_DB_pdo_forge { | ||||
|  | ||||
| 	/** | ||||
| 	 * CREATE DATABASE statement | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_create_database	= FALSE; | ||||
|  | ||||
| 	/** | ||||
| 	 * CREATE TABLE IF statement | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_create_table_if	= FALSE; | ||||
|  | ||||
| 	/** | ||||
| 	 * DROP DATABASE statement | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_drop_database	= FALSE; | ||||
|  | ||||
| 	/** | ||||
| 	 * UNSIGNED support | ||||
| 	 * | ||||
| 	 * @var	bool|array | ||||
| 	 */ | ||||
| 	protected $_unsigned		= FALSE; | ||||
|  | ||||
| 	/** | ||||
| 	 * NULL value representation in CREATE/ALTER TABLE statements | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_null		= 'NULL'; | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * ALTER TABLE | ||||
| 	 * | ||||
| 	 * @param	string	$alter_type	ALTER type | ||||
| 	 * @param	string	$table		Table name | ||||
| 	 * @param	mixed	$field		Column definition | ||||
| 	 * @return	string|string[] | ||||
| 	 */ | ||||
| 	protected function _alter_table($alter_type, $table, $field) | ||||
| 	{ | ||||
| 		if ($alter_type === 'DROP') | ||||
| 		{ | ||||
| 			return parent::_alter_table($alter_type, $table, $field); | ||||
| 		} | ||||
| 		elseif ($alter_type === 'CHANGE') | ||||
| 		{ | ||||
| 			$alter_type = 'MODIFY'; | ||||
| 		} | ||||
|  | ||||
| 		$sql = 'ALTER TABLE '.$this->db->escape_identifiers($table); | ||||
| 		$sqls = array(); | ||||
| 		for ($i = 0, $c = count($field); $i < $c; $i++) | ||||
| 		{ | ||||
| 			if ($field[$i]['_literal'] !== FALSE) | ||||
| 			{ | ||||
| 				$field[$i] = "\n\t".$field[$i]['_literal']; | ||||
| 			} | ||||
| 			else | ||||
| 			{ | ||||
| 				$field[$i]['_literal'] = "\n\t".$this->_process_column($field[$i]); | ||||
|  | ||||
| 				if ( ! empty($field[$i]['comment'])) | ||||
| 				{ | ||||
| 					$sqls[] = 'COMMENT ON COLUMN ' | ||||
| 						.$this->db->escape_identifiers($table).'.'.$this->db->escape_identifiers($field[$i]['name']) | ||||
| 						.' IS '.$field[$i]['comment']; | ||||
| 				} | ||||
|  | ||||
| 				if ($alter_type === 'MODIFY' && ! empty($field[$i]['new_name'])) | ||||
| 				{ | ||||
| 					$sqls[] = $sql.' RENAME COLUMN '.$this->db->escape_identifiers($field[$i]['name']) | ||||
| 						.' TO '.$this->db->escape_identifiers($field[$i]['new_name']); | ||||
| 				} | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		$sql .= ' '.$alter_type.' '; | ||||
| 		$sql .= (count($field) === 1) | ||||
| 				? $field[0] | ||||
| 				: '('.implode(',', $field).')'; | ||||
|  | ||||
| 		// RENAME COLUMN must be executed after MODIFY | ||||
| 		array_unshift($sqls, $sql); | ||||
| 		return $sql; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Field attribute AUTO_INCREMENT | ||||
| 	 * | ||||
| 	 * @param	array	&$attributes | ||||
| 	 * @param	array	&$field | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	protected function _attr_auto_increment(&$attributes, &$field) | ||||
| 	{ | ||||
| 		// Not supported - sequences and triggers must be used instead | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Field attribute TYPE | ||||
| 	 * | ||||
| 	 * Performs a data type mapping between different databases. | ||||
| 	 * | ||||
| 	 * @param	array	&$attributes | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	protected function _attr_type(&$attributes) | ||||
| 	{ | ||||
| 		switch (strtoupper($attributes['TYPE'])) | ||||
| 		{ | ||||
| 			case 'TINYINT': | ||||
| 				$attributes['TYPE'] = 'NUMBER'; | ||||
| 				return; | ||||
| 			case 'MEDIUMINT': | ||||
| 				$attributes['TYPE'] = 'NUMBER'; | ||||
| 				return; | ||||
| 			case 'INT': | ||||
| 				$attributes['TYPE'] = 'NUMBER'; | ||||
| 				return; | ||||
| 			case 'BIGINT': | ||||
| 				$attributes['TYPE'] = 'NUMBER'; | ||||
| 				return; | ||||
| 			default: return; | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
							
								
								
									
										229
									
								
								system/database/drivers/pdo/subdrivers/pdo_odbc_driver.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										229
									
								
								system/database/drivers/pdo/subdrivers/pdo_odbc_driver.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,229 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/) | ||||
|  * @license	https://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 3.0.0 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * PDO ODBC Database Adapter Class | ||||
|  * | ||||
|  * Note: _DB is an extender class that the app controller | ||||
|  * creates dynamically based on whether the query builder | ||||
|  * class is being used or not. | ||||
|  * | ||||
|  * @package		CodeIgniter | ||||
|  * @subpackage	Drivers | ||||
|  * @category	Database | ||||
|  * @author		EllisLab Dev Team | ||||
|  * @link		https://codeigniter.com/user_guide/database/ | ||||
|  */ | ||||
| class CI_DB_pdo_odbc_driver extends CI_DB_pdo_driver { | ||||
|  | ||||
| 	/** | ||||
| 	 * Sub-driver | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	public $subdriver = 'odbc'; | ||||
|  | ||||
| 	/** | ||||
| 	 * Database schema | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	public $schema = 'public'; | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Identifier escape character | ||||
| 	 * | ||||
| 	 * Must be empty for ODBC. | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_escape_char = ''; | ||||
|  | ||||
| 	/** | ||||
| 	 * ESCAPE statement string | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_like_escape_str = " {escape '%s'} "; | ||||
|  | ||||
| 	/** | ||||
| 	 * ORDER BY random keyword | ||||
| 	 * | ||||
| 	 * @var	array | ||||
| 	 */ | ||||
| 	protected $_random_keyword = array('RND()', 'RND(%d)'); | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Class constructor | ||||
| 	 * | ||||
| 	 * Builds the DSN if not already set. | ||||
| 	 * | ||||
| 	 * @param	array	$params | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	public function __construct($params) | ||||
| 	{ | ||||
| 		parent::__construct($params); | ||||
|  | ||||
| 		if (empty($this->dsn)) | ||||
| 		{ | ||||
| 			$this->dsn = 'odbc:'; | ||||
|  | ||||
| 			// Pre-defined DSN | ||||
| 			if (empty($this->hostname) && empty($this->HOSTNAME) && empty($this->port) && empty($this->PORT)) | ||||
| 			{ | ||||
| 				if (isset($this->DSN)) | ||||
| 				{ | ||||
| 					$this->dsn .= 'DSN='.$this->DSN; | ||||
| 				} | ||||
| 				elseif ( ! empty($this->database)) | ||||
| 				{ | ||||
| 					$this->dsn .= 'DSN='.$this->database; | ||||
| 				} | ||||
|  | ||||
| 				return; | ||||
| 			} | ||||
|  | ||||
| 			// If the DSN is not pre-configured - try to build an IBM DB2 connection string | ||||
| 			$this->dsn .= 'DRIVER='.(isset($this->DRIVER) ? '{'.$this->DRIVER.'}' : '{IBM DB2 ODBC DRIVER}').';'; | ||||
|  | ||||
| 			if (isset($this->DATABASE)) | ||||
| 			{ | ||||
| 				$this->dsn .= 'DATABASE='.$this->DATABASE.';'; | ||||
| 			} | ||||
| 			elseif ( ! empty($this->database)) | ||||
| 			{ | ||||
| 				$this->dsn .= 'DATABASE='.$this->database.';'; | ||||
| 			} | ||||
|  | ||||
| 			if (isset($this->HOSTNAME)) | ||||
| 			{ | ||||
| 				$this->dsn .= 'HOSTNAME='.$this->HOSTNAME.';'; | ||||
| 			} | ||||
| 			else | ||||
| 			{ | ||||
| 				$this->dsn .= 'HOSTNAME='.(empty($this->hostname) ? '127.0.0.1;' : $this->hostname.';'); | ||||
| 			} | ||||
|  | ||||
| 			if (isset($this->PORT)) | ||||
| 			{ | ||||
| 				$this->dsn .= 'PORT='.$this->port.';'; | ||||
| 			} | ||||
| 			elseif ( ! empty($this->port)) | ||||
| 			{ | ||||
| 				$this->dsn .= ';PORT='.$this->port.';'; | ||||
| 			} | ||||
|  | ||||
| 			$this->dsn .= 'PROTOCOL='.(isset($this->PROTOCOL) ? $this->PROTOCOL.';' : 'TCPIP;'); | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Platform-dependent string escape | ||||
| 	 * | ||||
| 	 * @param	string | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _escape_str($str) | ||||
| 	{ | ||||
| 		$this->display_error('db_unsupported_feature'); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Determines if a query is a "write" type. | ||||
| 	 * | ||||
| 	 * @param	string	An SQL query string | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	public function is_write_type($sql) | ||||
| 	{ | ||||
| 		if (preg_match('#^(INSERT|UPDATE).*RETURNING\s.+(\,\s?.+)*$#is', $sql)) | ||||
| 		{ | ||||
| 			return FALSE; | ||||
| 		} | ||||
|  | ||||
| 		return parent::is_write_type($sql); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Show table query | ||||
| 	 * | ||||
| 	 * Generates a platform-specific query string so that the table names can be fetched | ||||
| 	 * | ||||
| 	 * @param	bool	$prefix_limit | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _list_tables($prefix_limit = FALSE) | ||||
| 	{ | ||||
| 		$sql = "SELECT table_name FROM information_schema.tables WHERE table_schema = '".$this->schema."'"; | ||||
|  | ||||
| 		if ($prefix_limit !== FALSE && $this->dbprefix !== '') | ||||
| 		{ | ||||
| 			return $sql." AND table_name LIKE '".$this->escape_like_str($this->dbprefix)."%' " | ||||
| 				.sprintf($this->_like_escape_str, $this->_like_escape_chr); | ||||
| 		} | ||||
|  | ||||
| 		return $sql; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Show column query | ||||
| 	 * | ||||
| 	 * Generates a platform-specific query string so that the column names can be fetched | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _list_columns($table = '') | ||||
| 	{ | ||||
| 		return 'SELECT column_name FROM information_schema.columns WHERE table_name = '.$this->escape($table); | ||||
| 	} | ||||
| } | ||||
							
								
								
									
										70
									
								
								system/database/drivers/pdo/subdrivers/pdo_odbc_forge.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										70
									
								
								system/database/drivers/pdo/subdrivers/pdo_odbc_forge.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,70 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/) | ||||
|  * @license	https://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 3.0.0 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * PDO ODBC Forge Class | ||||
|  * | ||||
|  * @category	Database | ||||
|  * @author		EllisLab Dev Team | ||||
|  * @link		https://codeigniter.com/database/ | ||||
|  */ | ||||
| class CI_DB_pdo_odbc_forge extends CI_DB_pdo_forge { | ||||
|  | ||||
| 	/** | ||||
| 	 * UNSIGNED support | ||||
| 	 * | ||||
| 	 * @var	bool|array | ||||
| 	 */ | ||||
| 	protected $_unsigned		= FALSE; | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Field attribute AUTO_INCREMENT | ||||
| 	 * | ||||
| 	 * @param	array	&$attributes | ||||
| 	 * @param	array	&$field | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	protected function _attr_auto_increment(&$attributes, &$field) | ||||
| 	{ | ||||
| 		// Not supported (in most databases at least) | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										384
									
								
								system/database/drivers/pdo/subdrivers/pdo_pgsql_driver.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										384
									
								
								system/database/drivers/pdo/subdrivers/pdo_pgsql_driver.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,384 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/) | ||||
|  * @license	https://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 3.0.0 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * PDO PostgreSQL Database Adapter Class | ||||
|  * | ||||
|  * Note: _DB is an extender class that the app controller | ||||
|  * creates dynamically based on whether the query builder | ||||
|  * class is being used or not. | ||||
|  * | ||||
|  * @package		CodeIgniter | ||||
|  * @subpackage	Drivers | ||||
|  * @category	Database | ||||
|  * @author		EllisLab Dev Team | ||||
|  * @link		https://codeigniter.com/user_guide/database/ | ||||
|  */ | ||||
| class CI_DB_pdo_pgsql_driver extends CI_DB_pdo_driver { | ||||
|  | ||||
| 	/** | ||||
| 	 * Sub-driver | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	public $subdriver = 'pgsql'; | ||||
|  | ||||
| 	/** | ||||
| 	 * Database schema | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	public $schema = 'public'; | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * ORDER BY random keyword | ||||
| 	 * | ||||
| 	 * @var	array | ||||
| 	 */ | ||||
| 	protected $_random_keyword = array('RANDOM()', 'RANDOM()'); | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Class constructor | ||||
| 	 * | ||||
| 	 * Builds the DSN if not already set. | ||||
| 	 * | ||||
| 	 * @param	array	$params | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	public function __construct($params) | ||||
| 	{ | ||||
| 		parent::__construct($params); | ||||
|  | ||||
| 		if (empty($this->dsn)) | ||||
| 		{ | ||||
| 			$this->dsn = 'pgsql:host='.(empty($this->hostname) ? '127.0.0.1' : $this->hostname); | ||||
|  | ||||
| 			empty($this->port) OR $this->dsn .= ';port='.$this->port; | ||||
| 			empty($this->database) OR $this->dsn .= ';dbname='.$this->database; | ||||
|  | ||||
| 			if ( ! empty($this->username)) | ||||
| 			{ | ||||
| 				$this->dsn .= ';user='.$this->username; | ||||
| 				empty($this->password) OR $this->dsn .= ';password='.$this->password; | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Database connection | ||||
| 	 * | ||||
| 	 * @param	bool	$persistent | ||||
| 	 * @return	object | ||||
| 	 */ | ||||
| 	public function db_connect($persistent = FALSE) | ||||
| 	{ | ||||
| 		$this->conn_id = parent::db_connect($persistent); | ||||
|  | ||||
| 		if (is_object($this->conn_id) && ! empty($this->schema)) | ||||
| 		{ | ||||
| 			$this->simple_query('SET search_path TO '.$this->schema.',public'); | ||||
| 		} | ||||
|  | ||||
| 		return $this->conn_id; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Insert ID | ||||
| 	 * | ||||
| 	 * @param	string	$name | ||||
| 	 * @return	int | ||||
| 	 */ | ||||
| 	public function insert_id($name = NULL) | ||||
| 	{ | ||||
| 		if ($name === NULL && version_compare($this->version(), '8.1', '>=')) | ||||
| 		{ | ||||
| 			$query = $this->query('SELECT LASTVAL() AS ins_id'); | ||||
| 			$query = $query->row(); | ||||
| 			return $query->ins_id; | ||||
| 		} | ||||
|  | ||||
| 		return $this->conn_id->lastInsertId($name); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Determines if a query is a "write" type. | ||||
| 	 * | ||||
| 	 * @param	string	An SQL query string | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	public function is_write_type($sql) | ||||
| 	{ | ||||
| 		if (preg_match('#^(INSERT|UPDATE).*RETURNING\s.+(\,\s?.+)*$#is', $sql)) | ||||
| 		{ | ||||
| 			return FALSE; | ||||
| 		} | ||||
|  | ||||
| 		return parent::is_write_type($sql); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * "Smart" Escape String | ||||
| 	 * | ||||
| 	 * Escapes data based on type | ||||
| 	 * | ||||
| 	 * @param	string	$str | ||||
| 	 * @return	mixed | ||||
| 	 */ | ||||
| 	public function escape($str) | ||||
| 	{ | ||||
| 		if (is_bool($str)) | ||||
| 		{ | ||||
| 			return ($str) ? 'TRUE' : 'FALSE'; | ||||
| 		} | ||||
|  | ||||
| 		return parent::escape($str); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * ORDER BY | ||||
| 	 * | ||||
| 	 * @param	string	$orderby | ||||
| 	 * @param	string	$direction	ASC, DESC or RANDOM | ||||
| 	 * @param	bool	$escape | ||||
| 	 * @return	object | ||||
| 	 */ | ||||
| 	public function order_by($orderby, $direction = '', $escape = NULL) | ||||
| 	{ | ||||
| 		$direction = strtoupper(trim($direction)); | ||||
| 		if ($direction === 'RANDOM') | ||||
| 		{ | ||||
| 			if ( ! is_float($orderby) && ctype_digit((string) $orderby)) | ||||
| 			{ | ||||
| 				$orderby = ($orderby > 1) | ||||
| 					? (float) '0.'.$orderby | ||||
| 					: (float) $orderby; | ||||
| 			} | ||||
|  | ||||
| 			if (is_float($orderby)) | ||||
| 			{ | ||||
| 				$this->simple_query('SET SEED '.$orderby); | ||||
| 			} | ||||
|  | ||||
| 			$orderby = $this->_random_keyword[0]; | ||||
| 			$direction = ''; | ||||
| 			$escape = FALSE; | ||||
| 		} | ||||
|  | ||||
| 		return parent::order_by($orderby, $direction, $escape); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Show table query | ||||
| 	 * | ||||
| 	 * Generates a platform-specific query string so that the table names can be fetched | ||||
| 	 * | ||||
| 	 * @param	bool	$prefix_limit | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _list_tables($prefix_limit = FALSE) | ||||
| 	{ | ||||
| 		$sql = 'SELECT "table_name" FROM "information_schema"."tables" WHERE "table_schema" = \''.$this->schema."'"; | ||||
|  | ||||
| 		if ($prefix_limit === TRUE && $this->dbprefix !== '') | ||||
| 		{ | ||||
| 			return $sql.' AND "table_name" LIKE \'' | ||||
| 				.$this->escape_like_str($this->dbprefix)."%' " | ||||
| 				.sprintf($this->_like_escape_str, $this->_like_escape_chr); | ||||
| 		} | ||||
|  | ||||
| 		return $sql; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * List column query | ||||
| 	 * | ||||
| 	 * Generates a platform-specific query string so that the column names can be fetched | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _list_columns($table = '') | ||||
| 	{ | ||||
| 		return 'SELECT "column_name" | ||||
| 			FROM "information_schema"."columns" | ||||
| 			WHERE LOWER("table_name") = '.$this->escape(strtolower($table)); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Returns an object with field data | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	public function field_data($table) | ||||
| 	{ | ||||
| 		$sql = 'SELECT "column_name", "data_type", "character_maximum_length", "numeric_precision", "column_default" | ||||
| 			FROM "information_schema"."columns" | ||||
| 			WHERE LOWER("table_name") = '.$this->escape(strtolower($table)); | ||||
|  | ||||
| 		if (($query = $this->query($sql)) === FALSE) | ||||
| 		{ | ||||
| 			return FALSE; | ||||
| 		} | ||||
| 		$query = $query->result_object(); | ||||
|  | ||||
| 		$retval = array(); | ||||
| 		for ($i = 0, $c = count($query); $i < $c; $i++) | ||||
| 		{ | ||||
| 			$retval[$i]			= new stdClass(); | ||||
| 			$retval[$i]->name		= $query[$i]->column_name; | ||||
| 			$retval[$i]->type		= $query[$i]->data_type; | ||||
| 			$retval[$i]->max_length		= ($query[$i]->character_maximum_length > 0) ? $query[$i]->character_maximum_length : $query[$i]->numeric_precision; | ||||
| 			$retval[$i]->default		= $query[$i]->column_default; | ||||
| 		} | ||||
|  | ||||
| 		return $retval; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Update statement | ||||
| 	 * | ||||
| 	 * Generates a platform-specific update string from the supplied data | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @param	array	$values | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _update($table, $values) | ||||
| 	{ | ||||
| 		$this->qb_limit = FALSE; | ||||
| 		$this->qb_orderby = array(); | ||||
| 		return parent::_update($table, $values); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Update_Batch statement | ||||
| 	 * | ||||
| 	 * Generates a platform-specific batch update string from the supplied data | ||||
| 	 * | ||||
| 	 * @param	string	$table	Table name | ||||
| 	 * @param	array	$values	Update data | ||||
| 	 * @param	string	$index	WHERE key | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _update_batch($table, $values, $index) | ||||
| 	{ | ||||
| 		$ids = array(); | ||||
| 		foreach ($values as $key => $val) | ||||
| 		{ | ||||
| 			$ids[] = $val[$index]['value']; | ||||
|  | ||||
| 			foreach (array_keys($val) as $field) | ||||
| 			{ | ||||
| 				if ($field !== $index) | ||||
| 				{ | ||||
| 					$final[$val[$field]['field']][] = 'WHEN '.$val[$index]['value'].' THEN '.$val[$field]['value']; | ||||
| 				} | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		$cases = ''; | ||||
| 		foreach ($final as $k => $v) | ||||
| 		{ | ||||
| 			$cases .= $k.' = (CASE '.$val[$index]['field']."\n" | ||||
| 				.implode("\n", $v)."\n" | ||||
| 				.'ELSE '.$k.' END), '; | ||||
| 		} | ||||
|  | ||||
| 		$this->where($val[$index]['field'].' IN('.implode(',', $ids).')', NULL, FALSE); | ||||
|  | ||||
| 		return 'UPDATE '.$table.' SET '.substr($cases, 0, -2).$this->_compile_wh('qb_where'); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Delete statement | ||||
| 	 * | ||||
| 	 * Generates a platform-specific delete string from the supplied data | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _delete($table) | ||||
| 	{ | ||||
| 		$this->qb_limit = FALSE; | ||||
| 		return parent::_delete($table); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * LIMIT | ||||
| 	 * | ||||
| 	 * Generates a platform-specific LIMIT clause | ||||
| 	 * | ||||
| 	 * @param	string	$sql	SQL Query | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _limit($sql) | ||||
| 	{ | ||||
| 		return $sql.' LIMIT '.$this->qb_limit.($this->qb_offset ? ' OFFSET '.$this->qb_offset : ''); | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										210
									
								
								system/database/drivers/pdo/subdrivers/pdo_pgsql_forge.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										210
									
								
								system/database/drivers/pdo/subdrivers/pdo_pgsql_forge.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,210 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/) | ||||
|  * @license	https://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 3.0.0 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * PDO PostgreSQL Forge Class | ||||
|  * | ||||
|  * @category	Database | ||||
|  * @author		EllisLab Dev Team | ||||
|  * @link		https://codeigniter.com/user_guide/database/ | ||||
|  */ | ||||
| class CI_DB_pdo_pgsql_forge extends CI_DB_pdo_forge { | ||||
|  | ||||
| 	/** | ||||
| 	 * DROP TABLE IF statement | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_drop_table_if	= 'DROP TABLE IF EXISTS'; | ||||
|  | ||||
| 	/** | ||||
| 	 * UNSIGNED support | ||||
| 	 * | ||||
| 	 * @var	array | ||||
| 	 */ | ||||
| 	protected $_unsigned		= array( | ||||
| 		'INT2'		=> 'INTEGER', | ||||
| 		'SMALLINT'	=> 'INTEGER', | ||||
| 		'INT'		=> 'BIGINT', | ||||
| 		'INT4'		=> 'BIGINT', | ||||
| 		'INTEGER'	=> 'BIGINT', | ||||
| 		'INT8'		=> 'NUMERIC', | ||||
| 		'BIGINT'	=> 'NUMERIC', | ||||
| 		'REAL'		=> 'DOUBLE PRECISION', | ||||
| 		'FLOAT'		=> 'DOUBLE PRECISION' | ||||
| 	); | ||||
|  | ||||
| 	/** | ||||
| 	 * NULL value representation in CREATE/ALTER TABLE statements | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_null = 'NULL'; | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Class constructor | ||||
| 	 * | ||||
| 	 * @param	object	&$db	Database object | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	public function __construct(&$db) | ||||
| 	{ | ||||
| 		parent::__construct($db); | ||||
|  | ||||
| 		if (version_compare($this->db->version(), '9.0', '>')) | ||||
| 		{ | ||||
| 			$this->create_table_if = 'CREATE TABLE IF NOT EXISTS'; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * ALTER TABLE | ||||
| 	 * | ||||
| 	 * @param	string	$alter_type	ALTER type | ||||
| 	 * @param	string	$table		Table name | ||||
| 	 * @param	mixed	$field		Column definition | ||||
| 	 * @return	string|string[] | ||||
| 	 */ | ||||
| 	protected function _alter_table($alter_type, $table, $field) | ||||
|  	{ | ||||
| 		if (in_array($alter_type, array('DROP', 'ADD'), TRUE)) | ||||
| 		{ | ||||
| 			return parent::_alter_table($alter_type, $table, $field); | ||||
| 		} | ||||
|  | ||||
| 		$sql = 'ALTER TABLE '.$this->db->escape_identifiers($table); | ||||
| 		$sqls = array(); | ||||
| 		for ($i = 0, $c = count($field); $i < $c; $i++) | ||||
| 		{ | ||||
| 			if ($field[$i]['_literal'] !== FALSE) | ||||
| 			{ | ||||
| 				return FALSE; | ||||
| 			} | ||||
|  | ||||
| 			if (version_compare($this->db->version(), '8', '>=') && isset($field[$i]['type'])) | ||||
| 			{ | ||||
| 				$sqls[] = $sql.' ALTER COLUMN '.$this->db->escape_identifiers($field[$i]['name']) | ||||
| 					.' TYPE '.$field[$i]['type'].$field[$i]['length']; | ||||
| 			} | ||||
|  | ||||
| 			if ( ! empty($field[$i]['default'])) | ||||
| 			{ | ||||
| 				$sqls[] = $sql.' ALTER COLUMN '.$this->db->escape_identifiers($field[$i]['name']) | ||||
| 					.' SET '.$field[$i]['default']; | ||||
| 			} | ||||
|  | ||||
| 			if (isset($field[$i]['null'])) | ||||
| 			{ | ||||
| 				$sqls[] = $sql.' ALTER COLUMN '.$this->db->escape_identifiers($field[$i]['name']) | ||||
| 					.(trim($field[$i]['null']) === $this->_null ? ' DROP NOT NULL' : ' SET NOT NULL'); | ||||
| 			} | ||||
|  | ||||
| 			if ( ! empty($field[$i]['new_name'])) | ||||
| 			{ | ||||
| 				$sqls[] = $sql.' RENAME COLUMN '.$this->db->escape_identifiers($field[$i]['name']) | ||||
| 					.' TO '.$this->db->escape_identifiers($field[$i]['new_name']); | ||||
| 			} | ||||
|  | ||||
| 			if ( ! empty($field[$i]['comment'])) | ||||
| 			{ | ||||
| 				$sqls[] = 'COMMENT ON COLUMN ' | ||||
| 					.$this->db->escape_identifiers($table).'.'.$this->db->escape_identifiers($field[$i]['name']) | ||||
| 					.' IS '.$field[$i]['comment']; | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		return $sqls; | ||||
|  	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Field attribute TYPE | ||||
| 	 * | ||||
| 	 * Performs a data type mapping between different databases. | ||||
| 	 * | ||||
| 	 * @param	array	&$attributes | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	protected function _attr_type(&$attributes) | ||||
| 	{ | ||||
| 		// Reset field lengths for data types that don't support it | ||||
| 		if (isset($attributes['CONSTRAINT']) && stripos($attributes['TYPE'], 'int') !== FALSE) | ||||
| 		{ | ||||
| 			$attributes['CONSTRAINT'] = NULL; | ||||
| 		} | ||||
|  | ||||
| 		switch (strtoupper($attributes['TYPE'])) | ||||
| 		{ | ||||
| 			case 'TINYINT': | ||||
| 				$attributes['TYPE'] = 'SMALLINT'; | ||||
| 				$attributes['UNSIGNED'] = FALSE; | ||||
| 				return; | ||||
| 			case 'MEDIUMINT': | ||||
| 				$attributes['TYPE'] = 'INTEGER'; | ||||
| 				$attributes['UNSIGNED'] = FALSE; | ||||
| 				return; | ||||
| 			default: return; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Field attribute AUTO_INCREMENT | ||||
| 	 * | ||||
| 	 * @param	array	&$attributes | ||||
| 	 * @param	array	&$field | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	protected function _attr_auto_increment(&$attributes, &$field) | ||||
| 	{ | ||||
| 		if ( ! empty($attributes['AUTO_INCREMENT']) && $attributes['AUTO_INCREMENT'] === TRUE) | ||||
| 		{ | ||||
| 			$field['type'] = ($field['type'] === 'NUMERIC') | ||||
| 				? 'BIGSERIAL' | ||||
| 				: 'SERIAL'; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										213
									
								
								system/database/drivers/pdo/subdrivers/pdo_sqlite_driver.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										213
									
								
								system/database/drivers/pdo/subdrivers/pdo_sqlite_driver.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,213 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/) | ||||
|  * @license	https://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 3.0.0 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * PDO SQLite Database Adapter Class | ||||
|  * | ||||
|  * Note: _DB is an extender class that the app controller | ||||
|  * creates dynamically based on whether the query builder | ||||
|  * class is being used or not. | ||||
|  * | ||||
|  * @package		CodeIgniter | ||||
|  * @subpackage	Drivers | ||||
|  * @category	Database | ||||
|  * @author		EllisLab Dev Team | ||||
|  * @link		https://codeigniter.com/user_guide/database/ | ||||
|  */ | ||||
| class CI_DB_pdo_sqlite_driver extends CI_DB_pdo_driver { | ||||
|  | ||||
| 	/** | ||||
| 	 * Sub-driver | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	public $subdriver = 'sqlite'; | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * ORDER BY random keyword | ||||
| 	 * | ||||
| 	 * @var	array | ||||
| 	 */ | ||||
| 	protected $_random_keyword = array('RANDOM()', 'RANDOM()'); | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Class constructor | ||||
| 	 * | ||||
| 	 * Builds the DSN if not already set. | ||||
| 	 * | ||||
| 	 * @param	array	$params | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	public function __construct($params) | ||||
| 	{ | ||||
| 		parent::__construct($params); | ||||
|  | ||||
| 		if (empty($this->dsn)) | ||||
| 		{ | ||||
| 			$this->dsn = 'sqlite:'; | ||||
|  | ||||
| 			if (empty($this->database) && empty($this->hostname)) | ||||
| 			{ | ||||
| 				$this->database = ':memory:'; | ||||
| 			} | ||||
|  | ||||
| 			$this->database = empty($this->database) ? $this->hostname : $this->database; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Show table query | ||||
| 	 * | ||||
| 	 * Generates a platform-specific query string so that the table names can be fetched | ||||
| 	 * | ||||
| 	 * @param	bool	$prefix_limit | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _list_tables($prefix_limit = FALSE) | ||||
| 	{ | ||||
| 		$sql = 'SELECT "NAME" FROM "SQLITE_MASTER" WHERE "TYPE" = \'table\''; | ||||
|  | ||||
| 		if ($prefix_limit === TRUE && $this->dbprefix !== '') | ||||
| 		{ | ||||
| 			return $sql.' AND "NAME" LIKE \''.$this->escape_like_str($this->dbprefix)."%' " | ||||
| 				.sprintf($this->_like_escape_str, $this->_like_escape_chr); | ||||
| 		} | ||||
|  | ||||
| 		return $sql; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Fetch Field Names | ||||
| 	 * | ||||
| 	 * @param	string	$table	Table name | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	public function list_fields($table) | ||||
| 	{ | ||||
| 		if (($result = $this->query('PRAGMA TABLE_INFO('.$this->protect_identifiers($table, TRUE, NULL, FALSE).')')) === FALSE) | ||||
| 		{ | ||||
| 			return FALSE; | ||||
| 		} | ||||
|  | ||||
| 		$fields = array(); | ||||
| 		foreach ($result->result_array() as $row) | ||||
| 		{ | ||||
| 			$fields[] = $row['name']; | ||||
| 		} | ||||
|  | ||||
| 		return $fields; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Returns an object with field data | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	public function field_data($table) | ||||
| 	{ | ||||
| 		if (($query = $this->query('PRAGMA TABLE_INFO('.$this->protect_identifiers($table, TRUE, NULL, FALSE).')')) === FALSE) | ||||
| 		{ | ||||
| 			return FALSE; | ||||
| 		} | ||||
|  | ||||
| 		$query = $query->result_array(); | ||||
| 		if (empty($query)) | ||||
| 		{ | ||||
| 			return FALSE; | ||||
| 		} | ||||
|  | ||||
| 		$retval = array(); | ||||
| 		for ($i = 0, $c = count($query); $i < $c; $i++) | ||||
| 		{ | ||||
| 			$retval[$i]			= new stdClass(); | ||||
| 			$retval[$i]->name		= $query[$i]['name']; | ||||
| 			$retval[$i]->type		= $query[$i]['type']; | ||||
| 			$retval[$i]->max_length		= NULL; | ||||
| 			$retval[$i]->default		= $query[$i]['dflt_value']; | ||||
| 			$retval[$i]->primary_key	= isset($query[$i]['pk']) ? (int) $query[$i]['pk'] : 0; | ||||
| 		} | ||||
|  | ||||
| 		return $retval; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Replace statement | ||||
| 	 * | ||||
| 	 * @param	string	$table	Table name | ||||
| 	 * @param	array	$keys	INSERT keys | ||||
| 	 * @param	array	$values	INSERT values | ||||
| 	 * @return 	string | ||||
| 	 */ | ||||
| 	protected function _replace($table, $keys, $values) | ||||
| 	{ | ||||
| 		return 'INSERT OR '.parent::_replace($table, $keys, $values); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Truncate statement | ||||
| 	 * | ||||
| 	 * Generates a platform-specific truncate string from the supplied data | ||||
| 	 * | ||||
| 	 * If the database does not support the TRUNCATE statement, | ||||
| 	 * then this method maps to 'DELETE FROM table' | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _truncate($table) | ||||
| 	{ | ||||
| 		return 'DELETE FROM '.$table; | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										238
									
								
								system/database/drivers/pdo/subdrivers/pdo_sqlite_forge.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										238
									
								
								system/database/drivers/pdo/subdrivers/pdo_sqlite_forge.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,238 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/) | ||||
|  * @license	https://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 3.0.0 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * PDO SQLite Forge Class | ||||
|  * | ||||
|  * @category	Database | ||||
|  * @author		EllisLab Dev Team | ||||
|  * @link		https://codeigniter.com/user_guide/database/ | ||||
|  */ | ||||
| class CI_DB_pdo_sqlite_forge extends CI_DB_pdo_forge { | ||||
|  | ||||
| 	/** | ||||
| 	 * CREATE TABLE IF statement | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_create_table_if	= 'CREATE TABLE IF NOT EXISTS'; | ||||
|  | ||||
| 	/** | ||||
| 	 * DROP TABLE IF statement | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_drop_table_if	= 'DROP TABLE IF EXISTS'; | ||||
|  | ||||
| 	/** | ||||
| 	 * UNSIGNED support | ||||
| 	 * | ||||
| 	 * @var	bool|array | ||||
| 	 */ | ||||
| 	protected $_unsigned		= FALSE; | ||||
|  | ||||
| 	/** | ||||
| 	 * NULL value representation in CREATE/ALTER TABLE statements | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_null		= 'NULL'; | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Class constructor | ||||
| 	 * | ||||
| 	 * @param	object	&$db	Database object | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	public function __construct(&$db) | ||||
| 	{ | ||||
| 		parent::__construct($db); | ||||
|  | ||||
| 		if (version_compare($this->db->version(), '3.3', '<')) | ||||
| 		{ | ||||
| 			$this->_create_table_if = FALSE; | ||||
| 			$this->_drop_table_if   = FALSE; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Create database | ||||
| 	 * | ||||
| 	 * @param	string	$db_name	(ignored) | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	public function create_database($db_name) | ||||
| 	{ | ||||
| 		// In SQLite, a database is created when you connect to the database. | ||||
| 		// We'll return TRUE so that an error isn't generated | ||||
| 		return TRUE; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Drop database | ||||
| 	 * | ||||
| 	 * @param	string	$db_name	(ignored) | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	public function drop_database($db_name) | ||||
| 	{ | ||||
| 		// In SQLite, a database is dropped when we delete a file | ||||
| 		if (file_exists($this->db->database)) | ||||
| 		{ | ||||
| 			// We need to close the pseudo-connection first | ||||
| 			$this->db->close(); | ||||
| 			if ( ! @unlink($this->db->database)) | ||||
| 			{ | ||||
| 				return $this->db->db_debug ? $this->db->display_error('db_unable_to_drop') : FALSE; | ||||
| 			} | ||||
| 			elseif ( ! empty($this->db->data_cache['db_names'])) | ||||
| 			{ | ||||
| 				$key = array_search(strtolower($this->db->database), array_map('strtolower', $this->db->data_cache['db_names']), TRUE); | ||||
| 				if ($key !== FALSE) | ||||
| 				{ | ||||
| 					unset($this->db->data_cache['db_names'][$key]); | ||||
| 				} | ||||
| 			} | ||||
|  | ||||
| 			return TRUE; | ||||
| 		} | ||||
|  | ||||
| 		return $this->db->db_debug ? $this->db->display_error('db_unable_to_drop') : FALSE; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * ALTER TABLE | ||||
| 	 * | ||||
| 	 * @param	string	$alter_type	ALTER type | ||||
| 	 * @param	string	$table		Table name | ||||
| 	 * @param	mixed	$field		Column definition | ||||
| 	 * @return	string|string[] | ||||
| 	 */ | ||||
| 	protected function _alter_table($alter_type, $table, $field) | ||||
| 	{ | ||||
| 		if ($alter_type === 'DROP' OR $alter_type === 'CHANGE') | ||||
| 		{ | ||||
| 			// drop_column(): | ||||
| 			//	BEGIN TRANSACTION; | ||||
| 			//	CREATE TEMPORARY TABLE t1_backup(a,b); | ||||
| 			//	INSERT INTO t1_backup SELECT a,b FROM t1; | ||||
| 			//	DROP TABLE t1; | ||||
| 			//	CREATE TABLE t1(a,b); | ||||
| 			//	INSERT INTO t1 SELECT a,b FROM t1_backup; | ||||
| 			//	DROP TABLE t1_backup; | ||||
| 			//	COMMIT; | ||||
|  | ||||
| 			return FALSE; | ||||
| 		} | ||||
|  | ||||
| 		return parent::_alter_table($alter_type, $table, $field); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Process column | ||||
| 	 * | ||||
| 	 * @param	array	$field | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _process_column($field) | ||||
| 	{ | ||||
| 		return $this->db->escape_identifiers($field['name']) | ||||
| 			.' '.$field['type'] | ||||
| 			.$field['auto_increment'] | ||||
| 			.$field['null'] | ||||
| 			.$field['unique'] | ||||
| 			.$field['default']; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Field attribute TYPE | ||||
| 	 * | ||||
| 	 * Performs a data type mapping between different databases. | ||||
| 	 * | ||||
| 	 * @param	array	&$attributes | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	protected function _attr_type(&$attributes) | ||||
| 	{ | ||||
| 		switch (strtoupper($attributes['TYPE'])) | ||||
| 		{ | ||||
| 			case 'ENUM': | ||||
| 			case 'SET': | ||||
| 				$attributes['TYPE'] = 'TEXT'; | ||||
| 				return; | ||||
| 			default: return; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Field attribute AUTO_INCREMENT | ||||
| 	 * | ||||
| 	 * @param	array	&$attributes | ||||
| 	 * @param	array	&$field | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	protected function _attr_auto_increment(&$attributes, &$field) | ||||
| 	{ | ||||
| 		if ( ! empty($attributes['AUTO_INCREMENT']) && $attributes['AUTO_INCREMENT'] === TRUE && stripos($field['type'], 'int') !== FALSE) | ||||
| 		{ | ||||
| 			$field['type'] = 'INTEGER PRIMARY KEY'; | ||||
| 			$field['default'] = ''; | ||||
| 			$field['null'] = ''; | ||||
| 			$field['unique'] = ''; | ||||
| 			$field['auto_increment'] = ' AUTOINCREMENT'; | ||||
|  | ||||
| 			$this->primary_keys = array(); | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										369
									
								
								system/database/drivers/pdo/subdrivers/pdo_sqlsrv_driver.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										369
									
								
								system/database/drivers/pdo/subdrivers/pdo_sqlsrv_driver.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,369 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/) | ||||
|  * @license	https://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 3.0.0 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * PDO SQLSRV Database Adapter Class | ||||
|  * | ||||
|  * Note: _DB is an extender class that the app controller | ||||
|  * creates dynamically based on whether the query builder | ||||
|  * class is being used or not. | ||||
|  * | ||||
|  * @package		CodeIgniter | ||||
|  * @subpackage	Drivers | ||||
|  * @category	Database | ||||
|  * @author		EllisLab Dev Team | ||||
|  * @link		https://codeigniter.com/user_guide/database/ | ||||
|  */ | ||||
| class CI_DB_pdo_sqlsrv_driver extends CI_DB_pdo_driver { | ||||
|  | ||||
| 	/** | ||||
| 	 * Sub-driver | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	public $subdriver = 'sqlsrv'; | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * ORDER BY random keyword | ||||
| 	 * | ||||
| 	 * @var	array | ||||
| 	 */ | ||||
| 	protected $_random_keyword = array('NEWID()', 'RAND(%d)'); | ||||
|  | ||||
| 	/** | ||||
| 	 * Quoted identifier flag | ||||
| 	 * | ||||
| 	 * Whether to use SQL-92 standard quoted identifier | ||||
| 	 * (double quotes) or brackets for identifier escaping. | ||||
| 	 * | ||||
| 	 * @var	bool | ||||
| 	 */ | ||||
| 	protected $_quoted_identifier; | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Class constructor | ||||
| 	 * | ||||
| 	 * Builds the DSN if not already set. | ||||
| 	 * | ||||
| 	 * @param	array	$params | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	public function __construct($params) | ||||
| 	{ | ||||
| 		parent::__construct($params); | ||||
|  | ||||
| 		if (empty($this->dsn)) | ||||
| 		{ | ||||
| 			$this->dsn = 'sqlsrv:Server='.(empty($this->hostname) ? '127.0.0.1' : $this->hostname); | ||||
|  | ||||
| 			empty($this->port) OR $this->dsn .= ','.$this->port; | ||||
| 			empty($this->database) OR $this->dsn .= ';Database='.$this->database; | ||||
|  | ||||
| 			// Some custom options | ||||
|  | ||||
| 			if (isset($this->QuotedId)) | ||||
| 			{ | ||||
| 				$this->dsn .= ';QuotedId='.$this->QuotedId; | ||||
| 				$this->_quoted_identifier = (bool) $this->QuotedId; | ||||
| 			} | ||||
|  | ||||
| 			if (isset($this->ConnectionPooling)) | ||||
| 			{ | ||||
| 				$this->dsn .= ';ConnectionPooling='.$this->ConnectionPooling; | ||||
| 			} | ||||
|  | ||||
| 			if ($this->encrypt === TRUE) | ||||
| 			{ | ||||
| 				$this->dsn .= ';Encrypt=1'; | ||||
| 			} | ||||
|  | ||||
| 			if (isset($this->TraceOn)) | ||||
| 			{ | ||||
| 				$this->dsn .= ';TraceOn='.$this->TraceOn; | ||||
| 			} | ||||
|  | ||||
| 			if (isset($this->TrustServerCertificate)) | ||||
| 			{ | ||||
| 				$this->dsn .= ';TrustServerCertificate='.$this->TrustServerCertificate; | ||||
| 			} | ||||
|  | ||||
| 			empty($this->APP) OR $this->dsn .= ';APP='.$this->APP; | ||||
| 			empty($this->Failover_Partner) OR $this->dsn .= ';Failover_Partner='.$this->Failover_Partner; | ||||
| 			empty($this->LoginTimeout) OR $this->dsn .= ';LoginTimeout='.$this->LoginTimeout; | ||||
| 			empty($this->MultipleActiveResultSets) OR $this->dsn .= ';MultipleActiveResultSets='.$this->MultipleActiveResultSets; | ||||
| 			empty($this->TraceFile) OR $this->dsn .= ';TraceFile='.$this->TraceFile; | ||||
| 			empty($this->WSID) OR $this->dsn .= ';WSID='.$this->WSID; | ||||
| 		} | ||||
| 		elseif (preg_match('/QuotedId=(0|1)/', $this->dsn, $match)) | ||||
| 		{ | ||||
| 			$this->_quoted_identifier = (bool) $match[1]; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Database connection | ||||
| 	 * | ||||
| 	 * @param	bool	$persistent | ||||
| 	 * @return	object | ||||
| 	 */ | ||||
| 	public function db_connect($persistent = FALSE) | ||||
| 	{ | ||||
| 		if ( ! empty($this->char_set) && preg_match('/utf[^8]*8/i', $this->char_set)) | ||||
| 		{ | ||||
| 			$this->options[PDO::SQLSRV_ENCODING_UTF8] = 1; | ||||
| 		} | ||||
|  | ||||
| 		$this->conn_id = parent::db_connect($persistent); | ||||
|  | ||||
| 		if ( ! is_object($this->conn_id) OR is_bool($this->_quoted_identifier)) | ||||
| 		{ | ||||
| 			return $this->conn_id; | ||||
| 		} | ||||
|  | ||||
| 		// Determine how identifiers are escaped | ||||
| 		$query = $this->query('SELECT CASE WHEN (@@OPTIONS | 256) = @@OPTIONS THEN 1 ELSE 0 END AS qi'); | ||||
| 		$query = $query->row_array(); | ||||
| 		$this->_quoted_identifier = empty($query) ? FALSE : (bool) $query['qi']; | ||||
| 		$this->_escape_char = ($this->_quoted_identifier) ? '"' : array('[', ']'); | ||||
|  | ||||
| 		return $this->conn_id; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Show table query | ||||
| 	 * | ||||
| 	 * Generates a platform-specific query string so that the table names can be fetched | ||||
| 	 * | ||||
| 	 * @param	bool	$prefix_limit | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _list_tables($prefix_limit = FALSE) | ||||
| 	{ | ||||
| 		$sql = 'SELECT '.$this->escape_identifiers('name') | ||||
| 			.' FROM '.$this->escape_identifiers('sysobjects') | ||||
| 			.' WHERE '.$this->escape_identifiers('type')." = 'U'"; | ||||
|  | ||||
| 		if ($prefix_limit === TRUE && $this->dbprefix !== '') | ||||
| 		{ | ||||
| 			$sql .= ' AND '.$this->escape_identifiers('name')." LIKE '".$this->escape_like_str($this->dbprefix)."%' " | ||||
| 				.sprintf($this->_like_escape_str, $this->_like_escape_chr); | ||||
| 		} | ||||
|  | ||||
| 		return $sql.' ORDER BY '.$this->escape_identifiers('name'); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Show column query | ||||
| 	 * | ||||
| 	 * Generates a platform-specific query string so that the column names can be fetched | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _list_columns($table = '') | ||||
| 	{ | ||||
| 		return 'SELECT COLUMN_NAME | ||||
| 			FROM INFORMATION_SCHEMA.Columns | ||||
| 			WHERE UPPER(TABLE_NAME) = '.$this->escape(strtoupper($table)); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Returns an object with field data | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	public function field_data($table) | ||||
| 	{ | ||||
| 		$sql = 'SELECT COLUMN_NAME, DATA_TYPE, CHARACTER_MAXIMUM_LENGTH, NUMERIC_PRECISION, COLUMN_DEFAULT | ||||
| 			FROM INFORMATION_SCHEMA.Columns | ||||
| 			WHERE UPPER(TABLE_NAME) = '.$this->escape(strtoupper($table)); | ||||
|  | ||||
| 		if (($query = $this->query($sql)) === FALSE) | ||||
| 		{ | ||||
| 			return FALSE; | ||||
| 		} | ||||
| 		$query = $query->result_object(); | ||||
|  | ||||
| 		$retval = array(); | ||||
| 		for ($i = 0, $c = count($query); $i < $c; $i++) | ||||
| 		{ | ||||
| 			$retval[$i]			= new stdClass(); | ||||
| 			$retval[$i]->name		= $query[$i]->COLUMN_NAME; | ||||
| 			$retval[$i]->type		= $query[$i]->DATA_TYPE; | ||||
| 			$retval[$i]->max_length		= ($query[$i]->CHARACTER_MAXIMUM_LENGTH > 0) ? $query[$i]->CHARACTER_MAXIMUM_LENGTH : $query[$i]->NUMERIC_PRECISION; | ||||
| 			$retval[$i]->default		= $query[$i]->COLUMN_DEFAULT; | ||||
| 		} | ||||
|  | ||||
| 		return $retval; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Update statement | ||||
| 	 * | ||||
| 	 * Generates a platform-specific update string from the supplied data | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @param	array	$values | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _update($table, $values) | ||||
| 	{ | ||||
| 		$this->qb_limit = FALSE; | ||||
| 		$this->qb_orderby = array(); | ||||
| 		return parent::_update($table, $values); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Delete statement | ||||
| 	 * | ||||
| 	 * Generates a platform-specific delete string from the supplied data | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _delete($table) | ||||
| 	{ | ||||
| 		if ($this->qb_limit) | ||||
| 		{ | ||||
| 			return 'WITH ci_delete AS (SELECT TOP '.$this->qb_limit.' * FROM '.$table.$this->_compile_wh('qb_where').') DELETE FROM ci_delete'; | ||||
| 		} | ||||
|  | ||||
| 		return parent::_delete($table); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * LIMIT | ||||
| 	 * | ||||
| 	 * Generates a platform-specific LIMIT clause | ||||
| 	 * | ||||
| 	 * @param	string	$sql	SQL Query | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _limit($sql) | ||||
| 	{ | ||||
| 		// As of SQL Server 2012 (11.0.*) OFFSET is supported | ||||
| 		if (version_compare($this->version(), '11', '>=')) | ||||
| 		{ | ||||
| 			// SQL Server OFFSET-FETCH can be used only with the ORDER BY clause | ||||
| 			empty($this->qb_orderby) && $sql .= ' ORDER BY 1'; | ||||
|  | ||||
| 			return $sql.' OFFSET '.(int) $this->qb_offset.' ROWS FETCH NEXT '.$this->qb_limit.' ROWS ONLY'; | ||||
| 		} | ||||
|  | ||||
| 		$limit = $this->qb_offset + $this->qb_limit; | ||||
|  | ||||
| 		// An ORDER BY clause is required for ROW_NUMBER() to work | ||||
| 		if ($this->qb_offset && ! empty($this->qb_orderby)) | ||||
| 		{ | ||||
| 			$orderby = $this->_compile_order_by(); | ||||
|  | ||||
| 			// We have to strip the ORDER BY clause | ||||
| 			$sql = trim(substr($sql, 0, strrpos($sql, $orderby))); | ||||
|  | ||||
| 			// Get the fields to select from our subquery, so that we can avoid CI_rownum appearing in the actual results | ||||
| 			if (count($this->qb_select) === 0 OR strpos(implode(',', $this->qb_select), '*') !== FALSE) | ||||
| 			{ | ||||
| 				$select = '*'; // Inevitable | ||||
| 			} | ||||
| 			else | ||||
| 			{ | ||||
| 				// Use only field names and their aliases, everything else is out of our scope. | ||||
| 				$select = array(); | ||||
| 				$field_regexp = ($this->_quoted_identifier) | ||||
| 					? '("[^\"]+")' : '(\[[^\]]+\])'; | ||||
| 				for ($i = 0, $c = count($this->qb_select); $i < $c; $i++) | ||||
| 				{ | ||||
| 					$select[] = preg_match('/(?:\s|\.)'.$field_regexp.'$/i', $this->qb_select[$i], $m) | ||||
| 						? $m[1] : $this->qb_select[$i]; | ||||
| 				} | ||||
| 				$select = implode(', ', $select); | ||||
| 			} | ||||
|  | ||||
| 			return 'SELECT '.$select." FROM (\n\n" | ||||
| 				.preg_replace('/^(SELECT( DISTINCT)?)/i', '\\1 ROW_NUMBER() OVER('.trim($orderby).') AS '.$this->escape_identifiers('CI_rownum').', ', $sql) | ||||
| 				."\n\n) ".$this->escape_identifiers('CI_subquery') | ||||
| 				."\nWHERE ".$this->escape_identifiers('CI_rownum').' BETWEEN '.($this->qb_offset + 1).' AND '.$limit; | ||||
| 		} | ||||
|  | ||||
| 		return preg_replace('/(^\SELECT (DISTINCT)?)/i','\\1 TOP '.$limit.' ', $sql); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Insert batch statement | ||||
| 	 * | ||||
| 	 * Generates a platform-specific insert string from the supplied data. | ||||
| 	 * | ||||
| 	 * @param	string	$table	Table name | ||||
| 	 * @param	array	$keys	INSERT keys | ||||
| 	 * @param	array	$values	INSERT values | ||||
| 	 * @return	string|bool | ||||
| 	 */ | ||||
| 	protected function _insert_batch($table, $keys, $values) | ||||
| 	{ | ||||
| 		// Multiple-value inserts are only supported as of SQL Server 2008 | ||||
| 		if (version_compare($this->version(), '10', '>=')) | ||||
| 		{ | ||||
| 			return parent::_insert_batch($table, $keys, $values); | ||||
| 		} | ||||
|  | ||||
| 		return ($this->db_debug) ? $this->display_error('db_unsupported_feature') : FALSE; | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										149
									
								
								system/database/drivers/pdo/subdrivers/pdo_sqlsrv_forge.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										149
									
								
								system/database/drivers/pdo/subdrivers/pdo_sqlsrv_forge.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,149 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/) | ||||
|  * @license	https://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 3.0.0 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * PDO SQLSRV Forge Class | ||||
|  * | ||||
|  * @category	Database | ||||
|  * @author		EllisLab Dev Team | ||||
|  * @link		https://codeigniter.com/user_guide/database/ | ||||
|  */ | ||||
| class CI_DB_pdo_sqlsrv_forge extends CI_DB_pdo_forge { | ||||
|  | ||||
| 	/** | ||||
| 	 * CREATE TABLE IF statement | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_create_table_if	= "IF NOT EXISTS (SELECT * FROM sysobjects WHERE ID = object_id(N'%s') AND OBJECTPROPERTY(id, N'IsUserTable') = 1)\nCREATE TABLE"; | ||||
|  | ||||
| 	/** | ||||
| 	 * DROP TABLE IF statement | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_drop_table_if	= "IF EXISTS (SELECT * FROM sysobjects WHERE ID = object_id(N'%s') AND OBJECTPROPERTY(id, N'IsUserTable') = 1)\nDROP TABLE"; | ||||
|  | ||||
| 	/** | ||||
| 	 * UNSIGNED support | ||||
| 	 * | ||||
| 	 * @var	array | ||||
| 	 */ | ||||
| 	protected $_unsigned		= array( | ||||
| 		'TINYINT'	=> 'SMALLINT', | ||||
| 		'SMALLINT'	=> 'INT', | ||||
| 		'INT'		=> 'BIGINT', | ||||
| 		'REAL'		=> 'FLOAT' | ||||
| 	); | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * ALTER TABLE | ||||
| 	 * | ||||
| 	 * @param	string	$alter_type	ALTER type | ||||
| 	 * @param	string	$table		Table name | ||||
| 	 * @param	mixed	$field		Column definition | ||||
| 	 * @return	string|string[] | ||||
| 	 */ | ||||
| 	protected function _alter_table($alter_type, $table, $field) | ||||
| 	{ | ||||
| 		if (in_array($alter_type, array('ADD', 'DROP'), TRUE)) | ||||
| 		{ | ||||
| 			return parent::_alter_table($alter_type, $table, $field); | ||||
| 		} | ||||
|  | ||||
| 		$sql = 'ALTER TABLE '.$this->db->escape_identifiers($table).' ALTER COLUMN '; | ||||
| 		$sqls = array(); | ||||
| 		for ($i = 0, $c = count($field); $i < $c; $i++) | ||||
| 		{ | ||||
| 			$sqls[] = $sql.$this->_process_column($field[$i]); | ||||
| 		} | ||||
|  | ||||
| 		return $sqls; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Field attribute TYPE | ||||
| 	 * | ||||
| 	 * Performs a data type mapping between different databases. | ||||
| 	 * | ||||
| 	 * @param	array	&$attributes | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	protected function _attr_type(&$attributes) | ||||
| 	{ | ||||
| 		if (isset($attributes['CONSTRAINT']) && strpos($attributes['TYPE'], 'INT') !== FALSE) | ||||
| 		{ | ||||
| 			unset($attributes['CONSTRAINT']); | ||||
| 		} | ||||
|  | ||||
| 		switch (strtoupper($attributes['TYPE'])) | ||||
| 		{ | ||||
| 			case 'MEDIUMINT': | ||||
| 				$attributes['TYPE'] = 'INTEGER'; | ||||
| 				$attributes['UNSIGNED'] = FALSE; | ||||
| 				return; | ||||
| 			case 'INTEGER': | ||||
| 				$attributes['TYPE'] = 'INT'; | ||||
| 				return; | ||||
| 			default: return; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Field attribute AUTO_INCREMENT | ||||
| 	 * | ||||
| 	 * @param	array	&$attributes | ||||
| 	 * @param	array	&$field | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	protected function _attr_auto_increment(&$attributes, &$field) | ||||
| 	{ | ||||
| 		if ( ! empty($attributes['AUTO_INCREMENT']) && $attributes['AUTO_INCREMENT'] === TRUE && stripos($field['type'], 'int') !== FALSE) | ||||
| 		{ | ||||
| 			$field['auto_increment'] = ' IDENTITY(1,1)'; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										11
									
								
								system/database/drivers/postgre/index.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								system/database/drivers/postgre/index.html
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,11 @@ | ||||
| <!DOCTYPE html> | ||||
| <html> | ||||
| <head> | ||||
| 	<title>403 Forbidden</title> | ||||
| </head> | ||||
| <body> | ||||
|  | ||||
| <p>Directory access is forbidden.</p> | ||||
|  | ||||
| </body> | ||||
| </html> | ||||
							
								
								
									
										619
									
								
								system/database/drivers/postgre/postgre_driver.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										619
									
								
								system/database/drivers/postgre/postgre_driver.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,619 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/) | ||||
|  * @license	https://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 1.3.0 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * Postgre Database Adapter Class | ||||
|  * | ||||
|  * Note: _DB is an extender class that the app controller | ||||
|  * creates dynamically based on whether the query builder | ||||
|  * class is being used or not. | ||||
|  * | ||||
|  * @package		CodeIgniter | ||||
|  * @subpackage	Drivers | ||||
|  * @category	Database | ||||
|  * @author		EllisLab Dev Team | ||||
|  * @link		https://codeigniter.com/user_guide/database/ | ||||
|  */ | ||||
| class CI_DB_postgre_driver extends CI_DB { | ||||
|  | ||||
| 	/** | ||||
| 	 * Database driver | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	public $dbdriver = 'postgre'; | ||||
|  | ||||
| 	/** | ||||
| 	 * Database schema | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	public $schema = 'public'; | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * ORDER BY random keyword | ||||
| 	 * | ||||
| 	 * @var	array | ||||
| 	 */ | ||||
| 	protected $_random_keyword = array('RANDOM()', 'RANDOM()'); | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Class constructor | ||||
| 	 * | ||||
| 	 * Creates a DSN string to be used for db_connect() and db_pconnect() | ||||
| 	 * | ||||
| 	 * @param	array	$params | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	public function __construct($params) | ||||
| 	{ | ||||
| 		parent::__construct($params); | ||||
|  | ||||
| 		if ( ! empty($this->dsn)) | ||||
| 		{ | ||||
| 			return; | ||||
| 		} | ||||
|  | ||||
| 		$this->dsn === '' OR $this->dsn = ''; | ||||
|  | ||||
| 		if (strpos($this->hostname, '/') !== FALSE) | ||||
| 		{ | ||||
| 			// If UNIX sockets are used, we shouldn't set a port | ||||
| 			$this->port = ''; | ||||
| 		} | ||||
|  | ||||
| 		$this->hostname === '' OR $this->dsn = 'host='.$this->hostname.' '; | ||||
|  | ||||
| 		if ( ! empty($this->port) && ctype_digit($this->port)) | ||||
| 		{ | ||||
| 			$this->dsn .= 'port='.$this->port.' '; | ||||
| 		} | ||||
|  | ||||
| 		if ($this->username !== '') | ||||
| 		{ | ||||
| 			$this->dsn .= 'user='.$this->username.' '; | ||||
|  | ||||
| 			/* An empty password is valid! | ||||
| 			 * | ||||
| 			 * $db['password'] = NULL must be done in order to ignore it. | ||||
| 			 */ | ||||
| 			$this->password === NULL OR $this->dsn .= "password='".$this->password."' "; | ||||
| 		} | ||||
|  | ||||
| 		$this->database === '' OR $this->dsn .= 'dbname='.$this->database.' '; | ||||
|  | ||||
| 		/* We don't have these options as elements in our standard configuration | ||||
| 		 * array, but they might be set by parse_url() if the configuration was | ||||
| 		 * provided via string. Example: | ||||
| 		 * | ||||
| 		 * postgre://username:password@localhost:5432/database?connect_timeout=5&sslmode=1 | ||||
| 		 */ | ||||
| 		foreach (array('connect_timeout', 'options', 'sslmode', 'service') as $key) | ||||
| 		{ | ||||
| 			if (isset($this->$key) && is_string($this->$key) && $this->$key !== '') | ||||
| 			{ | ||||
| 				$this->dsn .= $key."='".$this->$key."' "; | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		$this->dsn = rtrim($this->dsn); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Database connection | ||||
| 	 * | ||||
| 	 * @param	bool	$persistent | ||||
| 	 * @return	resource | ||||
| 	 */ | ||||
| 	public function db_connect($persistent = FALSE) | ||||
| 	{ | ||||
| 		$this->conn_id = ($persistent === TRUE) | ||||
| 			? pg_pconnect($this->dsn) | ||||
| 			: pg_connect($this->dsn); | ||||
|  | ||||
| 		if ($this->conn_id !== FALSE) | ||||
| 		{ | ||||
| 			if ($persistent === TRUE | ||||
| 				&& pg_connection_status($this->conn_id) === PGSQL_CONNECTION_BAD | ||||
| 				&& pg_ping($this->conn_id) === FALSE | ||||
| 			) | ||||
| 			{ | ||||
| 				return FALSE; | ||||
| 			} | ||||
|  | ||||
| 			empty($this->schema) OR $this->simple_query('SET search_path TO '.$this->schema.',public'); | ||||
| 		} | ||||
|  | ||||
| 		return $this->conn_id; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Reconnect | ||||
| 	 * | ||||
| 	 * Keep / reestablish the db connection if no queries have been | ||||
| 	 * sent for a length of time exceeding the server's idle timeout | ||||
| 	 * | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	public function reconnect() | ||||
| 	{ | ||||
| 		if (pg_ping($this->conn_id) === FALSE) | ||||
| 		{ | ||||
| 			$this->conn_id = FALSE; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Set client character set | ||||
| 	 * | ||||
| 	 * @param	string	$charset | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	protected function _db_set_charset($charset) | ||||
| 	{ | ||||
| 		return (pg_set_client_encoding($this->conn_id, $charset) === 0); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Database version number | ||||
| 	 * | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	public function version() | ||||
| 	{ | ||||
| 		if (isset($this->data_cache['version'])) | ||||
| 		{ | ||||
| 			return $this->data_cache['version']; | ||||
| 		} | ||||
|  | ||||
| 		if ( ! $this->conn_id OR ($pg_version = pg_version($this->conn_id)) === FALSE) | ||||
| 		{ | ||||
| 			return FALSE; | ||||
| 		} | ||||
|  | ||||
| 		/* If PHP was compiled with PostgreSQL lib versions earlier | ||||
| 		 * than 7.4, pg_version() won't return the server version | ||||
| 		 * and so we'll have to fall back to running a query in | ||||
| 		 * order to get it. | ||||
| 		 */ | ||||
| 		return (isset($pg_version['server']) && preg_match('#^(\d+\.\d+)#', $pg_version['server'], $match)) | ||||
| 			? $this->data_cache['version'] = $match[1] | ||||
| 			: parent::version(); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Execute the query | ||||
| 	 * | ||||
| 	 * @param	string	$sql	an SQL query | ||||
| 	 * @return	resource | ||||
| 	 */ | ||||
| 	protected function _execute($sql) | ||||
| 	{ | ||||
| 		return pg_query($this->conn_id, $sql); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Begin Transaction | ||||
| 	 * | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	protected function _trans_begin() | ||||
| 	{ | ||||
| 		return (bool) pg_query($this->conn_id, 'BEGIN'); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Commit Transaction | ||||
| 	 * | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	protected function _trans_commit() | ||||
| 	{ | ||||
| 		return (bool) pg_query($this->conn_id, 'COMMIT'); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Rollback Transaction | ||||
| 	 * | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	protected function _trans_rollback() | ||||
| 	{ | ||||
| 		return (bool) pg_query($this->conn_id, 'ROLLBACK'); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Determines if a query is a "write" type. | ||||
| 	 * | ||||
| 	 * @param	string	An SQL query string | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	public function is_write_type($sql) | ||||
| 	{ | ||||
| 		if (preg_match('#^(INSERT|UPDATE).*RETURNING\s.+(\,\s?.+)*$#is', $sql)) | ||||
| 		{ | ||||
| 			return FALSE; | ||||
| 		} | ||||
|  | ||||
| 		return parent::is_write_type($sql); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Platform-dependent string escape | ||||
| 	 * | ||||
| 	 * @param	string | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _escape_str($str) | ||||
| 	{ | ||||
| 		return pg_escape_string($this->conn_id, $str); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * "Smart" Escape String | ||||
| 	 * | ||||
| 	 * Escapes data based on type | ||||
| 	 * | ||||
| 	 * @param	string	$str | ||||
| 	 * @return	mixed | ||||
| 	 */ | ||||
| 	public function escape($str) | ||||
| 	{ | ||||
| 		if (is_php('5.4.4') && (is_string($str) OR (is_object($str) && method_exists($str, '__toString')))) | ||||
| 		{ | ||||
| 			return pg_escape_literal($this->conn_id, $str); | ||||
| 		} | ||||
| 		elseif (is_bool($str)) | ||||
| 		{ | ||||
| 			return ($str) ? 'TRUE' : 'FALSE'; | ||||
| 		} | ||||
|  | ||||
| 		return parent::escape($str); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Affected Rows | ||||
| 	 * | ||||
| 	 * @return	int | ||||
| 	 */ | ||||
| 	public function affected_rows() | ||||
| 	{ | ||||
| 		return pg_affected_rows($this->result_id); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Insert ID | ||||
| 	 * | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	public function insert_id() | ||||
| 	{ | ||||
| 		$v = $this->version(); | ||||
|  | ||||
| 		$table	= (func_num_args() > 0) ? func_get_arg(0) : NULL; | ||||
| 		$column	= (func_num_args() > 1) ? func_get_arg(1) : NULL; | ||||
|  | ||||
| 		if ($table === NULL && $v >= '8.1') | ||||
| 		{ | ||||
| 			$sql = 'SELECT LASTVAL() AS ins_id'; | ||||
| 		} | ||||
| 		elseif ($table !== NULL) | ||||
| 		{ | ||||
| 			if ($column !== NULL && $v >= '8.0') | ||||
| 			{ | ||||
| 				$sql = 'SELECT pg_get_serial_sequence(\''.$table."', '".$column."') AS seq"; | ||||
| 				$query = $this->query($sql); | ||||
| 				$query = $query->row(); | ||||
| 				$seq = $query->seq; | ||||
| 			} | ||||
| 			else | ||||
| 			{ | ||||
| 				// seq_name passed in table parameter | ||||
| 				$seq = $table; | ||||
| 			} | ||||
|  | ||||
| 			$sql = 'SELECT CURRVAL(\''.$seq."') AS ins_id"; | ||||
| 		} | ||||
| 		else | ||||
| 		{ | ||||
| 			return pg_last_oid($this->result_id); | ||||
| 		} | ||||
|  | ||||
| 		$query = $this->query($sql); | ||||
| 		$query = $query->row(); | ||||
| 		return (int) $query->ins_id; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Show table query | ||||
| 	 * | ||||
| 	 * Generates a platform-specific query string so that the table names can be fetched | ||||
| 	 * | ||||
| 	 * @param	bool	$prefix_limit | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _list_tables($prefix_limit = FALSE) | ||||
| 	{ | ||||
| 		$sql = 'SELECT "table_name" FROM "information_schema"."tables" WHERE "table_schema" = \''.$this->schema."'"; | ||||
|  | ||||
| 		if ($prefix_limit !== FALSE && $this->dbprefix !== '') | ||||
| 		{ | ||||
| 			return $sql.' AND "table_name" LIKE \'' | ||||
| 				.$this->escape_like_str($this->dbprefix)."%' " | ||||
| 				.sprintf($this->_like_escape_str, $this->_like_escape_chr); | ||||
| 		} | ||||
|  | ||||
| 		return $sql; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * List column query | ||||
| 	 * | ||||
| 	 * Generates a platform-specific query string so that the column names can be fetched | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _list_columns($table = '') | ||||
| 	{ | ||||
| 		return 'SELECT "column_name" | ||||
| 			FROM "information_schema"."columns" | ||||
| 			WHERE LOWER("table_name") = '.$this->escape(strtolower($table)); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Returns an object with field data | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	public function field_data($table) | ||||
| 	{ | ||||
| 		$sql = 'SELECT "column_name", "data_type", "character_maximum_length", "numeric_precision", "column_default" | ||||
| 			FROM "information_schema"."columns" | ||||
| 			WHERE LOWER("table_name") = '.$this->escape(strtolower($table)); | ||||
|  | ||||
| 		if (($query = $this->query($sql)) === FALSE) | ||||
| 		{ | ||||
| 			return FALSE; | ||||
| 		} | ||||
| 		$query = $query->result_object(); | ||||
|  | ||||
| 		$retval = array(); | ||||
| 		for ($i = 0, $c = count($query); $i < $c; $i++) | ||||
| 		{ | ||||
| 			$retval[$i]			= new stdClass(); | ||||
| 			$retval[$i]->name		= $query[$i]->column_name; | ||||
| 			$retval[$i]->type		= $query[$i]->data_type; | ||||
| 			$retval[$i]->max_length		= ($query[$i]->character_maximum_length > 0) ? $query[$i]->character_maximum_length : $query[$i]->numeric_precision; | ||||
| 			$retval[$i]->default		= $query[$i]->column_default; | ||||
| 		} | ||||
|  | ||||
| 		return $retval; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Error | ||||
| 	 * | ||||
| 	 * Returns an array containing code and message of the last | ||||
| 	 * database error that has occurred. | ||||
| 	 * | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	public function error() | ||||
| 	{ | ||||
| 		return array('code' => '', 'message' => pg_last_error($this->conn_id)); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * ORDER BY | ||||
| 	 * | ||||
| 	 * @param	string	$orderby | ||||
| 	 * @param	string	$direction	ASC, DESC or RANDOM | ||||
| 	 * @param	bool	$escape | ||||
| 	 * @return	object | ||||
| 	 */ | ||||
| 	public function order_by($orderby, $direction = '', $escape = NULL) | ||||
| 	{ | ||||
| 		$direction = strtoupper(trim($direction)); | ||||
| 		if ($direction === 'RANDOM') | ||||
| 		{ | ||||
| 			if ( ! is_float($orderby) && ctype_digit((string) $orderby)) | ||||
| 			{ | ||||
| 				$orderby = ($orderby > 1) | ||||
| 					? (float) '0.'.$orderby | ||||
| 					: (float) $orderby; | ||||
| 			} | ||||
|  | ||||
| 			if (is_float($orderby)) | ||||
| 			{ | ||||
| 				$this->simple_query('SET SEED '.$orderby); | ||||
| 			} | ||||
|  | ||||
| 			$orderby = $this->_random_keyword[0]; | ||||
| 			$direction = ''; | ||||
| 			$escape = FALSE; | ||||
| 		} | ||||
|  | ||||
| 		return parent::order_by($orderby, $direction, $escape); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Update statement | ||||
| 	 * | ||||
| 	 * Generates a platform-specific update string from the supplied data | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @param	array	$values | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _update($table, $values) | ||||
| 	{ | ||||
| 		$this->qb_limit = FALSE; | ||||
| 		$this->qb_orderby = array(); | ||||
| 		return parent::_update($table, $values); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Update_Batch statement | ||||
| 	 * | ||||
| 	 * Generates a platform-specific batch update string from the supplied data | ||||
| 	 * | ||||
| 	 * @param	string	$table	Table name | ||||
| 	 * @param	array	$values	Update data | ||||
| 	 * @param	string	$index	WHERE key | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _update_batch($table, $values, $index) | ||||
| 	{ | ||||
| 		$ids = array(); | ||||
| 		foreach ($values as $key => $val) | ||||
| 		{ | ||||
| 			$ids[] = $val[$index]['value']; | ||||
|  | ||||
| 			foreach (array_keys($val) as $field) | ||||
| 			{ | ||||
| 				if ($field !== $index) | ||||
| 				{ | ||||
| 					$final[$val[$field]['field']][] = 'WHEN '.$val[$index]['value'].' THEN '.$val[$field]['value']; | ||||
| 				} | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		$cases = ''; | ||||
| 		foreach ($final as $k => $v) | ||||
| 		{ | ||||
| 			$cases .= $k.' = (CASE '.$val[$index]['field']."\n" | ||||
| 				.implode("\n", $v)."\n" | ||||
| 				.'ELSE '.$k.' END), '; | ||||
| 		} | ||||
|  | ||||
| 		$this->where($val[$index]['field'].' IN('.implode(',', $ids).')', NULL, FALSE); | ||||
|  | ||||
| 		return 'UPDATE '.$table.' SET '.substr($cases, 0, -2).$this->_compile_wh('qb_where'); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Delete statement | ||||
| 	 * | ||||
| 	 * Generates a platform-specific delete string from the supplied data | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _delete($table) | ||||
| 	{ | ||||
| 		$this->qb_limit = FALSE; | ||||
| 		return parent::_delete($table); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * LIMIT | ||||
| 	 * | ||||
| 	 * Generates a platform-specific LIMIT clause | ||||
| 	 * | ||||
| 	 * @param	string	$sql	SQL Query | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _limit($sql) | ||||
| 	{ | ||||
| 		return $sql.' LIMIT '.$this->qb_limit.($this->qb_offset ? ' OFFSET '.$this->qb_offset : ''); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Close DB Connection | ||||
| 	 * | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	protected function _close() | ||||
| 	{ | ||||
| 		pg_close($this->conn_id); | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										205
									
								
								system/database/drivers/postgre/postgre_forge.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										205
									
								
								system/database/drivers/postgre/postgre_forge.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,205 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/) | ||||
|  * @license	https://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 1.3.0 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * Postgre Forge Class | ||||
|  * | ||||
|  * @package		CodeIgniter | ||||
|  * @subpackage	Drivers | ||||
|  * @category	Database | ||||
|  * @author		EllisLab Dev Team | ||||
|  * @link		https://codeigniter.com/user_guide/database/ | ||||
|  */ | ||||
| class CI_DB_postgre_forge extends CI_DB_forge { | ||||
|  | ||||
| 	/** | ||||
| 	 * UNSIGNED support | ||||
| 	 * | ||||
| 	 * @var	array | ||||
| 	 */ | ||||
| 	protected $_unsigned		= array( | ||||
| 		'INT2'		=> 'INTEGER', | ||||
| 		'SMALLINT'	=> 'INTEGER', | ||||
| 		'INT'		=> 'BIGINT', | ||||
| 		'INT4'		=> 'BIGINT', | ||||
| 		'INTEGER'	=> 'BIGINT', | ||||
| 		'INT8'		=> 'NUMERIC', | ||||
| 		'BIGINT'	=> 'NUMERIC', | ||||
| 		'REAL'		=> 'DOUBLE PRECISION', | ||||
| 		'FLOAT'		=> 'DOUBLE PRECISION' | ||||
| 	); | ||||
|  | ||||
| 	/** | ||||
| 	 * NULL value representation in CREATE/ALTER TABLE statements | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_null = 'NULL'; | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Class constructor | ||||
| 	 * | ||||
| 	 * @param	object	&$db	Database object | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	public function __construct(&$db) | ||||
| 	{ | ||||
| 		parent::__construct($db); | ||||
|  | ||||
| 		if (version_compare($this->db->version(), '9.0', '>')) | ||||
| 		{ | ||||
| 			$this->create_table_if = 'CREATE TABLE IF NOT EXISTS'; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * ALTER TABLE | ||||
| 	 * | ||||
| 	 * @param	string	$alter_type	ALTER type | ||||
| 	 * @param	string	$table		Table name | ||||
| 	 * @param	mixed	$field		Column definition | ||||
| 	 * @return	string|string[] | ||||
| 	 */ | ||||
| 	protected function _alter_table($alter_type, $table, $field) | ||||
|  	{ | ||||
| 		if (in_array($alter_type, array('DROP', 'ADD'), TRUE)) | ||||
| 		{ | ||||
| 			return parent::_alter_table($alter_type, $table, $field); | ||||
| 		} | ||||
|  | ||||
| 		$sql = 'ALTER TABLE '.$this->db->escape_identifiers($table); | ||||
| 		$sqls = array(); | ||||
| 		for ($i = 0, $c = count($field); $i < $c; $i++) | ||||
| 		{ | ||||
| 			if ($field[$i]['_literal'] !== FALSE) | ||||
| 			{ | ||||
| 				return FALSE; | ||||
| 			} | ||||
|  | ||||
| 			if (version_compare($this->db->version(), '8', '>=') && isset($field[$i]['type'])) | ||||
| 			{ | ||||
| 				$sqls[] = $sql.' ALTER COLUMN '.$this->db->escape_identifiers($field[$i]['name']) | ||||
| 					.' TYPE '.$field[$i]['type'].$field[$i]['length']; | ||||
| 			} | ||||
|  | ||||
| 			if ( ! empty($field[$i]['default'])) | ||||
| 			{ | ||||
| 				$sqls[] = $sql.' ALTER COLUMN '.$this->db->escape_identifiers($field[$i]['name']) | ||||
| 					.' SET '.$field[$i]['default']; | ||||
| 			} | ||||
|  | ||||
| 			if (isset($field[$i]['null'])) | ||||
| 			{ | ||||
| 				$sqls[] = $sql.' ALTER COLUMN '.$this->db->escape_identifiers($field[$i]['name']) | ||||
| 					.(trim($field[$i]['null']) === $this->_null ? ' DROP NOT NULL' : ' SET NOT NULL'); | ||||
| 			} | ||||
|  | ||||
| 			if ( ! empty($field[$i]['new_name'])) | ||||
| 			{ | ||||
| 				$sqls[] = $sql.' RENAME COLUMN '.$this->db->escape_identifiers($field[$i]['name']) | ||||
| 					.' TO '.$this->db->escape_identifiers($field[$i]['new_name']); | ||||
| 			} | ||||
|  | ||||
| 			if ( ! empty($field[$i]['comment'])) | ||||
| 			{ | ||||
| 				$sqls[] = 'COMMENT ON COLUMN ' | ||||
| 					.$this->db->escape_identifiers($table).'.'.$this->db->escape_identifiers($field[$i]['name']) | ||||
| 					.' IS '.$field[$i]['comment']; | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		return $sqls; | ||||
|  	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Field attribute TYPE | ||||
| 	 * | ||||
| 	 * Performs a data type mapping between different databases. | ||||
| 	 * | ||||
| 	 * @param	array	&$attributes | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	protected function _attr_type(&$attributes) | ||||
| 	{ | ||||
| 		// Reset field lengths for data types that don't support it | ||||
| 		if (isset($attributes['CONSTRAINT']) && stripos($attributes['TYPE'], 'int') !== FALSE) | ||||
| 		{ | ||||
| 			$attributes['CONSTRAINT'] = NULL; | ||||
| 		} | ||||
|  | ||||
| 		switch (strtoupper($attributes['TYPE'])) | ||||
| 		{ | ||||
| 			case 'TINYINT': | ||||
| 				$attributes['TYPE'] = 'SMALLINT'; | ||||
| 				$attributes['UNSIGNED'] = FALSE; | ||||
| 				return; | ||||
| 			case 'MEDIUMINT': | ||||
| 				$attributes['TYPE'] = 'INTEGER'; | ||||
| 				$attributes['UNSIGNED'] = FALSE; | ||||
| 				return; | ||||
| 			default: return; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Field attribute AUTO_INCREMENT | ||||
| 	 * | ||||
| 	 * @param	array	&$attributes | ||||
| 	 * @param	array	&$field | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	protected function _attr_auto_increment(&$attributes, &$field) | ||||
| 	{ | ||||
| 		if ( ! empty($attributes['AUTO_INCREMENT']) && $attributes['AUTO_INCREMENT'] === TRUE) | ||||
| 		{ | ||||
| 			$field['type'] = ($field['type'] === 'NUMERIC') | ||||
| 				? 'BIGSERIAL' | ||||
| 				: 'SERIAL'; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										182
									
								
								system/database/drivers/postgre/postgre_result.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										182
									
								
								system/database/drivers/postgre/postgre_result.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,182 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/) | ||||
|  * @license	https://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 1.3.0 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * Postgres Result Class | ||||
|  * | ||||
|  * This class extends the parent result class: CI_DB_result | ||||
|  * | ||||
|  * @package		CodeIgniter | ||||
|  * @subpackage	Drivers | ||||
|  * @category	Database | ||||
|  * @author		EllisLab Dev Team | ||||
|  * @link		https://codeigniter.com/user_guide/database/ | ||||
|  */ | ||||
| class CI_DB_postgre_result extends CI_DB_result { | ||||
|  | ||||
| 	/** | ||||
| 	 * Number of rows in the result set | ||||
| 	 * | ||||
| 	 * @return	int | ||||
| 	 */ | ||||
| 	public function num_rows() | ||||
| 	{ | ||||
| 		return is_int($this->num_rows) | ||||
| 			? $this->num_rows | ||||
| 			: $this->num_rows = pg_num_rows($this->result_id); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Number of fields in the result set | ||||
| 	 * | ||||
| 	 * @return	int | ||||
| 	 */ | ||||
| 	public function num_fields() | ||||
| 	{ | ||||
| 		return pg_num_fields($this->result_id); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Fetch Field Names | ||||
| 	 * | ||||
| 	 * Generates an array of column names | ||||
| 	 * | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	public function list_fields() | ||||
| 	{ | ||||
| 		$field_names = array(); | ||||
| 		for ($i = 0, $c = $this->num_fields(); $i < $c; $i++) | ||||
| 		{ | ||||
| 			$field_names[] = pg_field_name($this->result_id, $i); | ||||
| 		} | ||||
|  | ||||
| 		return $field_names; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Field data | ||||
| 	 * | ||||
| 	 * Generates an array of objects containing field meta-data | ||||
| 	 * | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	public function field_data() | ||||
| 	{ | ||||
| 		$retval = array(); | ||||
| 		for ($i = 0, $c = $this->num_fields(); $i < $c; $i++) | ||||
| 		{ | ||||
| 			$retval[$i]			= new stdClass(); | ||||
| 			$retval[$i]->name		= pg_field_name($this->result_id, $i); | ||||
| 			$retval[$i]->type		= pg_field_type($this->result_id, $i); | ||||
| 			$retval[$i]->max_length		= pg_field_size($this->result_id, $i); | ||||
| 		} | ||||
|  | ||||
| 		return $retval; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Free the result | ||||
| 	 * | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	public function free_result() | ||||
| 	{ | ||||
| 		if (is_resource($this->result_id)) | ||||
| 		{ | ||||
| 			pg_free_result($this->result_id); | ||||
| 			$this->result_id = FALSE; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Data Seek | ||||
| 	 * | ||||
| 	 * Moves the internal pointer to the desired offset. We call | ||||
| 	 * this internally before fetching results to make sure the | ||||
| 	 * result set starts at zero. | ||||
| 	 * | ||||
| 	 * @param	int	$n | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	public function data_seek($n = 0) | ||||
| 	{ | ||||
| 		return pg_result_seek($this->result_id, $n); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Result - associative array | ||||
| 	 * | ||||
| 	 * Returns the result set as an array | ||||
| 	 * | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	protected function _fetch_assoc() | ||||
| 	{ | ||||
| 		return pg_fetch_assoc($this->result_id); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Result - object | ||||
| 	 * | ||||
| 	 * Returns the result set as an object | ||||
| 	 * | ||||
| 	 * @param	string	$class_name | ||||
| 	 * @return	object | ||||
| 	 */ | ||||
| 	protected function _fetch_object($class_name = 'stdClass') | ||||
| 	{ | ||||
| 		return pg_fetch_object($this->result_id, NULL, $class_name); | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										78
									
								
								system/database/drivers/postgre/postgre_utility.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										78
									
								
								system/database/drivers/postgre/postgre_utility.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,78 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/) | ||||
|  * @license	https://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 1.3.0 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * Postgre Utility Class | ||||
|  * | ||||
|  * @package		CodeIgniter | ||||
|  * @subpackage	Drivers | ||||
|  * @category	Database | ||||
|  * @author		EllisLab Dev Team | ||||
|  * @link		https://codeigniter.com/user_guide/database/ | ||||
|  */ | ||||
| class CI_DB_postgre_utility extends CI_DB_utility { | ||||
|  | ||||
| 	/** | ||||
| 	 * List databases statement | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_list_databases	= 'SELECT datname FROM pg_database'; | ||||
|  | ||||
| 	/** | ||||
| 	 * OPTIMIZE TABLE statement | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_optimize_table	= 'REINDEX TABLE %s'; | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Export | ||||
| 	 * | ||||
| 	 * @param	array	$params	Preferences | ||||
| 	 * @return	mixed | ||||
| 	 */ | ||||
| 	protected function _backup($params = array()) | ||||
| 	{ | ||||
| 		// Currently unsupported | ||||
| 		return $this->db->display_error('db_unsupported_feature'); | ||||
| 	} | ||||
| } | ||||
							
								
								
									
										11
									
								
								system/database/drivers/sqlite/index.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								system/database/drivers/sqlite/index.html
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,11 @@ | ||||
| <!DOCTYPE html> | ||||
| <html> | ||||
| <head> | ||||
| 	<title>403 Forbidden</title> | ||||
| </head> | ||||
| <body> | ||||
|  | ||||
| <p>Directory access is forbidden.</p> | ||||
|  | ||||
| </body> | ||||
| </html> | ||||
							
								
								
									
										330
									
								
								system/database/drivers/sqlite/sqlite_driver.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										330
									
								
								system/database/drivers/sqlite/sqlite_driver.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,330 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (http://bcit.ca/) | ||||
|  * @license	http://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 1.3.0 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * SQLite Database Adapter Class | ||||
|  * | ||||
|  * Note: _DB is an extender class that the app controller | ||||
|  * creates dynamically based on whether the query builder | ||||
|  * class is being used or not. | ||||
|  * | ||||
|  * @package		CodeIgniter | ||||
|  * @subpackage	Drivers | ||||
|  * @category	Database | ||||
|  * @author		EllisLab Dev Team | ||||
|  * @link		https://codeigniter.com/user_guide/database/ | ||||
|  */ | ||||
| class CI_DB_sqlite_driver extends CI_DB { | ||||
|  | ||||
| 	/** | ||||
| 	 * Database driver | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	public $dbdriver = 'sqlite'; | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * ORDER BY random keyword | ||||
| 	 * | ||||
| 	 * @var	array | ||||
| 	 */ | ||||
| 	protected $_random_keyword = array('RANDOM()', 'RANDOM()'); | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Non-persistent database connection | ||||
| 	 * | ||||
| 	 * @param	bool	$persistent | ||||
| 	 * @return	resource | ||||
| 	 */ | ||||
| 	public function db_connect($persistent = FALSE) | ||||
| 	{ | ||||
| 		$error = NULL; | ||||
| 		$conn_id = ($persistent === TRUE) | ||||
| 			? sqlite_popen($this->database, 0666, $error) | ||||
| 			: sqlite_open($this->database, 0666, $error); | ||||
|  | ||||
| 		isset($error) && log_message('error', $error); | ||||
|  | ||||
| 		return $conn_id; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Database version number | ||||
| 	 * | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	public function version() | ||||
| 	{ | ||||
| 		return isset($this->data_cache['version']) | ||||
| 			? $this->data_cache['version'] | ||||
| 			: $this->data_cache['version'] = sqlite_libversion(); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Execute the query | ||||
| 	 * | ||||
| 	 * @param	string	$sql	an SQL query | ||||
| 	 * @return	resource | ||||
| 	 */ | ||||
| 	protected function _execute($sql) | ||||
| 	{ | ||||
| 		return $this->is_write_type($sql) | ||||
| 			? sqlite_exec($this->conn_id, $sql) | ||||
| 			: sqlite_query($this->conn_id, $sql); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Begin Transaction | ||||
| 	 * | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	protected function _trans_begin() | ||||
| 	{ | ||||
| 		return $this->simple_query('BEGIN TRANSACTION'); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Commit Transaction | ||||
| 	 * | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	protected function _trans_commit() | ||||
| 	{ | ||||
| 		return $this->simple_query('COMMIT'); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Rollback Transaction | ||||
| 	 * | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	protected function _trans_rollback() | ||||
| 	{ | ||||
| 		return $this->simple_query('ROLLBACK'); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Platform-dependant string escape | ||||
| 	 * | ||||
| 	 * @param	string | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _escape_str($str) | ||||
| 	{ | ||||
| 		return sqlite_escape_string($str); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Affected Rows | ||||
| 	 * | ||||
| 	 * @return	int | ||||
| 	 */ | ||||
| 	public function affected_rows() | ||||
| 	{ | ||||
| 		return sqlite_changes($this->conn_id); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Insert ID | ||||
| 	 * | ||||
| 	 * @return	int | ||||
| 	 */ | ||||
| 	public function insert_id() | ||||
| 	{ | ||||
| 		return sqlite_last_insert_rowid($this->conn_id); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * List table query | ||||
| 	 * | ||||
| 	 * Generates a platform-specific query string so that the table names can be fetched | ||||
| 	 * | ||||
| 	 * @param	bool	$prefix_limit | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _list_tables($prefix_limit = FALSE) | ||||
| 	{ | ||||
| 		$sql = "SELECT name FROM sqlite_master WHERE type='table'"; | ||||
|  | ||||
| 		if ($prefix_limit !== FALSE && $this->dbprefix != '') | ||||
| 		{ | ||||
| 			return $sql." AND 'name' LIKE '".$this->escape_like_str($this->dbprefix)."%' ".sprintf($this->_like_escape_str, $this->_like_escape_chr); | ||||
| 		} | ||||
|  | ||||
| 		return $sql; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Show column query | ||||
| 	 * | ||||
| 	 * Generates a platform-specific query string so that the column names can be fetched | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	protected function _list_columns($table = '') | ||||
| 	{ | ||||
| 		// Not supported | ||||
| 		return FALSE; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Returns an object with field data | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	public function field_data($table) | ||||
| 	{ | ||||
| 		if (($query = $this->query('PRAGMA TABLE_INFO('.$this->protect_identifiers($table, TRUE, NULL, FALSE).')')) === FALSE) | ||||
| 		{ | ||||
| 			return FALSE; | ||||
| 		} | ||||
|  | ||||
| 		$query = $query->result_array(); | ||||
| 		if (empty($query)) | ||||
| 		{ | ||||
| 			return FALSE; | ||||
| 		} | ||||
|  | ||||
| 		$retval = array(); | ||||
| 		for ($i = 0, $c = count($query); $i < $c; $i++) | ||||
| 		{ | ||||
| 			$retval[$i]			= new stdClass(); | ||||
| 			$retval[$i]->name		= $query[$i]['name']; | ||||
| 			$retval[$i]->type		= $query[$i]['type']; | ||||
| 			$retval[$i]->max_length		= NULL; | ||||
| 			$retval[$i]->default		= $query[$i]['dflt_value']; | ||||
| 			$retval[$i]->primary_key	= isset($query[$i]['pk']) ? (int) $query[$i]['pk'] : 0; | ||||
| 		} | ||||
|  | ||||
| 		return $retval; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Error | ||||
| 	 * | ||||
| 	 * Returns an array containing code and message of the last | ||||
| 	 * database error that has occured. | ||||
| 	 * | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	public function error() | ||||
| 	{ | ||||
| 		$error = array('code' => sqlite_last_error($this->conn_id)); | ||||
| 		$error['message'] = sqlite_error_string($error['code']); | ||||
| 		return $error; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Replace statement | ||||
| 	 * | ||||
| 	 * Generates a platform-specific replace string from the supplied data | ||||
| 	 * | ||||
| 	 * @param	string	$table	Table name | ||||
| 	 * @param	array	$keys	INSERT keys | ||||
| 	 * @param	array	$values	INSERT values | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _replace($table, $keys, $values) | ||||
| 	{ | ||||
| 		return 'INSERT OR '.parent::_replace($table, $keys, $values); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Truncate statement | ||||
| 	 * | ||||
| 	 * Generates a platform-specific truncate string from the supplied data | ||||
| 	 * | ||||
| 	 * If the database does not support the TRUNCATE statement, | ||||
| 	 * then this function maps to 'DELETE FROM table' | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _truncate($table) | ||||
| 	{ | ||||
| 		return 'DELETE FROM '.$table; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Close DB Connection | ||||
| 	 * | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	protected function _close() | ||||
| 	{ | ||||
| 		sqlite_close($this->conn_id); | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										205
									
								
								system/database/drivers/sqlite/sqlite_forge.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										205
									
								
								system/database/drivers/sqlite/sqlite_forge.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,205 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (http://bcit.ca/) | ||||
|  * @license	http://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 1.3.0 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * SQLite Forge Class | ||||
|  * | ||||
|  * @category	Database | ||||
|  * @author		EllisLab Dev Team | ||||
|  * @link		https://codeigniter.com/user_guide/database/ | ||||
|  */ | ||||
| class CI_DB_sqlite_forge extends CI_DB_forge { | ||||
|  | ||||
| 	/** | ||||
| 	 * CREATE TABLE IF statement | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_create_table_if	= FALSE; | ||||
|  | ||||
| 	/** | ||||
| 	 * UNSIGNED support | ||||
| 	 * | ||||
| 	 * @var	bool|array | ||||
| 	 */ | ||||
| 	protected $_unsigned		= FALSE; | ||||
|  | ||||
| 	/** | ||||
| 	 * NULL value representation in CREATE/ALTER TABLE statements | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_null		= 'NULL'; | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Create database | ||||
| 	 * | ||||
| 	 * @param	string	$db_name	(ignored) | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	public function create_database($db_name) | ||||
| 	{ | ||||
| 		// In SQLite, a database is created when you connect to the database. | ||||
| 		// We'll return TRUE so that an error isn't generated | ||||
| 		return TRUE; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Drop database | ||||
| 	 * | ||||
| 	 * @param	string	$db_name	(ignored) | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	public function drop_database($db_name) | ||||
| 	{ | ||||
| 		if ( ! file_exists($this->db->database) OR ! @unlink($this->db->database)) | ||||
| 		{ | ||||
| 			return ($this->db->db_debug) ? $this->db->display_error('db_unable_to_drop') : FALSE; | ||||
| 		} | ||||
| 		elseif ( ! empty($this->db->data_cache['db_names'])) | ||||
| 		{ | ||||
| 			$key = array_search(strtolower($this->db->database), array_map('strtolower', $this->db->data_cache['db_names']), TRUE); | ||||
| 			if ($key !== FALSE) | ||||
| 			{ | ||||
| 				unset($this->db->data_cache['db_names'][$key]); | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		return TRUE; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * ALTER TABLE | ||||
| 	 * | ||||
| 	 * @todo	implement drop_column(), modify_column() | ||||
| 	 * @param	string	$alter_type	ALTER type | ||||
| 	 * @param	string	$table		Table name | ||||
| 	 * @param	mixed	$field		Column definition | ||||
| 	 * @return	string|string[] | ||||
| 	 */ | ||||
| 	protected function _alter_table($alter_type, $table, $field) | ||||
| 	{ | ||||
| 		if ($alter_type === 'DROP' OR $alter_type === 'CHANGE') | ||||
| 		{ | ||||
| 			// drop_column(): | ||||
| 			//	BEGIN TRANSACTION; | ||||
| 			//	CREATE TEMPORARY TABLE t1_backup(a,b); | ||||
| 			//	INSERT INTO t1_backup SELECT a,b FROM t1; | ||||
| 			//	DROP TABLE t1; | ||||
| 			//	CREATE TABLE t1(a,b); | ||||
| 			//	INSERT INTO t1 SELECT a,b FROM t1_backup; | ||||
| 			//	DROP TABLE t1_backup; | ||||
| 			//	COMMIT; | ||||
|  | ||||
| 			return FALSE; | ||||
| 		} | ||||
|  | ||||
| 		return parent::_alter_table($alter_type, $table, $field); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Process column | ||||
| 	 * | ||||
| 	 * @param	array	$field | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _process_column($field) | ||||
| 	{ | ||||
| 		return $this->db->escape_identifiers($field['name']) | ||||
| 			.' '.$field['type'] | ||||
| 			.$field['auto_increment'] | ||||
| 			.$field['null'] | ||||
| 			.$field['unique'] | ||||
| 			.$field['default']; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Field attribute TYPE | ||||
| 	 * | ||||
| 	 * Performs a data type mapping between different databases. | ||||
| 	 * | ||||
| 	 * @param	array	&$attributes | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	protected function _attr_type(&$attributes) | ||||
| 	{ | ||||
| 		switch (strtoupper($attributes['TYPE'])) | ||||
| 		{ | ||||
| 			case 'ENUM': | ||||
| 			case 'SET': | ||||
| 				$attributes['TYPE'] = 'TEXT'; | ||||
| 				return; | ||||
| 			default: return; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Field attribute AUTO_INCREMENT | ||||
| 	 * | ||||
| 	 * @param	array	&$attributes | ||||
| 	 * @param	array	&$field | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	protected function _attr_auto_increment(&$attributes, &$field) | ||||
| 	{ | ||||
| 		if ( ! empty($attributes['AUTO_INCREMENT']) && $attributes['AUTO_INCREMENT'] === TRUE && stripos($field['type'], 'int') !== FALSE) | ||||
| 		{ | ||||
| 			$field['type'] = 'INTEGER PRIMARY KEY'; | ||||
| 			$field['default'] = ''; | ||||
| 			$field['null'] = ''; | ||||
| 			$field['unique'] = ''; | ||||
| 			$field['auto_increment'] = ' AUTOINCREMENT'; | ||||
|  | ||||
| 			$this->primary_keys = array(); | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										164
									
								
								system/database/drivers/sqlite/sqlite_result.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										164
									
								
								system/database/drivers/sqlite/sqlite_result.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,164 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (http://bcit.ca/) | ||||
|  * @license	http://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 1.3.0 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * SQLite Result Class | ||||
|  * | ||||
|  * This class extends the parent result class: CI_DB_result | ||||
|  * | ||||
|  * @category	Database | ||||
|  * @author		EllisLab Dev Team | ||||
|  * @link		https://codeigniter.com/user_guide/database/ | ||||
|  */ | ||||
| class CI_DB_sqlite_result extends CI_DB_result { | ||||
|  | ||||
| 	/** | ||||
| 	 * Number of rows in the result set | ||||
| 	 * | ||||
| 	 * @return	int | ||||
| 	 */ | ||||
| 	public function num_rows() | ||||
| 	{ | ||||
| 		return is_int($this->num_rows) | ||||
| 			? $this->num_rows | ||||
| 			: $this->num_rows = @sqlite_num_rows($this->result_id); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Number of fields in the result set | ||||
| 	 * | ||||
| 	 * @return	int | ||||
| 	 */ | ||||
| 	public function num_fields() | ||||
| 	{ | ||||
| 		return @sqlite_num_fields($this->result_id); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Fetch Field Names | ||||
| 	 * | ||||
| 	 * Generates an array of column names | ||||
| 	 * | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	public function list_fields() | ||||
| 	{ | ||||
| 		$field_names = array(); | ||||
| 		for ($i = 0, $c = $this->num_fields(); $i < $c; $i++) | ||||
| 		{ | ||||
| 			$field_names[$i] = sqlite_field_name($this->result_id, $i); | ||||
| 		} | ||||
|  | ||||
| 		return $field_names; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Field data | ||||
| 	 * | ||||
| 	 * Generates an array of objects containing field meta-data | ||||
| 	 * | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	public function field_data() | ||||
| 	{ | ||||
| 		$retval = array(); | ||||
| 		for ($i = 0, $c = $this->num_fields(); $i < $c; $i++) | ||||
| 		{ | ||||
| 			$retval[$i]			= new stdClass(); | ||||
| 			$retval[$i]->name		= sqlite_field_name($this->result_id, $i); | ||||
| 			$retval[$i]->type		= NULL; | ||||
| 			$retval[$i]->max_length		= NULL; | ||||
| 		} | ||||
|  | ||||
| 		return $retval; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Data Seek | ||||
| 	 * | ||||
| 	 * Moves the internal pointer to the desired offset. We call | ||||
| 	 * this internally before fetching results to make sure the | ||||
| 	 * result set starts at zero. | ||||
| 	 * | ||||
| 	 * @param	int	$n | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	public function data_seek($n = 0) | ||||
| 	{ | ||||
| 		return sqlite_seek($this->result_id, $n); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Result - associative array | ||||
| 	 * | ||||
| 	 * Returns the result set as an array | ||||
| 	 * | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	protected function _fetch_assoc() | ||||
| 	{ | ||||
| 		return sqlite_fetch_array($this->result_id); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Result - object | ||||
| 	 * | ||||
| 	 * Returns the result set as an object | ||||
| 	 * | ||||
| 	 * @param	string	$class_name | ||||
| 	 * @return	object | ||||
| 	 */ | ||||
| 	protected function _fetch_object($class_name = 'stdClass') | ||||
| 	{ | ||||
| 		return sqlite_fetch_object($this->result_id, $class_name); | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										61
									
								
								system/database/drivers/sqlite/sqlite_utility.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										61
									
								
								system/database/drivers/sqlite/sqlite_utility.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,61 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (http://bcit.ca/) | ||||
|  * @license	http://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 1.3.0 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * SQLite Utility Class | ||||
|  * | ||||
|  * @category	Database | ||||
|  * @author		EllisLab Dev Team | ||||
|  * @link		https://codeigniter.com/user_guide/database/ | ||||
|  */ | ||||
| class CI_DB_sqlite_utility extends CI_DB_utility { | ||||
|  | ||||
| 	/** | ||||
| 	 * Export | ||||
| 	 * | ||||
| 	 * @param	array	$params	Preferences | ||||
| 	 * @return	mixed | ||||
| 	 */ | ||||
| 	protected function _backup($params = array()) | ||||
| 	{ | ||||
| 		// Currently unsupported | ||||
| 		return $this->db->display_error('db_unsupported_feature'); | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										11
									
								
								system/database/drivers/sqlite3/index.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								system/database/drivers/sqlite3/index.html
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,11 @@ | ||||
| <!DOCTYPE html> | ||||
| <html> | ||||
| <head> | ||||
| 	<title>403 Forbidden</title> | ||||
| </head> | ||||
| <body> | ||||
|  | ||||
| <p>Directory access is forbidden.</p> | ||||
|  | ||||
| </body> | ||||
| </html> | ||||
							
								
								
									
										344
									
								
								system/database/drivers/sqlite3/sqlite3_driver.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										344
									
								
								system/database/drivers/sqlite3/sqlite3_driver.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,344 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/) | ||||
|  * @license	https://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 3.0.0 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * SQLite3 Database Adapter Class | ||||
|  * | ||||
|  * Note: _DB is an extender class that the app controller | ||||
|  * creates dynamically based on whether the query builder | ||||
|  * class is being used or not. | ||||
|  * | ||||
|  * @package		CodeIgniter | ||||
|  * @subpackage	Drivers | ||||
|  * @category	Database | ||||
|  * @author		Andrey Andreev | ||||
|  * @link		https://codeigniter.com/user_guide/database/ | ||||
|  */ | ||||
| class CI_DB_sqlite3_driver extends CI_DB { | ||||
|  | ||||
| 	/** | ||||
| 	 * Database driver | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	public $dbdriver = 'sqlite3'; | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * ORDER BY random keyword | ||||
| 	 * | ||||
| 	 * @var	array | ||||
| 	 */ | ||||
| 	protected $_random_keyword = array('RANDOM()', 'RANDOM()'); | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Non-persistent database connection | ||||
| 	 * | ||||
| 	 * @param	bool	$persistent | ||||
| 	 * @return	SQLite3 | ||||
| 	 */ | ||||
| 	public function db_connect($persistent = FALSE) | ||||
| 	{ | ||||
| 		if ($persistent) | ||||
| 		{ | ||||
| 			log_message('debug', 'SQLite3 doesn\'t support persistent connections'); | ||||
| 		} | ||||
|  | ||||
| 		try | ||||
| 		{ | ||||
| 			return ( ! $this->password) | ||||
| 				? new SQLite3($this->database) | ||||
| 				: new SQLite3($this->database, SQLITE3_OPEN_READWRITE | SQLITE3_OPEN_CREATE, $this->password); | ||||
| 		} | ||||
| 		catch (Exception $e) | ||||
| 		{ | ||||
| 			return FALSE; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Database version number | ||||
| 	 * | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	public function version() | ||||
| 	{ | ||||
| 		if (isset($this->data_cache['version'])) | ||||
| 		{ | ||||
| 			return $this->data_cache['version']; | ||||
| 		} | ||||
|  | ||||
| 		$version = SQLite3::version(); | ||||
| 		return $this->data_cache['version'] = $version['versionString']; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Execute the query | ||||
| 	 * | ||||
| 	 * @todo	Implement use of SQLite3::querySingle(), if needed | ||||
| 	 * @param	string	$sql | ||||
| 	 * @return	mixed	SQLite3Result object or bool | ||||
| 	 */ | ||||
| 	protected function _execute($sql) | ||||
| 	{ | ||||
| 		return $this->is_write_type($sql) | ||||
| 			? $this->conn_id->exec($sql) | ||||
| 			: $this->conn_id->query($sql); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Begin Transaction | ||||
| 	 * | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	protected function _trans_begin() | ||||
| 	{ | ||||
| 		return $this->conn_id->exec('BEGIN TRANSACTION'); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Commit Transaction | ||||
| 	 * | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	protected function _trans_commit() | ||||
| 	{ | ||||
| 		return $this->conn_id->exec('END TRANSACTION'); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Rollback Transaction | ||||
| 	 * | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	protected function _trans_rollback() | ||||
| 	{ | ||||
| 		return $this->conn_id->exec('ROLLBACK'); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Platform-dependent string escape | ||||
| 	 * | ||||
| 	 * @param	string | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _escape_str($str) | ||||
| 	{ | ||||
| 		return $this->conn_id->escapeString($str); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Affected Rows | ||||
| 	 * | ||||
| 	 * @return	int | ||||
| 	 */ | ||||
| 	public function affected_rows() | ||||
| 	{ | ||||
| 		return $this->conn_id->changes(); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Insert ID | ||||
| 	 * | ||||
| 	 * @return	int | ||||
| 	 */ | ||||
| 	public function insert_id() | ||||
| 	{ | ||||
| 		return $this->conn_id->lastInsertRowID(); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Show table query | ||||
| 	 * | ||||
| 	 * Generates a platform-specific query string so that the table names can be fetched | ||||
| 	 * | ||||
| 	 * @param	bool	$prefix_limit | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _list_tables($prefix_limit = FALSE) | ||||
| 	{ | ||||
| 		return 'SELECT "NAME" FROM "SQLITE_MASTER" WHERE "TYPE" = \'table\'' | ||||
| 			.(($prefix_limit !== FALSE && $this->dbprefix != '') | ||||
| 				? ' AND "NAME" LIKE \''.$this->escape_like_str($this->dbprefix).'%\' '.sprintf($this->_like_escape_str, $this->_like_escape_chr) | ||||
| 				: ''); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Fetch Field Names | ||||
| 	 * | ||||
| 	 * @param	string	$table	Table name | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	public function list_fields($table) | ||||
| 	{ | ||||
| 		if (($result = $this->query('PRAGMA TABLE_INFO('.$this->protect_identifiers($table, TRUE, NULL, FALSE).')')) === FALSE) | ||||
| 		{ | ||||
| 			return FALSE; | ||||
| 		} | ||||
|  | ||||
| 		$fields = array(); | ||||
| 		foreach ($result->result_array() as $row) | ||||
| 		{ | ||||
| 			$fields[] = $row['name']; | ||||
| 		} | ||||
|  | ||||
| 		return $fields; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Returns an object with field data | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	public function field_data($table) | ||||
| 	{ | ||||
| 		if (($query = $this->query('PRAGMA TABLE_INFO('.$this->protect_identifiers($table, TRUE, NULL, FALSE).')')) === FALSE) | ||||
| 		{ | ||||
| 			return FALSE; | ||||
| 		} | ||||
|  | ||||
| 		$query = $query->result_array(); | ||||
| 		if (empty($query)) | ||||
| 		{ | ||||
| 			return FALSE; | ||||
| 		} | ||||
|  | ||||
| 		$retval = array(); | ||||
| 		for ($i = 0, $c = count($query); $i < $c; $i++) | ||||
| 		{ | ||||
| 			$retval[$i]			= new stdClass(); | ||||
| 			$retval[$i]->name		= $query[$i]['name']; | ||||
| 			$retval[$i]->type		= $query[$i]['type']; | ||||
| 			$retval[$i]->max_length		= NULL; | ||||
| 			$retval[$i]->default		= $query[$i]['dflt_value']; | ||||
| 			$retval[$i]->primary_key	= isset($query[$i]['pk']) ? (int) $query[$i]['pk'] : 0; | ||||
| 		} | ||||
|  | ||||
| 		return $retval; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Error | ||||
| 	 * | ||||
| 	 * Returns an array containing code and message of the last | ||||
| 	 * database error that has occurred. | ||||
| 	 * | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	public function error() | ||||
| 	{ | ||||
| 		return array('code' => $this->conn_id->lastErrorCode(), 'message' => $this->conn_id->lastErrorMsg()); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Replace statement | ||||
| 	 * | ||||
| 	 * Generates a platform-specific replace string from the supplied data | ||||
| 	 * | ||||
| 	 * @param	string	$table	Table name | ||||
| 	 * @param	array	$keys	INSERT keys | ||||
| 	 * @param	array	$values	INSERT values | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _replace($table, $keys, $values) | ||||
| 	{ | ||||
| 		return 'INSERT OR '.parent::_replace($table, $keys, $values); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Truncate statement | ||||
| 	 * | ||||
| 	 * Generates a platform-specific truncate string from the supplied data | ||||
| 	 * | ||||
| 	 * If the database does not support the TRUNCATE statement, | ||||
| 	 * then this method maps to 'DELETE FROM table' | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _truncate($table) | ||||
| 	{ | ||||
| 		return 'DELETE FROM '.$table; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Close DB Connection | ||||
| 	 * | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	protected function _close() | ||||
| 	{ | ||||
| 		$this->conn_id->close(); | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										225
									
								
								system/database/drivers/sqlite3/sqlite3_forge.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										225
									
								
								system/database/drivers/sqlite3/sqlite3_forge.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,225 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/) | ||||
|  * @license	https://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 3.0.0 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * SQLite3 Forge Class | ||||
|  * | ||||
|  * @category	Database | ||||
|  * @author	Andrey Andreev | ||||
|  * @link	https://codeigniter.com/user_guide/database/ | ||||
|  */ | ||||
| class CI_DB_sqlite3_forge extends CI_DB_forge { | ||||
|  | ||||
| 	/** | ||||
| 	 * UNSIGNED support | ||||
| 	 * | ||||
| 	 * @var	bool|array | ||||
| 	 */ | ||||
| 	protected $_unsigned		= FALSE; | ||||
|  | ||||
| 	/** | ||||
| 	 * NULL value representation in CREATE/ALTER TABLE statements | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_null		= 'NULL'; | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Class constructor | ||||
| 	 * | ||||
| 	 * @param	object	&$db	Database object | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	public function __construct(&$db) | ||||
| 	{ | ||||
| 		parent::__construct($db); | ||||
|  | ||||
| 		if (version_compare($this->db->version(), '3.3', '<')) | ||||
| 		{ | ||||
| 			$this->_create_table_if = FALSE; | ||||
| 			$this->_drop_table_if   = FALSE; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Create database | ||||
| 	 * | ||||
| 	 * @param	string	$db_name | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	public function create_database($db_name) | ||||
| 	{ | ||||
| 		// In SQLite, a database is created when you connect to the database. | ||||
| 		// We'll return TRUE so that an error isn't generated | ||||
| 		return TRUE; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Drop database | ||||
| 	 * | ||||
| 	 * @param	string	$db_name	(ignored) | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	public function drop_database($db_name) | ||||
| 	{ | ||||
| 		// In SQLite, a database is dropped when we delete a file | ||||
| 		if (file_exists($this->db->database)) | ||||
| 		{ | ||||
| 			// We need to close the pseudo-connection first | ||||
| 			$this->db->close(); | ||||
| 			if ( ! @unlink($this->db->database)) | ||||
| 			{ | ||||
| 				return $this->db->db_debug ? $this->db->display_error('db_unable_to_drop') : FALSE; | ||||
| 			} | ||||
| 			elseif ( ! empty($this->db->data_cache['db_names'])) | ||||
| 			{ | ||||
| 				$key = array_search(strtolower($this->db->database), array_map('strtolower', $this->db->data_cache['db_names']), TRUE); | ||||
| 				if ($key !== FALSE) | ||||
| 				{ | ||||
| 					unset($this->db->data_cache['db_names'][$key]); | ||||
| 				} | ||||
| 			} | ||||
|  | ||||
| 			return TRUE; | ||||
| 		} | ||||
|  | ||||
| 		return $this->db->db_debug ? $this->db->display_error('db_unable_to_drop') : FALSE; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * ALTER TABLE | ||||
| 	 * | ||||
| 	 * @todo	implement drop_column(), modify_column() | ||||
| 	 * @param	string	$alter_type	ALTER type | ||||
| 	 * @param	string	$table		Table name | ||||
| 	 * @param	mixed	$field		Column definition | ||||
| 	 * @return	string|string[] | ||||
| 	 */ | ||||
| 	protected function _alter_table($alter_type, $table, $field) | ||||
| 	{ | ||||
| 		if ($alter_type === 'DROP' OR $alter_type === 'CHANGE') | ||||
| 		{ | ||||
| 			// drop_column(): | ||||
| 			//	BEGIN TRANSACTION; | ||||
| 			//	CREATE TEMPORARY TABLE t1_backup(a,b); | ||||
| 			//	INSERT INTO t1_backup SELECT a,b FROM t1; | ||||
| 			//	DROP TABLE t1; | ||||
| 			//	CREATE TABLE t1(a,b); | ||||
| 			//	INSERT INTO t1 SELECT a,b FROM t1_backup; | ||||
| 			//	DROP TABLE t1_backup; | ||||
| 			//	COMMIT; | ||||
|  | ||||
| 			return FALSE; | ||||
| 		} | ||||
|  | ||||
| 		return parent::_alter_table($alter_type, $table, $field); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Process column | ||||
| 	 * | ||||
| 	 * @param	array	$field | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _process_column($field) | ||||
| 	{ | ||||
| 		return $this->db->escape_identifiers($field['name']) | ||||
| 			.' '.$field['type'] | ||||
| 			.$field['auto_increment'] | ||||
| 			.$field['null'] | ||||
| 			.$field['unique'] | ||||
| 			.$field['default']; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Field attribute TYPE | ||||
| 	 * | ||||
| 	 * Performs a data type mapping between different databases. | ||||
| 	 * | ||||
| 	 * @param	array	&$attributes | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	protected function _attr_type(&$attributes) | ||||
| 	{ | ||||
| 		switch (strtoupper($attributes['TYPE'])) | ||||
| 		{ | ||||
| 			case 'ENUM': | ||||
| 			case 'SET': | ||||
| 				$attributes['TYPE'] = 'TEXT'; | ||||
| 				return; | ||||
| 			default: return; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Field attribute AUTO_INCREMENT | ||||
| 	 * | ||||
| 	 * @param	array	&$attributes | ||||
| 	 * @param	array	&$field | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	protected function _attr_auto_increment(&$attributes, &$field) | ||||
| 	{ | ||||
| 		if ( ! empty($attributes['AUTO_INCREMENT']) && $attributes['AUTO_INCREMENT'] === TRUE && stripos($field['type'], 'int') !== FALSE) | ||||
| 		{ | ||||
| 			$field['type'] = 'INTEGER PRIMARY KEY'; | ||||
| 			$field['default'] = ''; | ||||
| 			$field['null'] = ''; | ||||
| 			$field['unique'] = ''; | ||||
| 			$field['auto_increment'] = ' AUTOINCREMENT'; | ||||
|  | ||||
| 			$this->primary_keys = array(); | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										194
									
								
								system/database/drivers/sqlite3/sqlite3_result.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										194
									
								
								system/database/drivers/sqlite3/sqlite3_result.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,194 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/) | ||||
|  * @license	https://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 3.0.0 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * SQLite3 Result Class | ||||
|  * | ||||
|  * This class extends the parent result class: CI_DB_result | ||||
|  * | ||||
|  * @category	Database | ||||
|  * @author		Andrey Andreev | ||||
|  * @link		https://codeigniter.com/user_guide/database/ | ||||
|  */ | ||||
| class CI_DB_sqlite3_result extends CI_DB_result { | ||||
|  | ||||
| 	/** | ||||
| 	 * Number of fields in the result set | ||||
| 	 * | ||||
| 	 * @return	int | ||||
| 	 */ | ||||
| 	public function num_fields() | ||||
| 	{ | ||||
| 		return $this->result_id->numColumns(); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Fetch Field Names | ||||
| 	 * | ||||
| 	 * Generates an array of column names | ||||
| 	 * | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	public function list_fields() | ||||
| 	{ | ||||
| 		$field_names = array(); | ||||
| 		for ($i = 0, $c = $this->num_fields(); $i < $c; $i++) | ||||
| 		{ | ||||
| 			$field_names[] = $this->result_id->columnName($i); | ||||
| 		} | ||||
|  | ||||
| 		return $field_names; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Field data | ||||
| 	 * | ||||
| 	 * Generates an array of objects containing field meta-data | ||||
| 	 * | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	public function field_data() | ||||
| 	{ | ||||
| 		static $data_types = array( | ||||
| 			SQLITE3_INTEGER	=> 'integer', | ||||
| 			SQLITE3_FLOAT	=> 'float', | ||||
| 			SQLITE3_TEXT	=> 'text', | ||||
| 			SQLITE3_BLOB	=> 'blob', | ||||
| 			SQLITE3_NULL	=> 'null' | ||||
| 		); | ||||
|  | ||||
| 		$retval = array(); | ||||
| 		for ($i = 0, $c = $this->num_fields(); $i < $c; $i++) | ||||
| 		{ | ||||
| 			$retval[$i]			= new stdClass(); | ||||
| 			$retval[$i]->name		= $this->result_id->columnName($i); | ||||
|  | ||||
| 			$type = $this->result_id->columnType($i); | ||||
| 			$retval[$i]->type		= isset($data_types[$type]) ? $data_types[$type] : $type; | ||||
|  | ||||
| 			$retval[$i]->max_length		= NULL; | ||||
| 		} | ||||
|  | ||||
| 		return $retval; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Free the result | ||||
| 	 * | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	public function free_result() | ||||
| 	{ | ||||
| 		if (is_object($this->result_id)) | ||||
| 		{ | ||||
| 			$this->result_id->finalize(); | ||||
| 			$this->result_id = NULL; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Result - associative array | ||||
| 	 * | ||||
| 	 * Returns the result set as an array | ||||
| 	 * | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	protected function _fetch_assoc() | ||||
| 	{ | ||||
| 		return $this->result_id->fetchArray(SQLITE3_ASSOC); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Result - object | ||||
| 	 * | ||||
| 	 * Returns the result set as an object | ||||
| 	 * | ||||
| 	 * @param	string	$class_name | ||||
| 	 * @return	object | ||||
| 	 */ | ||||
| 	protected function _fetch_object($class_name = 'stdClass') | ||||
| 	{ | ||||
| 		// No native support for fetching rows as objects | ||||
| 		if (($row = $this->result_id->fetchArray(SQLITE3_ASSOC)) === FALSE) | ||||
| 		{ | ||||
| 			return FALSE; | ||||
| 		} | ||||
| 		elseif ($class_name === 'stdClass') | ||||
| 		{ | ||||
| 			return (object) $row; | ||||
| 		} | ||||
|  | ||||
| 		$class_name = new $class_name(); | ||||
| 		foreach (array_keys($row) as $key) | ||||
| 		{ | ||||
| 			$class_name->$key = $row[$key]; | ||||
| 		} | ||||
|  | ||||
| 		return $class_name; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Data Seek | ||||
| 	 * | ||||
| 	 * Moves the internal pointer to the desired offset. We call | ||||
| 	 * this internally before fetching results to make sure the | ||||
| 	 * result set starts at zero. | ||||
| 	 * | ||||
| 	 * @param	int	$n	(ignored) | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	public function data_seek($n = 0) | ||||
| 	{ | ||||
| 		// Only resetting to the start of the result set is supported | ||||
| 		return ($n > 0) ? FALSE : $this->result_id->reset(); | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										61
									
								
								system/database/drivers/sqlite3/sqlite3_utility.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										61
									
								
								system/database/drivers/sqlite3/sqlite3_utility.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,61 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/) | ||||
|  * @license	https://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 3.0.0 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * SQLite3 Utility Class | ||||
|  * | ||||
|  * @category	Database | ||||
|  * @author	Andrey Andreev | ||||
|  * @link	https://codeigniter.com/user_guide/database/ | ||||
|  */ | ||||
| class CI_DB_sqlite3_utility extends CI_DB_utility { | ||||
|  | ||||
| 	/** | ||||
| 	 * Export | ||||
| 	 * | ||||
| 	 * @param	array	$params	Preferences | ||||
| 	 * @return	mixed | ||||
| 	 */ | ||||
| 	protected function _backup($params = array()) | ||||
| 	{ | ||||
| 		// Not supported | ||||
| 		return $this->db->display_error('db_unsupported_feature'); | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										11
									
								
								system/database/drivers/sqlsrv/index.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								system/database/drivers/sqlsrv/index.html
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,11 @@ | ||||
| <!DOCTYPE html> | ||||
| <html> | ||||
| <head> | ||||
| 	<title>403 Forbidden</title> | ||||
| </head> | ||||
| <body> | ||||
|  | ||||
| <p>Directory access is forbidden.</p> | ||||
|  | ||||
| </body> | ||||
| </html> | ||||
							
								
								
									
										543
									
								
								system/database/drivers/sqlsrv/sqlsrv_driver.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										543
									
								
								system/database/drivers/sqlsrv/sqlsrv_driver.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,543 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/) | ||||
|  * @license	https://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 2.0.3 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * SQLSRV Database Adapter Class | ||||
|  * | ||||
|  * Note: _DB is an extender class that the app controller | ||||
|  * creates dynamically based on whether the query builder | ||||
|  * class is being used or not. | ||||
|  * | ||||
|  * @package		CodeIgniter | ||||
|  * @subpackage	Drivers | ||||
|  * @category	Database | ||||
|  * @author		EllisLab Dev Team | ||||
|  * @link		https://codeigniter.com/user_guide/database/ | ||||
|  */ | ||||
| class CI_DB_sqlsrv_driver extends CI_DB { | ||||
|  | ||||
| 	/** | ||||
| 	 * Database driver | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	public $dbdriver = 'sqlsrv'; | ||||
|  | ||||
| 	/** | ||||
| 	 * Scrollable flag | ||||
| 	 * | ||||
| 	 * Determines what cursor type to use when executing queries. | ||||
| 	 * | ||||
| 	 * FALSE or SQLSRV_CURSOR_FORWARD would increase performance, | ||||
| 	 * but would disable num_rows() (and possibly insert_id()) | ||||
| 	 * | ||||
| 	 * @var	mixed | ||||
| 	 */ | ||||
| 	public $scrollable; | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * ORDER BY random keyword | ||||
| 	 * | ||||
| 	 * @var	array | ||||
| 	 */ | ||||
| 	protected $_random_keyword = array('NEWID()', 'RAND(%d)'); | ||||
|  | ||||
| 	/** | ||||
| 	 * Quoted identifier flag | ||||
| 	 * | ||||
| 	 * Whether to use SQL-92 standard quoted identifier | ||||
| 	 * (double quotes) or brackets for identifier escaping. | ||||
| 	 * | ||||
| 	 * @var	bool | ||||
| 	 */ | ||||
| 	protected $_quoted_identifier = TRUE; | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Class constructor | ||||
| 	 * | ||||
| 	 * @param	array	$params | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	public function __construct($params) | ||||
| 	{ | ||||
| 		parent::__construct($params); | ||||
|  | ||||
| 		// This is only supported as of SQLSRV 3.0 | ||||
| 		if ($this->scrollable === NULL) | ||||
| 		{ | ||||
| 			$this->scrollable = defined('SQLSRV_CURSOR_CLIENT_BUFFERED') | ||||
| 				? SQLSRV_CURSOR_CLIENT_BUFFERED | ||||
| 				: FALSE; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Database connection | ||||
| 	 * | ||||
| 	 * @param	bool	$pooling | ||||
| 	 * @return	resource | ||||
| 	 */ | ||||
| 	public function db_connect($pooling = FALSE) | ||||
| 	{ | ||||
| 		$charset = in_array(strtolower($this->char_set), array('utf-8', 'utf8'), TRUE) | ||||
| 			? 'UTF-8' : SQLSRV_ENC_CHAR; | ||||
|  | ||||
| 		$connection = array( | ||||
| 			'UID'			=> empty($this->username) ? '' : $this->username, | ||||
| 			'PWD'			=> empty($this->password) ? '' : $this->password, | ||||
| 			'Database'		=> $this->database, | ||||
| 			'ConnectionPooling'	=> ($pooling === TRUE) ? 1 : 0, | ||||
| 			'CharacterSet'		=> $charset, | ||||
| 			'Encrypt'		=> ($this->encrypt === TRUE) ? 1 : 0, | ||||
| 			'ReturnDatesAsStrings'	=> 1 | ||||
| 		); | ||||
|  | ||||
| 		// If the username and password are both empty, assume this is a | ||||
| 		// 'Windows Authentication Mode' connection. | ||||
| 		if (empty($connection['UID']) && empty($connection['PWD'])) | ||||
| 		{ | ||||
| 			unset($connection['UID'], $connection['PWD']); | ||||
| 		} | ||||
|  | ||||
| 		if (FALSE !== ($this->conn_id = sqlsrv_connect($this->hostname, $connection))) | ||||
| 		{ | ||||
| 			// Determine how identifiers are escaped | ||||
| 			$query = $this->query('SELECT CASE WHEN (@@OPTIONS | 256) = @@OPTIONS THEN 1 ELSE 0 END AS qi'); | ||||
| 			$query = $query->row_array(); | ||||
| 			$this->_quoted_identifier = empty($query) ? FALSE : (bool) $query['qi']; | ||||
| 			$this->_escape_char = ($this->_quoted_identifier) ? '"' : array('[', ']'); | ||||
| 		} | ||||
|  | ||||
| 		return $this->conn_id; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Select the database | ||||
| 	 * | ||||
| 	 * @param	string	$database | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	public function db_select($database = '') | ||||
| 	{ | ||||
| 		if ($database === '') | ||||
| 		{ | ||||
| 			$database = $this->database; | ||||
| 		} | ||||
|  | ||||
| 		if ($this->_execute('USE '.$this->escape_identifiers($database))) | ||||
| 		{ | ||||
| 			$this->database = $database; | ||||
| 			$this->data_cache = array(); | ||||
| 			return TRUE; | ||||
| 		} | ||||
|  | ||||
| 		return FALSE; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Execute the query | ||||
| 	 * | ||||
| 	 * @param	string	$sql	an SQL query | ||||
| 	 * @return	resource | ||||
| 	 */ | ||||
| 	protected function _execute($sql) | ||||
| 	{ | ||||
| 		return ($this->scrollable === FALSE OR $this->is_write_type($sql)) | ||||
| 			? sqlsrv_query($this->conn_id, $sql) | ||||
| 			: sqlsrv_query($this->conn_id, $sql, NULL, array('Scrollable' => $this->scrollable)); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Begin Transaction | ||||
| 	 * | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	protected function _trans_begin() | ||||
| 	{ | ||||
| 		return sqlsrv_begin_transaction($this->conn_id); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Commit Transaction | ||||
| 	 * | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	protected function _trans_commit() | ||||
| 	{ | ||||
| 		return sqlsrv_commit($this->conn_id); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Rollback Transaction | ||||
| 	 * | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	protected function _trans_rollback() | ||||
| 	{ | ||||
| 		return sqlsrv_rollback($this->conn_id); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Affected Rows | ||||
| 	 * | ||||
| 	 * @return	int | ||||
| 	 */ | ||||
| 	public function affected_rows() | ||||
| 	{ | ||||
| 		return sqlsrv_rows_affected($this->result_id); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Insert ID | ||||
| 	 * | ||||
| 	 * Returns the last id created in the Identity column. | ||||
| 	 * | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	public function insert_id() | ||||
| 	{ | ||||
| 		return $this->query('SELECT SCOPE_IDENTITY() AS insert_id')->row()->insert_id; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Database version number | ||||
| 	 * | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	public function version() | ||||
| 	{ | ||||
| 		if (isset($this->data_cache['version'])) | ||||
| 		{ | ||||
| 			return $this->data_cache['version']; | ||||
| 		} | ||||
|  | ||||
| 		if ( ! $this->conn_id OR ($info = sqlsrv_server_info($this->conn_id)) === FALSE) | ||||
| 		{ | ||||
| 			return FALSE; | ||||
| 		} | ||||
|  | ||||
| 		return $this->data_cache['version'] = $info['SQLServerVersion']; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * List table query | ||||
| 	 * | ||||
| 	 * Generates a platform-specific query string so that the table names can be fetched | ||||
| 	 * | ||||
| 	 * @param	bool | ||||
| 	 * @return	string	$prefix_limit | ||||
| 	 */ | ||||
| 	protected function _list_tables($prefix_limit = FALSE) | ||||
| 	{ | ||||
| 		$sql = 'SELECT '.$this->escape_identifiers('name') | ||||
| 			.' FROM '.$this->escape_identifiers('sysobjects') | ||||
| 			.' WHERE '.$this->escape_identifiers('type')." = 'U'"; | ||||
|  | ||||
| 		if ($prefix_limit === TRUE && $this->dbprefix !== '') | ||||
| 		{ | ||||
| 			$sql .= ' AND '.$this->escape_identifiers('name')." LIKE '".$this->escape_like_str($this->dbprefix)."%' " | ||||
| 				.sprintf($this->_escape_like_str, $this->_escape_like_chr); | ||||
| 		} | ||||
|  | ||||
| 		return $sql.' ORDER BY '.$this->escape_identifiers('name'); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * List column query | ||||
| 	 * | ||||
| 	 * Generates a platform-specific query string so that the column names can be fetched | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _list_columns($table = '') | ||||
| 	{ | ||||
| 		return 'SELECT COLUMN_NAME | ||||
| 			FROM INFORMATION_SCHEMA.Columns | ||||
| 			WHERE UPPER(TABLE_NAME) = '.$this->escape(strtoupper($table)); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Returns an object with field data | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	public function field_data($table) | ||||
| 	{ | ||||
| 		$sql = 'SELECT COLUMN_NAME, DATA_TYPE, CHARACTER_MAXIMUM_LENGTH, NUMERIC_PRECISION, COLUMN_DEFAULT | ||||
| 			FROM INFORMATION_SCHEMA.Columns | ||||
| 			WHERE UPPER(TABLE_NAME) = '.$this->escape(strtoupper($table)); | ||||
|  | ||||
| 		if (($query = $this->query($sql)) === FALSE) | ||||
| 		{ | ||||
| 			return FALSE; | ||||
| 		} | ||||
| 		$query = $query->result_object(); | ||||
|  | ||||
| 		$retval = array(); | ||||
| 		for ($i = 0, $c = count($query); $i < $c; $i++) | ||||
| 		{ | ||||
| 			$retval[$i]			= new stdClass(); | ||||
| 			$retval[$i]->name		= $query[$i]->COLUMN_NAME; | ||||
| 			$retval[$i]->type		= $query[$i]->DATA_TYPE; | ||||
| 			$retval[$i]->max_length		= ($query[$i]->CHARACTER_MAXIMUM_LENGTH > 0) ? $query[$i]->CHARACTER_MAXIMUM_LENGTH : $query[$i]->NUMERIC_PRECISION; | ||||
| 			$retval[$i]->default		= $query[$i]->COLUMN_DEFAULT; | ||||
| 		} | ||||
|  | ||||
| 		return $retval; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Error | ||||
| 	 * | ||||
| 	 * Returns an array containing code and message of the last | ||||
| 	 * database error that has occurred. | ||||
| 	 * | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	public function error() | ||||
| 	{ | ||||
| 		$error = array('code' => '00000', 'message' => ''); | ||||
| 		$sqlsrv_errors = sqlsrv_errors(SQLSRV_ERR_ERRORS); | ||||
|  | ||||
| 		if ( ! is_array($sqlsrv_errors)) | ||||
| 		{ | ||||
| 			return $error; | ||||
| 		} | ||||
|  | ||||
| 		$sqlsrv_error = array_shift($sqlsrv_errors); | ||||
| 		if (isset($sqlsrv_error['SQLSTATE'])) | ||||
| 		{ | ||||
| 			$error['code'] = isset($sqlsrv_error['code']) ? $sqlsrv_error['SQLSTATE'].'/'.$sqlsrv_error['code'] : $sqlsrv_error['SQLSTATE']; | ||||
| 		} | ||||
| 		elseif (isset($sqlsrv_error['code'])) | ||||
| 		{ | ||||
| 			$error['code'] = $sqlsrv_error['code']; | ||||
| 		} | ||||
|  | ||||
| 		if (isset($sqlsrv_error['message'])) | ||||
| 		{ | ||||
| 			$error['message'] = $sqlsrv_error['message']; | ||||
| 		} | ||||
|  | ||||
| 		return $error; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Update statement | ||||
| 	 * | ||||
| 	 * Generates a platform-specific update string from the supplied data | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @param	array	$values | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _update($table, $values) | ||||
| 	{ | ||||
| 		$this->qb_limit = FALSE; | ||||
| 		$this->qb_orderby = array(); | ||||
| 		return parent::_update($table, $values); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Truncate statement | ||||
| 	 * | ||||
| 	 * Generates a platform-specific truncate string from the supplied data | ||||
| 	 * | ||||
| 	 * If the database does not support the TRUNCATE statement, | ||||
| 	 * then this method maps to 'DELETE FROM table' | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _truncate($table) | ||||
| 	{ | ||||
| 		return 'TRUNCATE TABLE '.$table; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Delete statement | ||||
| 	 * | ||||
| 	 * Generates a platform-specific delete string from the supplied data | ||||
| 	 * | ||||
| 	 * @param	string	$table | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _delete($table) | ||||
| 	{ | ||||
| 		if ($this->qb_limit) | ||||
| 		{ | ||||
| 			return 'WITH ci_delete AS (SELECT TOP '.$this->qb_limit.' * FROM '.$table.$this->_compile_wh('qb_where').') DELETE FROM ci_delete'; | ||||
| 		} | ||||
|  | ||||
| 		return parent::_delete($table); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * LIMIT | ||||
| 	 * | ||||
| 	 * Generates a platform-specific LIMIT clause | ||||
| 	 * | ||||
| 	 * @param	string	$sql	SQL Query | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	protected function _limit($sql) | ||||
| 	{ | ||||
| 		// As of SQL Server 2012 (11.0.*) OFFSET is supported | ||||
| 		if (version_compare($this->version(), '11', '>=')) | ||||
| 		{ | ||||
| 			// SQL Server OFFSET-FETCH can be used only with the ORDER BY clause | ||||
| 			empty($this->qb_orderby) && $sql .= ' ORDER BY 1'; | ||||
|  | ||||
| 			return $sql.' OFFSET '.(int) $this->qb_offset.' ROWS FETCH NEXT '.$this->qb_limit.' ROWS ONLY'; | ||||
| 		} | ||||
|  | ||||
| 		$limit = $this->qb_offset + $this->qb_limit; | ||||
|  | ||||
| 		// An ORDER BY clause is required for ROW_NUMBER() to work | ||||
| 		if ($this->qb_offset && ! empty($this->qb_orderby)) | ||||
| 		{ | ||||
| 			$orderby = $this->_compile_order_by(); | ||||
|  | ||||
| 			// We have to strip the ORDER BY clause | ||||
| 			$sql = trim(substr($sql, 0, strrpos($sql, $orderby))); | ||||
|  | ||||
| 			// Get the fields to select from our subquery, so that we can avoid CI_rownum appearing in the actual results | ||||
| 			if (count($this->qb_select) === 0 OR strpos(implode(',', $this->qb_select), '*') !== FALSE) | ||||
| 			{ | ||||
| 				$select = '*'; // Inevitable | ||||
| 			} | ||||
| 			else | ||||
| 			{ | ||||
| 				// Use only field names and their aliases, everything else is out of our scope. | ||||
| 				$select = array(); | ||||
| 				$field_regexp = ($this->_quoted_identifier) | ||||
| 					? '("[^\"]+")' : '(\[[^\]]+\])'; | ||||
| 				for ($i = 0, $c = count($this->qb_select); $i < $c; $i++) | ||||
| 				{ | ||||
| 					$select[] = preg_match('/(?:\s|\.)'.$field_regexp.'$/i', $this->qb_select[$i], $m) | ||||
| 						? $m[1] : $this->qb_select[$i]; | ||||
| 				} | ||||
| 				$select = implode(', ', $select); | ||||
| 			} | ||||
|  | ||||
| 			return 'SELECT '.$select." FROM (\n\n" | ||||
| 				.preg_replace('/^(SELECT( DISTINCT)?)/i', '\\1 ROW_NUMBER() OVER('.trim($orderby).') AS '.$this->escape_identifiers('CI_rownum').', ', $sql) | ||||
| 				."\n\n) ".$this->escape_identifiers('CI_subquery') | ||||
| 				."\nWHERE ".$this->escape_identifiers('CI_rownum').' BETWEEN '.($this->qb_offset + 1).' AND '.$limit; | ||||
| 		} | ||||
|  | ||||
| 		return preg_replace('/(^\SELECT (DISTINCT)?)/i','\\1 TOP '.$limit.' ', $sql); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Insert batch statement | ||||
| 	 * | ||||
| 	 * Generates a platform-specific insert string from the supplied data. | ||||
| 	 * | ||||
| 	 * @param	string	$table	Table name | ||||
| 	 * @param	array	$keys	INSERT keys | ||||
| 	 * @param	array	$values	INSERT values | ||||
| 	 * @return	string|bool | ||||
| 	 */ | ||||
| 	protected function _insert_batch($table, $keys, $values) | ||||
| 	{ | ||||
| 		// Multiple-value inserts are only supported as of SQL Server 2008 | ||||
| 		if (version_compare($this->version(), '10', '>=')) | ||||
| 		{ | ||||
| 			return parent::_insert_batch($table, $keys, $values); | ||||
| 		} | ||||
|  | ||||
| 		return ($this->db_debug) ? $this->display_error('db_unsupported_feature') : FALSE; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Close DB Connection | ||||
| 	 * | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	protected function _close() | ||||
| 	{ | ||||
| 		sqlsrv_close($this->conn_id); | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										149
									
								
								system/database/drivers/sqlsrv/sqlsrv_forge.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										149
									
								
								system/database/drivers/sqlsrv/sqlsrv_forge.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,149 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/) | ||||
|  * @license	https://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 2.0.3 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * SQLSRV Forge Class | ||||
|  * | ||||
|  * @category	Database | ||||
|  * @author		EllisLab Dev Team | ||||
|  * @link		https://codeigniter.com/user_guide/database/ | ||||
|  */ | ||||
| class CI_DB_sqlsrv_forge extends CI_DB_forge { | ||||
|  | ||||
| 	/** | ||||
| 	 * CREATE TABLE IF statement | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_create_table_if	= "IF NOT EXISTS (SELECT * FROM sysobjects WHERE ID = object_id(N'%s') AND OBJECTPROPERTY(id, N'IsUserTable') = 1)\nCREATE TABLE"; | ||||
|  | ||||
| 	/** | ||||
| 	 * DROP TABLE IF statement | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_drop_table_if	= "IF EXISTS (SELECT * FROM sysobjects WHERE ID = object_id(N'%s') AND OBJECTPROPERTY(id, N'IsUserTable') = 1)\nDROP TABLE"; | ||||
|  | ||||
| 	/** | ||||
| 	 * UNSIGNED support | ||||
| 	 * | ||||
| 	 * @var	array | ||||
| 	 */ | ||||
| 	protected $_unsigned		= array( | ||||
| 		'TINYINT'	=> 'SMALLINT', | ||||
| 		'SMALLINT'	=> 'INT', | ||||
| 		'INT'		=> 'BIGINT', | ||||
| 		'REAL'		=> 'FLOAT' | ||||
| 	); | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * ALTER TABLE | ||||
| 	 * | ||||
| 	 * @param	string	$alter_type	ALTER type | ||||
| 	 * @param	string	$table		Table name | ||||
| 	 * @param	mixed	$field		Column definition | ||||
| 	 * @return	string|string[] | ||||
| 	 */ | ||||
| 	protected function _alter_table($alter_type, $table, $field) | ||||
| 	{ | ||||
| 		if (in_array($alter_type, array('ADD', 'DROP'), TRUE)) | ||||
| 		{ | ||||
| 			return parent::_alter_table($alter_type, $table, $field); | ||||
| 		} | ||||
|  | ||||
| 		$sql = 'ALTER TABLE '.$this->db->escape_identifiers($table).' ALTER COLUMN '; | ||||
| 		$sqls = array(); | ||||
| 		for ($i = 0, $c = count($field); $i < $c; $i++) | ||||
| 		{ | ||||
| 			$sqls[] = $sql.$this->_process_column($field[$i]); | ||||
| 		} | ||||
|  | ||||
| 		return $sqls; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Field attribute TYPE | ||||
| 	 * | ||||
| 	 * Performs a data type mapping between different databases. | ||||
| 	 * | ||||
| 	 * @param	array	&$attributes | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	protected function _attr_type(&$attributes) | ||||
| 	{ | ||||
| 		if (isset($attributes['CONSTRAINT']) && strpos($attributes['TYPE'], 'INT') !== FALSE) | ||||
| 		{ | ||||
| 			unset($attributes['CONSTRAINT']); | ||||
| 		} | ||||
|  | ||||
| 		switch (strtoupper($attributes['TYPE'])) | ||||
| 		{ | ||||
| 			case 'MEDIUMINT': | ||||
| 				$attributes['TYPE'] = 'INTEGER'; | ||||
| 				$attributes['UNSIGNED'] = FALSE; | ||||
| 				return; | ||||
| 			case 'INTEGER': | ||||
| 				$attributes['TYPE'] = 'INT'; | ||||
| 				return; | ||||
| 			default: return; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Field attribute AUTO_INCREMENT | ||||
| 	 * | ||||
| 	 * @param	array	&$attributes | ||||
| 	 * @param	array	&$field | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	protected function _attr_auto_increment(&$attributes, &$field) | ||||
| 	{ | ||||
| 		if ( ! empty($attributes['AUTO_INCREMENT']) && $attributes['AUTO_INCREMENT'] === TRUE && stripos($field['type'], 'int') !== FALSE) | ||||
| 		{ | ||||
| 			$field['auto_increment'] = ' IDENTITY(1,1)'; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										193
									
								
								system/database/drivers/sqlsrv/sqlsrv_result.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										193
									
								
								system/database/drivers/sqlsrv/sqlsrv_result.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,193 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/) | ||||
|  * @license	https://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 2.0.3 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * SQLSRV Result Class | ||||
|  * | ||||
|  * This class extends the parent result class: CI_DB_result | ||||
|  * | ||||
|  * @category	Database | ||||
|  * @author		EllisLab Dev Team | ||||
|  * @link		https://codeigniter.com/user_guide/database/ | ||||
|  */ | ||||
| class CI_DB_sqlsrv_result extends CI_DB_result { | ||||
|  | ||||
| 	/** | ||||
| 	 * Scrollable flag | ||||
| 	 * | ||||
| 	 * @var	mixed | ||||
| 	 */ | ||||
| 	public $scrollable; | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Constructor | ||||
| 	 * | ||||
| 	 * @param	object	$driver_object | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	public function __construct(&$driver_object) | ||||
| 	{ | ||||
| 		parent::__construct($driver_object); | ||||
|  | ||||
| 		$this->scrollable = $driver_object->scrollable; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Number of rows in the result set | ||||
| 	 * | ||||
| 	 * @return	int | ||||
| 	 */ | ||||
| 	public function num_rows() | ||||
| 	{ | ||||
| 		// sqlsrv_num_rows() doesn't work with the FORWARD and DYNAMIC cursors (FALSE is the same as FORWARD) | ||||
| 		if ( ! in_array($this->scrollable, array(FALSE, SQLSRV_CURSOR_FORWARD, SQLSRV_CURSOR_DYNAMIC), TRUE)) | ||||
| 		{ | ||||
| 			return parent::num_rows(); | ||||
| 		} | ||||
|  | ||||
| 		return is_int($this->num_rows) | ||||
| 			? $this->num_rows | ||||
| 			: $this->num_rows = sqlsrv_num_rows($this->result_id); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Number of fields in the result set | ||||
| 	 * | ||||
| 	 * @return	int | ||||
| 	 */ | ||||
| 	public function num_fields() | ||||
| 	{ | ||||
| 		return @sqlsrv_num_fields($this->result_id); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Fetch Field Names | ||||
| 	 * | ||||
| 	 * Generates an array of column names | ||||
| 	 * | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	public function list_fields() | ||||
| 	{ | ||||
| 		$field_names = array(); | ||||
| 		foreach (sqlsrv_field_metadata($this->result_id) as $offset => $field) | ||||
| 		{ | ||||
| 			$field_names[] = $field['Name']; | ||||
| 		} | ||||
|  | ||||
| 		return $field_names; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Field data | ||||
| 	 * | ||||
| 	 * Generates an array of objects containing field meta-data | ||||
| 	 * | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	public function field_data() | ||||
| 	{ | ||||
| 		$retval = array(); | ||||
| 		foreach (sqlsrv_field_metadata($this->result_id) as $i => $field) | ||||
| 		{ | ||||
| 			$retval[$i]		= new stdClass(); | ||||
| 			$retval[$i]->name	= $field['Name']; | ||||
| 			$retval[$i]->type	= $field['Type']; | ||||
| 			$retval[$i]->max_length	= $field['Size']; | ||||
| 		} | ||||
|  | ||||
| 		return $retval; | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Free the result | ||||
| 	 * | ||||
| 	 * @return	void | ||||
| 	 */ | ||||
| 	public function free_result() | ||||
| 	{ | ||||
| 		if (is_resource($this->result_id)) | ||||
| 		{ | ||||
| 			sqlsrv_free_stmt($this->result_id); | ||||
| 			$this->result_id = FALSE; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Result - associative array | ||||
| 	 * | ||||
| 	 * Returns the result set as an array | ||||
| 	 * | ||||
| 	 * @return	array | ||||
| 	 */ | ||||
| 	protected function _fetch_assoc() | ||||
| 	{ | ||||
| 		return sqlsrv_fetch_array($this->result_id, SQLSRV_FETCH_ASSOC); | ||||
| 	} | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Result - object | ||||
| 	 * | ||||
| 	 * Returns the result set as an object | ||||
| 	 * | ||||
| 	 * @param	string	$class_name | ||||
| 	 * @return	object | ||||
| 	 */ | ||||
| 	protected function _fetch_object($class_name = 'stdClass') | ||||
| 	{ | ||||
| 		return sqlsrv_fetch_object($this->result_id, $class_name); | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										77
									
								
								system/database/drivers/sqlsrv/sqlsrv_utility.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										77
									
								
								system/database/drivers/sqlsrv/sqlsrv_utility.php
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,77 @@ | ||||
| <?php | ||||
| /** | ||||
|  * CodeIgniter | ||||
|  * | ||||
|  * An open source application development framework for PHP | ||||
|  * | ||||
|  * This content is released under the MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2014 - 2019, British Columbia Institute of Technology | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * @package	CodeIgniter | ||||
|  * @author	EllisLab Dev Team | ||||
|  * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | ||||
|  * @copyright	Copyright (c) 2014 - 2019, British Columbia Institute of Technology (https://bcit.ca/) | ||||
|  * @license	https://opensource.org/licenses/MIT	MIT License | ||||
|  * @link	https://codeigniter.com | ||||
|  * @since	Version 2.0.3 | ||||
|  * @filesource | ||||
|  */ | ||||
| defined('BASEPATH') OR exit('No direct script access allowed'); | ||||
|  | ||||
| /** | ||||
|  * SQLSRV Utility Class | ||||
|  * | ||||
|  * @category	Database | ||||
|  * @author		EllisLab Dev Team | ||||
|  * @link		https://codeigniter.com/user_guide/database/ | ||||
|  */ | ||||
| class CI_DB_sqlsrv_utility extends CI_DB_utility { | ||||
|  | ||||
| 	/** | ||||
| 	 * List databases statement | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_list_databases	= 'EXEC sp_helpdb'; // Can also be: EXEC sp_databases | ||||
|  | ||||
| 	/** | ||||
| 	 * OPTIMIZE TABLE statement | ||||
| 	 * | ||||
| 	 * @var	string | ||||
| 	 */ | ||||
| 	protected $_optimize_table	= 'ALTER INDEX all ON %s REORGANIZE'; | ||||
|  | ||||
| 	// -------------------------------------------------------------------- | ||||
|  | ||||
| 	/** | ||||
| 	 * Export | ||||
| 	 * | ||||
| 	 * @param	array	$params	Preferences | ||||
| 	 * @return	bool | ||||
| 	 */ | ||||
| 	protected function _backup($params = array()) | ||||
| 	{ | ||||
| 		// Currently unsupported | ||||
| 		return $this->db->display_error('db_unsupported_feature'); | ||||
| 	} | ||||
|  | ||||
| } | ||||
		Reference in New Issue
	
	Block a user
	 Al Azhar
					Al Azhar