Server IP : 127.0.0.2 / Your IP : 3.145.177.28 Web Server : Apache/2.4.18 (Ubuntu) System : User : www-data ( ) PHP Version : 7.0.33-0ubuntu0.16.04.16 Disable Function : disk_free_space,disk_total_space,diskfreespace,dl,exec,fpaththru,getmyuid,getmypid,highlight_file,ignore_user_abord,leak,listen,link,opcache_get_configuration,opcache_get_status,passthru,pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,php_uname,phpinfo,posix_ctermid,posix_getcwd,posix_getegid,posix_geteuid,posix_getgid,posix_getgrgid,posix_getgrnam,posix_getgroups,posix_getlogin,posix_getpgid,posix_getpgrp,posix_getpid,posix,_getppid,posix_getpwnam,posix_getpwuid,posix_getrlimit,posix_getsid,posix_getuid,posix_isatty,posix_kill,posix_mkfifo,posix_setegid,posix_seteuid,posix_setgid,posix_setpgid,posix_setsid,posix_setuid,posix_times,posix_ttyname,posix_uname,pclose,popen,proc_open,proc_close,proc_get_status,proc_nice,proc_terminate,shell_exec,source,show_source,system,virtual MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : ON | Pkexec : ON Directory : /usr/share/phpmyadmin/libraries/plugins/schema/ |
Upload File : |
<?php /* vim: set expandtab sw=4 ts=4 sts=4: */ /** * Contains abstract class to hold table preferences/statistics * * @package PhpMyAdmin */ if (! defined('PHPMYADMIN')) { exit; } /** * Table preferences/statistics * * This class preserves the table co-ordinates,fields * and helps in drawing/generating the tables. * * @package PhpMyAdmin * @abstract */ abstract class TableStats { protected $diagram; protected $db; protected $pageNumber; protected $tableName; protected $showKeys; protected $tableDimension; public $displayfield; public $fields = array(); public $primary = array(); public $x, $y; public $width = 0; public $heightCell = 0; protected $offline; /** * Constructor * * @param object $diagram schema diagram * @param string $db current db name * @param integer $pageNumber current page number (from the * $cfg['Servers'][$i]['table_coords'] table) * @param string $tableName table name * @param boolean $showKeys whether to display keys or not * @param boolean $tableDimension whether to display table position or not * @param boolean $offline whether the coordinates are sent * from the browser */ public function __construct( $diagram, $db, $pageNumber, $tableName, $showKeys, $tableDimension, $offline ) { $this->diagram = $diagram; $this->db = $db; $this->pageNumber = $pageNumber; $this->tableName = $tableName; $this->showKeys = $showKeys; $this->tableDimension = $tableDimension; $this->offline = $offline; // checks whether the table exists // and loads fields $this->validateTableAndLoadFields(); // load table coordinates $this->loadCoordinates(); // loads display field $this->loadDisplayField(); // loads primary keys $this->loadPrimaryKey(); } /** * Validate whether the table exists. * * @return void */ protected function validateTableAndLoadFields() { $sql = 'DESCRIBE ' . PMA_Util::backquote($this->tableName); $result = $GLOBALS['dbi']->tryQuery( $sql, null, PMA_DatabaseInterface::QUERY_STORE ); if (! $result || ! $GLOBALS['dbi']->numRows($result)) { $this->showMissingTableError(); } if ($this->showKeys) { $indexes = PMA_Index::getFromTable($this->tableName, $this->db); $all_columns = array(); foreach ($indexes as $index) { $all_columns = array_merge( $all_columns, array_flip(array_keys($index->getColumns())) ); } $this->fields = array_keys($all_columns); } else { while ($row = $GLOBALS['dbi']->fetchRow($result)) { $this->fields[] = $row[0]; } } } /** * Displays an error when the table cannot be found. * * @return void * @abstract */ protected abstract function showMissingTableError(); /** * Loads coordinates of a table * * @return void */ protected function loadCoordinates() { foreach ($_REQUEST['t_h'] as $key => $value) { if ($this->db . '.' . $this->tableName == $key) { $this->x = (double) $_REQUEST['t_x'][$key]; $this->y = (double) $_REQUEST['t_y'][$key]; break; } } } /** * Loads the table's display field * * @return void */ protected function loadDisplayField() { $this->displayfield = PMA_getDisplayField($this->db, $this->tableName); } /** * Loads the PRIMARY key. * * @return void */ protected function loadPrimaryKey() { $result = $GLOBALS['dbi']->query( 'SHOW INDEX FROM ' . PMA_Util::backquote($this->tableName) . ';', null, PMA_DatabaseInterface::QUERY_STORE ); if ($GLOBALS['dbi']->numRows($result) > 0) { while ($row = $GLOBALS['dbi']->fetchAssoc($result)) { if ($row['Key_name'] == 'PRIMARY') { $this->primary[] = $row['Column_name']; } } } } /** * Returns title of the current table, * title can have the dimensions/co-ordinates of the table * * @return string title of the current table */ protected function getTitle() { return ($this->tableDimension ? sprintf('%.0fx%0.f', $this->width, $this->heightCell) : '' ) . ' ' . $this->tableName; } }