Laravel version update
Laravel version update
This commit is contained in:
		
							
								
								
									
										156
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Cache/ArrayStatement.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										156
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Cache/ArrayStatement.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,156 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Cache; | ||||
|  | ||||
| use Doctrine\DBAL\Driver\ResultStatement; | ||||
| use Doctrine\DBAL\FetchMode; | ||||
| use function array_merge; | ||||
| use function array_values; | ||||
| use function count; | ||||
| use function reset; | ||||
|  | ||||
| class ArrayStatement implements \IteratorAggregate, ResultStatement | ||||
| { | ||||
|     /** | ||||
|      * @var array | ||||
|      */ | ||||
|     private $data; | ||||
|  | ||||
|     /** | ||||
|      * @var int | ||||
|      */ | ||||
|     private $columnCount = 0; | ||||
|  | ||||
|     /** | ||||
|      * @var int | ||||
|      */ | ||||
|     private $num = 0; | ||||
|  | ||||
|     /** | ||||
|      * @var int | ||||
|      */ | ||||
|     private $defaultFetchMode = FetchMode::MIXED; | ||||
|  | ||||
|     /** | ||||
|      * @param array $data | ||||
|      */ | ||||
|     public function __construct(array $data) | ||||
|     { | ||||
|         $this->data = $data; | ||||
|         if (count($data)) { | ||||
|             $this->columnCount = count($data[0]); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function closeCursor() | ||||
|     { | ||||
|         unset ($this->data); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function columnCount() | ||||
|     { | ||||
|         return $this->columnCount; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function setFetchMode($fetchMode, $arg2 = null, $arg3 = null) | ||||
|     { | ||||
|         if ($arg2 !== null || $arg3 !== null) { | ||||
|             throw new \InvalidArgumentException("Caching layer does not support 2nd/3rd argument to setFetchMode()"); | ||||
|         } | ||||
|  | ||||
|         $this->defaultFetchMode = $fetchMode; | ||||
|  | ||||
|         return true; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function getIterator() | ||||
|     { | ||||
|         $data = $this->fetchAll(); | ||||
|  | ||||
|         return new \ArrayIterator($data); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function fetch($fetchMode = null, $cursorOrientation = \PDO::FETCH_ORI_NEXT, $cursorOffset = 0) | ||||
|     { | ||||
|         if (! isset($this->data[$this->num])) { | ||||
|             return false; | ||||
|         } | ||||
|  | ||||
|         $row       = $this->data[$this->num++]; | ||||
|         $fetchMode = $fetchMode ?: $this->defaultFetchMode; | ||||
|  | ||||
|         if ($fetchMode === FetchMode::ASSOCIATIVE) { | ||||
|             return $row; | ||||
|         } | ||||
|  | ||||
|         if ($fetchMode === FetchMode::NUMERIC) { | ||||
|             return array_values($row); | ||||
|         } | ||||
|  | ||||
|         if ($fetchMode === FetchMode::MIXED) { | ||||
|             return array_merge($row, array_values($row)); | ||||
|         } | ||||
|  | ||||
|         if ($fetchMode === FetchMode::COLUMN) { | ||||
|             return reset($row); | ||||
|         } | ||||
|  | ||||
|         throw new \InvalidArgumentException('Invalid fetch-style given for fetching result.'); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function fetchAll($fetchMode = null, $fetchArgument = null, $ctorArgs = null) | ||||
|     { | ||||
|         $rows = []; | ||||
|         while ($row = $this->fetch($fetchMode)) { | ||||
|             $rows[] = $row; | ||||
|         } | ||||
|  | ||||
|         return $rows; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function fetchColumn($columnIndex = 0) | ||||
|     { | ||||
|         $row = $this->fetch(FetchMode::NUMERIC); | ||||
|  | ||||
|         // TODO: verify that return false is the correct behavior | ||||
|         return $row[$columnIndex] ?? false; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										43
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Cache/CacheException.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										43
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Cache/CacheException.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,43 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Cache; | ||||
|  | ||||
| /** | ||||
|  * @author Benjamin Eberlei <kontakt@beberlei.de> | ||||
|  * @since 2.2 | ||||
|  */ | ||||
| class CacheException extends \Doctrine\DBAL\DBALException | ||||
| { | ||||
|     /** | ||||
|      * @return \Doctrine\DBAL\Cache\CacheException | ||||
|      */ | ||||
|     public static function noCacheKey() | ||||
|     { | ||||
|         return new self("No cache key was set."); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @return \Doctrine\DBAL\Cache\CacheException | ||||
|      */ | ||||
|     public static function noResultDriverConfigured() | ||||
|     { | ||||
|         return new self("Trying to cache a query but no result driver is configured."); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										145
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Cache/QueryCacheProfile.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										145
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Cache/QueryCacheProfile.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,145 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Cache; | ||||
|  | ||||
| use Doctrine\Common\Cache\Cache; | ||||
| use function hash; | ||||
| use function serialize; | ||||
| use function sha1; | ||||
|  | ||||
| /** | ||||
|  * Query Cache Profile handles the data relevant for query caching. | ||||
|  * | ||||
|  * It is a value object, setter methods return NEW instances. | ||||
|  */ | ||||
| class QueryCacheProfile | ||||
| { | ||||
|     /** | ||||
|      * @var Cache|null | ||||
|      */ | ||||
|     private $resultCacheDriver; | ||||
|  | ||||
|     /** | ||||
|      * @var int | ||||
|      */ | ||||
|     private $lifetime = 0; | ||||
|  | ||||
|     /** | ||||
|      * @var string|null | ||||
|      */ | ||||
|     private $cacheKey; | ||||
|  | ||||
|     /** | ||||
|      * @param int         $lifetime | ||||
|      * @param string|null $cacheKey | ||||
|      */ | ||||
|     public function __construct($lifetime = 0, $cacheKey = null, ?Cache $resultCache = null) | ||||
|     { | ||||
|         $this->lifetime          = $lifetime; | ||||
|         $this->cacheKey          = $cacheKey; | ||||
|         $this->resultCacheDriver = $resultCache; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @return Cache|null | ||||
|      */ | ||||
|     public function getResultCacheDriver() | ||||
|     { | ||||
|         return $this->resultCacheDriver; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @return int | ||||
|      */ | ||||
|     public function getLifetime() | ||||
|     { | ||||
|         return $this->lifetime; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @return string | ||||
|      * | ||||
|      * @throws CacheException | ||||
|      */ | ||||
|     public function getCacheKey() | ||||
|     { | ||||
|         if ($this->cacheKey === null) { | ||||
|             throw CacheException::noCacheKey(); | ||||
|         } | ||||
|  | ||||
|         return $this->cacheKey; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Generates the real cache key from query, params, types and connection parameters. | ||||
|      * | ||||
|      * @param string $query | ||||
|      * @param array  $params | ||||
|      * @param array  $types | ||||
|      * @param array  $connectionParams | ||||
|      * | ||||
|      * @return array | ||||
|      */ | ||||
|     public function generateCacheKeys($query, $params, $types, array $connectionParams = []) | ||||
|     { | ||||
|         $realCacheKey = 'query=' . $query . | ||||
|             '¶ms=' . serialize($params) . | ||||
|             '&types=' . serialize($types) . | ||||
|             '&connectionParams=' . hash('sha256', serialize($connectionParams)); | ||||
|  | ||||
|         // should the key be automatically generated using the inputs or is the cache key set? | ||||
|         if ($this->cacheKey === null) { | ||||
|             $cacheKey = sha1($realCacheKey); | ||||
|         } else { | ||||
|             $cacheKey = $this->cacheKey; | ||||
|         } | ||||
|  | ||||
|         return [$cacheKey, $realCacheKey]; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * | ||||
|      * @return \Doctrine\DBAL\Cache\QueryCacheProfile | ||||
|      */ | ||||
|     public function setResultCacheDriver(Cache $cache) | ||||
|     { | ||||
|         return new QueryCacheProfile($this->lifetime, $this->cacheKey, $cache); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @param string|null $cacheKey | ||||
|      * | ||||
|      * @return \Doctrine\DBAL\Cache\QueryCacheProfile | ||||
|      */ | ||||
|     public function setCacheKey($cacheKey) | ||||
|     { | ||||
|         return new QueryCacheProfile($this->lifetime, $cacheKey, $this->resultCacheDriver); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @param int $lifetime | ||||
|      * | ||||
|      * @return \Doctrine\DBAL\Cache\QueryCacheProfile | ||||
|      */ | ||||
|     public function setLifetime($lifetime) | ||||
|     { | ||||
|         return new QueryCacheProfile($lifetime, $this->cacheKey, $this->resultCacheDriver); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										229
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Cache/ResultCacheStatement.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										229
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Cache/ResultCacheStatement.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,229 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Cache; | ||||
|  | ||||
| use Doctrine\DBAL\Driver\Statement; | ||||
| use Doctrine\DBAL\Driver\ResultStatement; | ||||
| use Doctrine\Common\Cache\Cache; | ||||
| use Doctrine\DBAL\FetchMode; | ||||
| use function array_merge; | ||||
| use function array_values; | ||||
| use function reset; | ||||
|  | ||||
| /** | ||||
|  * Cache statement for SQL results. | ||||
|  * | ||||
|  * A result is saved in multiple cache keys, there is the originally specified | ||||
|  * cache key which is just pointing to result rows by key. The following things | ||||
|  * have to be ensured: | ||||
|  * | ||||
|  * 1. lifetime of the original key has to be longer than that of all the individual rows keys | ||||
|  * 2. if any one row key is missing the query has to be re-executed. | ||||
|  * | ||||
|  * Also you have to realize that the cache will load the whole result into memory at once to ensure 2. | ||||
|  * This means that the memory usage for cached results might increase by using this feature. | ||||
|  */ | ||||
| class ResultCacheStatement implements \IteratorAggregate, ResultStatement | ||||
| { | ||||
|     /** | ||||
|      * @var \Doctrine\Common\Cache\Cache | ||||
|      */ | ||||
|     private $resultCache; | ||||
|  | ||||
|     /** | ||||
|      * | ||||
|      * @var string | ||||
|      */ | ||||
|     private $cacheKey; | ||||
|  | ||||
|     /** | ||||
|      * @var string | ||||
|      */ | ||||
|     private $realKey; | ||||
|  | ||||
|     /** | ||||
|      * @var int | ||||
|      */ | ||||
|     private $lifetime; | ||||
|  | ||||
|     /** | ||||
|      * @var \Doctrine\DBAL\Driver\Statement | ||||
|      */ | ||||
|     private $statement; | ||||
|  | ||||
|     /** | ||||
|      * Did we reach the end of the statement? | ||||
|      * | ||||
|      * @var bool | ||||
|      */ | ||||
|     private $emptied = false; | ||||
|  | ||||
|     /** | ||||
|      * @var array | ||||
|      */ | ||||
|     private $data; | ||||
|  | ||||
|     /** | ||||
|      * @var int | ||||
|      */ | ||||
|     private $defaultFetchMode = FetchMode::MIXED; | ||||
|  | ||||
|     /** | ||||
|      * @param \Doctrine\DBAL\Driver\Statement $stmt | ||||
|      * @param \Doctrine\Common\Cache\Cache    $resultCache | ||||
|      * @param string                          $cacheKey | ||||
|      * @param string                          $realKey | ||||
|      * @param int                             $lifetime | ||||
|      */ | ||||
|     public function __construct(Statement $stmt, Cache $resultCache, $cacheKey, $realKey, $lifetime) | ||||
|     { | ||||
|         $this->statement = $stmt; | ||||
|         $this->resultCache = $resultCache; | ||||
|         $this->cacheKey = $cacheKey; | ||||
|         $this->realKey = $realKey; | ||||
|         $this->lifetime = $lifetime; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function closeCursor() | ||||
|     { | ||||
|         $this->statement->closeCursor(); | ||||
|         if ($this->emptied && $this->data !== null) { | ||||
|             $data = $this->resultCache->fetch($this->cacheKey); | ||||
|             if ( ! $data) { | ||||
|                 $data = []; | ||||
|             } | ||||
|             $data[$this->realKey] = $this->data; | ||||
|  | ||||
|             $this->resultCache->save($this->cacheKey, $data, $this->lifetime); | ||||
|             unset($this->data); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function columnCount() | ||||
|     { | ||||
|         return $this->statement->columnCount(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function setFetchMode($fetchMode, $arg2 = null, $arg3 = null) | ||||
|     { | ||||
|         $this->defaultFetchMode = $fetchMode; | ||||
|  | ||||
|         return true; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function getIterator() | ||||
|     { | ||||
|         $data = $this->fetchAll(); | ||||
|  | ||||
|         return new \ArrayIterator($data); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function fetch($fetchMode = null, $cursorOrientation = \PDO::FETCH_ORI_NEXT, $cursorOffset = 0) | ||||
|     { | ||||
|         if ($this->data === null) { | ||||
|             $this->data = []; | ||||
|         } | ||||
|  | ||||
|         $row = $this->statement->fetch(FetchMode::ASSOCIATIVE); | ||||
|  | ||||
|         if ($row) { | ||||
|             $this->data[] = $row; | ||||
|  | ||||
|             $fetchMode = $fetchMode ?: $this->defaultFetchMode; | ||||
|  | ||||
|             if ($fetchMode === FetchMode::ASSOCIATIVE) { | ||||
|                 return $row; | ||||
|             } | ||||
|  | ||||
|             if ($fetchMode === FetchMode::NUMERIC) { | ||||
|                 return array_values($row); | ||||
|             } | ||||
|  | ||||
|             if ($fetchMode === FetchMode::MIXED) { | ||||
|                 return array_merge($row, array_values($row)); | ||||
|             } | ||||
|  | ||||
|             if ($fetchMode === FetchMode::COLUMN) { | ||||
|                 return reset($row); | ||||
|             } | ||||
|  | ||||
|             throw new \InvalidArgumentException('Invalid fetch-style given for caching result.'); | ||||
|         } | ||||
|  | ||||
|         $this->emptied = true; | ||||
|  | ||||
|         return false; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function fetchAll($fetchMode = null, $fetchArgument = null, $ctorArgs = null) | ||||
|     { | ||||
|         $rows = []; | ||||
|         while ($row = $this->fetch($fetchMode)) { | ||||
|             $rows[] = $row; | ||||
|         } | ||||
|  | ||||
|         return $rows; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function fetchColumn($columnIndex = 0) | ||||
|     { | ||||
|         $row = $this->fetch(FetchMode::NUMERIC); | ||||
|  | ||||
|         // TODO: verify that return false is the correct behavior | ||||
|         return $row[$columnIndex] ?? false; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Returns the number of rows affected by the last DELETE, INSERT, or UPDATE statement | ||||
|      * executed by the corresponding object. | ||||
|      * | ||||
|      * If the last SQL statement executed by the associated Statement object was a SELECT statement, | ||||
|      * some databases may return the number of rows returned by that statement. However, | ||||
|      * this behaviour is not guaranteed for all databases and should not be | ||||
|      * relied on for portable applications. | ||||
|      * | ||||
|      * @return int The number of rows. | ||||
|      */ | ||||
|     public function rowCount() | ||||
|     { | ||||
|         return $this->statement->rowCount(); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										30
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/ColumnCase.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										30
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/ColumnCase.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,30 @@ | ||||
| <?php | ||||
|  | ||||
| namespace Doctrine\DBAL; | ||||
|  | ||||
| /** | ||||
|  * Contains portable column case conversions. | ||||
|  */ | ||||
| final class ColumnCase | ||||
| { | ||||
|     /** | ||||
|      * Convert column names to upper case. | ||||
|      * | ||||
|      * @see \PDO::CASE_UPPER | ||||
|      */ | ||||
|     public const UPPER = \PDO::CASE_UPPER; | ||||
|  | ||||
|     /** | ||||
|      * Convert column names to lower case. | ||||
|      * | ||||
|      * @see \PDO::CASE_LOWER | ||||
|      */ | ||||
|     public const LOWER = \PDO::CASE_LOWER; | ||||
|  | ||||
|     /** | ||||
|      * This class cannot be instantiated. | ||||
|      */ | ||||
|     private function __construct() | ||||
|     { | ||||
|     } | ||||
| } | ||||
							
								
								
									
										142
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Configuration.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										142
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Configuration.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,142 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL; | ||||
|  | ||||
| use Doctrine\DBAL\Logging\SQLLogger; | ||||
| use Doctrine\Common\Cache\Cache; | ||||
|  | ||||
| /** | ||||
|  * Configuration container for the Doctrine DBAL. | ||||
|  * | ||||
|  * @since    2.0 | ||||
|  * @author   Guilherme Blanco <guilhermeblanco@hotmail.com> | ||||
|  * @author   Jonathan Wage <jonwage@gmail.com> | ||||
|  * @author   Roman Borschel <roman@code-factory.org> | ||||
|  * @internal When adding a new configuration option just write a getter/setter | ||||
|  *           pair and add the option to the _attributes array with a proper default value. | ||||
|  */ | ||||
| class Configuration | ||||
| { | ||||
|     /** | ||||
|      * The attributes that are contained in the configuration. | ||||
|      * Values are default values. | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     protected $_attributes = []; | ||||
|  | ||||
|     /** | ||||
|      * Sets the SQL logger to use. Defaults to NULL which means SQL logging is disabled. | ||||
|      * | ||||
|      * @param \Doctrine\DBAL\Logging\SQLLogger|null $logger | ||||
|      * | ||||
|      * @return void | ||||
|      */ | ||||
|     public function setSQLLogger(SQLLogger $logger = null) | ||||
|     { | ||||
|         $this->_attributes['sqlLogger'] = $logger; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Gets the SQL logger that is used. | ||||
|      * | ||||
|      * @return \Doctrine\DBAL\Logging\SQLLogger|null | ||||
|      */ | ||||
|     public function getSQLLogger() | ||||
|     { | ||||
|         return $this->_attributes['sqlLogger'] ?? null; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Gets the cache driver implementation that is used for query result caching. | ||||
|      * | ||||
|      * @return \Doctrine\Common\Cache\Cache|null | ||||
|      */ | ||||
|     public function getResultCacheImpl() | ||||
|     { | ||||
|         return $this->_attributes['resultCacheImpl'] ?? null; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Sets the cache driver implementation that is used for query result caching. | ||||
|      * | ||||
|      * @param \Doctrine\Common\Cache\Cache $cacheImpl | ||||
|      * | ||||
|      * @return void | ||||
|      */ | ||||
|     public function setResultCacheImpl(Cache $cacheImpl) | ||||
|     { | ||||
|         $this->_attributes['resultCacheImpl'] = $cacheImpl; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Sets the filter schema assets expression. | ||||
|      * | ||||
|      * Only include tables/sequences matching the filter expression regexp in | ||||
|      * schema instances generated for the active connection when calling | ||||
|      * {AbstractSchemaManager#createSchema()}. | ||||
|      * | ||||
|      * @param string $filterExpression | ||||
|      * | ||||
|      * @return void | ||||
|      */ | ||||
|     public function setFilterSchemaAssetsExpression($filterExpression) | ||||
|     { | ||||
|         $this->_attributes['filterSchemaAssetsExpression'] = $filterExpression; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Returns filter schema assets expression. | ||||
|      * | ||||
|      * @return string|null | ||||
|      */ | ||||
|     public function getFilterSchemaAssetsExpression() | ||||
|     { | ||||
|         return $this->_attributes['filterSchemaAssetsExpression'] ?? null; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Sets the default auto-commit mode for connections. | ||||
|      * | ||||
|      * If a connection is in auto-commit mode, then all its SQL statements will be executed and committed as individual | ||||
|      * transactions. Otherwise, its SQL statements are grouped into transactions that are terminated by a call to either | ||||
|      * the method commit or the method rollback. By default, new connections are in auto-commit mode. | ||||
|      * | ||||
|      * @param bool $autoCommit True to enable auto-commit mode; false to disable it. | ||||
|      * | ||||
|      * @see   getAutoCommit | ||||
|      */ | ||||
|     public function setAutoCommit($autoCommit) | ||||
|     { | ||||
|         $this->_attributes['autoCommit'] = (boolean) $autoCommit; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Returns the default auto-commit mode for connections. | ||||
|      * | ||||
|      * @return bool True if auto-commit mode is enabled by default for connections, false otherwise. | ||||
|      * | ||||
|      * @see    setAutoCommit | ||||
|      */ | ||||
|     public function getAutoCommit() | ||||
|     { | ||||
|         return $this->_attributes['autoCommit'] ?? true; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										1706
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Connection.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										1706
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Connection.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										60
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/ConnectionException.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										60
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/ConnectionException.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,60 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL; | ||||
|  | ||||
| /** | ||||
|  * @link   www.doctrine-project.org | ||||
|  * @since  2.0 | ||||
|  * @author Jonathan H. Wage <jonwage@gmail.com | ||||
|  */ | ||||
| class ConnectionException extends DBALException | ||||
| { | ||||
|     /** | ||||
|      * @return \Doctrine\DBAL\ConnectionException | ||||
|      */ | ||||
|     public static function commitFailedRollbackOnly() | ||||
|     { | ||||
|         return new self("Transaction commit failed because the transaction has been marked for rollback only."); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @return \Doctrine\DBAL\ConnectionException | ||||
|      */ | ||||
|     public static function noActiveTransaction() | ||||
|     { | ||||
|         return new self("There is no active transaction."); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @return \Doctrine\DBAL\ConnectionException | ||||
|      */ | ||||
|     public static function savepointsNotSupported() | ||||
|     { | ||||
|         return new self("Savepoints are not supported by this driver."); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @return \Doctrine\DBAL\ConnectionException | ||||
|      */ | ||||
|     public static function mayNotAlterNestedTransactionWithSavepointsInTransaction() | ||||
|     { | ||||
|         return new self("May not alter the nested transaction with savepoints behavior while a transaction is open."); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										395
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Connections/MasterSlaveConnection.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										395
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Connections/MasterSlaveConnection.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,395 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Connections; | ||||
|  | ||||
| use Doctrine\DBAL\Connection; | ||||
| use Doctrine\DBAL\Driver; | ||||
| use Doctrine\DBAL\Driver\Connection as DriverConnection; | ||||
| use Doctrine\DBAL\Configuration; | ||||
| use Doctrine\Common\EventManager; | ||||
| use Doctrine\DBAL\Event\ConnectionEventArgs; | ||||
| use Doctrine\DBAL\Events; | ||||
| use function array_rand; | ||||
| use function count; | ||||
| use function func_get_args; | ||||
|  | ||||
| /** | ||||
|  * Master-Slave Connection | ||||
|  * | ||||
|  * Connection can be used with master-slave setups. | ||||
|  * | ||||
|  * Important for the understanding of this connection should be how and when | ||||
|  * it picks the slave or master. | ||||
|  * | ||||
|  * 1. Slave if master was never picked before and ONLY if 'getWrappedConnection' | ||||
|  *    or 'executeQuery' is used. | ||||
|  * 2. Master picked when 'exec', 'executeUpdate', 'insert', 'delete', 'update', 'createSavepoint', | ||||
|  *    'releaseSavepoint', 'beginTransaction', 'rollback', 'commit', 'query' or | ||||
|  *    'prepare' is called. | ||||
|  * 3. If master was picked once during the lifetime of the connection it will always get picked afterwards. | ||||
|  * 4. One slave connection is randomly picked ONCE during a request. | ||||
|  * | ||||
|  * ATTENTION: You can write to the slave with this connection if you execute a write query without | ||||
|  * opening up a transaction. For example: | ||||
|  * | ||||
|  *      $conn = DriverManager::getConnection(...); | ||||
|  *      $conn->executeQuery("DELETE FROM table"); | ||||
|  * | ||||
|  * Be aware that Connection#executeQuery is a method specifically for READ | ||||
|  * operations only. | ||||
|  * | ||||
|  * This connection is limited to slave operations using the | ||||
|  * Connection#executeQuery operation only, because it wouldn't be compatible | ||||
|  * with the ORM or SchemaManager code otherwise. Both use all the other | ||||
|  * operations in a context where writes could happen to a slave, which makes | ||||
|  * this restricted approach necessary. | ||||
|  * | ||||
|  * You can manually connect to the master at any time by calling: | ||||
|  * | ||||
|  *      $conn->connect('master'); | ||||
|  * | ||||
|  * Instantiation through the DriverManager looks like: | ||||
|  * | ||||
|  * @example | ||||
|  * | ||||
|  * $conn = DriverManager::getConnection(array( | ||||
|  *    'wrapperClass' => 'Doctrine\DBAL\Connections\MasterSlaveConnection', | ||||
|  *    'driver' => 'pdo_mysql', | ||||
|  *    'master' => array('user' => '', 'password' => '', 'host' => '', 'dbname' => ''), | ||||
|  *    'slaves' => array( | ||||
|  *        array('user' => 'slave1', 'password', 'host' => '', 'dbname' => ''), | ||||
|  *        array('user' => 'slave2', 'password', 'host' => '', 'dbname' => ''), | ||||
|  *    ) | ||||
|  * )); | ||||
|  * | ||||
|  * You can also pass 'driverOptions' and any other documented option to each of this drivers to pass additional information. | ||||
|  * | ||||
|  * @author Lars Strojny <lstrojny@php.net> | ||||
|  * @author Benjamin Eberlei <kontakt@beberlei.de> | ||||
|  */ | ||||
| class MasterSlaveConnection extends Connection | ||||
| { | ||||
|     /** | ||||
|      * Master and slave connection (one of the randomly picked slaves). | ||||
|      * | ||||
|      * @var DriverConnection[]|null[] | ||||
|      */ | ||||
|     protected $connections = ['master' => null, 'slave' => null]; | ||||
|  | ||||
|     /** | ||||
|      * You can keep the slave connection and then switch back to it | ||||
|      * during the request if you know what you are doing. | ||||
|      * | ||||
|      * @var bool | ||||
|      */ | ||||
|     protected $keepSlave = false; | ||||
|  | ||||
|     /** | ||||
|      * Creates Master Slave Connection. | ||||
|      * | ||||
|      * @param array                              $params | ||||
|      * @param \Doctrine\DBAL\Driver              $driver | ||||
|      * @param \Doctrine\DBAL\Configuration|null  $config | ||||
|      * @param \Doctrine\Common\EventManager|null $eventManager | ||||
|      * | ||||
|      * @throws \InvalidArgumentException | ||||
|      */ | ||||
|     public function __construct(array $params, Driver $driver, Configuration $config = null, EventManager $eventManager = null) | ||||
|     { | ||||
|         if (! isset($params['slaves'], $params['master'])) { | ||||
|             throw new \InvalidArgumentException('master or slaves configuration missing'); | ||||
|         } | ||||
|         if (count($params['slaves']) == 0) { | ||||
|             throw new \InvalidArgumentException('You have to configure at least one slaves.'); | ||||
|         } | ||||
|  | ||||
|         $params['master']['driver'] = $params['driver']; | ||||
|         foreach ($params['slaves'] as $slaveKey => $slave) { | ||||
|             $params['slaves'][$slaveKey]['driver'] = $params['driver']; | ||||
|         } | ||||
|  | ||||
|         $this->keepSlave = (bool) ($params['keepSlave'] ?? false); | ||||
|  | ||||
|         parent::__construct($params, $driver, $config, $eventManager); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Checks if the connection is currently towards the master or not. | ||||
|      * | ||||
|      * @return bool | ||||
|      */ | ||||
|     public function isConnectedToMaster() | ||||
|     { | ||||
|         return $this->_conn !== null && $this->_conn === $this->connections['master']; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritDoc} | ||||
|      */ | ||||
|     public function connect($connectionName = null) | ||||
|     { | ||||
|         $requestedConnectionChange = ($connectionName !== null); | ||||
|         $connectionName            = $connectionName ?: 'slave'; | ||||
|  | ||||
|         if ($connectionName !== 'slave' && $connectionName !== 'master') { | ||||
|             throw new \InvalidArgumentException("Invalid option to connect(), only master or slave allowed."); | ||||
|         } | ||||
|  | ||||
|         // If we have a connection open, and this is not an explicit connection | ||||
|         // change request, then abort right here, because we are already done. | ||||
|         // This prevents writes to the slave in case of "keepSlave" option enabled. | ||||
|         if (isset($this->_conn) && $this->_conn && !$requestedConnectionChange) { | ||||
|             return false; | ||||
|         } | ||||
|  | ||||
|         $forceMasterAsSlave = false; | ||||
|  | ||||
|         if ($this->getTransactionNestingLevel() > 0) { | ||||
|             $connectionName     = 'master'; | ||||
|             $forceMasterAsSlave = true; | ||||
|         } | ||||
|  | ||||
|         if (isset($this->connections[$connectionName]) && $this->connections[$connectionName]) { | ||||
|             $this->_conn = $this->connections[$connectionName]; | ||||
|  | ||||
|             if ($forceMasterAsSlave && ! $this->keepSlave) { | ||||
|                 $this->connections['slave'] = $this->_conn; | ||||
|             } | ||||
|  | ||||
|             return false; | ||||
|         } | ||||
|  | ||||
|         if ($connectionName === 'master') { | ||||
|             $this->connections['master'] = $this->_conn = $this->connectTo($connectionName); | ||||
|  | ||||
|             // Set slave connection to master to avoid invalid reads | ||||
|             if ( ! $this->keepSlave) { | ||||
|                 $this->connections['slave'] = $this->connections['master']; | ||||
|             } | ||||
|         } else { | ||||
|             $this->connections['slave'] = $this->_conn = $this->connectTo($connectionName); | ||||
|         } | ||||
|  | ||||
|         if ($this->_eventManager->hasListeners(Events::postConnect)) { | ||||
|             $eventArgs = new ConnectionEventArgs($this); | ||||
|             $this->_eventManager->dispatchEvent(Events::postConnect, $eventArgs); | ||||
|         } | ||||
|  | ||||
|         return true; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Connects to a specific connection. | ||||
|      * | ||||
|      * @param string $connectionName | ||||
|      * | ||||
|      * @return DriverConnection | ||||
|      */ | ||||
|     protected function connectTo($connectionName) | ||||
|     { | ||||
|         $params = $this->getParams(); | ||||
|  | ||||
|         $driverOptions = $params['driverOptions'] ?? []; | ||||
|  | ||||
|         $connectionParams = $this->chooseConnectionConfiguration($connectionName, $params); | ||||
|  | ||||
|         $user = $connectionParams['user'] ?? null; | ||||
|         $password = $connectionParams['password'] ?? null; | ||||
|  | ||||
|         return $this->_driver->connect($connectionParams, $user, $password, $driverOptions); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @param string $connectionName | ||||
|      * @param array  $params | ||||
|      * | ||||
|      * @return mixed | ||||
|      */ | ||||
|     protected function chooseConnectionConfiguration($connectionName, $params) | ||||
|     { | ||||
|         if ($connectionName === 'master') { | ||||
|             return $params['master']; | ||||
|         } | ||||
|  | ||||
|         $config = $params['slaves'][array_rand($params['slaves'])]; | ||||
|  | ||||
|         if ( ! isset($config['charset']) && isset($params['master']['charset'])) { | ||||
|             $config['charset'] = $params['master']['charset']; | ||||
|         } | ||||
|  | ||||
|         return $config; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritDoc} | ||||
|      */ | ||||
|     public function executeUpdate($query, array $params = [], array $types = []) | ||||
|     { | ||||
|         $this->connect('master'); | ||||
|  | ||||
|         return parent::executeUpdate($query, $params, $types); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritDoc} | ||||
|      */ | ||||
|     public function beginTransaction() | ||||
|     { | ||||
|         $this->connect('master'); | ||||
|  | ||||
|         parent::beginTransaction(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritDoc} | ||||
|      */ | ||||
|     public function commit() | ||||
|     { | ||||
|         $this->connect('master'); | ||||
|  | ||||
|         parent::commit(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritDoc} | ||||
|      */ | ||||
|     public function rollBack() | ||||
|     { | ||||
|         $this->connect('master'); | ||||
|  | ||||
|         return parent::rollBack(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritDoc} | ||||
|      */ | ||||
|     public function delete($tableName, array $identifier, array $types = []) | ||||
|     { | ||||
|         $this->connect('master'); | ||||
|  | ||||
|         return parent::delete($tableName, $identifier, $types); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritDoc} | ||||
|      */ | ||||
|     public function close() | ||||
|     { | ||||
|         unset($this->connections['master'], $this->connections['slave']); | ||||
|  | ||||
|         parent::close(); | ||||
|  | ||||
|         $this->_conn = null; | ||||
|         $this->connections = ['master' => null, 'slave' => null]; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritDoc} | ||||
|      */ | ||||
|     public function update($tableName, array $data, array $identifier, array $types = []) | ||||
|     { | ||||
|         $this->connect('master'); | ||||
|  | ||||
|         return parent::update($tableName, $data, $identifier, $types); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritDoc} | ||||
|      */ | ||||
|     public function insert($tableName, array $data, array $types = []) | ||||
|     { | ||||
|         $this->connect('master'); | ||||
|  | ||||
|         return parent::insert($tableName, $data, $types); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritDoc} | ||||
|      */ | ||||
|     public function exec($statement) | ||||
|     { | ||||
|         $this->connect('master'); | ||||
|  | ||||
|         return parent::exec($statement); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritDoc} | ||||
|      */ | ||||
|     public function createSavepoint($savepoint) | ||||
|     { | ||||
|         $this->connect('master'); | ||||
|  | ||||
|         parent::createSavepoint($savepoint); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritDoc} | ||||
|      */ | ||||
|     public function releaseSavepoint($savepoint) | ||||
|     { | ||||
|         $this->connect('master'); | ||||
|  | ||||
|         parent::releaseSavepoint($savepoint); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritDoc} | ||||
|      */ | ||||
|     public function rollbackSavepoint($savepoint) | ||||
|     { | ||||
|         $this->connect('master'); | ||||
|  | ||||
|         parent::rollbackSavepoint($savepoint); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritDoc} | ||||
|      */ | ||||
|     public function query() | ||||
|     { | ||||
|         $this->connect('master'); | ||||
|  | ||||
|         $args = func_get_args(); | ||||
|  | ||||
|         $logger = $this->getConfiguration()->getSQLLogger(); | ||||
|         if ($logger) { | ||||
|             $logger->startQuery($args[0]); | ||||
|         } | ||||
|  | ||||
|         $statement = $this->_conn->query(...$args); | ||||
|  | ||||
|         if ($logger) { | ||||
|             $logger->stopQuery(); | ||||
|         } | ||||
|  | ||||
|         return $statement; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritDoc} | ||||
|      */ | ||||
|     public function prepare($statement) | ||||
|     { | ||||
|         $this->connect('master'); | ||||
|  | ||||
|         return parent::prepare($statement); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										302
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/DBALException.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										302
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/DBALException.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,302 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL; | ||||
|  | ||||
| use Doctrine\DBAL\Exception; | ||||
| use Doctrine\DBAL\Driver; | ||||
| use Doctrine\DBAL\Driver\ExceptionConverterDriver; | ||||
| use Doctrine\DBAL\Platforms\AbstractPlatform; | ||||
| use function array_map; | ||||
| use function bin2hex; | ||||
| use function implode; | ||||
| use function is_resource; | ||||
| use function is_string; | ||||
| use function json_encode; | ||||
| use function sprintf; | ||||
| use function str_split; | ||||
|  | ||||
| class DBALException extends \Exception | ||||
| { | ||||
|     /** | ||||
|      * @param string $method | ||||
|      * | ||||
|      * @return \Doctrine\DBAL\DBALException | ||||
|      */ | ||||
|     public static function notSupported($method) | ||||
|     { | ||||
|         return new self("Operation '$method' is not supported by platform."); | ||||
|     } | ||||
|  | ||||
|     public static function invalidPlatformSpecified() : self | ||||
|     { | ||||
|         return new self( | ||||
|             "Invalid 'platform' option specified, need to give an instance of ". | ||||
|             "\Doctrine\DBAL\Platforms\AbstractPlatform."); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @param mixed $invalidPlatform | ||||
|      */ | ||||
|     public static function invalidPlatformType($invalidPlatform) : self | ||||
|     { | ||||
|         if (\is_object($invalidPlatform)) { | ||||
|             return new self( | ||||
|                 sprintf( | ||||
|                     "Option 'platform' must be a subtype of '%s', instance of '%s' given", | ||||
|                     AbstractPlatform::class, | ||||
|                     \get_class($invalidPlatform) | ||||
|                 ) | ||||
|             ); | ||||
|         } | ||||
|  | ||||
|         return new self( | ||||
|             sprintf( | ||||
|                 "Option 'platform' must be an object and subtype of '%s'. Got '%s'", | ||||
|                 AbstractPlatform::class, | ||||
|                 \gettype($invalidPlatform) | ||||
|             ) | ||||
|         ); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Returns a new instance for an invalid specified platform version. | ||||
|      * | ||||
|      * @param string $version        The invalid platform version given. | ||||
|      * @param string $expectedFormat The expected platform version format. | ||||
|      * | ||||
|      * @return DBALException | ||||
|      */ | ||||
|     public static function invalidPlatformVersionSpecified($version, $expectedFormat) | ||||
|     { | ||||
|         return new self( | ||||
|             sprintf( | ||||
|                 'Invalid platform version "%s" specified. ' . | ||||
|                 'The platform version has to be specified in the format: "%s".', | ||||
|                 $version, | ||||
|                 $expectedFormat | ||||
|             ) | ||||
|         ); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @return \Doctrine\DBAL\DBALException | ||||
|      */ | ||||
|     public static function invalidPdoInstance() | ||||
|     { | ||||
|         return new self( | ||||
|             "The 'pdo' option was used in DriverManager::getConnection() but no ". | ||||
|             "instance of PDO was given." | ||||
|         ); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @param string|null $url The URL that was provided in the connection parameters (if any). | ||||
|      * | ||||
|      * @return \Doctrine\DBAL\DBALException | ||||
|      */ | ||||
|     public static function driverRequired($url = null) | ||||
|     { | ||||
|         if ($url) { | ||||
|             return new self( | ||||
|                 sprintf( | ||||
|                     "The options 'driver' or 'driverClass' are mandatory if a connection URL without scheme " . | ||||
|                     "is given to DriverManager::getConnection(). Given URL: %s", | ||||
|                     $url | ||||
|                 ) | ||||
|             ); | ||||
|         } | ||||
|  | ||||
|         return new self("The options 'driver' or 'driverClass' are mandatory if no PDO ". | ||||
|             "instance is given to DriverManager::getConnection()."); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @param string $unknownDriverName | ||||
|      * @param array  $knownDrivers | ||||
|      * | ||||
|      * @return \Doctrine\DBAL\DBALException | ||||
|      */ | ||||
|     public static function unknownDriver($unknownDriverName, array $knownDrivers) | ||||
|     { | ||||
|         return new self("The given 'driver' ".$unknownDriverName." is unknown, ". | ||||
|             "Doctrine currently supports only the following drivers: ".implode(", ", $knownDrivers)); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @param \Doctrine\DBAL\Driver $driver | ||||
|      * @param \Exception            $driverEx | ||||
|      * @param string                $sql | ||||
|      * @param array                 $params | ||||
|      * | ||||
|      * @return \Doctrine\DBAL\DBALException | ||||
|      */ | ||||
|     public static function driverExceptionDuringQuery(Driver $driver, \Exception $driverEx, $sql, array $params = []) | ||||
|     { | ||||
|         $msg = "An exception occurred while executing '".$sql."'"; | ||||
|         if ($params) { | ||||
|             $msg .= " with params " . self::formatParameters($params); | ||||
|         } | ||||
|         $msg .= ":\n\n".$driverEx->getMessage(); | ||||
|  | ||||
|         return static::wrapException($driver, $driverEx, $msg); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @param \Doctrine\DBAL\Driver $driver | ||||
|      * @param \Exception            $driverEx | ||||
|      * | ||||
|      * @return \Doctrine\DBAL\DBALException | ||||
|      */ | ||||
|     public static function driverException(Driver $driver, \Exception $driverEx) | ||||
|     { | ||||
|         return static::wrapException($driver, $driverEx, "An exception occurred in driver: " . $driverEx->getMessage()); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @param \Doctrine\DBAL\Driver $driver | ||||
|      * @param \Exception            $driverEx | ||||
|      * | ||||
|      * @return \Doctrine\DBAL\DBALException | ||||
|      */ | ||||
|     private static function wrapException(Driver $driver, \Exception $driverEx, $msg) | ||||
|     { | ||||
|         if ($driverEx instanceof Exception\DriverException) { | ||||
|             return $driverEx; | ||||
|         } | ||||
|         if ($driver instanceof ExceptionConverterDriver && $driverEx instanceof Driver\DriverException) { | ||||
|             return $driver->convertException($msg, $driverEx); | ||||
|         } | ||||
|  | ||||
|         return new self($msg, 0, $driverEx); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Returns a human-readable representation of an array of parameters. | ||||
|      * This properly handles binary data by returning a hex representation. | ||||
|      * | ||||
|      * @param array $params | ||||
|      * | ||||
|      * @return string | ||||
|      */ | ||||
|     private static function formatParameters(array $params) | ||||
|     { | ||||
|         return '[' . implode(', ', array_map(function ($param) { | ||||
|             if (is_resource($param)) { | ||||
|                 return (string) $param; | ||||
|             } | ||||
|              | ||||
|             $json = @json_encode($param); | ||||
|  | ||||
|             if (! is_string($json) || $json == 'null' && is_string($param)) { | ||||
|                 // JSON encoding failed, this is not a UTF-8 string. | ||||
|                 return '"\x' . implode('\x', str_split(bin2hex($param), 2)) . '"'; | ||||
|             } | ||||
|  | ||||
|             return $json; | ||||
|         }, $params)) . ']'; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @param string $wrapperClass | ||||
|      * | ||||
|      * @return \Doctrine\DBAL\DBALException | ||||
|      */ | ||||
|     public static function invalidWrapperClass($wrapperClass) | ||||
|     { | ||||
|         return new self("The given 'wrapperClass' ".$wrapperClass." has to be a ". | ||||
|             "subtype of \Doctrine\DBAL\Connection."); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @param string $driverClass | ||||
|      * | ||||
|      * @return \Doctrine\DBAL\DBALException | ||||
|      */ | ||||
|     public static function invalidDriverClass($driverClass) | ||||
|     { | ||||
|         return new self("The given 'driverClass' ".$driverClass." has to implement the ". | ||||
|             "\Doctrine\DBAL\Driver interface."); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @param string $tableName | ||||
|      * | ||||
|      * @return \Doctrine\DBAL\DBALException | ||||
|      */ | ||||
|     public static function invalidTableName($tableName) | ||||
|     { | ||||
|         return new self("Invalid table name specified: ".$tableName); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @param string $tableName | ||||
|      * | ||||
|      * @return \Doctrine\DBAL\DBALException | ||||
|      */ | ||||
|     public static function noColumnsSpecifiedForTable($tableName) | ||||
|     { | ||||
|         return new self("No columns specified for table ".$tableName); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @return \Doctrine\DBAL\DBALException | ||||
|      */ | ||||
|     public static function limitOffsetInvalid() | ||||
|     { | ||||
|         return new self("Invalid Offset in Limit Query, it has to be larger than or equal to 0."); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @param string $name | ||||
|      * | ||||
|      * @return \Doctrine\DBAL\DBALException | ||||
|      */ | ||||
|     public static function typeExists($name) | ||||
|     { | ||||
|         return new self('Type '.$name.' already exists.'); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @param string $name | ||||
|      * | ||||
|      * @return \Doctrine\DBAL\DBALException | ||||
|      */ | ||||
|     public static function unknownColumnType($name) | ||||
|     { | ||||
|         return new self('Unknown column type "'.$name.'" requested. Any Doctrine type that you use has ' . | ||||
|             'to be registered with \Doctrine\DBAL\Types\Type::addType(). You can get a list of all the ' . | ||||
|             'known types with \Doctrine\DBAL\Types\Type::getTypesMap(). If this error occurs during database ' . | ||||
|             'introspection then you might have forgotten to register all database types for a Doctrine Type. Use ' . | ||||
|             'AbstractPlatform#registerDoctrineTypeMapping() or have your custom types implement ' . | ||||
|             'Type#getMappedDatabaseTypes(). If the type name is empty you might ' . | ||||
|             'have a problem with the cache or forgot some mapping information.' | ||||
|         ); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @param string $name | ||||
|      * | ||||
|      * @return \Doctrine\DBAL\DBALException | ||||
|      */ | ||||
|     public static function typeNotFound($name) | ||||
|     { | ||||
|         return new self('Type to be overwritten '.$name.' does not exist.'); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										75
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										75
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,75 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL; | ||||
|  | ||||
| /** | ||||
|  * Driver interface. | ||||
|  * Interface that all DBAL drivers must implement. | ||||
|  * | ||||
|  * @since 2.0 | ||||
|  */ | ||||
| interface Driver | ||||
| { | ||||
|     /** | ||||
|      * Attempts to create a connection with the database. | ||||
|      * | ||||
|      * @param array       $params        All connection parameters passed by the user. | ||||
|      * @param string|null $username      The username to use when connecting. | ||||
|      * @param string|null $password      The password to use when connecting. | ||||
|      * @param array       $driverOptions The driver options to use when connecting. | ||||
|      * | ||||
|      * @return \Doctrine\DBAL\Driver\Connection The database connection. | ||||
|      */ | ||||
|     public function connect(array $params, $username = null, $password = null, array $driverOptions = []); | ||||
|  | ||||
|     /** | ||||
|      * Gets the DatabasePlatform instance that provides all the metadata about | ||||
|      * the platform this driver connects to. | ||||
|      * | ||||
|      * @return \Doctrine\DBAL\Platforms\AbstractPlatform The database platform. | ||||
|      */ | ||||
|     public function getDatabasePlatform(); | ||||
|  | ||||
|     /** | ||||
|      * Gets the SchemaManager that can be used to inspect and change the underlying | ||||
|      * database schema of the platform this driver connects to. | ||||
|      * | ||||
|      * @param \Doctrine\DBAL\Connection $conn | ||||
|      * | ||||
|      * @return \Doctrine\DBAL\Schema\AbstractSchemaManager | ||||
|      */ | ||||
|     public function getSchemaManager(Connection $conn); | ||||
|  | ||||
|     /** | ||||
|      * Gets the name of the driver. | ||||
|      * | ||||
|      * @return string The name of the driver. | ||||
|      */ | ||||
|     public function getName(); | ||||
|  | ||||
|     /** | ||||
|      * Gets the name of the database connected to for this driver. | ||||
|      * | ||||
|      * @param \Doctrine\DBAL\Connection $conn | ||||
|      * | ||||
|      * @return string The name of the database. | ||||
|      */ | ||||
|     public function getDatabase(Connection $conn); | ||||
| } | ||||
							
								
								
									
										60
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/AbstractDB2Driver.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										60
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/AbstractDB2Driver.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,60 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Driver; | ||||
|  | ||||
| use Doctrine\DBAL\Driver; | ||||
| use Doctrine\DBAL\Platforms\DB2Platform; | ||||
| use Doctrine\DBAL\Schema\DB2SchemaManager; | ||||
|  | ||||
| /** | ||||
|  * Abstract base implementation of the {@link Doctrine\DBAL\Driver} interface for IBM DB2 based drivers. | ||||
|  * | ||||
|  * @author Steve Müller <st.mueller@dzh-online.de> | ||||
|  * @link   www.doctrine-project.org | ||||
|  * @since  2.5 | ||||
|  */ | ||||
| abstract class AbstractDB2Driver implements Driver | ||||
| { | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function getDatabase(\Doctrine\DBAL\Connection $conn) | ||||
|     { | ||||
|         $params = $conn->getParams(); | ||||
|  | ||||
|         return $params['dbname']; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function getDatabasePlatform() | ||||
|     { | ||||
|         return new DB2Platform(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function getSchemaManager(\Doctrine\DBAL\Connection $conn) | ||||
|     { | ||||
|         return new DB2SchemaManager($conn); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										75
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/AbstractDriverException.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										75
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/AbstractDriverException.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,75 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Driver; | ||||
|  | ||||
| /** | ||||
|  * Abstract base implementation of the {@link DriverException} interface. | ||||
|  * | ||||
|  * @author Steve Müller <st.mueller@dzh-online.de> | ||||
|  * @link   www.doctrine-project.org | ||||
|  * @since  2.5 | ||||
|  */ | ||||
| abstract class AbstractDriverException extends \Exception implements DriverException | ||||
| { | ||||
|     /** | ||||
|      * The driver specific error code. | ||||
|      * | ||||
|      * @var int|string|null | ||||
|      */ | ||||
|     private $errorCode; | ||||
|  | ||||
|     /** | ||||
|      * The SQLSTATE of the driver. | ||||
|      * | ||||
|      * @var string|null | ||||
|      */ | ||||
|     private $sqlState; | ||||
|  | ||||
|     /** | ||||
|      * Constructor. | ||||
|      * | ||||
|      * @param string          $message   The driver error message. | ||||
|      * @param string|null     $sqlState  The SQLSTATE the driver is in at the time the error occurred, if any. | ||||
|      * @param int|string|null $errorCode The driver specific error code if any. | ||||
|      */ | ||||
|     public function __construct($message, $sqlState = null, $errorCode = null) | ||||
|     { | ||||
|         parent::__construct($message); | ||||
|  | ||||
|         $this->errorCode = $errorCode; | ||||
|         $this->sqlState  = $sqlState; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function getErrorCode() | ||||
|     { | ||||
|         return $this->errorCode; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function getSQLState() | ||||
|     { | ||||
|         return $this->sqlState; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										234
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/AbstractMySQLDriver.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										234
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/AbstractMySQLDriver.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,234 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Driver; | ||||
|  | ||||
| use Doctrine\DBAL\DBALException; | ||||
| use Doctrine\DBAL\Driver; | ||||
| use Doctrine\DBAL\Exception; | ||||
| use Doctrine\DBAL\Platforms\MariaDb1027Platform; | ||||
| use Doctrine\DBAL\Platforms\MySQL57Platform; | ||||
| use Doctrine\DBAL\Platforms\MySQL80Platform; | ||||
| use Doctrine\DBAL\Platforms\MySqlPlatform; | ||||
| use Doctrine\DBAL\Schema\MySqlSchemaManager; | ||||
| use Doctrine\DBAL\VersionAwarePlatformDriver; | ||||
| use function preg_match; | ||||
| use function stripos; | ||||
| use function version_compare; | ||||
|  | ||||
| /** | ||||
|  * Abstract base implementation of the {@link Doctrine\DBAL\Driver} interface for MySQL based drivers. | ||||
|  * | ||||
|  * @author Steve Müller <st.mueller@dzh-online.de> | ||||
|  * @link   www.doctrine-project.org | ||||
|  * @since  2.5 | ||||
|  */ | ||||
| abstract class AbstractMySQLDriver implements Driver, ExceptionConverterDriver, VersionAwarePlatformDriver | ||||
| { | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      * | ||||
|      * @link http://dev.mysql.com/doc/refman/5.7/en/error-messages-client.html | ||||
|      * @link http://dev.mysql.com/doc/refman/5.7/en/error-messages-server.html | ||||
|      */ | ||||
|     public function convertException($message, DriverException $exception) | ||||
|     { | ||||
|         switch ($exception->getErrorCode()) { | ||||
|             case '1213': | ||||
|                 return new Exception\DeadlockException($message, $exception); | ||||
|             case '1205': | ||||
|                 return new Exception\LockWaitTimeoutException($message, $exception); | ||||
|             case '1050': | ||||
|                 return new Exception\TableExistsException($message, $exception); | ||||
|  | ||||
|             case '1051': | ||||
|             case '1146': | ||||
|                 return new Exception\TableNotFoundException($message, $exception); | ||||
|  | ||||
|             case '1216': | ||||
|             case '1217': | ||||
|             case '1451': | ||||
|             case '1452': | ||||
|             case '1701': | ||||
|                 return new Exception\ForeignKeyConstraintViolationException($message, $exception); | ||||
|  | ||||
|             case '1062': | ||||
|             case '1557': | ||||
|             case '1569': | ||||
|             case '1586': | ||||
|                 return new Exception\UniqueConstraintViolationException($message, $exception); | ||||
|  | ||||
|             case '1054': | ||||
|             case '1166': | ||||
|             case '1611': | ||||
|                 return new Exception\InvalidFieldNameException($message, $exception); | ||||
|  | ||||
|             case '1052': | ||||
|             case '1060': | ||||
|             case '1110': | ||||
|                 return new Exception\NonUniqueFieldNameException($message, $exception); | ||||
|  | ||||
|             case '1064': | ||||
|             case '1149': | ||||
|             case '1287': | ||||
|             case '1341': | ||||
|             case '1342': | ||||
|             case '1343': | ||||
|             case '1344': | ||||
|             case '1382': | ||||
|             case '1479': | ||||
|             case '1541': | ||||
|             case '1554': | ||||
|             case '1626': | ||||
|                 return new Exception\SyntaxErrorException($message, $exception); | ||||
|  | ||||
|             case '1044': | ||||
|             case '1045': | ||||
|             case '1046': | ||||
|             case '1049': | ||||
|             case '1095': | ||||
|             case '1142': | ||||
|             case '1143': | ||||
|             case '1227': | ||||
|             case '1370': | ||||
|             case '1429': | ||||
|             case '2002': | ||||
|             case '2005': | ||||
|                 return new Exception\ConnectionException($message, $exception); | ||||
|  | ||||
|             case '1048': | ||||
|             case '1121': | ||||
|             case '1138': | ||||
|             case '1171': | ||||
|             case '1252': | ||||
|             case '1263': | ||||
|             case '1364': | ||||
|             case '1566': | ||||
|                 return new Exception\NotNullConstraintViolationException($message, $exception); | ||||
|         } | ||||
|  | ||||
|         return new Exception\DriverException($message, $exception); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      * | ||||
|      * @throws DBALException | ||||
|      */ | ||||
|     public function createDatabasePlatformForVersion($version) | ||||
|     { | ||||
|         $mariadb = false !== stripos($version, 'mariadb'); | ||||
|         if ($mariadb && version_compare($this->getMariaDbMysqlVersionNumber($version), '10.2.7', '>=')) { | ||||
|             return new MariaDb1027Platform(); | ||||
|         } | ||||
|  | ||||
|         if (! $mariadb) { | ||||
|             $oracleMysqlVersion = $this->getOracleMysqlVersionNumber($version); | ||||
|             if (version_compare($oracleMysqlVersion, '8', '>=')) { | ||||
|                 return new MySQL80Platform(); | ||||
|             } | ||||
|             if (version_compare($oracleMysqlVersion, '5.7.9', '>=')) { | ||||
|                 return new MySQL57Platform(); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         return $this->getDatabasePlatform(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get a normalized 'version number' from the server string | ||||
|      * returned by Oracle MySQL servers. | ||||
|      * | ||||
|      * @param string $versionString Version string returned by the driver, i.e. '5.7.10' | ||||
|      * @throws DBALException | ||||
|      */ | ||||
|     private function getOracleMysqlVersionNumber(string $versionString) : string | ||||
|     { | ||||
|         if ( ! preg_match( | ||||
|             '/^(?P<major>\d+)(?:\.(?P<minor>\d+)(?:\.(?P<patch>\d+))?)?/', | ||||
|             $versionString, | ||||
|             $versionParts | ||||
|         )) { | ||||
|             throw DBALException::invalidPlatformVersionSpecified( | ||||
|                 $versionString, | ||||
|                 '<major_version>.<minor_version>.<patch_version>' | ||||
|             ); | ||||
|         } | ||||
|         $majorVersion = $versionParts['major']; | ||||
|         $minorVersion = $versionParts['minor'] ?? 0; | ||||
|         $patchVersion = $versionParts['patch'] ?? null; | ||||
|  | ||||
|         if ('5' === $majorVersion && '7' === $minorVersion && null === $patchVersion) { | ||||
|             $patchVersion = '9'; | ||||
|         } | ||||
|  | ||||
|         return $majorVersion . '.' . $minorVersion . '.' . $patchVersion; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Detect MariaDB server version, including hack for some mariadb distributions | ||||
|      * that starts with the prefix '5.5.5-' | ||||
|      * | ||||
|      * @param string $versionString Version string as returned by mariadb server, i.e. '5.5.5-Mariadb-10.0.8-xenial' | ||||
|      * @throws DBALException | ||||
|      */ | ||||
|     private function getMariaDbMysqlVersionNumber(string $versionString) : string | ||||
|     { | ||||
|         if ( ! preg_match( | ||||
|             '/^(?:5\.5\.5-)?(mariadb-)?(?P<major>\d+)\.(?P<minor>\d+)\.(?P<patch>\d+)/i', | ||||
|             $versionString, | ||||
|             $versionParts | ||||
|         )) { | ||||
|             throw DBALException::invalidPlatformVersionSpecified( | ||||
|                 $versionString, | ||||
|                 '^(?:5\.5\.5-)?(mariadb-)?<major_version>.<minor_version>.<patch_version>' | ||||
|             ); | ||||
|         } | ||||
|  | ||||
|         return $versionParts['major'] . '.' . $versionParts['minor'] . '.' . $versionParts['patch']; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function getDatabase(\Doctrine\DBAL\Connection $conn) | ||||
|     { | ||||
|         $params = $conn->getParams(); | ||||
|  | ||||
|         return $params['dbname'] ?? $conn->query('SELECT DATABASE()')->fetchColumn(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      * @return MySqlPlatform | ||||
|      */ | ||||
|     public function getDatabasePlatform() | ||||
|     { | ||||
|         return new MySqlPlatform(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      * @return MySqlSchemaManager | ||||
|      */ | ||||
|     public function getSchemaManager(\Doctrine\DBAL\Connection $conn) | ||||
|     { | ||||
|         return new MySqlSchemaManager($conn); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										155
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/AbstractOracleDriver.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										155
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/AbstractOracleDriver.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,155 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Driver; | ||||
|  | ||||
| use Doctrine\DBAL\Driver; | ||||
| use Doctrine\DBAL\Exception; | ||||
| use Doctrine\DBAL\Platforms\OraclePlatform; | ||||
| use Doctrine\DBAL\Schema\OracleSchemaManager; | ||||
|  | ||||
| /** | ||||
|  * Abstract base implementation of the {@link Doctrine\DBAL\Driver} interface for Oracle based drivers. | ||||
|  * | ||||
|  * @author Steve Müller <st.mueller@dzh-online.de> | ||||
|  * @link   www.doctrine-project.org | ||||
|  * @since  2.5 | ||||
|  */ | ||||
| abstract class AbstractOracleDriver implements Driver, ExceptionConverterDriver | ||||
| { | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function convertException($message, DriverException $exception) | ||||
|     { | ||||
|         switch ($exception->getErrorCode()) { | ||||
|             case '1': | ||||
|             case '2299': | ||||
|             case '38911': | ||||
|                 return new Exception\UniqueConstraintViolationException($message, $exception); | ||||
|  | ||||
|             case '904': | ||||
|                 return new Exception\InvalidFieldNameException($message, $exception); | ||||
|  | ||||
|             case '918': | ||||
|             case '960': | ||||
|                 return new Exception\NonUniqueFieldNameException($message, $exception); | ||||
|  | ||||
|             case '923': | ||||
|                 return new Exception\SyntaxErrorException($message, $exception); | ||||
|  | ||||
|             case '942': | ||||
|                 return new Exception\TableNotFoundException($message, $exception); | ||||
|  | ||||
|             case '955': | ||||
|                 return new Exception\TableExistsException($message, $exception); | ||||
|  | ||||
|             case '1017': | ||||
|             case '12545': | ||||
|                 return new Exception\ConnectionException($message, $exception); | ||||
|  | ||||
|             case '1400': | ||||
|                 return new Exception\NotNullConstraintViolationException($message, $exception); | ||||
|  | ||||
|             case '2266': | ||||
|             case '2291': | ||||
|             case '2292': | ||||
|                 return new Exception\ForeignKeyConstraintViolationException($message, $exception); | ||||
|         } | ||||
|  | ||||
|         return new Exception\DriverException($message, $exception); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function getDatabase(\Doctrine\DBAL\Connection $conn) | ||||
|     { | ||||
|         $params = $conn->getParams(); | ||||
|  | ||||
|         return $params['user']; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function getDatabasePlatform() | ||||
|     { | ||||
|         return new OraclePlatform(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function getSchemaManager(\Doctrine\DBAL\Connection $conn) | ||||
|     { | ||||
|         return new OracleSchemaManager($conn); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Returns an appropriate Easy Connect String for the given parameters. | ||||
|      * | ||||
|      * @param array $params The connection parameters to return the Easy Connect STring for. | ||||
|      * | ||||
|      * @return string | ||||
|      * | ||||
|      * @link https://docs.oracle.com/database/121/NETAG/naming.htm | ||||
|      */ | ||||
|     protected function getEasyConnectString(array $params) | ||||
|     { | ||||
|         if ( ! empty($params['connectstring'])) { | ||||
|             return $params['connectstring']; | ||||
|         } | ||||
|  | ||||
|         if ( ! empty($params['host'])) { | ||||
|             if ( ! isset($params['port'])) { | ||||
|                 $params['port'] = 1521; | ||||
|             } | ||||
|  | ||||
|             $serviceName = $params['dbname']; | ||||
|  | ||||
|             if ( ! empty($params['servicename'])) { | ||||
|                 $serviceName = $params['servicename']; | ||||
|             } | ||||
|  | ||||
|             $service = 'SID=' . $serviceName; | ||||
|             $pooled  = ''; | ||||
|             $instance = ''; | ||||
|  | ||||
|             if (isset($params['service']) && $params['service'] == true) { | ||||
|                 $service = 'SERVICE_NAME=' . $serviceName; | ||||
|             } | ||||
|  | ||||
|             if (isset($params['instancename']) && ! empty($params['instancename'])) { | ||||
|                 $instance = '(INSTANCE_NAME = ' . $params['instancename'] . ')'; | ||||
|             } | ||||
|  | ||||
|             if (isset($params['pooled']) && $params['pooled'] == true) { | ||||
|                 $pooled = '(SERVER=POOLED)'; | ||||
|             } | ||||
|  | ||||
|             return '(DESCRIPTION=' . | ||||
|                      '(ADDRESS=(PROTOCOL=TCP)(HOST=' . $params['host'] . ')(PORT=' . $params['port'] . '))' . | ||||
|                      '(CONNECT_DATA=(' . $service . ')' . $instance . $pooled . '))'; | ||||
|  | ||||
|         } | ||||
|  | ||||
|         return $params['dbname'] ?? ''; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										158
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/AbstractPostgreSQLDriver.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										158
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/AbstractPostgreSQLDriver.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,158 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Driver; | ||||
|  | ||||
| use Doctrine\DBAL\DBALException; | ||||
| use Doctrine\DBAL\Driver; | ||||
| use Doctrine\DBAL\Exception; | ||||
| use Doctrine\DBAL\Platforms\PostgreSQL100Platform; | ||||
| use Doctrine\DBAL\Platforms\PostgreSQL91Platform; | ||||
| use Doctrine\DBAL\Platforms\PostgreSQL92Platform; | ||||
| use Doctrine\DBAL\Platforms\PostgreSQL94Platform; | ||||
| use Doctrine\DBAL\Platforms\PostgreSqlPlatform; | ||||
| use Doctrine\DBAL\Schema\PostgreSqlSchemaManager; | ||||
| use Doctrine\DBAL\VersionAwarePlatformDriver; | ||||
| use function preg_match; | ||||
| use function strpos; | ||||
| use function version_compare; | ||||
|  | ||||
| /** | ||||
|  * Abstract base implementation of the {@link Doctrine\DBAL\Driver} interface for PostgreSQL based drivers. | ||||
|  * | ||||
|  * @author Steve Müller <st.mueller@dzh-online.de> | ||||
|  * @link   www.doctrine-project.org | ||||
|  * @since  2.5 | ||||
|  */ | ||||
| abstract class AbstractPostgreSQLDriver implements Driver, ExceptionConverterDriver, VersionAwarePlatformDriver | ||||
| { | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      * | ||||
|      * @link http://www.postgresql.org/docs/9.3/static/errcodes-appendix.html | ||||
|      */ | ||||
|     public function convertException($message, DriverException $exception) | ||||
|     { | ||||
|         switch ($exception->getSQLState()) { | ||||
|             case '40001': | ||||
|             case '40P01': | ||||
|                 return new Exception\DeadlockException($message, $exception); | ||||
|             case '0A000': | ||||
|                 // Foreign key constraint violations during a TRUNCATE operation | ||||
|                 // are considered "feature not supported" in PostgreSQL. | ||||
|                 if (strpos($exception->getMessage(), 'truncate') !== false) { | ||||
|                     return new Exception\ForeignKeyConstraintViolationException($message, $exception); | ||||
|                 } | ||||
|  | ||||
|                 break; | ||||
|             case '23502': | ||||
|                 return new Exception\NotNullConstraintViolationException($message, $exception); | ||||
|  | ||||
|             case '23503': | ||||
|                 return new Exception\ForeignKeyConstraintViolationException($message, $exception); | ||||
|  | ||||
|             case '23505': | ||||
|                 return new Exception\UniqueConstraintViolationException($message, $exception); | ||||
|  | ||||
|             case '42601': | ||||
|                 return new Exception\SyntaxErrorException($message, $exception); | ||||
|  | ||||
|             case '42702': | ||||
|                 return new Exception\NonUniqueFieldNameException($message, $exception); | ||||
|  | ||||
|             case '42703': | ||||
|                 return new Exception\InvalidFieldNameException($message, $exception); | ||||
|  | ||||
|             case '42P01': | ||||
|                 return new Exception\TableNotFoundException($message, $exception); | ||||
|  | ||||
|             case '42P07': | ||||
|                 return new Exception\TableExistsException($message, $exception); | ||||
|  | ||||
|             case '7': | ||||
|                 // In some case (mainly connection errors) the PDO exception does not provide a SQLSTATE via its code. | ||||
|                 // The exception code is always set to 7 here. | ||||
|                 // We have to match against the SQLSTATE in the error message in these cases. | ||||
|                 if (strpos($exception->getMessage(), 'SQLSTATE[08006]') !== false) { | ||||
|                     return new Exception\ConnectionException($message, $exception); | ||||
|                 } | ||||
|  | ||||
|                 break; | ||||
|         } | ||||
|  | ||||
|         return new Exception\DriverException($message, $exception); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function createDatabasePlatformForVersion($version) | ||||
|     { | ||||
|         if ( ! preg_match('/^(?P<major>\d+)(?:\.(?P<minor>\d+)(?:\.(?P<patch>\d+))?)?/', $version, $versionParts)) { | ||||
|             throw DBALException::invalidPlatformVersionSpecified( | ||||
|                 $version, | ||||
|                 '<major_version>.<minor_version>.<patch_version>' | ||||
|             ); | ||||
|         } | ||||
|  | ||||
|         $majorVersion = $versionParts['major']; | ||||
|         $minorVersion = $versionParts['minor'] ?? 0; | ||||
|         $patchVersion = $versionParts['patch'] ?? 0; | ||||
|         $version      = $majorVersion . '.' . $minorVersion . '.' . $patchVersion; | ||||
|  | ||||
|         switch(true) { | ||||
|             case version_compare($version, '10.0', '>='): | ||||
|                 return new PostgreSQL100Platform(); | ||||
|             case version_compare($version, '9.4', '>='): | ||||
|                 return new PostgreSQL94Platform(); | ||||
|             case version_compare($version, '9.2', '>='): | ||||
|                 return new PostgreSQL92Platform(); | ||||
|             case version_compare($version, '9.1', '>='): | ||||
|                 return new PostgreSQL91Platform(); | ||||
|             default: | ||||
|                 return new PostgreSqlPlatform(); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function getDatabase(\Doctrine\DBAL\Connection $conn) | ||||
|     { | ||||
|         $params = $conn->getParams(); | ||||
|  | ||||
|         return $params['dbname'] ?? $conn->query('SELECT CURRENT_DATABASE()')->fetchColumn(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function getDatabasePlatform() | ||||
|     { | ||||
|         return new PostgreSqlPlatform(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function getSchemaManager(\Doctrine\DBAL\Connection $conn) | ||||
|     { | ||||
|         return new PostgreSqlSchemaManager($conn); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										147
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/AbstractSQLAnywhereDriver.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										147
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/AbstractSQLAnywhereDriver.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,147 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Driver; | ||||
|  | ||||
| use Doctrine\DBAL\DBALException; | ||||
| use Doctrine\DBAL\Driver; | ||||
| use Doctrine\DBAL\Exception; | ||||
| use Doctrine\DBAL\Platforms\SQLAnywhere11Platform; | ||||
| use Doctrine\DBAL\Platforms\SQLAnywhere12Platform; | ||||
| use Doctrine\DBAL\Platforms\SQLAnywhere16Platform; | ||||
| use Doctrine\DBAL\Platforms\SQLAnywherePlatform; | ||||
| use Doctrine\DBAL\Schema\SQLAnywhereSchemaManager; | ||||
| use Doctrine\DBAL\VersionAwarePlatformDriver; | ||||
| use function preg_match; | ||||
| use function version_compare; | ||||
|  | ||||
| /** | ||||
|  * Abstract base implementation of the {@link Doctrine\DBAL\Driver} interface for SAP Sybase SQL Anywhere based drivers. | ||||
|  * | ||||
|  * @author Steve Müller <st.mueller@dzh-online.de> | ||||
|  * @link   www.doctrine-project.org | ||||
|  * @since  2.5 | ||||
|  */ | ||||
| abstract class AbstractSQLAnywhereDriver implements Driver, ExceptionConverterDriver, VersionAwarePlatformDriver | ||||
| { | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      * | ||||
|      * @link http://dcx.sybase.com/index.html#sa160/en/saerrors/sqlerror.html | ||||
|      */ | ||||
|     public function convertException($message, DriverException $exception) | ||||
|     { | ||||
|         switch ($exception->getErrorCode()) { | ||||
|             case '-306': | ||||
|             case '-307': | ||||
|             case '-684': | ||||
|                 return new Exception\DeadlockException($message, $exception); | ||||
|             case '-210': | ||||
|             case '-1175': | ||||
|             case '-1281': | ||||
|                 return new Exception\LockWaitTimeoutException($message, $exception); | ||||
|             case '-100': | ||||
|             case '-103': | ||||
|             case '-832': | ||||
|                 return new Exception\ConnectionException($message, $exception); | ||||
|             case '-143': | ||||
|                 return new Exception\InvalidFieldNameException($message, $exception); | ||||
|             case '-193': | ||||
|             case '-196': | ||||
|                 return new Exception\UniqueConstraintViolationException($message, $exception); | ||||
|             case '-194': | ||||
|             case '-198': | ||||
|                 return new Exception\ForeignKeyConstraintViolationException($message, $exception); | ||||
|             case '-144': | ||||
|                 return new Exception\NonUniqueFieldNameException($message, $exception); | ||||
|             case '-184': | ||||
|             case '-195': | ||||
|                 return new Exception\NotNullConstraintViolationException($message, $exception); | ||||
|             case '-131': | ||||
|                 return new Exception\SyntaxErrorException($message, $exception); | ||||
|             case '-110': | ||||
|                 return new Exception\TableExistsException($message, $exception); | ||||
|             case '-141': | ||||
|             case '-1041': | ||||
|                 return new Exception\TableNotFoundException($message, $exception); | ||||
|         } | ||||
|  | ||||
|         return new Exception\DriverException($message, $exception); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function createDatabasePlatformForVersion($version) | ||||
|     { | ||||
|         if ( ! preg_match( | ||||
|             '/^(?P<major>\d+)(?:\.(?P<minor>\d+)(?:\.(?P<patch>\d+)(?:\.(?P<build>\d+))?)?)?/', | ||||
|             $version, | ||||
|             $versionParts | ||||
|         )) { | ||||
|             throw DBALException::invalidPlatformVersionSpecified( | ||||
|                 $version, | ||||
|                 '<major_version>.<minor_version>.<patch_version>.<build_version>' | ||||
|             ); | ||||
|         } | ||||
|  | ||||
|         $majorVersion = $versionParts['major']; | ||||
|         $minorVersion = $versionParts['minor'] ?? 0; | ||||
|         $patchVersion = $versionParts['patch'] ?? 0; | ||||
|         $buildVersion = $versionParts['build'] ?? 0; | ||||
|         $version      = $majorVersion . '.' . $minorVersion . '.' . $patchVersion . '.' . $buildVersion; | ||||
|  | ||||
|         switch(true) { | ||||
|             case version_compare($version, '16', '>='): | ||||
|                 return new SQLAnywhere16Platform(); | ||||
|             case version_compare($version, '12', '>='): | ||||
|                 return new SQLAnywhere12Platform(); | ||||
|             case version_compare($version, '11', '>='): | ||||
|                 return new SQLAnywhere11Platform(); | ||||
|             default: | ||||
|                 return new SQLAnywherePlatform(); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function getDatabase(\Doctrine\DBAL\Connection $conn) | ||||
|     { | ||||
|         $params = $conn->getParams(); | ||||
|  | ||||
|         return $params['dbname'] ?? $conn->query('SELECT DB_NAME()')->fetchColumn(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function getDatabasePlatform() | ||||
|     { | ||||
|         return new SQLAnywhere12Platform(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function getSchemaManager(\Doctrine\DBAL\Connection $conn) | ||||
|     { | ||||
|         return new SQLAnywhereSchemaManager($conn); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										102
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/AbstractSQLServerDriver.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										102
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/AbstractSQLServerDriver.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,102 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Driver; | ||||
|  | ||||
| use Doctrine\DBAL\DBALException; | ||||
| use Doctrine\DBAL\Driver; | ||||
| use Doctrine\DBAL\Platforms\SQLServer2005Platform; | ||||
| use Doctrine\DBAL\Platforms\SQLServer2008Platform; | ||||
| use Doctrine\DBAL\Platforms\SQLServer2012Platform; | ||||
| use Doctrine\DBAL\Platforms\SQLServerPlatform; | ||||
| use Doctrine\DBAL\Schema\SQLServerSchemaManager; | ||||
| use Doctrine\DBAL\VersionAwarePlatformDriver; | ||||
| use function preg_match; | ||||
| use function version_compare; | ||||
|  | ||||
| /** | ||||
|  * Abstract base implementation of the {@link Doctrine\DBAL\Driver} interface for Microsoft SQL Server based drivers. | ||||
|  * | ||||
|  * @author Steve Müller <st.mueller@dzh-online.de> | ||||
|  * @link   www.doctrine-project.org | ||||
|  * @since  2.5 | ||||
|  */ | ||||
| abstract class AbstractSQLServerDriver implements Driver, VersionAwarePlatformDriver | ||||
| { | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function createDatabasePlatformForVersion($version) | ||||
|     { | ||||
|         if ( ! preg_match( | ||||
|             '/^(?P<major>\d+)(?:\.(?P<minor>\d+)(?:\.(?P<patch>\d+)(?:\.(?P<build>\d+))?)?)?/', | ||||
|             $version, | ||||
|             $versionParts | ||||
|         )) { | ||||
|             throw DBALException::invalidPlatformVersionSpecified( | ||||
|                 $version, | ||||
|                 '<major_version>.<minor_version>.<patch_version>.<build_version>' | ||||
|             ); | ||||
|         } | ||||
|  | ||||
|         $majorVersion = $versionParts['major']; | ||||
|         $minorVersion = $versionParts['minor'] ?? 0; | ||||
|         $patchVersion = $versionParts['patch'] ?? 0; | ||||
|         $buildVersion = $versionParts['build'] ?? 0; | ||||
|         $version      = $majorVersion . '.' . $minorVersion . '.' . $patchVersion . '.' . $buildVersion; | ||||
|  | ||||
|         switch(true) { | ||||
|             case version_compare($version, '11.00.2100', '>='): | ||||
|                 return new SQLServer2012Platform(); | ||||
|             case version_compare($version, '10.00.1600', '>='): | ||||
|                 return new SQLServer2008Platform(); | ||||
|             case version_compare($version, '9.00.1399', '>='): | ||||
|                 return new SQLServer2005Platform(); | ||||
|             default: | ||||
|                 return new SQLServerPlatform(); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function getDatabase(\Doctrine\DBAL\Connection $conn) | ||||
|     { | ||||
|         $params = $conn->getParams(); | ||||
|  | ||||
|         return $params['dbname'] ?? $conn->query('SELECT DB_NAME()')->fetchColumn(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function getDatabasePlatform() | ||||
|     { | ||||
|         return new SQLServer2008Platform(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|  | ||||
|     public function getSchemaManager(\Doctrine\DBAL\Connection $conn) | ||||
|     { | ||||
|         return new SQLServerSchemaManager($conn); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										118
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/AbstractSQLiteDriver.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										118
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/AbstractSQLiteDriver.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,118 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Driver; | ||||
|  | ||||
| use Doctrine\DBAL\Driver; | ||||
| use Doctrine\DBAL\Exception; | ||||
| use Doctrine\DBAL\Platforms\SqlitePlatform; | ||||
| use Doctrine\DBAL\Schema\SqliteSchemaManager; | ||||
| use function strpos; | ||||
|  | ||||
| /** | ||||
|  * Abstract base implementation of the {@link Doctrine\DBAL\Driver} interface for SQLite based drivers. | ||||
|  * | ||||
|  * @author Steve Müller <st.mueller@dzh-online.de> | ||||
|  * @link   www.doctrine-project.org | ||||
|  * @since  2.5 | ||||
|  */ | ||||
| abstract class AbstractSQLiteDriver implements Driver, ExceptionConverterDriver | ||||
| { | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      * | ||||
|      * @link http://www.sqlite.org/c3ref/c_abort.html | ||||
|      */ | ||||
|     public function convertException($message, DriverException $exception) | ||||
|     { | ||||
|         if (strpos($exception->getMessage(), 'database is locked') !== false) { | ||||
|             return new Exception\LockWaitTimeoutException($message, $exception); | ||||
|         } | ||||
|  | ||||
|         if (strpos($exception->getMessage(), 'must be unique') !== false || | ||||
|             strpos($exception->getMessage(), 'is not unique') !== false || | ||||
|             strpos($exception->getMessage(), 'are not unique') !== false || | ||||
|             strpos($exception->getMessage(), 'UNIQUE constraint failed') !== false | ||||
|         ) { | ||||
|             return new Exception\UniqueConstraintViolationException($message, $exception); | ||||
|         } | ||||
|  | ||||
|         if (strpos($exception->getMessage(), 'may not be NULL') !== false || | ||||
|             strpos($exception->getMessage(), 'NOT NULL constraint failed') !== false | ||||
|         ) { | ||||
|             return new Exception\NotNullConstraintViolationException($message, $exception); | ||||
|         } | ||||
|  | ||||
|         if (strpos($exception->getMessage(), 'no such table:') !== false) { | ||||
|             return new Exception\TableNotFoundException($message, $exception); | ||||
|         } | ||||
|  | ||||
|         if (strpos($exception->getMessage(), 'already exists') !== false) { | ||||
|             return new Exception\TableExistsException($message, $exception); | ||||
|         } | ||||
|  | ||||
|         if (strpos($exception->getMessage(), 'has no column named') !== false) { | ||||
|             return new Exception\InvalidFieldNameException($message, $exception); | ||||
|         } | ||||
|  | ||||
|         if (strpos($exception->getMessage(), 'ambiguous column name') !== false) { | ||||
|             return new Exception\NonUniqueFieldNameException($message, $exception); | ||||
|         } | ||||
|  | ||||
|         if (strpos($exception->getMessage(), 'syntax error') !== false) { | ||||
|             return new Exception\SyntaxErrorException($message, $exception); | ||||
|         } | ||||
|  | ||||
|         if (strpos($exception->getMessage(), 'attempt to write a readonly database') !== false) { | ||||
|             return new Exception\ReadOnlyException($message, $exception); | ||||
|         } | ||||
|  | ||||
|         if (strpos($exception->getMessage(), 'unable to open database file') !== false) { | ||||
|             return new Exception\ConnectionException($message, $exception); | ||||
|         } | ||||
|  | ||||
|         return new Exception\DriverException($message, $exception); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function getDatabase(\Doctrine\DBAL\Connection $conn) | ||||
|     { | ||||
|         $params = $conn->getParams(); | ||||
|  | ||||
|         return $params['path'] ?? null; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function getDatabasePlatform() | ||||
|     { | ||||
|         return new SqlitePlatform(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function getSchemaManager(\Doctrine\DBAL\Connection $conn) | ||||
|     { | ||||
|         return new SqliteSchemaManager($conn); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										112
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/Connection.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										112
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/Connection.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,112 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Driver; | ||||
|  | ||||
| use Doctrine\DBAL\ParameterType; | ||||
|  | ||||
| /** | ||||
|  * Connection interface. | ||||
|  * Driver connections must implement this interface. | ||||
|  * | ||||
|  * This resembles (a subset of) the PDO interface. | ||||
|  * | ||||
|  * @since 2.0 | ||||
|  */ | ||||
| interface Connection | ||||
| { | ||||
|     /** | ||||
|      * Prepares a statement for execution and returns a Statement object. | ||||
|      * | ||||
|      * @param string $prepareString | ||||
|      * | ||||
|      * @return Statement | ||||
|      */ | ||||
|     public function prepare($prepareString); | ||||
|  | ||||
|     /** | ||||
|      * Executes an SQL statement, returning a result set as a Statement object. | ||||
|      * | ||||
|      * @return \Doctrine\DBAL\Driver\Statement | ||||
|      */ | ||||
|     public function query(); | ||||
|  | ||||
|     /** | ||||
|      * Quotes a string for use in a query. | ||||
|      * | ||||
|      * @param mixed $input | ||||
|      * @param int   $type | ||||
|      * | ||||
|      * @return mixed | ||||
|      */ | ||||
|     public function quote($input, $type = ParameterType::STRING); | ||||
|  | ||||
|     /** | ||||
|      * Executes an SQL statement and return the number of affected rows. | ||||
|      * | ||||
|      * @param string $statement | ||||
|      * | ||||
|      * @return int | ||||
|      */ | ||||
|     public function exec($statement); | ||||
|  | ||||
|     /** | ||||
|      * Returns the ID of the last inserted row or sequence value. | ||||
|      * | ||||
|      * @param string|null $name | ||||
|      * | ||||
|      * @return string | ||||
|      */ | ||||
|     public function lastInsertId($name = null); | ||||
|  | ||||
|     /** | ||||
|      * Initiates a transaction. | ||||
|      * | ||||
|      * @return bool TRUE on success or FALSE on failure. | ||||
|      */ | ||||
|     public function beginTransaction(); | ||||
|  | ||||
|     /** | ||||
|      * Commits a transaction. | ||||
|      * | ||||
|      * @return bool TRUE on success or FALSE on failure. | ||||
|      */ | ||||
|     public function commit(); | ||||
|  | ||||
|     /** | ||||
|      * Rolls back the current transaction, as initiated by beginTransaction(). | ||||
|      * | ||||
|      * @return bool TRUE on success or FALSE on failure. | ||||
|      */ | ||||
|     public function rollBack(); | ||||
|  | ||||
|     /** | ||||
|      * Returns the error code associated with the last operation on the database handle. | ||||
|      * | ||||
|      * @return string|null The error code, or null if no operation has been run on the database handle. | ||||
|      */ | ||||
|     public function errorCode(); | ||||
|  | ||||
|     /** | ||||
|      * Returns extended error information associated with the last operation on the database handle. | ||||
|      * | ||||
|      * @return array | ||||
|      */ | ||||
|     public function errorInfo(); | ||||
| } | ||||
							
								
								
									
										59
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/DriverException.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										59
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/DriverException.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,59 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Driver; | ||||
|  | ||||
| /** | ||||
|  * Contract for a driver exception. | ||||
|  * | ||||
|  * Driver exceptions provide the SQLSTATE of the driver | ||||
|  * and the driver specific error code at the time the error occurred. | ||||
|  * | ||||
|  * @author Steve Müller <st.mueller@dzh-online.de> | ||||
|  * @link   www.doctrine-project.org | ||||
|  * @since  2.5 | ||||
|  */ | ||||
| interface DriverException extends \Throwable | ||||
| { | ||||
|     /** | ||||
|      * Returns the driver specific error code if available. | ||||
|      * | ||||
|      * Returns null if no driver specific error code is available | ||||
|      * for the error raised by the driver. | ||||
|      * | ||||
|      * @return int|string|null | ||||
|      */ | ||||
|     public function getErrorCode(); | ||||
|  | ||||
|     /** | ||||
|      * Returns the driver error message. | ||||
|      * | ||||
|      * @return string | ||||
|      */ | ||||
|     public function getMessage(); | ||||
|  | ||||
|     /** | ||||
|      * Returns the SQLSTATE the driver was in at the time the error occurred. | ||||
|      * | ||||
|      * Returns null if the driver does not provide a SQLSTATE for the error occurred. | ||||
|      * | ||||
|      * @return string|null | ||||
|      */ | ||||
|     public function getSQLState(); | ||||
| } | ||||
							
								
								
									
										40
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/DrizzlePDOMySql/Connection.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										40
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/DrizzlePDOMySql/Connection.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,40 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Driver\DrizzlePDOMySql; | ||||
|  | ||||
| use Doctrine\DBAL\ParameterType; | ||||
|  | ||||
| /** | ||||
|  * @author Kim Hemsø Rasmussen <kimhemsoe@gmail.com> | ||||
|  */ | ||||
| class Connection extends \Doctrine\DBAL\Driver\PDOConnection | ||||
| { | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function quote($value, $type = ParameterType::STRING) | ||||
|     { | ||||
|         if ($type === ParameterType::BOOLEAN) { | ||||
|             return $value ? 'true' : 'false'; | ||||
|         } | ||||
|  | ||||
|         return parent::quote($value, $type); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										78
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/DrizzlePDOMySql/Driver.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										78
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/DrizzlePDOMySql/Driver.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,78 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Driver\DrizzlePDOMySql; | ||||
|  | ||||
| use Doctrine\DBAL\Platforms\DrizzlePlatform; | ||||
| use Doctrine\DBAL\Schema\DrizzleSchemaManager; | ||||
|  | ||||
| /** | ||||
|  * Drizzle driver using PDO MySql. | ||||
|  * | ||||
|  * @author Kim Hemsø Rasmussen <kimhemsoe@gmail.com> | ||||
|  */ | ||||
| class Driver extends \Doctrine\DBAL\Driver\PDOMySql\Driver | ||||
| { | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function connect(array $params, $username = null, $password = null, array $driverOptions = []) | ||||
|     { | ||||
|         $conn = new Connection( | ||||
|             $this->constructPdoDsn($params), | ||||
|             $username, | ||||
|             $password, | ||||
|             $driverOptions | ||||
|         ); | ||||
|  | ||||
|         return $conn; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function createDatabasePlatformForVersion($version) | ||||
|     { | ||||
|         return $this->getDatabasePlatform(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function getDatabasePlatform() | ||||
|     { | ||||
|         return new DrizzlePlatform(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function getSchemaManager(\Doctrine\DBAL\Connection $conn) | ||||
|     { | ||||
|         return new DrizzleSchemaManager($conn); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function getName() | ||||
|     { | ||||
|         return 'drizzle_pdo_mysql'; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										44
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/ExceptionConverterDriver.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										44
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/ExceptionConverterDriver.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,44 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Driver; | ||||
|  | ||||
| /** | ||||
|  * Contract for a driver that is capable of converting DBAL driver exceptions into standardized DBAL driver exceptions. | ||||
|  * | ||||
|  * @author Benjamin Eberlei <kontakt@beberlei.de> | ||||
|  * @author Steve Müller <st.mueller@dzh-online.de> | ||||
|  * @link   www.doctrine-project.org | ||||
|  * @since  2.5 | ||||
|  */ | ||||
| interface ExceptionConverterDriver | ||||
| { | ||||
|     /** | ||||
|      * Converts a given DBAL driver exception into a standardized DBAL driver exception. | ||||
|      * | ||||
|      * It evaluates the vendor specific error code and SQLSTATE and transforms | ||||
|      * it into a unified {@link Doctrine\DBAL\Exception\DriverException} subclass. | ||||
|      * | ||||
|      * @param string                                $message   The DBAL exception message to use. | ||||
|      * @param \Doctrine\DBAL\Driver\DriverException $exception The DBAL driver exception to convert. | ||||
|      * | ||||
|      * @return \Doctrine\DBAL\Exception\DriverException An instance of one of the DriverException subclasses. | ||||
|      */ | ||||
|     public function convertException($message, DriverException $exception); | ||||
| } | ||||
							
								
								
									
										202
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/IBMDB2/DB2Connection.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										202
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/IBMDB2/DB2Connection.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,202 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Driver\IBMDB2; | ||||
|  | ||||
| use Doctrine\DBAL\Driver\Connection; | ||||
| use Doctrine\DBAL\Driver\ServerInfoAwareConnection; | ||||
| use Doctrine\DBAL\ParameterType; | ||||
| use stdClass; | ||||
| use const DB2_AUTOCOMMIT_OFF; | ||||
| use const DB2_AUTOCOMMIT_ON; | ||||
| use function db2_autocommit; | ||||
| use function db2_commit; | ||||
| use function db2_conn_error; | ||||
| use function db2_conn_errormsg; | ||||
| use function db2_connect; | ||||
| use function db2_escape_string; | ||||
| use function db2_exec; | ||||
| use function db2_last_insert_id; | ||||
| use function db2_num_rows; | ||||
| use function db2_pconnect; | ||||
| use function db2_prepare; | ||||
| use function db2_rollback; | ||||
| use function db2_server_info; | ||||
| use function db2_stmt_errormsg; | ||||
| use function func_get_args; | ||||
|  | ||||
| class DB2Connection implements Connection, ServerInfoAwareConnection | ||||
| { | ||||
|     /** | ||||
|      * @var resource | ||||
|      */ | ||||
|     private $_conn = null; | ||||
|  | ||||
|     /** | ||||
|      * @param array  $params | ||||
|      * @param string $username | ||||
|      * @param string $password | ||||
|      * @param array  $driverOptions | ||||
|      * | ||||
|      * @throws \Doctrine\DBAL\Driver\IBMDB2\DB2Exception | ||||
|      */ | ||||
|     public function __construct(array $params, $username, $password, $driverOptions = []) | ||||
|     { | ||||
|         $isPersistent = (isset($params['persistent']) && $params['persistent'] == true); | ||||
|  | ||||
|         if ($isPersistent) { | ||||
|             $this->_conn = db2_pconnect($params['dbname'], $username, $password, $driverOptions); | ||||
|         } else { | ||||
|             $this->_conn = db2_connect($params['dbname'], $username, $password, $driverOptions); | ||||
|         } | ||||
|         if ( ! $this->_conn) { | ||||
|             throw new DB2Exception(db2_conn_errormsg()); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function getServerVersion() | ||||
|     { | ||||
|         /** @var stdClass $serverInfo */ | ||||
|         $serverInfo = db2_server_info($this->_conn); | ||||
|  | ||||
|         return $serverInfo->DBMS_VER; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function requiresQueryForServerVersion() | ||||
|     { | ||||
|         return false; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function prepare($sql) | ||||
|     { | ||||
|         $stmt = @db2_prepare($this->_conn, $sql); | ||||
|         if ( ! $stmt) { | ||||
|             throw new DB2Exception(db2_stmt_errormsg()); | ||||
|         } | ||||
|  | ||||
|         return new DB2Statement($stmt); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function query() | ||||
|     { | ||||
|         $args = func_get_args(); | ||||
|         $sql = $args[0]; | ||||
|         $stmt = $this->prepare($sql); | ||||
|         $stmt->execute(); | ||||
|  | ||||
|         return $stmt; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function quote($input, $type = ParameterType::STRING) | ||||
|     { | ||||
|         $input = db2_escape_string($input); | ||||
|  | ||||
|         if ($type === ParameterType::INTEGER) { | ||||
|             return $input; | ||||
|         } | ||||
|  | ||||
|         return "'".$input."'"; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function exec($statement) | ||||
|     { | ||||
|         $stmt = @db2_exec($this->_conn, $statement); | ||||
|  | ||||
|         if (false === $stmt) { | ||||
|             throw new DB2Exception(db2_stmt_errormsg()); | ||||
|         } | ||||
|  | ||||
|         return db2_num_rows($stmt); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function lastInsertId($name = null) | ||||
|     { | ||||
|         return db2_last_insert_id($this->_conn); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function beginTransaction() | ||||
|     { | ||||
|         db2_autocommit($this->_conn, DB2_AUTOCOMMIT_OFF); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function commit() | ||||
|     { | ||||
|         if (!db2_commit($this->_conn)) { | ||||
|             throw new DB2Exception(db2_conn_errormsg($this->_conn)); | ||||
|         } | ||||
|         db2_autocommit($this->_conn, DB2_AUTOCOMMIT_ON); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function rollBack() | ||||
|     { | ||||
|         if (!db2_rollback($this->_conn)) { | ||||
|             throw new DB2Exception(db2_conn_errormsg($this->_conn)); | ||||
|         } | ||||
|         db2_autocommit($this->_conn, DB2_AUTOCOMMIT_ON); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function errorCode() | ||||
|     { | ||||
|         return db2_conn_error($this->_conn); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function errorInfo() | ||||
|     { | ||||
|         return [ | ||||
|             0 => db2_conn_errormsg($this->_conn), | ||||
|             1 => $this->errorCode(), | ||||
|         ]; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										67
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/IBMDB2/DB2Driver.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										67
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/IBMDB2/DB2Driver.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,67 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Driver\IBMDB2; | ||||
|  | ||||
| use Doctrine\DBAL\Driver\AbstractDB2Driver; | ||||
|  | ||||
| /** | ||||
|  * IBM DB2 Driver. | ||||
|  * | ||||
|  * @since 2.0 | ||||
|  * @author Benjamin Eberlei <kontakt@beberlei.de> | ||||
|  */ | ||||
| class DB2Driver extends AbstractDB2Driver | ||||
| { | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function connect(array $params, $username = null, $password = null, array $driverOptions = []) | ||||
|     { | ||||
|         if ( ! isset($params['protocol'])) { | ||||
|             $params['protocol'] = 'TCPIP'; | ||||
|         } | ||||
|  | ||||
|         if ($params['host'] !== 'localhost' && $params['host'] != '127.0.0.1') { | ||||
|             // if the host isn't localhost, use extended connection params | ||||
|             $params['dbname'] = 'DRIVER={IBM DB2 ODBC DRIVER}' . | ||||
|                      ';DATABASE=' . $params['dbname'] . | ||||
|                      ';HOSTNAME=' . $params['host'] . | ||||
|                      ';PROTOCOL=' . $params['protocol'] . | ||||
|                      ';UID='      . $username . | ||||
|                      ';PWD='      . $password .';'; | ||||
|             if (isset($params['port'])) { | ||||
|                 $params['dbname'] .= 'PORT=' . $params['port']; | ||||
|             } | ||||
|  | ||||
|             $username = null; | ||||
|             $password = null; | ||||
|         } | ||||
|  | ||||
|         return new DB2Connection($params, $username, $password, $driverOptions); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function getName() | ||||
|     { | ||||
|         return 'ibm_db2'; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										24
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/IBMDB2/DB2Exception.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										24
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/IBMDB2/DB2Exception.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,24 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Driver\IBMDB2; | ||||
|  | ||||
| class DB2Exception extends \Exception | ||||
| { | ||||
| } | ||||
							
								
								
									
										395
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/IBMDB2/DB2Statement.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										395
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/IBMDB2/DB2Statement.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,395 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Driver\IBMDB2; | ||||
|  | ||||
| use Doctrine\DBAL\Driver\Statement; | ||||
| use Doctrine\DBAL\Driver\StatementIterator; | ||||
| use Doctrine\DBAL\FetchMode; | ||||
| use Doctrine\DBAL\ParameterType; | ||||
| use const DB2_CHAR; | ||||
| use const DB2_LONG; | ||||
| use const DB2_PARAM_IN; | ||||
| use function array_change_key_case; | ||||
| use function call_user_func_array; | ||||
| use function db2_bind_param; | ||||
| use function db2_execute; | ||||
| use function db2_fetch_array; | ||||
| use function db2_fetch_assoc; | ||||
| use function db2_fetch_both; | ||||
| use function db2_fetch_object; | ||||
| use function db2_free_result; | ||||
| use function db2_num_fields; | ||||
| use function db2_num_rows; | ||||
| use function db2_stmt_error; | ||||
| use function db2_stmt_errormsg; | ||||
| use function func_get_args; | ||||
| use function func_num_args; | ||||
| use function gettype; | ||||
| use function is_object; | ||||
| use function is_string; | ||||
| use function ksort; | ||||
| use function sprintf; | ||||
| use function strtolower; | ||||
|  | ||||
| class DB2Statement implements \IteratorAggregate, Statement | ||||
| { | ||||
|     /** | ||||
|      * @var resource | ||||
|      */ | ||||
|     private $_stmt; | ||||
|  | ||||
|     /** | ||||
|      * @var array | ||||
|      */ | ||||
|     private $_bindParam = []; | ||||
|  | ||||
|     /** | ||||
|      * @var string Name of the default class to instantiate when fetching class instances. | ||||
|      */ | ||||
|     private $defaultFetchClass = '\stdClass'; | ||||
|  | ||||
|     /** | ||||
|      * @var mixed[] Constructor arguments for the default class to instantiate when fetching class instances. | ||||
|      */ | ||||
|     private $defaultFetchClassCtorArgs = []; | ||||
|  | ||||
|     /** | ||||
|      * @var int | ||||
|      */ | ||||
|     private $_defaultFetchMode = FetchMode::MIXED; | ||||
|  | ||||
|     /** | ||||
|      * Indicates whether the statement is in the state when fetching results is possible | ||||
|      * | ||||
|      * @var bool | ||||
|      */ | ||||
|     private $result = false; | ||||
|  | ||||
|     /** | ||||
|      * DB2_BINARY, DB2_CHAR, DB2_DOUBLE, or DB2_LONG | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     static private $_typeMap = [ | ||||
|         ParameterType::INTEGER => DB2_LONG, | ||||
|         ParameterType::STRING  => DB2_CHAR, | ||||
|     ]; | ||||
|  | ||||
|     /** | ||||
|      * @param resource $stmt | ||||
|      */ | ||||
|     public function __construct($stmt) | ||||
|     { | ||||
|         $this->_stmt = $stmt; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function bindValue($param, $value, $type = ParameterType::STRING) | ||||
|     { | ||||
|         return $this->bindParam($param, $value, $type); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function bindParam($column, &$variable, $type = ParameterType::STRING, $length = null) | ||||
|     { | ||||
|         $this->_bindParam[$column] =& $variable; | ||||
|  | ||||
|         if ($type && isset(self::$_typeMap[$type])) { | ||||
|             $type = self::$_typeMap[$type]; | ||||
|         } else { | ||||
|             $type = DB2_CHAR; | ||||
|         } | ||||
|  | ||||
|         if (!db2_bind_param($this->_stmt, $column, "variable", DB2_PARAM_IN, $type)) { | ||||
|             throw new DB2Exception(db2_stmt_errormsg()); | ||||
|         } | ||||
|  | ||||
|         return true; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function closeCursor() | ||||
|     { | ||||
|         if ( ! $this->_stmt) { | ||||
|             return false; | ||||
|         } | ||||
|  | ||||
|         $this->_bindParam = []; | ||||
|  | ||||
|         if (!db2_free_result($this->_stmt)) { | ||||
|             return false; | ||||
|         } | ||||
|  | ||||
|         $this->result = false; | ||||
|  | ||||
|         return true; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function columnCount() | ||||
|     { | ||||
|         if ( ! $this->_stmt) { | ||||
|             return false; | ||||
|         } | ||||
|  | ||||
|         return db2_num_fields($this->_stmt); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function errorCode() | ||||
|     { | ||||
|         return db2_stmt_error(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function errorInfo() | ||||
|     { | ||||
|         return [ | ||||
|             db2_stmt_errormsg(), | ||||
|             db2_stmt_error(), | ||||
|         ]; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function execute($params = null) | ||||
|     { | ||||
|         if ( ! $this->_stmt) { | ||||
|             return false; | ||||
|         } | ||||
|  | ||||
|         if ($params === null) { | ||||
|             ksort($this->_bindParam); | ||||
|  | ||||
|             $params = []; | ||||
|  | ||||
|             foreach ($this->_bindParam as $column => $value) { | ||||
|                 $params[] = $value; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         $retval = db2_execute($this->_stmt, $params); | ||||
|  | ||||
|         if ($retval === false) { | ||||
|             throw new DB2Exception(db2_stmt_errormsg()); | ||||
|         } | ||||
|  | ||||
|         $this->result = true; | ||||
|  | ||||
|         return $retval; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function setFetchMode($fetchMode, $arg2 = null, $arg3 = null) | ||||
|     { | ||||
|         $this->_defaultFetchMode         = $fetchMode; | ||||
|         $this->defaultFetchClass         = $arg2 ?: $this->defaultFetchClass; | ||||
|         $this->defaultFetchClassCtorArgs = $arg3 ? (array) $arg3 : $this->defaultFetchClassCtorArgs; | ||||
|  | ||||
|         return true; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function getIterator() | ||||
|     { | ||||
|         return new StatementIterator($this); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function fetch($fetchMode = null, $cursorOrientation = \PDO::FETCH_ORI_NEXT, $cursorOffset = 0) | ||||
|     { | ||||
|         // do not try fetching from the statement if it's not expected to contain result | ||||
|         // in order to prevent exceptional situation | ||||
|         if (!$this->result) { | ||||
|             return false; | ||||
|         } | ||||
|  | ||||
|         $fetchMode = $fetchMode ?: $this->_defaultFetchMode; | ||||
|         switch ($fetchMode) { | ||||
|             case FetchMode::COLUMN: | ||||
|                 return $this->fetchColumn(); | ||||
|  | ||||
|             case FetchMode::MIXED: | ||||
|                 return db2_fetch_both($this->_stmt); | ||||
|  | ||||
|             case FetchMode::ASSOCIATIVE: | ||||
|                 return db2_fetch_assoc($this->_stmt); | ||||
|  | ||||
|             case FetchMode::CUSTOM_OBJECT: | ||||
|                 $className = $this->defaultFetchClass; | ||||
|                 $ctorArgs  = $this->defaultFetchClassCtorArgs; | ||||
|  | ||||
|                 if (func_num_args() >= 2) { | ||||
|                     $args      = func_get_args(); | ||||
|                     $className = $args[1]; | ||||
|                     $ctorArgs  = $args[2] ?? []; | ||||
|                 } | ||||
|  | ||||
|                 $result = db2_fetch_object($this->_stmt); | ||||
|  | ||||
|                 if ($result instanceof \stdClass) { | ||||
|                     $result = $this->castObject($result, $className, $ctorArgs); | ||||
|                 } | ||||
|  | ||||
|                 return $result; | ||||
|  | ||||
|             case FetchMode::NUMERIC: | ||||
|                 return db2_fetch_array($this->_stmt); | ||||
|  | ||||
|             case FetchMode::STANDARD_OBJECT: | ||||
|                 return db2_fetch_object($this->_stmt); | ||||
|  | ||||
|             default: | ||||
|                 throw new DB2Exception('Given Fetch-Style ' . $fetchMode . ' is not supported.'); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function fetchAll($fetchMode = null, $fetchArgument = null, $ctorArgs = null) | ||||
|     { | ||||
|         $rows = []; | ||||
|  | ||||
|         switch ($fetchMode) { | ||||
|             case FetchMode::CUSTOM_OBJECT: | ||||
|                 while (($row = $this->fetch(...func_get_args())) !== false) { | ||||
|                     $rows[] = $row; | ||||
|                 } | ||||
|                 break; | ||||
|             case FetchMode::COLUMN: | ||||
|                 while (($row = $this->fetchColumn()) !== false) { | ||||
|                     $rows[] = $row; | ||||
|                 } | ||||
|                 break; | ||||
|             default: | ||||
|                 while (($row = $this->fetch($fetchMode)) !== false) { | ||||
|                     $rows[] = $row; | ||||
|                 } | ||||
|         } | ||||
|  | ||||
|         return $rows; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function fetchColumn($columnIndex = 0) | ||||
|     { | ||||
|         $row = $this->fetch(FetchMode::NUMERIC); | ||||
|  | ||||
|         if (false === $row) { | ||||
|             return false; | ||||
|         } | ||||
|  | ||||
|         return $row[$columnIndex] ?? null; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function rowCount() | ||||
|     { | ||||
|         return (@db2_num_rows($this->_stmt)) ? : 0; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Casts a stdClass object to the given class name mapping its' properties. | ||||
|      * | ||||
|      * @param \stdClass     $sourceObject     Object to cast from. | ||||
|      * @param string|object $destinationClass Name of the class or class instance to cast to. | ||||
|      * @param array         $ctorArgs         Arguments to use for constructing the destination class instance. | ||||
|      * | ||||
|      * @return object | ||||
|      * | ||||
|      * @throws DB2Exception | ||||
|      */ | ||||
|     private function castObject(\stdClass $sourceObject, $destinationClass, array $ctorArgs = []) | ||||
|     { | ||||
|         if ( ! is_string($destinationClass)) { | ||||
|             if ( ! is_object($destinationClass)) { | ||||
|                 throw new DB2Exception(sprintf( | ||||
|                     'Destination class has to be of type string or object, %s given.', gettype($destinationClass) | ||||
|                 )); | ||||
|             } | ||||
|         } else { | ||||
|             $destinationClass = new \ReflectionClass($destinationClass); | ||||
|             $destinationClass = $destinationClass->newInstanceArgs($ctorArgs); | ||||
|         } | ||||
|  | ||||
|         $sourceReflection           = new \ReflectionObject($sourceObject); | ||||
|         $destinationClassReflection = new \ReflectionObject($destinationClass); | ||||
|         /** @var \ReflectionProperty[] $destinationProperties */ | ||||
|         $destinationProperties      = array_change_key_case($destinationClassReflection->getProperties(), \CASE_LOWER); | ||||
|  | ||||
|         foreach ($sourceReflection->getProperties() as $sourceProperty) { | ||||
|             $sourceProperty->setAccessible(true); | ||||
|  | ||||
|             $name  = $sourceProperty->getName(); | ||||
|             $value = $sourceProperty->getValue($sourceObject); | ||||
|  | ||||
|             // Try to find a case-matching property. | ||||
|             if ($destinationClassReflection->hasProperty($name)) { | ||||
|                 $destinationProperty = $destinationClassReflection->getProperty($name); | ||||
|  | ||||
|                 $destinationProperty->setAccessible(true); | ||||
|                 $destinationProperty->setValue($destinationClass, $value); | ||||
|  | ||||
|                 continue; | ||||
|             } | ||||
|  | ||||
|             $name = strtolower($name); | ||||
|  | ||||
|             // Try to find a property without matching case. | ||||
|             // Fallback for the driver returning either all uppercase or all lowercase column names. | ||||
|             if (isset($destinationProperties[$name])) { | ||||
|                 $destinationProperty = $destinationProperties[$name]; | ||||
|  | ||||
|                 $destinationProperty->setAccessible(true); | ||||
|                 $destinationProperty->setValue($destinationClass, $value); | ||||
|  | ||||
|                 continue; | ||||
|             } | ||||
|  | ||||
|             $destinationClass->$name = $value; | ||||
|         } | ||||
|  | ||||
|         return $destinationClass; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										49
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/Mysqli/Driver.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										49
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/Mysqli/Driver.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,49 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Driver\Mysqli; | ||||
|  | ||||
| use Doctrine\DBAL\Driver\AbstractMySQLDriver; | ||||
| use Doctrine\DBAL\DBALException; | ||||
|  | ||||
| /** | ||||
|  * @author Kim Hemsø Rasmussen <kimhemsoe@gmail.com> | ||||
|  */ | ||||
| class Driver extends AbstractMySQLDriver | ||||
| { | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function connect(array $params, $username = null, $password = null, array $driverOptions = []) | ||||
|     { | ||||
|         try { | ||||
|             return new MysqliConnection($params, $username, $password, $driverOptions); | ||||
|         } catch (MysqliException $e) { | ||||
|             throw DBALException::driverException($this, $e); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function getName() | ||||
|     { | ||||
|         return 'mysqli'; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										315
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/Mysqli/MysqliConnection.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										315
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/Mysqli/MysqliConnection.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,315 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Driver\Mysqli; | ||||
|  | ||||
| use Doctrine\DBAL\Driver\Connection; | ||||
| use Doctrine\DBAL\Driver\PingableConnection; | ||||
| use Doctrine\DBAL\Driver\ServerInfoAwareConnection; | ||||
| use Doctrine\DBAL\ParameterType; | ||||
| use function defined; | ||||
| use function floor; | ||||
| use function func_get_args; | ||||
| use function in_array; | ||||
| use function ini_get; | ||||
| use function mysqli_errno; | ||||
| use function mysqli_error; | ||||
| use function mysqli_init; | ||||
| use function mysqli_options; | ||||
| use function restore_error_handler; | ||||
| use function set_error_handler; | ||||
| use function sprintf; | ||||
| use function stripos; | ||||
|  | ||||
| /** | ||||
|  * @author Kim Hemsø Rasmussen <kimhemsoe@gmail.com> | ||||
|  * @author Till Klampaeckel <till@php.net> | ||||
|  */ | ||||
| class MysqliConnection implements Connection, PingableConnection, ServerInfoAwareConnection | ||||
| { | ||||
|     /** | ||||
|      * Name of the option to set connection flags | ||||
|      */ | ||||
|     const OPTION_FLAGS = 'flags'; | ||||
|  | ||||
|     /** | ||||
|      * @var \mysqli | ||||
|      */ | ||||
|     private $_conn; | ||||
|  | ||||
|     /** | ||||
|      * @param array  $params | ||||
|      * @param string $username | ||||
|      * @param string $password | ||||
|      * @param array  $driverOptions | ||||
|      * | ||||
|      * @throws \Doctrine\DBAL\Driver\Mysqli\MysqliException | ||||
|      */ | ||||
|     public function __construct(array $params, $username, $password, array $driverOptions = []) | ||||
|     { | ||||
|         $port = $params['port'] ?? ini_get('mysqli.default_port'); | ||||
|  | ||||
|         // Fallback to default MySQL port if not given. | ||||
|         if ( ! $port) { | ||||
|             $port = 3306; | ||||
|         } | ||||
|  | ||||
|         $socket = $params['unix_socket'] ?? ini_get('mysqli.default_socket'); | ||||
|         $dbname = $params['dbname'] ?? null; | ||||
|  | ||||
|         $flags = $driverOptions[static::OPTION_FLAGS] ?? null; | ||||
|  | ||||
|         $this->_conn = mysqli_init(); | ||||
|  | ||||
|         $this->setSecureConnection($params); | ||||
|         $this->setDriverOptions($driverOptions); | ||||
|  | ||||
|         set_error_handler(function () {}); | ||||
|         try { | ||||
|             if ( ! $this->_conn->real_connect($params['host'], $username, $password, $dbname, $port, $socket, $flags)) { | ||||
|                 throw new MysqliException($this->_conn->connect_error, $this->_conn->sqlstate ?? 'HY000', $this->_conn->connect_errno); | ||||
|             } | ||||
|         } finally { | ||||
|             restore_error_handler(); | ||||
|         } | ||||
|  | ||||
|         if (isset($params['charset'])) { | ||||
|             $this->_conn->set_charset($params['charset']); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Retrieves mysqli native resource handle. | ||||
|      * | ||||
|      * Could be used if part of your application is not using DBAL. | ||||
|      * | ||||
|      * @return \mysqli | ||||
|      */ | ||||
|     public function getWrappedResourceHandle() | ||||
|     { | ||||
|         return $this->_conn; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      * | ||||
|      * The server version detection includes a special case for MariaDB | ||||
|      * to support '5.5.5-' prefixed versions introduced in Maria 10+ | ||||
|      * @link https://jira.mariadb.org/browse/MDEV-4088 | ||||
|      */ | ||||
|     public function getServerVersion() | ||||
|     { | ||||
|         $serverInfos = $this->_conn->get_server_info(); | ||||
|         if (false !== stripos($serverInfos, 'mariadb')) { | ||||
|             return $serverInfos; | ||||
|         } | ||||
|  | ||||
|         $majorVersion = floor($this->_conn->server_version / 10000); | ||||
|         $minorVersion = floor(($this->_conn->server_version - $majorVersion * 10000) / 100); | ||||
|         $patchVersion = floor($this->_conn->server_version - $majorVersion * 10000 - $minorVersion * 100); | ||||
|  | ||||
|         return $majorVersion . '.' . $minorVersion . '.' . $patchVersion; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function requiresQueryForServerVersion() | ||||
|     { | ||||
|         return false; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function prepare($prepareString) | ||||
|     { | ||||
|         return new MysqliStatement($this->_conn, $prepareString); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function query() | ||||
|     { | ||||
|         $args = func_get_args(); | ||||
|         $sql = $args[0]; | ||||
|         $stmt = $this->prepare($sql); | ||||
|         $stmt->execute(); | ||||
|  | ||||
|         return $stmt; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function quote($input, $type = ParameterType::STRING) | ||||
|     { | ||||
|         return "'". $this->_conn->escape_string($input) ."'"; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function exec($statement) | ||||
|     { | ||||
|         if (false === $this->_conn->query($statement)) { | ||||
|             throw new MysqliException($this->_conn->error, $this->_conn->sqlstate, $this->_conn->errno); | ||||
|         } | ||||
|  | ||||
|         return $this->_conn->affected_rows; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function lastInsertId($name = null) | ||||
|     { | ||||
|         return $this->_conn->insert_id; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function beginTransaction() | ||||
|     { | ||||
|         $this->_conn->query('START TRANSACTION'); | ||||
|  | ||||
|         return true; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function commit() | ||||
|     { | ||||
|         return $this->_conn->commit(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc}non-PHPdoc) | ||||
|      */ | ||||
|     public function rollBack() | ||||
|     { | ||||
|         return $this->_conn->rollback(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function errorCode() | ||||
|     { | ||||
|         return $this->_conn->errno; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function errorInfo() | ||||
|     { | ||||
|         return $this->_conn->error; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Apply the driver options to the connection. | ||||
|      * | ||||
|      * @param array $driverOptions | ||||
|      * | ||||
|      * @throws MysqliException When one of of the options is not supported. | ||||
|      * @throws MysqliException When applying doesn't work - e.g. due to incorrect value. | ||||
|      */ | ||||
|     private function setDriverOptions(array $driverOptions = []) | ||||
|     { | ||||
|         $supportedDriverOptions = [ | ||||
|             \MYSQLI_OPT_CONNECT_TIMEOUT, | ||||
|             \MYSQLI_OPT_LOCAL_INFILE, | ||||
|             \MYSQLI_INIT_COMMAND, | ||||
|             \MYSQLI_READ_DEFAULT_FILE, | ||||
|             \MYSQLI_READ_DEFAULT_GROUP, | ||||
|         ]; | ||||
|  | ||||
|         if (defined('MYSQLI_SERVER_PUBLIC_KEY')) { | ||||
|             $supportedDriverOptions[] = \MYSQLI_SERVER_PUBLIC_KEY; | ||||
|         } | ||||
|  | ||||
|         $exceptionMsg = "%s option '%s' with value '%s'"; | ||||
|  | ||||
|         foreach ($driverOptions as $option => $value) { | ||||
|  | ||||
|             if ($option === static::OPTION_FLAGS) { | ||||
|                 continue; | ||||
|             } | ||||
|  | ||||
|             if (!in_array($option, $supportedDriverOptions, true)) { | ||||
|                 throw new MysqliException( | ||||
|                     sprintf($exceptionMsg, 'Unsupported', $option, $value) | ||||
|                 ); | ||||
|             } | ||||
|  | ||||
|             if (@mysqli_options($this->_conn, $option, $value)) { | ||||
|                 continue; | ||||
|             } | ||||
|  | ||||
|             $msg  = sprintf($exceptionMsg, 'Failed to set', $option, $value); | ||||
|             $msg .= sprintf(', error: %s (%d)', mysqli_error($this->_conn), mysqli_errno($this->_conn)); | ||||
|  | ||||
|             throw new MysqliException( | ||||
|                 $msg, | ||||
|                 $this->_conn->sqlstate, | ||||
|                 $this->_conn->errno | ||||
|             ); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Pings the server and re-connects when `mysqli.reconnect = 1` | ||||
|      * | ||||
|      * @return bool | ||||
|      */ | ||||
|     public function ping() | ||||
|     { | ||||
|         return $this->_conn->ping(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Establish a secure connection | ||||
|      * | ||||
|      * @param array $params | ||||
|      * @throws MysqliException | ||||
|      */ | ||||
|     private function setSecureConnection(array $params) | ||||
|     { | ||||
|         if (! isset($params['ssl_key']) && | ||||
|             ! isset($params['ssl_cert']) && | ||||
|             ! isset($params['ssl_ca']) && | ||||
|             ! isset($params['ssl_capath']) && | ||||
|             ! isset($params['ssl_cipher']) | ||||
|         ) { | ||||
|             return; | ||||
|         } | ||||
|  | ||||
|         $this->_conn->ssl_set( | ||||
|             $params['ssl_key']    ?? null, | ||||
|             $params['ssl_cert']   ?? null, | ||||
|             $params['ssl_ca']     ?? null, | ||||
|             $params['ssl_capath'] ?? null, | ||||
|             $params['ssl_cipher'] ?? null | ||||
|         ); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										32
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/Mysqli/MysqliException.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										32
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/Mysqli/MysqliException.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,32 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Driver\Mysqli; | ||||
|  | ||||
| use Doctrine\DBAL\Driver\AbstractDriverException; | ||||
|  | ||||
| /** | ||||
|  * Exception thrown in case the mysqli driver errors. | ||||
|  * | ||||
|  * @author Kim Hemsø Rasmussen <kimhemsoe@gmail.com> | ||||
|  * @author Steve Müller <st.mueller@dzh-online.de> | ||||
|  */ | ||||
| class MysqliException extends AbstractDriverException | ||||
| { | ||||
| } | ||||
							
								
								
									
										427
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/Mysqli/MysqliStatement.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										427
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/Mysqli/MysqliStatement.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,427 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Driver\Mysqli; | ||||
|  | ||||
| use Doctrine\DBAL\Driver\Statement; | ||||
| use Doctrine\DBAL\Driver\StatementIterator; | ||||
| use Doctrine\DBAL\FetchMode; | ||||
| use Doctrine\DBAL\ParameterType; | ||||
| use function array_combine; | ||||
| use function array_fill; | ||||
| use function call_user_func_array; | ||||
| use function count; | ||||
| use function str_repeat; | ||||
|  | ||||
| /** | ||||
|  * @author Kim Hemsø Rasmussen <kimhemsoe@gmail.com> | ||||
|  */ | ||||
| class MysqliStatement implements \IteratorAggregate, Statement | ||||
| { | ||||
|     /** | ||||
|      * @var array | ||||
|      */ | ||||
|     protected static $_paramTypeMap = [ | ||||
|         ParameterType::STRING       => 's', | ||||
|         ParameterType::BINARY       => 's', | ||||
|         ParameterType::BOOLEAN      => 'i', | ||||
|         ParameterType::NULL         => 's', | ||||
|         ParameterType::INTEGER      => 'i', | ||||
|  | ||||
|         // TODO Support LOB bigger then max package size | ||||
|         ParameterType::LARGE_OBJECT => 's', | ||||
|     ]; | ||||
|  | ||||
|     /** | ||||
|      * @var \mysqli | ||||
|      */ | ||||
|     protected $_conn; | ||||
|  | ||||
|     /** | ||||
|      * @var \mysqli_stmt | ||||
|      */ | ||||
|     protected $_stmt; | ||||
|  | ||||
|     /** | ||||
|      * @var null|boolean|array | ||||
|      */ | ||||
|     protected $_columnNames; | ||||
|  | ||||
|     /** | ||||
|      * @var null|array | ||||
|      */ | ||||
|     protected $_rowBindedValues; | ||||
|  | ||||
|     /** | ||||
|      * @var array | ||||
|      */ | ||||
|     protected $_bindedValues; | ||||
|  | ||||
|     /** | ||||
|      * @var string | ||||
|      */ | ||||
|     protected $types; | ||||
|  | ||||
|     /** | ||||
|      * Contains ref values for bindValue(). | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     protected $_values = []; | ||||
|  | ||||
|     /** | ||||
|      * @var int | ||||
|      */ | ||||
|     protected $_defaultFetchMode = FetchMode::MIXED; | ||||
|  | ||||
|     /** | ||||
|      * Indicates whether the statement is in the state when fetching results is possible | ||||
|      * | ||||
|      * @var bool | ||||
|      */ | ||||
|     private $result = false; | ||||
|  | ||||
|     /** | ||||
|      * @param \mysqli $conn | ||||
|      * @param string  $prepareString | ||||
|      * | ||||
|      * @throws \Doctrine\DBAL\Driver\Mysqli\MysqliException | ||||
|      */ | ||||
|     public function __construct(\mysqli $conn, $prepareString) | ||||
|     { | ||||
|         $this->_conn = $conn; | ||||
|         $this->_stmt = $conn->prepare($prepareString); | ||||
|         if (false === $this->_stmt) { | ||||
|             throw new MysqliException($this->_conn->error, $this->_conn->sqlstate, $this->_conn->errno); | ||||
|         } | ||||
|  | ||||
|         $paramCount = $this->_stmt->param_count; | ||||
|         if (0 < $paramCount) { | ||||
|             $this->types = str_repeat('s', $paramCount); | ||||
|             $this->_bindedValues = array_fill(1, $paramCount, null); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function bindParam($column, &$variable, $type = ParameterType::STRING, $length = null) | ||||
|     { | ||||
|         if (null === $type) { | ||||
|             $type = 's'; | ||||
|         } else { | ||||
|             if (isset(self::$_paramTypeMap[$type])) { | ||||
|                 $type = self::$_paramTypeMap[$type]; | ||||
|             } else { | ||||
|                 throw new MysqliException("Unknown type: '{$type}'"); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         $this->_bindedValues[$column] =& $variable; | ||||
|         $this->types[$column - 1] = $type; | ||||
|  | ||||
|         return true; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function bindValue($param, $value, $type = ParameterType::STRING) | ||||
|     { | ||||
|         if (null === $type) { | ||||
|             $type = 's'; | ||||
|         } else { | ||||
|             if (isset(self::$_paramTypeMap[$type])) { | ||||
|                 $type = self::$_paramTypeMap[$type]; | ||||
|             } else { | ||||
|                 throw new MysqliException("Unknown type: '{$type}'"); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         $this->_values[$param] = $value; | ||||
|         $this->_bindedValues[$param] =& $this->_values[$param]; | ||||
|         $this->types[$param - 1] = $type; | ||||
|  | ||||
|         return true; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function execute($params = null) | ||||
|     { | ||||
|         if (null !== $this->_bindedValues) { | ||||
|             if (null !== $params) { | ||||
|                 if ( ! $this->_bindValues($params)) { | ||||
|                     throw new MysqliException($this->_stmt->error, $this->_stmt->errno); | ||||
|                 } | ||||
|             } else { | ||||
|                 if (!call_user_func_array([$this->_stmt, 'bind_param'], [$this->types] + $this->_bindedValues)) { | ||||
|                     throw new MysqliException($this->_stmt->error, $this->_stmt->sqlstate, $this->_stmt->errno); | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         if ( ! $this->_stmt->execute()) { | ||||
|             throw new MysqliException($this->_stmt->error, $this->_stmt->sqlstate, $this->_stmt->errno); | ||||
|         } | ||||
|  | ||||
|         if (null === $this->_columnNames) { | ||||
|             $meta = $this->_stmt->result_metadata(); | ||||
|             if (false !== $meta) { | ||||
|                 $columnNames = []; | ||||
|                 foreach ($meta->fetch_fields() as $col) { | ||||
|                     $columnNames[] = $col->name; | ||||
|                 } | ||||
|                 $meta->free(); | ||||
|  | ||||
|                 $this->_columnNames = $columnNames; | ||||
|             } else { | ||||
|                 $this->_columnNames = false; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         if (false !== $this->_columnNames) { | ||||
|             // Store result of every execution which has it. Otherwise it will be impossible | ||||
|             // to execute a new statement in case if the previous one has non-fetched rows | ||||
|             // @link http://dev.mysql.com/doc/refman/5.7/en/commands-out-of-sync.html | ||||
|             $this->_stmt->store_result(); | ||||
|  | ||||
|             // Bind row values _after_ storing the result. Otherwise, if mysqli is compiled with libmysql, | ||||
|             // it will have to allocate as much memory as it may be needed for the given column type | ||||
|             // (e.g. for a LONGBLOB field it's 4 gigabytes) | ||||
|             // @link https://bugs.php.net/bug.php?id=51386#1270673122 | ||||
|             // | ||||
|             // Make sure that the values are bound after each execution. Otherwise, if closeCursor() has been | ||||
|             // previously called on the statement, the values are unbound making the statement unusable. | ||||
|             // | ||||
|             // It's also important that row values are bound after _each_ call to store_result(). Otherwise, | ||||
|             // if mysqli is compiled with libmysql, subsequently fetched string values will get truncated | ||||
|             // to the length of the ones fetched during the previous execution. | ||||
|             $this->_rowBindedValues = array_fill(0, count($this->_columnNames), null); | ||||
|  | ||||
|             $refs = []; | ||||
|             foreach ($this->_rowBindedValues as $key => &$value) { | ||||
|                 $refs[$key] =& $value; | ||||
|             } | ||||
|  | ||||
|             if (!call_user_func_array([$this->_stmt, 'bind_result'], $refs)) { | ||||
|                 throw new MysqliException($this->_stmt->error, $this->_stmt->sqlstate, $this->_stmt->errno); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         $this->result = true; | ||||
|  | ||||
|         return true; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Binds a array of values to bound parameters. | ||||
|      * | ||||
|      * @param array $values | ||||
|      * | ||||
|      * @return bool | ||||
|      */ | ||||
|     private function _bindValues($values) | ||||
|     { | ||||
|         $params = []; | ||||
|         $types = str_repeat('s', count($values)); | ||||
|         $params[0] = $types; | ||||
|  | ||||
|         foreach ($values as &$v) { | ||||
|             $params[] =& $v; | ||||
|         } | ||||
|  | ||||
|         return call_user_func_array([$this->_stmt, 'bind_param'], $params); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @return mixed[]|false | ||||
|      */ | ||||
|     private function _fetch() | ||||
|     { | ||||
|         $ret = $this->_stmt->fetch(); | ||||
|  | ||||
|         if (true === $ret) { | ||||
|             $values = []; | ||||
|             foreach ($this->_rowBindedValues as $v) { | ||||
|                 $values[] = $v; | ||||
|             } | ||||
|  | ||||
|             return $values; | ||||
|         } | ||||
|  | ||||
|         return $ret; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function fetch($fetchMode = null, $cursorOrientation = \PDO::FETCH_ORI_NEXT, $cursorOffset = 0) | ||||
|     { | ||||
|         // do not try fetching from the statement if it's not expected to contain result | ||||
|         // in order to prevent exceptional situation | ||||
|         if (!$this->result) { | ||||
|             return false; | ||||
|         } | ||||
|  | ||||
|         $fetchMode = $fetchMode ?: $this->_defaultFetchMode; | ||||
|  | ||||
|         if ($fetchMode === FetchMode::COLUMN) { | ||||
|             return $this->fetchColumn(); | ||||
|         } | ||||
|  | ||||
|         $values = $this->_fetch(); | ||||
|         if (null === $values) { | ||||
|             return false; | ||||
|         } | ||||
|  | ||||
|         if (false === $values) { | ||||
|             throw new MysqliException($this->_stmt->error, $this->_stmt->sqlstate, $this->_stmt->errno); | ||||
|         } | ||||
|  | ||||
|         switch ($fetchMode) { | ||||
|             case FetchMode::NUMERIC: | ||||
|                 return $values; | ||||
|  | ||||
|             case FetchMode::ASSOCIATIVE: | ||||
|                 return array_combine($this->_columnNames, $values); | ||||
|  | ||||
|             case FetchMode::MIXED: | ||||
|                 $ret = array_combine($this->_columnNames, $values); | ||||
|                 $ret += $values; | ||||
|  | ||||
|                 return $ret; | ||||
|  | ||||
|             case FetchMode::STANDARD_OBJECT: | ||||
|                 $assoc = array_combine($this->_columnNames, $values); | ||||
|                 $ret = new \stdClass(); | ||||
|  | ||||
|                 foreach ($assoc as $column => $value) { | ||||
|                     $ret->$column = $value; | ||||
|                 } | ||||
|  | ||||
|                 return $ret; | ||||
|  | ||||
|             default: | ||||
|                 throw new MysqliException("Unknown fetch type '{$fetchMode}'"); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function fetchAll($fetchMode = null, $fetchArgument = null, $ctorArgs = null) | ||||
|     { | ||||
|         $fetchMode = $fetchMode ?: $this->_defaultFetchMode; | ||||
|  | ||||
|         $rows = []; | ||||
|  | ||||
|         if ($fetchMode === FetchMode::COLUMN) { | ||||
|             while (($row = $this->fetchColumn()) !== false) { | ||||
|                 $rows[] = $row; | ||||
|             } | ||||
|         } else { | ||||
|             while (($row = $this->fetch($fetchMode)) !== false) { | ||||
|                 $rows[] = $row; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         return $rows; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function fetchColumn($columnIndex = 0) | ||||
|     { | ||||
|         $row = $this->fetch(FetchMode::NUMERIC); | ||||
|  | ||||
|         if (false === $row) { | ||||
|             return false; | ||||
|         } | ||||
|  | ||||
|         return $row[$columnIndex] ?? null; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function errorCode() | ||||
|     { | ||||
|         return $this->_stmt->errno; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function errorInfo() | ||||
|     { | ||||
|         return $this->_stmt->error; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function closeCursor() | ||||
|     { | ||||
|         $this->_stmt->free_result(); | ||||
|         $this->result = false; | ||||
|  | ||||
|         return true; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function rowCount() | ||||
|     { | ||||
|         if (false === $this->_columnNames) { | ||||
|             return $this->_stmt->affected_rows; | ||||
|         } | ||||
|  | ||||
|         return $this->_stmt->num_rows; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function columnCount() | ||||
|     { | ||||
|         return $this->_stmt->field_count; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function setFetchMode($fetchMode, $arg2 = null, $arg3 = null) | ||||
|     { | ||||
|         $this->_defaultFetchMode = $fetchMode; | ||||
|  | ||||
|         return true; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function getIterator() | ||||
|     { | ||||
|         return new StatementIterator($this); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										72
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/OCI8/Driver.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										72
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/OCI8/Driver.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,72 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Driver\OCI8; | ||||
|  | ||||
| use Doctrine\DBAL\DBALException; | ||||
| use Doctrine\DBAL\Driver\AbstractOracleDriver; | ||||
| use const OCI_DEFAULT; | ||||
|  | ||||
| /** | ||||
|  * A Doctrine DBAL driver for the Oracle OCI8 PHP extensions. | ||||
|  * | ||||
|  * @author Roman Borschel <roman@code-factory.org> | ||||
|  * @since 2.0 | ||||
|  */ | ||||
| class Driver extends AbstractOracleDriver | ||||
| { | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function connect(array $params, $username = null, $password = null, array $driverOptions = []) | ||||
|     { | ||||
|         try { | ||||
|             return new OCI8Connection( | ||||
|                 $username, | ||||
|                 $password, | ||||
|                 $this->_constructDsn($params), | ||||
|                 $params['charset'] ?? null, | ||||
|                 $params['sessionMode'] ?? OCI_DEFAULT, | ||||
|                 $params['persistent'] ?? false | ||||
|             ); | ||||
|         } catch (OCI8Exception $e) { | ||||
|             throw DBALException::driverException($this, $e); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Constructs the Oracle DSN. | ||||
|      * | ||||
|      * @param array $params | ||||
|      * | ||||
|      * @return string The DSN. | ||||
|      */ | ||||
|     protected function _constructDsn(array $params) | ||||
|     { | ||||
|         return $this->getEasyConnectString($params); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function getName() | ||||
|     { | ||||
|         return 'oci8'; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										249
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/OCI8/OCI8Connection.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										249
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/OCI8/OCI8Connection.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,249 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Driver\OCI8; | ||||
|  | ||||
| use Doctrine\DBAL\Driver\Connection; | ||||
| use Doctrine\DBAL\Driver\ServerInfoAwareConnection; | ||||
| use Doctrine\DBAL\ParameterType; | ||||
| use const OCI_COMMIT_ON_SUCCESS; | ||||
| use const OCI_DEFAULT; | ||||
| use const OCI_NO_AUTO_COMMIT; | ||||
| use function addcslashes; | ||||
| use function define; | ||||
| use function defined; | ||||
| use function func_get_args; | ||||
| use function is_float; | ||||
| use function is_int; | ||||
| use function oci_commit; | ||||
| use function oci_connect; | ||||
| use function oci_error; | ||||
| use function oci_pconnect; | ||||
| use function oci_rollback; | ||||
| use function oci_server_version; | ||||
| use function preg_match; | ||||
| use function sprintf; | ||||
| use function str_replace; | ||||
|  | ||||
| /** | ||||
|  * OCI8 implementation of the Connection interface. | ||||
|  * | ||||
|  * @since 2.0 | ||||
|  */ | ||||
| class OCI8Connection implements Connection, ServerInfoAwareConnection | ||||
| { | ||||
|     /** | ||||
|      * @var resource | ||||
|      */ | ||||
|     protected $dbh; | ||||
|  | ||||
|     /** | ||||
|      * @var int | ||||
|      */ | ||||
|     protected $executeMode = OCI_COMMIT_ON_SUCCESS; | ||||
|  | ||||
|     /** | ||||
|      * Creates a Connection to an Oracle Database using oci8 extension. | ||||
|      * | ||||
|      * @param string      $username | ||||
|      * @param string      $password | ||||
|      * @param string      $db | ||||
|      * @param string|null $charset | ||||
|      * @param int         $sessionMode | ||||
|      * @param bool        $persistent | ||||
|      * | ||||
|      * @throws OCI8Exception | ||||
|      */ | ||||
|     public function __construct($username, $password, $db, $charset = null, $sessionMode = OCI_DEFAULT, $persistent = false) | ||||
|     { | ||||
|         if (!defined('OCI_NO_AUTO_COMMIT')) { | ||||
|             define('OCI_NO_AUTO_COMMIT', 0); | ||||
|         } | ||||
|  | ||||
|         $this->dbh = $persistent | ||||
|             ? @oci_pconnect($username, $password, $db, $charset, $sessionMode) | ||||
|             : @oci_connect($username, $password, $db, $charset, $sessionMode); | ||||
|  | ||||
|         if ( ! $this->dbh) { | ||||
|             throw OCI8Exception::fromErrorInfo(oci_error()); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      * | ||||
|      * @throws \UnexpectedValueException if the version string returned by the database server | ||||
|      *                                   does not contain a parsable version number. | ||||
|      */ | ||||
|     public function getServerVersion() | ||||
|     { | ||||
|         if ( ! preg_match('/\s+(\d+\.\d+\.\d+\.\d+\.\d+)\s+/', oci_server_version($this->dbh), $version)) { | ||||
|             throw new \UnexpectedValueException( | ||||
|                 sprintf( | ||||
|                     'Unexpected database version string "%s". Cannot parse an appropriate version number from it. ' . | ||||
|                     'Please report this database version string to the Doctrine team.', | ||||
|                     oci_server_version($this->dbh) | ||||
|                 ) | ||||
|             ); | ||||
|         } | ||||
|  | ||||
|         return $version[1]; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function requiresQueryForServerVersion() | ||||
|     { | ||||
|         return false; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function prepare($prepareString) | ||||
|     { | ||||
|         return new OCI8Statement($this->dbh, $prepareString, $this); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function query() | ||||
|     { | ||||
|         $args = func_get_args(); | ||||
|         $sql = $args[0]; | ||||
|         //$fetchMode = $args[1]; | ||||
|         $stmt = $this->prepare($sql); | ||||
|         $stmt->execute(); | ||||
|  | ||||
|         return $stmt; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function quote($value, $type = ParameterType::STRING) | ||||
|     { | ||||
|         if (is_int($value) || is_float($value)) { | ||||
|             return $value; | ||||
|         } | ||||
|         $value = str_replace("'", "''", $value); | ||||
|  | ||||
|         return "'" . addcslashes($value, "\000\n\r\\\032") . "'"; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function exec($statement) | ||||
|     { | ||||
|         $stmt = $this->prepare($statement); | ||||
|         $stmt->execute(); | ||||
|  | ||||
|         return $stmt->rowCount(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function lastInsertId($name = null) | ||||
|     { | ||||
|         if ($name === null) { | ||||
|             return false; | ||||
|         } | ||||
|  | ||||
|         $sql    = 'SELECT ' . $name . '.CURRVAL FROM DUAL'; | ||||
|         $stmt   = $this->query($sql); | ||||
|         $result = $stmt->fetchColumn(); | ||||
|  | ||||
|         if ($result === false) { | ||||
|             throw new OCI8Exception("lastInsertId failed: Query was executed but no result was returned."); | ||||
|         } | ||||
|  | ||||
|         return (int) $result; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Returns the current execution mode. | ||||
|      * | ||||
|      * @return int | ||||
|      */ | ||||
|     public function getExecuteMode() | ||||
|     { | ||||
|         return $this->executeMode; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function beginTransaction() | ||||
|     { | ||||
|         $this->executeMode = OCI_NO_AUTO_COMMIT; | ||||
|  | ||||
|         return true; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function commit() | ||||
|     { | ||||
|         if (!oci_commit($this->dbh)) { | ||||
|             throw OCI8Exception::fromErrorInfo($this->errorInfo()); | ||||
|         } | ||||
|         $this->executeMode = OCI_COMMIT_ON_SUCCESS; | ||||
|  | ||||
|         return true; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function rollBack() | ||||
|     { | ||||
|         if (!oci_rollback($this->dbh)) { | ||||
|             throw OCI8Exception::fromErrorInfo($this->errorInfo()); | ||||
|         } | ||||
|         $this->executeMode = OCI_COMMIT_ON_SUCCESS; | ||||
|  | ||||
|         return true; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function errorCode() | ||||
|     { | ||||
|         $error = oci_error($this->dbh); | ||||
|         if ($error !== false) { | ||||
|             $error = $error['code']; | ||||
|         } | ||||
|  | ||||
|         return $error; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function errorInfo() | ||||
|     { | ||||
|         return oci_error($this->dbh); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										35
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/OCI8/OCI8Exception.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										35
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/OCI8/OCI8Exception.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,35 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Driver\OCI8; | ||||
|  | ||||
| use Doctrine\DBAL\Driver\AbstractDriverException; | ||||
|  | ||||
| class OCI8Exception extends AbstractDriverException | ||||
| { | ||||
|     /** | ||||
|      * @param array $error | ||||
|      * | ||||
|      * @return \Doctrine\DBAL\Driver\OCI8\OCI8Exception | ||||
|      */ | ||||
|     public static function fromErrorInfo($error) | ||||
|     { | ||||
|         return new self($error['message'], null, $error['code']); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										534
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/OCI8/OCI8Statement.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										534
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/OCI8/OCI8Statement.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,534 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Driver\OCI8; | ||||
|  | ||||
| use Doctrine\DBAL\Driver\Statement; | ||||
| use Doctrine\DBAL\Driver\StatementIterator; | ||||
| use Doctrine\DBAL\FetchMode; | ||||
| use Doctrine\DBAL\ParameterType; | ||||
| use IteratorAggregate; | ||||
| use const OCI_ASSOC; | ||||
| use const OCI_B_BIN; | ||||
| use const OCI_B_BLOB; | ||||
| use const OCI_BOTH; | ||||
| use const OCI_D_LOB; | ||||
| use const OCI_FETCHSTATEMENT_BY_COLUMN; | ||||
| use const OCI_FETCHSTATEMENT_BY_ROW; | ||||
| use const OCI_NUM; | ||||
| use const OCI_RETURN_LOBS; | ||||
| use const OCI_RETURN_NULLS; | ||||
| use const OCI_TEMP_BLOB; | ||||
| use const PREG_OFFSET_CAPTURE; | ||||
| use const SQLT_CHR; | ||||
| use function array_key_exists; | ||||
| use function count; | ||||
| use function implode; | ||||
| use function is_numeric; | ||||
| use function oci_bind_by_name; | ||||
| use function oci_cancel; | ||||
| use function oci_error; | ||||
| use function oci_execute; | ||||
| use function oci_fetch_all; | ||||
| use function oci_fetch_array; | ||||
| use function oci_fetch_object; | ||||
| use function oci_new_descriptor; | ||||
| use function oci_num_fields; | ||||
| use function oci_num_rows; | ||||
| use function oci_parse; | ||||
| use function preg_match; | ||||
| use function preg_quote; | ||||
| use function sprintf; | ||||
| use function substr; | ||||
|  | ||||
| /** | ||||
|  * The OCI8 implementation of the Statement interface. | ||||
|  * | ||||
|  * @since 2.0 | ||||
|  * @author Roman Borschel <roman@code-factory.org> | ||||
|  */ | ||||
| class OCI8Statement implements IteratorAggregate, Statement | ||||
| { | ||||
|     /** | ||||
|      * @var resource | ||||
|      */ | ||||
|     protected $_dbh; | ||||
|  | ||||
|     /** | ||||
|      * @var resource | ||||
|      */ | ||||
|     protected $_sth; | ||||
|  | ||||
|     /** | ||||
|      * @var \Doctrine\DBAL\Driver\OCI8\OCI8Connection | ||||
|      */ | ||||
|     protected $_conn; | ||||
|  | ||||
|     /** | ||||
|      * @var string | ||||
|      */ | ||||
|     protected static $_PARAM = ':param'; | ||||
|  | ||||
|     /** | ||||
|      * @var array | ||||
|      */ | ||||
|     protected static $fetchModeMap = [ | ||||
|         FetchMode::MIXED       => OCI_BOTH, | ||||
|         FetchMode::ASSOCIATIVE => OCI_ASSOC, | ||||
|         FetchMode::NUMERIC     => OCI_NUM, | ||||
|         FetchMode::COLUMN      => OCI_NUM, | ||||
|     ]; | ||||
|  | ||||
|     /** | ||||
|      * @var int | ||||
|      */ | ||||
|     protected $_defaultFetchMode = FetchMode::MIXED; | ||||
|  | ||||
|     /** | ||||
|      * @var array | ||||
|      */ | ||||
|     protected $_paramMap = []; | ||||
|  | ||||
|     /** | ||||
|      * Holds references to bound parameter values. | ||||
|      * | ||||
|      * This is a new requirement for PHP7's oci8 extension that prevents bound values from being garbage collected. | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     private $boundValues = []; | ||||
|  | ||||
|     /** | ||||
|      * Indicates whether the statement is in the state when fetching results is possible | ||||
|      * | ||||
|      * @var bool | ||||
|      */ | ||||
|     private $result = false; | ||||
|  | ||||
|     /** | ||||
|      * Creates a new OCI8Statement that uses the given connection handle and SQL statement. | ||||
|      * | ||||
|      * @param resource                                  $dbh       The connection handle. | ||||
|      * @param string                                    $statement The SQL statement. | ||||
|      * @param \Doctrine\DBAL\Driver\OCI8\OCI8Connection $conn | ||||
|      */ | ||||
|     public function __construct($dbh, $statement, OCI8Connection $conn) | ||||
|     { | ||||
|         list($statement, $paramMap) = self::convertPositionalToNamedPlaceholders($statement); | ||||
|         $this->_sth = oci_parse($dbh, $statement); | ||||
|         $this->_dbh = $dbh; | ||||
|         $this->_paramMap = $paramMap; | ||||
|         $this->_conn = $conn; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Converts positional (?) into named placeholders (:param<num>). | ||||
|      * | ||||
|      * Oracle does not support positional parameters, hence this method converts all | ||||
|      * positional parameters into artificially named parameters. Note that this conversion | ||||
|      * is not perfect. All question marks (?) in the original statement are treated as | ||||
|      * placeholders and converted to a named parameter. | ||||
|      * | ||||
|      * The algorithm uses a state machine with two possible states: InLiteral and NotInLiteral. | ||||
|      * Question marks inside literal strings are therefore handled correctly by this method. | ||||
|      * This comes at a cost, the whole sql statement has to be looped over. | ||||
|      * | ||||
|      * @todo extract into utility class in Doctrine\DBAL\Util namespace | ||||
|      * @todo review and test for lost spaces. we experienced missing spaces with oci8 in some sql statements. | ||||
|      * | ||||
|      * @param string $statement The SQL statement to convert. | ||||
|      * | ||||
|      * @return array [0] => the statement value (string), [1] => the paramMap value (array). | ||||
|      * @throws \Doctrine\DBAL\Driver\OCI8\OCI8Exception | ||||
|      */ | ||||
|     public static function convertPositionalToNamedPlaceholders($statement) | ||||
|     { | ||||
|         $fragmentOffset = $tokenOffset = 0; | ||||
|         $fragments = $paramMap = []; | ||||
|         $currentLiteralDelimiter = null; | ||||
|  | ||||
|         do { | ||||
|             if (!$currentLiteralDelimiter) { | ||||
|                 $result = self::findPlaceholderOrOpeningQuote( | ||||
|                     $statement, | ||||
|                     $tokenOffset, | ||||
|                     $fragmentOffset, | ||||
|                     $fragments, | ||||
|                     $currentLiteralDelimiter, | ||||
|                     $paramMap | ||||
|                 ); | ||||
|             } else { | ||||
|                 $result = self::findClosingQuote($statement, $tokenOffset, $currentLiteralDelimiter); | ||||
|             } | ||||
|         } while ($result); | ||||
|  | ||||
|         if ($currentLiteralDelimiter) { | ||||
|             throw new OCI8Exception(sprintf( | ||||
|                 'The statement contains non-terminated string literal starting at offset %d', | ||||
|                 $tokenOffset - 1 | ||||
|             )); | ||||
|         } | ||||
|  | ||||
|         $fragments[] = substr($statement, $fragmentOffset); | ||||
|         $statement = implode('', $fragments); | ||||
|  | ||||
|         return [$statement, $paramMap]; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Finds next placeholder or opening quote. | ||||
|      * | ||||
|      * @param string             $statement               The SQL statement to parse | ||||
|      * @param string             $tokenOffset             The offset to start searching from | ||||
|      * @param int                $fragmentOffset          The offset to build the next fragment from | ||||
|      * @param string[]           $fragments               Fragments of the original statement not containing placeholders | ||||
|      * @param string|null        $currentLiteralDelimiter The delimiter of the current string literal | ||||
|      *                                                    or NULL if not currently in a literal | ||||
|      * @param array<int, string> $paramMap                Mapping of the original parameter positions to their named replacements | ||||
|      * @return bool Whether the token was found | ||||
|      */ | ||||
|     private static function findPlaceholderOrOpeningQuote( | ||||
|         $statement, | ||||
|         &$tokenOffset, | ||||
|         &$fragmentOffset, | ||||
|         &$fragments, | ||||
|         &$currentLiteralDelimiter, | ||||
|         &$paramMap | ||||
|     ) { | ||||
|         $token = self::findToken($statement, $tokenOffset, '/[?\'"]/'); | ||||
|  | ||||
|         if (!$token) { | ||||
|             return false; | ||||
|         } | ||||
|  | ||||
|         if ($token === '?') { | ||||
|             $position = count($paramMap) + 1; | ||||
|             $param = ':param' . $position; | ||||
|             $fragments[] = substr($statement, $fragmentOffset, $tokenOffset - $fragmentOffset); | ||||
|             $fragments[] = $param; | ||||
|             $paramMap[$position] = $param; | ||||
|             $tokenOffset += 1; | ||||
|             $fragmentOffset = $tokenOffset; | ||||
|  | ||||
|             return true; | ||||
|         } | ||||
|  | ||||
|         $currentLiteralDelimiter = $token; | ||||
|         ++$tokenOffset; | ||||
|  | ||||
|         return true; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Finds closing quote | ||||
|      * | ||||
|      * @param string      $statement               The SQL statement to parse | ||||
|      * @param string      $tokenOffset             The offset to start searching from | ||||
|      * @param string|null $currentLiteralDelimiter The delimiter of the current string literal | ||||
|      *                                             or NULL if not currently in a literal | ||||
|      * @return bool Whether the token was found | ||||
|      */ | ||||
|     private static function findClosingQuote( | ||||
|         $statement, | ||||
|         &$tokenOffset, | ||||
|         &$currentLiteralDelimiter | ||||
|     ) { | ||||
|         $token = self::findToken( | ||||
|             $statement, | ||||
|             $tokenOffset, | ||||
|             '/' . preg_quote($currentLiteralDelimiter, '/') . '/' | ||||
|         ); | ||||
|  | ||||
|         if (!$token) { | ||||
|             return false; | ||||
|         } | ||||
|  | ||||
|         $currentLiteralDelimiter = false; | ||||
|         ++$tokenOffset; | ||||
|  | ||||
|         return true; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Finds the token described by regex starting from the given offset. Updates the offset with the position | ||||
|      * where the token was found. | ||||
|      * | ||||
|      * @param string $statement The SQL statement to parse | ||||
|      * @param string $offset    The offset to start searching from | ||||
|      * @param string $regex     The regex containing token pattern | ||||
|      * @return string|null Token or NULL if not found | ||||
|      */ | ||||
|     private static function findToken($statement, &$offset, $regex) | ||||
|     { | ||||
|         if (preg_match($regex, $statement, $matches, PREG_OFFSET_CAPTURE, $offset)) { | ||||
|             $offset = $matches[0][1]; | ||||
|             return $matches[0][0]; | ||||
|         } | ||||
|  | ||||
|         return null; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function bindValue($param, $value, $type = ParameterType::STRING) | ||||
|     { | ||||
|         return $this->bindParam($param, $value, $type, null); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function bindParam($column, &$variable, $type = ParameterType::STRING, $length = null) | ||||
|     { | ||||
|         $column = $this->_paramMap[$column] ?? $column; | ||||
|  | ||||
|         if ($type === ParameterType::LARGE_OBJECT) { | ||||
|             $lob = oci_new_descriptor($this->_dbh, OCI_D_LOB); | ||||
|             $lob->writeTemporary($variable, OCI_TEMP_BLOB); | ||||
|  | ||||
|             $variable =& $lob; | ||||
|         } | ||||
|  | ||||
|         $this->boundValues[$column] =& $variable; | ||||
|  | ||||
|         return oci_bind_by_name( | ||||
|             $this->_sth, | ||||
|             $column, | ||||
|             $variable, | ||||
|             $length ?? -1, | ||||
|             $this->convertParameterType($type) | ||||
|         ); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Converts DBAL parameter type to oci8 parameter type | ||||
|      */ | ||||
|     private function convertParameterType(int $type) : int | ||||
|     { | ||||
|         switch ($type) { | ||||
|             case ParameterType::BINARY: | ||||
|                 return OCI_B_BIN; | ||||
|  | ||||
|             case ParameterType::LARGE_OBJECT: | ||||
|                 return OCI_B_BLOB; | ||||
|  | ||||
|             default: | ||||
|                 return SQLT_CHR; | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function closeCursor() | ||||
|     { | ||||
|         // not having the result means there's nothing to close | ||||
|         if (!$this->result) { | ||||
|             return true; | ||||
|         } | ||||
|  | ||||
|         oci_cancel($this->_sth); | ||||
|  | ||||
|         $this->result = false; | ||||
|  | ||||
|         return true; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function columnCount() | ||||
|     { | ||||
|         return oci_num_fields($this->_sth); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function errorCode() | ||||
|     { | ||||
|         $error = oci_error($this->_sth); | ||||
|         if ($error !== false) { | ||||
|             $error = $error['code']; | ||||
|         } | ||||
|  | ||||
|         return $error; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function errorInfo() | ||||
|     { | ||||
|         return oci_error($this->_sth); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function execute($params = null) | ||||
|     { | ||||
|         if ($params) { | ||||
|             $hasZeroIndex = array_key_exists(0, $params); | ||||
|             foreach ($params as $key => $val) { | ||||
|                 if ($hasZeroIndex && is_numeric($key)) { | ||||
|                     $this->bindValue($key + 1, $val); | ||||
|                 } else { | ||||
|                     $this->bindValue($key, $val); | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         $ret = @oci_execute($this->_sth, $this->_conn->getExecuteMode()); | ||||
|         if ( ! $ret) { | ||||
|             throw OCI8Exception::fromErrorInfo($this->errorInfo()); | ||||
|         } | ||||
|  | ||||
|         $this->result = true; | ||||
|  | ||||
|         return $ret; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function setFetchMode($fetchMode, $arg2 = null, $arg3 = null) | ||||
|     { | ||||
|         $this->_defaultFetchMode = $fetchMode; | ||||
|  | ||||
|         return true; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function getIterator() | ||||
|     { | ||||
|         return new StatementIterator($this); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function fetch($fetchMode = null, $cursorOrientation = \PDO::FETCH_ORI_NEXT, $cursorOffset = 0) | ||||
|     { | ||||
|         // do not try fetching from the statement if it's not expected to contain result | ||||
|         // in order to prevent exceptional situation | ||||
|         if (!$this->result) { | ||||
|             return false; | ||||
|         } | ||||
|  | ||||
|         $fetchMode = $fetchMode ?: $this->_defaultFetchMode; | ||||
|  | ||||
|         if ($fetchMode === FetchMode::COLUMN) { | ||||
|             return $this->fetchColumn(); | ||||
|         } | ||||
|  | ||||
|         if ($fetchMode === FetchMode::STANDARD_OBJECT) { | ||||
|             return oci_fetch_object($this->_sth); | ||||
|         } | ||||
|  | ||||
|         if (! isset(self::$fetchModeMap[$fetchMode])) { | ||||
|             throw new \InvalidArgumentException("Invalid fetch style: " . $fetchMode); | ||||
|         } | ||||
|  | ||||
|         return oci_fetch_array( | ||||
|             $this->_sth, | ||||
|             self::$fetchModeMap[$fetchMode] | OCI_RETURN_NULLS | OCI_RETURN_LOBS | ||||
|         ); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function fetchAll($fetchMode = null, $fetchArgument = null, $ctorArgs = null) | ||||
|     { | ||||
|         $fetchMode = $fetchMode ?: $this->_defaultFetchMode; | ||||
|  | ||||
|         $result = []; | ||||
|  | ||||
|         if ($fetchMode === FetchMode::STANDARD_OBJECT) { | ||||
|             while ($row = $this->fetch($fetchMode)) { | ||||
|                 $result[] = $row; | ||||
|             } | ||||
|  | ||||
|             return $result; | ||||
|         } | ||||
|  | ||||
|         if ( ! isset(self::$fetchModeMap[$fetchMode])) { | ||||
|             throw new \InvalidArgumentException("Invalid fetch style: " . $fetchMode); | ||||
|         } | ||||
|  | ||||
|         if (self::$fetchModeMap[$fetchMode] === OCI_BOTH) { | ||||
|             while ($row = $this->fetch($fetchMode)) { | ||||
|                 $result[] = $row; | ||||
|             } | ||||
|         } else { | ||||
|             $fetchStructure = OCI_FETCHSTATEMENT_BY_ROW; | ||||
|  | ||||
|             if ($fetchMode === FetchMode::COLUMN) { | ||||
|                 $fetchStructure = OCI_FETCHSTATEMENT_BY_COLUMN; | ||||
|             } | ||||
|  | ||||
|             // do not try fetching from the statement if it's not expected to contain result | ||||
|             // in order to prevent exceptional situation | ||||
|             if (!$this->result) { | ||||
|                 return []; | ||||
|             } | ||||
|  | ||||
|             oci_fetch_all($this->_sth, $result, 0, -1, | ||||
|                 self::$fetchModeMap[$fetchMode] | OCI_RETURN_NULLS | $fetchStructure | OCI_RETURN_LOBS); | ||||
|  | ||||
|             if ($fetchMode === FetchMode::COLUMN) { | ||||
|                 $result = $result[0]; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         return $result; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function fetchColumn($columnIndex = 0) | ||||
|     { | ||||
|         // do not try fetching from the statement if it's not expected to contain result | ||||
|         // in order to prevent exceptional situation | ||||
|         if (!$this->result) { | ||||
|             return false; | ||||
|         } | ||||
|  | ||||
|         $row = oci_fetch_array($this->_sth, OCI_NUM | OCI_RETURN_NULLS | OCI_RETURN_LOBS); | ||||
|  | ||||
|         if (false === $row) { | ||||
|             return false; | ||||
|         } | ||||
|  | ||||
|         return $row[$columnIndex] ?? null; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function rowCount() | ||||
|     { | ||||
|         return oci_num_rows($this->_sth); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										136
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/PDOConnection.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										136
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/PDOConnection.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,136 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Driver; | ||||
|  | ||||
| use Doctrine\DBAL\ParameterType; | ||||
| use PDO; | ||||
| use function count; | ||||
| use function func_get_args; | ||||
|  | ||||
| /** | ||||
|  * PDO implementation of the Connection interface. | ||||
|  * Used by all PDO-based drivers. | ||||
|  * | ||||
|  * @since 2.0 | ||||
|  */ | ||||
| class PDOConnection extends PDO implements Connection, ServerInfoAwareConnection | ||||
| { | ||||
|     /** | ||||
|      * @param string      $dsn | ||||
|      * @param string|null $user | ||||
|      * @param string|null $password | ||||
|      * @param array|null  $options | ||||
|      * | ||||
|      * @throws PDOException in case of an error. | ||||
|      */ | ||||
|     public function __construct($dsn, $user = null, $password = null, array $options = null) | ||||
|     { | ||||
|         try { | ||||
|             parent::__construct($dsn, $user, $password, $options); | ||||
|             $this->setAttribute(PDO::ATTR_STATEMENT_CLASS, ['Doctrine\DBAL\Driver\PDOStatement', []]); | ||||
|             $this->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); | ||||
|         } catch (\PDOException $exception) { | ||||
|             throw new PDOException($exception); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function exec($statement) | ||||
|     { | ||||
|         try { | ||||
|             return parent::exec($statement); | ||||
|         } catch (\PDOException $exception) { | ||||
|             throw new PDOException($exception); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function getServerVersion() | ||||
|     { | ||||
|         return PDO::getAttribute(PDO::ATTR_SERVER_VERSION); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function prepare($prepareString, $driverOptions = []) | ||||
|     { | ||||
|         try { | ||||
|             return parent::prepare($prepareString, $driverOptions); | ||||
|         } catch (\PDOException $exception) { | ||||
|             throw new PDOException($exception); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function query() | ||||
|     { | ||||
|         $args = func_get_args(); | ||||
|         $argsCount = count($args); | ||||
|  | ||||
|         try { | ||||
|             if ($argsCount == 4) { | ||||
|                 return parent::query($args[0], $args[1], $args[2], $args[3]); | ||||
|             } | ||||
|  | ||||
|             if ($argsCount == 3) { | ||||
|                 return parent::query($args[0], $args[1], $args[2]); | ||||
|             } | ||||
|  | ||||
|             if ($argsCount == 2) { | ||||
|                 return parent::query($args[0], $args[1]); | ||||
|             } | ||||
|  | ||||
|             return parent::query($args[0]); | ||||
|         } catch (\PDOException $exception) { | ||||
|             throw new PDOException($exception); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function quote($input, $type = ParameterType::STRING) | ||||
|     { | ||||
|         return parent::quote($input, $type); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function lastInsertId($name = null) | ||||
|     { | ||||
|         return parent::lastInsertId($name); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function requiresQueryForServerVersion() | ||||
|     { | ||||
|         return false; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										75
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/PDOException.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										75
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/PDOException.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,75 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Driver; | ||||
|  | ||||
| /** | ||||
|  * Tiny wrapper for PDOException instances to implement the {@link DriverException} interface. | ||||
|  * | ||||
|  * @author Steve Müller <st.mueller@dzh-online.de> | ||||
|  * @link   www.doctrine-project.org | ||||
|  * @since  2.5 | ||||
|  */ | ||||
| class PDOException extends \PDOException implements DriverException | ||||
| { | ||||
|     /** | ||||
|      * The driver specific error code. | ||||
|      * | ||||
|      * @var int|string|null | ||||
|      */ | ||||
|     private $errorCode; | ||||
|  | ||||
|     /** | ||||
|      * The SQLSTATE of the driver. | ||||
|      * | ||||
|      * @var string|null | ||||
|      */ | ||||
|     private $sqlState; | ||||
|  | ||||
|     /** | ||||
|      * Constructor. | ||||
|      * | ||||
|      * @param \PDOException $exception The PDO exception to wrap. | ||||
|      */ | ||||
|     public function __construct(\PDOException $exception) | ||||
|     { | ||||
|         parent::__construct($exception->getMessage(), 0, $exception); | ||||
|  | ||||
|         $this->code      = $exception->getCode(); | ||||
|         $this->errorInfo = $exception->errorInfo; | ||||
|         $this->errorCode = $exception->errorInfo[1] ?? $exception->getCode(); | ||||
|         $this->sqlState  = $exception->errorInfo[0] ?? $exception->getCode(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function getErrorCode() | ||||
|     { | ||||
|         return $this->errorCode; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function getSQLState() | ||||
|     { | ||||
|         return $this->sqlState; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										83
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/PDOIbm/Driver.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										83
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/PDOIbm/Driver.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,83 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Driver\PDOIbm; | ||||
|  | ||||
| use Doctrine\DBAL\Driver\AbstractDB2Driver; | ||||
| use Doctrine\DBAL\Driver\PDOConnection; | ||||
|  | ||||
| /** | ||||
|  * Driver for the PDO IBM extension. | ||||
|  * | ||||
|  * @link   www.doctrine-project.org | ||||
|  * @since  1.0 | ||||
|  * @author Benjamin Eberlei <kontakt@beberlei.de> | ||||
|  * @author Guilherme Blanco <guilhermeblanco@hotmail.com> | ||||
|  * @author Jonathan Wage <jonwage@gmail.com> | ||||
|  * @author Roman Borschel <roman@code-factory.org> | ||||
|  */ | ||||
| class Driver extends AbstractDB2Driver | ||||
| { | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function connect(array $params, $username = null, $password = null, array $driverOptions = []) | ||||
|     { | ||||
|         $conn = new PDOConnection( | ||||
|             $this->_constructPdoDsn($params), | ||||
|             $username, | ||||
|             $password, | ||||
|             $driverOptions | ||||
|         ); | ||||
|  | ||||
|         return $conn; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Constructs the IBM PDO DSN. | ||||
|      * | ||||
|      * @param array $params | ||||
|      * | ||||
|      * @return string The DSN. | ||||
|      */ | ||||
|     private function _constructPdoDsn(array $params) | ||||
|     { | ||||
|         $dsn = 'ibm:'; | ||||
|         if (isset($params['host'])) { | ||||
|             $dsn .= 'HOSTNAME=' . $params['host'] . ';'; | ||||
|         } | ||||
|         if (isset($params['port'])) { | ||||
|             $dsn .= 'PORT=' . $params['port'] . ';'; | ||||
|         } | ||||
|         $dsn .= 'PROTOCOL=TCPIP;'; | ||||
|         if (isset($params['dbname'])) { | ||||
|             $dsn .= 'DATABASE=' . $params['dbname'] . ';'; | ||||
|         } | ||||
|  | ||||
|         return $dsn; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function getName() | ||||
|     { | ||||
|         return 'pdo_ibm'; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										89
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/PDOMySql/Driver.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										89
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/PDOMySql/Driver.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,89 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Driver\PDOMySql; | ||||
|  | ||||
| use Doctrine\DBAL\DBALException; | ||||
| use Doctrine\DBAL\Driver\AbstractMySQLDriver; | ||||
| use Doctrine\DBAL\Driver\PDOConnection; | ||||
| use PDOException; | ||||
|  | ||||
| /** | ||||
|  * PDO MySql driver. | ||||
|  * | ||||
|  * @since 2.0 | ||||
|  */ | ||||
| class Driver extends AbstractMySQLDriver | ||||
| { | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function connect(array $params, $username = null, $password = null, array $driverOptions = []) | ||||
|     { | ||||
|         try { | ||||
|             $conn = new PDOConnection( | ||||
|                 $this->constructPdoDsn($params), | ||||
|                 $username, | ||||
|                 $password, | ||||
|                 $driverOptions | ||||
|             ); | ||||
|         } catch (PDOException $e) { | ||||
|             throw DBALException::driverException($this, $e); | ||||
|         } | ||||
|  | ||||
|         return $conn; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Constructs the MySql PDO DSN. | ||||
|      * | ||||
|      * @param array $params | ||||
|      * | ||||
|      * @return string The DSN. | ||||
|      */ | ||||
|     protected function constructPdoDsn(array $params) | ||||
|     { | ||||
|         $dsn = 'mysql:'; | ||||
|         if (isset($params['host']) && $params['host'] != '') { | ||||
|             $dsn .= 'host=' . $params['host'] . ';'; | ||||
|         } | ||||
|         if (isset($params['port'])) { | ||||
|             $dsn .= 'port=' . $params['port'] . ';'; | ||||
|         } | ||||
|         if (isset($params['dbname'])) { | ||||
|             $dsn .= 'dbname=' . $params['dbname'] . ';'; | ||||
|         } | ||||
|         if (isset($params['unix_socket'])) { | ||||
|             $dsn .= 'unix_socket=' . $params['unix_socket'] . ';'; | ||||
|         } | ||||
|         if (isset($params['charset'])) { | ||||
|             $dsn .= 'charset=' . $params['charset'] . ';'; | ||||
|         } | ||||
|  | ||||
|         return $dsn; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function getName() | ||||
|     { | ||||
|         return 'pdo_mysql'; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										78
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/PDOOracle/Driver.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										78
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/PDOOracle/Driver.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,78 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Driver\PDOOracle; | ||||
|  | ||||
| use Doctrine\DBAL\DBALException; | ||||
| use Doctrine\DBAL\Driver\AbstractOracleDriver; | ||||
| use Doctrine\DBAL\Driver\PDOConnection; | ||||
|  | ||||
| /** | ||||
|  * PDO Oracle driver. | ||||
|  * | ||||
|  * WARNING: This driver gives us segfaults in our testsuites on CLOB and other | ||||
|  * stuff. PDO Oracle is not maintained by Oracle or anyone in the PHP community, | ||||
|  * which leads us to the recommendation to use the "oci8" driver to connect | ||||
|  * to Oracle instead. | ||||
|  */ | ||||
| class Driver extends AbstractOracleDriver | ||||
| { | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function connect(array $params, $username = null, $password = null, array $driverOptions = []) | ||||
|     { | ||||
|         try { | ||||
|             return new PDOConnection( | ||||
|                 $this->constructPdoDsn($params), | ||||
|                 $username, | ||||
|                 $password, | ||||
|                 $driverOptions | ||||
|             ); | ||||
|         } catch (\PDOException $e) { | ||||
|             throw DBALException::driverException($this, $e); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Constructs the Oracle PDO DSN. | ||||
|      * | ||||
|      * @param array $params | ||||
|      * | ||||
|      * @return string The DSN. | ||||
|      */ | ||||
|     private function constructPdoDsn(array $params) | ||||
|     { | ||||
|         $dsn = 'oci:dbname=' . $this->getEasyConnectString($params); | ||||
|  | ||||
|         if (isset($params['charset'])) { | ||||
|             $dsn .= ';charset=' . $params['charset']; | ||||
|         } | ||||
|  | ||||
|         return $dsn; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function getName() | ||||
|     { | ||||
|         return 'pdo_oracle'; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										135
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/PDOPgSql/Driver.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										135
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/PDOPgSql/Driver.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,135 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Driver\PDOPgSql; | ||||
|  | ||||
| use Doctrine\DBAL\Driver\AbstractPostgreSQLDriver; | ||||
| use Doctrine\DBAL\Driver\PDOConnection; | ||||
| use Doctrine\DBAL\DBALException; | ||||
| use PDOException; | ||||
| use PDO; | ||||
| use function defined; | ||||
|  | ||||
| /** | ||||
|  * Driver that connects through pdo_pgsql. | ||||
|  * | ||||
|  * @since 2.0 | ||||
|  */ | ||||
| class Driver extends AbstractPostgreSQLDriver | ||||
| { | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function connect(array $params, $username = null, $password = null, array $driverOptions = []) | ||||
|     { | ||||
|         try { | ||||
|             $pdo = new PDOConnection( | ||||
|                 $this->_constructPdoDsn($params), | ||||
|                 $username, | ||||
|                 $password, | ||||
|                 $driverOptions | ||||
|             ); | ||||
|  | ||||
|             if (defined('PDO::PGSQL_ATTR_DISABLE_PREPARES') | ||||
|                 && (! isset($driverOptions[PDO::PGSQL_ATTR_DISABLE_PREPARES]) | ||||
|                     || true === $driverOptions[PDO::PGSQL_ATTR_DISABLE_PREPARES] | ||||
|                 ) | ||||
|             ) { | ||||
|                 $pdo->setAttribute(PDO::PGSQL_ATTR_DISABLE_PREPARES, true); | ||||
|             } | ||||
|  | ||||
|             /* defining client_encoding via SET NAMES to avoid inconsistent DSN support | ||||
|              * - the 'client_encoding' connection param only works with postgres >= 9.1 | ||||
|              * - passing client_encoding via the 'options' param breaks pgbouncer support | ||||
|              */ | ||||
|             if (isset($params['charset'])) { | ||||
|                 $pdo->exec('SET NAMES \'' . $params['charset'] . '\''); | ||||
|             } | ||||
|  | ||||
|             return $pdo; | ||||
|         } catch (PDOException $e) { | ||||
|             throw DBALException::driverException($this, $e); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Constructs the Postgres PDO DSN. | ||||
|      * | ||||
|      * @param array $params | ||||
|      * | ||||
|      * @return string The DSN. | ||||
|      */ | ||||
|     private function _constructPdoDsn(array $params) | ||||
|     { | ||||
|         $dsn = 'pgsql:'; | ||||
|  | ||||
|         if (isset($params['host']) && $params['host'] != '') { | ||||
|             $dsn .= 'host=' . $params['host'] . ';'; | ||||
|         } | ||||
|  | ||||
|         if (isset($params['port']) && $params['port'] != '') { | ||||
|             $dsn .= 'port=' . $params['port'] . ';'; | ||||
|         } | ||||
|  | ||||
|         if (isset($params['dbname'])) { | ||||
|             $dsn .= 'dbname=' . $params['dbname'] . ';'; | ||||
|         } elseif (isset($params['default_dbname'])) { | ||||
|             $dsn .= 'dbname=' . $params['default_dbname'] . ';'; | ||||
|         } else { | ||||
|             // Used for temporary connections to allow operations like dropping the database currently connected to. | ||||
|             // Connecting without an explicit database does not work, therefore "postgres" database is used | ||||
|             // as it is mostly present in every server setup. | ||||
|             $dsn .= 'dbname=postgres' . ';'; | ||||
|         } | ||||
|  | ||||
|         if (isset($params['sslmode'])) { | ||||
|             $dsn .= 'sslmode=' . $params['sslmode'] . ';'; | ||||
|         } | ||||
|  | ||||
|         if (isset($params['sslrootcert'])) { | ||||
|             $dsn .= 'sslrootcert=' . $params['sslrootcert'] . ';'; | ||||
|         } | ||||
|  | ||||
|         if (isset($params['sslcert'])) { | ||||
|             $dsn .= 'sslcert=' . $params['sslcert'] . ';'; | ||||
|         } | ||||
|  | ||||
|         if (isset($params['sslkey'])) { | ||||
|             $dsn .= 'sslkey=' . $params['sslkey'] . ';'; | ||||
|         } | ||||
|  | ||||
|         if (isset($params['sslcrl'])) { | ||||
|             $dsn .= 'sslcrl=' . $params['sslcrl'] . ';'; | ||||
|         } | ||||
|  | ||||
|         if (isset($params['application_name'])) { | ||||
|             $dsn .= 'application_name=' . $params['application_name'] . ';'; | ||||
|         } | ||||
|  | ||||
|         return $dsn; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function getName() | ||||
|     { | ||||
|         return 'pdo_pgsql'; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										99
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/PDOSqlite/Driver.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										99
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/PDOSqlite/Driver.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,99 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Driver\PDOSqlite; | ||||
|  | ||||
| use Doctrine\DBAL\DBALException; | ||||
| use Doctrine\DBAL\Driver\AbstractSQLiteDriver; | ||||
| use Doctrine\DBAL\Driver\PDOConnection; | ||||
| use PDOException; | ||||
| use function array_merge; | ||||
|  | ||||
| /** | ||||
|  * The PDO Sqlite driver. | ||||
|  * | ||||
|  * @since 2.0 | ||||
|  */ | ||||
| class Driver extends AbstractSQLiteDriver | ||||
| { | ||||
|     /** | ||||
|      * @var array | ||||
|      */ | ||||
|     protected $_userDefinedFunctions = [ | ||||
|         'sqrt' => ['callback' => ['Doctrine\DBAL\Platforms\SqlitePlatform', 'udfSqrt'], 'numArgs' => 1], | ||||
|         'mod'  => ['callback' => ['Doctrine\DBAL\Platforms\SqlitePlatform', 'udfMod'], 'numArgs' => 2], | ||||
|         'locate'  => ['callback' => ['Doctrine\DBAL\Platforms\SqlitePlatform', 'udfLocate'], 'numArgs' => -1], | ||||
|     ]; | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function connect(array $params, $username = null, $password = null, array $driverOptions = []) | ||||
|     { | ||||
|         if (isset($driverOptions['userDefinedFunctions'])) { | ||||
|             $this->_userDefinedFunctions = array_merge( | ||||
|                 $this->_userDefinedFunctions, $driverOptions['userDefinedFunctions']); | ||||
|             unset($driverOptions['userDefinedFunctions']); | ||||
|         } | ||||
|  | ||||
|         try { | ||||
|             $pdo = new PDOConnection( | ||||
|                 $this->_constructPdoDsn($params), | ||||
|                 $username, | ||||
|                 $password, | ||||
|                 $driverOptions | ||||
|             ); | ||||
|         } catch (PDOException $ex) { | ||||
|             throw DBALException::driverException($this, $ex); | ||||
|         } | ||||
|  | ||||
|         foreach ($this->_userDefinedFunctions as $fn => $data) { | ||||
|             $pdo->sqliteCreateFunction($fn, $data['callback'], $data['numArgs']); | ||||
|         } | ||||
|  | ||||
|         return $pdo; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Constructs the Sqlite PDO DSN. | ||||
|      * | ||||
|      * @param array $params | ||||
|      * | ||||
|      * @return string The DSN. | ||||
|      */ | ||||
|     protected function _constructPdoDsn(array $params) | ||||
|     { | ||||
|         $dsn = 'sqlite:'; | ||||
|         if (isset($params['path'])) { | ||||
|             $dsn .= $params['path']; | ||||
|         } elseif (isset($params['memory'])) { | ||||
|             $dsn .= ':memory:'; | ||||
|         } | ||||
|  | ||||
|         return $dsn; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function getName() | ||||
|     { | ||||
|         return 'pdo_sqlite'; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										72
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/PDOSqlsrv/Connection.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										72
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/PDOSqlsrv/Connection.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,72 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Driver\PDOSqlsrv; | ||||
|  | ||||
| use Doctrine\DBAL\Driver\PDOConnection; | ||||
| use Doctrine\DBAL\ParameterType; | ||||
| use function strpos; | ||||
| use function substr; | ||||
|  | ||||
| /** | ||||
|  * Sqlsrv Connection implementation. | ||||
|  * | ||||
|  * @since 2.0 | ||||
|  */ | ||||
| class Connection extends PDOConnection implements \Doctrine\DBAL\Driver\Connection | ||||
| { | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function __construct($dsn, $user = null, $password = null, array $options = null) | ||||
|     { | ||||
|         parent::__construct($dsn, $user, $password, $options); | ||||
|         $this->setAttribute(\PDO::ATTR_STATEMENT_CLASS, [Statement::class, []]); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritDoc} | ||||
|      */ | ||||
|     public function lastInsertId($name = null) | ||||
|     { | ||||
|         if (null === $name) { | ||||
|             return parent::lastInsertId($name); | ||||
|         } | ||||
|  | ||||
|         $stmt = $this->prepare('SELECT CONVERT(VARCHAR(MAX), current_value) FROM sys.sequences WHERE name = ?'); | ||||
|         $stmt->execute([$name]); | ||||
|  | ||||
|         return $stmt->fetchColumn(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritDoc} | ||||
|      */ | ||||
|     public function quote($value, $type = ParameterType::STRING) | ||||
|     { | ||||
|         $val = parent::quote($value, $type); | ||||
|  | ||||
|         // Fix for a driver version terminating all values with null byte | ||||
|         if (strpos($val, "\0") !== false) { | ||||
|             $val = substr($val, 0, -1); | ||||
|         } | ||||
|  | ||||
|         return $val; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										126
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/PDOSqlsrv/Driver.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										126
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/PDOSqlsrv/Driver.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,126 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Driver\PDOSqlsrv; | ||||
|  | ||||
| use Doctrine\DBAL\Driver\AbstractSQLServerDriver; | ||||
| use function is_int; | ||||
| use function sprintf; | ||||
|  | ||||
| /** | ||||
|  * The PDO-based Sqlsrv driver. | ||||
|  * | ||||
|  * @since 2.0 | ||||
|  */ | ||||
| class Driver extends AbstractSQLServerDriver | ||||
| { | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function connect(array $params, $username = null, $password = null, array $driverOptions = []) | ||||
|     { | ||||
|         [$driverOptions, $connectionOptions] = $this->splitOptions($driverOptions); | ||||
|  | ||||
|         return new Connection( | ||||
|             $this->_constructPdoDsn($params, $connectionOptions), | ||||
|             $username, | ||||
|             $password, | ||||
|             $driverOptions | ||||
|         ); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Constructs the Sqlsrv PDO DSN. | ||||
|      * | ||||
|      * @param array $params | ||||
|      * @param string[] $connectionOptions | ||||
|      * | ||||
|      * @return string The DSN. | ||||
|      */ | ||||
|     private function _constructPdoDsn(array $params, array $connectionOptions) | ||||
|     { | ||||
|         $dsn = 'sqlsrv:server='; | ||||
|  | ||||
|         if (isset($params['host'])) { | ||||
|             $dsn .= $params['host']; | ||||
|         } | ||||
|  | ||||
|         if (isset($params['port']) && !empty($params['port'])) { | ||||
|             $dsn .= ',' . $params['port']; | ||||
|         } | ||||
|  | ||||
|         if (isset($params['dbname'])) { | ||||
|             $connectionOptions['Database'] = $params['dbname']; | ||||
|         } | ||||
|  | ||||
|         if (isset($params['MultipleActiveResultSets'])) { | ||||
|             $connectionOptions['MultipleActiveResultSets'] = $params['MultipleActiveResultSets'] ? 'true' : 'false'; | ||||
|         } | ||||
|  | ||||
|         $dsn .= $this->getConnectionOptionsDsn($connectionOptions); | ||||
|  | ||||
|         return $dsn; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Separates a connection options from a driver options | ||||
|      * | ||||
|      * @param int[]|string[] $options | ||||
|      * @return int[][]|string[][] | ||||
|      */ | ||||
|     private function splitOptions(array $options) : array | ||||
|     { | ||||
|         $driverOptions     = []; | ||||
|         $connectionOptions = []; | ||||
|  | ||||
|         foreach ($options as $optionKey => $optionValue) { | ||||
|             if (is_int($optionKey)) { | ||||
|                 $driverOptions[$optionKey] = $optionValue; | ||||
|             } else { | ||||
|                 $connectionOptions[$optionKey] = $optionValue; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         return [$driverOptions, $connectionOptions]; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Converts a connection options array to the DSN | ||||
|      * | ||||
|      * @param string[] $connectionOptions | ||||
|      */ | ||||
|     private function getConnectionOptionsDsn(array $connectionOptions) : string | ||||
|     { | ||||
|         $connectionOptionsDsn = ''; | ||||
|  | ||||
|         foreach ($connectionOptions as $paramName => $paramValue) { | ||||
|             $connectionOptionsDsn .= sprintf(';%s=%s', $paramName, $paramValue); | ||||
|         } | ||||
|  | ||||
|         return $connectionOptionsDsn; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function getName() | ||||
|     { | ||||
|         return 'pdo_sqlsrv'; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										52
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/PDOSqlsrv/Statement.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										52
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/PDOSqlsrv/Statement.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,52 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Driver\PDOSqlsrv; | ||||
|  | ||||
| use Doctrine\DBAL\Driver\PDOStatement; | ||||
| use Doctrine\DBAL\ParameterType; | ||||
| use PDO; | ||||
|  | ||||
| /** | ||||
|  * PDO SQL Server Statement | ||||
|  */ | ||||
| class Statement extends PDOStatement | ||||
| { | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function bindParam($column, &$variable, $type = ParameterType::STRING, $length = null, $driverOptions = null) | ||||
|     { | ||||
|         if (($type === ParameterType::LARGE_OBJECT || $type === ParameterType::BINARY) | ||||
|             && $driverOptions === null | ||||
|         ) { | ||||
|             $driverOptions = PDO::SQLSRV_ENCODING_BINARY; | ||||
|         } | ||||
|  | ||||
|         return parent::bindParam($column, $variable, $type, $length, $driverOptions); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function bindValue($param, $value, $type = ParameterType::STRING) | ||||
|     { | ||||
|         return $this->bindParam($param, $value, $type); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										256
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/PDOStatement.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										256
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/PDOStatement.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,256 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Driver; | ||||
|  | ||||
| use Doctrine\DBAL\FetchMode; | ||||
| use Doctrine\DBAL\ParameterType; | ||||
| use PDO; | ||||
| use const E_USER_DEPRECATED; | ||||
| use function sprintf; | ||||
| use function trigger_error; | ||||
|  | ||||
| /** | ||||
|  * The PDO implementation of the Statement interface. | ||||
|  * Used by all PDO-based drivers. | ||||
|  * | ||||
|  * @since 2.0 | ||||
|  */ | ||||
| class PDOStatement extends \PDOStatement implements Statement | ||||
| { | ||||
|     /** | ||||
|      * @var int[] | ||||
|      */ | ||||
|     private const PARAM_TYPE_MAP = [ | ||||
|         ParameterType::NULL         => PDO::PARAM_NULL, | ||||
|         ParameterType::INTEGER      => PDO::PARAM_INT, | ||||
|         ParameterType::STRING       => PDO::PARAM_STR, | ||||
|         ParameterType::BINARY       => PDO::PARAM_LOB, | ||||
|         ParameterType::LARGE_OBJECT => PDO::PARAM_LOB, | ||||
|         ParameterType::BOOLEAN      => PDO::PARAM_BOOL, | ||||
|     ]; | ||||
|  | ||||
|     /** | ||||
|      * @var int[] | ||||
|      */ | ||||
|     private const FETCH_MODE_MAP = [ | ||||
|         FetchMode::ASSOCIATIVE     => PDO::FETCH_ASSOC, | ||||
|         FetchMode::NUMERIC         => PDO::FETCH_NUM, | ||||
|         FetchMode::MIXED           => PDO::FETCH_BOTH, | ||||
|         FetchMode::STANDARD_OBJECT => PDO::FETCH_OBJ, | ||||
|         FetchMode::COLUMN          => PDO::FETCH_COLUMN, | ||||
|         FetchMode::CUSTOM_OBJECT   => PDO::FETCH_CLASS, | ||||
|     ]; | ||||
|  | ||||
|     /** | ||||
|      * Protected constructor. | ||||
|      */ | ||||
|     protected function __construct() | ||||
|     { | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function setFetchMode($fetchMode, $arg2 = null, $arg3 = null) | ||||
|     { | ||||
|         $fetchMode = $this->convertFetchMode($fetchMode); | ||||
|  | ||||
|         // This thin wrapper is necessary to shield against the weird signature | ||||
|         // of PDOStatement::setFetchMode(): even if the second and third | ||||
|         // parameters are optional, PHP will not let us remove it from this | ||||
|         // declaration. | ||||
|         try { | ||||
|             if ($arg2 === null && $arg3 === null) { | ||||
|                 return parent::setFetchMode($fetchMode); | ||||
|             } | ||||
|  | ||||
|             if ($arg3 === null) { | ||||
|                 return parent::setFetchMode($fetchMode, $arg2); | ||||
|             } | ||||
|  | ||||
|             return parent::setFetchMode($fetchMode, $arg2, $arg3); | ||||
|         } catch (\PDOException $exception) { | ||||
|             throw new PDOException($exception); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function bindValue($param, $value, $type = ParameterType::STRING) | ||||
|     { | ||||
|         $type = $this->convertParamType($type); | ||||
|  | ||||
|         try { | ||||
|             return parent::bindValue($param, $value, $type); | ||||
|         } catch (\PDOException $exception) { | ||||
|             throw new PDOException($exception); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function bindParam($column, &$variable, $type = ParameterType::STRING, $length = null, $driverOptions = null) | ||||
|     { | ||||
|         $type = $this->convertParamType($type); | ||||
|  | ||||
|         try { | ||||
|             return parent::bindParam($column, $variable, $type, $length, $driverOptions); | ||||
|         } catch (\PDOException $exception) { | ||||
|             throw new PDOException($exception); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function closeCursor() | ||||
|     { | ||||
|         try { | ||||
|             return parent::closeCursor(); | ||||
|         } catch (\PDOException $exception) { | ||||
|             // Exceptions not allowed by the interface. | ||||
|             // In case driver implementations do not adhere to the interface, silence exceptions here. | ||||
|             return true; | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function execute($params = null) | ||||
|     { | ||||
|         try { | ||||
|             return parent::execute($params); | ||||
|         } catch (\PDOException $exception) { | ||||
|             throw new PDOException($exception); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function fetch($fetchMode = null, $cursorOrientation = \PDO::FETCH_ORI_NEXT, $cursorOffset = 0) | ||||
|     { | ||||
|         $fetchMode = $this->convertFetchMode($fetchMode); | ||||
|  | ||||
|         try { | ||||
|             if ($fetchMode === null && \PDO::FETCH_ORI_NEXT === $cursorOrientation && 0 === $cursorOffset) { | ||||
|                 return parent::fetch(); | ||||
|             } | ||||
|  | ||||
|             if (\PDO::FETCH_ORI_NEXT === $cursorOrientation && 0 === $cursorOffset) { | ||||
|                 return parent::fetch($fetchMode); | ||||
|             } | ||||
|  | ||||
|             if (0 === $cursorOffset) { | ||||
|                 return parent::fetch($fetchMode, $cursorOrientation); | ||||
|             } | ||||
|  | ||||
|             return parent::fetch($fetchMode, $cursorOrientation, $cursorOffset); | ||||
|         } catch (\PDOException $exception) { | ||||
|             throw new PDOException($exception); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function fetchAll($fetchMode = null, $fetchArgument = null, $ctorArgs = null) | ||||
|     { | ||||
|         $fetchMode = $this->convertFetchMode($fetchMode); | ||||
|  | ||||
|         try { | ||||
|             if ($fetchMode === null && null === $fetchArgument && null === $ctorArgs) { | ||||
|                 return parent::fetchAll(); | ||||
|             } | ||||
|  | ||||
|             if (null === $fetchArgument && null === $ctorArgs) { | ||||
|                 return parent::fetchAll($fetchMode); | ||||
|             } | ||||
|  | ||||
|             if (null === $ctorArgs) { | ||||
|                 return parent::fetchAll($fetchMode, $fetchArgument); | ||||
|             } | ||||
|  | ||||
|             return parent::fetchAll($fetchMode, $fetchArgument, $ctorArgs); | ||||
|         } catch (\PDOException $exception) { | ||||
|             throw new PDOException($exception); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function fetchColumn($columnIndex = 0) | ||||
|     { | ||||
|         try { | ||||
|             return parent::fetchColumn($columnIndex); | ||||
|         } catch (\PDOException $exception) { | ||||
|             throw new PDOException($exception); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Converts DBAL parameter type to PDO parameter type | ||||
|      * | ||||
|      * @param int $type Parameter type | ||||
|      */ | ||||
|     private function convertParamType(int $type) : int | ||||
|     { | ||||
|         if (! isset(self::PARAM_TYPE_MAP[$type])) { | ||||
|             // TODO: next major: throw an exception | ||||
|             @trigger_error(sprintf( | ||||
|                 'Using a PDO parameter type (%d given) is deprecated and will cause an error in Doctrine 3.0', | ||||
|                 $type | ||||
|             ), E_USER_DEPRECATED); | ||||
|  | ||||
|             return $type; | ||||
|         } | ||||
|  | ||||
|         return self::PARAM_TYPE_MAP[$type]; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Converts DBAL fetch mode to PDO fetch mode | ||||
|      * | ||||
|      * @param int|null $fetchMode Fetch mode | ||||
|      */ | ||||
|     private function convertFetchMode(?int $fetchMode) : ?int | ||||
|     { | ||||
|         if ($fetchMode === null) { | ||||
|             return null; | ||||
|         } | ||||
|  | ||||
|         if (! isset(self::FETCH_MODE_MAP[$fetchMode])) { | ||||
|             // TODO: next major: throw an exception | ||||
|             @trigger_error(sprintf( | ||||
|                 'Using a PDO fetch mode or their combination (%d given)' . | ||||
|                 ' is deprecated and will cause an error in Doctrine 3.0', | ||||
|                 $fetchMode | ||||
|             ), E_USER_DEPRECATED); | ||||
|  | ||||
|             return $fetchMode; | ||||
|         } | ||||
|  | ||||
|         return self::FETCH_MODE_MAP[$fetchMode]; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										39
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/PingableConnection.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										39
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/PingableConnection.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,39 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Driver; | ||||
|  | ||||
| /** | ||||
|  * An interface for connections which support a "native" ping method. | ||||
|  * | ||||
|  * @link   www.doctrine-project.org | ||||
|  * @since  2.5 | ||||
|  * @author Till Klampaeckel <till@php.net> | ||||
|  * @author Benjamin Eberlei <kontakt@beberlei.de> | ||||
|  */ | ||||
| interface PingableConnection | ||||
| { | ||||
|     /** | ||||
|      * Pings the database server to determine if the connection is still | ||||
|      * available. Return true/false based on if that was successful or not. | ||||
|      * | ||||
|      * @return bool | ||||
|      */ | ||||
|     public function ping(); | ||||
| } | ||||
							
								
								
									
										115
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/ResultStatement.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										115
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/ResultStatement.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,115 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Driver; | ||||
|  | ||||
| /** | ||||
|  * Interface for the reading part of a prepare statement only. | ||||
|  * | ||||
|  * @author Benjamin Eberlei <kontakt@beberlei.de> | ||||
|  */ | ||||
| interface ResultStatement extends \Traversable | ||||
| { | ||||
|     /** | ||||
|      * Closes the cursor, enabling the statement to be executed again. | ||||
|      * | ||||
|      * @return bool TRUE on success or FALSE on failure. | ||||
|      */ | ||||
|     public function closeCursor(); | ||||
|  | ||||
|     /** | ||||
|      * Returns the number of columns in the result set | ||||
|      * | ||||
|      * @return int The number of columns in the result set represented | ||||
|      *                 by the PDOStatement object. If there is no result set, | ||||
|      *                 this method should return 0. | ||||
|      */ | ||||
|     public function columnCount(); | ||||
|  | ||||
|     /** | ||||
|      * Sets the fetch mode to use while iterating this statement. | ||||
|      * | ||||
|      * @param int   $fetchMode The fetch mode must be one of the {@link \Doctrine\DBAL\FetchMode} constants. | ||||
|      * @param mixed $arg2 | ||||
|      * @param mixed $arg3 | ||||
|      * | ||||
|      * @return bool | ||||
|      */ | ||||
|     public function setFetchMode($fetchMode, $arg2 = null, $arg3 = null); | ||||
|  | ||||
|     /** | ||||
|      * Returns the next row of a result set. | ||||
|      * | ||||
|      * @param int|null $fetchMode         Controls how the next row will be returned to the caller. | ||||
|      *                                    The value must be one of the {@link \Doctrine\DBAL\FetchMode} constants, | ||||
|      *                                    defaulting to {@link \Doctrine\DBAL\FetchMode::MIXED}. | ||||
|      * @param int      $cursorOrientation For a ResultStatement object representing a scrollable cursor, | ||||
|      *                                    this value determines which row will be returned to the caller. | ||||
|      *                                    This value must be one of the \PDO::FETCH_ORI_* constants, | ||||
|      *                                    defaulting to \PDO::FETCH_ORI_NEXT. To request a scrollable | ||||
|      *                                    cursor for your ResultStatement object, you must set the \PDO::ATTR_CURSOR | ||||
|      *                                    attribute to \PDO::CURSOR_SCROLL when you prepare the SQL statement with | ||||
|      *                                    \PDO::prepare(). | ||||
|      * @param int      $cursorOffset      For a ResultStatement object representing a scrollable cursor for which the | ||||
|      *                                    cursorOrientation parameter is set to \PDO::FETCH_ORI_ABS, this value | ||||
|      *                                    specifies the absolute number of the row in the result set that shall be | ||||
|      *                                    fetched. | ||||
|      *                                    For a ResultStatement object representing a scrollable cursor for which the | ||||
|      *                                    cursorOrientation parameter is set to \PDO::FETCH_ORI_REL, this value | ||||
|      *                                    specifies the row to fetch relative to the cursor position before | ||||
|      *                                    ResultStatement::fetch() was called. | ||||
|      * | ||||
|      * @return mixed The return value of this method on success depends on the fetch mode. In all cases, FALSE is | ||||
|      *               returned on failure. | ||||
|      */ | ||||
|     public function fetch($fetchMode = null, $cursorOrientation = \PDO::FETCH_ORI_NEXT, $cursorOffset = 0); | ||||
|  | ||||
|     /** | ||||
|      * Returns an array containing all of the result set rows. | ||||
|      * | ||||
|      * @param int|null   $fetchMode     Controls how the next row will be returned to the caller. | ||||
|      *                                  The value must be one of the {@link \Doctrine\DBAL\FetchMode} constants, | ||||
|      *                                  defaulting to {@link \Doctrine\DBAL\FetchMode::MIXED}. | ||||
|      * @param int|null   $fetchArgument This argument has a different meaning depending on the value of the $fetchMode parameter: | ||||
|      *                                  * {@link \Doctrine\DBAL\FetchMode::COLUMN}: | ||||
|      *                                    Returns the indicated 0-indexed column. | ||||
|      *                                  * {@link \Doctrine\DBAL\FetchMode::CUSTOM_OBJECT}: | ||||
|      *                                    Returns instances of the specified class, mapping the columns of each row | ||||
|      *                                    to named properties in the class. | ||||
|      *                                  * \PDO::FETCH_FUNC: Returns the results of calling the specified function, using each row's | ||||
|      *                                    columns as parameters in the call. | ||||
|      * @param array|null $ctorArgs      Controls how the next row will be returned to the caller. | ||||
|      *                                  The value must be one of the {@link \Doctrine\DBAL\FetchMode} constants, | ||||
|      *                                  defaulting to {@link \Doctrine\DBAL\FetchMode::MIXED}. | ||||
|      * | ||||
|      * @return array | ||||
|      */ | ||||
|     public function fetchAll($fetchMode = null, $fetchArgument = null, $ctorArgs = null); | ||||
|  | ||||
|     /** | ||||
|      * Returns a single column from the next row of a result set or FALSE if there are no more rows. | ||||
|      * | ||||
|      * @param int $columnIndex 0-indexed number of the column you wish to retrieve from the row. | ||||
|      *                         If no value is supplied, PDOStatement->fetchColumn() | ||||
|      *                         fetches the first column. | ||||
|      * | ||||
|      * @return string|boolean A single column in the next row of a result set, or FALSE if there are no more rows. | ||||
|      */ | ||||
|     public function fetchColumn($columnIndex = 0); | ||||
| } | ||||
							
								
								
									
										107
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/SQLAnywhere/Driver.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										107
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/SQLAnywhere/Driver.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,107 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Driver\SQLAnywhere; | ||||
|  | ||||
| use Doctrine\DBAL\DBALException; | ||||
| use Doctrine\DBAL\Driver\AbstractSQLAnywhereDriver; | ||||
| use function array_keys; | ||||
| use function array_map; | ||||
| use function implode; | ||||
|  | ||||
| /** | ||||
|  * A Doctrine DBAL driver for the SAP Sybase SQL Anywhere PHP extension. | ||||
|  * | ||||
|  * @author Steve Müller <st.mueller@dzh-online.de> | ||||
|  * @link   www.doctrine-project.org | ||||
|  * @since  2.5 | ||||
|  */ | ||||
| class Driver extends AbstractSQLAnywhereDriver | ||||
| { | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      * | ||||
|      * @throws \Doctrine\DBAL\DBALException if there was a problem establishing the connection. | ||||
|      */ | ||||
|     public function connect(array $params, $username = null, $password = null, array $driverOptions = []) | ||||
|     { | ||||
|         try { | ||||
|             return new SQLAnywhereConnection( | ||||
|                 $this->buildDsn( | ||||
|                     $params['host'] ?? null, | ||||
|                     $params['port'] ?? null, | ||||
|                     $params['server'] ?? null, | ||||
|                     $params['dbname'] ?? null, | ||||
|                     $username, | ||||
|                     $password, | ||||
|                     $driverOptions | ||||
|                 ), | ||||
|                 $params['persistent'] ?? false | ||||
|             ); | ||||
|         } catch (SQLAnywhereException $e) { | ||||
|             throw DBALException::driverException($this, $e); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function getName() | ||||
|     { | ||||
|         return 'sqlanywhere'; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Build the connection string for given connection parameters and driver options. | ||||
|      * | ||||
|      * @param string $host          Host address to connect to. | ||||
|      * @param int    $port          Port to use for the connection (default to SQL Anywhere standard port 2638). | ||||
|      * @param string $server        Database server name on the host to connect to. | ||||
|      *                              SQL Anywhere allows multiple database server instances on the same host, | ||||
|      *                              therefore specifying the server instance name to use is mandatory. | ||||
|      * @param string $dbname        Name of the database on the server instance to connect to. | ||||
|      * @param string $username      User name to use for connection authentication. | ||||
|      * @param string $password      Password to use for connection authentication. | ||||
|      * @param array  $driverOptions Additional parameters to use for the connection. | ||||
|      * | ||||
|      * @return string | ||||
|      */ | ||||
|     private function buildDsn($host, $port, $server, $dbname, $username = null, $password = null, array $driverOptions = []) | ||||
|     { | ||||
|         $host = $host ?: 'localhost'; | ||||
|         $port = $port ?: 2638; | ||||
|  | ||||
|         if (! empty($server)) { | ||||
|             $server = ';ServerName=' . $server; | ||||
|         } | ||||
|  | ||||
|         return | ||||
|             'HOST=' . $host . ':' . $port . | ||||
|             $server . | ||||
|             ';DBN=' . $dbname . | ||||
|             ';UID=' . $username . | ||||
|             ';PWD=' . $password . | ||||
|             ';' . implode( | ||||
|                 ';', | ||||
|                 array_map(function ($key, $value) { | ||||
|                     return $key . '=' . $value; | ||||
|                 }, array_keys($driverOptions), $driverOptions) | ||||
|             ); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										245
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/SQLAnywhere/SQLAnywhereConnection.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										245
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/SQLAnywhere/SQLAnywhereConnection.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,245 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Driver\SQLAnywhere; | ||||
|  | ||||
| use Doctrine\DBAL\Driver\Connection; | ||||
| use Doctrine\DBAL\Driver\ServerInfoAwareConnection; | ||||
| use Doctrine\DBAL\ParameterType; | ||||
| use function assert; | ||||
| use function func_get_args; | ||||
| use function is_float; | ||||
| use function is_int; | ||||
| use function is_resource; | ||||
| use function is_string; | ||||
| use function sasql_affected_rows; | ||||
| use function sasql_commit; | ||||
| use function sasql_connect; | ||||
| use function sasql_error; | ||||
| use function sasql_errorcode; | ||||
| use function sasql_escape_string; | ||||
| use function sasql_insert_id; | ||||
| use function sasql_pconnect; | ||||
| use function sasql_real_query; | ||||
| use function sasql_rollback; | ||||
| use function sasql_set_option; | ||||
|  | ||||
| /** | ||||
|  * SAP Sybase SQL Anywhere implementation of the Connection interface. | ||||
|  * | ||||
|  * @author Steve Müller <st.mueller@dzh-online.de> | ||||
|  * @link   www.doctrine-project.org | ||||
|  * @since  2.5 | ||||
|  */ | ||||
| class SQLAnywhereConnection implements Connection, ServerInfoAwareConnection | ||||
| { | ||||
|     /** | ||||
|      * @var resource The SQL Anywhere connection resource. | ||||
|      */ | ||||
|     private $connection; | ||||
|  | ||||
|     /** | ||||
|      * Constructor. | ||||
|      * | ||||
|      * Connects to database with given connection string. | ||||
|      * | ||||
|      * @param string $dsn        The connection string. | ||||
|      * @param bool   $persistent Whether or not to establish a persistent connection. | ||||
|      * | ||||
|      * @throws SQLAnywhereException | ||||
|      */ | ||||
|     public function __construct($dsn, $persistent = false) | ||||
|     { | ||||
|         $this->connection = $persistent ? @sasql_pconnect($dsn) : @sasql_connect($dsn); | ||||
|  | ||||
|         if ( ! is_resource($this->connection)) { | ||||
|             throw SQLAnywhereException::fromSQLAnywhereError(); | ||||
|         } | ||||
|  | ||||
|         // Disable PHP warnings on error. | ||||
|         if ( ! sasql_set_option($this->connection, 'verbose_errors', false)) { | ||||
|             throw SQLAnywhereException::fromSQLAnywhereError($this->connection); | ||||
|         } | ||||
|  | ||||
|         // Enable auto committing by default. | ||||
|         if ( ! sasql_set_option($this->connection, 'auto_commit', 'on')) { | ||||
|             throw SQLAnywhereException::fromSQLAnywhereError($this->connection); | ||||
|         } | ||||
|  | ||||
|         // Enable exact, non-approximated row count retrieval. | ||||
|         if ( ! sasql_set_option($this->connection, 'row_counts', true)) { | ||||
|             throw SQLAnywhereException::fromSQLAnywhereError($this->connection); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      * | ||||
|      * @throws SQLAnywhereException | ||||
|      */ | ||||
|     public function beginTransaction() | ||||
|     { | ||||
|         if ( ! sasql_set_option($this->connection, 'auto_commit', 'off')) { | ||||
|             throw SQLAnywhereException::fromSQLAnywhereError($this->connection); | ||||
|         } | ||||
|  | ||||
|         return true; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      * | ||||
|      * @throws SQLAnywhereException | ||||
|      */ | ||||
|     public function commit() | ||||
|     { | ||||
|         if ( ! sasql_commit($this->connection)) { | ||||
|             throw SQLAnywhereException::fromSQLAnywhereError($this->connection); | ||||
|         } | ||||
|  | ||||
|         $this->endTransaction(); | ||||
|  | ||||
|         return true; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function errorCode() | ||||
|     { | ||||
|         return sasql_errorcode($this->connection); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function errorInfo() | ||||
|     { | ||||
|         return sasql_error($this->connection); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function exec($statement) | ||||
|     { | ||||
|         if (false === sasql_real_query($this->connection, $statement)) { | ||||
|             throw SQLAnywhereException::fromSQLAnywhereError($this->connection); | ||||
|         } | ||||
|  | ||||
|         return sasql_affected_rows($this->connection); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function getServerVersion() | ||||
|     { | ||||
|         $version = $this->query("SELECT PROPERTY('ProductVersion')")->fetchColumn(); | ||||
|  | ||||
|         assert(is_string($version)); | ||||
|  | ||||
|         return $version; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function lastInsertId($name = null) | ||||
|     { | ||||
|         if (null === $name) { | ||||
|             return sasql_insert_id($this->connection); | ||||
|         } | ||||
|  | ||||
|         return $this->query('SELECT ' . $name . '.CURRVAL')->fetchColumn(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function prepare($prepareString) | ||||
|     { | ||||
|         return new SQLAnywhereStatement($this->connection, $prepareString); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function query() | ||||
|     { | ||||
|         $args = func_get_args(); | ||||
|         $stmt = $this->prepare($args[0]); | ||||
|  | ||||
|         $stmt->execute(); | ||||
|  | ||||
|         return $stmt; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function quote($input, $type = ParameterType::STRING) | ||||
|     { | ||||
|         if (is_int($input) || is_float($input)) { | ||||
|             return $input; | ||||
|         } | ||||
|  | ||||
|         return "'" . sasql_escape_string($this->connection, $input) . "'"; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function requiresQueryForServerVersion() | ||||
|     { | ||||
|         return true; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      * | ||||
|      * @throws SQLAnywhereException | ||||
|      */ | ||||
|     public function rollBack() | ||||
|     { | ||||
|         if ( ! sasql_rollback($this->connection)) { | ||||
|             throw SQLAnywhereException::fromSQLAnywhereError($this->connection); | ||||
|         } | ||||
|  | ||||
|         $this->endTransaction(); | ||||
|  | ||||
|         return true; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Ends transactional mode and enables auto commit again. | ||||
|      * | ||||
|      * @throws SQLAnywhereException | ||||
|      * | ||||
|      * @return bool Whether or not ending transactional mode succeeded. | ||||
|      */ | ||||
|     private function endTransaction() | ||||
|     { | ||||
|         if ( ! sasql_set_option($this->connection, 'auto_commit', 'on')) { | ||||
|             throw SQLAnywhereException::fromSQLAnywhereError($this->connection); | ||||
|         } | ||||
|  | ||||
|         return true; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										100
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/SQLAnywhere/SQLAnywhereException.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										100
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/SQLAnywhere/SQLAnywhereException.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,100 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Driver\SQLAnywhere; | ||||
|  | ||||
| use Doctrine\DBAL\Driver\AbstractDriverException; | ||||
| use function is_resource; | ||||
| use function sasql_error; | ||||
| use function sasql_errorcode; | ||||
| use function sasql_sqlstate; | ||||
| use function sasql_stmt_errno; | ||||
| use function sasql_stmt_error; | ||||
|  | ||||
| /** | ||||
|  * SAP Sybase SQL Anywhere driver exception. | ||||
|  * | ||||
|  * @author Steve Müller <st.mueller@dzh-online.de> | ||||
|  * @link   www.doctrine-project.org | ||||
|  * @since  2.5 | ||||
|  */ | ||||
| class SQLAnywhereException extends AbstractDriverException | ||||
| { | ||||
|     /** | ||||
|      * Helper method to turn SQL Anywhere error into exception. | ||||
|      * | ||||
|      * @param resource|null $conn The SQL Anywhere connection resource to retrieve the last error from. | ||||
|      * @param resource|null $stmt The SQL Anywhere statement resource to retrieve the last error from. | ||||
|      * | ||||
|      * @return SQLAnywhereException | ||||
|      * | ||||
|      * @throws \InvalidArgumentException | ||||
|      */ | ||||
|     public static function fromSQLAnywhereError($conn = null, $stmt = null) | ||||
|     { | ||||
|         if (null !== $conn && ! (is_resource($conn))) { | ||||
|             throw new \InvalidArgumentException('Invalid SQL Anywhere connection resource given: ' . $conn); | ||||
|         } | ||||
|  | ||||
|         if (null !== $stmt && ! (is_resource($stmt))) { | ||||
|             throw new \InvalidArgumentException('Invalid SQL Anywhere statement resource given: ' . $stmt); | ||||
|         } | ||||
|  | ||||
|         $state   = $conn ? sasql_sqlstate($conn) : sasql_sqlstate(); | ||||
|         $code    = null; | ||||
|         $message = null; | ||||
|  | ||||
|         /** | ||||
|          * Try retrieving the last error from statement resource if given | ||||
|          */ | ||||
|         if ($stmt) { | ||||
|             $code    = sasql_stmt_errno($stmt); | ||||
|             $message = sasql_stmt_error($stmt); | ||||
|         } | ||||
|  | ||||
|         /** | ||||
|          * Try retrieving the last error from the connection resource | ||||
|          * if either the statement resource is not given or the statement | ||||
|          * resource is given but the last error could not be retrieved from it (fallback). | ||||
|          * Depending on the type of error, it is sometimes necessary to retrieve | ||||
|          * it from the connection resource even though it occurred during | ||||
|          * a prepared statement. | ||||
|          */ | ||||
|         if ($conn && ! $code) { | ||||
|             $code    = sasql_errorcode($conn); | ||||
|             $message = sasql_error($conn); | ||||
|         } | ||||
|  | ||||
|         /** | ||||
|          * Fallback mode if either no connection resource is given | ||||
|          * or the last error could not be retrieved from the given | ||||
|          * connection / statement resource. | ||||
|          */ | ||||
|         if ( ! $conn || ! $code) { | ||||
|             $code    = sasql_errorcode(); | ||||
|             $message = sasql_error(); | ||||
|         } | ||||
|  | ||||
|         if ($message) { | ||||
|             return new self('SQLSTATE [' . $state . '] [' . $code . '] ' . $message, $state, $code); | ||||
|         } | ||||
|  | ||||
|         return new self('SQL Anywhere error occurred but no error message was retrieved from driver.', $state, $code); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										388
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/SQLAnywhere/SQLAnywhereStatement.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										388
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/SQLAnywhere/SQLAnywhereStatement.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,388 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Driver\SQLAnywhere; | ||||
|  | ||||
| use Doctrine\DBAL\Driver\Statement; | ||||
| use Doctrine\DBAL\Driver\StatementIterator; | ||||
| use Doctrine\DBAL\FetchMode; | ||||
| use Doctrine\DBAL\ParameterType; | ||||
| use IteratorAggregate; | ||||
| use const SASQL_BOTH; | ||||
| use function array_key_exists; | ||||
| use function call_user_func_array; | ||||
| use function func_get_args; | ||||
| use function func_num_args; | ||||
| use function gettype; | ||||
| use function is_array; | ||||
| use function is_numeric; | ||||
| use function is_object; | ||||
| use function is_resource; | ||||
| use function is_string; | ||||
| use function sasql_fetch_array; | ||||
| use function sasql_fetch_assoc; | ||||
| use function sasql_fetch_object; | ||||
| use function sasql_fetch_row; | ||||
| use function sasql_prepare; | ||||
| use function sasql_stmt_affected_rows; | ||||
| use function sasql_stmt_bind_param_ex; | ||||
| use function sasql_stmt_errno; | ||||
| use function sasql_stmt_error; | ||||
| use function sasql_stmt_execute; | ||||
| use function sasql_stmt_field_count; | ||||
| use function sasql_stmt_reset; | ||||
| use function sasql_stmt_result_metadata; | ||||
| use function sprintf; | ||||
|  | ||||
| /** | ||||
|  * SAP SQL Anywhere implementation of the Statement interface. | ||||
|  * | ||||
|  * @author Steve Müller <st.mueller@dzh-online.de> | ||||
|  * @link   www.doctrine-project.org | ||||
|  * @since  2.5 | ||||
|  */ | ||||
| class SQLAnywhereStatement implements IteratorAggregate, Statement | ||||
| { | ||||
|     /** | ||||
|      * @var resource The connection resource. | ||||
|      */ | ||||
|     private $conn; | ||||
|  | ||||
|     /** | ||||
|      * @var string Name of the default class to instantiate when fetching class instances. | ||||
|      */ | ||||
|     private $defaultFetchClass = '\stdClass'; | ||||
|  | ||||
|     /** | ||||
|      * @var mixed[] Constructor arguments for the default class to instantiate when fetching class instances. | ||||
|      */ | ||||
|     private $defaultFetchClassCtorArgs = []; | ||||
|  | ||||
|     /** | ||||
|      * @var int Default fetch mode to use. | ||||
|      */ | ||||
|     private $defaultFetchMode = FetchMode::MIXED; | ||||
|  | ||||
|     /** | ||||
|      * @var resource The result set resource to fetch. | ||||
|      */ | ||||
|     private $result; | ||||
|  | ||||
|     /** | ||||
|      * @var resource The prepared SQL statement to execute. | ||||
|      */ | ||||
|     private $stmt; | ||||
|  | ||||
|     /** | ||||
|      * Constructor. | ||||
|      * | ||||
|      * Prepares given statement for given connection. | ||||
|      * | ||||
|      * @param resource $conn The connection resource to use. | ||||
|      * @param string   $sql  The SQL statement to prepare. | ||||
|      * | ||||
|      * @throws SQLAnywhereException | ||||
|      */ | ||||
|     public function __construct($conn, $sql) | ||||
|     { | ||||
|         if ( ! is_resource($conn)) { | ||||
|             throw new SQLAnywhereException('Invalid SQL Anywhere connection resource: ' . $conn); | ||||
|         } | ||||
|  | ||||
|         $this->conn = $conn; | ||||
|         $this->stmt = sasql_prepare($conn, $sql); | ||||
|  | ||||
|         if ( ! is_resource($this->stmt)) { | ||||
|             throw SQLAnywhereException::fromSQLAnywhereError($conn); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      * | ||||
|      * @throws SQLAnywhereException | ||||
|      */ | ||||
|     public function bindParam($column, &$variable, $type = ParameterType::STRING, $length = null) | ||||
|     { | ||||
|         switch ($type) { | ||||
|             case ParameterType::INTEGER: | ||||
|             case ParameterType::BOOLEAN: | ||||
|                 $type = 'i'; | ||||
|                 break; | ||||
|  | ||||
|             case ParameterType::LARGE_OBJECT: | ||||
|                 $type = 'b'; | ||||
|                 break; | ||||
|  | ||||
|             case ParameterType::NULL: | ||||
|             case ParameterType::STRING: | ||||
|             case ParameterType::BINARY: | ||||
|                 $type = 's'; | ||||
|                 break; | ||||
|  | ||||
|             default: | ||||
|                 throw new SQLAnywhereException('Unknown type: ' . $type); | ||||
|         } | ||||
|  | ||||
|         if ( ! sasql_stmt_bind_param_ex($this->stmt, $column - 1, $variable, $type, $variable === null)) { | ||||
|             throw SQLAnywhereException::fromSQLAnywhereError($this->conn, $this->stmt); | ||||
|         } | ||||
|  | ||||
|         return true; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function bindValue($param, $value, $type = ParameterType::STRING) | ||||
|     { | ||||
|         return $this->bindParam($param, $value, $type); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      * | ||||
|      * @throws SQLAnywhereException | ||||
|      */ | ||||
|     public function closeCursor() | ||||
|     { | ||||
|         if (!sasql_stmt_reset($this->stmt)) { | ||||
|             throw SQLAnywhereException::fromSQLAnywhereError($this->conn, $this->stmt); | ||||
|         } | ||||
|  | ||||
|         return true; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function columnCount() | ||||
|     { | ||||
|         return sasql_stmt_field_count($this->stmt); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function errorCode() | ||||
|     { | ||||
|         return sasql_stmt_errno($this->stmt); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function errorInfo() | ||||
|     { | ||||
|         return sasql_stmt_error($this->stmt); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      * | ||||
|      * @throws SQLAnywhereException | ||||
|      */ | ||||
|     public function execute($params = null) | ||||
|     { | ||||
|         if (is_array($params)) { | ||||
|             $hasZeroIndex = array_key_exists(0, $params); | ||||
|  | ||||
|             foreach ($params as $key => $val) { | ||||
|                 $key = ($hasZeroIndex && is_numeric($key)) ? $key + 1 : $key; | ||||
|  | ||||
|                 $this->bindValue($key, $val); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         if ( ! sasql_stmt_execute($this->stmt)) { | ||||
|             throw SQLAnywhereException::fromSQLAnywhereError($this->conn, $this->stmt); | ||||
|         } | ||||
|  | ||||
|         $this->result = sasql_stmt_result_metadata($this->stmt); | ||||
|  | ||||
|         return true; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      * | ||||
|      * @throws SQLAnywhereException | ||||
|      */ | ||||
|     public function fetch($fetchMode = null, $cursorOrientation = \PDO::FETCH_ORI_NEXT, $cursorOffset = 0) | ||||
|     { | ||||
|         if ( ! is_resource($this->result)) { | ||||
|             return false; | ||||
|         } | ||||
|  | ||||
|         $fetchMode = $fetchMode ?: $this->defaultFetchMode; | ||||
|  | ||||
|         switch ($fetchMode) { | ||||
|             case FetchMode::COLUMN: | ||||
|                 return $this->fetchColumn(); | ||||
|  | ||||
|             case FetchMode::ASSOCIATIVE: | ||||
|                 return sasql_fetch_assoc($this->result); | ||||
|  | ||||
|             case FetchMode::MIXED: | ||||
|                 return sasql_fetch_array($this->result, SASQL_BOTH); | ||||
|  | ||||
|             case FetchMode::CUSTOM_OBJECT: | ||||
|                 $className = $this->defaultFetchClass; | ||||
|                 $ctorArgs  = $this->defaultFetchClassCtorArgs; | ||||
|  | ||||
|                 if (func_num_args() >= 2) { | ||||
|                     $args      = func_get_args(); | ||||
|                     $className = $args[1]; | ||||
|                     $ctorArgs  = $args[2] ?? []; | ||||
|                 } | ||||
|  | ||||
|                 $result = sasql_fetch_object($this->result); | ||||
|  | ||||
|                 if ($result instanceof \stdClass) { | ||||
|                     $result = $this->castObject($result, $className, $ctorArgs); | ||||
|                 } | ||||
|  | ||||
|                 return $result; | ||||
|  | ||||
|             case FetchMode::NUMERIC: | ||||
|                 return sasql_fetch_row($this->result); | ||||
|  | ||||
|             case FetchMode::STANDARD_OBJECT: | ||||
|                 return sasql_fetch_object($this->result); | ||||
|  | ||||
|             default: | ||||
|                 throw new SQLAnywhereException('Fetch mode is not supported: ' . $fetchMode); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function fetchAll($fetchMode = null, $fetchArgument = null, $ctorArgs = null) | ||||
|     { | ||||
|         $rows = []; | ||||
|  | ||||
|         switch ($fetchMode) { | ||||
|             case FetchMode::CUSTOM_OBJECT: | ||||
|                 while ($row = call_user_func_array([$this, 'fetch'], func_get_args())) { | ||||
|                     $rows[] = $row; | ||||
|                 } | ||||
|                 break; | ||||
|  | ||||
|             case FetchMode::COLUMN: | ||||
|                 while ($row = $this->fetchColumn()) { | ||||
|                     $rows[] = $row; | ||||
|                 } | ||||
|                 break; | ||||
|  | ||||
|             default: | ||||
|                 while ($row = $this->fetch($fetchMode)) { | ||||
|                     $rows[] = $row; | ||||
|                 } | ||||
|         } | ||||
|  | ||||
|         return $rows; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function fetchColumn($columnIndex = 0) | ||||
|     { | ||||
|         $row = $this->fetch(FetchMode::NUMERIC); | ||||
|  | ||||
|         if (false === $row) { | ||||
|             return false; | ||||
|         } | ||||
|  | ||||
|         return $row[$columnIndex] ?? null; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function getIterator() | ||||
|     { | ||||
|         return new StatementIterator($this); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function rowCount() | ||||
|     { | ||||
|         return sasql_stmt_affected_rows($this->stmt); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function setFetchMode($fetchMode, $arg2 = null, $arg3 = null) | ||||
|     { | ||||
|         $this->defaultFetchMode          = $fetchMode; | ||||
|         $this->defaultFetchClass         = $arg2 ?: $this->defaultFetchClass; | ||||
|         $this->defaultFetchClassCtorArgs = $arg3 ? (array) $arg3 : $this->defaultFetchClassCtorArgs; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Casts a stdClass object to the given class name mapping its' properties. | ||||
|      * | ||||
|      * @param \stdClass     $sourceObject     Object to cast from. | ||||
|      * @param string|object $destinationClass Name of the class or class instance to cast to. | ||||
|      * @param array         $ctorArgs         Arguments to use for constructing the destination class instance. | ||||
|      * | ||||
|      * @return object | ||||
|      * | ||||
|      * @throws SQLAnywhereException | ||||
|      */ | ||||
|     private function castObject(\stdClass $sourceObject, $destinationClass, array $ctorArgs = []) | ||||
|     { | ||||
|         if ( ! is_string($destinationClass)) { | ||||
|             if ( ! is_object($destinationClass)) { | ||||
|                 throw new SQLAnywhereException(sprintf( | ||||
|                     'Destination class has to be of type string or object, %s given.', gettype($destinationClass) | ||||
|                 )); | ||||
|             } | ||||
|         } else { | ||||
|             $destinationClass = new \ReflectionClass($destinationClass); | ||||
|             $destinationClass = $destinationClass->newInstanceArgs($ctorArgs); | ||||
|         } | ||||
|  | ||||
|         $sourceReflection           = new \ReflectionObject($sourceObject); | ||||
|         $destinationClassReflection = new \ReflectionObject($destinationClass); | ||||
|  | ||||
|         foreach ($sourceReflection->getProperties() as $sourceProperty) { | ||||
|             $sourceProperty->setAccessible(true); | ||||
|  | ||||
|             $name  = $sourceProperty->getName(); | ||||
|             $value = $sourceProperty->getValue($sourceObject); | ||||
|  | ||||
|             if ($destinationClassReflection->hasProperty($name)) { | ||||
|                 $destinationProperty = $destinationClassReflection->getProperty($name); | ||||
|  | ||||
|                 $destinationProperty->setAccessible(true); | ||||
|                 $destinationProperty->setValue($destinationClass, $value); | ||||
|             } else { | ||||
|                 $destinationClass->$name = $value; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         return $destinationClass; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										68
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/SQLSrv/Driver.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										68
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/SQLSrv/Driver.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,68 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Driver\SQLSrv; | ||||
|  | ||||
| use Doctrine\DBAL\Driver\AbstractSQLServerDriver; | ||||
|  | ||||
| /** | ||||
|  * Driver for ext/sqlsrv. | ||||
|  */ | ||||
| class Driver extends AbstractSQLServerDriver | ||||
| { | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function connect(array $params, $username = null, $password = null, array $driverOptions = []) | ||||
|     { | ||||
|         if (!isset($params['host'])) { | ||||
|             throw new SQLSrvException("Missing 'host' in configuration for sqlsrv driver."); | ||||
|         } | ||||
|  | ||||
|         $serverName = $params['host']; | ||||
|         if (isset($params['port'])) { | ||||
|             $serverName .= ', ' . $params['port']; | ||||
|         } | ||||
|  | ||||
|         if (isset($params['dbname'])) { | ||||
|             $driverOptions['Database'] = $params['dbname']; | ||||
|         } | ||||
|          | ||||
|         if (isset($params['charset'])) { | ||||
|             $driverOptions['CharacterSet'] = $params['charset']; | ||||
|         } | ||||
|  | ||||
|         $driverOptions['UID'] = $username; | ||||
|         $driverOptions['PWD'] = $password; | ||||
|  | ||||
|         if (!isset($driverOptions['ReturnDatesAsStrings'])) { | ||||
|             $driverOptions['ReturnDatesAsStrings'] = 1; | ||||
|         } | ||||
|  | ||||
|         return new SQLSrvConnection($serverName, $driverOptions); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function getName() | ||||
|     { | ||||
|         return 'sqlsrv'; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										50
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/SQLSrv/LastInsertId.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										50
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/SQLSrv/LastInsertId.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,50 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Driver\SQLSrv; | ||||
|  | ||||
| /** | ||||
|  * Last Id Data Container. | ||||
|  * | ||||
|  * @since 2.3 | ||||
|  * @author Benjamin Eberlei <kontakt@beberlei.de> | ||||
|  */ | ||||
| class LastInsertId | ||||
| { | ||||
|     /** | ||||
|      * @var int | ||||
|      */ | ||||
|     private $id; | ||||
|  | ||||
|     /** | ||||
|      * @param int $id | ||||
|      */ | ||||
|     public function setId($id) | ||||
|     { | ||||
|         $this->id = $id; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @return int | ||||
|      */ | ||||
|     public function getId() | ||||
|     { | ||||
|         return $this->id; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										211
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/SQLSrv/SQLSrvConnection.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										211
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/SQLSrv/SQLSrvConnection.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,211 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Driver\SQLSrv; | ||||
|  | ||||
| use Doctrine\DBAL\Driver\Connection; | ||||
| use Doctrine\DBAL\Driver\ServerInfoAwareConnection; | ||||
| use Doctrine\DBAL\ParameterType; | ||||
| use const SQLSRV_ERR_ERRORS; | ||||
| use function func_get_args; | ||||
| use function is_float; | ||||
| use function is_int; | ||||
| use function sprintf; | ||||
| use function sqlsrv_begin_transaction; | ||||
| use function sqlsrv_commit; | ||||
| use function sqlsrv_configure; | ||||
| use function sqlsrv_connect; | ||||
| use function sqlsrv_errors; | ||||
| use function sqlsrv_query; | ||||
| use function sqlsrv_rollback; | ||||
| use function sqlsrv_rows_affected; | ||||
| use function sqlsrv_server_info; | ||||
| use function str_replace; | ||||
|  | ||||
| /** | ||||
|  * SQL Server implementation for the Connection interface. | ||||
|  * | ||||
|  * @since 2.3 | ||||
|  * @author Benjamin Eberlei <kontakt@beberlei.de> | ||||
|  */ | ||||
| class SQLSrvConnection implements Connection, ServerInfoAwareConnection | ||||
| { | ||||
|     /** | ||||
|      * @var resource | ||||
|      */ | ||||
|     protected $conn; | ||||
|  | ||||
|     /** | ||||
|      * @var \Doctrine\DBAL\Driver\SQLSrv\LastInsertId | ||||
|      */ | ||||
|     protected $lastInsertId; | ||||
|  | ||||
|     /** | ||||
|      * @param string $serverName | ||||
|      * @param array  $connectionOptions | ||||
|      * | ||||
|      * @throws \Doctrine\DBAL\Driver\SQLSrv\SQLSrvException | ||||
|      */ | ||||
|     public function __construct($serverName, $connectionOptions) | ||||
|     { | ||||
|         if ( ! sqlsrv_configure('WarningsReturnAsErrors', 0)) { | ||||
|             throw SQLSrvException::fromSqlSrvErrors(); | ||||
|         } | ||||
|  | ||||
|         $this->conn = sqlsrv_connect($serverName, $connectionOptions); | ||||
|         if ( ! $this->conn) { | ||||
|             throw SQLSrvException::fromSqlSrvErrors(); | ||||
|         } | ||||
|         $this->lastInsertId = new LastInsertId(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function getServerVersion() | ||||
|     { | ||||
|         $serverInfo = sqlsrv_server_info($this->conn); | ||||
|  | ||||
|         return $serverInfo['SQLServerVersion']; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function requiresQueryForServerVersion() | ||||
|     { | ||||
|         return false; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritDoc} | ||||
|      */ | ||||
|     public function prepare($sql) | ||||
|     { | ||||
|         return new SQLSrvStatement($this->conn, $sql, $this->lastInsertId); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritDoc} | ||||
|      */ | ||||
|     public function query() | ||||
|     { | ||||
|         $args = func_get_args(); | ||||
|         $sql = $args[0]; | ||||
|         $stmt = $this->prepare($sql); | ||||
|         $stmt->execute(); | ||||
|  | ||||
|         return $stmt; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritDoc} | ||||
|      * @license New BSD, code from Zend Framework | ||||
|      */ | ||||
|     public function quote($value, $type = ParameterType::STRING) | ||||
|     { | ||||
|         if (is_int($value)) { | ||||
|             return $value; | ||||
|         } elseif (is_float($value)) { | ||||
|             return sprintf('%F', $value); | ||||
|         } | ||||
|  | ||||
|         return "'" . str_replace("'", "''", $value) . "'"; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritDoc} | ||||
|      */ | ||||
|     public function exec($statement) | ||||
|     { | ||||
|         $stmt = sqlsrv_query($this->conn, $statement); | ||||
|  | ||||
|         if (false === $stmt) { | ||||
|             throw SQLSrvException::fromSqlSrvErrors(); | ||||
|         } | ||||
|  | ||||
|         return sqlsrv_rows_affected($stmt); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritDoc} | ||||
|      */ | ||||
|     public function lastInsertId($name = null) | ||||
|     { | ||||
|         if ($name !== null) { | ||||
|             $stmt = $this->prepare('SELECT CONVERT(VARCHAR(MAX), current_value) FROM sys.sequences WHERE name = ?'); | ||||
|             $stmt->execute([$name]); | ||||
|         } else { | ||||
|             $stmt = $this->query('SELECT @@IDENTITY'); | ||||
|         } | ||||
|  | ||||
|         return $stmt->fetchColumn(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritDoc} | ||||
|      */ | ||||
|     public function beginTransaction() | ||||
|     { | ||||
|         if ( ! sqlsrv_begin_transaction($this->conn)) { | ||||
|             throw SQLSrvException::fromSqlSrvErrors(); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritDoc} | ||||
|      */ | ||||
|     public function commit() | ||||
|     { | ||||
|         if ( ! sqlsrv_commit($this->conn)) { | ||||
|             throw SQLSrvException::fromSqlSrvErrors(); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritDoc} | ||||
|      */ | ||||
|     public function rollBack() | ||||
|     { | ||||
|         if ( ! sqlsrv_rollback($this->conn)) { | ||||
|             throw SQLSrvException::fromSqlSrvErrors(); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritDoc} | ||||
|      */ | ||||
|     public function errorCode() | ||||
|     { | ||||
|         $errors = sqlsrv_errors(SQLSRV_ERR_ERRORS); | ||||
|         if ($errors) { | ||||
|             return $errors[0]['code']; | ||||
|         } | ||||
|  | ||||
|         return false; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritDoc} | ||||
|      */ | ||||
|     public function errorInfo() | ||||
|     { | ||||
|         return sqlsrv_errors(SQLSRV_ERR_ERRORS); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										59
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/SQLSrv/SQLSrvException.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										59
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/SQLSrv/SQLSrvException.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,59 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Driver\SQLSrv; | ||||
|  | ||||
|  | ||||
| use Doctrine\DBAL\Driver\AbstractDriverException; | ||||
| use const SQLSRV_ERR_ERRORS; | ||||
| use function rtrim; | ||||
| use function sqlsrv_errors; | ||||
|  | ||||
| class SQLSrvException extends AbstractDriverException | ||||
| { | ||||
|     /** | ||||
|      * Helper method to turn sql server errors into exception. | ||||
|      * | ||||
|      * @return \Doctrine\DBAL\Driver\SQLSrv\SQLSrvException | ||||
|      */ | ||||
|     public static function fromSqlSrvErrors() | ||||
|     { | ||||
|         $errors = sqlsrv_errors(SQLSRV_ERR_ERRORS); | ||||
|         $message = ""; | ||||
|         $sqlState = null; | ||||
|         $errorCode = null; | ||||
|  | ||||
|         foreach ($errors as $error) { | ||||
|             $message .= "SQLSTATE [".$error['SQLSTATE'].", ".$error['code']."]: ". $error['message']."\n"; | ||||
|  | ||||
|             if (null === $sqlState) { | ||||
|                 $sqlState = $error['SQLSTATE']; | ||||
|             } | ||||
|  | ||||
|             if (null === $errorCode) { | ||||
|                 $errorCode = $error['code']; | ||||
|             } | ||||
|         } | ||||
|         if ( ! $message) { | ||||
|             $message = "SQL Server error occurred but no error message was retrieved from driver."; | ||||
|         } | ||||
|  | ||||
|         return new self(rtrim($message), $sqlState, $errorCode); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										429
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/SQLSrv/SQLSrvStatement.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										429
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/SQLSrv/SQLSrvStatement.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,429 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Driver\SQLSrv; | ||||
|  | ||||
| use Doctrine\DBAL\Driver\StatementIterator; | ||||
| use Doctrine\DBAL\FetchMode; | ||||
| use Doctrine\DBAL\ParameterType; | ||||
| use IteratorAggregate; | ||||
| use Doctrine\DBAL\Driver\Statement; | ||||
| use const SQLSRV_ENC_BINARY; | ||||
| use const SQLSRV_ERR_ERRORS; | ||||
| use const SQLSRV_FETCH_ASSOC; | ||||
| use const SQLSRV_FETCH_BOTH; | ||||
| use const SQLSRV_FETCH_NUMERIC; | ||||
| use const SQLSRV_PARAM_IN; | ||||
| use function array_key_exists; | ||||
| use function count; | ||||
| use function func_get_args; | ||||
| use function in_array; | ||||
| use function is_numeric; | ||||
| use function sqlsrv_errors; | ||||
| use function sqlsrv_execute; | ||||
| use function sqlsrv_fetch; | ||||
| use function sqlsrv_fetch_array; | ||||
| use function sqlsrv_fetch_object; | ||||
| use function sqlsrv_get_field; | ||||
| use function sqlsrv_next_result; | ||||
| use function sqlsrv_num_fields; | ||||
| use function SQLSRV_PHPTYPE_STREAM; | ||||
| use function SQLSRV_PHPTYPE_STRING; | ||||
| use function sqlsrv_prepare; | ||||
| use function sqlsrv_rows_affected; | ||||
| use function SQLSRV_SQLTYPE_VARBINARY; | ||||
| use function stripos; | ||||
|  | ||||
| /** | ||||
|  * SQL Server Statement. | ||||
|  * | ||||
|  * @since 2.3 | ||||
|  * @author Benjamin Eberlei <kontakt@beberlei.de> | ||||
|  */ | ||||
| class SQLSrvStatement implements IteratorAggregate, Statement | ||||
| { | ||||
|     /** | ||||
|      * The SQLSRV Resource. | ||||
|      * | ||||
|      * @var resource | ||||
|      */ | ||||
|     private $conn; | ||||
|  | ||||
|     /** | ||||
|      * The SQL statement to execute. | ||||
|      * | ||||
|      * @var string | ||||
|      */ | ||||
|     private $sql; | ||||
|  | ||||
|     /** | ||||
|      * The SQLSRV statement resource. | ||||
|      * | ||||
|      * @var resource|null | ||||
|      */ | ||||
|     private $stmt; | ||||
|  | ||||
|     /** | ||||
|      * References to the variables bound as statement parameters. | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     private $variables = []; | ||||
|  | ||||
|     /** | ||||
|      * Bound parameter types. | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     private $types = []; | ||||
|  | ||||
|     /** | ||||
|      * Translations. | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     private static $fetchMap = [ | ||||
|         FetchMode::MIXED       => SQLSRV_FETCH_BOTH, | ||||
|         FetchMode::ASSOCIATIVE => SQLSRV_FETCH_ASSOC, | ||||
|         FetchMode::NUMERIC     => SQLSRV_FETCH_NUMERIC, | ||||
|     ]; | ||||
|  | ||||
|     /** | ||||
|      * The name of the default class to instantiate when fetching class instances. | ||||
|      * | ||||
|      * @var string | ||||
|      */ | ||||
|     private $defaultFetchClass = '\stdClass'; | ||||
|  | ||||
|     /** | ||||
|      * The constructor arguments for the default class to instantiate when fetching class instances. | ||||
|      * | ||||
|      * @var mixed[] | ||||
|      */ | ||||
|     private $defaultFetchClassCtorArgs = []; | ||||
|  | ||||
|     /** | ||||
|      * The fetch style. | ||||
|      * | ||||
|      * @var int | ||||
|      */ | ||||
|     private $defaultFetchMode = FetchMode::MIXED; | ||||
|  | ||||
|     /** | ||||
|      * The last insert ID. | ||||
|      * | ||||
|      * @var \Doctrine\DBAL\Driver\SQLSrv\LastInsertId|null | ||||
|      */ | ||||
|     private $lastInsertId; | ||||
|  | ||||
|     /** | ||||
|      * Indicates whether the statement is in the state when fetching results is possible | ||||
|      * | ||||
|      * @var bool | ||||
|      */ | ||||
|     private $result = false; | ||||
|  | ||||
|     /** | ||||
|      * Append to any INSERT query to retrieve the last insert id. | ||||
|      * | ||||
|      * @var string | ||||
|      */ | ||||
|     const LAST_INSERT_ID_SQL = ';SELECT SCOPE_IDENTITY() AS LastInsertId;'; | ||||
|  | ||||
|     /** | ||||
|      * @param resource                                       $conn | ||||
|      * @param string                                         $sql | ||||
|      * @param \Doctrine\DBAL\Driver\SQLSrv\LastInsertId|null $lastInsertId | ||||
|      */ | ||||
|     public function __construct($conn, $sql, LastInsertId $lastInsertId = null) | ||||
|     { | ||||
|         $this->conn = $conn; | ||||
|         $this->sql = $sql; | ||||
|  | ||||
|         if (stripos($sql, 'INSERT INTO ') === 0) { | ||||
|             $this->sql .= self::LAST_INSERT_ID_SQL; | ||||
|             $this->lastInsertId = $lastInsertId; | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function bindValue($param, $value, $type = ParameterType::STRING) | ||||
|     { | ||||
|         if (!is_numeric($param)) { | ||||
|             throw new SQLSrvException( | ||||
|                 'sqlsrv does not support named parameters to queries, use question mark (?) placeholders instead.' | ||||
|             ); | ||||
|         } | ||||
|  | ||||
|         $this->variables[$param] = $value; | ||||
|         $this->types[$param] = $type; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function bindParam($column, &$variable, $type = ParameterType::STRING, $length = null) | ||||
|     { | ||||
|         if (!is_numeric($column)) { | ||||
|             throw new SQLSrvException("sqlsrv does not support named parameters to queries, use question mark (?) placeholders instead."); | ||||
|         } | ||||
|  | ||||
|         $this->variables[$column] =& $variable; | ||||
|         $this->types[$column] = $type; | ||||
|  | ||||
|         // unset the statement resource if it exists as the new one will need to be bound to the new variable | ||||
|         $this->stmt = null; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function closeCursor() | ||||
|     { | ||||
|         // not having the result means there's nothing to close | ||||
|         if (!$this->result) { | ||||
|             return true; | ||||
|         } | ||||
|  | ||||
|         // emulate it by fetching and discarding rows, similarly to what PDO does in this case | ||||
|         // @link http://php.net/manual/en/pdostatement.closecursor.php | ||||
|         // @link https://github.com/php/php-src/blob/php-7.0.11/ext/pdo/pdo_stmt.c#L2075 | ||||
|         // deliberately do not consider multiple result sets, since doctrine/dbal doesn't support them | ||||
|         while (sqlsrv_fetch($this->stmt)); | ||||
|  | ||||
|         $this->result = false; | ||||
|  | ||||
|         return true; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function columnCount() | ||||
|     { | ||||
|         return sqlsrv_num_fields($this->stmt); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function errorCode() | ||||
|     { | ||||
|         $errors = sqlsrv_errors(SQLSRV_ERR_ERRORS); | ||||
|         if ($errors) { | ||||
|             return $errors[0]['code']; | ||||
|         } | ||||
|  | ||||
|         return false; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function errorInfo() | ||||
|     { | ||||
|         return sqlsrv_errors(SQLSRV_ERR_ERRORS); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function execute($params = null) | ||||
|     { | ||||
|         if ($params) { | ||||
|             $hasZeroIndex = array_key_exists(0, $params); | ||||
|             foreach ($params as $key => $val) { | ||||
|                 $key = ($hasZeroIndex && is_numeric($key)) ? $key + 1 : $key; | ||||
|                 $this->bindValue($key, $val); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         if ( ! $this->stmt) { | ||||
|             $this->stmt = $this->prepare(); | ||||
|         } | ||||
|  | ||||
|         if (!sqlsrv_execute($this->stmt)) { | ||||
|             throw SQLSrvException::fromSqlSrvErrors(); | ||||
|         } | ||||
|  | ||||
|         if ($this->lastInsertId) { | ||||
|             sqlsrv_next_result($this->stmt); | ||||
|             sqlsrv_fetch($this->stmt); | ||||
|             $this->lastInsertId->setId(sqlsrv_get_field($this->stmt, 0)); | ||||
|         } | ||||
|  | ||||
|         $this->result = true; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Prepares SQL Server statement resource | ||||
|      * | ||||
|      * @return resource | ||||
|      * @throws SQLSrvException | ||||
|      */ | ||||
|     private function prepare() | ||||
|     { | ||||
|         $params = []; | ||||
|  | ||||
|         foreach ($this->variables as $column => &$variable) { | ||||
|             switch ($this->types[$column]) { | ||||
|                 case ParameterType::LARGE_OBJECT: | ||||
|                     $params[$column - 1] = [ | ||||
|                         &$variable, | ||||
|                         SQLSRV_PARAM_IN, | ||||
|                         SQLSRV_PHPTYPE_STREAM(SQLSRV_ENC_BINARY), | ||||
|                         SQLSRV_SQLTYPE_VARBINARY('max'), | ||||
|                     ]; | ||||
|                     break; | ||||
|  | ||||
|                 case ParameterType::BINARY: | ||||
|                     $params[$column - 1] = [ | ||||
|                         &$variable, | ||||
|                         SQLSRV_PARAM_IN, | ||||
|                         SQLSRV_PHPTYPE_STRING(SQLSRV_ENC_BINARY), | ||||
|                     ]; | ||||
|                     break; | ||||
|  | ||||
|                 default: | ||||
|                     $params[$column - 1] =& $variable; | ||||
|                     break; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         $stmt = sqlsrv_prepare($this->conn, $this->sql, $params); | ||||
|  | ||||
|         if (!$stmt) { | ||||
|             throw SQLSrvException::fromSqlSrvErrors(); | ||||
|         } | ||||
|  | ||||
|         return $stmt; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function setFetchMode($fetchMode, $arg2 = null, $arg3 = null) | ||||
|     { | ||||
|         $this->defaultFetchMode          = $fetchMode; | ||||
|         $this->defaultFetchClass         = $arg2 ?: $this->defaultFetchClass; | ||||
|         $this->defaultFetchClassCtorArgs = $arg3 ? (array) $arg3 : $this->defaultFetchClassCtorArgs; | ||||
|  | ||||
|         return true; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function getIterator() | ||||
|     { | ||||
|         return new StatementIterator($this); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      * | ||||
|      * @throws SQLSrvException | ||||
|      */ | ||||
|     public function fetch($fetchMode = null, $cursorOrientation = \PDO::FETCH_ORI_NEXT, $cursorOffset = 0) | ||||
|     { | ||||
|         // do not try fetching from the statement if it's not expected to contain result | ||||
|         // in order to prevent exceptional situation | ||||
|         if (!$this->result) { | ||||
|             return false; | ||||
|         } | ||||
|  | ||||
|         $args      = func_get_args(); | ||||
|         $fetchMode = $fetchMode ?: $this->defaultFetchMode; | ||||
|  | ||||
|         if ($fetchMode === FetchMode::COLUMN) { | ||||
|             return $this->fetchColumn(); | ||||
|         } | ||||
|  | ||||
|         if (isset(self::$fetchMap[$fetchMode])) { | ||||
|             return sqlsrv_fetch_array($this->stmt, self::$fetchMap[$fetchMode]) ?: false; | ||||
|         } | ||||
|  | ||||
|         if (in_array($fetchMode, [FetchMode::STANDARD_OBJECT, FetchMode::CUSTOM_OBJECT], true)) { | ||||
|             $className = $this->defaultFetchClass; | ||||
|             $ctorArgs  = $this->defaultFetchClassCtorArgs; | ||||
|  | ||||
|             if (count($args) >= 2) { | ||||
|                 $className = $args[1]; | ||||
|                 $ctorArgs  = $args[2] ?? []; | ||||
|             } | ||||
|  | ||||
|             return sqlsrv_fetch_object($this->stmt, $className, $ctorArgs) ?: false; | ||||
|         } | ||||
|  | ||||
|         throw new SQLSrvException('Fetch mode is not supported!'); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function fetchAll($fetchMode = null, $fetchArgument = null, $ctorArgs = null) | ||||
|     { | ||||
|         $rows = []; | ||||
|  | ||||
|         switch ($fetchMode) { | ||||
|             case FetchMode::CUSTOM_OBJECT: | ||||
|                 while (($row = $this->fetch(...func_get_args())) !== false) { | ||||
|                     $rows[] = $row; | ||||
|                 } | ||||
|                 break; | ||||
|  | ||||
|             case FetchMode::COLUMN: | ||||
|                 while (($row = $this->fetchColumn()) !== false) { | ||||
|                     $rows[] = $row; | ||||
|                 } | ||||
|                 break; | ||||
|  | ||||
|             default: | ||||
|                 while (($row = $this->fetch($fetchMode)) !== false) { | ||||
|                     $rows[] = $row; | ||||
|                 } | ||||
|         } | ||||
|  | ||||
|         return $rows; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function fetchColumn($columnIndex = 0) | ||||
|     { | ||||
|         $row = $this->fetch(FetchMode::NUMERIC); | ||||
|  | ||||
|         if (false === $row) { | ||||
|             return false; | ||||
|         } | ||||
|  | ||||
|         return $row[$columnIndex] ?? null; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function rowCount() | ||||
|     { | ||||
|         return sqlsrv_rows_affected($this->stmt); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										44
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/ServerInfoAwareConnection.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										44
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/ServerInfoAwareConnection.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,44 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Driver; | ||||
|  | ||||
| /** | ||||
|  * Contract for a connection that is able to provide information about the server it is connected to. | ||||
|  * | ||||
|  * @author Steve Müller <st.mueller@dzh-online.de> | ||||
|  * @link   www.doctrine-project.org | ||||
|  * @since  2.5 | ||||
|  */ | ||||
| interface ServerInfoAwareConnection | ||||
| { | ||||
|     /** | ||||
|      * Returns the version number of the database server connected to. | ||||
|      * | ||||
|      * @return string | ||||
|      */ | ||||
|     public function getServerVersion(); | ||||
|  | ||||
|     /** | ||||
|      * Checks whether a query is required to retrieve the database server version. | ||||
|      * | ||||
|      * @return bool True if a query is required to retrieve the database server version, false otherwise. | ||||
|      */ | ||||
|     public function requiresQueryForServerVersion(); | ||||
| } | ||||
							
								
								
									
										130
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/Statement.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										130
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/Statement.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,130 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Driver; | ||||
|  | ||||
| use Doctrine\DBAL\ParameterType; | ||||
|  | ||||
| /** | ||||
|  * Statement interface. | ||||
|  * Drivers must implement this interface. | ||||
|  * | ||||
|  * This resembles (a subset of) the PDOStatement interface. | ||||
|  * | ||||
|  * @author Konsta Vesterinen <kvesteri@cc.hut.fi> | ||||
|  * @author Roman Borschel <roman@code-factory.org> | ||||
|  * @link   www.doctrine-project.org | ||||
|  * @since  2.0 | ||||
|  */ | ||||
| interface Statement extends ResultStatement | ||||
| { | ||||
|     /** | ||||
|      * Binds a value to a corresponding named (not supported by mysqli driver, see comment below) or positional | ||||
|      * placeholder in the SQL statement that was used to prepare the statement. | ||||
|      * | ||||
|      * As mentioned above, the named parameters are not natively supported by the mysqli driver, use executeQuery(), | ||||
|      * fetchAll(), fetchArray(), fetchColumn(), fetchAssoc() methods to have the named parameter emulated by doctrine. | ||||
|      * | ||||
|      * @param mixed $param Parameter identifier. For a prepared statement using named placeholders, | ||||
|      *                     this will be a parameter name of the form :name. For a prepared statement | ||||
|      *                     using question mark placeholders, this will be the 1-indexed position of the parameter. | ||||
|      * @param mixed $value The value to bind to the parameter. | ||||
|      * @param int   $type  Explicit data type for the parameter using the {@link \Doctrine\DBAL\ParameterType} | ||||
|      *                     constants. | ||||
|      * | ||||
|      * @return bool TRUE on success or FALSE on failure. | ||||
|      */ | ||||
|     public function bindValue($param, $value, $type = ParameterType::STRING); | ||||
|  | ||||
|     /** | ||||
|      * Binds a PHP variable to a corresponding named (not supported by mysqli driver, see comment below) or question | ||||
|      * mark placeholder in the SQL statement that was use to prepare the statement. Unlike PDOStatement->bindValue(), | ||||
|      * the variable is bound as a reference and will only be evaluated at the time | ||||
|      * that PDOStatement->execute() is called. | ||||
|      * | ||||
|      * As mentioned above, the named parameters are not natively supported by the mysqli driver, use executeQuery(), | ||||
|      * fetchAll(), fetchArray(), fetchColumn(), fetchAssoc() methods to have the named parameter emulated by doctrine. | ||||
|      * | ||||
|      * Most parameters are input parameters, that is, parameters that are | ||||
|      * used in a read-only fashion to build up the query. Some drivers support the invocation | ||||
|      * of stored procedures that return data as output parameters, and some also as input/output | ||||
|      * parameters that both send in data and are updated to receive it. | ||||
|      * | ||||
|      * @param mixed    $column   Parameter identifier. For a prepared statement using named placeholders, | ||||
|      *                           this will be a parameter name of the form :name. For a prepared statement using | ||||
|      *                           question mark placeholders, this will be the 1-indexed position of the parameter. | ||||
|      * @param mixed    $variable Name of the PHP variable to bind to the SQL statement parameter. | ||||
|      * @param int|null $type     Explicit data type for the parameter using the {@link \Doctrine\DBAL\ParameterType} | ||||
|      *                           constants. To return an INOUT parameter from a stored procedure, use the bitwise | ||||
|      *                           OR operator to set the PDO::PARAM_INPUT_OUTPUT bits for the data_type parameter. | ||||
|      * @param int|null $length   You must specify maxlength when using an OUT bind | ||||
|      *                           so that PHP allocates enough memory to hold the returned value. | ||||
|      * | ||||
|      * @return bool TRUE on success or FALSE on failure. | ||||
|      */ | ||||
|     public function bindParam($column, &$variable, $type = ParameterType::STRING, $length = null); | ||||
|  | ||||
|     /** | ||||
|      * Fetches the SQLSTATE associated with the last operation on the statement handle. | ||||
|      * | ||||
|      * @see Doctrine_Adapter_Interface::errorCode() | ||||
|      * | ||||
|      * @return string|int|bool The error code string. | ||||
|      */ | ||||
|     public function errorCode(); | ||||
|  | ||||
|     /** | ||||
|      * Fetches extended error information associated with the last operation on the statement handle. | ||||
|      * | ||||
|      * @see Doctrine_Adapter_Interface::errorInfo() | ||||
|      * | ||||
|      * @return array The error info array. | ||||
|      */ | ||||
|     public function errorInfo(); | ||||
|  | ||||
|     /** | ||||
|      * Executes a prepared statement | ||||
|      * | ||||
|      * If the prepared statement included parameter markers, you must either: | ||||
|      * call PDOStatement->bindParam() to bind PHP variables to the parameter markers: | ||||
|      * bound variables pass their value as input and receive the output value, | ||||
|      * if any, of their associated parameter markers or pass an array of input-only | ||||
|      * parameter values. | ||||
|      * | ||||
|      * | ||||
|      * @param array|null $params An array of values with as many elements as there are | ||||
|      *                           bound parameters in the SQL statement being executed. | ||||
|      * | ||||
|      * @return bool TRUE on success or FALSE on failure. | ||||
|      */ | ||||
|     public function execute($params = null); | ||||
|  | ||||
|     /** | ||||
|      * Returns the number of rows affected by the last DELETE, INSERT, or UPDATE statement | ||||
|      * executed by the corresponding object. | ||||
|      * | ||||
|      * If the last SQL statement executed by the associated Statement object was a SELECT statement, | ||||
|      * some databases may return the number of rows returned by that statement. However, | ||||
|      * this behaviour is not guaranteed for all databases and should not be | ||||
|      * relied on for portable applications. | ||||
|      * | ||||
|      * @return int The number of rows. | ||||
|      */ | ||||
|     public function rowCount(); | ||||
| } | ||||
							
								
								
									
										29
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/StatementIterator.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										29
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/StatementIterator.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,29 @@ | ||||
| <?php | ||||
|  | ||||
| namespace Doctrine\DBAL\Driver; | ||||
|  | ||||
| class StatementIterator implements \IteratorAggregate | ||||
| { | ||||
|     /** | ||||
|      * @var Statement | ||||
|      */ | ||||
|     private $statement; | ||||
|  | ||||
|     /** | ||||
|      * @param Statement $statement | ||||
|      */ | ||||
|     public function __construct(Statement $statement) | ||||
|     { | ||||
|         $this->statement = $statement; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function getIterator() | ||||
|     { | ||||
|         while (false !== ($result = $this->statement->fetch())) { | ||||
|             yield $result; | ||||
|         } | ||||
|     } | ||||
| } | ||||
							
								
								
									
										425
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/DriverManager.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										425
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/DriverManager.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,425 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL; | ||||
|  | ||||
| use Doctrine\Common\EventManager; | ||||
| use function array_keys; | ||||
| use function array_map; | ||||
| use function array_merge; | ||||
| use function class_implements; | ||||
| use function in_array; | ||||
| use function is_subclass_of; | ||||
| use function parse_str; | ||||
| use function parse_url; | ||||
| use function preg_replace; | ||||
| use function str_replace; | ||||
| use function strpos; | ||||
| use function substr; | ||||
|  | ||||
| /** | ||||
|  * Factory for creating Doctrine\DBAL\Connection instances. | ||||
|  * | ||||
|  * @author Roman Borschel <roman@code-factory.org> | ||||
|  * @since 2.0 | ||||
|  */ | ||||
| final class DriverManager | ||||
| { | ||||
|     /** | ||||
|      * List of supported drivers and their mappings to the driver classes. | ||||
|      * | ||||
|      * To add your own driver use the 'driverClass' parameter to | ||||
|      * {@link DriverManager::getConnection()}. | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|      private static $_driverMap = [ | ||||
|          'pdo_mysql'          => 'Doctrine\DBAL\Driver\PDOMySql\Driver', | ||||
|          'pdo_sqlite'         => 'Doctrine\DBAL\Driver\PDOSqlite\Driver', | ||||
|          'pdo_pgsql'          => 'Doctrine\DBAL\Driver\PDOPgSql\Driver', | ||||
|          'pdo_oci'            => 'Doctrine\DBAL\Driver\PDOOracle\Driver', | ||||
|          'oci8'               => 'Doctrine\DBAL\Driver\OCI8\Driver', | ||||
|          'ibm_db2'            => 'Doctrine\DBAL\Driver\IBMDB2\DB2Driver', | ||||
|          'pdo_sqlsrv'         => 'Doctrine\DBAL\Driver\PDOSqlsrv\Driver', | ||||
|          'mysqli'             => 'Doctrine\DBAL\Driver\Mysqli\Driver', | ||||
|          'drizzle_pdo_mysql'  => 'Doctrine\DBAL\Driver\DrizzlePDOMySql\Driver', | ||||
|          'sqlanywhere'        => 'Doctrine\DBAL\Driver\SQLAnywhere\Driver', | ||||
|          'sqlsrv'             => 'Doctrine\DBAL\Driver\SQLSrv\Driver', | ||||
|     ]; | ||||
|  | ||||
|     /** | ||||
|      * List of URL schemes from a database URL and their mappings to driver. | ||||
|      */ | ||||
|     private static $driverSchemeAliases = [ | ||||
|         'db2'        => 'ibm_db2', | ||||
|         'mssql'      => 'pdo_sqlsrv', | ||||
|         'mysql'      => 'pdo_mysql', | ||||
|         'mysql2'     => 'pdo_mysql', // Amazon RDS, for some weird reason | ||||
|         'postgres'   => 'pdo_pgsql', | ||||
|         'postgresql' => 'pdo_pgsql', | ||||
|         'pgsql'      => 'pdo_pgsql', | ||||
|         'sqlite'     => 'pdo_sqlite', | ||||
|         'sqlite3'    => 'pdo_sqlite', | ||||
|     ]; | ||||
|  | ||||
|     /** | ||||
|      * Private constructor. This class cannot be instantiated. | ||||
|      */ | ||||
|     private function __construct() | ||||
|     { | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Creates a connection object based on the specified parameters. | ||||
|      * This method returns a Doctrine\DBAL\Connection which wraps the underlying | ||||
|      * driver connection. | ||||
|      * | ||||
|      * $params must contain at least one of the following. | ||||
|      * | ||||
|      * Either 'driver' with one of the following values: | ||||
|      * | ||||
|      *     pdo_mysql | ||||
|      *     pdo_sqlite | ||||
|      *     pdo_pgsql | ||||
|      *     pdo_oci (unstable) | ||||
|      *     pdo_sqlsrv | ||||
|      *     pdo_sqlsrv | ||||
|      *     mysqli | ||||
|      *     sqlanywhere | ||||
|      *     sqlsrv | ||||
|      *     ibm_db2 (unstable) | ||||
|      *     drizzle_pdo_mysql | ||||
|      * | ||||
|      * OR 'driverClass' that contains the full class name (with namespace) of the | ||||
|      * driver class to instantiate. | ||||
|      * | ||||
|      * Other (optional) parameters: | ||||
|      * | ||||
|      * <b>user (string)</b>: | ||||
|      * The username to use when connecting. | ||||
|      * | ||||
|      * <b>password (string)</b>: | ||||
|      * The password to use when connecting. | ||||
|      * | ||||
|      * <b>driverOptions (array)</b>: | ||||
|      * Any additional driver-specific options for the driver. These are just passed | ||||
|      * through to the driver. | ||||
|      * | ||||
|      * <b>pdo</b>: | ||||
|      * You can pass an existing PDO instance through this parameter. The PDO | ||||
|      * instance will be wrapped in a Doctrine\DBAL\Connection. | ||||
|      * | ||||
|      * <b>wrapperClass</b>: | ||||
|      * You may specify a custom wrapper class through the 'wrapperClass' | ||||
|      * parameter but this class MUST inherit from Doctrine\DBAL\Connection. | ||||
|      * | ||||
|      * <b>driverClass</b>: | ||||
|      * The driver class to use. | ||||
|      * | ||||
|      * @param array                              $params       The parameters. | ||||
|      * @param \Doctrine\DBAL\Configuration|null  $config       The configuration to use. | ||||
|      * @param \Doctrine\Common\EventManager|null $eventManager The event manager to use. | ||||
|      * | ||||
|      * @return \Doctrine\DBAL\Connection | ||||
|      * | ||||
|      * @throws \Doctrine\DBAL\DBALException | ||||
|      */ | ||||
|     public static function getConnection( | ||||
|             array $params, | ||||
|             Configuration $config = null, | ||||
|             EventManager $eventManager = null): Connection | ||||
|     { | ||||
|         // create default config and event manager, if not set | ||||
|         if ( ! $config) { | ||||
|             $config = new Configuration(); | ||||
|         } | ||||
|         if ( ! $eventManager) { | ||||
|             $eventManager = new EventManager(); | ||||
|         } | ||||
|  | ||||
|         $params = self::parseDatabaseUrl($params); | ||||
|  | ||||
|         // check for existing pdo object | ||||
|         if (isset($params['pdo']) && ! $params['pdo'] instanceof \PDO) { | ||||
|             throw DBALException::invalidPdoInstance(); | ||||
|         } elseif (isset($params['pdo'])) { | ||||
|             $params['pdo']->setAttribute(\PDO::ATTR_ERRMODE, \PDO::ERRMODE_EXCEPTION); | ||||
|             $params['driver'] = 'pdo_' . $params['pdo']->getAttribute(\PDO::ATTR_DRIVER_NAME); | ||||
|         } else { | ||||
|             self::_checkParams($params); | ||||
|         } | ||||
|  | ||||
|         $className = $params['driverClass'] ?? self::$_driverMap[$params['driver']]; | ||||
|  | ||||
|         $driver = new $className(); | ||||
|  | ||||
|         $wrapperClass = 'Doctrine\DBAL\Connection'; | ||||
|         if (isset($params['wrapperClass'])) { | ||||
|             if (is_subclass_of($params['wrapperClass'], $wrapperClass)) { | ||||
|                $wrapperClass = $params['wrapperClass']; | ||||
|             } else { | ||||
|                 throw DBALException::invalidWrapperClass($params['wrapperClass']); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         return new $wrapperClass($params, $driver, $config, $eventManager); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Returns the list of supported drivers. | ||||
|      * | ||||
|      * @return array | ||||
|      */ | ||||
|     public static function getAvailableDrivers(): array | ||||
|     { | ||||
|         return array_keys(self::$_driverMap); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Checks the list of parameters. | ||||
|      * | ||||
|      * @param array $params The list of parameters. | ||||
|      * | ||||
|      * @return void | ||||
|      * | ||||
|      * @throws \Doctrine\DBAL\DBALException | ||||
|      */ | ||||
|     private static function _checkParams(array $params): void | ||||
|     { | ||||
|         // check existence of mandatory parameters | ||||
|  | ||||
|         // driver | ||||
|         if ( ! isset($params['driver']) && ! isset($params['driverClass'])) { | ||||
|             throw DBALException::driverRequired(); | ||||
|         } | ||||
|  | ||||
|         // check validity of parameters | ||||
|  | ||||
|         // driver | ||||
|         if (isset($params['driver']) && ! isset(self::$_driverMap[$params['driver']])) { | ||||
|             throw DBALException::unknownDriver($params['driver'], array_keys(self::$_driverMap)); | ||||
|         } | ||||
|  | ||||
|         if (isset($params['driverClass']) && ! in_array('Doctrine\DBAL\Driver', class_implements($params['driverClass'], true))) { | ||||
|             throw DBALException::invalidDriverClass($params['driverClass']); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Normalizes the given connection URL path. | ||||
|      * | ||||
|      * @param string $urlPath | ||||
|      * | ||||
|      * @return string The normalized connection URL path | ||||
|      */ | ||||
|     private static function normalizeDatabaseUrlPath(string $urlPath): string | ||||
|     { | ||||
|         // Trim leading slash from URL path. | ||||
|         return substr($urlPath, 1); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Extracts parts from a database URL, if present, and returns an | ||||
|      * updated list of parameters. | ||||
|      * | ||||
|      * @param array $params The list of parameters. | ||||
|      * | ||||
|      * @return array A modified list of parameters with info from a database | ||||
|      *               URL extracted into indidivual parameter parts. | ||||
|      * | ||||
|      * @throws DBALException | ||||
|      */ | ||||
|     private static function parseDatabaseUrl(array $params): array | ||||
|     { | ||||
|         if (!isset($params['url'])) { | ||||
|             return $params; | ||||
|         } | ||||
|  | ||||
|         // (pdo_)?sqlite3?:///... => (pdo_)?sqlite3?://localhost/... or else the URL will be invalid | ||||
|         $url = preg_replace('#^((?:pdo_)?sqlite3?):///#', '$1://localhost/', $params['url']); | ||||
|         $url = parse_url($url); | ||||
|  | ||||
|         if ($url === false) { | ||||
|             throw new DBALException('Malformed parameter "url".'); | ||||
|         } | ||||
|  | ||||
|         $url = array_map('rawurldecode', $url); | ||||
|  | ||||
|         // If we have a connection URL, we have to unset the default PDO instance connection parameter (if any) | ||||
|         // as we cannot merge connection details from the URL into the PDO instance (URL takes precedence). | ||||
|         unset($params['pdo']); | ||||
|  | ||||
|         $params = self::parseDatabaseUrlScheme($url, $params); | ||||
|  | ||||
|         if (isset($url['host'])) { | ||||
|             $params['host'] = $url['host']; | ||||
|         } | ||||
|         if (isset($url['port'])) { | ||||
|             $params['port'] = $url['port']; | ||||
|         } | ||||
|         if (isset($url['user'])) { | ||||
|             $params['user'] = $url['user']; | ||||
|         } | ||||
|         if (isset($url['pass'])) { | ||||
|             $params['password'] = $url['pass']; | ||||
|         } | ||||
|  | ||||
|         $params = self::parseDatabaseUrlPath($url, $params); | ||||
|         $params = self::parseDatabaseUrlQuery($url, $params); | ||||
|  | ||||
|         return $params; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Parses the given connection URL and resolves the given connection parameters. | ||||
|      * | ||||
|      * Assumes that the connection URL scheme is already parsed and resolved into the given connection parameters | ||||
|      * via {@link parseDatabaseUrlScheme}. | ||||
|      * | ||||
|      * @param array $url    The URL parts to evaluate. | ||||
|      * @param array $params The connection parameters to resolve. | ||||
|      * | ||||
|      * @return array The resolved connection parameters. | ||||
|      * | ||||
|      * @see parseDatabaseUrlScheme | ||||
|      */ | ||||
|     private static function parseDatabaseUrlPath(array $url, array $params): array | ||||
|     { | ||||
|         if (! isset($url['path'])) { | ||||
|             return $params; | ||||
|         } | ||||
|  | ||||
|         $url['path'] = self::normalizeDatabaseUrlPath($url['path']); | ||||
|  | ||||
|         // If we do not have a known DBAL driver, we do not know any connection URL path semantics to evaluate | ||||
|         // and therefore treat the path as regular DBAL connection URL path. | ||||
|         if (! isset($params['driver'])) { | ||||
|             return self::parseRegularDatabaseUrlPath($url, $params); | ||||
|         } | ||||
|  | ||||
|         if (strpos($params['driver'], 'sqlite') !== false) { | ||||
|             return self::parseSqliteDatabaseUrlPath($url, $params); | ||||
|         } | ||||
|  | ||||
|         return self::parseRegularDatabaseUrlPath($url, $params); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Parses the query part of the given connection URL and resolves the given connection parameters. | ||||
|      * | ||||
|      * @param array $url    The connection URL parts to evaluate. | ||||
|      * @param array $params The connection parameters to resolve. | ||||
|      * | ||||
|      * @return array The resolved connection parameters. | ||||
|      */ | ||||
|     private static function parseDatabaseUrlQuery(array $url, array $params): array | ||||
|     { | ||||
|         if (! isset($url['query'])) { | ||||
|             return $params; | ||||
|         } | ||||
|  | ||||
|         $query = []; | ||||
|  | ||||
|         parse_str($url['query'], $query); // simply ingest query as extra params, e.g. charset or sslmode | ||||
|  | ||||
|         return array_merge($params, $query); // parse_str wipes existing array elements | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Parses the given regular connection URL and resolves the given connection parameters. | ||||
|      * | ||||
|      * Assumes that the "path" URL part is already normalized via {@link normalizeDatabaseUrlPath}. | ||||
|      * | ||||
|      * @param array $url    The regular connection URL parts to evaluate. | ||||
|      * @param array $params The connection parameters to resolve. | ||||
|      * | ||||
|      * @return array The resolved connection parameters. | ||||
|      * | ||||
|      * @see normalizeDatabaseUrlPath | ||||
|      */ | ||||
|     private static function parseRegularDatabaseUrlPath(array $url, array $params): array | ||||
|     { | ||||
|         $params['dbname'] = $url['path']; | ||||
|  | ||||
|         return $params; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Parses the given SQLite connection URL and resolves the given connection parameters. | ||||
|      * | ||||
|      * Assumes that the "path" URL part is already normalized via {@link normalizeDatabaseUrlPath}. | ||||
|      * | ||||
|      * @param array $url    The SQLite connection URL parts to evaluate. | ||||
|      * @param array $params The connection parameters to resolve. | ||||
|      * | ||||
|      * @return array The resolved connection parameters. | ||||
|      * | ||||
|      * @see normalizeDatabaseUrlPath | ||||
|      */ | ||||
|     private static function parseSqliteDatabaseUrlPath(array $url, array $params): array | ||||
|     { | ||||
|         if ($url['path'] === ':memory:') { | ||||
|             $params['memory'] = true; | ||||
|  | ||||
|             return $params; | ||||
|         } | ||||
|  | ||||
|         $params['path'] = $url['path']; // pdo_sqlite driver uses 'path' instead of 'dbname' key | ||||
|  | ||||
|         return $params; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Parses the scheme part from given connection URL and resolves the given connection parameters. | ||||
|      * | ||||
|      * @param array $url    The connection URL parts to evaluate. | ||||
|      * @param array $params The connection parameters to resolve. | ||||
|      * | ||||
|      * @return array The resolved connection parameters. | ||||
|      * | ||||
|      * @throws DBALException if parsing failed or resolution is not possible. | ||||
|      */ | ||||
|     private static function parseDatabaseUrlScheme(array $url, array $params): array | ||||
|     { | ||||
|         if (isset($url['scheme'])) { | ||||
|             // The requested driver from the URL scheme takes precedence | ||||
|             // over the default custom driver from the connection parameters (if any). | ||||
|             unset($params['driverClass']); | ||||
|  | ||||
|             // URL schemes must not contain underscores, but dashes are ok | ||||
|             $driver = str_replace('-', '_', $url['scheme']); | ||||
|  | ||||
|             // The requested driver from the URL scheme takes precedence over the | ||||
|             // default driver from the connection parameters. If the driver is | ||||
|             // an alias (e.g. "postgres"), map it to the actual name ("pdo-pgsql"). | ||||
|             // Otherwise, let checkParams decide later if the driver exists. | ||||
|             $params['driver'] = self::$driverSchemeAliases[$driver] ?? $driver; | ||||
|  | ||||
|             return $params; | ||||
|         } | ||||
|  | ||||
|         // If a schemeless connection URL is given, we require a default driver or default custom driver | ||||
|         // as connection parameter. | ||||
|         if (! isset($params['driverClass']) && ! isset($params['driver'])) { | ||||
|             throw DBALException::driverRequired($params['url']); | ||||
|         } | ||||
|  | ||||
|         return $params; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										78
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Event/ConnectionEventArgs.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										78
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Event/ConnectionEventArgs.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,78 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Event; | ||||
|  | ||||
| use Doctrine\Common\EventArgs; | ||||
| use Doctrine\DBAL\Connection; | ||||
|  | ||||
| /** | ||||
|  * Event Arguments used when a Driver connection is established inside Doctrine\DBAL\Connection. | ||||
|  * | ||||
|  * @link   www.doctrine-project.org | ||||
|  * @since  1.0 | ||||
|  * @author Benjamin Eberlei <kontakt@beberlei.de> | ||||
|  */ | ||||
| class ConnectionEventArgs extends EventArgs | ||||
| { | ||||
|     /** | ||||
|      * @var \Doctrine\DBAL\Connection | ||||
|      */ | ||||
|     private $_connection; | ||||
|  | ||||
|     /** | ||||
|      * @param \Doctrine\DBAL\Connection $connection | ||||
|      */ | ||||
|     public function __construct(Connection $connection) | ||||
|     { | ||||
|         $this->_connection = $connection; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @return \Doctrine\DBAL\Connection | ||||
|      */ | ||||
|     public function getConnection() | ||||
|     { | ||||
|         return $this->_connection; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @return \Doctrine\DBAL\Driver | ||||
|      */ | ||||
|     public function getDriver() | ||||
|     { | ||||
|         return $this->_connection->getDriver(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @return \Doctrine\DBAL\Platforms\AbstractPlatform | ||||
|      */ | ||||
|     public function getDatabasePlatform() | ||||
|     { | ||||
|         return $this->_connection->getDatabasePlatform(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @return \Doctrine\DBAL\Schema\AbstractSchemaManager | ||||
|      */ | ||||
|     public function getSchemaManager() | ||||
|     { | ||||
|         return $this->_connection->getSchemaManager(); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										80
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Event/Listeners/MysqlSessionInit.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										80
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Event/Listeners/MysqlSessionInit.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,80 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Event\Listeners; | ||||
|  | ||||
| use Doctrine\DBAL\Event\ConnectionEventArgs; | ||||
| use Doctrine\DBAL\Events; | ||||
| use Doctrine\Common\EventSubscriber; | ||||
|  | ||||
| /** | ||||
|  * MySQL Session Init Event Subscriber which allows to set the Client Encoding of the Connection. | ||||
|  * | ||||
|  * @link       www.doctrine-project.org | ||||
|  * @since      1.0 | ||||
|  * @author     Benjamin Eberlei <kontakt@beberlei.de> | ||||
|  * @deprecated Use "charset" option to PDO MySQL Connection instead. | ||||
|  */ | ||||
| class MysqlSessionInit implements EventSubscriber | ||||
| { | ||||
|     /** | ||||
|      * The charset. | ||||
|      * | ||||
|      * @var string | ||||
|      */ | ||||
|     private $_charset; | ||||
|  | ||||
|     /** | ||||
|      * The collation, or FALSE if no collation. | ||||
|      * | ||||
|      * @var string|boolean | ||||
|      */ | ||||
|     private $_collation; | ||||
|  | ||||
|     /** | ||||
|      * Configure Charset and Collation options of MySQL Client for each Connection. | ||||
|      * | ||||
|      * @param string         $charset   The charset. | ||||
|      * @param string|boolean $collation The collation, or FALSE if no collation. | ||||
|      */ | ||||
|     public function __construct($charset = 'utf8', $collation = false) | ||||
|     { | ||||
|         $this->_charset = $charset; | ||||
|         $this->_collation = $collation; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @param \Doctrine\DBAL\Event\ConnectionEventArgs $args | ||||
|      * | ||||
|      * @return void | ||||
|      */ | ||||
|     public function postConnect(ConnectionEventArgs $args) | ||||
|     { | ||||
|         $collation = ($this->_collation) ? " COLLATE ".$this->_collation : ""; | ||||
|         $args->getConnection()->executeUpdate("SET NAMES ".$this->_charset . $collation); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function getSubscribedEvents() | ||||
|     { | ||||
|         return [Events::postConnect]; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										94
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Event/Listeners/OracleSessionInit.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										94
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Event/Listeners/OracleSessionInit.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,94 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Event\Listeners; | ||||
|  | ||||
| use Doctrine\DBAL\Event\ConnectionEventArgs; | ||||
| use Doctrine\DBAL\Events; | ||||
| use Doctrine\Common\EventSubscriber; | ||||
| use function array_change_key_case; | ||||
| use function array_merge; | ||||
| use function count; | ||||
| use function implode; | ||||
|  | ||||
| /** | ||||
|  * Should be used when Oracle Server default environment does not match the Doctrine requirements. | ||||
|  * | ||||
|  * The following environment variables are required for the Doctrine default date format: | ||||
|  * | ||||
|  * NLS_TIME_FORMAT="HH24:MI:SS" | ||||
|  * NLS_DATE_FORMAT="YYYY-MM-DD HH24:MI:SS" | ||||
|  * NLS_TIMESTAMP_FORMAT="YYYY-MM-DD HH24:MI:SS" | ||||
|  * NLS_TIMESTAMP_TZ_FORMAT="YYYY-MM-DD HH24:MI:SS TZH:TZM" | ||||
|  * | ||||
|  * @link   www.doctrine-project.org | ||||
|  * @since  2.0 | ||||
|  * @author Benjamin Eberlei <kontakt@beberlei.de> | ||||
|  */ | ||||
| class OracleSessionInit implements EventSubscriber | ||||
| { | ||||
|     /** | ||||
|      * @var array | ||||
|      */ | ||||
|     protected $_defaultSessionVars = [ | ||||
|         'NLS_TIME_FORMAT' => "HH24:MI:SS", | ||||
|         'NLS_DATE_FORMAT' => "YYYY-MM-DD HH24:MI:SS", | ||||
|         'NLS_TIMESTAMP_FORMAT' => "YYYY-MM-DD HH24:MI:SS", | ||||
|         'NLS_TIMESTAMP_TZ_FORMAT' => "YYYY-MM-DD HH24:MI:SS TZH:TZM", | ||||
|         'NLS_NUMERIC_CHARACTERS' => ".,", | ||||
|     ]; | ||||
|  | ||||
|     /** | ||||
|      * @param array $oracleSessionVars | ||||
|      */ | ||||
|     public function __construct(array $oracleSessionVars = []) | ||||
|     { | ||||
|         $this->_defaultSessionVars = array_merge($this->_defaultSessionVars, $oracleSessionVars); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @param \Doctrine\DBAL\Event\ConnectionEventArgs $args | ||||
|      * | ||||
|      * @return void | ||||
|      */ | ||||
|     public function postConnect(ConnectionEventArgs $args) | ||||
|     { | ||||
|         if (count($this->_defaultSessionVars)) { | ||||
|             array_change_key_case($this->_defaultSessionVars, \CASE_UPPER); | ||||
|             $vars = []; | ||||
|             foreach ($this->_defaultSessionVars as $option => $value) { | ||||
|                 if ($option === 'CURRENT_SCHEMA') { | ||||
|                     $vars[] = $option . " = " . $value; | ||||
|                 } else { | ||||
|                     $vars[] = $option . " = '" . $value . "'"; | ||||
|                 } | ||||
|             } | ||||
|             $sql = "ALTER SESSION SET ".implode(" ", $vars); | ||||
|             $args->getConnection()->executeUpdate($sql); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function getSubscribedEvents() | ||||
|     { | ||||
|         return [Events::postConnect]; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										66
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Event/Listeners/SQLSessionInit.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										66
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Event/Listeners/SQLSessionInit.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,66 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Event\Listeners; | ||||
|  | ||||
| use Doctrine\DBAL\Event\ConnectionEventArgs; | ||||
| use Doctrine\DBAL\Events; | ||||
| use Doctrine\Common\EventSubscriber; | ||||
|  | ||||
| /** | ||||
|  * Session init listener for executing a single SQL statement right after a connection is opened. | ||||
|  * | ||||
|  * @link    www.doctrine-project.org | ||||
|  * @since   2.2 | ||||
|  * @author  Benjamin Eberlei <kontakt@beberlei.de> | ||||
|  */ | ||||
| class SQLSessionInit implements EventSubscriber | ||||
| { | ||||
|     /** | ||||
|      * @var string | ||||
|      */ | ||||
|     protected $sql; | ||||
|  | ||||
|     /** | ||||
|      * @param string $sql | ||||
|      */ | ||||
|     public function __construct($sql) | ||||
|     { | ||||
|         $this->sql = $sql; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @param \Doctrine\DBAL\Event\ConnectionEventArgs $args | ||||
|      * | ||||
|      * @return void | ||||
|      */ | ||||
|     public function postConnect(ConnectionEventArgs $args) | ||||
|     { | ||||
|         $conn = $args->getConnection(); | ||||
|         $conn->exec($this->sql); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function getSubscribedEvents() | ||||
|     { | ||||
|         return [Events::postConnect]; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										116
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Event/SchemaAlterTableAddColumnEventArgs.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										116
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Event/SchemaAlterTableAddColumnEventArgs.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,116 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Event; | ||||
|  | ||||
| use Doctrine\DBAL\Platforms\AbstractPlatform; | ||||
| use Doctrine\DBAL\Schema\Column; | ||||
| use Doctrine\DBAL\Schema\TableDiff; | ||||
| use function array_merge; | ||||
| use function is_array; | ||||
|  | ||||
| /** | ||||
|  * Event Arguments used when SQL queries for adding table columns are generated inside Doctrine\DBAL\Platform\*Platform. | ||||
|  * | ||||
|  * @link   www.doctrine-project.org | ||||
|  * @since  2.2 | ||||
|  * @author Jan Sorgalla <jsorgalla@googlemail.com> | ||||
|  */ | ||||
| class SchemaAlterTableAddColumnEventArgs extends SchemaEventArgs | ||||
| { | ||||
|     /** | ||||
|      * @var \Doctrine\DBAL\Schema\Column | ||||
|      */ | ||||
|     private $_column; | ||||
|  | ||||
|     /** | ||||
|      * @var \Doctrine\DBAL\Schema\TableDiff | ||||
|      */ | ||||
|     private $_tableDiff; | ||||
|  | ||||
|     /** | ||||
|      * @var \Doctrine\DBAL\Platforms\AbstractPlatform | ||||
|      */ | ||||
|     private $_platform; | ||||
|  | ||||
|     /** | ||||
|      * @var array | ||||
|      */ | ||||
|     private $_sql = []; | ||||
|  | ||||
|     /** | ||||
|      * @param \Doctrine\DBAL\Schema\Column              $column | ||||
|      * @param \Doctrine\DBAL\Schema\TableDiff           $tableDiff | ||||
|      * @param \Doctrine\DBAL\Platforms\AbstractPlatform $platform | ||||
|      */ | ||||
|     public function __construct(Column $column, TableDiff $tableDiff, AbstractPlatform $platform) | ||||
|     { | ||||
|         $this->_column    = $column; | ||||
|         $this->_tableDiff = $tableDiff; | ||||
|         $this->_platform  = $platform; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @return \Doctrine\DBAL\Schema\Column | ||||
|      */ | ||||
|     public function getColumn() | ||||
|     { | ||||
|         return $this->_column; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @return \Doctrine\DBAL\Schema\TableDiff | ||||
|      */ | ||||
|     public function getTableDiff() | ||||
|     { | ||||
|         return $this->_tableDiff; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @return \Doctrine\DBAL\Platforms\AbstractPlatform | ||||
|      */ | ||||
|     public function getPlatform() | ||||
|     { | ||||
|         return $this->_platform; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @param string|array $sql | ||||
|      * | ||||
|      * @return \Doctrine\DBAL\Event\SchemaAlterTableAddColumnEventArgs | ||||
|      */ | ||||
|     public function addSql($sql) | ||||
|     { | ||||
|         if (is_array($sql)) { | ||||
|             $this->_sql = array_merge($this->_sql, $sql); | ||||
|         } else { | ||||
|             $this->_sql[] = $sql; | ||||
|         } | ||||
|  | ||||
|         return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @return array | ||||
|      */ | ||||
|     public function getSql() | ||||
|     { | ||||
|         return $this->_sql; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										116
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Event/SchemaAlterTableChangeColumnEventArgs.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										116
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Event/SchemaAlterTableChangeColumnEventArgs.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,116 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Event; | ||||
|  | ||||
| use Doctrine\DBAL\Platforms\AbstractPlatform; | ||||
| use Doctrine\DBAL\Schema\ColumnDiff; | ||||
| use Doctrine\DBAL\Schema\TableDiff; | ||||
| use function array_merge; | ||||
| use function is_array; | ||||
|  | ||||
| /** | ||||
|  * Event Arguments used when SQL queries for changing table columns are generated inside Doctrine\DBAL\Platform\*Platform. | ||||
|  * | ||||
|  * @link   www.doctrine-project.org | ||||
|  * @since  2.2 | ||||
|  * @author Jan Sorgalla <jsorgalla@googlemail.com> | ||||
|  */ | ||||
| class SchemaAlterTableChangeColumnEventArgs extends SchemaEventArgs | ||||
| { | ||||
|     /** | ||||
|      * @var \Doctrine\DBAL\Schema\ColumnDiff | ||||
|      */ | ||||
|     private $_columnDiff; | ||||
|  | ||||
|     /** | ||||
|      * @var \Doctrine\DBAL\Schema\TableDiff | ||||
|      */ | ||||
|     private $_tableDiff; | ||||
|  | ||||
|     /** | ||||
|      * @var \Doctrine\DBAL\Platforms\AbstractPlatform | ||||
|      */ | ||||
|     private $_platform; | ||||
|  | ||||
|     /** | ||||
|      * @var array | ||||
|      */ | ||||
|     private $_sql = []; | ||||
|  | ||||
|     /** | ||||
|      * @param \Doctrine\DBAL\Schema\ColumnDiff          $columnDiff | ||||
|      * @param \Doctrine\DBAL\Schema\TableDiff           $tableDiff | ||||
|      * @param \Doctrine\DBAL\Platforms\AbstractPlatform $platform | ||||
|      */ | ||||
|     public function __construct(ColumnDiff $columnDiff, TableDiff $tableDiff, AbstractPlatform $platform) | ||||
|     { | ||||
|         $this->_columnDiff = $columnDiff; | ||||
|         $this->_tableDiff  = $tableDiff; | ||||
|         $this->_platform   = $platform; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @return \Doctrine\DBAL\Schema\ColumnDiff | ||||
|      */ | ||||
|     public function getColumnDiff() | ||||
|     { | ||||
|         return $this->_columnDiff; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @return \Doctrine\DBAL\Schema\TableDiff | ||||
|      */ | ||||
|     public function getTableDiff() | ||||
|     { | ||||
|         return $this->_tableDiff; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @return \Doctrine\DBAL\Platforms\AbstractPlatform | ||||
|      */ | ||||
|     public function getPlatform() | ||||
|     { | ||||
|         return $this->_platform; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @param string|array $sql | ||||
|      * | ||||
|      * @return \Doctrine\DBAL\Event\SchemaAlterTableChangeColumnEventArgs | ||||
|      */ | ||||
|     public function addSql($sql) | ||||
|     { | ||||
|         if (is_array($sql)) { | ||||
|             $this->_sql = array_merge($this->_sql, $sql); | ||||
|         } else { | ||||
|             $this->_sql[] = $sql; | ||||
|         } | ||||
|  | ||||
|         return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @return array | ||||
|      */ | ||||
|     public function getSql() | ||||
|     { | ||||
|         return $this->_sql; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										100
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Event/SchemaAlterTableEventArgs.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										100
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Event/SchemaAlterTableEventArgs.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,100 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Event; | ||||
|  | ||||
| use Doctrine\DBAL\Platforms\AbstractPlatform; | ||||
| use Doctrine\DBAL\Schema\TableDiff; | ||||
| use function array_merge; | ||||
| use function is_array; | ||||
|  | ||||
| /** | ||||
|  * Event Arguments used when SQL queries for creating tables are generated inside Doctrine\DBAL\Platform\*Platform. | ||||
|  * | ||||
|  * @link   www.doctrine-project.org | ||||
|  * @since  2.2 | ||||
|  * @author Jan Sorgalla <jsorgalla@googlemail.com> | ||||
|  */ | ||||
| class SchemaAlterTableEventArgs extends SchemaEventArgs | ||||
| { | ||||
|     /** | ||||
|      * @var \Doctrine\DBAL\Schema\TableDiff | ||||
|      */ | ||||
|     private $_tableDiff; | ||||
|  | ||||
|     /** | ||||
|      * @var \Doctrine\DBAL\Platforms\AbstractPlatform | ||||
|      */ | ||||
|     private $_platform; | ||||
|  | ||||
|     /** | ||||
|      * @var array | ||||
|      */ | ||||
|     private $_sql = []; | ||||
|  | ||||
|     /** | ||||
|      * @param \Doctrine\DBAL\Schema\TableDiff           $tableDiff | ||||
|      * @param \Doctrine\DBAL\Platforms\AbstractPlatform $platform | ||||
|      */ | ||||
|     public function __construct(TableDiff $tableDiff, AbstractPlatform $platform) | ||||
|     { | ||||
|         $this->_tableDiff = $tableDiff; | ||||
|         $this->_platform  = $platform; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @return \Doctrine\DBAL\Schema\TableDiff | ||||
|      */ | ||||
|     public function getTableDiff() | ||||
|     { | ||||
|         return $this->_tableDiff; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @return \Doctrine\DBAL\Platforms\AbstractPlatform | ||||
|      */ | ||||
|     public function getPlatform() | ||||
|     { | ||||
|         return $this->_platform; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @param string|array $sql | ||||
|      * | ||||
|      * @return \Doctrine\DBAL\Event\SchemaAlterTableEventArgs | ||||
|      */ | ||||
|     public function addSql($sql) | ||||
|     { | ||||
|         if (is_array($sql)) { | ||||
|             $this->_sql = array_merge($this->_sql, $sql); | ||||
|         } else { | ||||
|             $this->_sql[] = $sql; | ||||
|         } | ||||
|  | ||||
|         return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @return array | ||||
|      */ | ||||
|     public function getSql() | ||||
|     { | ||||
|         return $this->_sql; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										116
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Event/SchemaAlterTableRemoveColumnEventArgs.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										116
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Event/SchemaAlterTableRemoveColumnEventArgs.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,116 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Event; | ||||
|  | ||||
| use Doctrine\DBAL\Platforms\AbstractPlatform; | ||||
| use Doctrine\DBAL\Schema\Column; | ||||
| use Doctrine\DBAL\Schema\TableDiff; | ||||
| use function array_merge; | ||||
| use function is_array; | ||||
|  | ||||
| /** | ||||
|  * Event Arguments used when SQL queries for removing table columns are generated inside Doctrine\DBAL\Platform\*Platform. | ||||
|  * | ||||
|  * @link   www.doctrine-project.org | ||||
|  * @since  2.2 | ||||
|  * @author Jan Sorgalla <jsorgalla@googlemail.com> | ||||
|  */ | ||||
| class SchemaAlterTableRemoveColumnEventArgs extends SchemaEventArgs | ||||
| { | ||||
|     /** | ||||
|      * @var \Doctrine\DBAL\Schema\Column | ||||
|      */ | ||||
|     private $_column; | ||||
|  | ||||
|     /** | ||||
|      * @var \Doctrine\DBAL\Schema\TableDiff | ||||
|      */ | ||||
|     private $_tableDiff; | ||||
|  | ||||
|     /** | ||||
|      * @var \Doctrine\DBAL\Platforms\AbstractPlatform | ||||
|      */ | ||||
|     private $_platform; | ||||
|  | ||||
|     /** | ||||
|      * @var array | ||||
|      */ | ||||
|     private $_sql = []; | ||||
|  | ||||
|     /** | ||||
|      * @param \Doctrine\DBAL\Schema\Column              $column | ||||
|      * @param \Doctrine\DBAL\Schema\TableDiff           $tableDiff | ||||
|      * @param \Doctrine\DBAL\Platforms\AbstractPlatform $platform | ||||
|      */ | ||||
|     public function __construct(Column $column, TableDiff $tableDiff, AbstractPlatform $platform) | ||||
|     { | ||||
|         $this->_column    = $column; | ||||
|         $this->_tableDiff = $tableDiff; | ||||
|         $this->_platform  = $platform; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @return \Doctrine\DBAL\Schema\Column | ||||
|      */ | ||||
|     public function getColumn() | ||||
|     { | ||||
|         return $this->_column; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @return \Doctrine\DBAL\Schema\TableDiff | ||||
|      */ | ||||
|     public function getTableDiff() | ||||
|     { | ||||
|         return $this->_tableDiff; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @return \Doctrine\DBAL\Platforms\AbstractPlatform | ||||
|      */ | ||||
|     public function getPlatform() | ||||
|     { | ||||
|         return $this->_platform; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @param string|array $sql | ||||
|      * | ||||
|      * @return \Doctrine\DBAL\Event\SchemaAlterTableRemoveColumnEventArgs | ||||
|      */ | ||||
|     public function addSql($sql) | ||||
|     { | ||||
|         if (is_array($sql)) { | ||||
|             $this->_sql = array_merge($this->_sql, $sql); | ||||
|         } else { | ||||
|             $this->_sql[] = $sql; | ||||
|         } | ||||
|  | ||||
|         return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @return array | ||||
|      */ | ||||
|     public function getSql() | ||||
|     { | ||||
|         return $this->_sql; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										131
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Event/SchemaAlterTableRenameColumnEventArgs.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										131
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Event/SchemaAlterTableRenameColumnEventArgs.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,131 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Event; | ||||
|  | ||||
| use Doctrine\DBAL\Platforms\AbstractPlatform; | ||||
| use Doctrine\DBAL\Schema\Column; | ||||
| use Doctrine\DBAL\Schema\TableDiff; | ||||
| use function array_merge; | ||||
| use function is_array; | ||||
|  | ||||
| /** | ||||
|  * Event Arguments used when SQL queries for renaming table columns are generated inside Doctrine\DBAL\Platform\*Platform. | ||||
|  * | ||||
|  * @link   www.doctrine-project.org | ||||
|  * @since  2.2 | ||||
|  * @author Jan Sorgalla <jsorgalla@googlemail.com> | ||||
|  */ | ||||
| class SchemaAlterTableRenameColumnEventArgs extends SchemaEventArgs | ||||
| { | ||||
|     /** | ||||
|      * @var string | ||||
|      */ | ||||
|     private $_oldColumnName; | ||||
|  | ||||
|     /** | ||||
|      * @var \Doctrine\DBAL\Schema\Column | ||||
|      */ | ||||
|     private $_column; | ||||
|  | ||||
|     /** | ||||
|      * @var \Doctrine\DBAL\Schema\TableDiff | ||||
|      */ | ||||
|     private $_tableDiff; | ||||
|  | ||||
|     /** | ||||
|      * @var \Doctrine\DBAL\Platforms\AbstractPlatform | ||||
|      */ | ||||
|     private $_platform; | ||||
|  | ||||
|     /** | ||||
|      * @var array | ||||
|      */ | ||||
|     private $_sql = []; | ||||
|  | ||||
|     /** | ||||
|      * @param string                                    $oldColumnName | ||||
|      * @param \Doctrine\DBAL\Schema\Column              $column | ||||
|      * @param \Doctrine\DBAL\Schema\TableDiff           $tableDiff | ||||
|      * @param \Doctrine\DBAL\Platforms\AbstractPlatform $platform | ||||
|      */ | ||||
|     public function __construct($oldColumnName, Column $column, TableDiff $tableDiff, AbstractPlatform $platform) | ||||
|     { | ||||
|         $this->_oldColumnName = $oldColumnName; | ||||
|         $this->_column        = $column; | ||||
|         $this->_tableDiff     = $tableDiff; | ||||
|         $this->_platform      = $platform; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @return string | ||||
|      */ | ||||
|     public function getOldColumnName() | ||||
|     { | ||||
|         return $this->_oldColumnName; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @return \Doctrine\DBAL\Schema\Column | ||||
|      */ | ||||
|     public function getColumn() | ||||
|     { | ||||
|         return $this->_column; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @return \Doctrine\DBAL\Schema\TableDiff | ||||
|      */ | ||||
|     public function getTableDiff() | ||||
|     { | ||||
|         return $this->_tableDiff; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @return \Doctrine\DBAL\Platforms\AbstractPlatform | ||||
|      */ | ||||
|     public function getPlatform() | ||||
|     { | ||||
|         return $this->_platform; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @param string|array $sql | ||||
|      * | ||||
|      * @return \Doctrine\DBAL\Event\SchemaAlterTableRenameColumnEventArgs | ||||
|      */ | ||||
|     public function addSql($sql) | ||||
|     { | ||||
|         if (is_array($sql)) { | ||||
|             $this->_sql = array_merge($this->_sql, $sql); | ||||
|         } else { | ||||
|             $this->_sql[] = $sql; | ||||
|         } | ||||
|  | ||||
|         return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @return array | ||||
|      */ | ||||
|     public function getSql() | ||||
|     { | ||||
|         return $this->_sql; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										137
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Event/SchemaColumnDefinitionEventArgs.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										137
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Event/SchemaColumnDefinitionEventArgs.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,137 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Event; | ||||
|  | ||||
| use Doctrine\DBAL\Connection; | ||||
| use Doctrine\DBAL\Schema\Column; | ||||
|  | ||||
| /** | ||||
|  * Event Arguments used when the portable column definition is generated inside Doctrine\DBAL\Schema\AbstractSchemaManager. | ||||
|  * | ||||
|  * @link   www.doctrine-project.org | ||||
|  * @since  2.2 | ||||
|  * @author Jan Sorgalla <jsorgalla@googlemail.com> | ||||
|  */ | ||||
| class SchemaColumnDefinitionEventArgs extends SchemaEventArgs | ||||
| { | ||||
|     /** | ||||
|      * @var \Doctrine\DBAL\Schema\Column|null | ||||
|      */ | ||||
|     private $_column = null; | ||||
|  | ||||
|     /** | ||||
|      * Raw column data as fetched from the database. | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     private $_tableColumn; | ||||
|  | ||||
|     /** | ||||
|      * @var string | ||||
|      */ | ||||
|     private $_table; | ||||
|  | ||||
|     /** | ||||
|      * @var string | ||||
|      */ | ||||
|     private $_database; | ||||
|  | ||||
|     /** | ||||
|      * @var \Doctrine\DBAL\Connection | ||||
|      */ | ||||
|     private $_connection; | ||||
|  | ||||
|     /** | ||||
|      * @param array                     $tableColumn | ||||
|      * @param string                    $table | ||||
|      * @param string                    $database | ||||
|      * @param \Doctrine\DBAL\Connection $connection | ||||
|      */ | ||||
|     public function __construct(array $tableColumn, $table, $database, Connection $connection) | ||||
|     { | ||||
|         $this->_tableColumn = $tableColumn; | ||||
|         $this->_table       = $table; | ||||
|         $this->_database    = $database; | ||||
|         $this->_connection  = $connection; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Allows to clear the column which means the column will be excluded from | ||||
|      * tables column list. | ||||
|      * | ||||
|      * @param null|\Doctrine\DBAL\Schema\Column $column | ||||
|      * | ||||
|      * @return \Doctrine\DBAL\Event\SchemaColumnDefinitionEventArgs | ||||
|      */ | ||||
|     public function setColumn(Column $column = null) | ||||
|     { | ||||
|         $this->_column = $column; | ||||
|  | ||||
|         return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @return \Doctrine\DBAL\Schema\Column|null | ||||
|      */ | ||||
|     public function getColumn() | ||||
|     { | ||||
|         return $this->_column; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @return array | ||||
|      */ | ||||
|     public function getTableColumn() | ||||
|     { | ||||
|         return $this->_tableColumn; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @return string | ||||
|      */ | ||||
|     public function getTable() | ||||
|     { | ||||
|         return $this->_table; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @return string | ||||
|      */ | ||||
|     public function getDatabase() | ||||
|     { | ||||
|         return $this->_database; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @return \Doctrine\DBAL\Connection | ||||
|      */ | ||||
|     public function getConnection() | ||||
|     { | ||||
|         return $this->_connection; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @return \Doctrine\DBAL\Platforms\AbstractPlatform | ||||
|      */ | ||||
|     public function getDatabasePlatform() | ||||
|     { | ||||
|         return $this->_connection->getDatabasePlatform(); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										116
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Event/SchemaCreateTableColumnEventArgs.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										116
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Event/SchemaCreateTableColumnEventArgs.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,116 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Event; | ||||
|  | ||||
| use Doctrine\DBAL\Platforms\AbstractPlatform; | ||||
| use Doctrine\DBAL\Schema\Column; | ||||
| use Doctrine\DBAL\Schema\Table; | ||||
| use function array_merge; | ||||
| use function is_array; | ||||
|  | ||||
| /** | ||||
|  * Event Arguments used when SQL queries for creating table columns are generated inside Doctrine\DBAL\Platform\AbstractPlatform. | ||||
|  * | ||||
|  * @link   www.doctrine-project.org | ||||
|  * @since  2.2 | ||||
|  * @author Jan Sorgalla <jsorgalla@googlemail.com> | ||||
|  */ | ||||
| class SchemaCreateTableColumnEventArgs extends SchemaEventArgs | ||||
| { | ||||
|     /** | ||||
|      * @var \Doctrine\DBAL\Schema\Column | ||||
|      */ | ||||
|     private $_column; | ||||
|  | ||||
|     /** | ||||
|      * @var \Doctrine\DBAL\Schema\Table | ||||
|      */ | ||||
|     private $_table; | ||||
|  | ||||
|     /** | ||||
|      * @var \Doctrine\DBAL\Platforms\AbstractPlatform | ||||
|      */ | ||||
|     private $_platform; | ||||
|  | ||||
|     /** | ||||
|      * @var array | ||||
|      */ | ||||
|     private $_sql = []; | ||||
|  | ||||
|     /** | ||||
|      * @param \Doctrine\DBAL\Schema\Column              $column | ||||
|      * @param \Doctrine\DBAL\Schema\Table               $table | ||||
|      * @param \Doctrine\DBAL\Platforms\AbstractPlatform $platform | ||||
|      */ | ||||
|     public function __construct(Column $column, Table $table, AbstractPlatform $platform) | ||||
|     { | ||||
|         $this->_column   = $column; | ||||
|         $this->_table    = $table; | ||||
|         $this->_platform = $platform; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @return \Doctrine\DBAL\Schema\Column | ||||
|      */ | ||||
|     public function getColumn() | ||||
|     { | ||||
|         return $this->_column; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @return \Doctrine\DBAL\Schema\Table | ||||
|      */ | ||||
|     public function getTable() | ||||
|     { | ||||
|         return $this->_table; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @return \Doctrine\DBAL\Platforms\AbstractPlatform | ||||
|      */ | ||||
|     public function getPlatform() | ||||
|     { | ||||
|         return $this->_platform; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @param string|array $sql | ||||
|      * | ||||
|      * @return \Doctrine\DBAL\Event\SchemaCreateTableColumnEventArgs | ||||
|      */ | ||||
|     public function addSql($sql) | ||||
|     { | ||||
|         if (is_array($sql)) { | ||||
|             $this->_sql = array_merge($this->_sql, $sql); | ||||
|         } else { | ||||
|             $this->_sql[] = $sql; | ||||
|         } | ||||
|  | ||||
|         return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @return array | ||||
|      */ | ||||
|     public function getSql() | ||||
|     { | ||||
|         return $this->_sql; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										130
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Event/SchemaCreateTableEventArgs.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										130
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Event/SchemaCreateTableEventArgs.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,130 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Event; | ||||
|  | ||||
| use Doctrine\DBAL\Platforms\AbstractPlatform; | ||||
| use Doctrine\DBAL\Schema\Table; | ||||
| use function array_merge; | ||||
| use function is_array; | ||||
|  | ||||
| /** | ||||
|  * Event Arguments used when SQL queries for creating tables are generated inside Doctrine\DBAL\Platform\AbstractPlatform. | ||||
|  * | ||||
|  * @link   www.doctrine-project.org | ||||
|  * @since  2.2 | ||||
|  * @author Jan Sorgalla <jsorgalla@googlemail.com> | ||||
|  */ | ||||
| class SchemaCreateTableEventArgs extends SchemaEventArgs | ||||
| { | ||||
|     /** | ||||
|      * @var \Doctrine\DBAL\Schema\Table | ||||
|      */ | ||||
|     private $_table; | ||||
|  | ||||
|     /** | ||||
|      * @var array | ||||
|      */ | ||||
|     private $_columns; | ||||
|  | ||||
|     /** | ||||
|      * @var array | ||||
|      */ | ||||
|     private $_options; | ||||
|  | ||||
|     /** | ||||
|      * @var \Doctrine\DBAL\Platforms\AbstractPlatform | ||||
|      */ | ||||
|     private $_platform; | ||||
|  | ||||
|     /** | ||||
|      * @var array | ||||
|      */ | ||||
|     private $_sql = []; | ||||
|  | ||||
|     /** | ||||
|      * @param \Doctrine\DBAL\Schema\Table               $table | ||||
|      * @param array                                     $columns | ||||
|      * @param array                                     $options | ||||
|      * @param \Doctrine\DBAL\Platforms\AbstractPlatform $platform | ||||
|      */ | ||||
|     public function __construct(Table $table, array $columns, array $options, AbstractPlatform $platform) | ||||
|     { | ||||
|         $this->_table    = $table; | ||||
|         $this->_columns  = $columns; | ||||
|         $this->_options  = $options; | ||||
|         $this->_platform = $platform; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @return \Doctrine\DBAL\Schema\Table | ||||
|      */ | ||||
|     public function getTable() | ||||
|     { | ||||
|         return $this->_table; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @return array | ||||
|      */ | ||||
|     public function getColumns() | ||||
|     { | ||||
|         return $this->_columns; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @return array | ||||
|      */ | ||||
|     public function getOptions() | ||||
|     { | ||||
|         return $this->_options; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @return \Doctrine\DBAL\Platforms\AbstractPlatform | ||||
|      */ | ||||
|     public function getPlatform() | ||||
|     { | ||||
|         return $this->_platform; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @param string|array $sql | ||||
|      * | ||||
|      * @return \Doctrine\DBAL\Event\SchemaCreateTableEventArgs | ||||
|      */ | ||||
|     public function addSql($sql) | ||||
|     { | ||||
|         if (is_array($sql)) { | ||||
|             $this->_sql = array_merge($this->_sql, $sql); | ||||
|         } else { | ||||
|             $this->_sql[] = $sql; | ||||
|         } | ||||
|  | ||||
|         return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @return array | ||||
|      */ | ||||
|     public function getSql() | ||||
|     { | ||||
|         return $this->_sql; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										101
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Event/SchemaDropTableEventArgs.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										101
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Event/SchemaDropTableEventArgs.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,101 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Event; | ||||
|  | ||||
| use Doctrine\DBAL\Platforms\AbstractPlatform; | ||||
| use Doctrine\DBAL\Schema\Table; | ||||
| use function is_string; | ||||
|  | ||||
| /** | ||||
|  * Event Arguments used when the SQL query for dropping tables are generated inside Doctrine\DBAL\Platform\AbstractPlatform. | ||||
|  * | ||||
|  * @link   www.doctrine-project.org | ||||
|  * @since  2.2 | ||||
|  * @author Jan Sorgalla <jsorgalla@googlemail.com> | ||||
|  */ | ||||
| class SchemaDropTableEventArgs extends SchemaEventArgs | ||||
| { | ||||
|     /** | ||||
|      * @var string|\Doctrine\DBAL\Schema\Table | ||||
|      */ | ||||
|     private $_table; | ||||
|  | ||||
|     /** | ||||
|      * @var \Doctrine\DBAL\Platforms\AbstractPlatform | ||||
|      */ | ||||
|     private $_platform; | ||||
|  | ||||
|     /** | ||||
|      * @var string|null | ||||
|      */ | ||||
|     private $_sql = null; | ||||
|  | ||||
|     /** | ||||
|      * @param string|\Doctrine\DBAL\Schema\Table        $table | ||||
|      * @param \Doctrine\DBAL\Platforms\AbstractPlatform $platform | ||||
|      * | ||||
|      * @throws \InvalidArgumentException | ||||
|      */ | ||||
|     public function __construct($table, AbstractPlatform $platform) | ||||
|     { | ||||
|         if ( ! $table instanceof Table && !is_string($table)) { | ||||
|             throw new \InvalidArgumentException('SchemaDropTableEventArgs expects $table parameter to be string or \Doctrine\DBAL\Schema\Table.'); | ||||
|         } | ||||
|  | ||||
|         $this->_table    = $table; | ||||
|         $this->_platform = $platform; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @return string|\Doctrine\DBAL\Schema\Table | ||||
|      */ | ||||
|     public function getTable() | ||||
|     { | ||||
|         return $this->_table; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @return \Doctrine\DBAL\Platforms\AbstractPlatform | ||||
|      */ | ||||
|     public function getPlatform() | ||||
|     { | ||||
|         return $this->_platform; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @param string $sql | ||||
|      * | ||||
|      * @return \Doctrine\DBAL\Event\SchemaDropTableEventArgs | ||||
|      */ | ||||
|     public function setSql($sql) | ||||
|     { | ||||
|         $this->_sql = $sql; | ||||
|  | ||||
|         return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @return string|null | ||||
|      */ | ||||
|     public function getSql() | ||||
|     { | ||||
|         return $this->_sql; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										55
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Event/SchemaEventArgs.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										55
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Event/SchemaEventArgs.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,55 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Event; | ||||
|  | ||||
| use Doctrine\Common\EventArgs; | ||||
|  | ||||
| /** | ||||
|  * Base class for schema related events. | ||||
|  * | ||||
|  * @link   www.doctrine-project.org | ||||
|  * @since  2.2 | ||||
|  * @author Jan Sorgalla <jsorgalla@googlemail.com> | ||||
|  */ | ||||
| class SchemaEventArgs extends EventArgs | ||||
| { | ||||
|     /** | ||||
|      * @var bool | ||||
|      */ | ||||
|     private $_preventDefault = false; | ||||
|  | ||||
|     /** | ||||
|      * @return \Doctrine\DBAL\Event\SchemaEventArgs | ||||
|      */ | ||||
|     public function preventDefault() | ||||
|     { | ||||
|         $this->_preventDefault = true; | ||||
|  | ||||
|         return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @return bool | ||||
|      */ | ||||
|     public function isDefaultPrevented() | ||||
|     { | ||||
|         return $this->_preventDefault; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										121
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Event/SchemaIndexDefinitionEventArgs.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										121
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Event/SchemaIndexDefinitionEventArgs.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,121 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Event; | ||||
|  | ||||
| use Doctrine\DBAL\Connection; | ||||
| use Doctrine\DBAL\Schema\Index; | ||||
|  | ||||
| /** | ||||
|  * Event Arguments used when the portable index definition is generated inside Doctrine\DBAL\Schema\AbstractSchemaManager. | ||||
|  * | ||||
|  * @link   www.doctrine-project.org | ||||
|  * @since  2.2 | ||||
|  * @author Jan Sorgalla <jsorgalla@googlemail.com> | ||||
|  */ | ||||
| class SchemaIndexDefinitionEventArgs extends SchemaEventArgs | ||||
| { | ||||
|     /** | ||||
|      * @var \Doctrine\DBAL\Schema\Index|null | ||||
|      */ | ||||
|     private $_index = null; | ||||
|  | ||||
|     /** | ||||
|      * Raw index data as fetched from the database. | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     private $_tableIndex; | ||||
|  | ||||
|     /** | ||||
|      * @var string | ||||
|      */ | ||||
|     private $_table; | ||||
|  | ||||
|     /** | ||||
|      * @var \Doctrine\DBAL\Connection | ||||
|      */ | ||||
|     private $_connection; | ||||
|  | ||||
|     /** | ||||
|      * @param array                     $tableIndex | ||||
|      * @param string                    $table | ||||
|      * @param \Doctrine\DBAL\Connection $connection | ||||
|      */ | ||||
|     public function __construct(array $tableIndex, $table, Connection $connection) | ||||
|     { | ||||
|         $this->_tableIndex = $tableIndex; | ||||
|         $this->_table      = $table; | ||||
|         $this->_connection = $connection; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Allows to clear the index which means the index will be excluded from tables index list. | ||||
|      * | ||||
|      * @param null|\Doctrine\DBAL\Schema\Index $index | ||||
|      * | ||||
|      * @return SchemaIndexDefinitionEventArgs | ||||
|      */ | ||||
|     public function setIndex(Index $index = null) | ||||
|     { | ||||
|         $this->_index = $index; | ||||
|  | ||||
|         return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @return \Doctrine\DBAL\Schema\Index|null | ||||
|      */ | ||||
|     public function getIndex() | ||||
|     { | ||||
|         return $this->_index; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @return array | ||||
|      */ | ||||
|     public function getTableIndex() | ||||
|     { | ||||
|         return $this->_tableIndex; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @return string | ||||
|      */ | ||||
|     public function getTable() | ||||
|     { | ||||
|         return $this->_table; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @return \Doctrine\DBAL\Connection | ||||
|      */ | ||||
|     public function getConnection() | ||||
|     { | ||||
|         return $this->_connection; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @return \Doctrine\DBAL\Platforms\AbstractPlatform | ||||
|      */ | ||||
|     public function getDatabasePlatform() | ||||
|     { | ||||
|         return $this->_connection->getDatabasePlatform(); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										51
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Events.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										51
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Events.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,51 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL; | ||||
|  | ||||
| /** | ||||
|  * Container for all DBAL events. | ||||
|  * | ||||
|  * This class cannot be instantiated. | ||||
|  * | ||||
|  * @author Roman Borschel <roman@code-factory.org> | ||||
|  * @since 2.0 | ||||
|  */ | ||||
| final class Events | ||||
| { | ||||
|     /** | ||||
|      * Private constructor. This class cannot be instantiated. | ||||
|      */ | ||||
|     private function __construct() | ||||
|     { | ||||
|     } | ||||
|  | ||||
|     const postConnect = 'postConnect'; | ||||
|  | ||||
|     const onSchemaCreateTable             = 'onSchemaCreateTable'; | ||||
|     const onSchemaCreateTableColumn       = 'onSchemaCreateTableColumn'; | ||||
|     const onSchemaDropTable               = 'onSchemaDropTable'; | ||||
|     const onSchemaAlterTable              = 'onSchemaAlterTable'; | ||||
|     const onSchemaAlterTableAddColumn     = 'onSchemaAlterTableAddColumn'; | ||||
|     const onSchemaAlterTableRemoveColumn  = 'onSchemaAlterTableRemoveColumn'; | ||||
|     const onSchemaAlterTableChangeColumn  = 'onSchemaAlterTableChangeColumn'; | ||||
|     const onSchemaAlterTableRenameColumn  = 'onSchemaAlterTableRenameColumn'; | ||||
|     const onSchemaColumnDefinition        = 'onSchemaColumnDefinition'; | ||||
|     const onSchemaIndexDefinition         = 'onSchemaIndexDefinition'; | ||||
| } | ||||
							
								
								
									
										31
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Exception/ConnectionException.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										31
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Exception/ConnectionException.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,31 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Exception; | ||||
|  | ||||
| /** | ||||
|  * Base class for all connection related errors detected in the driver. | ||||
|  * | ||||
|  * @author Steve Müller <st.mueller@dzh-online.de> | ||||
|  * @link   www.doctrine-project.org | ||||
|  * @since  2.5 | ||||
|  */ | ||||
| class ConnectionException extends DriverException | ||||
| { | ||||
| } | ||||
							
								
								
									
										31
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Exception/ConstraintViolationException.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										31
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Exception/ConstraintViolationException.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,31 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Exception; | ||||
|  | ||||
| /** | ||||
|  * Base class for all constraint violation related errors detected in the driver. | ||||
|  * | ||||
|  * @author Steve Müller <st.mueller@dzh-online.de> | ||||
|  * @link   www.doctrine-project.org | ||||
|  * @since  2.5 | ||||
|  */ | ||||
| class ConstraintViolationException extends ServerException | ||||
| { | ||||
| } | ||||
							
								
								
									
										35
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Exception/DatabaseObjectExistsException.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										35
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Exception/DatabaseObjectExistsException.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,35 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Exception; | ||||
|  | ||||
| /** | ||||
|  * Base class for all already existing database object related errors detected in the driver. | ||||
|  * | ||||
|  * A database object is considered any asset that can be created in a database | ||||
|  * such as schemas, tables, views, sequences, triggers,  constraints, indexes, | ||||
|  * functions, stored procedures etc. | ||||
|  * | ||||
|  * @author Steve Müller <st.mueller@dzh-online.de> | ||||
|  * @link   www.doctrine-project.org | ||||
|  * @since  2.5 | ||||
|  */ | ||||
| class DatabaseObjectExistsException extends ServerException | ||||
| { | ||||
| } | ||||
							
								
								
									
										35
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Exception/DatabaseObjectNotFoundException.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										35
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Exception/DatabaseObjectNotFoundException.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,35 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Exception; | ||||
|  | ||||
| /** | ||||
|  * Base class for all unknown database object related errors detected in the driver. | ||||
|  * | ||||
|  * A database object is considered any asset that can be created in a database | ||||
|  * such as schemas, tables, views, sequences, triggers,  constraints, indexes, | ||||
|  * functions, stored procedures etc. | ||||
|  * | ||||
|  * @author Steve Müller <st.mueller@dzh-online.de> | ||||
|  * @link   www.doctrine-project.org | ||||
|  * @since  2.5 | ||||
|  */ | ||||
| class DatabaseObjectNotFoundException extends ServerException | ||||
| { | ||||
| } | ||||
							
								
								
									
										31
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Exception/DeadlockException.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										31
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Exception/DeadlockException.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,31 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Exception; | ||||
|  | ||||
| /** | ||||
|  * Exception for a deadlock error of a transaction detected in the driver. | ||||
|  * | ||||
|  * @author Tobias Schultze <http://tobion.de> | ||||
|  * @link   www.doctrine-project.org | ||||
|  * @since  2.6 | ||||
|  */ | ||||
| class DeadlockException extends ServerException implements RetryableException | ||||
| { | ||||
| } | ||||
							
								
								
									
										82
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Exception/DriverException.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										82
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Exception/DriverException.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,82 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Exception; | ||||
|  | ||||
| use Doctrine\DBAL\DBALException; | ||||
|  | ||||
| /** | ||||
|  * Base class for all errors detected in the driver. | ||||
|  * | ||||
|  * @author Steve Müller <st.mueller@dzh-online.de> | ||||
|  * @link   www.doctrine-project.org | ||||
|  * @since  2.5 | ||||
|  */ | ||||
| class DriverException extends DBALException | ||||
| { | ||||
|     /** | ||||
|      * The previous DBAL driver exception. | ||||
|      * | ||||
|      * @var \Doctrine\DBAL\Driver\DriverException | ||||
|      */ | ||||
|     private $driverException; | ||||
|  | ||||
|     /** | ||||
|      * Constructor. | ||||
|      * | ||||
|      * @param string                                $message         The exception message. | ||||
|      * @param \Doctrine\DBAL\Driver\DriverException $driverException The DBAL driver exception to chain. | ||||
|      */ | ||||
|     public function __construct($message, \Doctrine\DBAL\Driver\DriverException $driverException) | ||||
|     { | ||||
|         $exception = null; | ||||
|  | ||||
|         if ($driverException instanceof \Exception) { | ||||
|             $exception = $driverException; | ||||
|         } | ||||
|  | ||||
|         parent::__construct($message, 0, $exception); | ||||
|  | ||||
|         $this->driverException = $driverException; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Returns the driver specific error code if given. | ||||
|      * | ||||
|      * Returns null if no error code was given by the driver. | ||||
|      * | ||||
|      * @return int|string|null | ||||
|      */ | ||||
|     public function getErrorCode() | ||||
|     { | ||||
|         return $this->driverException->getErrorCode(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Returns the SQLSTATE the driver was in at the time the error occurred, if given. | ||||
|      * | ||||
|      * Returns null if no SQLSTATE was given by the driver. | ||||
|      * | ||||
|      * @return string|null | ||||
|      */ | ||||
|     public function getSQLState() | ||||
|     { | ||||
|         return $this->driverException->getSQLState(); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										32
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Exception/ForeignKeyConstraintViolationException.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										32
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Exception/ForeignKeyConstraintViolationException.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,32 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Exception; | ||||
|  | ||||
| /** | ||||
|  * Exception for a foreign key constraint violation detected in the driver. | ||||
|  * | ||||
|  * @author Benjamin Eberlei <kontakt@beberlei.de> | ||||
|  * @author Steve Müller <st.mueller@dzh-online.de> | ||||
|  * @link   www.doctrine-project.org | ||||
|  * @since  2.5 | ||||
|  */ | ||||
| class ForeignKeyConstraintViolationException extends ConstraintViolationException | ||||
| { | ||||
| } | ||||
							
								
								
									
										40
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Exception/InvalidArgumentException.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										40
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Exception/InvalidArgumentException.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,40 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Exception; | ||||
|  | ||||
| use Doctrine\DBAL\DBALException; | ||||
|  | ||||
| /** | ||||
|  * Exception to be thrown when invalid arguments are passed to any DBAL API | ||||
|  * | ||||
|  * @author Marco Pivetta <ocramius@gmail.com> | ||||
|  * @link   www.doctrine-project.org | ||||
|  * @since  2.5 | ||||
|  */ | ||||
| class InvalidArgumentException extends DBALException | ||||
| { | ||||
|     /** | ||||
|      * @return self | ||||
|      */ | ||||
|     public static function fromEmptyCriteria() | ||||
|     { | ||||
|         return new self('Empty criteria was used, expected non-empty criteria'); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										31
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Exception/InvalidFieldNameException.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										31
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Exception/InvalidFieldNameException.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,31 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Exception; | ||||
|  | ||||
| /** | ||||
|  * Exception for an invalid specified field name in a statement detected in the driver. | ||||
|  * | ||||
|  * @author Steve Müller <st.mueller@dzh-online.de> | ||||
|  * @link   www.doctrine-project.org | ||||
|  * @since  2.5 | ||||
|  */ | ||||
| class InvalidFieldNameException extends ServerException | ||||
| { | ||||
| } | ||||
							
								
								
									
										31
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Exception/LockWaitTimeoutException.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										31
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Exception/LockWaitTimeoutException.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,31 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Exception; | ||||
|  | ||||
| /** | ||||
|  * Exception for a lock wait timeout error of a transaction detected in the driver. | ||||
|  * | ||||
|  * @author Tobias Schultze <http://tobion.de> | ||||
|  * @link   www.doctrine-project.org | ||||
|  * @since  2.6 | ||||
|  */ | ||||
| class LockWaitTimeoutException extends ServerException implements RetryableException | ||||
| { | ||||
| } | ||||
							
								
								
									
										31
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Exception/NonUniqueFieldNameException.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										31
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Exception/NonUniqueFieldNameException.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,31 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Exception; | ||||
|  | ||||
| /** | ||||
|  * Exception for a non-unique/ambiguous specified field name in a statement detected in the driver. | ||||
|  * | ||||
|  * @author Steve Müller <st.mueller@dzh-online.de> | ||||
|  * @link   www.doctrine-project.org | ||||
|  * @since  2.5 | ||||
|  */ | ||||
| class NonUniqueFieldNameException extends ServerException | ||||
| { | ||||
| } | ||||
							
								
								
									
										32
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Exception/NotNullConstraintViolationException.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										32
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Exception/NotNullConstraintViolationException.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,32 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Exception; | ||||
|  | ||||
| /** | ||||
|  * Exception for a NOT NULL constraint violation detected in the driver. | ||||
|  * | ||||
|  * @author Benjamin Eberlei <kontakt@beberlei.de> | ||||
|  * @author Steve Müller <st.mueller@dzh-online.de> | ||||
|  * @link   www.doctrine-project.org | ||||
|  * @since  2.5 | ||||
|  */ | ||||
| class NotNullConstraintViolationException extends ConstraintViolationException | ||||
| { | ||||
| } | ||||
							
								
								
									
										31
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Exception/ReadOnlyException.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										31
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Exception/ReadOnlyException.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,31 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Exception; | ||||
|  | ||||
| /** | ||||
|  * Exception for a write operation attempt on a read-only database element detected in the driver. | ||||
|  * | ||||
|  * @author Steve Müller <st.mueller@dzh-online.de> | ||||
|  * @link   www.doctrine-project.org | ||||
|  * @since  2.5 | ||||
|  */ | ||||
| class ReadOnlyException extends ServerException | ||||
| { | ||||
| } | ||||
							
								
								
									
										31
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Exception/RetryableException.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										31
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Exception/RetryableException.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,31 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Exception; | ||||
|  | ||||
| /** | ||||
|  * Marker interface for all exceptions where retrying the transaction makes sense. | ||||
|  * | ||||
|  * @author Tobias Schultze <http://tobion.de> | ||||
|  * @link   www.doctrine-project.org | ||||
|  * @since  2.6 | ||||
|  */ | ||||
| interface RetryableException | ||||
| { | ||||
| } | ||||
							
								
								
									
										31
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Exception/ServerException.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										31
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Exception/ServerException.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,31 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Exception; | ||||
|  | ||||
| /** | ||||
|  * Base class for all server related errors detected in the driver. | ||||
|  * | ||||
|  * @author Steve Müller <st.mueller@dzh-online.de> | ||||
|  * @link   www.doctrine-project.org | ||||
|  * @since  2.5 | ||||
|  */ | ||||
| class ServerException extends DriverException | ||||
| { | ||||
| } | ||||
							
								
								
									
										31
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Exception/SyntaxErrorException.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										31
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Exception/SyntaxErrorException.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,31 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Exception; | ||||
|  | ||||
| /** | ||||
|  * Exception for a syntax error in a statement detected in the driver. | ||||
|  * | ||||
|  * @author Steve Müller <st.mueller@dzh-online.de> | ||||
|  * @link   www.doctrine-project.org | ||||
|  * @since  2.5 | ||||
|  */ | ||||
| class SyntaxErrorException extends ServerException | ||||
| { | ||||
| } | ||||
							
								
								
									
										31
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Exception/TableExistsException.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										31
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Exception/TableExistsException.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,31 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Exception; | ||||
|  | ||||
| /** | ||||
|  * Exception for an already existing table referenced in a statement detected in the driver. | ||||
|  * | ||||
|  * @author Steve Müller <st.mueller@dzh-online.de> | ||||
|  * @link   www.doctrine-project.org | ||||
|  * @since  2.5 | ||||
|  */ | ||||
| class TableExistsException extends DatabaseObjectExistsException | ||||
| { | ||||
| } | ||||
							
								
								
									
										31
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Exception/TableNotFoundException.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										31
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Exception/TableNotFoundException.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,31 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Exception; | ||||
|  | ||||
| /** | ||||
|  * Exception for an unknown table referenced in a statement detected in the driver. | ||||
|  * | ||||
|  * @author Steve Müller <st.mueller@dzh-online.de> | ||||
|  * @link   www.doctrine-project.org | ||||
|  * @since  2.5 | ||||
|  */ | ||||
| class TableNotFoundException extends DatabaseObjectNotFoundException | ||||
| { | ||||
| } | ||||
							
								
								
									
										32
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Exception/UniqueConstraintViolationException.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										32
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Exception/UniqueConstraintViolationException.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,32 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Exception; | ||||
|  | ||||
| /** | ||||
|  * Exception for a unique constraint violation detected in the driver. | ||||
|  * | ||||
|  * @author Benjamin Eberlei <kontakt@beberlei.de> | ||||
|  * @author Steve Müller <st.mueller@dzh-online.de> | ||||
|  * @link   www.doctrine-project.org | ||||
|  * @since  2.5 | ||||
|  */ | ||||
| class UniqueConstraintViolationException extends ConstraintViolationException | ||||
| { | ||||
| } | ||||
							
								
								
									
										69
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/FetchMode.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										69
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/FetchMode.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,69 @@ | ||||
| <?php | ||||
|  | ||||
| namespace Doctrine\DBAL; | ||||
|  | ||||
| /** | ||||
|  * Contains statement fetch modes. | ||||
|  */ | ||||
| final class FetchMode | ||||
| { | ||||
|     /** | ||||
|      * Specifies that the fetch method shall return each row as an array indexed | ||||
|      * by column name as returned in the corresponding result set. If the result | ||||
|      * set contains multiple columns with the same name, the statement returns | ||||
|      * only a single value per column name. | ||||
|      * | ||||
|      * @see \PDO::FETCH_ASSOC | ||||
|      */ | ||||
|     public const ASSOCIATIVE = \PDO::FETCH_ASSOC; | ||||
|  | ||||
|     /** | ||||
|      * Specifies that the fetch method shall return each row as an array indexed | ||||
|      * by column number as returned in the corresponding result set, starting at | ||||
|      * column 0. | ||||
|      * | ||||
|      * @see \PDO::FETCH_NUM | ||||
|      */ | ||||
|     public const NUMERIC = \PDO::FETCH_NUM; | ||||
|  | ||||
|     /** | ||||
|      * Specifies that the fetch method shall return each row as an array indexed | ||||
|      * by both column name and number as returned in the corresponding result set, | ||||
|      * starting at column 0. | ||||
|      * | ||||
|      * @see \PDO::FETCH_BOTH | ||||
|      */ | ||||
|     public const MIXED = \PDO::FETCH_BOTH; | ||||
|  | ||||
|     /** | ||||
|      * Specifies that the fetch method shall return each row as an object with | ||||
|      * property names that correspond to the column names returned in the result | ||||
|      * set. | ||||
|      * | ||||
|      * @see \PDO::FETCH_OBJ | ||||
|      */ | ||||
|     public const STANDARD_OBJECT = \PDO::FETCH_OBJ; | ||||
|  | ||||
|     /** | ||||
|      * Specifies that the fetch method shall return only a single requested | ||||
|      * column from the next row in the result set. | ||||
|      * | ||||
|      * @see \PDO::FETCH_COLUMN | ||||
|      */ | ||||
|     public const COLUMN = \PDO::FETCH_COLUMN; | ||||
|  | ||||
|     /** | ||||
|      * Specifies that the fetch method shall return a new instance of the | ||||
|      * requested class, mapping the columns to named properties in the class. | ||||
|      * | ||||
|      * @see \PDO::FETCH_CLASS | ||||
|      */ | ||||
|     public const CUSTOM_OBJECT = \PDO::FETCH_CLASS; | ||||
|  | ||||
|     /** | ||||
|      * This class cannot be instantiated. | ||||
|      */ | ||||
|     private function __construct() | ||||
|     { | ||||
|     } | ||||
| } | ||||
							
								
								
									
										170
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Id/TableGenerator.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										170
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Id/TableGenerator.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,170 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Id; | ||||
|  | ||||
| use Doctrine\DBAL\DriverManager; | ||||
| use Doctrine\DBAL\Connection; | ||||
| use Doctrine\DBAL\FetchMode; | ||||
| use Doctrine\DBAL\LockMode; | ||||
| use const CASE_LOWER; | ||||
| use function array_change_key_case; | ||||
|  | ||||
| /** | ||||
|  * Table ID Generator for those poor languages that are missing sequences. | ||||
|  * | ||||
|  * WARNING: The Table Id Generator clones a second independent database | ||||
|  * connection to work correctly. This means using the generator requests that | ||||
|  * generate IDs will have two open database connections. This is necessary to | ||||
|  * be safe from transaction failures in the main connection. Make sure to only | ||||
|  * ever use one TableGenerator otherwise you end up with many connections. | ||||
|  * | ||||
|  * TableID Generator does not work with SQLite. | ||||
|  * | ||||
|  * The TableGenerator does not take care of creating the SQL Table itself. You | ||||
|  * should look at the `TableGeneratorSchemaVisitor` to do this for you. | ||||
|  * Otherwise the schema for a table looks like: | ||||
|  * | ||||
|  * CREATE sequences ( | ||||
|  *   sequence_name VARCHAR(255) NOT NULL, | ||||
|  *   sequence_value INT NOT NULL DEFAULT 1, | ||||
|  *   sequence_increment_by INT NOT NULL DEFAULT 1, | ||||
|  *   PRIMARY KEY (sequence_name) | ||||
|  * ); | ||||
|  * | ||||
|  * Technically this generator works as follows: | ||||
|  * | ||||
|  * 1. Use a robust transaction serialization level. | ||||
|  * 2. Open transaction | ||||
|  * 3. Acquire a read lock on the table row (SELECT .. FOR UPDATE) | ||||
|  * 4. Increment current value by one and write back to database | ||||
|  * 5. Commit transaction | ||||
|  * | ||||
|  * If you are using a sequence_increment_by value that is larger than one the | ||||
|  * ID Generator will keep incrementing values until it hits the incrementation | ||||
|  * gap before issuing another query. | ||||
|  * | ||||
|  * If no row is present for a given sequence a new one will be created with the | ||||
|  * default values 'value' = 1 and 'increment_by' = 1 | ||||
|  * | ||||
|  * @author Benjamin Eberlei <kontakt@beberlei.de> | ||||
|  */ | ||||
| class TableGenerator | ||||
| { | ||||
|     /** | ||||
|      * @var \Doctrine\DBAL\Connection | ||||
|      */ | ||||
|     private $conn; | ||||
|  | ||||
|     /** | ||||
|      * @var string | ||||
|      */ | ||||
|     private $generatorTableName; | ||||
|  | ||||
|     /** | ||||
|      * @var array | ||||
|      */ | ||||
|     private $sequences = []; | ||||
|  | ||||
|     /** | ||||
|      * @param \Doctrine\DBAL\Connection $conn | ||||
|      * @param string                    $generatorTableName | ||||
|      * | ||||
|      * @throws \Doctrine\DBAL\DBALException | ||||
|      */ | ||||
|     public function __construct(Connection $conn, $generatorTableName = 'sequences') | ||||
|     { | ||||
|         $params = $conn->getParams(); | ||||
|         if ($params['driver'] == 'pdo_sqlite') { | ||||
|             throw new \Doctrine\DBAL\DBALException("Cannot use TableGenerator with SQLite."); | ||||
|         } | ||||
|         $this->conn = DriverManager::getConnection($params, $conn->getConfiguration(), $conn->getEventManager()); | ||||
|         $this->generatorTableName = $generatorTableName; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Generates the next unused value for the given sequence name. | ||||
|      * | ||||
|      * @param string $sequenceName | ||||
|      * | ||||
|      * @return int | ||||
|      * | ||||
|      * @throws \Doctrine\DBAL\DBALException | ||||
|      */ | ||||
|     public function nextValue($sequenceName) | ||||
|     { | ||||
|         if (isset($this->sequences[$sequenceName])) { | ||||
|             $value = $this->sequences[$sequenceName]['value']; | ||||
|             $this->sequences[$sequenceName]['value']++; | ||||
|             if ($this->sequences[$sequenceName]['value'] >= $this->sequences[$sequenceName]['max']) { | ||||
|                 unset ($this->sequences[$sequenceName]); | ||||
|             } | ||||
|  | ||||
|             return $value; | ||||
|         } | ||||
|  | ||||
|         $this->conn->beginTransaction(); | ||||
|  | ||||
|         try { | ||||
|             $platform = $this->conn->getDatabasePlatform(); | ||||
|             $sql      = 'SELECT sequence_value, sequence_increment_by' | ||||
|                 . ' FROM ' . $platform->appendLockHint($this->generatorTableName, LockMode::PESSIMISTIC_WRITE) | ||||
|                 . ' WHERE sequence_name = ? ' . $platform->getWriteLockSQL(); | ||||
|             $stmt     = $this->conn->executeQuery($sql, [$sequenceName]); | ||||
|             $row      = $stmt->fetch(FetchMode::ASSOCIATIVE); | ||||
|  | ||||
|             if ($row !== false) { | ||||
|                 $row = array_change_key_case($row, CASE_LOWER); | ||||
|  | ||||
|                 $value = $row['sequence_value']; | ||||
|                 $value++; | ||||
|  | ||||
|                 if ($row['sequence_increment_by'] > 1) { | ||||
|                     $this->sequences[$sequenceName] = [ | ||||
|                         'value' => $value, | ||||
|                         'max' => $row['sequence_value'] + $row['sequence_increment_by'] | ||||
|                     ]; | ||||
|                 } | ||||
|  | ||||
|                 $sql = "UPDATE " . $this->generatorTableName . " ". | ||||
|                        "SET sequence_value = sequence_value + sequence_increment_by " . | ||||
|                        "WHERE sequence_name = ? AND sequence_value = ?"; | ||||
|                 $rows = $this->conn->executeUpdate($sql, [$sequenceName, $row['sequence_value']]); | ||||
|  | ||||
|                 if ($rows != 1) { | ||||
|                     throw new \Doctrine\DBAL\DBALException("Race-condition detected while updating sequence. Aborting generation"); | ||||
|                 } | ||||
|             } else { | ||||
|                 $this->conn->insert( | ||||
|                     $this->generatorTableName, | ||||
|                     ['sequence_name' => $sequenceName, 'sequence_value' => 1, 'sequence_increment_by' => 1] | ||||
|                 ); | ||||
|                 $value = 1; | ||||
|             } | ||||
|  | ||||
|             $this->conn->commit(); | ||||
|  | ||||
|         } catch (\Exception $e) { | ||||
|             $this->conn->rollBack(); | ||||
|             throw new \Doctrine\DBAL\DBALException("Error occurred while generating ID with TableGenerator, aborted generation: " . $e->getMessage(), 0, $e); | ||||
|         } | ||||
|  | ||||
|         return $value; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										89
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Id/TableGeneratorSchemaVisitor.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										89
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Id/TableGeneratorSchemaVisitor.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,89 @@ | ||||
| <?php | ||||
| /* | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||
|  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||
|  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||
|  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||
|  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||
|  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||
|  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||
|  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||
|  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||
|  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  * | ||||
|  * This software consists of voluntary contributions made by many individuals | ||||
|  * and is licensed under the MIT license. For more information, see | ||||
|  * <http://www.doctrine-project.org>. | ||||
|  */ | ||||
|  | ||||
| namespace Doctrine\DBAL\Id; | ||||
|  | ||||
| use Doctrine\DBAL\Schema\Table; | ||||
| use Doctrine\DBAL\Schema\Schema; | ||||
| use Doctrine\DBAL\Schema\Column; | ||||
| use Doctrine\DBAL\Schema\ForeignKeyConstraint; | ||||
| use Doctrine\DBAL\Schema\Sequence; | ||||
| use Doctrine\DBAL\Schema\Index; | ||||
|  | ||||
| class TableGeneratorSchemaVisitor implements \Doctrine\DBAL\Schema\Visitor\Visitor | ||||
| { | ||||
|     /** | ||||
|      * @var string | ||||
|      */ | ||||
|     private $generatorTableName; | ||||
|  | ||||
|     /** | ||||
|      * @param string $generatorTableName | ||||
|      */ | ||||
|     public function __construct($generatorTableName = 'sequences') | ||||
|     { | ||||
|         $this->generatorTableName = $generatorTableName; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function acceptSchema(Schema $schema) | ||||
|     { | ||||
|         $table = $schema->createTable($this->generatorTableName); | ||||
|         $table->addColumn('sequence_name', 'string'); | ||||
|         $table->addColumn('sequence_value', 'integer', ['default' => 1]); | ||||
|         $table->addColumn('sequence_increment_by', 'integer', ['default' => 1]); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function acceptTable(Table $table) | ||||
|     { | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function acceptColumn(Table $table, Column $column) | ||||
|     { | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function acceptForeignKey(Table $localTable, ForeignKeyConstraint $fkConstraint) | ||||
|     { | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function acceptIndex(Table $table, Index $index) | ||||
|     { | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function acceptSequence(Sequence $sequence) | ||||
|     { | ||||
|     } | ||||
| } | ||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user
	 Manish Verma
					Manish Verma