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.
		
		
		
		
		
			
		
			
				
					
					
						
							101 lines
						
					
					
						
							2.6 KiB
						
					
					
				
			
		
		
	
	
							101 lines
						
					
					
						
							2.6 KiB
						
					
					
				/*!
 | 
						|
 * Module dependencies.
 | 
						|
 */
 | 
						|
 | 
						|
'use strict';
 | 
						|
 | 
						|
const NodeJSDocument = require('./document');
 | 
						|
const EventEmitter = require('events').EventEmitter;
 | 
						|
const MongooseError = require('./error/index');
 | 
						|
const Schema = require('./schema');
 | 
						|
const ObjectId = require('./types/objectid');
 | 
						|
const ValidationError = MongooseError.ValidationError;
 | 
						|
const applyHooks = require('./helpers/model/applyHooks');
 | 
						|
const isObject = require('./helpers/isObject');
 | 
						|
 | 
						|
/**
 | 
						|
 * Document constructor.
 | 
						|
 *
 | 
						|
 * @param {Object} obj the values to set
 | 
						|
 * @param {Object} [fields] optional object containing the fields which were selected in the query returning this document and any populated paths data
 | 
						|
 * @param {Boolean} [skipId] bool, should we auto create an ObjectId _id
 | 
						|
 * @inherits NodeJS EventEmitter http://nodejs.org/api/events.html#events_class_events_eventemitter
 | 
						|
 * @event `init`: Emitted on a document after it has was retrieved from the db and fully hydrated by Mongoose.
 | 
						|
 * @event `save`: Emitted when the document is successfully saved
 | 
						|
 * @api private
 | 
						|
 */
 | 
						|
 | 
						|
function Document(obj, schema, fields, skipId, skipInit) {
 | 
						|
  if (!(this instanceof Document)) {
 | 
						|
    return new Document(obj, schema, fields, skipId, skipInit);
 | 
						|
  }
 | 
						|
 | 
						|
  if (isObject(schema) && !schema.instanceOfSchema) {
 | 
						|
    schema = new Schema(schema);
 | 
						|
  }
 | 
						|
 | 
						|
  // When creating EmbeddedDocument, it already has the schema and he doesn't need the _id
 | 
						|
  schema = this.schema || schema;
 | 
						|
 | 
						|
  // Generate ObjectId if it is missing, but it requires a scheme
 | 
						|
  if (!this.schema && schema.options._id) {
 | 
						|
    obj = obj || {};
 | 
						|
 | 
						|
    if (obj._id === undefined) {
 | 
						|
      obj._id = new ObjectId();
 | 
						|
    }
 | 
						|
  }
 | 
						|
 | 
						|
  if (!schema) {
 | 
						|
    throw new MongooseError.MissingSchemaError();
 | 
						|
  }
 | 
						|
 | 
						|
  this.$__setSchema(schema);
 | 
						|
 | 
						|
  NodeJSDocument.call(this, obj, fields, skipId, skipInit);
 | 
						|
 | 
						|
  applyHooks(this, schema, { decorateDoc: true });
 | 
						|
 | 
						|
  // apply methods
 | 
						|
  for (const m in schema.methods) {
 | 
						|
    this[m] = schema.methods[m];
 | 
						|
  }
 | 
						|
  // apply statics
 | 
						|
  for (const s in schema.statics) {
 | 
						|
    this[s] = schema.statics[s];
 | 
						|
  }
 | 
						|
}
 | 
						|
 | 
						|
/*!
 | 
						|
 * Inherit from the NodeJS document
 | 
						|
 */
 | 
						|
 | 
						|
Document.prototype = Object.create(NodeJSDocument.prototype);
 | 
						|
Document.prototype.constructor = Document;
 | 
						|
 | 
						|
/*!
 | 
						|
 * ignore
 | 
						|
 */
 | 
						|
 | 
						|
Document.events = new EventEmitter();
 | 
						|
 | 
						|
/*!
 | 
						|
 * Browser doc exposes the event emitter API
 | 
						|
 */
 | 
						|
 | 
						|
Document.$emitter = new EventEmitter();
 | 
						|
 | 
						|
['on', 'once', 'emit', 'listeners', 'removeListener', 'setMaxListeners',
 | 
						|
  'removeAllListeners', 'addListener'].forEach(function(emitterFn) {
 | 
						|
  Document[emitterFn] = function() {
 | 
						|
    return Document.$emitter[emitterFn].apply(Document.$emitter, arguments);
 | 
						|
  };
 | 
						|
});
 | 
						|
 | 
						|
/*!
 | 
						|
 * Module exports.
 | 
						|
 */
 | 
						|
 | 
						|
Document.ValidationError = ValidationError;
 | 
						|
module.exports = exports = Document;
 |