♬♪♬..I'm too sexy... ♫♪ catwalk... <br />Como modelar el dominioefectivamente<br />
¿Cual es el problema que resuelve?<br />
Complex/Long SQL<br />QLUserInfo     custom:/userinfosSQLNamedQuery   userinfos FREEFORM "  SELECT     `phpbb`.`pbb_users`...
aspectosesenciales a tomar en cuenta<br />
Data Source Architectural Patterns:<br />Active Record. Un objeto que envuelve un registro de una tabla o una vista en una...
Rails 3 - Modelos<br />El generador de código de RoR<br />rails generate model item thing:stringdone:booleanlist:reference...
App. Conjunto de objetos que interactuan<br />Objeto. Una implementación de uno o más roles<br />Role. Un conjunto de resp...
Ma! Mis controladores son gordos y mis modelos flacos<br />Definir los roles y respetar el contrato<br />Asignar correctam...
Las tresLeyes de las interfaces:<br />La implementación de una interfaz debe de hacer lo que sus métodos dice que hace<br ...
El ciclo de vida de los modelos<br />Durante el funcionamiento normal de una appRails, los modelos se pueden crear, actual...
Asociaciones<br />Definen una colaboración entre Modelos<br />Establecen el orden de la colaboración: belongs_to, has_one,...
Migraciones<br />Son unamaneraconvenienteparamodificar la BD de maneraestructuradayorganizada.<br />Active Record proporci...
Nombres con significado descriptivo, que revelen la intención de forma distinguible y en contexto<br />Clases y objetos de...
¿PorquéutilizarValidaciones?<br />Es un DSL que se utilizaparagarantizarquesólo los datosválidos se guarda en su base de d...
Validation Helpers & Common Validation Options<br />Se ofrecen helpers predefinidosquepuedes ser usadosdirectamente en las...
Callbacks – Llamadas de regreso<br />Callbacksson métodos que son llamados en ciertos momentos del ciclo de vida de un obj...
Observadores<br />Son parecidos a los callbacks pero con la diferencia que son llamadas a código que no es de la responsab...
Interface de Consultas<br />Active Record provee un interfaz ORM con métodos  finder que permiten pasar argumentos para re...
Interface de Consultas<br />Active Record provee un interfaz ORM con métodos  finder que permiten pasar argumentos para re...
Consultabásica<br />Model.find(options):<br />Convertir las opciones suministradas a su equivalente como consulta SQL.<br ...
ConsultasFrecuentes<br />Model.find (primary_key)<br />Model.firstModel.last<br />Model.find(m,n)<br />Finders dinámicos:<...
Condiciones<br />Client.where(["orders_count = ?", params[:orders]])<br />Client.where(["created_at IN (?)",  (params[:sta...
OrdenyGrupos<br />Client.order("created_at")<br />Client.order("created_at DESC")<br />Client.order("orders_count ASC, cre...
FindersDinamicos<br />User.find_by_email("user@ex.mx")<br />Cada atributo definido en la tabla del modelo puede ser usado ...
AREL<br />Arel es un álgebra relacional para Ruby:<br />Simplifica la generación de consultas SQL<br />Se adapta a los div...
Rails3: ActiveRelation – ActiveModel<br />ActiveRelation=== AREL<br />ActiveModelextraefuncionalidad de ActiveRecordparaqu...
Scopes (Alcances)<br />scope :recent, order("posts.published_at DESC")<br />scope :published, lambda {where("posts.publish...
♬♪♬..I'm too sexy... ♫♪ catwalk... Como modelar el dominio efectivamente
Upcoming SlideShare
Loading in …5
×

♬♪♬..I'm too sexy... ♫♪ catwalk... Como modelar el dominio efectivamente

1,241 views
1,040 views

Published on

La arquitectura de MVC ofrece al M - Models (no de Manuel) como el primer componente fundamental, pero muchas veces en Rails nos olvidamos de los Modelos y hacemos que los Controllers sean gordos y pesados que tengan de hecho toda la lógica de negocios y los modelos son meramente un mapa con las tablas en la base de datos. Ese estilo y enfoque es EQUIVOCADO, ERRONEO y NO SUSTENTABLE, por lo que en esta presentación se mostraran técnicas basadas en DDD (Domain-driven design) y principios como SOLID y conacimiento (connascence) para tener un modelaje efectivo y apropiado de la realidad lo que permita tener sistemas mantenibles con intefaces claramente definidas y responsabilidades, colaboraciones y roles de objetos que den verdadero valor a nuestros clientes. Se revisará como se implementa esto en la nueva versión de Rails3 por medio de Active Model y aplicación de patrones de diseño y mejores prácticas de Ruby y de RoR

Published in: Technology
0 Comments
1 Like
Statistics
Notes
  • Be the first to comment

No Downloads
Views
Total views
1,241
On SlideShare
0
From Embeds
0
Number of Embeds
7
Actions
Shares
0
Downloads
0
Comments
0
Likes
1
Embeds 0
No embeds

No notes for slide

♬♪♬..I'm too sexy... ♫♪ catwalk... Como modelar el dominio efectivamente

  1. 1. ♬♪♬..I'm too sexy... ♫♪ catwalk... <br />Como modelar el dominioefectivamente<br />
  2. 2. ¿Cual es el problema que resuelve?<br />
  3. 3.
  4. 4.
  5. 5.
  6. 6. Complex/Long SQL<br />QLUserInfo     custom:/userinfosSQLNamedQuery   userinfos FREEFORM "  SELECT     `phpbb`.`pbb_users`.`username` AS 'username',     CONCAT('{MD5}',`mabase`.`ltq_services_accounts`.`lsa_password`) AS 'password',     `ftp`.`ftp_profiles`.`fpf_uid` AS 'uid',     `ftp`.`ftp_profiles`.`fpf_gid` AS 'gid',     `ftp`.`ftp_profiles`.`fpf_home` AS 'homedir',     '/sbin/nologin' AS 'shell'   FROM     `phpbb`.`pbb_users`     INNER JOIN `mabase`.`ltq_users`       ON `phpbb`.`pbb_users`.`user_id`         =`mabase`.`ltq_users`.`lus_forum_id`     INNER JOIN `mabase`.`ltq_services_accounts`       ON `mabase`.`ltq_users`.`lus_id`         =`mabase`.`ltq_services_accounts`.`lsa_users_id`     INNER JOIN `ftp`.`ftp_profiles`       ON `mabase`.`ltq_services_accounts`.`lsa_ftp_profiles_id`         =`ftp`.`ftp_profiles`.`fpf_id`   WHERE     `phpbb`.`pbb_users`.`username`='%U'     AND       `mabase`.`ltq_services_accounts`.`lsa_ftp_activ`='1'     AND       `mabase`.`ltq_users`.`lus_useractiv`='1'     AND       `phpbb`.`pbb_users`.`user_active`='1'   LIMIT 1"<br />
  7. 7. aspectosesenciales a tomar en cuenta<br />
  8. 8. Data Source Architectural Patterns:<br />Active Record. Un objeto que envuelve un registro de una tabla o una vista en una BD, encapsulando su acceso y añadiendo lógica del dominio a esos datos<br />Table Data Gateway, Row Data Geteway, Data Mapper<br />
  9. 9. Rails 3 - Modelos<br />El generador de código de RoR<br />rails generate model item thing:stringdone:booleanlist:references -trspec<br /><ul><li>¿Qué se define en el modelo?:</li></ul>Susasociaciones con otrosmodelos<br />Susvalidacionesy callbacks<br />Susalcances (scopes) e interface de consultas(queries)<br />Los métodos de suresponsabilidad<br />
  10. 10. App. Conjunto de objetos que interactuan<br />Objeto. Una implementación de uno o más roles<br />Role. Un conjunto de responsabilidades relacionadas<br />Responsabilidad. Obligación de hacer una tarea o conocer una información<br />Colaboración. Una interacción de objetos, roles o ambos<br />Contrato. Un acuerdo que indica los términos de una colaboración<br />
  11. 11.
  12. 12. Ma! Mis controladores son gordos y mis modelos flacos<br />Definir los roles y respetar el contrato<br />Asignar correctamente la responsabilidad<br />Establecer las colaboraciones<br />El controlador es un orquestador y el servicio pesado lo deben de hacer los modelos y en algunos casos para ayudar a las vistas los helpers<br />La lógica del dominio debe de ser modelada en los modelos evitando hacerla en los controladores<br />
  13. 13.
  14. 14. Las tresLeyes de las interfaces:<br />La implementación de una interfaz debe de hacer lo que sus métodos dice que hace<br />La implementación de una interfaz no debe de producir daño. Es decir, no debe de interferir con sus colaboraciones y debe de usar recursos de forma eficiente<br />Si la implementación de una interfaz no es capaz de realizar sus responsabilidades, debe de notificarlo a quien la llamó.<br />
  15. 15. El ciclo de vida de los modelos<br />Durante el funcionamiento normal de una appRails, los modelos se pueden crear, actualizar y destruidos. Active Record brinda ganchos (hooks) de modo que se pueda controlar la app y datos.<br />Las Validaciones permiten garantizar que sólo los datos válidos se almacena en la BD. Callbacksy observadores permiten activar la lógica antes o después de una alteración del estado de un modelo.<br />
  16. 16.
  17. 17. Asociaciones<br />Definen una colaboración entre Modelos<br />Establecen el orden de la colaboración: belongs_to, has_one, has_many, has_many :through, has_one :through, has_and_belongs_to_many<br />Pueden ser polimorficas en las que un modelo puede tener con una sola asociación colaboración con más de un modelo. El modelo polimorfico debe de tener dos atributos: uno para el id del modelo asociado y otro para su tipo<br />Las asociaciones también pueden especificar callbacks y extensiones<br />
  18. 18.
  19. 19. Migraciones<br />Son unamaneraconvenienteparamodificar la BD de maneraestructuradayorganizada.<br />Active Record proporcionamétodosquerealizantareas de definición de datoscomunes en la BD de forma: CREATE_TABLE, change_table, drop_table, add_column, change_column, rename_column, remove_column, add_indexyremove_index<br />
  20. 20. Nombres con significado descriptivo, que revelen la intención de forma distinguible y en contexto<br />Clases y objetos deben de ser sustantivos o frases sustantivas<br />Métodos deben de ser verbos o frases verbales<br />Los métodos deben de ser cortos y deben de tener una responsabilidad y sólo una.<br />Los métodos deben de hacer algo (commands) ó dar respuestas (query) pero no ambas cosas<br />
  21. 21.
  22. 22. ¿PorquéutilizarValidaciones?<br />Es un DSL que se utilizaparagarantizarquesólo los datosválidos se guarda en su base de datos.<br />Se activancuando un objeto se vaya a insertaroactualizar en la BD.<br />Pero dado que hay muchasformas de cambiar el estado de un objeto, no todosdisparanlasvalidacionespor lo que se debe de tenercuidado<br />
  23. 23. Validation Helpers & Common Validation Options<br />Se ofrecen helpers predefinidosquepuedes ser usadosdirectamente en lasdefiniciones de clases.<br />Estos helper ofrecenreglas de validaciónque son frecuentementerequeridas<br />Adicionalmente, existenopcionescomunes de validación como: allow_nil, allow_blank, message, on<br />Pueden ser aplicadas de forma condicional<br />
  24. 24.
  25. 25. Callbacks – Llamadas de regreso<br />Callbacksson métodos que son llamados en ciertos momentos del ciclo de vida de un objeto. Con los callbacks es posible escribir código que se ejecutará cada vez que un objeto de Active Record es creado, salvado, actualizado, eliminado, validado, o cargado desde la base de datos.<br />En orden de usarse los callbacks se deben de registrar usando un DSL estilo macro con llamada a un método, es una mejor práctica que dicho método sea privado o protegido<br />Adicionalmente los callbackspueden ser relacionales y condicionales<br />
  26. 26. Observadores<br />Son parecidos a los callbacks pero con la diferencia que son llamadas a código que no es de la responsabilidad directa del modelo.<br />Los observadores deben de ser generados y registrados en el config/environment.rb<br />Se puedendeclarar de forma explicitacuando un observadorobserva a más de un odelo<br />
  27. 27.
  28. 28. Interface de Consultas<br />Active Record provee un interfaz ORM con métodos finder que permiten pasar argumentos para realizar queries en la base de datos sin necesidad de escribir SQL<br />Estos finders son: where, select, group, order, limit, offset, joins, includes, lock, readonly, from. Todosestosmetodos son instancias de ActiveRecord::Relation<br />
  29. 29. Interface de Consultas<br />Active Record provee un interfaz ORM con métodos finder que permiten pasar argumentos para realizar queries en la base de datos sin necesidad de escribir SQL<br />Estos finders son: where, select, group, order, limit, offset, joins, includes, lock, readonly, from. Todosestosmetodos son instancias de ActiveRecord::Relation<br />
  30. 30. Consultabásica<br />Model.find(options):<br />Convertir las opciones suministradas a su equivalente como consulta SQL.<br />Disparar la consulta SQL y recuperar los resultados correspondientes de la BD.<br />Cree una instancia del objeto Ruby equivalente al modelo correspondiente para cada fila resultante.<br />En su caso ejecutar after_findcallbaks<br />
  31. 31. ConsultasFrecuentes<br />Model.find (primary_key)<br />Model.firstModel.last<br />Model.find(m,n)<br />Finders dinámicos:<br />User.find_by_email(“user@ej.com”)<br />Item.find_by_done(true)<br />
  32. 32. Condiciones<br />Client.where(["orders_count = ?", params[:orders]])<br />Client.where(["created_at IN (?)", (params[:start_date].to_date)..(params[:end_date].to_date)])<br />Client.where({ :locked => true })<br />
  33. 33. OrdenyGrupos<br />Client.order("created_at")<br />Client.order("created_at DESC")<br />Client.order("orders_count ASC, created_at DESC")<br />Order.group("date(created_at)")<br />
  34. 34. FindersDinamicos<br />User.find_by_email("user@ex.mx")<br />Cada atributo definido en la tabla del modelo puede ser usado para generar un finderdinámico con la sintaxis find_by_<br />Existenmásfinders dinámicoscomo: find_all_by_, find_last_by_, find_or_create_by_<br />
  35. 35. AREL<br />Arel es un álgebra relacional para Ruby:<br />Simplifica la generación de consultas SQL<br />Se adapta a los diversos RDBMS diferentes. <br />Su objetivo es servir de frameworkde frameworks<br />Los métodos de Arel son concatenables por lo que se puede definir algo como esto:<br />Item.where(:user_id => 3).group("date(created_at)").order("created_at”)<br />
  36. 36. Rails3: ActiveRelation – ActiveModel<br />ActiveRelation=== AREL<br />ActiveModelextraefuncionalidad de ActiveRecordparaquetengauna sola responsabilidad<br />ActiveModelpresentauna API que los modelosdeben de cumplir en orden de tenercompatibilidad con los helpers de ActionPack<br />ActiveModelpermitequecualquiermodelopuedausar el API de activemodel<br />
  37. 37.
  38. 38. Scopes (Alcances)<br />scope :recent, order("posts.published_at DESC")<br />scope :published, lambda {where("posts.published_at IS NOT NULL AND posts.published_at <= ?", Time.zone.now)}<br />Paper.recent.published<br />

×