Browse Source

Verify that bbox longitude is not NaN.

sanitiser/_geo.js
	-The removal of the longitude sanitizer might result in a NaN
	longitude value passing through in the bbox. Add an `isNaN()`
	check.
pull/178/head
Severyn Kozak 10 years ago committed by Julian Simioni
parent
commit
8868039835
  1. 17
      sanitiser/_geo.js

17
sanitiser/_geo.js

@ -51,14 +51,17 @@ function sanitize_bbox( clean, param ) {
if( Array.isArray( bboxArr ) && bboxArr.length === 4 ) {
var bbox = bboxArr.map( function ( latlon ){
return parseFloat( latlon, 10 );
});
bboxArr.forEach( function( latlon, index ) {
if( index % 2 === 1 && check_lat.is_invalid( latlon ) ){
throw new Error( 'Invalid lat: ' + latlon );
var bbox = [];
for( var ind = 0; ind < bboxArr.length; ind++ ){
var num = parseFloat( bboxArr[ ind ] );
if( isNaN( num ) ){
return;
}
if( ind % 2 === 1 && check_lat.is_invalid( num ) ){
throw new Error( 'Invalid lat: ' + num );
}
bbox.push( num );
}
});
clean.bbox = {
right: Math.max( bbox[0], bbox[2] ),

Loading…
Cancel
Save