KickJava   Java API By Example, From Geeks To Geeks.

Java > Open Source Codes > org > jboss > axis > handlers > http > HTTPActionHandler


1 /*
2  * The Apache Software License, Version 1.1
3  *
4  * Copyright (c) 2001-2003 The Apache Software Foundation. All rights
5  * reserved.
6  *
7  * Redistribution and use in source and binary forms, with or without
8  * modification, are permitted provided that the following conditions
9  * are met:
10  *
11  * 1. Redistributions of source code must retain the above copyright
12  * notice, this list of conditions and the following disclaimer.
13  *
14  * 2. Redistributions in binary form must reproduce the above copyright
15  * notice, this list of conditions and the following disclaimer in
16  * the documentation and/or other materials provided with the
17  * distribution.
18  *
19  * 3. The end-user documentation included with the redistribution,
20  * if any, must include the following acknowledgment:
21  * "This product includes software developed by the
22  * Apache Software Foundation (http://www.apache.org/)."
23  * Alternately, this acknowledgment may appear in the software itself,
24  * if and wherever such third-party acknowledgments normally appear.
25  *
26  * 4. The names "Axis" and "Apache Software Foundation" must
27  * not be used to endorse or promote products derived from this
28  * software without prior written permission. For written
29  * permission, please contact apache@apache.org.
30  *
31  * 5. Products derived from this software may not be called "Apache",
32  * nor may "Apache" appear in their name, without prior written
33  * permission of the Apache Software Foundation.
34  *
35  * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
36  * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
37  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
38  * DISCLAIMED. IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR
39  * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
40  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
41  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
42  * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
43  * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
44  * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
45  * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
46  * SUCH DAMAGE.
47  * ====================================================================
48  *
49  * This software consists of voluntary contributions made by many
50  * individuals on behalf of the Apache Software Foundation. For more
51  * information on the Apache Software Foundation, please see
52  * <http://www.apache.org/>.
53  */

54
55 package org.jboss.axis.handlers.http;
56
57 import org.jboss.axis.AxisFault;
58 import org.jboss.axis.MessageContext;
59 import org.jboss.axis.handlers.BasicHandler;
60 import org.jboss.axis.utils.Messages;
61 import org.jboss.logging.Logger;
62
63
64 /**
65  * An <code>HTTPActionHandler</code> simply sets the context's TargetService
66  * property from the HTTPAction property. We expect there to be a
67  * Router on the chain after us, to dispatch to the service named in
68  * the SOAPAction.
69  * <p/>
70  * In the real world, this might do some more complex mapping of
71  * SOAPAction to a TargetService.
72  *
73  * @author Glen Daniels (gdaniels@allaire.com)
74  * @author Doug Davis (dug@us.ibm.com)
75  */

76 public class HTTPActionHandler extends BasicHandler
77 {
78    private static Logger log = Logger.getLogger(HTTPActionHandler.class.getName());
79
80    public void invoke(MessageContext msgContext) throws AxisFault
81    {
82       log.debug("Enter: HTTPActionHandler::invoke");
83
84       /** If there's already a targetService then just return.
85        */

86       if (msgContext.getService() == null)
87       {
88          String JavaDoc action = (String JavaDoc)msgContext.getSOAPActionURI();
89          log.debug(" HTTP SOAPAction: " + action);
90
91          /** The idea is that this handler only goes in the chain IF this
92           * service does a mapping between SOAPAction and target. Therefore
93           * if we get here with no action, we're in trouble.
94           */

95          if (action == null)
96          {
97             throw new AxisFault("Server.NoHTTPSOAPAction",
98                     Messages.getMessage("noSOAPAction00"),
99                     null, null);
100          }
101
102          action = action.trim();
103
104          // handle empty SOAPAction
105
if (action.length() > 0 && action.charAt(0) == '\"')
106          {
107             // assertTrue(action.endsWith("\"")
108
if (action.equals("\"\""))
109             {
110                action = "";
111             }
112             else
113             {
114                action = action.substring(1, action.length() - 1);
115             }
116          }
117
118          // if action is zero-length string, don't set anything
119
if (action.length() > 0)
120          {
121             msgContext.setTargetService(action);
122          }
123       }
124
125       log.debug("Exit: HTTPActionHandler::invoke");
126    }
127 }
128
Popular Tags