Submit
Path:
~
/
/
opt
/
psa
/
phpMyAdmin
/
libraries
/
classes
/
Utils
/
File Content:
Gis.php
<?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; } }
Edit
Rename
Chmod
Delete
FILE
FOLDER
INFO
Name
Size
Permission
Action
ForeignKey.php
2332 bytes
0644
FormatConverter.php
1858 bytes
0644
Gis.php
9704 bytes
0644
HttpRequest.php
9263 bytes
0644
SessionCache.php
1198 bytes
0644
N4ST4R_ID | Naxtarrr