mirror of https://github.com/pelias/api.git
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
82 lines
1.8 KiB
82 lines
1.8 KiB
// validate inputs, convert types and apply defaults |
|
function sanitize( req ){ |
|
|
|
var clean = req.clean || {}; |
|
var params= req.query; |
|
|
|
// ensure the input params are a valid object |
|
if( Object.prototype.toString.call( params ) !== '[object Object]' ){ |
|
params = {}; |
|
} |
|
|
|
var is_invalid_lat = function(lat) { |
|
return isNaN( lat ) || lat < -90 || lat > 90; |
|
}; |
|
|
|
var is_invalid_lon = function(lon) { |
|
return isNaN( lon ) || lon < -180 || lon > 180; |
|
}; |
|
|
|
// lat |
|
var lat = parseFloat( params.lat, 10 ); |
|
if( is_invalid_lat(lat) ){ |
|
return { |
|
'error': true, |
|
'message': 'invalid param \'lat\': must be >-90 and <90' |
|
}; |
|
} |
|
clean.lat = lat; |
|
|
|
// lon |
|
var lon = parseFloat( params.lon, 10 ); |
|
if( is_invalid_lon(lon) ){ |
|
return { |
|
'error': true, |
|
'message': 'invalid param \'lon\': must be >-180 and <180' |
|
}; |
|
} |
|
clean.lon = lon; |
|
|
|
// zoom level |
|
var zoom = parseInt( params.zoom, 10 ); |
|
if( !isNaN( zoom ) ){ |
|
clean.zoom = Math.min( Math.max( zoom, 1 ), 18 ); // max |
|
} else { |
|
clean.zoom = 10; // default |
|
} |
|
|
|
// bbox |
|
if (params.bbox) { |
|
var bbox = []; |
|
var bboxArr = params.bbox.split(','); |
|
if( Array.isArray(bboxArr) && bboxArr.length === 4 ){ |
|
bboxArr.forEach(function(latlon, index) { |
|
latlon = parseFloat(latlon, 10); |
|
if ( !(index % 2 === 0 ? is_invalid_lat(latlon) : is_invalid_lon(latlon)) ) { |
|
bbox.push(latlon); |
|
} |
|
}); |
|
if (bbox.length === 4) { |
|
clean.bbox = { |
|
top : bbox[0], |
|
right : bbox[1], |
|
bottom: bbox[2], |
|
left : bbox[3] |
|
}; |
|
} else { |
|
return { |
|
'error': true, |
|
'message': 'invalid bbox' |
|
}; |
|
} |
|
} |
|
} |
|
|
|
req.clean = clean; |
|
|
|
return { 'error': false }; |
|
|
|
} |
|
|
|
// export function |
|
module.exports = sanitize;
|
|
|