Erro ao editar Perfil (fixes bug #6331)

Tempo: 02 horas

git-svn-id: http://desenvolvimento.rjconsultores.com.br/repositorio/sco/AdmVenta/Model/trunk/modelWeb@44321 d1611594-4594-4d17-8e1d-87c2c4800839
master
julio 2015-05-25 19:14:18 +00:00
parent 8e6347b131
commit f13aebecd4
5 changed files with 126 additions and 61 deletions

View File

@ -12,5 +12,8 @@ import java.util.List;
* @author rodrigo
*/
public interface PerfilDAO extends GenericDAO<Perfil, Integer> {
public List<Perfil> buscar(String dscPerfil);
public List<Perfil> buscaPerfilJerarquia(Perfil perfilUsuario);
}

View File

@ -4,10 +4,10 @@
*/
package com.rjconsultores.ventaboletos.dao.hibernate;
import com.rjconsultores.ventaboletos.dao.PerfilDAO;
import com.rjconsultores.ventaboletos.entidad.Perfil;
import java.util.List;
import org.hibernate.Criteria;
import org.hibernate.Query;
import org.hibernate.SessionFactory;
import org.hibernate.criterion.Order;
import org.hibernate.criterion.Restrictions;
@ -15,6 +15,10 @@ import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.stereotype.Repository;
import com.rjconsultores.ventaboletos.dao.PerfilDAO;
import com.rjconsultores.ventaboletos.entidad.Perfil;
import com.rjconsultores.ventaboletos.vo.segurida.PerfilJerarquia;
/**
*
* @author rodrigo
@ -28,6 +32,28 @@ public class PerfilHibernateDAO extends GenericHibernateDAO<Perfil, Integer>
setSessionFactory(factory);
}
@Override
public List<Perfil> buscaPerfilJerarquia(Perfil perfilUsuario) {
PerfilJerarquia usuarioJerarquia = perfilUsuario.getIndJerarquia() == null ? PerfilJerarquia.NORMAL : PerfilJerarquia.buscar(perfilUsuario.getIndJerarquia());
StringBuilder sb = new StringBuilder();
sb.append(" from Perfil p ");
sb.append(" where p.activo = 1 ");
if (!usuarioJerarquia.equals(PerfilJerarquia.ADMIN)) {
if (!usuarioJerarquia.equals(PerfilJerarquia.NORMAL)) {
sb.append(" and (p.indJerarquia >= " + usuarioJerarquia.getValor() + " or p.indJerarquia <=" + PerfilJerarquia.NORMAL.getValor() + " or p.indJerarquia is null ) ");
} else {
sb.append(" and (p.indJerarquia is null or p.indJerarquia <=" + PerfilJerarquia.NORMAL.getValor() + " ) ");
}
}
sb.append(" order by p.descperfil ");
Query query = getSession().createQuery(sb.toString());
return query.list();
}
@Override
public List<Perfil> obtenerTodos() {
Criteria c = getSession().createCriteria(getPersistentClass());

View File

@ -25,4 +25,7 @@ public interface PerfilService{
public void borrar(Perfil entidad);
public List<Perfil> buscar(String dscPerfil);
public List<Perfil> buscaPerfilJerarquia(Perfil perfilUsuario);
}

View File

@ -62,4 +62,8 @@ public class PerfilServiceImpl implements PerfilService {
public List<Perfil> buscar(String dscPerfil) {
return perfilDAO.buscar(dscPerfil);
}
public List<Perfil> buscaPerfilJerarquia(Perfil perfilUsuario) {
return perfilDAO.buscaPerfilJerarquia(perfilUsuario);
}
}

View File

@ -0,0 +1,29 @@
package com.rjconsultores.ventaboletos.vo.segurida;
public enum PerfilJerarquia {
NORMAL(0), ADMIN(1), JERARQUIA_2(2), JERARQUIA_3(3), JERARQUIA_4(4);
private Integer valor;
private PerfilJerarquia(Integer valor) {
this.valor = valor;
}
public Integer getValor() {
return valor;
}
public static PerfilJerarquia buscar(Integer valor) {
if (valor == null)
return NORMAL;
for (PerfilJerarquia jerarquia : PerfilJerarquia.values()) {
if (jerarquia.getValor().equals(valor)) {
return jerarquia;
}
}
return null;
}
}