mirror of
https://github.com/Alfresco/alfresco-community-repo.git
synced 2025-07-31 17:39:05 +00:00
Moving to root below branch label
git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@2005 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
This commit is contained in:
@@ -0,0 +1,100 @@
|
||||
/*
|
||||
* Copyright (C) 2005 Alfresco, Inc.
|
||||
*
|
||||
* Licensed under the Mozilla Public License version 1.1
|
||||
* with a permitted attribution clause. You may obtain a
|
||||
* copy of the License at
|
||||
*
|
||||
* http://www.alfresco.org/legal/license.txt
|
||||
*
|
||||
* 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 org.alfresco.repo.webservice.axis;
|
||||
|
||||
import java.io.IOException;
|
||||
|
||||
import javax.security.auth.callback.Callback;
|
||||
import javax.security.auth.callback.CallbackHandler;
|
||||
import javax.security.auth.callback.UnsupportedCallbackException;
|
||||
|
||||
import org.alfresco.repo.security.authentication.AuthenticationException;
|
||||
import org.alfresco.repo.webservice.authentication.AuthenticationFault;
|
||||
import org.alfresco.service.cmr.security.AuthenticationService;
|
||||
import org.apache.commons.logging.Log;
|
||||
import org.apache.commons.logging.LogFactory;
|
||||
import org.apache.ws.security.WSPasswordCallback;
|
||||
|
||||
/**
|
||||
* CallbackHandler that verifies the given ticket in the password element of the UsernameToken
|
||||
* header is still a valid ticket
|
||||
*
|
||||
* @author gavinc
|
||||
*/
|
||||
public class TicketCallbackHandler implements CallbackHandler
|
||||
{
|
||||
private static final Log logger = LogFactory.getLog(TicketCallbackHandler.class);
|
||||
|
||||
private AuthenticationService authenticationService;
|
||||
|
||||
/**
|
||||
* Sets the AuthenticationService instance to use
|
||||
*
|
||||
* @param authenticationService The AuthenticationService
|
||||
*/
|
||||
public void setAuthenticationService(AuthenticationService authenticationService)
|
||||
{
|
||||
this.authenticationService = authenticationService;
|
||||
}
|
||||
|
||||
/**
|
||||
* @see javax.security.auth.callback.CallbackHandler#handle(javax.security.auth.callback.Callback[])
|
||||
*/
|
||||
public void handle(Callback[] callbacks) throws IOException, UnsupportedCallbackException
|
||||
{
|
||||
for (int i = 0; i < callbacks.length; i++)
|
||||
{
|
||||
if (callbacks[i] instanceof WSPasswordCallback)
|
||||
{
|
||||
WSPasswordCallback pc = (WSPasswordCallback)callbacks[i];
|
||||
String ticket = pc.getPassword();
|
||||
|
||||
if (logger.isDebugEnabled())
|
||||
{
|
||||
logger.debug("Verifying ticket for: " + pc.getIdentifer());
|
||||
logger.debug("Ticket: " + ticket);
|
||||
}
|
||||
|
||||
// ensure the ticket is valid
|
||||
try
|
||||
{
|
||||
this.authenticationService.validate(ticket);
|
||||
}
|
||||
catch (AuthenticationException ae)
|
||||
{
|
||||
if (logger.isDebugEnabled())
|
||||
logger.debug("Ticket validation failed: " + ae.getMessage());
|
||||
|
||||
// NOTE: Throwing AuthenticationFault just gets consumed and the ws-security handler
|
||||
// reports a missing password; we would need to modify the WSS4J code to let
|
||||
// the exception bubble up so for now just let the default message get thrown
|
||||
throw new AuthenticationFault(701, "Authentication failed due to an invalid ticket");
|
||||
}
|
||||
|
||||
if (logger.isDebugEnabled())
|
||||
logger.debug("Ticket validated successfully");
|
||||
|
||||
// if all is well set the password to return as the given ticket
|
||||
pc.setPassword(pc.getPassword());
|
||||
}
|
||||
else
|
||||
{
|
||||
throw new UnsupportedCallbackException(callbacks[i], "Unrecognized Callback");
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user