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