-
Notifications
You must be signed in to change notification settings - Fork 521
Expand file tree
/
Copy pathIP2LocationIo.php
More file actions
118 lines (97 loc) · 3.02 KB
/
IP2LocationIo.php
File metadata and controls
118 lines (97 loc) · 3.02 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
<?php
declare(strict_types=1);
/*
* This file is part of the Geocoder package.
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*
* @license MIT License
*/
namespace Geocoder\Provider\IP2LocationIo;
use Geocoder\Collection;
use Geocoder\Exception\InvalidCredentials;
use Geocoder\Exception\UnsupportedOperation;
use Geocoder\Http\Provider\AbstractHttpProvider;
use Geocoder\Model\Address;
use Geocoder\Model\AddressCollection;
use Geocoder\Provider\Provider;
use Geocoder\Query\GeocodeQuery;
use Geocoder\Query\ReverseQuery;
use Psr\Http\Client\ClientInterface;
/**
* @author IP2Location <support@ip2location.com>
*/
final class IP2LocationIo extends AbstractHttpProvider implements Provider
{
/**
* @var string
*/
public const ENDPOINT_URL = 'https://api.ip2location.io/?key=%s&ip=%s';
/**
* @var string
*/
private $apiKey;
/**
* @var string
*/
private $endpointUrl;
/**
* @param ClientInterface $client an HTTP adapter
* @param string $apiKey an API key
*
* @throws \Geocoder\Exception\InvalidArgument
*/
public function __construct(ClientInterface $client, string $apiKey)
{
parent::__construct($client);
$this->apiKey = $apiKey;
}
public function geocodeQuery(GeocodeQuery $query): Collection
{
$address = $query->getText();
if ($this->apiKey === null) {
throw new InvalidCredentials('No API Key provided.');
}
if (!filter_var($address, FILTER_VALIDATE_IP)) {
throw new UnsupportedOperation('The IP2LocationIo provider does not support street addresses, only IPv4 or IPv6 addresses.');
}
if ($address === '127.0.0.1') {
return new AddressCollection([$this->getLocationForLocalhost()]);
}
$url = sprintf(self::ENDPOINT_URL, $this->apiKey, $address);
return $this->executeQuery($url);
}
public function reverseQuery(ReverseQuery $query): Collection
{
throw new UnsupportedOperation('The IP2LocationIo provider is not able to do reverse geocoding.');
}
public function getName(): string
{
return 'ip2location_io';
}
private function executeQuery(string $url): AddressCollection
{
$content = $this->getUrlContents($url);
$data = json_decode($content, true);
if (empty($data) || isset($data['error'])) {
return new AddressCollection([]);
}
$timeZone = timezone_name_from_abbr('', (int) substr($data['time_zone'], 0, strpos($data['time_zone'], ':')) * 3600, 0);
if (isset($data['time_zone_info']['olson'])) {
$timeZone = $data['time_zone_info']['olson'];
}
return new AddressCollection([
Address::createFromArray([
'providedBy' => $this->getName(),
'latitude' => $data['latitude'] ?? null,
'longitude' => $data['longitude'] ?? null,
'locality' => $data['city_name'] ?? null,
'postalCode' => $data['zip_code'] ?? null,
'adminLevels' => [['name' => $data['region_name'], 'level' => 1]],
'country' => $data['country_name'] ?? null,
'countryCode' => $data['country_code'] ?? null,
'timezone' => $timeZone,
]),
]);
}
}