Browse Source

Simplify ids sanitizing logic

pull/273/head
Julian Simioni 10 years ago
parent
commit
3101aad399
  1. 32
      sanitiser/_ids.js

32
sanitiser/_ids.js

@ -23,34 +23,24 @@ function sanitize( raw, clean ){
return messages;
}
var rawIdsString;
if (check.unemptyString( raw.ids )) {
rawIdsString = raw.ids;
} else {
rawIdsString = '';
if (!check.unemptyString( raw.ids )) {
messages.errors.push( errorMessage( 'ids' ));
return messages;
}
// split string into array of values
var rawIds = rawIdsString.split(',');
var rawIds = raw.ids.split(',');
// deduplicate
rawIds = _.unique(rawIds);
// ensure all elements are valid non-empty strings
rawIds = rawIds.filter( function( uc ){
if( !check.unemptyString( uc ) ){
if (!rawIds.every(check.unemptyString)) {
messages.errors.push( errorMessage('ids') );
return false;
}
return true;
});
// init 'clean.ids'
var validIds = [];
}
// cycle through raw ids and set those which are valid
rawIds.forEach( function( rawId ){
var validIds = rawIds.map( function( rawId ){
var param_index = rawId.indexOf(ID_DELIM);
var type = rawId.substring(0, param_index );
var id = rawId.substring(param_index + 1);
@ -59,7 +49,6 @@ function sanitize( raw, clean ){
if(param_index === -1) {
messages.errors.push( 'invalid: must be of the format type:id for ex: \'geoname:4163334\'' );
}
// id text
else if( !check.unemptyString( id ) ){
messages.errors.push( errorMessage( rawId ) );
@ -74,15 +63,14 @@ function sanitize( raw, clean ){
}
// add valid id to 'clean.ids' array
else {
validIds.push({
return {
id: id,
type: type
});
};
}
});
if (validIds.length > 0) {
if (validIds.every(check.object)) {
clean.ids = validIds;
}

Loading…
Cancel
Save