mirror of
https://github.com/librenms/librenms.git
synced 2024-09-21 10:28:13 +00:00
04bb75f5f3
* Add no_proxy and other proxy related settings Set user agent on all http client requests Unify http client usage * Style fixes * Remove useless use statements * Correct variable, good job phpstan * Add tests fix https_proxy bug add tcp:// to the config settings format * style and lint fixes * Remove guzzle from the direct dependencies * Use built in Laravel testing functionality * update baseline
95 lines
2.7 KiB
PHP
95 lines
2.7 KiB
PHP
<?php
|
|
/**
|
|
* GeocodingHelper.php *
|
|
* -Description-
|
|
*
|
|
* This program is free software: you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
*
|
|
* @link https://www.librenms.org
|
|
*
|
|
* @copyright 2018 Tony Murray
|
|
* @author Tony Murray <murraytony@gmail.com>
|
|
*/
|
|
|
|
namespace App\ApiClients;
|
|
|
|
use Exception;
|
|
use Illuminate\Http\Client\PendingRequest;
|
|
use Illuminate\Http\Client\Response;
|
|
use LibreNMS\Config;
|
|
use Log;
|
|
|
|
trait GeocodingHelper
|
|
{
|
|
abstract protected function getClient(): PendingRequest;
|
|
|
|
/**
|
|
* Try to get the coordinates of a given address.
|
|
* If unsuccessful, the returned array will be empty
|
|
*
|
|
* @param string $address
|
|
* @return array ['lat' => 0, 'lng' => 0]
|
|
*/
|
|
public function getCoordinates($address)
|
|
{
|
|
if (! Config::get('geoloc.latlng', true)) {
|
|
Log::debug('Geocoding disabled');
|
|
|
|
return [];
|
|
}
|
|
|
|
try {
|
|
$client = $this->getClient()->withOptions($this->buildGeocodingOptions($address));
|
|
|
|
$response = $client->get($this->geocoding_uri);
|
|
$response_data = $response->json();
|
|
if ($this->checkResponse($response, $response_data)) {
|
|
return $this->parseLatLng($response_data);
|
|
} else {
|
|
Log::error('Geocoding failed.', ['response' => $response_data]);
|
|
}
|
|
} catch (Exception $e) {
|
|
Log::error('Geocoding failed: ' . $e->getMessage());
|
|
}
|
|
|
|
return [];
|
|
}
|
|
|
|
/**
|
|
* Checks if the request was a success
|
|
*/
|
|
protected function checkResponse(Response $response, array $data): bool
|
|
{
|
|
return $response->successful();
|
|
}
|
|
|
|
/**
|
|
* Get latitude and longitude from geocode response
|
|
*
|
|
* @param array $data
|
|
* @return array
|
|
*/
|
|
abstract protected function parseLatLng(array $data): array;
|
|
|
|
/**
|
|
* Build request option array
|
|
*
|
|
* @param string $address
|
|
* @return array
|
|
*
|
|
* @throws \Exception you may throw an Exception if validation fails
|
|
*/
|
|
abstract protected function buildGeocodingOptions(string $address): array;
|
|
}
|