GisVisualizationController.php 7.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227
  1. <?php
  2. /* vim: set expandtab sw=4 ts=4 sts=4: */
  3. /**
  4. * Holds the PhpMyAdmin\Controllers\Table\GisVisualizationController
  5. *
  6. * @package PhpMyAdmin\Controllers
  7. */
  8. declare(strict_types=1);
  9. namespace PhpMyAdmin\Controllers\Table;
  10. use PhpMyAdmin\Core;
  11. use PhpMyAdmin\DatabaseInterface;
  12. use PhpMyAdmin\Gis\GisVisualization;
  13. use PhpMyAdmin\Message;
  14. use PhpMyAdmin\Response;
  15. use PhpMyAdmin\Template;
  16. use PhpMyAdmin\Url;
  17. /**
  18. * Class GisVisualizationController
  19. *
  20. * @package PhpMyAdmin\Controllers
  21. */
  22. class GisVisualizationController extends AbstractController
  23. {
  24. /**
  25. * @var array
  26. */
  27. protected $url_params;
  28. /**
  29. * @var string
  30. */
  31. protected $sql_query;
  32. /**
  33. * @var array
  34. */
  35. protected $visualizationSettings;
  36. /**
  37. * @var GisVisualization
  38. */
  39. protected $visualization;
  40. /**
  41. * Constructor
  42. *
  43. * @param Response $response Response object
  44. * @param DatabaseInterface $dbi DatabaseInterface object
  45. * @param Template $template Template object
  46. * @param string $db Database name
  47. * @param string $table Table name
  48. * @param string $sql_query SQL query for retrieving GIS data
  49. * @param array $url_params array of URL parameters
  50. * @param string $goto goto script
  51. * @param string $back back script
  52. * @param array $visualizationSettings visualization settings
  53. */
  54. public function __construct(
  55. $response,
  56. $dbi,
  57. Template $template,
  58. $db,
  59. $table,
  60. $sql_query,
  61. array $url_params,
  62. $goto,
  63. $back,
  64. array $visualizationSettings
  65. ) {
  66. parent::__construct($response, $dbi, $template, $db, $table);
  67. require_once ROOT_PATH . 'libraries/common.inc.php';
  68. require_once ROOT_PATH . 'libraries/db_common.inc.php';
  69. $this->sql_query = $sql_query;
  70. $this->url_params = $url_params;
  71. $this->url_params['goto'] = $goto;
  72. $this->url_params['back'] = $back;
  73. $this->visualizationSettings = $visualizationSettings;
  74. }
  75. /**
  76. * Save to file
  77. *
  78. * @return void
  79. */
  80. public function saveToFileAction()
  81. {
  82. $this->response->disable();
  83. $file_name = $this->visualizationSettings['spatialColumn'];
  84. $save_format = $_GET['fileFormat'];
  85. $this->visualization->toFile($file_name, $save_format);
  86. }
  87. /**
  88. * Index
  89. *
  90. * @return void
  91. */
  92. public function indexAction()
  93. {
  94. // Throw error if no sql query is set
  95. if (! isset($this->sql_query) || $this->sql_query == '') {
  96. $this->response->setRequestStatus(false);
  97. $this->response->addHTML(
  98. Message::error(__('No SQL query was set to fetch data.'))
  99. );
  100. return;
  101. }
  102. // Execute the query and return the result
  103. $result = $this->dbi->tryQuery($this->sql_query);
  104. // Get the meta data of results
  105. $meta = $this->dbi->getFieldsMeta($result);
  106. // Find the candidate fields for label column and spatial column
  107. $labelCandidates = [];
  108. $spatialCandidates = [];
  109. foreach ($meta as $column_meta) {
  110. if ($column_meta->type == 'geometry') {
  111. $spatialCandidates[] = $column_meta->name;
  112. } else {
  113. $labelCandidates[] = $column_meta->name;
  114. }
  115. }
  116. // Get settings if any posted
  117. if (Core::isValid($_POST['visualizationSettings'], 'array')) {
  118. $this->visualizationSettings = $_POST['visualizationSettings'];
  119. }
  120. // Check mysql version
  121. $this->visualizationSettings['mysqlVersion'] = $this->dbi->getVersion();
  122. if (! isset($this->visualizationSettings['labelColumn'])
  123. && isset($labelCandidates[0])
  124. ) {
  125. $this->visualizationSettings['labelColumn'] = '';
  126. }
  127. // If spatial column is not set, use first geometric column as spatial column
  128. if (! isset($this->visualizationSettings['spatialColumn'])) {
  129. $this->visualizationSettings['spatialColumn'] = $spatialCandidates[0];
  130. }
  131. // Convert geometric columns from bytes to text.
  132. $pos = isset($_GET['pos']) ? $_GET['pos']
  133. : $_SESSION['tmpval']['pos'];
  134. if (isset($_GET['session_max_rows'])) {
  135. $rows = $_GET['session_max_rows'];
  136. } else {
  137. if ($_SESSION['tmpval']['max_rows'] != 'all') {
  138. $rows = $_SESSION['tmpval']['max_rows'];
  139. } else {
  140. $rows = $GLOBALS['cfg']['MaxRows'];
  141. }
  142. }
  143. $this->visualization = GisVisualization::get(
  144. $this->sql_query,
  145. $this->visualizationSettings,
  146. $rows,
  147. $pos
  148. );
  149. if (isset($_GET['saveToFile'])) {
  150. $this->saveToFileAction();
  151. return;
  152. }
  153. $this->response->getHeader()->getScripts()->addFiles(
  154. [
  155. 'vendor/openlayers/OpenLayers.js',
  156. 'vendor/jquery/jquery.svg.js',
  157. 'table/gis_visualization.js',
  158. ]
  159. );
  160. // If all the rows contain SRID, use OpenStreetMaps on the initial loading.
  161. if (! isset($_POST['displayVisualization'])) {
  162. if ($this->visualization->hasSrid()) {
  163. $this->visualizationSettings['choice'] = 'useBaseLayer';
  164. } else {
  165. unset($this->visualizationSettings['choice']);
  166. }
  167. }
  168. $this->visualization->setUserSpecifiedSettings($this->visualizationSettings);
  169. if ($this->visualizationSettings != null) {
  170. foreach ($this->visualization->getSettings() as $setting => $val) {
  171. if (! isset($this->visualizationSettings[$setting])) {
  172. $this->visualizationSettings[$setting] = $val;
  173. }
  174. }
  175. }
  176. /**
  177. * Displays the page
  178. */
  179. $this->url_params['sql_query'] = $this->sql_query;
  180. $downloadUrl = 'tbl_gis_visualization.php' . Url::getCommon(
  181. array_merge(
  182. $this->url_params,
  183. [
  184. 'saveToFile' => true,
  185. 'session_max_rows' => $rows,
  186. 'pos' => $pos,
  187. ]
  188. )
  189. );
  190. $html = $this->template->render('table/gis_visualization/gis_visualization', [
  191. 'url_params' => $this->url_params,
  192. 'download_url' => $downloadUrl,
  193. 'label_candidates' => $labelCandidates,
  194. 'spatial_candidates' => $spatialCandidates,
  195. 'visualization_settings' => $this->visualizationSettings,
  196. 'sql_query' => $this->sql_query,
  197. 'visualization' => $this->visualization->toImage('svg'),
  198. 'draw_ol' => $this->visualization->asOl(),
  199. 'pma_theme_image' => $GLOBALS['pmaThemeImage'],
  200. ]);
  201. $this->response->addHTML($html);
  202. }
  203. }