mirror of
				https://github.com/dg/dibi.git
				synced 2025-10-26 11:17:40 +01:00 
			
		
		
		
	separation of some classes into own files
This commit is contained in:
		| @@ -801,39 +801,3 @@ class DibiFirebirdDriver extends DibiObject implements IDibiDriver, IDibiResultD | |||||||
| 	} | 	} | ||||||
|  |  | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * Database procedure exception. |  | ||||||
|  * |  | ||||||
|  * @package    dibi\drivers |  | ||||||
|  */ |  | ||||||
| class DibiProcedureException extends DibiException |  | ||||||
| { |  | ||||||
| 	/** @var string */ |  | ||||||
| 	protected $severity; |  | ||||||
|  |  | ||||||
|  |  | ||||||
| 	/** |  | ||||||
| 	 * Construct the exception. |  | ||||||
| 	 * @param  string  Message describing the exception |  | ||||||
| 	 * @param  int     Some code |  | ||||||
| 	 * @param  string SQL command |  | ||||||
| 	 */ |  | ||||||
| 	public function __construct($message = NULL, $code = 0, $severity = NULL, $sql = NULL) |  | ||||||
| 	{ |  | ||||||
| 		parent::__construct($message, (int) $code, $sql); |  | ||||||
| 		$this->severity = $severity; |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
|  |  | ||||||
| 	/** |  | ||||||
| 	 * Gets the exception severity. |  | ||||||
| 	 * @return string |  | ||||||
| 	 */ |  | ||||||
| 	public function getSeverity() |  | ||||||
| 	{ |  | ||||||
| 		$this->severity; |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| } |  | ||||||
|   | |||||||
							
								
								
									
										205
									
								
								src/Dibi/Reflection/Column.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										205
									
								
								src/Dibi/Reflection/Column.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,205 @@ | |||||||
|  | <?php | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * This file is part of the "dibi" - smart database abstraction layer. | ||||||
|  |  * Copyright (c) 2005 David Grudl (https://davidgrudl.com) | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * Reflection metadata class for a table or result set column. | ||||||
|  |  * | ||||||
|  |  * @package    dibi\reflection | ||||||
|  |  * | ||||||
|  |  * @property-read string $name | ||||||
|  |  * @property-read string $fullName | ||||||
|  |  * @property-read DibiTableInfo $table | ||||||
|  |  * @property-read string $type | ||||||
|  |  * @property-read mixed $nativeType | ||||||
|  |  * @property-read int $size | ||||||
|  |  * @property-read bool $unsigned | ||||||
|  |  * @property-read bool $nullable | ||||||
|  |  * @property-read bool $autoIncrement | ||||||
|  |  * @property-read mixed $default | ||||||
|  |  */ | ||||||
|  | class DibiColumnInfo extends DibiObject | ||||||
|  | { | ||||||
|  | 	/** @var array */ | ||||||
|  | 	private static $types; | ||||||
|  |  | ||||||
|  | 	/** @var IDibiReflector|NULL when created by DibiResultInfo */ | ||||||
|  | 	private $reflector; | ||||||
|  |  | ||||||
|  | 	/** @var array (name, nativetype, [table], [fullname], [size], [nullable], [default], [autoincrement], [vendor]) */ | ||||||
|  | 	private $info; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	public function __construct(IDibiReflector $reflector = NULL, array $info) | ||||||
|  | 	{ | ||||||
|  | 		$this->reflector = $reflector; | ||||||
|  | 		$this->info = $info; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * @return string | ||||||
|  | 	 */ | ||||||
|  | 	public function getName() | ||||||
|  | 	{ | ||||||
|  | 		return $this->info['name']; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * @return string | ||||||
|  | 	 */ | ||||||
|  | 	public function getFullName() | ||||||
|  | 	{ | ||||||
|  | 		return isset($this->info['fullname']) ? $this->info['fullname'] : NULL; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * @return bool | ||||||
|  | 	 */ | ||||||
|  | 	public function hasTable() | ||||||
|  | 	{ | ||||||
|  | 		return !empty($this->info['table']); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * @return DibiTableInfo | ||||||
|  | 	 */ | ||||||
|  | 	public function getTable() | ||||||
|  | 	{ | ||||||
|  | 		if (empty($this->info['table']) || !$this->reflector) { | ||||||
|  | 			throw new DibiException("Table is unknown or not available."); | ||||||
|  | 		} | ||||||
|  | 		return new DibiTableInfo($this->reflector, array('name' => $this->info['table'])); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * @return string | ||||||
|  | 	 */ | ||||||
|  | 	public function getTableName() | ||||||
|  | 	{ | ||||||
|  | 		return isset($this->info['table']) && $this->info['table'] != NULL ? $this->info['table'] : NULL; // intentionally == | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * @return string | ||||||
|  | 	 */ | ||||||
|  | 	public function getType() | ||||||
|  | 	{ | ||||||
|  | 		return self::getTypeCache()->{$this->info['nativetype']}; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * @return mixed | ||||||
|  | 	 */ | ||||||
|  | 	public function getNativeType() | ||||||
|  | 	{ | ||||||
|  | 		return $this->info['nativetype']; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * @return int | ||||||
|  | 	 */ | ||||||
|  | 	public function getSize() | ||||||
|  | 	{ | ||||||
|  | 		return isset($this->info['size']) ? (int) $this->info['size'] : NULL; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * @return bool | ||||||
|  | 	 */ | ||||||
|  | 	public function isUnsigned() | ||||||
|  | 	{ | ||||||
|  | 		return isset($this->info['unsigned']) ? (bool) $this->info['unsigned'] : NULL; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * @return bool | ||||||
|  | 	 */ | ||||||
|  | 	public function isNullable() | ||||||
|  | 	{ | ||||||
|  | 		return isset($this->info['nullable']) ? (bool) $this->info['nullable'] : NULL; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * @return bool | ||||||
|  | 	 */ | ||||||
|  | 	public function isAutoIncrement() | ||||||
|  | 	{ | ||||||
|  | 		return isset($this->info['autoincrement']) ? (bool) $this->info['autoincrement'] : NULL; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * @return mixed | ||||||
|  | 	 */ | ||||||
|  | 	public function getDefault() | ||||||
|  | 	{ | ||||||
|  | 		return isset($this->info['default']) ? $this->info['default'] : NULL; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * @param  string | ||||||
|  | 	 * @return mixed | ||||||
|  | 	 */ | ||||||
|  | 	public function getVendorInfo($key) | ||||||
|  | 	{ | ||||||
|  | 		return isset($this->info['vendor'][$key]) ? $this->info['vendor'][$key] : NULL; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * Heuristic type detection. | ||||||
|  | 	 * @param  string | ||||||
|  | 	 * @return string | ||||||
|  | 	 * @internal | ||||||
|  | 	 */ | ||||||
|  | 	public static function detectType($type) | ||||||
|  | 	{ | ||||||
|  | 		static $patterns = array( | ||||||
|  | 			'^_' => dibi::TEXT, // PostgreSQL arrays | ||||||
|  | 			'BYTEA|BLOB|BIN' => dibi::BINARY, | ||||||
|  | 			'TEXT|CHAR|POINT|INTERVAL' => dibi::TEXT, | ||||||
|  | 			'YEAR|BYTE|COUNTER|SERIAL|INT|LONG|SHORT' => dibi::INTEGER, | ||||||
|  | 			'CURRENCY|REAL|MONEY|FLOAT|DOUBLE|DECIMAL|NUMERIC|NUMBER' => dibi::FLOAT, | ||||||
|  | 			'^TIME$' => dibi::TIME, | ||||||
|  | 			'TIME' => dibi::DATETIME, // DATETIME, TIMESTAMP | ||||||
|  | 			'DATE' => dibi::DATE, | ||||||
|  | 			'BOOL' => dibi::BOOL, | ||||||
|  | 		); | ||||||
|  |  | ||||||
|  | 		foreach ($patterns as $s => $val) { | ||||||
|  | 			if (preg_match("#$s#i", $type)) { | ||||||
|  | 				return $val; | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 		return dibi::TEXT; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * @internal | ||||||
|  | 	 */ | ||||||
|  | 	public static function getTypeCache() | ||||||
|  | 	{ | ||||||
|  | 		if (self::$types === NULL) { | ||||||
|  | 			self::$types = new DibiHashMap(array(__CLASS__, 'detectType')); | ||||||
|  | 		} | ||||||
|  | 		return self::$types; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | } | ||||||
							
								
								
									
										111
									
								
								src/Dibi/Reflection/Database.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										111
									
								
								src/Dibi/Reflection/Database.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,111 @@ | |||||||
|  | <?php | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * This file is part of the "dibi" - smart database abstraction layer. | ||||||
|  |  * Copyright (c) 2005 David Grudl (https://davidgrudl.com) | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * Reflection metadata class for a database. | ||||||
|  |  * | ||||||
|  |  * @package    dibi\reflection | ||||||
|  |  * | ||||||
|  |  * @property-read string $name | ||||||
|  |  * @property-read array $tables | ||||||
|  |  * @property-read array $tableNames | ||||||
|  |  */ | ||||||
|  | class DibiDatabaseInfo extends DibiObject | ||||||
|  | { | ||||||
|  | 	/** @var IDibiReflector */ | ||||||
|  | 	private $reflector; | ||||||
|  |  | ||||||
|  | 	/** @var string */ | ||||||
|  | 	private $name; | ||||||
|  |  | ||||||
|  | 	/** @var array */ | ||||||
|  | 	private $tables; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	public function __construct(IDibiReflector $reflector, $name) | ||||||
|  | 	{ | ||||||
|  | 		$this->reflector = $reflector; | ||||||
|  | 		$this->name = $name; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * @return string | ||||||
|  | 	 */ | ||||||
|  | 	public function getName() | ||||||
|  | 	{ | ||||||
|  | 		return $this->name; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * @return DibiTableInfo[] | ||||||
|  | 	 */ | ||||||
|  | 	public function getTables() | ||||||
|  | 	{ | ||||||
|  | 		$this->init(); | ||||||
|  | 		return array_values($this->tables); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * @return string[] | ||||||
|  | 	 */ | ||||||
|  | 	public function getTableNames() | ||||||
|  | 	{ | ||||||
|  | 		$this->init(); | ||||||
|  | 		$res = array(); | ||||||
|  | 		foreach ($this->tables as $table) { | ||||||
|  | 			$res[] = $table->getName(); | ||||||
|  | 		} | ||||||
|  | 		return $res; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * @param  string | ||||||
|  | 	 * @return DibiTableInfo | ||||||
|  | 	 */ | ||||||
|  | 	public function getTable($name) | ||||||
|  | 	{ | ||||||
|  | 		$this->init(); | ||||||
|  | 		$l = strtolower($name); | ||||||
|  | 		if (isset($this->tables[$l])) { | ||||||
|  | 			return $this->tables[$l]; | ||||||
|  |  | ||||||
|  | 		} else { | ||||||
|  | 			throw new DibiException("Database '$this->name' has no table '$name'."); | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * @param  string | ||||||
|  | 	 * @return bool | ||||||
|  | 	 */ | ||||||
|  | 	public function hasTable($name) | ||||||
|  | 	{ | ||||||
|  | 		$this->init(); | ||||||
|  | 		return isset($this->tables[strtolower($name)]); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * @return void | ||||||
|  | 	 */ | ||||||
|  | 	protected function init() | ||||||
|  | 	{ | ||||||
|  | 		if ($this->tables === NULL) { | ||||||
|  | 			$this->tables = array(); | ||||||
|  | 			foreach ($this->reflector->getTables() as $info) { | ||||||
|  | 				$this->tables[strtolower($info['name'])] = new DibiTableInfo($this->reflector, $info); | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | } | ||||||
| @@ -1,702 +0,0 @@ | |||||||
| <?php |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * This file is part of the "dibi" - smart database abstraction layer. |  | ||||||
|  * Copyright (c) 2005 David Grudl (https://davidgrudl.com) |  | ||||||
|  */ |  | ||||||
|  |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * Reflection metadata class for a database. |  | ||||||
|  * |  | ||||||
|  * @package    dibi\reflection |  | ||||||
|  * |  | ||||||
|  * @property-read string $name |  | ||||||
|  * @property-read array $tables |  | ||||||
|  * @property-read array $tableNames |  | ||||||
|  */ |  | ||||||
| class DibiDatabaseInfo extends DibiObject |  | ||||||
| { |  | ||||||
| 	/** @var IDibiReflector */ |  | ||||||
| 	private $reflector; |  | ||||||
|  |  | ||||||
| 	/** @var string */ |  | ||||||
| 	private $name; |  | ||||||
|  |  | ||||||
| 	/** @var array */ |  | ||||||
| 	private $tables; |  | ||||||
|  |  | ||||||
|  |  | ||||||
| 	public function __construct(IDibiReflector $reflector, $name) |  | ||||||
| 	{ |  | ||||||
| 		$this->reflector = $reflector; |  | ||||||
| 		$this->name = $name; |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
|  |  | ||||||
| 	/** |  | ||||||
| 	 * @return string |  | ||||||
| 	 */ |  | ||||||
| 	public function getName() |  | ||||||
| 	{ |  | ||||||
| 		return $this->name; |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
|  |  | ||||||
| 	/** |  | ||||||
| 	 * @return DibiTableInfo[] |  | ||||||
| 	 */ |  | ||||||
| 	public function getTables() |  | ||||||
| 	{ |  | ||||||
| 		$this->init(); |  | ||||||
| 		return array_values($this->tables); |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
|  |  | ||||||
| 	/** |  | ||||||
| 	 * @return string[] |  | ||||||
| 	 */ |  | ||||||
| 	public function getTableNames() |  | ||||||
| 	{ |  | ||||||
| 		$this->init(); |  | ||||||
| 		$res = array(); |  | ||||||
| 		foreach ($this->tables as $table) { |  | ||||||
| 			$res[] = $table->getName(); |  | ||||||
| 		} |  | ||||||
| 		return $res; |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
|  |  | ||||||
| 	/** |  | ||||||
| 	 * @param  string |  | ||||||
| 	 * @return DibiTableInfo |  | ||||||
| 	 */ |  | ||||||
| 	public function getTable($name) |  | ||||||
| 	{ |  | ||||||
| 		$this->init(); |  | ||||||
| 		$l = strtolower($name); |  | ||||||
| 		if (isset($this->tables[$l])) { |  | ||||||
| 			return $this->tables[$l]; |  | ||||||
|  |  | ||||||
| 		} else { |  | ||||||
| 			throw new DibiException("Database '$this->name' has no table '$name'."); |  | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
|  |  | ||||||
| 	/** |  | ||||||
| 	 * @param  string |  | ||||||
| 	 * @return bool |  | ||||||
| 	 */ |  | ||||||
| 	public function hasTable($name) |  | ||||||
| 	{ |  | ||||||
| 		$this->init(); |  | ||||||
| 		return isset($this->tables[strtolower($name)]); |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
|  |  | ||||||
| 	/** |  | ||||||
| 	 * @return void |  | ||||||
| 	 */ |  | ||||||
| 	protected function init() |  | ||||||
| 	{ |  | ||||||
| 		if ($this->tables === NULL) { |  | ||||||
| 			$this->tables = array(); |  | ||||||
| 			foreach ($this->reflector->getTables() as $info) { |  | ||||||
| 				$this->tables[strtolower($info['name'])] = new DibiTableInfo($this->reflector, $info); |  | ||||||
| 			} |  | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| } |  | ||||||
|  |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * Reflection metadata class for a database table. |  | ||||||
|  * |  | ||||||
|  * @package    dibi\reflection |  | ||||||
|  * |  | ||||||
|  * @property-read string $name |  | ||||||
|  * @property-read bool $view |  | ||||||
|  * @property-read array $columns |  | ||||||
|  * @property-read array $columnNames |  | ||||||
|  * @property-read array $foreignKeys |  | ||||||
|  * @property-read array $indexes |  | ||||||
|  * @property-read DibiIndexInfo $primaryKey |  | ||||||
|  */ |  | ||||||
| class DibiTableInfo extends DibiObject |  | ||||||
| { |  | ||||||
| 	/** @var IDibiReflector */ |  | ||||||
| 	private $reflector; |  | ||||||
|  |  | ||||||
| 	/** @var string */ |  | ||||||
| 	private $name; |  | ||||||
|  |  | ||||||
| 	/** @var bool */ |  | ||||||
| 	private $view; |  | ||||||
|  |  | ||||||
| 	/** @var array */ |  | ||||||
| 	private $columns; |  | ||||||
|  |  | ||||||
| 	/** @var array */ |  | ||||||
| 	private $foreignKeys; |  | ||||||
|  |  | ||||||
| 	/** @var array */ |  | ||||||
| 	private $indexes; |  | ||||||
|  |  | ||||||
| 	/** @var DibiIndexInfo */ |  | ||||||
| 	private $primaryKey; |  | ||||||
|  |  | ||||||
|  |  | ||||||
| 	public function __construct(IDibiReflector $reflector, array $info) |  | ||||||
| 	{ |  | ||||||
| 		$this->reflector = $reflector; |  | ||||||
| 		$this->name = $info['name']; |  | ||||||
| 		$this->view = !empty($info['view']); |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
|  |  | ||||||
| 	/** |  | ||||||
| 	 * @return string |  | ||||||
| 	 */ |  | ||||||
| 	public function getName() |  | ||||||
| 	{ |  | ||||||
| 		return $this->name; |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
|  |  | ||||||
| 	/** |  | ||||||
| 	 * @return bool |  | ||||||
| 	 */ |  | ||||||
| 	public function isView() |  | ||||||
| 	{ |  | ||||||
| 		return $this->view; |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
|  |  | ||||||
| 	/** |  | ||||||
| 	 * @return DibiColumnInfo[] |  | ||||||
| 	 */ |  | ||||||
| 	public function getColumns() |  | ||||||
| 	{ |  | ||||||
| 		$this->initColumns(); |  | ||||||
| 		return array_values($this->columns); |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
|  |  | ||||||
| 	/** |  | ||||||
| 	 * @return string[] |  | ||||||
| 	 */ |  | ||||||
| 	public function getColumnNames() |  | ||||||
| 	{ |  | ||||||
| 		$this->initColumns(); |  | ||||||
| 		$res = array(); |  | ||||||
| 		foreach ($this->columns as $column) { |  | ||||||
| 			$res[] = $column->getName(); |  | ||||||
| 		} |  | ||||||
| 		return $res; |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
|  |  | ||||||
| 	/** |  | ||||||
| 	 * @param  string |  | ||||||
| 	 * @return DibiColumnInfo |  | ||||||
| 	 */ |  | ||||||
| 	public function getColumn($name) |  | ||||||
| 	{ |  | ||||||
| 		$this->initColumns(); |  | ||||||
| 		$l = strtolower($name); |  | ||||||
| 		if (isset($this->columns[$l])) { |  | ||||||
| 			return $this->columns[$l]; |  | ||||||
|  |  | ||||||
| 		} else { |  | ||||||
| 			throw new DibiException("Table '$this->name' has no column '$name'."); |  | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
|  |  | ||||||
| 	/** |  | ||||||
| 	 * @param  string |  | ||||||
| 	 * @return bool |  | ||||||
| 	 */ |  | ||||||
| 	public function hasColumn($name) |  | ||||||
| 	{ |  | ||||||
| 		$this->initColumns(); |  | ||||||
| 		return isset($this->columns[strtolower($name)]); |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
|  |  | ||||||
| 	/** |  | ||||||
| 	 * @return DibiForeignKeyInfo[] |  | ||||||
| 	 */ |  | ||||||
| 	public function getForeignKeys() |  | ||||||
| 	{ |  | ||||||
| 		$this->initForeignKeys(); |  | ||||||
| 		return $this->foreignKeys; |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
|  |  | ||||||
| 	/** |  | ||||||
| 	 * @return DibiIndexInfo[] |  | ||||||
| 	 */ |  | ||||||
| 	public function getIndexes() |  | ||||||
| 	{ |  | ||||||
| 		$this->initIndexes(); |  | ||||||
| 		return $this->indexes; |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
|  |  | ||||||
| 	/** |  | ||||||
| 	 * @return DibiIndexInfo |  | ||||||
| 	 */ |  | ||||||
| 	public function getPrimaryKey() |  | ||||||
| 	{ |  | ||||||
| 		$this->initIndexes(); |  | ||||||
| 		return $this->primaryKey; |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
|  |  | ||||||
| 	/** |  | ||||||
| 	 * @return void |  | ||||||
| 	 */ |  | ||||||
| 	protected function initColumns() |  | ||||||
| 	{ |  | ||||||
| 		if ($this->columns === NULL) { |  | ||||||
| 			$this->columns = array(); |  | ||||||
| 			foreach ($this->reflector->getColumns($this->name) as $info) { |  | ||||||
| 				$this->columns[strtolower($info['name'])] = new DibiColumnInfo($this->reflector, $info); |  | ||||||
| 			} |  | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
|  |  | ||||||
| 	/** |  | ||||||
| 	 * @return void |  | ||||||
| 	 */ |  | ||||||
| 	protected function initIndexes() |  | ||||||
| 	{ |  | ||||||
| 		if ($this->indexes === NULL) { |  | ||||||
| 			$this->initColumns(); |  | ||||||
| 			$this->indexes = array(); |  | ||||||
| 			foreach ($this->reflector->getIndexes($this->name) as $info) { |  | ||||||
| 				foreach ($info['columns'] as $key => $name) { |  | ||||||
| 					$info['columns'][$key] = $this->columns[strtolower($name)]; |  | ||||||
| 				} |  | ||||||
| 				$this->indexes[strtolower($info['name'])] = new DibiIndexInfo($info); |  | ||||||
| 				if (!empty($info['primary'])) { |  | ||||||
| 					$this->primaryKey = $this->indexes[strtolower($info['name'])]; |  | ||||||
| 				} |  | ||||||
| 			} |  | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
|  |  | ||||||
| 	/** |  | ||||||
| 	 * @return void |  | ||||||
| 	 */ |  | ||||||
| 	protected function initForeignKeys() |  | ||||||
| 	{ |  | ||||||
| 		throw new DibiNotImplementedException; |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| } |  | ||||||
|  |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * Reflection metadata class for a result set. |  | ||||||
|  * |  | ||||||
|  * @package    dibi\reflection |  | ||||||
|  * |  | ||||||
|  * @property-read array $columns |  | ||||||
|  * @property-read array $columnNames |  | ||||||
|  */ |  | ||||||
| class DibiResultInfo extends DibiObject |  | ||||||
| { |  | ||||||
| 	/** @var IDibiResultDriver */ |  | ||||||
| 	private $driver; |  | ||||||
|  |  | ||||||
| 	/** @var array */ |  | ||||||
| 	private $columns; |  | ||||||
|  |  | ||||||
| 	/** @var array */ |  | ||||||
| 	private $names; |  | ||||||
|  |  | ||||||
|  |  | ||||||
| 	public function __construct(IDibiResultDriver $driver) |  | ||||||
| 	{ |  | ||||||
| 		$this->driver = $driver; |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
|  |  | ||||||
| 	/** |  | ||||||
| 	 * @return DibiColumnInfo[] |  | ||||||
| 	 */ |  | ||||||
| 	public function getColumns() |  | ||||||
| 	{ |  | ||||||
| 		$this->initColumns(); |  | ||||||
| 		return array_values($this->columns); |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
|  |  | ||||||
| 	/** |  | ||||||
| 	 * @param  bool |  | ||||||
| 	 * @return string[] |  | ||||||
| 	 */ |  | ||||||
| 	public function getColumnNames($fullNames = FALSE) |  | ||||||
| 	{ |  | ||||||
| 		$this->initColumns(); |  | ||||||
| 		$res = array(); |  | ||||||
| 		foreach ($this->columns as $column) { |  | ||||||
| 			$res[] = $fullNames ? $column->getFullName() : $column->getName(); |  | ||||||
| 		} |  | ||||||
| 		return $res; |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
|  |  | ||||||
| 	/** |  | ||||||
| 	 * @param  string |  | ||||||
| 	 * @return DibiColumnInfo |  | ||||||
| 	 */ |  | ||||||
| 	public function getColumn($name) |  | ||||||
| 	{ |  | ||||||
| 		$this->initColumns(); |  | ||||||
| 		$l = strtolower($name); |  | ||||||
| 		if (isset($this->names[$l])) { |  | ||||||
| 			return $this->names[$l]; |  | ||||||
|  |  | ||||||
| 		} else { |  | ||||||
| 			throw new DibiException("Result set has no column '$name'."); |  | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
|  |  | ||||||
| 	/** |  | ||||||
| 	 * @param  string |  | ||||||
| 	 * @return bool |  | ||||||
| 	 */ |  | ||||||
| 	public function hasColumn($name) |  | ||||||
| 	{ |  | ||||||
| 		$this->initColumns(); |  | ||||||
| 		return isset($this->names[strtolower($name)]); |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
|  |  | ||||||
| 	/** |  | ||||||
| 	 * @return void |  | ||||||
| 	 */ |  | ||||||
| 	protected function initColumns() |  | ||||||
| 	{ |  | ||||||
| 		if ($this->columns === NULL) { |  | ||||||
| 			$this->columns = array(); |  | ||||||
| 			$reflector = $this->driver instanceof IDibiReflector ? $this->driver : NULL; |  | ||||||
| 			foreach ($this->driver->getResultColumns() as $info) { |  | ||||||
| 				$this->columns[] = $this->names[$info['name']] = new DibiColumnInfo($reflector, $info); |  | ||||||
| 			} |  | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| } |  | ||||||
|  |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * Reflection metadata class for a table or result set column. |  | ||||||
|  * |  | ||||||
|  * @package    dibi\reflection |  | ||||||
|  * |  | ||||||
|  * @property-read string $name |  | ||||||
|  * @property-read string $fullName |  | ||||||
|  * @property-read DibiTableInfo $table |  | ||||||
|  * @property-read string $type |  | ||||||
|  * @property-read mixed $nativeType |  | ||||||
|  * @property-read int $size |  | ||||||
|  * @property-read bool $unsigned |  | ||||||
|  * @property-read bool $nullable |  | ||||||
|  * @property-read bool $autoIncrement |  | ||||||
|  * @property-read mixed $default |  | ||||||
|  */ |  | ||||||
| class DibiColumnInfo extends DibiObject |  | ||||||
| { |  | ||||||
| 	/** @var array */ |  | ||||||
| 	private static $types; |  | ||||||
|  |  | ||||||
| 	/** @var IDibiReflector|NULL when created by DibiResultInfo */ |  | ||||||
| 	private $reflector; |  | ||||||
|  |  | ||||||
| 	/** @var array (name, nativetype, [table], [fullname], [size], [nullable], [default], [autoincrement], [vendor]) */ |  | ||||||
| 	private $info; |  | ||||||
|  |  | ||||||
|  |  | ||||||
| 	public function __construct(IDibiReflector $reflector = NULL, array $info) |  | ||||||
| 	{ |  | ||||||
| 		$this->reflector = $reflector; |  | ||||||
| 		$this->info = $info; |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
|  |  | ||||||
| 	/** |  | ||||||
| 	 * @return string |  | ||||||
| 	 */ |  | ||||||
| 	public function getName() |  | ||||||
| 	{ |  | ||||||
| 		return $this->info['name']; |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
|  |  | ||||||
| 	/** |  | ||||||
| 	 * @return string |  | ||||||
| 	 */ |  | ||||||
| 	public function getFullName() |  | ||||||
| 	{ |  | ||||||
| 		return isset($this->info['fullname']) ? $this->info['fullname'] : NULL; |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
|  |  | ||||||
| 	/** |  | ||||||
| 	 * @return bool |  | ||||||
| 	 */ |  | ||||||
| 	public function hasTable() |  | ||||||
| 	{ |  | ||||||
| 		return !empty($this->info['table']); |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
|  |  | ||||||
| 	/** |  | ||||||
| 	 * @return DibiTableInfo |  | ||||||
| 	 */ |  | ||||||
| 	public function getTable() |  | ||||||
| 	{ |  | ||||||
| 		if (empty($this->info['table']) || !$this->reflector) { |  | ||||||
| 			throw new DibiException("Table is unknown or not available."); |  | ||||||
| 		} |  | ||||||
| 		return new DibiTableInfo($this->reflector, array('name' => $this->info['table'])); |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
|  |  | ||||||
| 	/** |  | ||||||
| 	 * @return string |  | ||||||
| 	 */ |  | ||||||
| 	public function getTableName() |  | ||||||
| 	{ |  | ||||||
| 		return isset($this->info['table']) && $this->info['table'] != NULL ? $this->info['table'] : NULL; // intentionally == |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
|  |  | ||||||
| 	/** |  | ||||||
| 	 * @return string |  | ||||||
| 	 */ |  | ||||||
| 	public function getType() |  | ||||||
| 	{ |  | ||||||
| 		return self::getTypeCache()->{$this->info['nativetype']}; |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
|  |  | ||||||
| 	/** |  | ||||||
| 	 * @return mixed |  | ||||||
| 	 */ |  | ||||||
| 	public function getNativeType() |  | ||||||
| 	{ |  | ||||||
| 		return $this->info['nativetype']; |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
|  |  | ||||||
| 	/** |  | ||||||
| 	 * @return int |  | ||||||
| 	 */ |  | ||||||
| 	public function getSize() |  | ||||||
| 	{ |  | ||||||
| 		return isset($this->info['size']) ? (int) $this->info['size'] : NULL; |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
|  |  | ||||||
| 	/** |  | ||||||
| 	 * @return bool |  | ||||||
| 	 */ |  | ||||||
| 	public function isUnsigned() |  | ||||||
| 	{ |  | ||||||
| 		return isset($this->info['unsigned']) ? (bool) $this->info['unsigned'] : NULL; |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
|  |  | ||||||
| 	/** |  | ||||||
| 	 * @return bool |  | ||||||
| 	 */ |  | ||||||
| 	public function isNullable() |  | ||||||
| 	{ |  | ||||||
| 		return isset($this->info['nullable']) ? (bool) $this->info['nullable'] : NULL; |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
|  |  | ||||||
| 	/** |  | ||||||
| 	 * @return bool |  | ||||||
| 	 */ |  | ||||||
| 	public function isAutoIncrement() |  | ||||||
| 	{ |  | ||||||
| 		return isset($this->info['autoincrement']) ? (bool) $this->info['autoincrement'] : NULL; |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
|  |  | ||||||
| 	/** |  | ||||||
| 	 * @return mixed |  | ||||||
| 	 */ |  | ||||||
| 	public function getDefault() |  | ||||||
| 	{ |  | ||||||
| 		return isset($this->info['default']) ? $this->info['default'] : NULL; |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
|  |  | ||||||
| 	/** |  | ||||||
| 	 * @param  string |  | ||||||
| 	 * @return mixed |  | ||||||
| 	 */ |  | ||||||
| 	public function getVendorInfo($key) |  | ||||||
| 	{ |  | ||||||
| 		return isset($this->info['vendor'][$key]) ? $this->info['vendor'][$key] : NULL; |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
|  |  | ||||||
| 	/** |  | ||||||
| 	 * Heuristic type detection. |  | ||||||
| 	 * @param  string |  | ||||||
| 	 * @return string |  | ||||||
| 	 * @internal |  | ||||||
| 	 */ |  | ||||||
| 	public static function detectType($type) |  | ||||||
| 	{ |  | ||||||
| 		static $patterns = array( |  | ||||||
| 			'^_' => dibi::TEXT, // PostgreSQL arrays |  | ||||||
| 			'BYTEA|BLOB|BIN' => dibi::BINARY, |  | ||||||
| 			'TEXT|CHAR|POINT|INTERVAL' => dibi::TEXT, |  | ||||||
| 			'YEAR|BYTE|COUNTER|SERIAL|INT|LONG|SHORT' => dibi::INTEGER, |  | ||||||
| 			'CURRENCY|REAL|MONEY|FLOAT|DOUBLE|DECIMAL|NUMERIC|NUMBER' => dibi::FLOAT, |  | ||||||
| 			'^TIME$' => dibi::TIME, |  | ||||||
| 			'TIME' => dibi::DATETIME, // DATETIME, TIMESTAMP |  | ||||||
| 			'DATE' => dibi::DATE, |  | ||||||
| 			'BOOL' => dibi::BOOL, |  | ||||||
| 		); |  | ||||||
|  |  | ||||||
| 		foreach ($patterns as $s => $val) { |  | ||||||
| 			if (preg_match("#$s#i", $type)) { |  | ||||||
| 				return $val; |  | ||||||
| 			} |  | ||||||
| 		} |  | ||||||
| 		return dibi::TEXT; |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
|  |  | ||||||
| 	/** |  | ||||||
| 	 * @internal |  | ||||||
| 	 */ |  | ||||||
| 	public static function getTypeCache() |  | ||||||
| 	{ |  | ||||||
| 		if (self::$types === NULL) { |  | ||||||
| 			self::$types = new DibiHashMap(array(__CLASS__, 'detectType')); |  | ||||||
| 		} |  | ||||||
| 		return self::$types; |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| } |  | ||||||
|  |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * Reflection metadata class for a foreign key. |  | ||||||
|  * |  | ||||||
|  * @package    dibi\reflection |  | ||||||
|  * @todo |  | ||||||
|  * |  | ||||||
|  * @property-read string $name |  | ||||||
|  * @property-read array $references |  | ||||||
|  */ |  | ||||||
| class DibiForeignKeyInfo extends DibiObject |  | ||||||
| { |  | ||||||
| 	/** @var string */ |  | ||||||
| 	private $name; |  | ||||||
|  |  | ||||||
| 	/** @var array of array(local, foreign, onDelete, onUpdate) */ |  | ||||||
| 	private $references; |  | ||||||
|  |  | ||||||
|  |  | ||||||
| 	public function __construct($name, array $references) |  | ||||||
| 	{ |  | ||||||
| 		$this->name = $name; |  | ||||||
| 		$this->references = $references; |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
|  |  | ||||||
| 	/** |  | ||||||
| 	 * @return string |  | ||||||
| 	 */ |  | ||||||
| 	public function getName() |  | ||||||
| 	{ |  | ||||||
| 		return $this->name; |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
|  |  | ||||||
| 	/** |  | ||||||
| 	 * @return array |  | ||||||
| 	 */ |  | ||||||
| 	public function getReferences() |  | ||||||
| 	{ |  | ||||||
| 		return $this->references; |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| } |  | ||||||
|  |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * Reflection metadata class for a index or primary key. |  | ||||||
|  * |  | ||||||
|  * @package    dibi\reflection |  | ||||||
|  * |  | ||||||
|  * @property-read string $name |  | ||||||
|  * @property-read array $columns |  | ||||||
|  * @property-read bool $unique |  | ||||||
|  * @property-read bool $primary |  | ||||||
|  */ |  | ||||||
| class DibiIndexInfo extends DibiObject |  | ||||||
| { |  | ||||||
| 	/** @var array (name, columns, [unique], [primary]) */ |  | ||||||
| 	private $info; |  | ||||||
|  |  | ||||||
|  |  | ||||||
| 	public function __construct(array $info) |  | ||||||
| 	{ |  | ||||||
| 		$this->info = $info; |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
|  |  | ||||||
| 	/** |  | ||||||
| 	 * @return string |  | ||||||
| 	 */ |  | ||||||
| 	public function getName() |  | ||||||
| 	{ |  | ||||||
| 		return $this->info['name']; |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
|  |  | ||||||
| 	/** |  | ||||||
| 	 * @return array |  | ||||||
| 	 */ |  | ||||||
| 	public function getColumns() |  | ||||||
| 	{ |  | ||||||
| 		return $this->info['columns']; |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
|  |  | ||||||
| 	/** |  | ||||||
| 	 * @return bool |  | ||||||
| 	 */ |  | ||||||
| 	public function isUnique() |  | ||||||
| 	{ |  | ||||||
| 		return !empty($this->info['unique']); |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
|  |  | ||||||
| 	/** |  | ||||||
| 	 * @return bool |  | ||||||
| 	 */ |  | ||||||
| 	public function isPrimary() |  | ||||||
| 	{ |  | ||||||
| 		return !empty($this->info['primary']); |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| } |  | ||||||
							
								
								
									
										51
									
								
								src/Dibi/Reflection/ForeignKey.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										51
									
								
								src/Dibi/Reflection/ForeignKey.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,51 @@ | |||||||
|  | <?php | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * This file is part of the "dibi" - smart database abstraction layer. | ||||||
|  |  * Copyright (c) 2005 David Grudl (https://davidgrudl.com) | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * Reflection metadata class for a foreign key. | ||||||
|  |  * | ||||||
|  |  * @package    dibi\reflection | ||||||
|  |  * @todo | ||||||
|  |  * | ||||||
|  |  * @property-read string $name | ||||||
|  |  * @property-read array $references | ||||||
|  |  */ | ||||||
|  | class DibiForeignKeyInfo extends DibiObject | ||||||
|  | { | ||||||
|  | 	/** @var string */ | ||||||
|  | 	private $name; | ||||||
|  |  | ||||||
|  | 	/** @var array of array(local, foreign, onDelete, onUpdate) */ | ||||||
|  | 	private $references; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	public function __construct($name, array $references) | ||||||
|  | 	{ | ||||||
|  | 		$this->name = $name; | ||||||
|  | 		$this->references = $references; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * @return string | ||||||
|  | 	 */ | ||||||
|  | 	public function getName() | ||||||
|  | 	{ | ||||||
|  | 		return $this->name; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * @return array | ||||||
|  | 	 */ | ||||||
|  | 	public function getReferences() | ||||||
|  | 	{ | ||||||
|  | 		return $this->references; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | } | ||||||
							
								
								
									
										66
									
								
								src/Dibi/Reflection/Index.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										66
									
								
								src/Dibi/Reflection/Index.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,66 @@ | |||||||
|  | <?php | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * This file is part of the "dibi" - smart database abstraction layer. | ||||||
|  |  * Copyright (c) 2005 David Grudl (https://davidgrudl.com) | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * Reflection metadata class for a index or primary key. | ||||||
|  |  * | ||||||
|  |  * @package    dibi\reflection | ||||||
|  |  * | ||||||
|  |  * @property-read string $name | ||||||
|  |  * @property-read array $columns | ||||||
|  |  * @property-read bool $unique | ||||||
|  |  * @property-read bool $primary | ||||||
|  |  */ | ||||||
|  | class DibiIndexInfo extends DibiObject | ||||||
|  | { | ||||||
|  | 	/** @var array (name, columns, [unique], [primary]) */ | ||||||
|  | 	private $info; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	public function __construct(array $info) | ||||||
|  | 	{ | ||||||
|  | 		$this->info = $info; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * @return string | ||||||
|  | 	 */ | ||||||
|  | 	public function getName() | ||||||
|  | 	{ | ||||||
|  | 		return $this->info['name']; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * @return array | ||||||
|  | 	 */ | ||||||
|  | 	public function getColumns() | ||||||
|  | 	{ | ||||||
|  | 		return $this->info['columns']; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * @return bool | ||||||
|  | 	 */ | ||||||
|  | 	public function isUnique() | ||||||
|  | 	{ | ||||||
|  | 		return !empty($this->info['unique']); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * @return bool | ||||||
|  | 	 */ | ||||||
|  | 	public function isPrimary() | ||||||
|  | 	{ | ||||||
|  | 		return !empty($this->info['primary']); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | } | ||||||
							
								
								
									
										102
									
								
								src/Dibi/Reflection/Result.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										102
									
								
								src/Dibi/Reflection/Result.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,102 @@ | |||||||
|  | <?php | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * This file is part of the "dibi" - smart database abstraction layer. | ||||||
|  |  * Copyright (c) 2005 David Grudl (https://davidgrudl.com) | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * Reflection metadata class for a result set. | ||||||
|  |  * | ||||||
|  |  * @package    dibi\reflection | ||||||
|  |  * | ||||||
|  |  * @property-read array $columns | ||||||
|  |  * @property-read array $columnNames | ||||||
|  |  */ | ||||||
|  | class DibiResultInfo extends DibiObject | ||||||
|  | { | ||||||
|  | 	/** @var IDibiResultDriver */ | ||||||
|  | 	private $driver; | ||||||
|  |  | ||||||
|  | 	/** @var array */ | ||||||
|  | 	private $columns; | ||||||
|  |  | ||||||
|  | 	/** @var array */ | ||||||
|  | 	private $names; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	public function __construct(IDibiResultDriver $driver) | ||||||
|  | 	{ | ||||||
|  | 		$this->driver = $driver; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * @return DibiColumnInfo[] | ||||||
|  | 	 */ | ||||||
|  | 	public function getColumns() | ||||||
|  | 	{ | ||||||
|  | 		$this->initColumns(); | ||||||
|  | 		return array_values($this->columns); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * @param  bool | ||||||
|  | 	 * @return string[] | ||||||
|  | 	 */ | ||||||
|  | 	public function getColumnNames($fullNames = FALSE) | ||||||
|  | 	{ | ||||||
|  | 		$this->initColumns(); | ||||||
|  | 		$res = array(); | ||||||
|  | 		foreach ($this->columns as $column) { | ||||||
|  | 			$res[] = $fullNames ? $column->getFullName() : $column->getName(); | ||||||
|  | 		} | ||||||
|  | 		return $res; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * @param  string | ||||||
|  | 	 * @return DibiColumnInfo | ||||||
|  | 	 */ | ||||||
|  | 	public function getColumn($name) | ||||||
|  | 	{ | ||||||
|  | 		$this->initColumns(); | ||||||
|  | 		$l = strtolower($name); | ||||||
|  | 		if (isset($this->names[$l])) { | ||||||
|  | 			return $this->names[$l]; | ||||||
|  |  | ||||||
|  | 		} else { | ||||||
|  | 			throw new DibiException("Result set has no column '$name'."); | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * @param  string | ||||||
|  | 	 * @return bool | ||||||
|  | 	 */ | ||||||
|  | 	public function hasColumn($name) | ||||||
|  | 	{ | ||||||
|  | 		$this->initColumns(); | ||||||
|  | 		return isset($this->names[strtolower($name)]); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * @return void | ||||||
|  | 	 */ | ||||||
|  | 	protected function initColumns() | ||||||
|  | 	{ | ||||||
|  | 		if ($this->columns === NULL) { | ||||||
|  | 			$this->columns = array(); | ||||||
|  | 			$reflector = $this->driver instanceof IDibiReflector ? $this->driver : NULL; | ||||||
|  | 			foreach ($this->driver->getResultColumns() as $info) { | ||||||
|  | 				$this->columns[] = $this->names[$info['name']] = new DibiColumnInfo($reflector, $info); | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | } | ||||||
							
								
								
									
										197
									
								
								src/Dibi/Reflection/Table.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										197
									
								
								src/Dibi/Reflection/Table.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,197 @@ | |||||||
|  | <?php | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * This file is part of the "dibi" - smart database abstraction layer. | ||||||
|  |  * Copyright (c) 2005 David Grudl (https://davidgrudl.com) | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * Reflection metadata class for a database table. | ||||||
|  |  * | ||||||
|  |  * @package    dibi\reflection | ||||||
|  |  * | ||||||
|  |  * @property-read string $name | ||||||
|  |  * @property-read bool $view | ||||||
|  |  * @property-read array $columns | ||||||
|  |  * @property-read array $columnNames | ||||||
|  |  * @property-read array $foreignKeys | ||||||
|  |  * @property-read array $indexes | ||||||
|  |  * @property-read DibiIndexInfo $primaryKey | ||||||
|  |  */ | ||||||
|  | class DibiTableInfo extends DibiObject | ||||||
|  | { | ||||||
|  | 	/** @var IDibiReflector */ | ||||||
|  | 	private $reflector; | ||||||
|  |  | ||||||
|  | 	/** @var string */ | ||||||
|  | 	private $name; | ||||||
|  |  | ||||||
|  | 	/** @var bool */ | ||||||
|  | 	private $view; | ||||||
|  |  | ||||||
|  | 	/** @var array */ | ||||||
|  | 	private $columns; | ||||||
|  |  | ||||||
|  | 	/** @var array */ | ||||||
|  | 	private $foreignKeys; | ||||||
|  |  | ||||||
|  | 	/** @var array */ | ||||||
|  | 	private $indexes; | ||||||
|  |  | ||||||
|  | 	/** @var DibiIndexInfo */ | ||||||
|  | 	private $primaryKey; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	public function __construct(IDibiReflector $reflector, array $info) | ||||||
|  | 	{ | ||||||
|  | 		$this->reflector = $reflector; | ||||||
|  | 		$this->name = $info['name']; | ||||||
|  | 		$this->view = !empty($info['view']); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * @return string | ||||||
|  | 	 */ | ||||||
|  | 	public function getName() | ||||||
|  | 	{ | ||||||
|  | 		return $this->name; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * @return bool | ||||||
|  | 	 */ | ||||||
|  | 	public function isView() | ||||||
|  | 	{ | ||||||
|  | 		return $this->view; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * @return DibiColumnInfo[] | ||||||
|  | 	 */ | ||||||
|  | 	public function getColumns() | ||||||
|  | 	{ | ||||||
|  | 		$this->initColumns(); | ||||||
|  | 		return array_values($this->columns); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * @return string[] | ||||||
|  | 	 */ | ||||||
|  | 	public function getColumnNames() | ||||||
|  | 	{ | ||||||
|  | 		$this->initColumns(); | ||||||
|  | 		$res = array(); | ||||||
|  | 		foreach ($this->columns as $column) { | ||||||
|  | 			$res[] = $column->getName(); | ||||||
|  | 		} | ||||||
|  | 		return $res; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * @param  string | ||||||
|  | 	 * @return DibiColumnInfo | ||||||
|  | 	 */ | ||||||
|  | 	public function getColumn($name) | ||||||
|  | 	{ | ||||||
|  | 		$this->initColumns(); | ||||||
|  | 		$l = strtolower($name); | ||||||
|  | 		if (isset($this->columns[$l])) { | ||||||
|  | 			return $this->columns[$l]; | ||||||
|  |  | ||||||
|  | 		} else { | ||||||
|  | 			throw new DibiException("Table '$this->name' has no column '$name'."); | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * @param  string | ||||||
|  | 	 * @return bool | ||||||
|  | 	 */ | ||||||
|  | 	public function hasColumn($name) | ||||||
|  | 	{ | ||||||
|  | 		$this->initColumns(); | ||||||
|  | 		return isset($this->columns[strtolower($name)]); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * @return DibiForeignKeyInfo[] | ||||||
|  | 	 */ | ||||||
|  | 	public function getForeignKeys() | ||||||
|  | 	{ | ||||||
|  | 		$this->initForeignKeys(); | ||||||
|  | 		return $this->foreignKeys; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * @return DibiIndexInfo[] | ||||||
|  | 	 */ | ||||||
|  | 	public function getIndexes() | ||||||
|  | 	{ | ||||||
|  | 		$this->initIndexes(); | ||||||
|  | 		return $this->indexes; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * @return DibiIndexInfo | ||||||
|  | 	 */ | ||||||
|  | 	public function getPrimaryKey() | ||||||
|  | 	{ | ||||||
|  | 		$this->initIndexes(); | ||||||
|  | 		return $this->primaryKey; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * @return void | ||||||
|  | 	 */ | ||||||
|  | 	protected function initColumns() | ||||||
|  | 	{ | ||||||
|  | 		if ($this->columns === NULL) { | ||||||
|  | 			$this->columns = array(); | ||||||
|  | 			foreach ($this->reflector->getColumns($this->name) as $info) { | ||||||
|  | 				$this->columns[strtolower($info['name'])] = new DibiColumnInfo($this->reflector, $info); | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * @return void | ||||||
|  | 	 */ | ||||||
|  | 	protected function initIndexes() | ||||||
|  | 	{ | ||||||
|  | 		if ($this->indexes === NULL) { | ||||||
|  | 			$this->initColumns(); | ||||||
|  | 			$this->indexes = array(); | ||||||
|  | 			foreach ($this->reflector->getIndexes($this->name) as $info) { | ||||||
|  | 				foreach ($info['columns'] as $key => $name) { | ||||||
|  | 					$info['columns'][$key] = $this->columns[strtolower($name)]; | ||||||
|  | 				} | ||||||
|  | 				$this->indexes[strtolower($info['name'])] = new DibiIndexInfo($info); | ||||||
|  | 				if (!empty($info['primary'])) { | ||||||
|  | 					$this->primaryKey = $this->indexes[strtolower($info['name'])]; | ||||||
|  | 				} | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	/** | ||||||
|  | 	 * @return void | ||||||
|  | 	 */ | ||||||
|  | 	protected function initForeignKeys() | ||||||
|  | 	{ | ||||||
|  | 		throw new DibiNotImplementedException; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | } | ||||||
| @@ -143,3 +143,39 @@ class DibiNotImplementedException extends DibiException | |||||||
|  */ |  */ | ||||||
| class DibiNotSupportedException extends DibiException | class DibiNotSupportedException extends DibiException | ||||||
| {} | {} | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | /** | ||||||
|  |  * Database procedure exception. | ||||||
|  |  * | ||||||
|  |  * @package    dibi | ||||||
|  |  */ | ||||||
|  | class DibiProcedureException extends DibiException | ||||||
|  | { | ||||||
|  | 	/** @var string */ | ||||||
|  | 	protected $severity; | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 	/** | ||||||
|  | 	 * Construct the exception. | ||||||
|  | 	 * @param  string  Message describing the exception | ||||||
|  | 	 * @param  int     Some code | ||||||
|  | 	 * @param  string SQL command | ||||||
|  | 	 */ | ||||||
|  | 	public function __construct($message = NULL, $code = 0, $severity = NULL, $sql = NULL) | ||||||
|  | 	{ | ||||||
|  | 		parent::__construct($message, (int) $code, $sql); | ||||||
|  | 		$this->severity = $severity; | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 	/** | ||||||
|  | 	 * Gets the exception severity. | ||||||
|  | 	 * @return string | ||||||
|  | 	 */ | ||||||
|  | 	public function getSeverity() | ||||||
|  | 	{ | ||||||
|  | 		$this->severity; | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | } | ||||||
| @@ -20,7 +20,7 @@ require_once dirname(__FILE__) . '/Dibi/DateTime.php'; | |||||||
| require_once dirname(__FILE__) . '/Dibi/Object.php'; | require_once dirname(__FILE__) . '/Dibi/Object.php'; | ||||||
| require_once dirname(__FILE__) . '/Dibi/Literal.php'; | require_once dirname(__FILE__) . '/Dibi/Literal.php'; | ||||||
| require_once dirname(__FILE__) . '/Dibi/HashMap.php'; | require_once dirname(__FILE__) . '/Dibi/HashMap.php'; | ||||||
| require_once dirname(__FILE__) . '/Dibi/Exception.php'; | require_once dirname(__FILE__) . '/Dibi/exceptions.php'; | ||||||
| require_once dirname(__FILE__) . '/Dibi/Connection.php'; | require_once dirname(__FILE__) . '/Dibi/Connection.php'; | ||||||
| require_once dirname(__FILE__) . '/Dibi/Result.php'; | require_once dirname(__FILE__) . '/Dibi/Result.php'; | ||||||
| require_once dirname(__FILE__) . '/Dibi/ResultIterator.php'; | require_once dirname(__FILE__) . '/Dibi/ResultIterator.php'; | ||||||
| @@ -28,7 +28,12 @@ require_once dirname(__FILE__) . '/Dibi/Row.php'; | |||||||
| require_once dirname(__FILE__) . '/Dibi/Translator.php'; | require_once dirname(__FILE__) . '/Dibi/Translator.php'; | ||||||
| require_once dirname(__FILE__) . '/Dibi/DataSource.php'; | require_once dirname(__FILE__) . '/Dibi/DataSource.php'; | ||||||
| require_once dirname(__FILE__) . '/Dibi/Fluent.php'; | require_once dirname(__FILE__) . '/Dibi/Fluent.php'; | ||||||
| require_once dirname(__FILE__) . '/Dibi/Reflection/DatabaseInfo.php'; | require_once dirname(__FILE__) . '/Dibi/Reflection/Column.php'; | ||||||
|  | require_once dirname(__FILE__) . '/Dibi/Reflection/Database.php'; | ||||||
|  | require_once dirname(__FILE__) . '/Dibi/Reflection/ForeignKey.php'; | ||||||
|  | require_once dirname(__FILE__) . '/Dibi/Reflection/Index.php'; | ||||||
|  | require_once dirname(__FILE__) . '/Dibi/Reflection/Result.php'; | ||||||
|  | require_once dirname(__FILE__) . '/Dibi/Reflection/Table.php'; | ||||||
| require_once dirname(__FILE__) . '/Dibi/Event.php'; | require_once dirname(__FILE__) . '/Dibi/Event.php'; | ||||||
| require_once dirname(__FILE__) . '/Dibi/Loggers/FileLogger.php'; | require_once dirname(__FILE__) . '/Dibi/Loggers/FileLogger.php'; | ||||||
| require_once dirname(__FILE__) . '/Dibi/Loggers/FirePhpLogger.php'; | require_once dirname(__FILE__) . '/Dibi/Loggers/FirePhpLogger.php'; | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user