the whole shebang
This commit is contained in:
		
							
								
								
									
										154
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/IBMDB2/DB2Connection.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										154
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/IBMDB2/DB2Connection.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,154 @@ | ||||
| <?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 DB2Connection implements \Doctrine\DBAL\Driver\Connection | ||||
| { | ||||
|     /** | ||||
|      * @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 = array()) | ||||
|     { | ||||
|         $isPersistant = (isset($params['persistent']) && $params['persistent'] == true); | ||||
|  | ||||
|         if ($isPersistant) { | ||||
|             $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 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=\PDO::PARAM_STR) | ||||
|     { | ||||
|         $input = db2_escape_string($input); | ||||
|         if ($type == \PDO::PARAM_INT ) { | ||||
|             return $input; | ||||
|         } else { | ||||
|             return "'".$input."'"; | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function exec($statement) | ||||
|     { | ||||
|         $stmt = $this->prepare($statement); | ||||
|         $stmt->execute(); | ||||
|         return $stmt->rowCount(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@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 array( | ||||
|             0 => db2_conn_errormsg($this->_conn), | ||||
|             1 => $this->errorCode(), | ||||
|         ); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										94
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/IBMDB2/DB2Driver.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										94
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/IBMDB2/DB2Driver.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\Driver\IBMDB2; | ||||
|  | ||||
| use Doctrine\DBAL\Driver; | ||||
| use Doctrine\DBAL\Connection; | ||||
|  | ||||
| /** | ||||
|  * IBM DB2 Driver. | ||||
|  * | ||||
|  * @since 2.0 | ||||
|  * @author Benjamin Eberlei <kontakt@beberlei.de> | ||||
|  */ | ||||
| class DB2Driver implements Driver | ||||
| { | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function connect(array $params, $username = null, $password = null, array $driverOptions = array()) | ||||
|     { | ||||
|         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 getDatabasePlatform() | ||||
|     { | ||||
|         return new \Doctrine\DBAL\Platforms\DB2Platform; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function getSchemaManager(Connection $conn) | ||||
|     { | ||||
|         return new \Doctrine\DBAL\Schema\DB2SchemaManager($conn); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function getName() | ||||
|     { | ||||
|         return 'ibm_db2'; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function getDatabase(\Doctrine\DBAL\Connection $conn) | ||||
|     { | ||||
|         $params = $conn->getParams(); | ||||
|  | ||||
|         return $params['dbname']; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										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 | ||||
| { | ||||
| } | ||||
							
								
								
									
										234
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/IBMDB2/DB2Statement.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										234
									
								
								vendor/doctrine/dbal/lib/Doctrine/DBAL/Driver/IBMDB2/DB2Statement.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\IBMDB2; | ||||
|  | ||||
| use \Doctrine\DBAL\Driver\Statement; | ||||
|  | ||||
| class DB2Statement implements \IteratorAggregate, Statement | ||||
| { | ||||
|     /** | ||||
|      * @var resource | ||||
|      */ | ||||
|     private $_stmt = null; | ||||
|  | ||||
|     /** | ||||
|      * @var array | ||||
|      */ | ||||
|     private $_bindParam = array(); | ||||
|  | ||||
|     /** | ||||
|      * @var integer | ||||
|      */ | ||||
|     private $_defaultFetchMode = \PDO::FETCH_BOTH; | ||||
|  | ||||
|     /** | ||||
|      * DB2_BINARY, DB2_CHAR, DB2_DOUBLE, or DB2_LONG | ||||
|      * | ||||
|      * @var array | ||||
|      */ | ||||
|     static private $_typeMap = array( | ||||
|         \PDO::PARAM_INT => DB2_LONG, | ||||
|         \PDO::PARAM_STR => DB2_CHAR, | ||||
|     ); | ||||
|  | ||||
|     /** | ||||
|      * @param resource $stmt | ||||
|      */ | ||||
|     public function __construct($stmt) | ||||
|     { | ||||
|         $this->_stmt = $stmt; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function bindValue($param, $value, $type = null) | ||||
|     { | ||||
|         return $this->bindParam($param, $value, $type); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function bindParam($column, &$variable, $type = null, $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 = array(); | ||||
|         db2_free_result($this->_stmt); | ||||
|         $ret = db2_free_stmt($this->_stmt); | ||||
|         $this->_stmt = false; | ||||
|  | ||||
|         return $ret; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@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 array( | ||||
|             0 => db2_stmt_errormsg(), | ||||
|             1 => db2_stmt_error(), | ||||
|         ); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function execute($params = null) | ||||
|     { | ||||
|         if ( ! $this->_stmt) { | ||||
|             return false; | ||||
|         } | ||||
|  | ||||
|         /*$retval = true; | ||||
|         if ($params !== null) { | ||||
|             $retval = @db2_execute($this->_stmt, $params); | ||||
|         } else { | ||||
|             $retval = @db2_execute($this->_stmt); | ||||
|         }*/ | ||||
|         if ($params === null) { | ||||
|             ksort($this->_bindParam); | ||||
|             $params = array_values($this->_bindParam); | ||||
|         } | ||||
|         $retval = @db2_execute($this->_stmt, $params); | ||||
|  | ||||
|         if ($retval === false) { | ||||
|             throw new DB2Exception(db2_stmt_errormsg()); | ||||
|         } | ||||
|  | ||||
|         return $retval; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@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) | ||||
|     { | ||||
|         $fetchMode = $fetchMode ?: $this->_defaultFetchMode; | ||||
|         switch ($fetchMode) { | ||||
|             case \PDO::FETCH_BOTH: | ||||
|                 return db2_fetch_both($this->_stmt); | ||||
|             case \PDO::FETCH_ASSOC: | ||||
|                 return db2_fetch_assoc($this->_stmt); | ||||
|             case \PDO::FETCH_NUM: | ||||
|                 return db2_fetch_array($this->_stmt); | ||||
|             default: | ||||
|                 throw new DB2Exception("Given Fetch-Style " . $fetchMode . " is not supported."); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function fetchAll($fetchMode = null) | ||||
|     { | ||||
|         $rows = array(); | ||||
|         while ($row = $this->fetch($fetchMode)) { | ||||
|             $rows[] = $row; | ||||
|         } | ||||
|  | ||||
|         return $rows; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function fetchColumn($columnIndex = 0) | ||||
|     { | ||||
|         $row = $this->fetch(\PDO::FETCH_NUM); | ||||
|         if ($row && isset($row[$columnIndex])) { | ||||
|             return $row[$columnIndex]; | ||||
|         } | ||||
|  | ||||
|         return false; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function rowCount() | ||||
|     { | ||||
|         return (@db2_num_rows($this->_stmt))?:0; | ||||
|     } | ||||
| } | ||||
		Reference in New Issue
	
	Block a user