Domain-Driven Design e Rails: Temendo um futuro próximo
Abril 1, 2008
Definitivamente, escrever software é uma arte!
E a preocupação com a qualidade dessa arte que criamos deveria ser uma constante em nós desenvolvedores!
Deveria….
Ao reler um antigo post do “Shoes”, baseado numa (ainda mais antiga) entrevista com Eric Evans na InfoQ, não pude deixar de lembrar de um post do Ronaldo de uns tempos atrás, no qual ele mencionava sua preocupação com relação a qualidade dos códigos atualmente _escritos_ no melhor estilo Rails Way.
Embora o Ronaldo tenha destacado o aspecto da mistura de lógica com a apresentação, comecei a refletir sobre a quantidade de má-representações de domínios de negócio que devem estar espalhadas por aí em aplicações Rails da atualidade. E confesso que isso também me preocupa!
Faz algum tempo que acompanho a lista Rails-BR, mesmo sem postar quase nada por lá. (Inclusive, lá não é o único lugar que tenho deixado de postar alguma coisa. Mas, sabe como é.. A vida de casado é um pouco mais atarefada que muitos imaginam!
)
Na grande maioria dos posts que vejo na lista Rails-BR, e na comunidade Rails brasileira como um todo, não vejo muita preocupação com o design da aplicação e uma boa representação dos domínios de negócio. (Será uma característica da adoção em massa de um hyppe?) Ao contrário, nos deparamos muito com a polida beleza de um domínio “doentio“, pobre em representação, com uma raison d’être resumida a mais uma triste estrutura de dados.
Diferentemente do que alguns pensam, uma boa representação de um domínio real de negócios não pode ser automatizada!
Espero que os desenvolvedores se atentem mais para isso, e que não nos deparemos com super-controllers e models anêmicos saltando de nossas telas diretamente para o nosso colo.
Do contrário, se essa tendência se mantiver, ainda veremos muitos códigos “macarrônicos”, ASP-like, escritos em Ruby com Rails. O que é uma grande infelicidade dado o poder da linguagem!
Espero que eu esteja errado nessa minha semi(pre)visão de Dante no domínio Rails. E que, ao contrário dessa possível tendência, possamos ter códigos compreensíveis, projetos com um domínio de negócio bem representado, e filhos plenamente felizes.
acts_as_state_machine: Gerenciando estados de um Model Rails
Dezembro 11, 2007
Acts as State Machine eh um plugin do Rails que visa facilitar o gerenciamento de estados de um dado model ActiveRecord, implementando assim uma Maquina de Estado Finito. O acts_as_state_machine carrega o conceito de eventos. Que sao blocos de codigo responsaveis pelas transicoes de um estado do Model para o outro. Suponhamos, por exemplo, que voce queira controlar os estados das tarefas que voce irah realizar durante um dia. Com o acts_as_state_machine voce poderia ter algo parecido com o seguinte:
class Tarefa < ActiveRecord::Base
# Inicialmente a Tarefa estarah no estado 'Pendente'
acts_as_state_machine :initial => :pendente
state :pendente
state :iniciada, :enter => Proc.new {|o| Mailer.send_notice(o)}
state :concluida
state :cancelada
# No evento 'iniciar' eh realizada a transicao do estado 'pendente' para 'iniciada'
event :iniciar do
transitions :from => :pendente, :to => :iniciada
end
event :concluir do
transitions :from => :iniciada, :to => :concluida
end
event :cancelar do
transitions :from => :pendente, :to => :cancelada
end
end
Para cada estado, um metodo “<nomedoestado>?” serah criado, e para cada evento, um metodo “<nomedoevento>!” serah criado:
t = Tarefa.create # Cria a tarefa com seu estado inicial... t.state # => "pendente" t.iniciar! # Envia notificacao por email, e muda estado da Tarefa para "iniciada" t.iniciada? # => true # ... t.concluir! # Muda o estado da tarefa para "Concluida"
Como voce pode ver no codigo de exemplo, quando a nossa Tarefa mudar para o estado ‘iniciada’, (em consequencia da chamada ao metodo do evento ‘iniciar’), serah enviada uma notificacao por email. Isso eh feito por meio daquela Proc que foi passada como uma funcao de callback do estado :iniciada. Nos mostrando que temos a flexibilidade de fazer qualquer coisa na mudanca de um estado para o outro. Alih, no lugar de um bloco de codigo, pode ser passado um simbolo, com o nome de um metodo de instancia do model.
Instalacao
Para quem jah instalou um plugin Rails, instalar o acts_as_state_machine nao tem segredo algum! Na raiz da tua aplicacao Rails, digite:
./script/plugin install http://elitists.textdriven.com/svn/plugins/acts_as_state_machine/trunk/
Daih em diante eh soh usar!
Minas on Rails ‘07: So’ mais um Post Mortem
Dezembro 4, 2007
O nosso primeiro Minas on Rails passou, mas muitas coisas boas ficaram!
Primeiro a lembranca do que rolou por aquelas bandas…Segundo aquele gostinho de “Quero mais!”…
Outra coisa boa que ficou foi a vontade insana de contribuir mais e aumentar minha participacao na comunidade…Espero que essa vontade continue e que esse blog ajude a satisfaze-la!