Start line:  
End line:  

Snippet Preview

Snippet HTML Code

Stack Overflow Questions
  /*
   * JBoss, Home of Professional Open Source.
   * Copyright 2008, Red Hat Middleware LLC, and individual contributors
   * as indicated by the @author tags. See the copyright.txt file in the
   * distribution for a full listing of individual contributors.
   *
   * This is free software; you can redistribute it and/or modify it
   * under the terms of the GNU Lesser General Public License as
   * published by the Free Software Foundation; either version 2.1 of
  * the License, or (at your option) any later version.
  *
  * This software 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 for more details.
  *
  * You should have received a copy of the GNU Lesser General Public
  * License along with this software; if not, write to the Free
  * Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
  * 02110-1301 USA, or see the FSF site: http://www.fsf.org.
  */
 package org.picketlink.trust.jbossws.handler;
 
 
 import  javax.security.jacc.PolicyContext;
 import  javax.security.jacc.PolicyContextException;
 import  javax.servlet.http.HttpServletRequest;
 

Author(s):
pskopek@redhat.com
 
 @SuppressWarnings({"rawtypes","restriction"})
     
     private SOAPFactory factory = null;
     
     @Override
     protected boolean handleInbound(MessageContext msgContext) {
         
         String username = getUserPrincipalName(msgContext);
 
         SOAPMessage sm = ((SOAPMessageContextmsgContext).getMessage();
         SOAPEnvelope envelope;
         try {
             envelope = sm.getSOAPPart().getEnvelope();
             SOAPBodyElement rst = (SOAPBodyElement) Util.findElement(envelopenew QName(..));
             if (rst != null) {
                 rst.addChildElement(createUsernameToken(username));
             }
         } catch (SOAPException e) {
             .jbossWSUnableToCreateBinaryToken(e);
         }
         if (.isTraceEnabled()) {
             .trace("SOAPMessage(SamlRequestSecurityTokenHandler)=" + SOAPUtil.soapMessageAsString(sm));            
         }
         return true;        
         
     }

    
    
Given a binary token, create a SOAPElement

Parameters:
token
Returns:
Throws:
SOAPException
 
     private SOAPElement createUsernameToken(String usernamevaluethrows SOAPException {
         if ( == null)
              = SOAPFactory.newInstance();
         SOAPElement usernametoken = .createElement(.,
                 ..);
                 .);
         username.addTextNode(usernamevalue);
 
         usernametoken.addChildElement(username);
         return usernametoken;
     }
    
    
    
Get the HttpServletRequest from the MessageContext

Parameters:
msgContext
Returns:
    private HttpServletRequest getHttpRequest(MessageContext msgContext) {
        HttpServletRequest request = (HttpServletRequest) msgContext.get(.);
        if (request == null) {
            try {
                request = (HttpServletRequest) PolicyContext.getContext("javax.servlet.http.HttpServletRequest");
            } catch (PolicyContextException e) {
                return null;
            }
        }
        return request;
    }
    
    protected String getUserPrincipalName(MessageContext msgContext) {
        HttpServletRequest servletRequest = getHttpRequest(msgContext);
        if (servletRequest == null) {
            .warn("Cannot get HttpRequest, ignoring " + SamlRequestSecurityTokenHandler.class.getName());
            return null;
        }
        
        Principal principal = servletRequest.getUserPrincipal();
        if (principal == null) {
            .warn("Cannot get Principal, ignoring " + SamlRequestSecurityTokenHandler.class.getName());
            return null;
        }
        
        return principal.getName();
    }
    
New to GrepCode? Check out our FAQ X