A java REST service for creating and searching GeoNames Apache Lucene indexes.
The service can be used for fully functional GeoNames search. Be aware that the service has been mainly developed for geographic location normalization in the ZooPhy pipeline employing strategies that may not be optimal for use in your pipeline. GeoNames provides a versatile API interface of its own that you should consider using for searching locations in languages other than English.
- Java (JDK) 10.x Check branches for other versions of Java.
- Maven 3.x
-
Install Java (JDK) 10.x and Maven if not already installed
-
Create a copy of the application.properties.template file in the
config
folder. Rename it toapplication.properties
. Configure the paths according to the instructions shown. -
To create the binaries, run the command:
mvn clean package
This will download the required packages using Maven and build the system. The build should run successfully and generate a runnable jar in the target
folder which can be run via terminal as shown below.
- Download the GeoNames files using the command.
java -jar target/geonames-service-0.1.0.jar download
This downloads the required GeoNames files (about 2.3 GB disk space) into the resources
directory.
- Create the lucene index using the command. This may
java -jar target/geonames-service-0.1.0.jar create
This creates a searchable Lucene Index (about 1.5 GB disk space) in the index
directory.
- Run the services for querying data
java -jar target/geonames-service-0.1.0.jar
If it runs successfully, you should see a list of messages ending with
Tomcat started on port(s): 8091 (http)
Started GeonamesService in 4.045 seconds (JVM running for 4.52)
The services may be accessed via HTTP requests. They return data in JSON format. There are two main search APIs that are available.
- Type: GET
- Path:
/location?location=<LOCATION_NAME>
Usage Examples:
http://localhost:8091/location?location=AZ
This will search for "AZ" in the field "Name" of the Lucene index.
{
"records": [
{
"AncestorsNames": "Azerbaijan, Asia",
"Continent": "Asia",
"GeonameId": "587116",
"Population": "8303512",
"Country": "Azerbaijan",
"Class": "A",
"Latitude": "40.5",
"Code": "PCLI",
"Longitude": "47.5",
"Name": "Republic of Azerbaijan (Azerbaijan, AZ, AZE)"
}
],
"retrieved": 1,
"available": 1556
}
You may have meant AZ as in Arizona, so you could search for that specifically by providing the country information (USA) as shown below:
http://localhost:8091/location?location=AZ,USA
{
"records": [
{
"AncestorsNames": "Arizona(AZ), United States (US, USA), North America",
"Continent": "North America",
"GeonameId": "5551752",
"State": "Arizona(AZ)",
"Population": "5863809",
"Country": "United States (US, USA)",
"Class": "A",
"Latitude": "34.5003",
"Code": "ADM1",
"Longitude": "-111.50098",
"Name": "Arizona (AZ)"
}
],
"retrieved": 1,
"available": 2
}
- Type: GET
- Path:
/search?query=<LUCENE_QUERY>&count=<150|all>
Usage Examples:
http://localhost:8091/search?query=GeonameId:390903
{
"records": [
{
"AncestorsNames": "Greece, Europe",
"Continent": "Europe",
"GeonameId": "390903",
"Population": "11000000",
"Country": "Greece",
"Class": "A",
"Latitude": "39.0",
"Code": "PCLI",
"Longitude": "22.0",
"Name": "Hellenic Republic (Greece, GR, GRC)"
}
],
"retrieved": 1,
"available": 1
}
You can limit number of results using the count
URL parameter as shown below:
http://localhost:8091/search?query=Name:Springfield AND State:PA&count=2
{
"records": [
{
"AncestorsNames": "Delaware County, Pennsylvania(PA), United States (US, USA), North America",
"Continent": "North America",
"GeonameId": "4561407",
"State": "Pennsylvania(PA)",
"Population": "23363",
"Country": "United States (US, USA)",
"Class": "P",
"Latitude": "39.93067",
"Code": "PPL",
"Longitude": "-75.32019",
"County": "Delaware County",
"Name": "Springfield"
},
{
"AncestorsNames": "Bradford County, Pennsylvania(PA), United States (US, USA), North America",
"Continent": "North America",
"GeonameId": "5213459",
"State": "Pennsylvania(PA)",
"Population": "0",
"Country": "United States (US, USA)",
"Class": "P",
"Latitude": "41.84924",
"Code": "PPL",
"Longitude": "-76.74579",
"County": "Bradford County",
"Name": "Springfield"
}
],
"retrieved": 2,
"available": -1
}