/* * Copyright (C) 2014 GG-Net GmbH - Oliver Günther * * 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 eu.ggnet.dwoss.assembly.local.provides; import eu.ggnet.saft.api.AuthenticationException; import eu.ggnet.saft.core.authorisation.Guardian; import org.openide.util.lookup.ServiceProvider; import eu.ggnet.dwoss.common.AbstractGuardian; import eu.ggnet.dwoss.rights.op.Authentication; import eu.ggnet.dwoss.util.UserInfoException; import static eu.ggnet.saft.core.Client.lookup; /** * Implementation of an IAuthenticator using the GG-Net Imap Server */ @ServiceProvider(service = Guardian.class) public class ImapGuardian extends AbstractGuardian implements Guardian { @Override public void login(String user, char[] pass) throws AuthenticationException { try { setRights(lookup(Authentication.class).login(user, pass)); } catch (UserInfoException e) { throw new AuthenticationException(e.getMessage()); } } }