| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248 |
- <?php
- /* vim: set expandtab sw=4 ts=4 sts=4: */
- /**
- * Holds the PMA\TableChartController
- *
- * @package PMA
- */
- namespace PMA\Controllers\Table;
- use PMA\DI\Container;
- use PMA_Util;
- use PMA_Message;
- use PMA\Template;
- use PMA\Controllers\TableController;
- require_once 'libraries/Util.class.php';
- require_once 'libraries/Message.class.php';
- require_once 'libraries/Template.class.php';
- require_once 'libraries/controllers/TableController.class.php';
- /**
- * Handles table related logic
- *
- * @package PhpMyAdmin
- */
- class TableChartController extends TableController
- {
- /**
- * @var string $sql_query
- */
- protected $sql_query;
- /**
- * @var string $url_query
- */
- protected $url_query;
- /**
- * @var array $cfg
- */
- protected $cfg;
- /**
- * Constructor
- *
- * @param string $sql_query Query
- * @param string $url_query Query URL
- * @param array $cfg Configuration
- */
- public function __construct($sql_query, $url_query, $cfg)
- {
- parent::__construct();
- $this->sql_query = $sql_query;
- $this->url_query = $url_query;
- $this->cfg = $cfg;
- }
- /**
- * Execute the query and return the result
- *
- * @return void
- */
- public function indexAction()
- {
- if (isset($_REQUEST['ajax_request'])
- && isset($_REQUEST['pos'])
- && isset($_REQUEST['session_max_rows'])
- ) {
- $this->ajaxAction();
- return;
- }
- // Throw error if no sql query is set
- if (!isset($this->sql_query) || $this->sql_query == '') {
- $this->response->isSuccess(false);
- $this->response->addHTML(
- PMA_Message::error(__('No SQL query was set to fetch data.'))
- );
- return;
- }
- $this->response->getHeader()->getScripts()->addFiles(
- array(
- 'chart.js',
- 'tbl_chart.js',
- 'jqplot/jquery.jqplot.js',
- 'jqplot/plugins/jqplot.barRenderer.js',
- 'jqplot/plugins/jqplot.canvasAxisLabelRenderer.js',
- 'jqplot/plugins/jqplot.canvasTextRenderer.js',
- 'jqplot/plugins/jqplot.categoryAxisRenderer.js',
- 'jqplot/plugins/jqplot.dateAxisRenderer.js',
- 'jqplot/plugins/jqplot.pointLabels.js',
- 'jqplot/plugins/jqplot.pieRenderer.js',
- 'jqplot/plugins/jqplot.highlighter.js'
- )
- );
- /**
- * Extract values for common work
- * @todo Extract common files
- */
- $db = &$this->db;
- $table = &$this->table;
- /**
- * Runs common work
- */
- if (/*overload*/ mb_strlen($this->table)) {
- $url_params['goto'] = PMA_Util::getScriptNameForOption(
- $this->cfg['DefaultTabTable'], 'table'
- );
- $url_params['back'] = 'tbl_sql.php';
- include 'libraries/tbl_common.inc.php';
- include 'libraries/tbl_info.inc.php';
- } elseif (/*overload*/ mb_strlen($this->db)) {
- $url_params['goto'] = PMA_Util::getScriptNameForOption(
- $this->cfg['DefaultTabDatabase'], 'database'
- );
- $url_params['back'] = 'sql.php';
- include 'libraries/db_common.inc.php';
- list(
- $tables,
- $num_tables,
- $total_num_tables,
- $sub_part,
- $is_show_stats,
- $db_is_system_schema,
- $tooltip_truename,
- $tooltip_aliasname,
- $pos
- ) = PMA_Util::getDbInfo($db, isset($sub_part) ? $sub_part : '');
- } else {
- $url_params['goto'] = PMA_Util::getScriptNameForOption(
- $this->cfg['DefaultTabServer'], 'server'
- );
- $url_params['back'] = 'sql.php';
- include 'libraries/server_common.inc.php';
- }
- $data = array();
- $result = $this->dbi->tryQuery($this->sql_query);
- $fields_meta = $this->dbi->getFieldsMeta($result);
- while ($row = $this->dbi->fetchAssoc($result)) {
- $data[] = $row;
- }
- $keys = array_keys($data[0]);
- $numeric_types = array('int', 'real');
- $numeric_column_count = 0;
- foreach ($keys as $idx => $key) {
- if (in_array($fields_meta[$idx]->type, $numeric_types)) {
- $numeric_column_count++;
- }
- }
- if ($numeric_column_count == 0) {
- $this->response->isSuccess(false);
- $this->response->addJSON(
- 'message',
- __('No numeric columns present in the table to plot.')
- );
- return;
- }
- $url_params['db'] = $this->db;
- $url_params['reload'] = 1;
- /**
- * Displays the page
- */
- $this->response->addHTML(
- Template::get('table/chart/tbl_chart')->render(
- array(
- 'url_query' => $this->url_query,
- 'url_params' => $url_params,
- 'keys' => $keys,
- 'fields_meta' => $fields_meta,
- 'numeric_types' => $numeric_types,
- 'numeric_column_count' => $numeric_column_count,
- 'sql_query' => $this->sql_query
- )
- )
- );
- }
- /**
- * Handle ajax request
- *
- * @return void
- */
- public function ajaxAction()
- {
- /**
- * Extract values for common work
- * @todo Extract common files
- */
- $db = &$this->db;
- $table = &$this->table;
- $tableLength = /*overload*/
- mb_strlen($this->table);
- $dbLength = /*overload*/
- mb_strlen($this->db);
- if ($tableLength && $dbLength) {
- include './libraries/tbl_common.inc.php';
- }
- $sql_with_limit = sprintf(
- 'SELECT * FROM(%s) AS `temp_res` LIMIT %s, %s',
- $this->sql_query,
- $_REQUEST['pos'],
- $_REQUEST['session_max_rows']
- );
- $data = array();
- $result = $this->dbi->tryQuery($sql_with_limit);
- while ($row = $this->dbi->fetchAssoc($result)) {
- $data[] = $row;
- }
- if (empty($data)) {
- $this->response->isSuccess(false);
- $this->response->addJSON('message', __('No data to display'));
- return;
- }
- $sanitized_data = array();
- foreach ($data as $data_row_number => $data_row) {
- $tmp_row = array();
- foreach ($data_row as $data_column => $data_value) {
- $tmp_row[htmlspecialchars($data_column)] = htmlspecialchars(
- $data_value
- );
- }
- $sanitized_data[] = $tmp_row;
- }
- $this->response->isSuccess(true);
- $this->response->addJSON('message', null);
- $this->response->addJSON('chartData', json_encode($sanitized_data));
- }
- }
|