X-Git-Url: https://git.openstreetmap.org./nominatim-ui.git/blobdiff_plain/6e68f11776a8f6f5a62b989f13ebf7438ef32476..33fa6758a39050475305d1816d5777907a6adef1:/src/lib/api_utils.js?ds=sidebyside diff --git a/src/lib/api_utils.js b/src/lib/api_utils.js index a44a30e..eb2a549 100644 --- a/src/lib/api_utils.js +++ b/src/lib/api_utils.js @@ -14,7 +14,7 @@ export async function fetch_from_api(endpoint_name, params, callback) { if (endpoint_name !== 'status') last_api_request_url_store.set(null); try { - await fetch(api_url) + await fetch(api_url, { headers: Nominatim_Config.Nominatim_API_Endpoint_Headers || {} }) .then(response => response.json()) .then(data => { if (data.error) { @@ -33,26 +33,43 @@ export async function fetch_from_api(endpoint_name, params, callback) { var fetch_content_cache = {}; export async function fetch_content_into_element(url, dom_element) { + if (!window.location.protocol.match(/^http/)) { + dom_element.innerHTML = `Cannot display data from ${url} here. ` + + 'Browser security prevents loading content from file:// URLs.'; + return; + } + if (fetch_content_cache[url]) { dom_element.innerHTML = fetch_content_cache[url]; return; } - await fetch(url) - .then(response => response.text()) - .then(html => { - html = html.replace('Nominatim_API_Endpoint', Nominatim_Config.Nominatim_API_Endpoint); - dom_element.innerHTML = html; - fetch_content_cache[url] = html; - }); + try { + await fetch(url) + .then(response => response.text()) + .then(html => { + html = html.replace('Nominatim_API_Endpoint', Nominatim_Config.Nominatim_API_Endpoint); + dom_element.innerHTML = html; + fetch_content_cache[url] = html; + }); + } catch (error) { + dom_element.innerHTML = `Error fetching content from ${url} (${error})`; + } } function generate_nominatim_api_url(endpoint_name, params) { + extend_parameters(params, Nominatim_Config.Nominatim_API_Endpoint_Params); return Nominatim_Config.Nominatim_API_Endpoint + endpoint_name + '.php?' + Object.keys(clean_up_parameters(params)).map((k) => { return encodeURIComponent(k) + '=' + encodeURIComponent(params[k]); }).join('&'); } +function extend_parameters(params, params2) { + var param_names = Object.keys(params2); + for (var i = 0; i < param_names.length; i += 1) { + params[param_names[i]] = params2[param_names[i]]; + } +} function clean_up_parameters(params) { // `&a=&b=&c=1` => '&c=1'