All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.apache.axis2.clustering.RequestBlockingHandler Maven / Gradle / Ivy

There is a newer version: 5.0.22
Show newest version
/*
 * 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 org.apache.axis2.clustering;

import org.apache.axis2.AxisFault;
import org.apache.axis2.context.ConfigurationContext;
import org.apache.axis2.context.MessageContext;
import org.apache.axis2.description.AxisService;
import org.apache.axis2.description.AxisServiceGroup;
import org.apache.axis2.description.HandlerDescription;
import org.apache.axis2.description.Parameter;
import org.apache.axis2.handlers.AbstractHandler;

/**
 *
 */
public class RequestBlockingHandler extends AbstractHandler {
    public InvocationResponse invoke(MessageContext msgContext) throws AxisFault {

        // Handle blocking at gobal level
        ConfigurationContext cfgCtx = msgContext.getConfigurationContext();
        Boolean isBlockingAllRequests =
                (Boolean) cfgCtx.getProperty(ClusteringConstants.BLOCK_ALL_REQUESTS);
        AxisServiceGroup serviceGroup = msgContext.getAxisServiceGroup();

        // Handle blocking at service group level
        Boolean isBlockingServiceGroupRequests = Boolean.FALSE;
        if (serviceGroup != null) {
            Parameter blockingParam =
                    serviceGroup.getParameter(ClusteringConstants.BLOCK_ALL_REQUESTS);
            if (blockingParam != null) {
                isBlockingServiceGroupRequests = (Boolean) blockingParam.getValue();
            }
        }

        // Handle blocking at service level
        AxisService service = msgContext.getAxisService();
        Boolean isBlockingServiceRequests = Boolean.FALSE;
        if (service != null) {
            Parameter blockingParam =
                    service.getParameter(ClusteringConstants.BLOCK_ALL_REQUESTS);
            if (blockingParam != null) {
                isBlockingServiceRequests = (Boolean) blockingParam.getValue();
            }
        }

        if (isBlockingAllRequests != null && isBlockingAllRequests.booleanValue()) {

            // Allow only NodeManager service commit requests to pass through. Block all others
            AxisService axisService = msgContext.getAxisService();
            if (!axisService.getName().equals(ClusteringConstants.NODE_MANAGER_SERVICE)) {
                if (!msgContext.getAxisOperation().getName().getLocalPart().equals("commit")) {
                    throw new AxisFault("System is being reinitialized. " +
                                        "Please try again in a few seconds.");
                } else {
                    throw new AxisFault("NodeManager service cannot call any other " +
                                        "operation after calling prepare");
                }
            }
        } else if (isBlockingServiceGroupRequests.booleanValue()) {
            throw new AxisFault("This service group is being initialized or unloaded. " +
                                "Please try again in a few seconds.");
        } else if (isBlockingServiceRequests.booleanValue()) {
            throw new AxisFault("This service is being initialized. " +
                                "Please try again in a few seconds.");
        }
        return InvocationResponse.CONTINUE;
    }


    public boolean equals(Object obj) {
        if(obj instanceof RequestBlockingHandler){
            RequestBlockingHandler that = (RequestBlockingHandler) obj;
            HandlerDescription thisDesc = this.getHandlerDesc();
            HandlerDescription thatDesc = that.getHandlerDesc();
            if(thisDesc != null && thatDesc != null && thisDesc.getName().equals(thatDesc.getName())){
                return true;
            }
        }
        return false;
    }


    public int hashCode() {
        if(this.handlerDesc != null){
            return this.handlerDesc.hashCode();
        }
        return super.hashCode();
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy