Package Data | |
---|---|
Maintainer Username: | AntonioCarlosRibeiro |
Maintainer Contact: | acr@antoniocarlosribeiro.com (Antonio Carlos Ribeiro) |
Package Create Date: | 2014-04-11 |
Package Last Update: | 2021-02-24 |
Language: | PHP |
License: | BSD-3-Clause |
Last Refreshed: | 2024-12-24 03:01:36 |
Package Statistics | |
---|---|
Total Downloads: | 63,251 |
Monthly Downloads: | 331 |
Daily Downloads: | 2 |
Total Stars: | 99 |
Total Watchers: | 7 |
Total Forks: | 41 |
Total Open Issues: | 16 |
You can use it in Laravel:
ZipCode::setCountry('US');
return Response::make(
ZipCode::find('10006')
);
Or outside it:
$z = new PragmaRX\ZipCode\ZipCode;
return $z->find('20250030')->toArray();
It automatically renders a JSON if you try to access it as string, but you still can:
$result = ZipCode::find('10006');
$json = $result->toJson();
$array = $result->toArray();
Select your preferred web service:
ZipCode::setPreferredWebService('Zippopotamus');
Get a web service by name, change things on it and find an address/city with it:
$webService = ZipCode::getWebServiceByName('Zippopotamus');
$webSerivice->setUrl('http://api.zippopotam.ca');
return ZipCode::find('20250030', $webService);
Create a new web service and add it to the list:
$webService = new PragmaRX\ZipCode\Support\WebService;
$webSerivice->setUrl('http://api.zippopotam.ca');
$webSerivice->setQuery('/%country%/%zip_code%');
ZipCode::addWebService($webService);
Change the user agent Guzzle will use to access the web service:
ZipCode::setUserAgent('Googlebot/2.1 (+http://www.google.com/bot.html)');
How much time it took to find a zip?:
$result = ZipCode::find('0200');
echo $result->getTimer();
Get a list of all available countries:
$array = ZipCode::getAvailableCountries();
Dynamically change query parameters, so if you have a Geonames login, you can set it by doing:
ZipCode::setQueryParameter('geonames_username', 'yourusername');
This package uses web services all around the world to provide addresses and cities information. There are at least 2 web services available to all countries (Brazil currently has 6), if ZipCode cannot access one or doesn't find a zip on it, it automatically falls back to the others. If you know of any other web services available that could be better than those, please create an issue or PR with it.
This is an example of what you get when you search a Zip with it:
{
country_id:"CH",
country_name:"Switzerland",
zip_code:"1005",
web_service:"Geonames",
timer:"0.7808",
service_query_url:"http://api.geonames.org/postalCodeSearch?country=CH&postalcode=1005&username=demo",
addresses:[
{
postal_code:"1005",
state_name:"Canton de Vaud",
state_id:"VD",
city:"Lausanne",
latitude:"46.51985",
longitude:"6.64252",
department:"District de Lausanne",
department_id:"2225",
district:"Lausanne"
}
],
result_raw:{
totalResultsCount:"1",
code:{
postalcode:"1005",
name:"Lausanne",
countryCode:"CH",
lat:"46.51985",
lng:"6.64252",
adminCode1:"VD",
adminName1:"Canton de Vaud",
adminCode2:"2225",
adminName2:"District de Lausanne",
adminCode3:"5586",
adminName3:"Lausanne"
}
},
success:true
}
ZipCode returns a PragmaRX\ZipCode\Support\Result
object and all properties can be accessed:
$result->getWebService();
$result->getCountryName();
This is an unconventionally hacked Laravel router which renders a form to query zips on a selected country:
Route::any('zipcode', function() {
echo
Form::open(array('url' => 'zipcode')) .
Form::select('country', ZipCode::getAvailableCountries(), Input::get('country')) .
Form::text('zipcode', Input::get('zipcode')) .
Form::submit('go!') .
Form::close();
if (Input::get('country'))
{
ZipCode::setCountry(Input::get('country'));
ZipCode::setQueryParameter('geonames_username', 'demo');
echo '<pre>';
var_dump(ZipCode::find(Input::get('zipcode'))->toArray());
echo '</pre>';
}
});
There are web services tested for the following countries:
If you need a different one, please ask or just send a pull request with it.
Install it using Composer:
composer require "pragmarx/zipcode"
Edit your app/config/app.php and add the Service Provider
'PragmaRX\ZipCode\Vendor\Laravel\ServiceProvider',
And the Facade
'ZipCode' => 'PragmaRX\ZipCode\Vendor\Laravel\Facade',
use PragmaRX\ZipCode\ZipCode;
$zipcode = new ZipCode();
return $zipcode->generateSecretKey()
$zipcode = app()->make('PragmaRX\ZipCode\Contracts\ZipCode');
return $zipcode->find('20250-030')
use PragmaRX\ZipCode\Contracts\ZipCode;
class WelcomeController extends Controller {
public function generateKey(ZipCode $zipcode)
{
return $zipcode->find('20250-030');
}
}
This is a really nice service and you should use it as your first option, but for it to be free (for 30,000 credits/day) you have to create an user account and enable the free webservices. And configure ZipCode to use your username:
ZipCode::setCountry('GB');
ZipCode::setQueryParameter('geonames_username', 'yourusername');
ZipCode::find('L23YL');
And you can also use config.php to set it:
return array(
...
'query_parameters' => array(
'geonames_username' => 'demo',
)
);
ZipCode is licensed under the BSD 3-Clause License - see the LICENSE
file for details
Pull requests and issues are more than welcome.