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.
		
		
		
		
		
			
		
			
				
					
					
						
							139 lines
						
					
					
						
							3.3 KiB
						
					
					
				
			
		
		
	
	
							139 lines
						
					
					
						
							3.3 KiB
						
					
					
				'use strict';
 | 
						|
 | 
						|
const SchemaTypeOptions = require('./SchemaTypeOptions');
 | 
						|
 | 
						|
/**
 | 
						|
 * The options defined on a string schematype.
 | 
						|
 *
 | 
						|
 * ####Example:
 | 
						|
 *
 | 
						|
 *     const schema = new Schema({ name: String });
 | 
						|
 *     schema.path('name').options; // SchemaStringOptions instance
 | 
						|
 *
 | 
						|
 * @api public
 | 
						|
 * @inherits SchemaTypeOptions
 | 
						|
 * @constructor SchemaStringOptions
 | 
						|
 */
 | 
						|
 | 
						|
class SchemaStringOptions extends SchemaTypeOptions {}
 | 
						|
 | 
						|
const opts = require('./propertyOptions');
 | 
						|
 | 
						|
/**
 | 
						|
 * Array of allowed values for this path
 | 
						|
 *
 | 
						|
 * @api public
 | 
						|
 * @property enum
 | 
						|
 * @memberOf SchemaStringOptions
 | 
						|
 * @type Array
 | 
						|
 * @instance
 | 
						|
 */
 | 
						|
 | 
						|
Object.defineProperty(SchemaStringOptions.prototype, 'enum', opts);
 | 
						|
 | 
						|
/**
 | 
						|
 * Attach a validator that succeeds if the data string matches the given regular
 | 
						|
 * expression, and fails otherwise.
 | 
						|
 *
 | 
						|
 * @api public
 | 
						|
 * @property match
 | 
						|
 * @memberOf SchemaStringOptions
 | 
						|
 * @type RegExp
 | 
						|
 * @instance
 | 
						|
 */
 | 
						|
 | 
						|
Object.defineProperty(SchemaStringOptions.prototype, 'match', opts);
 | 
						|
 | 
						|
/**
 | 
						|
 * If truthy, Mongoose will add a custom setter that lowercases this string
 | 
						|
 * using JavaScript's built-in `String#toLowerCase()`.
 | 
						|
 *
 | 
						|
 * @api public
 | 
						|
 * @property lowercase
 | 
						|
 * @memberOf SchemaStringOptions
 | 
						|
 * @type Boolean
 | 
						|
 * @instance
 | 
						|
 */
 | 
						|
 | 
						|
Object.defineProperty(SchemaStringOptions.prototype, 'lowercase', opts);
 | 
						|
 | 
						|
/**
 | 
						|
 * If truthy, Mongoose will add a custom setter that removes leading and trailing
 | 
						|
 * whitespace using JavaScript's built-in `String#trim()`.
 | 
						|
 *
 | 
						|
 * @api public
 | 
						|
 * @property trim
 | 
						|
 * @memberOf SchemaStringOptions
 | 
						|
 * @type Boolean
 | 
						|
 * @instance
 | 
						|
 */
 | 
						|
 | 
						|
Object.defineProperty(SchemaStringOptions.prototype, 'trim', opts);
 | 
						|
 | 
						|
/**
 | 
						|
 * If truthy, Mongoose will add a custom setter that uppercases this string
 | 
						|
 * using JavaScript's built-in `String#toUpperCase()`.
 | 
						|
 *
 | 
						|
 * @api public
 | 
						|
 * @property uppercase
 | 
						|
 * @memberOf SchemaStringOptions
 | 
						|
 * @type Boolean
 | 
						|
 * @instance
 | 
						|
 */
 | 
						|
 | 
						|
Object.defineProperty(SchemaStringOptions.prototype, 'uppercase', opts);
 | 
						|
 | 
						|
/**
 | 
						|
 * If set, Mongoose will add a custom validator that ensures the given
 | 
						|
 * string's `length` is at least the given number.
 | 
						|
 *
 | 
						|
 * Mongoose supports two different spellings for this option: `minLength` and `minlength`.
 | 
						|
 * `minLength` is the recommended way to specify this option, but Mongoose also supports
 | 
						|
 * `minlength` (lowercase "l").
 | 
						|
 *
 | 
						|
 * @api public
 | 
						|
 * @property minLength
 | 
						|
 * @memberOf SchemaStringOptions
 | 
						|
 * @type Number
 | 
						|
 * @instance
 | 
						|
 */
 | 
						|
 | 
						|
Object.defineProperty(SchemaStringOptions.prototype, 'minLength', opts);
 | 
						|
Object.defineProperty(SchemaStringOptions.prototype, 'minlength', opts);
 | 
						|
 | 
						|
/**
 | 
						|
 * If set, Mongoose will add a custom validator that ensures the given
 | 
						|
 * string's `length` is at most the given number.
 | 
						|
 *
 | 
						|
 * Mongoose supports two different spellings for this option: `maxLength` and `maxlength`.
 | 
						|
 * `maxLength` is the recommended way to specify this option, but Mongoose also supports
 | 
						|
 * `maxlength` (lowercase "l").
 | 
						|
 *
 | 
						|
 * @api public
 | 
						|
 * @property maxLength
 | 
						|
 * @memberOf SchemaStringOptions
 | 
						|
 * @type Number
 | 
						|
 * @instance
 | 
						|
 */
 | 
						|
 | 
						|
Object.defineProperty(SchemaStringOptions.prototype, 'maxLength', opts);
 | 
						|
Object.defineProperty(SchemaStringOptions.prototype, 'maxlength', opts);
 | 
						|
 | 
						|
/**
 | 
						|
 * Sets default [populate options](/docs/populate.html#query-conditions).
 | 
						|
 *
 | 
						|
 * @api public
 | 
						|
 * @property populate
 | 
						|
 * @memberOf SchemaStringOptions
 | 
						|
 * @type Object
 | 
						|
 * @instance
 | 
						|
 */
 | 
						|
 | 
						|
Object.defineProperty(SchemaStringOptions.prototype, 'populate', opts);
 | 
						|
 | 
						|
/*!
 | 
						|
 * ignore
 | 
						|
 */
 | 
						|
 | 
						|
module.exports = SchemaStringOptions;
 |