!C99Shell v. 2.5 [PHP 8 Update] [24.05.2025]!

Software: Apache. PHP/8.1.30 

uname -a: Linux server1.tuhinhossain.com 5.15.0-151-generic #161-Ubuntu SMP Tue Jul 22 14:25:40 UTC
2025 x86_64
 

uid=1002(picotech) gid=1003(picotech) groups=1003(picotech),0(root)  

Safe-mode: OFF (not secure)

/home/picotech/public_html/phpmyadmin/libraries/classes/Controllers/Table/   drwxr-xr-x
Free 28.69 GB of 117.98 GB (24.31%)
Home    Back    Forward    UPDIR    Refresh    Search    Buffer    Encoder    Tools    Proc.    FTP brute    Sec.    SQL    PHP-code    Update    Self remove    Logout    


Viewing file:     GisVisualizationController.php (7.05 KB)      -rwxr-x---
Select action/file-type:
(+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
<?php

declare(strict_types=1);

namespace 
PhpMyAdmin\Controllers\Table;

use 
PhpMyAdmin\Core;
use 
PhpMyAdmin\DatabaseInterface;
use 
PhpMyAdmin\Gis\GisVisualization;
use 
PhpMyAdmin\Html\Generator;
use 
PhpMyAdmin\Message;
use 
PhpMyAdmin\ResponseRenderer;
use 
PhpMyAdmin\Template;
use 
PhpMyAdmin\Url;
use 
PhpMyAdmin\Util;

use function 
__;
use function 
array_merge;
use function 
is_array;

/**
 * Handles creation of the GIS visualizations.
 */
final class GisVisualizationController extends AbstractController
{
    
/** @var GisVisualization */
    
private $visualization;

    
/** @var DatabaseInterface */
    
private $dbi;

    public function 
__construct(
        
ResponseRenderer $response,
        
Template $template,
        
string $db,
        
string $table,
        
DatabaseInterface $dbi
    
) {
        
parent::__construct($response$template$db$table);
        
$this->dbi $dbi;
    }

    public function 
__invoke(): void
    
{
        global 
$cfg$urlParams$db$errorUrl;

        
Util::checkParameters(['db']);

        
$errorUrl Util::getScriptNameForOption($cfg['DefaultTabDatabase'], 'database');
        
$errorUrl .= Url::getCommon(['db' => $db], '&');

        if (! 
$this->hasDatabase()) {
            return;
        }

        
// SQL query for retrieving GIS data
        
$sqlQuery '';
        if (isset(
$_GET['sql_query'], $_GET['sql_signature'])) {
            if (
Core::checkSqlQuerySignature($_GET['sql_query'], $_GET['sql_signature'])) {
                
$sqlQuery $_GET['sql_query'];
            }
        } elseif (isset(
$_POST['sql_query'])) {
            
$sqlQuery $_POST['sql_query'];
        }

        
// Throw error if no sql query is set
        
if ($sqlQuery == '') {
            
$this->response->setRequestStatus(false);
            
$this->response->addHTML(
                
Message::error(__('No SQL query was set to fetch data.'))->getDisplay()
            );

            return;
        }

        
// Execute the query and return the result
        
$result $this->dbi->tryQuery($sqlQuery);
        
// Get the meta data of results
        
$meta = [];
        if (
$result !== false) {
            
$meta $this->dbi->getFieldsMeta($result);
        }

        
// Find the candidate fields for label column and spatial column
        
$labelCandidates = [];
        
$spatialCandidates = [];
        foreach (
$meta as $column_meta) {
            if (
$column_meta->isMappedTypeGeometry) {
                
$spatialCandidates[] = $column_meta->name;
            } else {
                
$labelCandidates[] = $column_meta->name;
            }
        }

        
// Get settings if any posted
        
$visualizationSettings = [];
        
// Download as PNG/SVG/PDF use _GET and the normal form uses _POST
        
if (isset($_POST['visualizationSettings']) && is_array($_POST['visualizationSettings'])) {
            
$visualizationSettings $_POST['visualizationSettings'];
        } elseif (isset(
$_GET['visualizationSettings']) && is_array($_GET['visualizationSettings'])) {
            
$visualizationSettings $_GET['visualizationSettings'];
        }

        
// Check mysql version
        
$visualizationSettings['mysqlVersion'] = $this->dbi->getVersion();
        
$visualizationSettings['isMariaDB'] = $this->dbi->isMariaDB();

        if (! isset(
$visualizationSettings['labelColumn']) && isset($labelCandidates[0])) {
            
$visualizationSettings['labelColumn'] = '';
        }

        
// If spatial column is not set, use first geometric column as spatial column
        
if (! isset($visualizationSettings['spatialColumn'])) {
            
$visualizationSettings['spatialColumn'] = $spatialCandidates[0];
        }

        
// Download as PNG/SVG/PDF use _GET and the normal form uses _POST
        // Convert geometric columns from bytes to text.
        
$pos = (int) ($_POST['pos'] ?? $_GET['pos'] ?? $_SESSION['tmpval']['pos']);
        if (isset(
$_POST['session_max_rows']) || isset($_GET['session_max_rows'])) {
            
$rows = (int) ($_POST['session_max_rows'] ?? $_GET['session_max_rows']);
        } else {
            if (
$_SESSION['tmpval']['max_rows'] !== 'all') {
                
$rows = (int) $_SESSION['tmpval']['max_rows'];
            } else {
                
$rows = (int) $GLOBALS['cfg']['MaxRows'];
            }
        }

        
$this->visualization GisVisualization::get($sqlQuery$visualizationSettings$rows$pos);

        if (isset(
$_GET['saveToFile'])) {
            
$this->saveToFile($visualizationSettings['spatialColumn'], $_GET['fileFormat']);

            return;
        }

        
$this->addScriptFiles(['vendor/openlayers/OpenLayers.js''table/gis_visualization.js']);

        
// If all the rows contain SRID, use OpenStreetMaps on the initial loading.
        
if (! isset($_POST['displayVisualization'])) {
            if (
$this->visualization->hasSrid()) {
                
$visualizationSettings['choice'] = 'useBaseLayer';
            } else {
                unset(
$visualizationSettings['choice']);
            }
        }

        
$this->visualization->setUserSpecifiedSettings($visualizationSettings);
        if (
$visualizationSettings != null) {
            foreach (
$this->visualization->getSettings() as $setting => $val) {
                if (isset(
$visualizationSettings[$setting])) {
                    continue;
                }

                
$visualizationSettings[$setting] = $val;
            }
        }

        
/**
         * Displays the page
         */
        
$urlParams['goto'] = Util::getScriptNameForOption($cfg['DefaultTabDatabase'], 'database');
        
$urlParams['back'] = Url::getFromRoute('/sql');
        
$urlParams['sql_query'] = $sqlQuery;
        
$urlParams['sql_signature'] = Core::signSqlQuery($sqlQuery);
        
$downloadUrl Url::getFromRoute('/table/gis-visualization'array_merge(
            
$urlParams,
            [
                
'saveToFile' => true,
                
'session_max_rows' => $rows,
                
'pos' => $pos,
                
'visualizationSettings[spatialColumn]' => $visualizationSettings['spatialColumn'],
                
'visualizationSettings[labelColumn]' => $visualizationSettings['labelColumn'] ?? null,
            ]
        ));

        
$startAndNumberOfRowsFieldset Generator::getStartAndNumberOfRowsFieldsetData($sqlQuery);

        
$html $this->template->render('table/gis_visualization/gis_visualization', [
            
'url_params' => $urlParams,
            
'download_url' => $downloadUrl,
            
'label_candidates' => $labelCandidates,
            
'spatial_candidates' => $spatialCandidates,
            
'visualization_settings' => $visualizationSettings,
            
'start_and_number_of_rows_fieldset' => $startAndNumberOfRowsFieldset,
            
'visualization' => $this->visualization->toImage('svg'),
            
'draw_ol' => $this->visualization->asOl(),
        ]);

        
$this->response->addHTML($html);
    }

    
/**
     * @param string $filename File name
     * @param string $format   Save format
     */
    
private function saveToFile(string $filenamestring $format): void
    
{
        
$this->response->disable();
        
$this->visualization->toFile($filename$format);
    }
}

:: Command execute ::

Enter:
 
Select:
 

:: Search ::
  - regexp 

:: Upload ::
 
[ ok ]

:: Make Dir ::
 
[ ok ]
:: Make File ::
 
[ ok ]

:: Go Dir ::
 
:: Go File ::
 

--[ c99shell v. 2.5 [PHP 8 Update] [24.05.2025] | Generation time: 0.0046 ]--