X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=openstreetmap%2Fopenstreetmap.php;h=3b7c4a58623e2b58dcb03d36bada36fe42002ae6;hb=607cc9238cb62a049f9393906a656d7216095203;hp=370eb9104a15513f2e457c256c4049b006d1e3d9;hpb=9640142a720dfc7683e7bbf60d6f4f8799b918e9;p=friendica-addons.git diff --git a/openstreetmap/openstreetmap.php b/openstreetmap/openstreetmap.php index 370eb910..3b7c4a58 100644 --- a/openstreetmap/openstreetmap.php +++ b/openstreetmap/openstreetmap.php @@ -9,13 +9,13 @@ * */ -use Friendica\Core\Cache\Duration; +use Friendica\App; +use Friendica\Core\Cache\Enum\Duration; use Friendica\Core\Hook; use Friendica\Core\Logger; use Friendica\Core\Renderer; use Friendica\DI; -use Friendica\Network\HTTPRequest; -use Friendica\Util\ConfigFileLoader; +use Friendica\Core\Config\Util\ConfigFileManager; use Friendica\Util\Strings; const OSM_TMS = 'https://www.openstreetmap.org'; @@ -32,29 +32,17 @@ function openstreetmap_install() 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"); + Logger::notice("installed openstreetmap"); } -function openstreetmap_uninstall() +function openstreetmap_load_config(ConfigFileManager $loader) { - 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"); + DI::app()->getConfigCache()->load($loader->loadAddonConfig('openstreetmap'), \Friendica\Core\Config\ValueObject\Cache::SOURCE_STATIC); } -function openstreetmap_load_config(\Friendica\App $a, ConfigFileLoader $loader) +function openstreetmap_alterheader(&$navHtml) { - $a->getConfigCache()->load($loader->loadAddonConfig('openstreetmap')); -} - -function openstreetmap_alterheader($a, &$navHtml) -{ - $addScriptTag = '' . "\r\n"; + $addScriptTag = '' . "\r\n"; DI::page()['htmlhead'] .= $addScriptTag; } @@ -64,10 +52,9 @@ function openstreetmap_alterheader($a, &$navHtml) * 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) +function openstreetmap_location(array &$item) { if (!(strlen($item['location']) || strlen($item['coord']))) { return; @@ -91,9 +78,9 @@ function openstreetmap_location($a, &$item) $nomserver = OSM_NOM; } - if ($item['coord'] != "") { + if ($item['coord'] != '') { $coords = explode(' ', $item['coord']); - if (count($coords) > 1) { + if ((count($coords) > 1) && is_numeric($coords[0]) && is_numeric($coords[1])) { $lat = urlencode(round($coords[0], 5)); $lon = urlencode(round($coords[1], 5)); $target = $tmsserver; @@ -108,16 +95,16 @@ function openstreetmap_location($a, &$item) $target = $nomserver.'?q='.urlencode($item['location']); } - if ($item['location'] != "") { + if ($item['location'] != '') { $title = $item['location']; } else { $title = $item['coord']; } - $item['html'] = ''.$title.''; + $item['html'] = '' . $title . ''; } -function openstreetmap_get_coordinates($a, &$b) +function openstreetmap_get_coordinates(array &$b) { $nomserver = DI::config()->get('openstreetmap', 'nomserver', OSM_NOM); @@ -128,11 +115,11 @@ function openstreetmap_get_coordinates($a, &$b) $args = '?q=' . urlencode($b['location']) . '&format=json'; - $cachekey = "openstreetmap:" . $b['location']; + $cachekey = 'openstreetmap:' . $b['location']; $j = DI::cache()->get($cachekey); if (is_null($j)) { - $curlResult = HTTPRequest::curl($nomserver . $args); + $curlResult = DI::httpClient()->get($nomserver . $args); if ($curlResult->isSuccess()) { $j = json_decode($curlResult->getBody(), true); DI::cache()->set($cachekey, $j, Duration::MONTH); @@ -145,20 +132,20 @@ function openstreetmap_get_coordinates($a, &$b) } } -function openstreetmap_generate_named_map(&$a, &$b) +function openstreetmap_generate_named_map(array &$b) { - openstreetmap_get_coordinates($a, $b); + openstreetmap_get_coordinates($b); if (!empty($b['lat']) && !empty($b['lon'])) { - openstreetmap_generate_map($a, $b); + openstreetmap_generate_map($b); } } -function openstreetmap_generate_map(&$a, &$b) +function openstreetmap_generate_map(array &$b) { $tmsserver = DI::config()->get('openstreetmap', 'tmsserver', OSM_TMS); - if (strpos(DI::baseUrl()->get(true), 'https:') !== false) { + if (strpos(DI::baseUrl(), 'https:') !== false) { $tmsserver = str_replace('http:','https:',$tmsserver); } @@ -168,8 +155,8 @@ function openstreetmap_generate_map(&$a, &$b) $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); + Logger::debug('lat: ' . $lat); + Logger::debug('lon: ' . $lon); $cardlink = '' . ($b['location'] ? Strings::escapeHtml($b['location']) : DI::l10n()->t('View Larger')) . ''; + $cardlink .= '#map=' . $zoom . '/' . $lat . '/' . $lon . '">' . ($b['location'] ??0? Strings::escapeHtml($b['location']) : DI::l10n()->t('View Larger')) . ''; if (empty($b['mode'])) { $b['html'] = '