First commit
This commit is contained in:
		
						commit
						c6e2478c40
					
				
					 13918 changed files with 2303184 additions and 0 deletions
				
			
		
							
								
								
									
										440
									
								
								sites/all/modules/civicrm/packages/DB/Table/Manager/mysqli.php
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										440
									
								
								sites/all/modules/civicrm/packages/DB/Table/Manager/mysqli.php
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,440 @@ | |||
| <?php | ||||
| 
 | ||||
| /* vim: set expandtab tabstop=4 shiftwidth=4 softtabstop=4: */ | ||||
| 
 | ||||
| /** | ||||
|  * Index, constraint and alter methods for DB_Table usage with | ||||
|  * PEAR::DB as backend. | ||||
|  *  | ||||
|  * The code in this class was adopted from the MDB2 PEAR package. | ||||
|  *  | ||||
|  * PHP versions 4 and 5 | ||||
|  * | ||||
|  * LICENSE: | ||||
|  *  | ||||
|  * Copyright (c) 1997-2007, Lukas Smith <smith@pooteeweet.org> | ||||
|  *                          Paul M. Jones <pmjones@php.net> | ||||
|  *                          David C. Morse <morse@php.net> | ||||
|  *                          Mark Wiesemann <wiesemann@php.net> | ||||
|  * All rights reserved. | ||||
|  * | ||||
|  * Redistribution and use in source and binary forms, with or without | ||||
|  * modification, are permitted provided that the following conditions | ||||
|  * are met: | ||||
|  * | ||||
|  *    * Redistributions of source code must retain the above copyright | ||||
|  *      notice, this list of conditions and the following disclaimer. | ||||
|  *    * Redistributions in binary form must reproduce the above copyright | ||||
|  *      notice, this list of conditions and the following disclaimer in the  | ||||
|  *      documentation and/or other materials provided with the distribution. | ||||
|  *    * The names of the authors may not be used to endorse or promote products  | ||||
|  *      derived from this software without specific prior written permission. | ||||
|  * | ||||
|  * 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. | ||||
|  * | ||||
|  * @category Database | ||||
|  * @package  DB_Table | ||||
|  * @author   Lukas Smith <smith@pooteeweet.org> | ||||
|  * @author   Mark Wiesemann <wiesemann@php.net> | ||||
|  * @license  http://opensource.org/licenses/bsd-license.php New BSD License | ||||
|  * @version  CVS: $Id: mysqli.php,v 1.6 2007/12/13 16:52:15 wiesemann Exp $ | ||||
|  * @link     http://pear.php.net/package/DB_Table | ||||
|  */ | ||||
| 
 | ||||
| /** | ||||
|  * require DB_Table class | ||||
|  */ | ||||
| require_once 'DB/Table.php'; | ||||
| 
 | ||||
