blob: 293204edd9115bc0aa408afbf8eede4d004a75d2 [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* 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 javax.xml.rpc.handler;
import javax.xml.namespace.QName;
/**
* The <code>javax.xml.rpc.handler.GenericHandler</code> class
* implements the <code>Handler</code> interface. SOAP Message
* Handler developers should typically subclass
* <code>GenericHandler</code> class unless the Handler class
* needs another class as a superclass.
*
* <p>
* The <code>GenericHandler</code> class is a convenience abstract
* class that makes writing Handlers easy. This class provides
* default implementations of the lifecycle methods <code>init</code>
* and <code>destroy</code> and also different handle methods.
* A Handler developer should only override methods that it needs
* to specialize as part of the derived <code>Handler</code>
* implementation class.
*
* @version $Rev$ $Date$
*/
public abstract class GenericHandler implements Handler {
/**
* Default constructor.
*/
protected GenericHandler() {}
/**
* The <code>handleRequest</code> method processes the request
* SOAP message. The default implementation of this method returns
* <code>true</code>. This indicates that the handler chain
* should continue processing of the request SOAP message.
* This method should be overridden if the derived Handler class
* needs to specialize implementation of this method.
*
* @param context the message context
* @return true/false
*/
public boolean handleRequest(MessageContext context) {
return true;
}
/**
* The <code>handleResponse</code> method processes the response
* message. The default implementation of this method returns
* <code>true</code>. This indicates that the handler chain
* should continue processing of the response SOAP message.
* This method should be overridden if the derived Handler class
* needs to specialize implementation of this method.
*
* @param context the message context
* @return true/false
*/
public boolean handleResponse(MessageContext context) {
return true;
}
/**
* The <code>handleFault</code> method processes the SOAP faults
* based on the SOAP message processing model. The default
* implementation of this method returns <code>true</code>. This
* indicates that the handler chain should continue processing
* of the SOAP fault. This method should be overridden if
* the derived Handler class needs to specialize implementation
* of this method.
*
* @param context the message context
* @return true/false
*/
public boolean handleFault(MessageContext context) {
return true;
}
/**
* The <code>init</code> method to enable the Handler instance to
* initialize itself. This method should be overridden if
* the derived Handler class needs to specialize implementation
* of this method.
*
* @param config handler configuration
*/
public void init(HandlerInfo config) {}
/**
* The <code>destroy</code> method indicates the end of lifecycle
* for a Handler instance. This method should be overridden if
* the derived Handler class needs to specialize implementation
* of this method.
*/
public void destroy() {}
/**
* Gets the header blocks processed by this Handler instance.
*
* @return Array of QNames of header blocks processed by this handler instance.
* <code>QName</code> is the qualified name of the outermost element of the Header block.
*/
public abstract QName[] getHeaders();
}