[
MAINHACK
]
Mail Test
BC
Config Scan
HOME
Create...
New File
New Folder
Viewing / Editing File: GeoPoint.php
<?php /** * Copyright 2016 Google Inc. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ namespace Google\Cloud\Core; use InvalidArgumentException; /** * Represents a geographical point. * * Unless specified otherwise, this must conform to the * [WGS84](http://www.unoosa.org/pdf/icg/2012/template/WGS_84.pdf) standard. * Values must be within normalized ranges. * * Example: * ``` * use Google\Cloud\Core\GeoPoint; * * $point = new GeoPoint(37.423147, -122.085015); * ``` */ class GeoPoint implements \JsonSerializable { /** * @var float */ private $latitude; /** * @var float */ private $longitude; /** * Create a GeoPoint. * * Ints will be converted to floats. Values not passing the `is_numeric()` * check will result in an exception. * * @param float|int|null $latitude The GeoPoint Latitude. **Note** that * `null` is not a generally valid value, and will throw an * `InvalidArgumentException` unless `$allowNull` is set to `true`. * @param float|int|null $longitude The GeoPoint Longitude. **Note** that * `null` is not a generally valid value, and will throw an * `InvalidArgumentException` unless `$allowNull` is set to `true`. * @param bool $allowNull [optional] If true, null values will be allowed * in the constructor only. This switch exists to handle a rare case * wherein a geopoint may be empty and is not intended for use from * outside the client. **Defaults to** `false`. * @throws \InvalidArgumentException */ public function __construct($latitude, $longitude, $allowNull = false) { $this->latitude = $this->validateValue($latitude, 'latitude', $allowNull); $this->longitude = $this->validateValue($longitude, 'longitude', $allowNull); } /** * Get the latitude * * Example: * ``` * $latitude = $point->latitude(); * ``` * * @return float|null */ public function latitude() { $this->checkContext('latitude', func_get_args()); return $this->latitude; } /** * Set the latitude * * Non-numeric values will result in an exception * * Example: * ``` * $point->setLatitude(42.279594); * ``` * * @param int|float $latitude The new latitude * @return GeoPoint * @throws \InvalidArgumentException */ public function setLatitude($latitude) { $this->latitude = $this->validateValue($latitude, 'latitude'); return $this; } /** * Get the longitude * * Example: * ``` * $longitude = $point->longitude(); * ``` * * @return float|null */ public function longitude() { $this->checkContext('longitude', func_get_args()); return $this->longitude; } /** * Set the longitude * * Non-numeric values will result in an exception. * * Example: * ``` * $point->setLongitude(-83.732124); * ``` * * @param float|int $longitude The new longitude value * @return GeoPoint * @throws \InvalidArgumentException */ public function setLongitude($longitude) { $this->longitude = $this->validateValue($longitude, 'longitude'); return $this; } /** * Return a GeoPoint * * Example: * ``` * $point = $point->point(); * ``` * * @return array [LatLng](https://cloud.google.com/datastore/reference/rest/Shared.Types/LatLng) */ public function point() { return [ 'latitude' => $this->latitude, 'longitude' => $this->longitude ]; } /** * Let people know if they accidentally use the getter in setter context. * * @param string $method the method name * @param array $args The method arguments * @throws \InvalidArgumentException * @return void */ private function checkContext($method, array $args) { if (count($args) > 0) { throw new InvalidArgumentException(sprintf( 'Calling method %s with arguments is unsupported.', $method )); } } /** * Check a given value's validity as a coordinate. * * Numeric values will be cast to type `float`. All other values will raise * an exception with the exception of `null`, if `$allowNull` is set to true. * * @param mixed $value The coordinate value. * @param string $type The coordinate type for error reporting. * @param bool $allowNull [optional] Whether null values should be allowed. * **Defaults to** `false`. * @return float|null */ private function validateValue($value, $type, $allowNull = false) { if (!is_numeric($value) && (!$allowNull || ($allowNull && $value !== null))) { throw new InvalidArgumentException(sprintf( 'Given %s must be a numeric value.', $type )); } return $allowNull && $value === null ? $value : (float) $value; } /** * Implement JsonSerializable by representing GeoPoint as a JSON-object: * * ``` * { * latitude: 31.778333 * longitude: 35.229722 * } * ``` * * @return object * @access private */ #[\ReturnTypeWillChange] public function jsonSerialize() { return (object) $this->point(); } }
Save Changes
Cancel / Back
Close ×
Server Info
Hostname: server1.winmanyltd.com
Server IP: 203.161.60.52
PHP Version: 8.3.27
Server Software: Apache
System: Linux server1.winmanyltd.com 4.18.0-553.22.1.el8_10.x86_64 #1 SMP Tue Sep 24 05:16:59 EDT 2024 x86_64
HDD Total: 117.98 GB
HDD Free: 59.7 GB
Domains on IP: N/A (Requires external lookup)
System Features
Safe Mode:
Off
disable_functions:
None
allow_url_fopen:
On
allow_url_include:
Off
magic_quotes_gpc:
Off
register_globals:
Off
open_basedir:
None
cURL:
Enabled
ZipArchive:
Enabled
MySQLi:
Enabled
PDO:
Enabled
wget:
Yes
curl (cmd):
Yes
perl:
Yes
python:
Yes (py3)
gcc:
Yes
pkexec:
Yes
git:
Yes
User Info
Username: eliosofonline
User ID (UID): 1002
Group ID (GID): 1003
Script Owner UID: 1002
Current Dir Owner: 1002