| /** | ||||
|  * Index, constraint and alter methods for DB_Table usage with | ||||
|  * PEAR::DB as backend. | ||||
|  *  | ||||
|  * The code in this class was adopted from the MDB2 PEAR package. | ||||
|  *  | ||||
|  * @category Database | ||||
|  * @package  DB_Table | ||||
|  * @author   Lukas Smith <smith@pooteeweet.org> | ||||
|  * @author   Mark Wiesemann <wiesemann@php.net> | ||||
|  * @version  Release: 1.5.6 | ||||
|  * @link     http://pear.php.net/package/DB_Table | ||||
|  */ | ||||
| class DB_Table_Manager_mysqli { | ||||
| 
 | ||||
|     /** | ||||
|     *  | ||||
|     * The PEAR DB object that connects to the database. | ||||
|     *  | ||||
|     * @access private | ||||
|     *  | ||||
|     * @var object | ||||
|     *  | ||||
|     */ | ||||
|      | ||||
|     var $_db = null; | ||||
| 
 | ||||
| 
 | ||||
|     /** | ||||
|      * list all indexes in a table | ||||
|      * | ||||
|      * @param string    $table      name of table that should be used in method | ||||
|      * @return mixed data array on success, a PEAR error on failure | ||||
|      * @access public | ||||
|      */ | ||||
|     function listTableIndexes($table) | ||||
|     { | ||||
|         $key_name = 'Key_name'; | ||||
|         $non_unique = 'Non_unique'; | ||||
| 
 | ||||
|         $query = "SHOW INDEX FROM $table"; | ||||
|         $indexes = $this->_db->getAll($query, null, DB_FETCHMODE_ASSOC); | ||||
|         if (PEAR::isError($indexes)) { | ||||
|             return $indexes; | ||||
|         } | ||||
| 
 | ||||
|         $result = array(); | ||||
|         foreach ($indexes as $index_data) { | ||||
|             if ($index_data[$non_unique]) { | ||||
|                 $result[$index_data[$key_name]] = true; | ||||
|             } | ||||
|         } | ||||
|         $result = array_change_key_case($result, CASE_LOWER); | ||||
| 
 | ||||
|         return array_keys($result); | ||||
|     } | ||||
| 
 | ||||
| 
 | ||||
|     /** | ||||
|      * list all constraints in a table | ||||
|      * | ||||
|      * @param string    $table      name of table that should be used in method | ||||
|      * @return mixed data array on success, a PEAR error on failure | ||||
|      * @access public | ||||
|      */ | ||||
|     function listTableConstraints($table) | ||||
|     { | ||||
|         $key_name = 'Key_name'; | ||||
|         $non_unique = 'Non_unique'; | ||||
| 
 | ||||
|         $query = "SHOW INDEX FROM $table"; | ||||
|         $indexes = $this->_db->getAll($query, null, DB_FETCHMODE_ASSOC); | ||||
|         if (PEAR::isError($indexes)) { | ||||
|             return $indexes; | ||||
|         } | ||||
| 
 | ||||
|         $result = array(); | ||||
|         foreach ($indexes as $index_data) { | ||||
|             if (!$index_data[$non_unique]) { | ||||
|                 if ($index_data[$key_name] !== 'PRIMARY') { | ||||
|                     $index = $index_data[$key_name]; | ||||
|                 } else { | ||||
|                     $index = 'PRIMARY'; | ||||
|                 } | ||||
|                 $result[$index] = true; | ||||
|             } | ||||
|         } | ||||
|         $result = array_change_key_case($result, CASE_LOWER); | ||||
| 
 | ||||
|         return array_keys($result); | ||||
|     } | ||||
| 
 | ||||
| 
 | ||||
|     /** | ||||
|      * get the structure of an index into an array | ||||
|      * | ||||
|      * @param string    $table      name of table that should be used in method | ||||
|      * @param string    $index_name name of index that should be used in method | ||||
|      * @return mixed data array on success, a PEAR error on failure | ||||
|      * @access public | ||||
|      */ | ||||
|     function getTableIndexDefinition($table, $index_name) | ||||
|     { | ||||
|         $result = $this->_db->query("SHOW INDEX FROM $table"); | ||||
|         if (PEAR::isError($result)) { | ||||
|             return $result; | ||||
|         } | ||||
| 
 | ||||
|         $definition = array(); | ||||
|         while (is_array($row = $result->fetchRow(DB_FETCHMODE_ASSOC))) { | ||||
|             $row = array_change_key_case($row, CASE_LOWER); | ||||
|             $key_name = $row['key_name']; | ||||
|             $key_name = strtolower($key_name); | ||||
|             if ($index_name == $key_name) { | ||||
|                 $column_name = $row['column_name']; | ||||
|                 $column_name = strtolower($column_name); | ||||
|                 $definition['fields'][$column_name] = array(); | ||||
|                 if (array_key_exists('collation', $row)) { | ||||
|                     $definition['fields'][$column_name]['sorting'] = ($row['collation'] == 'A' | ||||
|                         ? 'ascending' : 'descending'); | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
| 
 | ||||
|         $result->free(); | ||||
| 
 | ||||
|         return $definition; | ||||
|     } | ||||
| 
 | ||||
| 
 | ||||
|     /** | ||||
|      * get the structure of a constraint into an array | ||||
|      * | ||||
|      * @param string    $table      name of table that should be used in method | ||||
|      * @param string    $index_name name of index that should be used in method | ||||
|      * @return mixed data array on success, a PEAR error on failure | ||||
|      * @access public | ||||
|      */ | ||||
|     function getTableConstraintDefinition($table, $index_name) | ||||
|     { | ||||
|         $result = $this->_db->query("SHOW INDEX FROM $table"); | ||||
|         if (PEAR::isError($result)) { | ||||
|             return $result; | ||||
|         } | ||||
| 
 | ||||
|         $definition = array(); | ||||
|         while (is_array($row = $result->fetchRow(DB_FETCHMODE_ASSOC))) { | ||||
|             $row = array_change_key_case($row, CASE_LOWER); | ||||
|             $key_name = $row['key_name']; | ||||
|             $key_name = strtolower($key_name); | ||||
|             if ($index_name == $key_name) { | ||||
|                 if ($row['key_name'] == 'PRIMARY') { | ||||
|                     $definition['primary'] = true; | ||||
|                 } else { | ||||
|                     $definition['unique'] = true; | ||||
|                 } | ||||
|                 $column_name = $row['column_name']; | ||||
|                 $column_name = strtolower($column_name); | ||||
|                 $definition['fields'][$column_name] = array(); | ||||
|                 if (array_key_exists('collation', $row)) { | ||||
|                     $definition['fields'][$column_name]['sorting'] = ($row['collation'] == 'A' | ||||
|                         ? 'ascending' : 'descending'); | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
| 
 | ||||
|         $result->free(); | ||||
| 
 | ||||
|         return $definition; | ||||
|     } | ||||
| 
 | ||||
|      | ||||
|     /** | ||||
|      * drop existing index | ||||
|      * | ||||
|      * @param string    $table         name of table that should be used in method | ||||
|      * @param string    $name         name of the index to be dropped | ||||
|      * @return mixed DB_OK on success, a PEAR error on failure | ||||
|      * @access public | ||||
|      */ | ||||
|     function dropIndex($table, $name) | ||||
|     { | ||||
|         $table = $this->_db->quoteIdentifier($table); | ||||
|         $name = $this->_db->quoteIdentifier($name); | ||||
|         return $this->_db->query("DROP INDEX $name ON $table"); | ||||
|     } | ||||
| 
 | ||||
| 
 | ||||
|     /** | ||||
|      * drop existing constraint | ||||
|      * | ||||
|      * @param string    $table         name of table that should be used in method | ||||
|      * @param string    $name         name of the constraint to be dropped | ||||
|      * @return mixed DB_OK on success, a PEAR error on failure | ||||
|      * @access public | ||||
|      */ | ||||
|     function dropConstraint($table, $name) | ||||
|     { | ||||
|         $table = $this->_db->quoteIdentifier($table); | ||||
|         if (strtolower($name) == 'primary') { | ||||
|             $query = "ALTER TABLE $table DROP PRIMARY KEY"; | ||||
|         } else { | ||||
|             $name = $this->_db->quoteIdentifier($name); | ||||
|             $query = "ALTER TABLE $table DROP INDEX $name"; | ||||
|         } | ||||
|         return $this->_db->query($query); | ||||
|     } | ||||
| 
 | ||||
| 
 | ||||
|     /** | ||||
|      * alter an existing table | ||||
|      * | ||||
|      * @param string $name         name of the table that is intended to be changed. | ||||
|      * @param array $changes     associative array that contains the details of each type | ||||
|      *                             of change that is intended to be performed. The types of | ||||
|      *                             changes that are currently supported are defined as follows: | ||||
|      * | ||||
|      *                             name | ||||
|      * | ||||
|      *                                New name for the table. | ||||
|      * | ||||
|      *                            add | ||||
|      * | ||||
|      *                                Associative array with the names of fields to be added as | ||||
|      *                                 indexes of the array. The value of each entry of the array | ||||
|      *                                 should be set to another associative array with the properties | ||||
|      *                                 of the fields to be added. The properties of the fields should | ||||
|      *                                 be the same as defined by the Metabase parser. | ||||
|      * | ||||
|      * | ||||
|      *                            remove | ||||
|      * | ||||
|      *                                Associative array with the names of fields to be removed as indexes | ||||
|      *                                 of the array. Currently the values assigned to each entry are ignored. | ||||
|      *                                 An empty array should be used for future compatibility. | ||||
|      * | ||||
|      *                            rename | ||||
|      * | ||||
|      *                                Associative array with the names of fields to be renamed as indexes | ||||
|      *                                 of the array. The value of each entry of the array should be set to | ||||
|      *                                 another associative array with the entry named name with the new | ||||
|      *                                 field name and the entry named Declaration that is expected to contain | ||||
|      *                                 the portion of the field declaration already in DBMS specific SQL code | ||||
|      *                                 as it is used in the CREATE TABLE statement. | ||||
|      * | ||||
|      *                            change | ||||
|      * | ||||
|      *                                Associative array with the names of the fields to be changed as indexes | ||||
|      *                                 of the array. Keep in mind that if it is intended to change either the | ||||
|      *                                 name of a field and any other properties, the change array entries | ||||
|      *                                 should have the new names of the fields as array indexes. | ||||
|      * | ||||
|      *                                The value of each entry of the array should be set to another associative | ||||
|      *                                 array with the properties of the fields to that are meant to be changed as | ||||
|      *                                 array entries. These entries should be assigned to the new values of the | ||||
|      *                                 respective properties. The properties of the fields should be the same | ||||
|      *                                 as defined by the Metabase parser. | ||||
|      * | ||||
|      *                            Example | ||||
|      *                                array( | ||||
|      *                                    'name' => 'userlist', | ||||
|      *                                    'add' => array( | ||||
|      *                                        'quota' => array( | ||||
|      *                                            'type' => 'integer', | ||||
|      *                                            'unsigned' => 1 | ||||
|      *                                        ) | ||||
|      *                                    ), | ||||
|      *                                    'remove' => array( | ||||
|      *                                        'file_limit' => array(), | ||||
|      *                                        'time_limit' => array() | ||||
|      *                                    ), | ||||
|      *                                    'change' => array( | ||||
|      *                                        'name' => array( | ||||
|      *                                            'length' => '20', | ||||
|      *                                            'definition' => array( | ||||
|      *                                                'type' => 'text', | ||||
|      *                                                'length' => 20, | ||||
|      *                                            ), | ||||
|      *                                        ) | ||||
|      *                                    ), | ||||
|      *                                    'rename' => array( | ||||
|      *                                        'sex' => array( | ||||
|      *                                            'name' => 'gender', | ||||
|      *                                            'definition' => array( | ||||
|      *                                                'type' => 'text', | ||||
|      *                                                'length' => 1, | ||||
|      *                                                'default' => 'M', | ||||
|      *                                            ), | ||||
|      *                                        ) | ||||
|      *                                    ) | ||||
|      *                                ) | ||||
|      * | ||||
|      * @param boolean $check     (ignored in DB_Table) | ||||
|      * @access public | ||||
|      * | ||||
|      * @return mixed DB_OK on success, a PEAR error on failure | ||||
|      */ | ||||
|     function alterTable($name, $changes, $check) | ||||
|     { | ||||
|         foreach ($changes as $change_name => $change) { | ||||
|             switch ($change_name) { | ||||
|             case 'add': | ||||
|             case 'remove': | ||||
|             case 'change': | ||||
|             case 'rename': | ||||
|             case 'name': | ||||
|                 break; | ||||
|             default: | ||||
|                 return DB_Table::throwError(DB_TABLE_ERR_ALTER_TABLE_IMPOS); | ||||
|             } | ||||
|         } | ||||
| 
 | ||||
|         $query = ''; | ||||
|         if (array_key_exists('name', $changes)) { | ||||
|             $change_name = $this->_db->quoteIdentifier($changes['name']); | ||||
|             $query .= 'RENAME TO ' . $change_name; | ||||
|         } | ||||
| 
 | ||||
|         if (array_key_exists('add', $changes)) { | ||||
|             foreach ($changes['add'] as $field_name => $field) { | ||||
|                 if ($query) { | ||||
|                     $query.= ', '; | ||||
|                 } | ||||
|                 $query.= 'ADD ' . $field_name . ' ' . $field; | ||||
|             } | ||||
|         } | ||||
| 
 | ||||
|         if (array_key_exists('remove', $changes)) { | ||||
|             foreach ($changes['remove'] as $field_name => $field) { | ||||
|                 if ($query) { | ||||
|                     $query.= ', '; | ||||
|                 } | ||||
|                 $field_name = $db->quoteIdentifier($field_name); | ||||
|                 $query.= 'DROP ' . $field_name; | ||||
|             } | ||||
|         } | ||||
| 
 | ||||
|         $rename = array(); | ||||
|         if (array_key_exists('rename', $changes)) { | ||||
|             foreach ($changes['rename'] as $field_name => $field) { | ||||
|                 $rename[$field['name']] = $field_name; | ||||
|             } | ||||
|         } | ||||
| 
 | ||||
|         if (array_key_exists('change', $changes)) { | ||||
|             foreach ($changes['change'] as $field_name => $field) { | ||||
|                 if ($query) { | ||||
|                     $query.= ', '; | ||||
|                 } | ||||
|                 if (isset($rename[$field_name])) { | ||||
|                     $old_field_name = $rename[$field_name]; | ||||
|                     unset($rename[$field_name]); | ||||
|                 } else { | ||||
|                     $old_field_name = $field_name; | ||||
|                 } | ||||
|                 $old_field_name = $this->_db->quoteIdentifier($old_field_name); | ||||
|                 $query.= "CHANGE $old_field_name " . $field_name . ' ' . $field['definition']; | ||||
|             } | ||||
|         } | ||||
| 
 | ||||
|         if (!empty($rename)) { | ||||
|             foreach ($rename as $rename_name => $renamed_field) { | ||||
|                 if ($query) { | ||||
|                     $query.= ', '; | ||||
|                 } | ||||
|                 $field = $changes['rename'][$renamed_field]; | ||||
|                 $renamed_field = $this->_db->quoteIdentifier($renamed_field); | ||||
|                 $query.= 'CHANGE ' . $renamed_field . ' ' . $field['name'] . ' ' . $renamed_field['definition']; | ||||
|             } | ||||
|         } | ||||
| 
 | ||||
|         if (!$query) { | ||||
|             return DB_OK; | ||||
|         } | ||||
| 
 | ||||
|         $name = $this->_db->quoteIdentifier($name); | ||||
|         return $this->_db->query("ALTER TABLE $name $query"); | ||||
|     } | ||||
| 
 | ||||
| } | ||||
| 
 | ||||
| ?>
 | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue