/*
* $Id: UsernamePasswordAuthenticationFilter.java 22156 2011-06-08 21:36:30Z dfeist $
* --------------------------------------------------------------------------------------
* Copyright (c) MuleSoft, Inc. All rights reserved. http://www.mulesoft.com
*
* The software in this package is published under the terms of the CPAL v1.0
* license, a copy of which has been included with this distribution in the
* LICENSE.txt file.
*/
package org.mule.security;
import org.mule.api.MuleEvent;
import org.mule.api.MuleMessage;
import org.mule.api.expression.ExpressionManager;
import org.mule.api.security.Authentication;
import org.mule.api.security.SecurityContext;
import org.mule.api.security.SecurityException;
import org.mule.api.security.SecurityManager;
import org.mule.api.security.SecurityProviderNotFoundException;
import org.mule.api.security.UnauthorisedException;
import org.mule.api.security.UnknownAuthenticationTypeException;
import org.mule.config.i18n.CoreMessages;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
/**
* Performs authentication based on a username and password. The username and password are retrieved from the
* {@link MuleMessage} based on expressions specified via the username and password setters. These
* are then used to create a DefaultMuleAuthentication object which is passed to the authenticate method of the
* {@link SecurityManager}.
*/
public class UsernamePasswordAuthenticationFilter extends AbstractAuthenticationFilter
{
/**
* logger used by this class
*/
protected static final Log logger = LogFactory.getLog(UsernamePasswordAuthenticationFilter.class);
private String username = "#[header:inbound:username]";
private String password = "#[header:inbound:password]";
public UsernamePasswordAuthenticationFilter()
{
super();
}
/**
* Authenticates the current message.
*
* @param event the current message recieved
* @throws org.mule.api.security.SecurityException if authentication fails
*/
@Override
public void authenticate(MuleEvent event)
throws SecurityException, SecurityProviderNotFoundException, UnknownAuthenticationTypeException
{
Authentication authentication = getAuthenticationToken(event);
Authentication authResult;
try
{
authResult = getSecurityManager().authenticate(authentication);
}
catch (UnauthorisedException e)
{
// Authentication failed
if (logger.isDebugEnabled())
{
logger.debug("Authentication request for user: " + username + " failed: " + e.toString());
}
throw new UnauthorisedException(CoreMessages.authFailedForUser(authentication.getPrincipal().toString()), e);
}
// Authentication success
if (logger.isDebugEnabled())
{
logger.debug("Authentication success: " + authResult.toString());
}
SecurityContext context = getSecurityManager().createSecurityContext(authResult);
context.setAuthentication(authResult);
event.getSession().setSecurityContext(context);
}
protected Authentication getAuthenticationToken(MuleEvent event) throws UnauthorisedException
{
ExpressionManager expressionManager = event.getMuleContext().getExpressionManager();
Object usernameEval = expressionManager.evaluate(username, event.getMessage());
Object passwordEval = expressionManager.evaluate(password, event.getMessage());
if (usernameEval == null) {
throw new UnauthorisedException(CoreMessages.authNoCredentials());
}
if (passwordEval == null) {
throw new UnauthorisedException(CoreMessages.authNoCredentials());
}
return new DefaultMuleAuthentication(new MuleCredentials(usernameEval.toString(), passwordEval.toString().toCharArray()));
}
public String getUsername()
{
return username;
}
public void setUsername(String username)
{
this.username = username;
}
public String getPassword()
{
return password;
}
public void setPassword(String password)
{
this.password = password;
}
}