summaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorEvan Prodromou <evan@status.net>2009-09-16 11:46:10 -0400
committerEvan Prodromou <evan@status.net>2009-10-21 22:47:19 -0400
commit7b227fd1c06ff6f3ba078b73348dd02419d44e38 (patch)
tree486b856b8a4a301eee63d08bd2542461b5f059d5 /lib
parentb6b245dc0be75a3358fee560a40a54e280e4f2a7 (diff)
start getting locations from remote services
Diffstat (limited to 'lib')
-rw-r--r--lib/default.php2
-rw-r--r--lib/location.php54
2 files changed, 55 insertions, 1 deletions
diff --git a/lib/default.php b/lib/default.php
index 30e43eefb..c896d5408 100644
--- a/lib/default.php
+++ b/lib/default.php
@@ -229,4 +229,6 @@ $default =
array('contentlimit' => null),
'http' =>
array('client' => 'curl'), // XXX: should this be the default?
+ 'location' =>
+ array('namespace' => 1), // 1 = geonames, 2 = Yahoo Where on Earth
);
diff --git a/lib/location.php b/lib/location.php
index cbd03f33a..f4ce7f67a 100644
--- a/lib/location.php
+++ b/lib/location.php
@@ -50,11 +50,63 @@ class Location
var $names;
- static function fromName($name, $language=null)
+ const geonames = 1;
+ const whereOnEarth = 2;
+
+ static function fromName($name, $language=null, $location_ns=null)
{
if (is_null($language)) {
$language = common_language();
}
+ if (is_null($location_ns)) {
+ $location_ns = common_config('location', 'namespace');
+ }
+
+ $location = null;
+
+ if (Event::handle('LocationFromName', array($name, $language, $location_ns, &$location))) {
+
+ switch ($location_ns) {
+ case Location::geonames:
+ return Location::fromGeonamesName($name, $language);
+ break;
+ case Location::whereOnEarth:
+ return Location::fromWhereOnEarthName($name, $language);
+ break;
+ }
+ }
+
+ return $location;
+ }
+
+ static function fromGeonamesName($name, $language)
+ {
+ $location = null;
+ $client = HTTPClient::start();
+
+ // XXX: break down a name by commas, narrow by each
+
+ $str = http_build_query(array('maxRows' => 1,
+ 'q' => $name,
+ 'lang' => $language,
+ 'type' => 'json'));
+
+ $result = $client->get('http://ws.geonames.org/search?'.$str);
+
+ if ($result->code == "200") {
+ $rj = json_decode($result->body);
+ if (count($rj['geonames']) > 0) {
+ $n = $rj['geonames'][0];
+ $location = new Location();
+ $location->lat = $n->lat;
+ $location->lon = $n->lon;
+ $location->name = $n->name;
+ $location->location_id = $n->geonameId;
+ $location->location_ns = Location:geonames;
+ }
+ }
+
+ return $location;
}
static function fromId($location_id, $location_ns = null)