var api_url = generate_nominatim_api_url(endpoint_name, params);
// For the test suite:
- // If httpbin_status URL parameter is set we call https://httpbin.org/#/Status_codes
+ // If mock_http_status URL parameter is set we call an external webservice. First
+ // https://httpbin.org/#/Status_codes but we saw timeouts. Now beeceptor.com
+ // If that turns out unreliable or expensive (only 50/day free) we might have to
+ // start running a local webserver for the test suite
var tmp_params = new URLSearchParams(window.location.search);
- if (tmp_params && tmp_params.get('httpbin_status')) {
- api_url = 'https://httpbin.org/status/' + parseInt(tmp_params.get('httpbin_status'), 10);
+ if (tmp_params && tmp_params.get('mock_http_status')) {
+ api_url = 'https://nominatim-ui.free.beeceptor.com/status/' + parseInt(tmp_params.get('mock_http_status'), 10);
}
api_request_progress('start');
await fetch(url)
.then(response => response.text())
.then(html => {
- html = html.replace('Nominatim_API_Endpoint', Nominatim_Config.Nominatim_API_Endpoint);
+ html = html.replace('Nominatim_API_Endpoint', generate_nominatim_endpoint_url());
dom_element.innerHTML = html;
fetch_content_cache[url] = html;
});
}
}
+function generate_nominatim_endpoint_url(endpoint_name) {
+ var conf_endpoint = Nominatim_Config.Nominatim_API_Endpoint;
+
+ if (typeof conf_endpoint === 'function') {
+ return conf_endpoint(endpoint_name);
+ }
+
+ if (!endpoint_name) return conf_endpoint;
+
+ return conf_endpoint + endpoint_name + '.php';
+}
+
function generate_nominatim_api_url(endpoint_name, params) {
+ // default value for /search
+ if (params.dedupe === 1) delete params.dedupe;
+
extend_parameters(params, Nominatim_Config.Nominatim_API_Endpoint_Params);
- return Nominatim_Config.Nominatim_API_Endpoint + endpoint_name + '.php?'
+ return generate_nominatim_endpoint_url(endpoint_name)
+ + '?'
+ Object.keys(clean_up_parameters(params)).map((k) => {
return encodeURIComponent(k) + '=' + encodeURIComponent(params[k]);
}).join('&');