/*
* This file is part of the OpenSCADA project
* Copyright (C) 2006-2010 TH4 SYSTEMS GmbH (http://th4-systems.com)
*
* OpenSCADA is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License version 3
* only, as published by the Free Software Foundation.
*
* OpenSCADA 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 Lesser General Public License version 3 for more details
* (a copy is included in the LICENSE file that accompanied this code).
*
* You should have received a copy of the GNU Lesser General Public License
* version 3 along with OpenSCADA. If not, see
* <http://opensource.org/licenses/lgpl-3.0.html> for a copy of the LGPLv3 License.
*/
package org.openscada.core.ui.connection.login;
import java.util.Collection;
import org.osgi.framework.BundleContext;
public class LoginSession
{
private final String username;
private final String password;
private final BundleContext context;
private final LoginContext loginContext;
private final Collection<LoginHandler> handler;
public LoginSession ( final BundleContext context, final String username, final String password, final LoginContext loginContext, final Collection<LoginHandler> handler )
{
this.context = context;
this.username = username;
this.password = password;
this.loginContext = loginContext;
this.handler = handler;
}
public String getPassword ()
{
return this.password;
}
public String getUsername ()
{
return this.username;
}
public LoginContext getLoginContext ()
{
return this.loginContext;
}
public void register ()
{
for ( final LoginHandler handler : this.handler )
{
handler.register ( this.context );
}
}
public void dispose ()
{
for ( final LoginHandler handler : this.handler )
{
handler.dispose ();
}
}
/**
* Checks with all login handler if the session has a role granted
* <p>
* If no handler grants the role, the default <code>false</code> is returned.
* </p>
* @param role the role to check
* @return <code>true</code> if the role was granted, <code>false</code> otherwise
*/
public boolean hasRole ( final String role )
{
for ( final LoginHandler handler : this.handler )
{
if ( handler.hasRole ( role ) )
{
return true;
}
}
return false;
}
}