O JBoss Seam de fato é um framework que enche os olhos de qualquer um, mesmo tendo trabalhando em geradores de códigos/aplicações, me rendi ao JBoss Seam desde a primeira vez que o vi, mais precisamente no final de 2006, de lá pra cá, os projetos que trabalhei usavam muito mais questões de integrações do que aplicações de usuários finais. Porém, desde que comecei a avaliar o Seam com um maior cuidado para utilizá-lo como framework JSF por trás do Console do novo JBoss Profiler, percebi que realmente o framework vale muito a pena.Não é pra menos, um time de talentosos desenvolvedores está por trás do Seam, logo, tal resultado já era esperado. Mas chega de papo, e vamos a algumas dicas interessantes:
Forçando o Login para Determinadas Páginas JSF
Muitas vezes você quer que determinadas Páginas sejam protegidas por Login, para resolver isso, o Seam possui todo um framework de segurança baseado em JAAS, e para ativar tal requisito para uma determinada página, basta adicionar a seguinte string no arquivo pages.xml :
[xml]
Adicionando novas Consultas baseadas na Extensão do EntityQuery
Quando você extende a classe EntityQuery você tem acesso a vários componentens que o Seam injeta dinamicamente para nós, entre eles o EntityManager do JPA, que pemite que criemos Queries dinamicas, veja no exemplo o método que adicionei em uma das classes que extende o EntityQuery:
[java]
public Employee getUserByEmail(String email) {
return (Employee) this.getEntityManager().createQuery
(”from Employee where email=:email”)
.setParameter(”email”, email)
.getSingleResult();
}
[/java]
Implementando uma Autenticação no Seam e salvando dados no Contexto
Imagine que seus dados de usuários serão buscados via JPA, o exemplo a seguir mostra o Autenticator em ação, que é um SessionBean que o Seam executa toda a vez que a Aplicação precisa autenticar alguém. O Autenticator é um recurso que também faz parte do Seam. (No exemplo abaixo não há encriptação de senha, por favor leve isso em consideração no mundo real):
[java]
@Name(”authenticator”)
public class Authenticator
{
@Logger Log log;
@In Identity identity;
@In FacesMessages facesMessages;
public boolean authenticate()
{
log.info(”authenticating #0″, identity.getUsername());
identity.addRole(”admin”);
Employee employee = new
EmployeeList().getUserByEmail
(identity.getUsername());
boolean ok = employee.getPassword().
equalsIgnoreCase(identity.getPassword());
if (ok) {
Contexts.getSessionContext().set(”employee”,
employee);
identity.addRole(employee.getPositionEmployee());
facesMessages.add
(String.format(”We allow the user %s request a Travel”,
employee.getName()));
}
return ok;
}
}
[/java]
EntityListeners nossos! E por que não?
Mesmo com o suporte a Inteceptors do Seam, não faz mal criarmos os nossos algumas vezes, eis então um exemplo de inteceptação de eventos
na EntityClass: TravelRequest, onde antes de persistirmos uma informação, podemos promover uma avaliação e tomar alguma ação antes da ação ser executada,
os famosos Eventos, presentes em frameworks de persistências muito antigos como o TFieldDataLink no Borland Delphi desde 1995. Veja o exemplo:
EntityListener:
[java]
import javax.persistence.PrePersist;
public class TravelRequestListener {
@PrePersist
public void beforePost(TravelRequest request) {
if (request.getStatus()!=null &&
request.getStatus().equalsIgnoreCase(”")) {
request.setStatus(”NEW”);
}
}
}
[/java]
Registro do EntityListener:
[java]
@Entity
@EntityListeners({TravelRequestListener.class})
public class TravelRequest implements Serializable {
…
[/java]


Entries (RSS)