# NAME Geo::GeoNames - Perform geographical queries using GeoNames Web Services # SYNOPSIS use Geo::GeoNames; my $geo = Geo::GeoNames->new( username => $username ); # make a query based on placename my $result = $geo->search(q => 'Fredrikstad', maxRows => 2); # print the first result print " Name: " . $result->[0]->{name}; print " Longitude: " . $result->[0]->{lng}; print " Lattitude: " . $result->[0]->{lat}; # Make a query based on postcode my $result = $geo->postalcode_search( postalcode => "1630", maxRows => 3, style => "FULL" ); # DESCRIPTION Before you start, get a free GeoNames account and enable it for access to the free web service: - Get an account Go to [http://www.geonames.org/login](http://www.geonames.org/login) - Respond to the email - Login and enable your account for free access [http://www.geonames.org/enablefreewebservice](http://www.geonames.org/enablefreewebservice) Provides a perl interface to the webservices found at [http://api.geonames.org](http://api.geonames.org). That is, given a given placename or postalcode, the module will look it up and return more information (longitude, lattitude, etc) for the given placename or postalcode. Wikipedia lookups are also supported. If more than one match is found, a list of locations will be returned. # METHODS - new $geo = Geo::GeoNames->new( username => '...' ) $geo = Geo::GeoNames->new( username => '...', url => $url ) Constructor for Geo::GeoNames. It returns a reference to an Geo::GeoNames object. You may also pass the url of the webservices to use. The default value is [http://api.geonames.org](http://api.geonames.org) and is the only url, to my knowledge, that provides the services needed by this module. The username parameter is required. - ua( $ua ) With a single argument, set the UserAgent to be used by all API calls and return that UserAgent object. Supports [Mojo::UserAgent](https://metacpan.org/pod/Mojo%3A%3AUserAgent) and [LWP::UserAgent](https://metacpan.org/pod/LWP%3A%3AUserAgent) derivatives. With no arguments, return the current UserAgent used. - username( $username ) With a single argument, set the GeoNames username and return that username. With no arguments, return the username. - default\_ua Returns the default UserAgent used a Mojo::UserAgent object that carps on errors. - default\_url Returns `http://api.geonames.org`. - url( $url ) With a single argument, set the GeoNames url and return that url. With no arguments, return the url. - geocode( $placename ) This method is just an easy access to search. It is the same as saying: $geo->search( q => $placename ); - search( arg => $arg ) Searches for information about a placename. Valid names for **arg** are as follows: q => $placename name => $placename name_equals => $placename maxRows => $maxrows startRow => $startrow country => $countrycode continentCode => $continentcode adminCode1 => $admin1 adminCode2 => $admin2 adminCode3 => $admin3 fclass => $fclass featureClass => $fclass, featureCode => $code lang => $lang type => $type style => $style isNameRequired => $isnamerequired tag => $tag name_startsWith => $name_startsWith countryBias => $countryBias cities => $cities operator => $operator searchlang => $searchlang charset => $charset fuzzy => $fuzzy north => $north west => $west east => $east south => $south orderby => $orderby One, and only one, of **q**, **name**, **name\_equals**, or **name\_startsWith** must be supplied to this method. fclass is deprecated. For a thorough description of the arguments, see [http://www.geonames.org/export/geonames-search.html](http://www.geonames.org/export/geonames-search.html) - find\_nearby\_placename( arg => $arg ) Reverse lookup for closest placename to a given coordinate. Valid names for **arg** are as follows: lat => $lat lng => $lng radius => $radius style => $style maxRows => $maxrows Both **lat** and **lng** must be supplied to this method. For a thorough descriptions of the arguments, see [http://www.geonames.org/export](http://www.geonames.org/export) - find\_nearest\_address(arg => $arg) Reverse lookup for closest address to a given coordinate. Valid names for **arg** are as follows: lat => $lat lng => $lng Both **lat** and **lng** must be supplied to this method. For a thorough descriptions of the arguments, see [http://www.geonames.org/maps/reverse-geocoder.html](http://www.geonames.org/maps/reverse-geocoder.html) US only. - find\_nearest\_intersection(arg => $arg) Reverse lookup for closest intersection to a given coordinate. Valid names for **arg** are as follows: lat => $lat lng => $lng Both **lat** and **lng** must be supplied to this method. For a thorough descriptions of the arguments, see [http://www.geonames.org/maps/reverse-geocoder.html](http://www.geonames.org/maps/reverse-geocoder.html) US only. - find\_nearby\_streets(arg => $arg) Reverse lookup for closest streets to a given coordinate. Valid names for **arg** are as follows: lat => $lat lng => $lng Both **lat** and **lng** must be supplied to this method. For a thorough descriptions of the arguments, see [http://www.geonames.org/maps/reverse-geocoder.html](http://www.geonames.org/maps/reverse-geocoder.html) US only. - postalcode\_search(arg => $arg) Searches for information about a postalcode. Valid names for **arg** are as follows: postalcode => $postalcode placename => $placename country => $country maxRows => $maxrows style => $style One, and only one, of **postalcode** or **placename** must be supplied to this method. For a thorough description of the arguments, see [http://www.geonames.org/export](http://www.geonames.org/export) - find\_nearby\_postalcodes(arg => $arg) Reverse lookup for postalcodes. Valid names for **arg** are as follows: lat => $lat lng => $lng radius => $radius maxRows => $maxrows style => $style country => $country Both **lat** and **lng** must be supplied to this method. For a thorough description of the arguments, see [http://www.geonames.org/export](http://www.geonames.org/export) - postalcode\_country\_info Returns a list of all postalcodes found on GeoNames. This method takes no arguments. - country\_info(arg => $arg) Returns country information. Valid names for **arg** are as follows: country => $country lang => $lang For a thorough description of the arguments, see [http://www.geonames.org/export](http://www.geonames.org/export) - find\_nearby\_wikipedia(arg => $arg) Reverse lookup for Wikipedia articles. Valid names for **arg** are as follows: lat => $lat lng => $lng radius => $radius maxRows => $maxrows lang => $lang country => $country Both **lat** and **lng** must be supplied to this method. For a thorough description of the arguments, see [http://www.geonames.org/export](http://www.geonames.org/export) - find\_nearby\_wikipediaby\_postalcode(arg => $arg) Reverse lookup for Wikipedia articles. Valid names for **arg** are as follows: postalcode => $postalcode country => $country radius => $radius maxRows => $maxrows Both **postalcode** and **country** must be supplied to this method. For a thorough description of the arguments, see [http://www.geonames.org/export](http://www.geonames.org/export) - wikipedia\_search(arg => $arg) Searches for Wikipedia articles. Valid names for **arg** are as follows: q => $placename maxRows => $maxrows lang => $lang title => $title **q** must be supplied to this method. For a thorough description of the arguments, see [http://www.geonames.org/export](http://www.geonames.org/export) - wikipedia\_bounding\_box(arg => $arg) Searches for Wikipedia articles. Valid names for **arg** are as follows: south => $south north => $north east => $east west => $west lang => $lang maxRows => $maxrows **south**, **north**, **east**, and **west** and must be supplied to this method. For a thorough description of the arguments, see [http://www.geonames.org/export](http://www.geonames.org/export) - cities(arg => $arg) Returns a list of cities and placenames within the bounding box. Valid names for **arg** are as follows: south => $south north => $north east => $east west => $west lang => $lang maxRows => $maxrows **south**, **north**, **east**, and **west** and must be supplied to this method. For a thorough description of the arguments, see [http://www.geonames.org/export](http://www.geonames.org/export) - country\_code(arg => $arg) Return the country code for a given point. Valid names for **arg** are as follows: lat => $lat lng => $lng radius => $radius lang => $lang Both **lat** and **lng** must be supplied to this method. For a thorough description of the arguments, see [http://www.geonames.org/export](http://www.geonames.org/export) - earthquakes(arg => $arg) Returns a list of cities and placenames within the bounding box. Valid names for **arg** are as follows: south => $south north => $north east => $east west => $west date => $date minMagnitude => $minmagnitude maxRows => $maxrows **south**, **north**, **east**, and **west** and must be supplied to this method. For a thorough description of the arguments, see [http://www.geonames.org/export](http://www.geonames.org/export) - find\_nearby\_weather(arg => $arg) Return the country code for a given point. Valid names for **arg** are as follows: lat => $lat lng => $lng Both **lat** and **lng** must be supplied to this method. For a thorough description of the arguments, see [http://www.geonames.org/export](http://www.geonames.org/export) - get(arg => $arg) Returns information about a given place based on a geonameId. geonameId => $geonameId lang => $lang style => $style (Seems to be ignored, although documented) **geonamesId** must be supplied to this method. **lang** and **style** are optional. For a thorough description of the arguments, see [http://www.geonames.org/export](http://www.geonames.org/export) - hiearchy(arg => $arg) Returns all GeoNames higher up in the hierarchy of a place based on a geonameId. geonameId => $geonameId style => $style (Not documented, but seems to be respected) **geonamesId** must be supplied to this method. **style** is optional. For a thorough description of the arguments, see [http://www.geonames.org/export/place-hierarchy.html#hierarchy](http://www.geonames.org/export/place-hierarchy.html#hierarchy) - children(arg => $arg) Returns the children (admin divisions and populated places) for a given geonameId. geonameId => $geonameId style => $style (Not documented, but seems to be respected) **geonamesId** must be supplied to this method. **style** is optional. For a thorough description of the arguments, see [https://www.geonames.org/export/place-hierarchy.html](https://www.geonames.org/export/place-hierarchy.html) # RETURNED DATASTRUCTURE The datastructure returned from methods in this module is an array of hashes. Each array element contains a hash which in turn contains the information about the placename/postalcode. For example, running the statement my $result = $geo->search( q => "Fredrikstad", maxRows => 3, style => "FULL" ); yields the result: $VAR1 = { 'population' => {}, 'lat' => '59.2166667', 'elevation' => {}, 'countryCode' => 'NO', 'adminName1' => "\x{d8}stfold", 'fclName' => 'city, village,...', 'adminCode2' => {}, 'lng' => '10.95', 'geonameId' => '3156529', 'timezone' => { 'dstOffset' => '2.0', 'content' => 'Europe/Oslo', 'gmtOffset' => '1.0' }, 'fcode' => 'PPL', 'countryName' => 'Norway', 'name' => 'Fredrikstad', 'fcodeName' => 'populated place', 'alternateNames' => 'Frederikstad,Fredrikstad,Fredrikstad kommun', 'adminCode1' => '13', 'adminName2' => {}, 'fcl' => 'P' }; The elements in the hashes depends on which **style** is passed to the method, but will always contain **name**, **lng**, and **lat** except for postalcode\_country\_info(), find\_nearest\_address(), find\_nearest\_intersection(), and find\_nearby\_streets(). # BUGS Not a bug, but the GeoNames services expects placenames to be UTF-8 encoded, and all data received from the webservices are also UTF-8 encoded. So make sure that strings are encoded/decoded based on the correct encoding. Please report any bugs found or feature requests through GitHub issues [https://https://github.com/nigelhorne/Geo-Geonames/issues](https://https://github.com/nigelhorne/Geo-Geonames/issues). or `bug-geo-geonamnes at rt.cpan.org`, or through the web interface at [http://rt.cpan.org/NoAuth/ReportBug.html?Queue=Geo-Geonames](http://rt.cpan.org/NoAuth/ReportBug.html?Queue=Geo-Geonames). I will be notified, and then you'll automatically be notified of progress on your bug as I make changes. # SEE ALSO - [http://www.geonames.org/export](http://www.geonames.org/export) - [http://www.geonames.org/export/ws-overview.html](http://www.geonames.org/export/ws-overview.html) # SOURCE AVAILABILITY The source code for this module is available from Github at [https://github.com/nigelhorne/Geo-Geonames](https://github.com/nigelhorne/Geo-Geonames). # AUTHOR Per Henrik Johansen, `<per.henrik.johansen@gmail.com>`. Previously maintained by brian d foy, `<brian.d.foy@gmail.com>` and Nicolas Mendoza, `<mendoza@pvv.ntnu.no>` Maintained by Nigel Horne, `<njh at bandsman.co.uk>` # COPYRIGHT AND LICENSE Copyright © 2007-2021 by Per Henrik Johansen Copyright © 2022 by Nigel Horne This library is available under the Artistic License 2.0.