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;
 |