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.
		
		
		
		
		
			
		
			
				
					
					
						
							38 lines
						
					
					
						
							995 B
						
					
					
				
			
		
		
	
	
							38 lines
						
					
					
						
							995 B
						
					
					
				'use strict';
 | 
						|
 | 
						|
const CastError = require('../error/cast');
 | 
						|
 | 
						|
/*!
 | 
						|
 * Given a value, cast it to a string, or throw a `CastError` if the value
 | 
						|
 * cannot be casted. `null` and `undefined` are considered valid.
 | 
						|
 *
 | 
						|
 * @param {Any} value
 | 
						|
 * @param {String} [path] optional the path to set on the CastError
 | 
						|
 * @return {string|null|undefined}
 | 
						|
 * @throws {CastError}
 | 
						|
 * @api private
 | 
						|
 */
 | 
						|
 | 
						|
module.exports = function castString(value, path) {
 | 
						|
  // If null or undefined
 | 
						|
  if (value == null) {
 | 
						|
    return value;
 | 
						|
  }
 | 
						|
 | 
						|
  // handle documents being passed
 | 
						|
  if (value._id && typeof value._id === 'string') {
 | 
						|
    return value._id;
 | 
						|
  }
 | 
						|
 | 
						|
  // Re: gh-647 and gh-3030, we're ok with casting using `toString()`
 | 
						|
  // **unless** its the default Object.toString, because "[object Object]"
 | 
						|
  // doesn't really qualify as useful data
 | 
						|
  if (value.toString &&
 | 
						|
      value.toString !== Object.prototype.toString &&
 | 
						|
      !Array.isArray(value)) {
 | 
						|
    return value.toString();
 | 
						|
  }
 | 
						|
 | 
						|
  throw new CastError('string', value, path);
 | 
						|
};
 |