003 File Manager
Current Path:
/usr/local/www/sites/shared/phpmyadmin/libraries/classes
usr
/
local
/
www
/
sites
/
shared
/
phpmyadmin
/
libraries
/
classes
/
📁
..
📄
Advisor.php
(17.87 KB)
📄
Bookmark.php
(9.85 KB)
📄
BrowseForeigners.php
(10.7 KB)
📄
CentralColumns.php
(53.12 KB)
📄
Charsets.php
(24.07 KB)
📄
CheckUserPrivileges.php
(11.58 KB)
📁
Config
📄
Config.php
(58.1 KB)
📄
Console.php
(3.58 KB)
📁
Controllers
📄
Core.php
(38.15 KB)
📄
CreateAddField.php
(17.95 KB)
📁
Database
📄
DatabaseInterface.php
(103.63 KB)
📁
Dbi
📁
Di
📁
Display
📄
Encoding.php
(8.25 KB)
📁
Engines
📄
Error.php
(12.93 KB)
📄
ErrorHandler.php
(16.32 KB)
📄
ErrorReport.php
(8.28 KB)
📄
Export.php
(40.32 KB)
📄
File.php
(20.43 KB)
📄
FileListing.php
(2.83 KB)
📄
Font.php
(4.25 KB)
📄
Footer.php
(10.47 KB)
📁
Gis
📄
Header.php
(25.81 KB)
📄
Import.php
(55.59 KB)
📄
Index.php
(24.63 KB)
📄
IndexColumn.php
(4.43 KB)
📄
InsertEdit.php
(129.1 KB)
📄
IpAllowDeny.php
(9.21 KB)
📄
Language.php
(4.3 KB)
📄
LanguageManager.php
(23.17 KB)
📄
Linter.php
(5.1 KB)
📄
ListAbstract.php
(3.15 KB)
📄
ListDatabase.php
(4.22 KB)
📄
Logging.php
(2.56 KB)
📄
Menu.php
(22.34 KB)
📄
Message.php
(19.19 KB)
📄
Mime.php
(891 B)
📄
MultSubmits.php
(23.19 KB)
📁
Navigation
📄
Normalization.php
(38.99 KB)
📄
OpenDocument.php
(8.5 KB)
📄
Operations.php
(79.4 KB)
📄
OutputBuffering.php
(3.63 KB)
📄
ParseAnalyze.php
(2.46 KB)
📄
Partition.php
(7.26 KB)
📄
Pdf.php
(4.07 KB)
📁
Plugins
📄
Plugins.php
(21.42 KB)
📁
Properties
📄
RecentFavoriteTable.php
(12.05 KB)
📄
Relation.php
(75.97 KB)
📄
RelationCleanup.php
(14.7 KB)
📄
Replication.php
(5.37 KB)
📄
ReplicationGui.php
(41.46 KB)
📄
Response.php
(16.31 KB)
📁
Rte
📄
Sanitize.php
(14.15 KB)
📄
SavedSearches.php
(11.95 KB)
📄
Scripts.php
(5.33 KB)
📁
Server
📄
Session.php
(7.68 KB)
📄
Sql.php
(87.62 KB)
📄
SqlQueryForm.php
(17.19 KB)
📄
StorageEngine.php
(13.47 KB)
📄
SubPartition.php
(3.53 KB)
📄
SysInfo.php
(1.54 KB)
📄
SysInfoBase.php
(801 B)
📄
SysInfoLinux.php
(1.96 KB)
📄
SysInfoSunOS.php
(1.87 KB)
📄
SysInfoWINNT.php
(3.1 KB)
📄
SystemDatabase.php
(3.84 KB)
📄
Table.php
(92.48 KB)
📄
Template.php
(3.91 KB)
📄
Theme.php
(10.53 KB)
📄
ThemeManager.php
(10.64 KB)
📄
Tracker.php
(29.43 KB)
📄
Tracking.php
(41.96 KB)
📄
Transformations.php
(16.12 KB)
📁
Twig
📄
TwoFactor.php
(7 KB)
📄
Types.php
(22.75 KB)
📄
Url.php
(8.02 KB)
📄
UserPassword.php
(8.26 KB)
📄
UserPreferences.php
(8.52 KB)
📄
Util.php
(162.41 KB)
📁
Utils
📄
VersionInformation.php
(6.34 KB)
📄
ZipExtension.php
(9.98 KB)
Editing: RecentFavoriteTable.php
<?php /* vim: set expandtab sw=4 ts=4 sts=4: */ /** * Recent and Favorite table list handling * * @package PhpMyAdmin */ namespace PhpMyAdmin; use PhpMyAdmin\DatabaseInterface; use PhpMyAdmin\Message; use PhpMyAdmin\Relation; use PhpMyAdmin\Url; use PhpMyAdmin\Util; /** * Handles the recently used and favorite tables. * * @TODO Change the release version in table pma_recent * (#recent in documentation) * * @package PhpMyAdmin */ class RecentFavoriteTable { /** * Reference to session variable containing recently used or favorite tables. * * @access private * @var array */ private $_tables; /** * Defines type of action, Favorite or Recent table. * * @access private * @var string */ private $_tableType; /** * RecentFavoriteTable instances. * * @access private * @var array */ private static $_instances = array(); /** * @var Relation $relation */ private $relation; /** * Creates a new instance of RecentFavoriteTable * * @param string $type the table type * * @access private */ private function __construct($type) { $this->relation = new Relation(); $this->_tableType = $type; $server_id = $GLOBALS['server']; if (! isset($_SESSION['tmpval'][$this->_tableType . '_tables'][$server_id]) ) { $_SESSION['tmpval'][$this->_tableType . '_tables'][$server_id] = $this->_getPmaTable() ? $this->getFromDb() : array(); } $this->_tables =& $_SESSION['tmpval'][$this->_tableType . '_tables'][$server_id]; } /** * Returns class instance. * * @param string $type the table type * * @return RecentFavoriteTable */ public static function getInstance($type) { if (! array_key_exists($type, self::$_instances)) { self::$_instances[$type] = new RecentFavoriteTable($type); } return self::$_instances[$type]; } /** * Returns the recent/favorite tables array * * @return array */ public function getTables() { return $this->_tables; } /** * Returns recently used tables or favorite from phpMyAdmin database. * * @return array */ public function getFromDb() { // Read from phpMyAdmin database, if recent tables is not in session $sql_query = " SELECT `tables` FROM " . $this->_getPmaTable() . " WHERE `username` = '" . $GLOBALS['dbi']->escapeString($GLOBALS['cfg']['Server']['user']) . "'"; $return = array(); $result = $this->relation->queryAsControlUser($sql_query, false); if ($result) { $row = $GLOBALS['dbi']->fetchArray($result); if (isset($row[0])) { $return = json_decode($row[0], true); } } return $return; } /** * Save recent/favorite tables into phpMyAdmin database. * * @return true|Message */ public function saveToDb() { $username = $GLOBALS['cfg']['Server']['user']; $sql_query = " REPLACE INTO " . $this->_getPmaTable() . " (`username`, `tables`)" . " VALUES ('" . $GLOBALS['dbi']->escapeString($username) . "', '" . $GLOBALS['dbi']->escapeString( json_encode($this->_tables) ) . "')"; $success = $GLOBALS['dbi']->tryQuery($sql_query, DatabaseInterface::CONNECT_CONTROL); if (! $success) { $error_msg = ''; switch ($this->_tableType) { case 'recent': $error_msg = __('Could not save recent table!'); break; case 'favorite': $error_msg = __('Could not save favorite table!'); break; } $message = Message::error($error_msg); $message->addMessage( Message::rawError( $GLOBALS['dbi']->getError(DatabaseInterface::CONNECT_CONTROL) ), '<br /><br />' ); return $message; } return true; } /** * Trim recent.favorite table according to the * NumRecentTables/NumFavoriteTables configuration. * * @return boolean True if trimming occurred */ public function trim() { $max = max( $GLOBALS['cfg']['Num' . ucfirst($this->_tableType) . 'Tables'], 0 ); $trimming_occurred = count($this->_tables) > $max; while (count($this->_tables) > $max) { array_pop($this->_tables); } return $trimming_occurred; } /** * Return HTML ul. * * @return string */ public function getHtmlList() { $html = ''; if (count($this->_tables)) { if ($this->_tableType == 'recent') { foreach ($this->_tables as $table) { $html .= '<li class="warp_link">'; $recent_params = array( 'db' => $table['db'], 'table' => $table['table'] ); $recent_url = 'tbl_recent_favorite.php' . Url::getCommon($recent_params); $html .= '<a href="' . $recent_url . '">`' . htmlspecialchars($table['db']) . '`.`' . htmlspecialchars($table['table']) . '`</a>'; $html .= '</li>'; } } else { foreach ($this->_tables as $table) { $html .= '<li class="warp_link">'; $html .= '<a class="ajax favorite_table_anchor" '; $fav_params = array( 'db' => $table['db'], 'ajax_request' => true, 'favorite_table' => $table['table'], 'remove_favorite' => true ); $fav_rm_url = 'db_structure.php' . Url::getCommon($fav_params); $html .= 'href="' . $fav_rm_url . '" title="' . __("Remove from Favorites") . '" data-favtargetn="' . md5($table['db'] . "." . $table['table']) . '" >' . Util::getIcon('b_favorite') . '</a>'; $fav_params = array( 'db' => $table['db'], 'table' => $table['table'] ); $table_url = 'tbl_recent_favorite.php' . Url::getCommon($fav_params); $html .= '<a href="' . $table_url . '">`' . htmlspecialchars($table['db']) . '`.`' . htmlspecialchars($table['table']) . '`</a>'; $html .= '</li>'; } } } else { $html .= '<li class="warp_link">' . ($this->_tableType == 'recent' ?__('There are no recent tables.') :__('There are no favorite tables.')) . '</li>'; } return $html; } /** * Return HTML. * * @return string */ public function getHtml() { $html = '<div class="drop_list">'; if ($this->_tableType == 'recent') { $html .= '<span title="' . __('Recent tables') . '" class="drop_button">' . __('Recent') . '</span><ul id="pma_recent_list">'; } else { $html .= '<span title="' . __('Favorite tables') . '" class="drop_button">' . __('Favorites') . '</span><ul id="pma_favorite_list">'; } $html .= $this->getHtmlList(); $html .= '</ul></div>'; return $html; } /** * Add recently used or favorite tables. * * @param string $db database name where the table is located * @param string $table table name * * @return true|Message True if success, Message if not */ public function add($db, $table) { // If table does not exist, do not add._getPmaTable() if (! $GLOBALS['dbi']->getColumns($db, $table)) { return true; } $table_arr = array(); $table_arr['db'] = $db; $table_arr['table'] = $table; // add only if this is new table if (! isset($this->_tables[0]) || $this->_tables[0] != $table_arr) { array_unshift($this->_tables, $table_arr); $this->_tables = array_merge(array_unique($this->_tables, SORT_REGULAR)); $this->trim(); if ($this->_getPmaTable()) { return $this->saveToDb(); } } return true; } /** * Removes recent/favorite tables that don't exist. * * @param string $db database * @param string $table table * * @return boolean|Message True if invalid and removed, False if not invalid, * Message if error while removing */ public function removeIfInvalid($db, $table) { foreach ($this->_tables as $tbl) { if ($tbl['db'] == $db && $tbl['table'] == $table) { // TODO Figure out a better way to find the existence of a table if (! $GLOBALS['dbi']->getColumns($tbl['db'], $tbl['table'])) { return $this->remove($tbl['db'], $tbl['table']); } } } return false; } /** * Remove favorite tables. * * @param string $db database name where the table is located * @param string $table table name * * @return true|Message True if success, Message if not */ public function remove($db, $table) { $table_arr = array(); $table_arr['db'] = $db; $table_arr['table'] = $table; foreach ($this->_tables as $key => $value) { if ($value['db'] == $db && $value['table'] == $table) { unset($this->_tables[$key]); } } if ($this->_getPmaTable()) { return $this->saveToDb(); } return true; } /** * Generate Html for sync Favorite tables anchor. (from localStorage to pmadb) * * @return string */ public function getHtmlSyncFavoriteTables() { $retval = ''; $server_id = $GLOBALS['server']; if ($server_id == 0) { return ''; } $cfgRelation = $this->relation->getRelationsParam(); // Not to show this once list is synchronized. if ($cfgRelation['favoritework'] && ! isset($_SESSION['tmpval']['favorites_synced'][$server_id])) { $params = array('ajax_request' => true, 'favorite_table' => true, 'sync_favorite_tables' => true); $url = 'db_structure.php' . Url::getCommon($params); $retval = '<a class="hide" id="sync_favorite_tables"'; $retval .= ' href="' . $url . '"></a>'; } return $retval; } /** * Generate Html to update recent tables. * * @return string html */ public static function getHtmlUpdateRecentTables() { $params = array('ajax_request' => true, 'recent_table' => true); $url = 'index.php' . Url::getCommon($params); $retval = '<a class="hide" id="update_recent_tables"'; $retval .= ' href="' . $url . '"></a>'; return $retval; } /** * Reutrn the name of the configuration storage table * * @return string pma table name */ private function _getPmaTable() { $cfgRelation = $this->relation->getRelationsParam(); if (! empty($cfgRelation['db']) && ! empty($cfgRelation[$this->_tableType]) ) { return Util::backquote($cfgRelation['db']) . "." . Util::backquote($cfgRelation[$this->_tableType]); } return null; } }
Upload File
Create Folder