Módulo: Mongoid::Factory
Overview
Instantiates los documentos que proceden de la base de datos.
Definido bajo Namespace
Clases: Instanciador
Resumen del método de instancia colapsar
-
#build(klass, attributes = nil) ⇒ Document
Compila un nuevo
Documentutilizando los atributos suministrados. -
#execute_build(klass, atributos = nil, opciones = {}) ⇒ Documento
privado
Ejecute compilar.
-
#ejecutar_desde_db(clase, atributos = nulo, criterios = nulo, campos_seleccionados = nulo, ejecutar_devoluciones_de_llamadas: Threaded.execute_callbacks?) ⇒ Documento
privado
Ejecutar desde_db.
-
#from_db(klass, attributes = nil, criteria = nil, selected_fields = nil) ⇒ Document
Construye un nuevo
Documenta partir de los atributos proporcionados cargados desde la base de datos.
Detalles del método de instancia
#build(klass, attributes = nil) ⇒ Document
Compila un nuevo Document utilizando los atributos suministrados.
Este método ya sea instantia klass o un descendiente de klass si los atributos incluyen la clave discriminadora de klass.
Si los atributos contienen la clave del discriminador (que por defecto es _type) y el valor del discriminador no corresponde a un descendiente de klass, entonces este método creará una instancia de klass.
154 155 156 |
# Archivo 'lib/mongoid/factory.rb', línea 154 def compilar(klass, atributos = nulo) execute_build(klass, atributos) end |
#execute_build(klass, attributes = nil, options = {}) ⇒ Documento
Este método forma parte de una API privada. Debe evitarlo si es posible, ya que podría eliminarse o modificarse en el futuro.
Un 2 error de Ruby.x impide que los hash de opciones se utilicen como argumentos de palabras clave. Una vez que se elimine el soporte para Ruby.x,2 podremos reimplementar los hash de opciones como argumentos de palabras clave. Consulte bugs.ruby-lang.org/issues/15753
Ejecute compilar.
175 176 177 178 179 180 181 182 183 184 |
# Archivo 'lib/mongoid/factory.rb', línea 175 def execute_build(klass, atributos = nulo, = {}) atributos ||= {} dvalue = atributos[klass.discriminador_clave] || atributos[klass.discriminador_clave.to_sym] tipo = klass.get_discriminator_mapping(dvalue) si tipo tipo.construct_document(atributos, ) else klass.construct_document(atributos, ) end end |
#execute_from_db(klass, attributes = nil, criteria = nil, selected_fields = nil, execute_callbacks: Threaded.execute_callbacks?) ⇒ documento
Este método forma parte de una API privada. Debe evitarlo si es posible, ya que podría eliminarse o modificarse en el futuro.
Ejecutar desde_db.
234 235 236 237 238 239 |
# Archivo 'lib/mongoid/factory.rb', línea 234 def execute_from_db(klass, atributos = nulo, criterios = nulo, campos seleccionados = nulo, execute_callbacks: Compacto.¿ejecutar_callbacks?) Instanciador.Nuevo(klass, atributos, criterios, campos seleccionados) .instancia(execute_callbacks: execute_callbacks) end |
#from_db(klass, attributes = nil, criteria = nil, selected_fields = nil) ⇒ Document
Construye un nuevo Document a partir de los atributos proporcionados cargados desde la base de datos.
Si los atributos contienen la clave discriminatoria (que por defecto es _type) y el valor discriminatorio no corresponde a un descendiente de klass, entonces este método genera un error de UnknownModel.
Si se proporciona un objeto de criterios, se utiliza de dos maneras:
-
Si el criterio tiene una lista de campos especificados a través de #only, solo esos campos se llenan en el documento devuelto.
-
Si el criterio tiene una asociación de referencia (es decir, este documento se está instanciando como una asociación de otro documento), el otro documento también se completa en la asociación inversa del documento devuelto, si existe una.
212 213 214 |
# Archivo 'lib/mongoid/factory.rb', línea 212 def desde_db(klass, atributos = nulo, criterios = nulo, campos seleccionados = nulo) execute_from_db(klass, atributos, criterios, campos seleccionados) end |