|
|
@ -1,10 +1,11 @@ |
|
|
|
var isObject = require('is-object'); |
|
|
|
var isObject = require('is-object'); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// validate inputs, convert types and apply defaults
|
|
|
|
// validate inputs, convert types and apply defaults
|
|
|
|
function sanitize( req, latlon_is_required ){ |
|
|
|
module.exports = function sanitize( req, latlon_is_required ){ |
|
|
|
|
|
|
|
|
|
|
|
var clean = req.clean || {}; |
|
|
|
var clean = req.clean || {}; |
|
|
|
var params= req.query; |
|
|
|
var params = req.query; |
|
|
|
latlon_is_required = latlon_is_required || false; |
|
|
|
latlon_is_required = latlon_is_required || false; |
|
|
|
|
|
|
|
|
|
|
|
// ensure the input params are a valid object
|
|
|
|
// ensure the input params are a valid object
|
|
|
@ -12,87 +13,102 @@ function sanitize( req, latlon_is_required ){ |
|
|
|
params = {}; |
|
|
|
params = {}; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
var is_invalid_lat = function(lat) { |
|
|
|
try { |
|
|
|
return isNaN( lat ) || lat < -90 || lat > 90; |
|
|
|
sanitize_coord( 'lat', clean, params.lat, latlon_is_required ); |
|
|
|
}; |
|
|
|
sanitize_coord( 'lon', clean, params.lon, latlon_is_required ); |
|
|
|
|
|
|
|
sanitize_zoom_level(clean, params.zoom); |
|
|
|
var is_invalid_lon = function(lon) { |
|
|
|
sanitize_bbox(clean, params.bbox); |
|
|
|
return isNaN( lon ) || lon < -180 || lon > 180; |
|
|
|
} |
|
|
|
}; |
|
|
|
catch (err) { |
|
|
|
|
|
|
|
|
|
|
|
// lat
|
|
|
|
|
|
|
|
var lat = parseFloat( params.lat, 10 ); |
|
|
|
|
|
|
|
if (!isNaN(lat)) { |
|
|
|
|
|
|
|
if( is_invalid_lat(lat) ){ |
|
|
|
|
|
|
|
return { |
|
|
|
|
|
|
|
'error': true, |
|
|
|
|
|
|
|
'message': 'invalid param \'lat\': must be >-90 and <90' |
|
|
|
|
|
|
|
}; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
clean.lat = lat; |
|
|
|
|
|
|
|
} else if (latlon_is_required) { |
|
|
|
|
|
|
|
return { |
|
|
|
return { |
|
|
|
'error': true, |
|
|
|
'error': true, |
|
|
|
'message': 'missing param \'lat\': must be >-90 and <90' |
|
|
|
'message': err.message |
|
|
|
}; |
|
|
|
}; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
// lon
|
|
|
|
req.clean = clean; |
|
|
|
var lon = parseFloat( params.lon, 10 ); |
|
|
|
|
|
|
|
if (!isNaN(lon)) { |
|
|
|
return { 'error': false }; |
|
|
|
if( is_invalid_lon(lon) ){ |
|
|
|
}; |
|
|
|
return { |
|
|
|
|
|
|
|
'error': true, |
|
|
|
|
|
|
|
'message': 'invalid param \'lon\': must be >-180 and <180' |
|
|
|
/** |
|
|
|
|
|
|
|
* Parse and validate bbox parameter |
|
|
|
|
|
|
|
* bbox = bottom_left lon, bottom_left lat, top_right lon, top_right lat |
|
|
|
|
|
|
|
* bbox = left, bottom, right, top |
|
|
|
|
|
|
|
* bbox = min Longitude, min Latitude, max Longitude, max Latitude |
|
|
|
|
|
|
|
* |
|
|
|
|
|
|
|
* @param {object} clean |
|
|
|
|
|
|
|
* @param {string} param |
|
|
|
|
|
|
|
*/ |
|
|
|
|
|
|
|
function sanitize_bbox( clean, param ) { |
|
|
|
|
|
|
|
if( !param ) { |
|
|
|
|
|
|
|
return; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var bbox = []; |
|
|
|
|
|
|
|
var bboxArr = param.split( ',' ); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if( Array.isArray( bboxArr ) && bboxArr.length === 4 ) { |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
bbox = bboxArr.filter( function( latlon, index ) { |
|
|
|
|
|
|
|
latlon = parseFloat( latlon, 10 ); |
|
|
|
|
|
|
|
return !(lat_lon_checks[(index % 2 === 0 ? 'lon' : 'lat')].is_invalid( latlon )); |
|
|
|
|
|
|
|
}); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if( bbox.length === 4 ) { |
|
|
|
|
|
|
|
clean.bbox = { |
|
|
|
|
|
|
|
right: Math.max( bbox[0], bbox[2] ), |
|
|
|
|
|
|
|
top: Math.max( bbox[1], bbox[3] ), |
|
|
|
|
|
|
|
left: Math.min( bbox[0], bbox[2] ), |
|
|
|
|
|
|
|
bottom: Math.min( bbox[1], bbox[3] ) |
|
|
|
}; |
|
|
|
}; |
|
|
|
|
|
|
|
} else { |
|
|
|
|
|
|
|
throw new Error('invalid bbox'); |
|
|
|
} |
|
|
|
} |
|
|
|
clean.lon = lon; |
|
|
|
|
|
|
|
} else if (latlon_is_required) { |
|
|
|
|
|
|
|
return { |
|
|
|
|
|
|
|
'error': true, |
|
|
|
|
|
|
|
'message': 'missing param \'lon\': must be >-180 and <180' |
|
|
|
|
|
|
|
}; |
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
// zoom level
|
|
|
|
/** |
|
|
|
var zoom = parseInt( params.zoom, 10 ); |
|
|
|
* Validate lat,lon values |
|
|
|
if( !isNaN( zoom ) ){ |
|
|
|
* |
|
|
|
clean.zoom = Math.min( Math.max( zoom, 1 ), 18 ); // max
|
|
|
|
* @param {string} coord lat|lon |
|
|
|
}
|
|
|
|
* @param {object} clean |
|
|
|
|
|
|
|
* @param {string} param |
|
|
|
// bbox
|
|
|
|
* @param {bool} latlon_is_required |
|
|
|
// bbox = bottom_left lat, bottom_left lon, top_right lat, top_right lon
|
|
|
|
*/ |
|
|
|
// bbox = left,bottom,right,top
|
|
|
|
function sanitize_coord( coord, clean, param, latlon_is_required ) { |
|
|
|
// bbox = min Longitude , min Latitude , max Longitude , max Latitude
|
|
|
|
var value = parseFloat( param, 10 ); |
|
|
|
if (params.bbox) { |
|
|
|
if ( !isNaN( value ) ) { |
|
|
|
var bbox = []; |
|
|
|
if( lat_lon_checks[coord].is_invalid( value ) ){ |
|
|
|
var bboxArr = params.bbox.split(','); |
|
|
|
throw new Error( 'invalid ' + lat_lon_checks[coord].error_msg ); |
|
|
|
if( Array.isArray(bboxArr) && bboxArr.length === 4 ) { |
|
|
|
|
|
|
|
bbox = bboxArr.filter(function(latlon, index) { |
|
|
|
|
|
|
|
latlon = parseFloat(latlon, 10); |
|
|
|
|
|
|
|
return !(index % 2 === 0 ? is_invalid_lat(latlon) : is_invalid_lon(latlon));
|
|
|
|
|
|
|
|
}); |
|
|
|
|
|
|
|
if (bbox.length === 4) { |
|
|
|
|
|
|
|
clean.bbox = { |
|
|
|
|
|
|
|
top : Math.max(bbox[0], bbox[2]), |
|
|
|
|
|
|
|
right : Math.max(bbox[1], bbox[3]), |
|
|
|
|
|
|
|
bottom: Math.min(bbox[0], bbox[2]), |
|
|
|
|
|
|
|
left : Math.min(bbox[1], bbox[3]) |
|
|
|
|
|
|
|
}; |
|
|
|
|
|
|
|
} else { |
|
|
|
|
|
|
|
return { |
|
|
|
|
|
|
|
'error': true, |
|
|
|
|
|
|
|
'message': 'invalid bbox' |
|
|
|
|
|
|
|
}; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
}
|
|
|
|
clean[coord] = value; |
|
|
|
|
|
|
|
} |
|
|
|
req.clean = clean; |
|
|
|
else if (latlon_is_required) { |
|
|
|
|
|
|
|
throw new Error('missing ' + lat_lon_checks[coord].error_msg); |
|
|
|
return { 'error': false }; |
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
function sanitize_zoom_level( clean, param ) { |
|
|
|
|
|
|
|
var zoom = parseInt( param, 10 ); |
|
|
|
|
|
|
|
if( !isNaN( zoom ) ){ |
|
|
|
|
|
|
|
clean.zoom = Math.min( Math.max( zoom, 1 ), 18 ); // max
|
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
// export function
|
|
|
|
var lat_lon_checks = { |
|
|
|
module.exports = sanitize; |
|
|
|
lat: { |
|
|
|
|
|
|
|
is_invalid: function is_invalid_lat(lat) { |
|
|
|
|
|
|
|
return isNaN( lat ) || lat < -90 || lat > 90; |
|
|
|
|
|
|
|
}, |
|
|
|
|
|
|
|
error_msg: 'param \'lat\': must be >-90 and <90' |
|
|
|
|
|
|
|
}, |
|
|
|
|
|
|
|
lon: { |
|
|
|
|
|
|
|
is_invalid: function is_invalid_lon(lon) { |
|
|
|
|
|
|
|
return isNaN(lon) || lon < -180 || lon > 180; |
|
|
|
|
|
|
|
}, |
|
|
|
|
|
|
|
error_msg: 'param \'lon\': must be >-180 and <180' |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
}; |
|
|
|
|
|
|
|
|
|
|
|