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
			| 
								 
											3 years ago
										 
									 | 
							
								'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);
							 | 
						||
| 
								 | 
							
								};
							 |