X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;ds=inline;f=openstreetmap%2Fopenstreetmap.php;h=ab6ec27fc9987ceb2ddcbcca01204d123125e90d;hb=37dd8a938bb947d8b8f463dd58d377b40654bba6;hp=fda29905d411821fb145ce80aae1c01767731ced;hpb=7b71fec6222988a89423ee4584c87927f1a6e149;p=friendica-addons.git diff --git a/openstreetmap/openstreetmap.php b/openstreetmap/openstreetmap.php old mode 100755 new mode 100644 index fda29905..ab6ec27f --- a/openstreetmap/openstreetmap.php +++ b/openstreetmap/openstreetmap.php @@ -1,81 +1,228 @@ * Author: Mike Macgirvin * Author: Klaus Weidenbach * */ -function openstreetmap_install() { - register_hook('render_location', 'addon/openstreetmap/openstreetmap.php', 'openstreetmap_location'); +use Friendica\Core\Cache; +use Friendica\Core\Config; +use Friendica\Core\Hook; +use Friendica\Core\L10n; +use Friendica\Core\Logger; +use Friendica\Core\Renderer; +use Friendica\Util\Network; +use Friendica\Util\Strings; - logger("installed openstreetmap"); +const OSM_TMS = 'https://www.openstreetmap.org'; +const OSM_NOM = 'https://nominatim.openstreetmap.org/search.php'; +const OSM_ZOOM = 16; +const OSM_MARKER = 0; + +function openstreetmap_install() +{ + Hook::register('load_config', 'addon/openstreetmap/openstreetmap.php', 'openstreetmap_load_config'); + Hook::register('render_location', 'addon/openstreetmap/openstreetmap.php', 'openstreetmap_location'); + Hook::register('generate_map', 'addon/openstreetmap/openstreetmap.php', 'openstreetmap_generate_map'); + Hook::register('generate_named_map', 'addon/openstreetmap/openstreetmap.php', 'openstreetmap_generate_named_map'); + Hook::register('Map::getCoordinates', 'addon/openstreetmap/openstreetmap.php', 'openstreetmap_get_coordinates'); + Hook::register('page_header', 'addon/openstreetmap/openstreetmap.php', 'openstreetmap_alterheader'); + + Logger::log("installed openstreetmap"); } -function openstreetmap_uninstall() { - unregister_hook('render_location', 'addon/openstreetmap/openstreetmap.php', 'openstreetmap_location'); +function openstreetmap_uninstall() +{ + Hook::unregister('load_config', 'addon/openstreetmap/openstreetmap.php', 'openstreetmap_load_config'); + Hook::unregister('render_location', 'addon/openstreetmap/openstreetmap.php', 'openstreetmap_location'); + Hook::unregister('generate_map', 'addon/openstreetmap/openstreetmap.php', 'openstreetmap_generate_map'); + Hook::unregister('generate_named_map', 'addon/openstreetmap/openstreetmap.php', 'openstreetmap_generate_named_map'); + Hook::unregister('Map::getCoordinates', 'addon/openstreetmap/openstreetmap.php', 'openstreetmap_get_coordinates'); + Hook::unregister('page_header', 'addon/openstreetmap/openstreetmap.php', 'openstreetmap_alterheader'); + + Logger::log("removed openstreetmap"); +} - logger("removed openstreetmap"); +function openstreetmap_load_config(\Friendica\App $a, Config\ConfigCacheLoader $loader) +{ + $a->getConfig()->loadConfigArray($loader->loadAddonConfig('openstreetmap')); } +function openstreetmap_alterheader($a, &$navHtml) +{ + $addScriptTag = '' . "\r\n"; + $a->page['htmlhead'] .= $addScriptTag; +} -function openstreetmap_location($a, &$item) { - if(! (strlen($item['location']) || strlen($item['coord']))) - return; +/** + * @brief Add link to a map for an item's set location/coordinates. + * + * If an item has coordinates add link to a tile map server, e.g. openstreetmap.org. + * If an item has a location open it with the help of OSM's Nominatim reverse geocode search. + * + * @param mixed $a + * @param array& $item + */ +function openstreetmap_location($a, &$item) +{ + if (!(strlen($item['location']) || strlen($item['coord']))) { + return; + } /* - * Get the configuration variables from the .htconfig file. + * Get the configuration variables from the config. + * @todo Separate the tile map server from the text-string to map tile server + * since they apparently use different URL conventions. + * We use OSM's current convention of "#map=zoom/lat/lon" and optional + * ?mlat=lat&mlon=lon for markers. */ - $tmsserver = get_config('openstreetmap','tmsserver'); - if(! $tmsserver) - $tmsserver = 'http://openstreetmap.org'; - $zoom = get_config('openstreetmap','zoom'); - if(! $zoom) - $zoom = 17; - $location = ''; - $coord = ''; + $tmsserver = Config::get('openstreetmap', 'tmsserver', OSM_TMS); + $nomserver = Config::get('openstreetmap', 'nomserver', OSM_NOM); + $zoom = Config::get('openstreetmap', 'zoom', OSM_ZOOM); + $marker = Config::get('openstreetmap', 'marker', OSM_MARKER); - $location = (($item['location']) ? '' . $item['location'] . '' : ''); + // This is needed since we stored an empty string in the config in previous versions + if (empty($nomserver)) { + $nomserver = OSM_NOM; + } - if($item['coord']) { + if ($item['coord'] != "") { $coords = explode(' ', $item['coord']); - if(count($coords) > 1) { - $coord = '' . $item['coord'] . '' ; + if (count($coords) > 1) { + $lat = urlencode(round($coords[0], 5)); + $lon = urlencode(round($coords[1], 5)); + $target = $tmsserver; + if ($marker > 0) { + $target .= '?mlat=' . $lat . '&mlon=' . $lon; + } + $target .= '#map='.intval($zoom).'/'.$lat.'/'.$lon; + } + } + + if (empty($target)) { + $target = $nomserver.'?q='.urlencode($item['location']); + } + + if ($item['location'] != "") { + $title = $item['location']; + } else { + $title = $item['coord']; + } + + $item['html'] = ''.$title.''; +} + +function openstreetmap_get_coordinates($a, &$b) +{ + $nomserver = Config::get('openstreetmap', 'nomserver', OSM_NOM); + + // This is needed since we stored an empty string in the config in previous versions + if (empty($nomserver)) { + $nomserver = OSM_NOM; + } + + $args = '?q=' . urlencode($b['location']) . '&format=json'; + + $cachekey = "openstreetmap:" . $b['location']; + $j = Cache::get($cachekey); + + if (is_null($j)) { + $curlResult = Network::curl($nomserver . $args); + if ($curlResult->isSuccess()) { + $j = json_decode($curlResult->getBody(), true); + Cache::set($cachekey, $j, Cache::MONTH); } } - if(strlen($coord)) { - if($location) - $location .= '
(' . $coord . ')'; - else - $location = '' . $coord . ''; + + if (!empty($j[0]['lat']) && !empty($j[0]['lon'])) { + $b['lat'] = $j[0]['lat']; + $b['lon'] = $j[0]['lon']; + } +} + +function openstreetmap_generate_named_map(&$a, &$b) +{ + openstreetmap_get_coordinates($a, $b); + + if (!empty($b['lat']) && !empty($b['lon'])) { + openstreetmap_generate_map($a, $b); + } +} + +function openstreetmap_generate_map(&$a, &$b) +{ + $tmsserver = Config::get('openstreetmap', 'tmsserver', OSM_TMS); + + if (strpos($a->getBaseURL(true), 'https:') !== false) { + $tmsserver = str_replace('http:','https:',$tmsserver); + } + + $zoom = Config::get('openstreetmap', 'zoom', OSM_ZOOM); + $marker = Config::get('openstreetmap', 'marker', OSM_MARKER); + + $lat = $b['lat']; // round($b['lat'], 5); + $lon = $b['lon']; // round($b['lon'], 5); + + Logger::log('lat: ' . $lat, Logger::DATA); + Logger::log('lon: ' . $lon, Logger::DATA); + + $cardlink = '' . ($b['location'] ? Strings::escapeHtml($b['location']) : L10n::t('View Larger')) . ''; + if (empty($b['mode'])) { + $b['html'] = '' . + '
' . $cardlink . ''; + } else { + $b['html'] .= '
' . $cardlink; } - $item['html'] = $location; - return; + + Logger::log('generate_map: ' . $b['html'], Logger::DATA); } +function openstreetmap_addon_admin(&$a, &$o) +{ + $t = Renderer::getMarkupTemplate("admin.tpl", "addon/openstreetmap/"); + $tmsserver = Config::get('openstreetmap', 'tmsserver', OSM_TMS); + $nomserver = Config::get('openstreetmap', 'nomserver', OSM_NOM); + $zoom = Config::get('openstreetmap', 'zoom', OSM_ZOOM); + $marker = Config::get('openstreetmap', 'marker', OSM_MARKER); + + // This is needed since we stored an empty string in the config in previous versions + if (empty($nomserver)) { + $nomserver = OSM_NOM; + } -function openstreetmap_plugin_admin (&$a, &$o) { - $t = file_get_contents( dirname(__file__)."/admin.tpl"); - $tmsserver = get_config('openstreetmap','tmsserver'); - if(! $tmsserver) - $tmsserver = 'http://openstreetmap.org'; - $zoom = get_config('openstreetmap','zoom'); - if(! $zoom) - $zoom = 17; - - $o = replace_macros( $t, array( - '$submit' => t('Submit'), - '$tmsserver' => array('tmsserver', t('Tile Server URL'), $tmsserver, t('A list of public tile servers')), - '$zoom' => array('zoom', t('Default zoom'), $zoom, t('The default zoom level. (1:world, 18:highest)')), - )); + $o = Renderer::replaceMacros($t, [ + '$submit' => L10n::t('Submit'), + '$tmsserver' => ['tmsserver', L10n::t('Tile Server URL'), $tmsserver, L10n::t('A list of public tile servers')], + '$nomserver' => ['nomserver', L10n::t('Nominatim (reverse geocoding) Server URL'), $nomserver, L10n::t('A list of Nominatim servers')], + '$zoom' => ['zoom', L10n::t('Default zoom'), $zoom, L10n::t('The default zoom level. (1:world, 18:highest, also depends on tile server)')], + '$marker' => ['marker', L10n::t('Include marker on map'), $marker, L10n::t('Include a marker on the map.')], + ]); } -function openstreetmap_plugin_admin_post (&$a) { - $url = ((x($_POST, 'tmsserver')) ? notags(trim($_POST['tmsserver'])) : ''); - $zoom = ((x($_POST, 'zoom')) ? intval(trim($_POST['zoom'])) : '17'); - set_config('openstreetmap', 'tmsserver', $url); - set_config('openstreetmap', 'zoom', $zoom); - info( t('Settings updated.'). EOL); + +function openstreetmap_addon_admin_post(&$a) +{ + $urltms = defaults($_POST, 'tmsserver', OSM_TMS); + $urlnom = defaults($_POST, 'nomserver', OSM_NOM); + $zoom = defaults($_POST, 'zoom', OSM_ZOOM); + $marker = defaults($_POST, 'marker', OSM_MARKER); + + Config::set('openstreetmap', 'tmsserver', $urltms); + Config::set('openstreetmap', 'nomserver', $urlnom); + Config::set('openstreetmap', 'zoom', $zoom); + Config::set('openstreetmap', 'marker', $marker); + + info(L10n::t('Settings updated.') . EOL); }