blob: 5d4dd7b5e892294dbeae4dc4be39763e2a31b113 [file] [log] [blame]
/*
* $Id$ $Revision:
* 1.6 $ $Date$
*
* ==============================================================================
* Licensed under the Apache License, Version 2.0 (the "License"); you may not
* use this file except in compliance with the License. You may obtain a copy of
* the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
* License for the specific language governing permissions and limitations under
* the License.
*/
package wicket.examples.signin;
import wicket.protocol.http.WebApplication;
import wicket.protocol.http.WebSession;
/**
* Session class for signin example. Holds and authenticates users.
*
* @author Jonathan Locke
*/
public final class SignInSession extends WebSession
{
/** Trivial user representation */
private String user;
/**
* Constructor
*
* @param application
* The application
*/
protected SignInSession(final WebApplication application)
{
super(application);
}
/**
* Checks the given username and password, returning a User object if if the
* username and password identify a valid user.
*
* @param username
* The username
* @param password
* The password
* @return True if the user was authenticated
*/
public final boolean authenticate(final String username, final String password)
{
if (user == null)
{
// Trivial password "db"
if ("wicket".equalsIgnoreCase(username) && "wicket".equalsIgnoreCase(password))
{
user = username;
}
}
return user != null;
}
/**
* @return True if user is signed in
*/
public boolean isSignedIn()
{
return user != null;
}
/**
* @return User
*/
public String getUser()
{
return user;
}
/**
* @param user
* New user
*/
public void setUser(final String user)
{
this.user = user;
}
}