librenms/app/ApiClients/GeocodingHelper.php
Tony Murray 04bb75f5f3
Alert transport cleanup, no_proxy support and other proxy cleanups (#14763)
* 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
2023-05-23 09:25:17 -05:00

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;
}