/*
* Copyright (C) 2010 Allan Lykke Christensen
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
package dk.i2m.converge.jsf.converters;
import dk.i2m.converge.core.security.Privilege;
import dk.i2m.converge.core.security.SystemPrivilege;
import dk.i2m.converge.ejb.facades.UserFacadeLocal;
import dk.i2m.converge.core.DataNotFoundException;
import java.util.logging.Level;
import java.util.logging.Logger;
import javax.faces.component.UIComponent;
import javax.faces.context.FacesContext;
import javax.faces.convert.Converter;
/**
* Converter for turning {@link SystemPrivilege}s into {@link Privilege}s.
*
* @author Allan Lykke Christensen
*/
public class SystemPrivilegeConverter implements Converter {
private static final Logger LOG = Logger.getLogger(SystemPrivilegeConverter.class.getName());
private UserFacadeLocal userFacade;
public SystemPrivilegeConverter(UserFacadeLocal userFacade) {
this.userFacade = userFacade;
}
/**
*
* @param fc
* @param uic
* @param string
* @return
*/
@Override
public Object getAsObject(FacesContext fc, UIComponent uic, String string) {
try {
return userFacade.findPrivilegeById(string);
} catch (DataNotFoundException ex) {
LOG.log(Level.WARNING, "Pririvilegde ID was not Found In the Database");
LOG.log(Level.FINEST, "",ex);
return null;
}
}
@Override
public String getAsString(FacesContext fc, UIComponent uic, Object o) {
if (o instanceof Privilege) {
return ((Privilege) o).getId().name();
} else {
LOG.log(Level.WARNING, "Not instance of Privilege: {0}", o.getClass().
getName());
return "";
}
}
}