| 
									
										
										
										
											2009-09-15 20:27:11 -04:00
										 |  |  | <?php | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * StatusNet, the distributed open-source microblogging tool | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Class for locations | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * PHP version 5 | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * LICENCE: This program is free software: you can redistribute it and/or modify | 
					
						
							|  |  |  |  * it under the terms of the GNU Affero General Public License as published by | 
					
						
							|  |  |  |  * the Free Software Foundation, either version 3 of the License, or | 
					
						
							|  |  |  |  * (at your option) any later version. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This program is distributed in the hope that it will be useful, | 
					
						
							|  |  |  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
					
						
							|  |  |  |  * GNU Affero General Public License for more details. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * You should have received a copy of the GNU Affero General Public License | 
					
						
							|  |  |  |  * along with this program.  If not, see <http://www.gnu.org/licenses/>. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @category  Location | 
					
						
							|  |  |  |  * @package   StatusNet | 
					
						
							|  |  |  |  * @author    Evan Prodromou <evan@status.net> | 
					
						
							|  |  |  |  * @copyright 2009 StatusNet, Inc. | 
					
						
							|  |  |  |  * @license   http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0 | 
					
						
							|  |  |  |  * @link      http://status.net/ | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | if (!defined('STATUSNET') && !defined('LACONICA')) { | 
					
						
							|  |  |  |     exit(1); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * class for locations | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2009-10-22 15:44:36 -04:00
										 |  |  |  * These are stored in the DB as part of notice and profile records, | 
					
						
							|  |  |  |  * but since they're about the same in both, we have a separate class | 
					
						
							|  |  |  |  * for them. | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2009-09-15 20:27:11 -04:00
										 |  |  |  * @category Location | 
					
						
							|  |  |  |  * @package  StatusNet | 
					
						
							|  |  |  |  * @author   Evan Prodromou <evan@status.net> | 
					
						
							|  |  |  |  * @license  http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0 | 
					
						
							|  |  |  |  * @link     http://status.net/ | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class Location | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2009-10-29 14:49:00 -04:00
										 |  |  |     public  $lat; | 
					
						
							|  |  |  |     public  $lon; | 
					
						
							|  |  |  |     public  $location_id; | 
					
						
							|  |  |  |     public  $location_ns; | 
					
						
							|  |  |  |     private $_url; | 
					
						
							| 
									
										
										
										
											2009-11-19 12:00:25 -05:00
										 |  |  |     private $_rdfurl; | 
					
						
							| 
									
										
										
										
											2009-09-15 20:27:11 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-22 15:44:36 -04:00
										 |  |  |     var $names = array(); | 
					
						
							| 
									
										
										
										
											2009-09-15 20:27:11 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-22 15:44:36 -04:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Constructor that makes a Location from a string name | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param string $name     Human-readable name (any kind) | 
					
						
							|  |  |  |      * @param string $language Language, default = common_language() | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return Location Location with that name (or null if not found) | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2009-09-16 11:46:10 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-22 15:44:36 -04:00
										 |  |  |     static function fromName($name, $language=null) | 
					
						
							| 
									
										
										
										
											2009-09-15 20:27:11 -04:00
										 |  |  |     { | 
					
						
							|  |  |  |         if (is_null($language)) { | 
					
						
							|  |  |  |             $language = common_language(); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2009-09-16 11:46:10 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |         $location = null; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-22 15:44:36 -04:00
										 |  |  |         // Let a third-party handle it
 | 
					
						
							| 
									
										
										
										
											2009-09-16 11:46:10 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-22 15:44:36 -04:00
										 |  |  |         Event::handle('LocationFromName', array($name, $language, &$location)); | 
					
						
							| 
									
										
										
										
											2009-09-16 11:46:10 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |         return $location; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-22 15:44:36 -04:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Constructor that makes a Location from an ID | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param integer $id       Identifier ID | 
					
						
							|  |  |  |      * @param integer $ns       Namespace of the identifier | 
					
						
							|  |  |  |      * @param string  $language Language to return name in (default is common) | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return Location The location with this ID (or null if none) | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     static function fromId($id, $ns, $language=null) | 
					
						
							| 
									
										
										
										
											2009-09-16 11:46:10 -04:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2009-10-29 16:15:49 -04:00
										 |  |  |         if (is_null($language)) { | 
					
						
							|  |  |  |             $language = common_language(); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-16 11:46:10 -04:00
										 |  |  |         $location = null; | 
					
						
							| 
									
										
										
										
											2009-10-22 15:44:36 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |         // Let a third-party handle it
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         Event::handle('LocationFromId', array($id, $ns, $language, &$location)); | 
					
						
							| 
									
										
										
										
											2009-09-16 11:46:10 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |         return $location; | 
					
						
							| 
									
										
										
										
											2009-09-15 20:27:11 -04:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-22 15:44:36 -04:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Constructor that finds the nearest location to a lat/lon pair | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param float  $lat      Latitude | 
					
						
							|  |  |  |      * @param float  $lon      Longitude | 
					
						
							|  |  |  |      * @param string $language Language for results, default = current | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return Location the location found, or null if none found | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     static function fromLatLon($lat, $lon, $language=null) | 
					
						
							| 
									
										
										
										
											2009-09-15 20:27:11 -04:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2009-10-22 15:44:36 -04:00
										 |  |  |         if (is_null($language)) { | 
					
						
							|  |  |  |             $language = common_language(); | 
					
						
							| 
									
										
										
										
											2009-09-15 20:27:11 -04:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2009-10-22 15:44:36 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |         $location = null; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // Let a third-party handle it
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (Event::handle('LocationFromLatLon', | 
					
						
							|  |  |  |                           array($lat, $lon, $language, &$location))) { | 
					
						
							|  |  |  |             // Default is just the lat/lon pair
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             $location = new Location(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             $location->lat = $lat; | 
					
						
							|  |  |  |             $location->lon = $lon; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $location; | 
					
						
							| 
									
										
										
										
											2009-09-15 20:27:11 -04:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-22 15:44:36 -04:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Get the name for this location in the given language | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param string $language language to use, default = current | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return string location name or null if not found | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-15 20:27:11 -04:00
										 |  |  |     function getName($language=null) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if (is_null($language)) { | 
					
						
							|  |  |  |             $language = common_language(); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-22 16:19:56 -04:00
										 |  |  |         if (array_key_exists($language, $this->names)) { | 
					
						
							| 
									
										
										
										
											2009-09-15 20:27:11 -04:00
										 |  |  |             return $this->names[$language]; | 
					
						
							| 
									
										
										
										
											2009-10-22 15:44:36 -04:00
										 |  |  |         } else { | 
					
						
							|  |  |  |             $name = null; | 
					
						
							|  |  |  |             Event::handle('LocationNameLanguage', array($this, $language, &$name)); | 
					
						
							|  |  |  |             if (!empty($name)) { | 
					
						
							|  |  |  |                 $this->names[$language] = $name; | 
					
						
							|  |  |  |                 return $name; | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2009-09-15 20:27:11 -04:00
										 |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2009-10-29 14:49:00 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Get an URL suitable for this location | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return string URL for this location or NULL | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     function getURL() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2009-10-29 16:15:49 -04:00
										 |  |  |         // Keep one cached
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (is_string($this->_url)) { | 
					
						
							| 
									
										
										
										
											2009-10-29 14:49:00 -04:00
										 |  |  |             return $this->_url; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $url = null; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         Event::handle('LocationUrl', array($this, &$url)); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-29 16:15:49 -04:00
										 |  |  |         $this->_url = $url; | 
					
						
							| 
									
										
										
										
											2009-10-29 14:49:00 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-29 16:15:49 -04:00
										 |  |  |         return $url; | 
					
						
							| 
									
										
										
										
											2009-10-29 14:49:00 -04:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2009-11-19 12:00:25 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Get an URL for this location, suitable for embedding in RDF | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return string URL for this location or NULL | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     function getRdfURL() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         // Keep one cached
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (is_string($this->_rdfurl)) { | 
					
						
							|  |  |  |             return $this->_rdfurl; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $url = null; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         Event::handle('LocationRdfUrl', array($this, &$url)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $this->_rdfurl = $url; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $url; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2009-09-15 20:27:11 -04:00
										 |  |  | } |