in bindings/servicemix-cxf-bc/src/main/java/org/apache/servicemix/cxfbc/interceptors/JbiJAASInterceptor.java [64:130]
public void handleMessage(SoapMessage message) throws Fault {
try {
if (!delegateToJaas) {
return;
}
Subject subject = (Subject) currentSubject.get();
if (subject == null) {
subject = new Subject();
currentSubject.set(subject);
}
List<Object> results = (List<Object>)message.get(WSHandlerConstants.RECV_RESULTS);
if (results == null) {
return;
}
for (Iterator iter = results.iterator(); iter.hasNext();) {
WSHandlerResult hr = (WSHandlerResult) iter.next();
if (hr == null || hr.getResults() == null) {
return;
}
boolean authenticated = false;
//favor WSSE UsernameToken based authentication over X.509 certificate
//based authentication. For that purpose we iterate twice over the
//WSHandler result list
for (Iterator it = hr.getResults().iterator(); it.hasNext();) {
WSSecurityEngineResult er = (WSSecurityEngineResult) it.next();
if (er != null && er.get(WSSecurityEngineResult.TAG_PRINCIPAL) instanceof WSUsernameTokenPrincipal) {
WSUsernameTokenPrincipal p = (WSUsernameTokenPrincipal)er.get(WSSecurityEngineResult.TAG_PRINCIPAL);
subject.getPrincipals().add(p);
this.authenticationService.authenticate(subject, domain, p.getName(), p.getPassword());
authenticated = true;
}
}
//Second iteration checking for X.509 certificate to run authentication on
//but only if not already authenticated on WSSE UsernameToken
if (!authenticated && x509) {
for (Iterator it = hr.getResults().iterator(); it.hasNext();) {
WSSecurityEngineResult er = (WSSecurityEngineResult) it.next();
if (er != null && er.get(WSSecurityEngineResult.TAG_X509_CERTIFICATES) instanceof X509Certificate) {
X509Certificate cert = (X509Certificate)er.get(WSSecurityEngineResult.TAG_X509_CERTIFICATES);
this.authenticationService.authenticate(subject, domain, cert.getIssuerX500Principal().getName(), cert);
}
}
}
}
message.put(Subject.class, subject);
} catch (GeneralSecurityException e) {
throw new Fault(e);
} catch (java.lang.reflect.UndeclaredThrowableException e) {
java.lang.Throwable undeclared = e.getUndeclaredThrowable();
if (undeclared != null
&& undeclared instanceof java.lang.reflect.InvocationTargetException) {
throw new Fault(
((java.lang.reflect.InvocationTargetException) undeclared)
.getTargetException());
}
} finally {
currentSubject.set(null);
}
}