Browse Source

add address alias and openaddresses type. change default layers to 'poi,admin'. add comments. update tests

pull/61/head
Peter Johnson 10 years ago
parent
commit
293465b90c
  1. 3
      query/indeces.js
  2. 24
      sanitiser/_layers.js
  3. 2
      test/unit/query/indeces.js
  4. 20
      test/unit/sanitiser/suggest.js

3
query/indeces.js

@ -8,5 +8,6 @@ module.exports = [
'admin0', 'admin0',
'admin1', 'admin1',
'admin2', 'admin2',
'neighborhood' 'neighborhood',
'openaddresses'
]; ];

24
sanitiser/_layers.js

@ -11,15 +11,22 @@ function sanitize( req ){
params = {}; params = {};
} }
// which layers to query // default case (no layers specified in GET params)
if('string' === typeof params.layers && params.layers.length){ if('string' !== typeof params.layers || !params.layers.length){
// @note: 'address' alias disabled by default feature testing completed
params.layers = 'poi,admin'; // default layers
}
var alias_layers = ['poi', 'admin']; // decide which layers can be queried
var alias_layers = ['poi', 'admin', 'address'];
var alias_indeces = indeces.concat(alias_layers); var alias_indeces = indeces.concat(alias_layers);
// parse GET params
var layers = params.layers.split(',').map( function( layer ){ var layers = params.layers.split(',').map( function( layer ){
return layer.toLowerCase(); // lowercase inputs return layer.toLowerCase(); // lowercase inputs
}); });
// validate layer names
for( var x=0; x<layers.length; x++ ){ for( var x=0; x<layers.length; x++ ){
if( -1 === alias_indeces.indexOf( layers[x] ) ){ if( -1 === alias_indeces.indexOf( layers[x] ) ){
return { return {
@ -28,6 +35,8 @@ function sanitize( req ){
}; };
} }
} }
// expand aliases
var expand_aliases = function(alias, layers, layer_indeces) { var expand_aliases = function(alias, layers, layer_indeces) {
var alias_index = layers.indexOf(alias); var alias_index = layers.indexOf(alias);
if (alias_index !== -1 ) { if (alias_index !== -1 ) {
@ -39,18 +48,15 @@ function sanitize( req ){
layers = expand_aliases('poi', layers, ['geoname','osmnode','osmway']); layers = expand_aliases('poi', layers, ['geoname','osmnode','osmway']);
layers = expand_aliases('admin', layers, ['admin0','admin1','admin2','neighborhood']); layers = expand_aliases('admin', layers, ['admin0','admin1','admin2','neighborhood']);
layers = expand_aliases('address', layers, ['openaddresses']);
// de-dup // de-dupe
layers = layers.filter(function(item, pos) { layers = layers.filter(function(item, pos) {
return layers.indexOf(item) === pos; return layers.indexOf(item) === pos;
}); });
// pass validated params to next middleware
clean.layers = layers; clean.layers = layers;
}
else {
clean.layers = indeces; // default (all layers)
}
req.clean = clean; req.clean = clean;
return { 'error': false }; return { 'error': false };

2
test/unit/query/indeces.js

@ -6,7 +6,7 @@ module.exports.tests = {};
module.exports.tests.interface = function(test, common) { module.exports.tests.interface = function(test, common) {
test('valid interface', function(t) { test('valid interface', function(t) {
t.true(Array.isArray(indeces), 'valid array'); t.true(Array.isArray(indeces), 'valid array');
t.equal(indeces.length, 7, 'valid array'); t.equal(indeces.length, 8, 'valid array');
t.end(); t.end();
}); });
}; };

20
test/unit/sanitiser/suggest.js

@ -160,8 +160,9 @@ module.exports.tests.sanitize_layers = function(test, common) {
}); });
test('invalid layer', function(t) { test('invalid layer', function(t) {
sanitize({ layers: 'test_layer', input: 'test', lat: 0, lon: 0 }, function( err, clean ){ sanitize({ layers: 'test_layer', input: 'test', lat: 0, lon: 0 }, function( err, clean ){
var msg = 'invalid param \'layer\': must be one or more of geoname,osmnode,osmway,admin0,admin1,admin2,neighborhood,poi,admin'; var msg = 'invalid param \'layer\': must be one or more of ';
t.equal(err, msg, 'invalid layer requested'); t.true(err.match(msg), 'invalid layer requested');
t.true(err.length > msg.length, 'invalid error message');
t.end(); t.end();
}); });
}); });
@ -179,6 +180,13 @@ module.exports.tests.sanitize_layers = function(test, common) {
t.end(); t.end();
}); });
}); });
test('address (alias) layer', function(t) {
var address_layers = ['openaddresses'];
sanitize({ layers: 'address', input: 'test', lat: 0, lon: 0 }, function( err, clean ){
t.deepEqual(clean.layers, address_layers, 'address layers set');
t.end();
});
});
test('poi alias layer plus regular layers', function(t) { test('poi alias layer plus regular layers', function(t) {
var poi_layers = ['geoname','osmnode','osmway']; var poi_layers = ['geoname','osmnode','osmway'];
var reg_layers = ['admin0', 'admin1']; var reg_layers = ['admin0', 'admin1'];
@ -195,6 +203,14 @@ module.exports.tests.sanitize_layers = function(test, common) {
t.end(); t.end();
}); });
}); });
test('address alias layer plus regular layers', function(t) {
var address_layers = ['openaddresses'];
var reg_layers = ['geoname', 'osmway'];
sanitize({ layers: 'address,geoname,osmway', input: 'test', lat: 0, lon: 0 }, function( err, clean ){
t.deepEqual(clean.layers, reg_layers.concat(address_layers), 'address + regular layers set');
t.end();
});
});
test('alias layer plus regular layers (no duplicates)', function(t) { test('alias layer plus regular layers (no duplicates)', function(t) {
var poi_layers = ['geoname','osmnode','osmway']; var poi_layers = ['geoname','osmnode','osmway'];
sanitize({ layers: 'poi,geoname,osmnode', input: 'test', lat: 0, lon: 0 }, function( err, clean ){ sanitize({ layers: 'poi,geoname,osmnode', input: 'test', lat: 0, lon: 0 }, function( err, clean ){

Loading…
Cancel
Save