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

org.apache.synapse.mediators.bean.BeanUtils Maven / Gradle / Ivy

There is a newer version: 3.0.2
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.synapse.mediators.bean;

import org.apache.axiom.om.util.AXIOMUtil;
import org.apache.axis2.databinding.typemapping.SimpleTypeMapper;
import org.apache.synapse.SynapseException;

import javax.xml.stream.XMLStreamException;
import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;

/**
 * Provides utility methods for method invocation via reflection.
 */
public class BeanUtils {

    private BeanUtils() {}

    /**
     * Invokes the given method on the given object via reflection, handles simple type conversion
     * from String to simple types.
     * @param instance  Instance to invoke the method on.
     * @param method    Method to be invoked.
     * @param args      Arguments for the method invocation.
     * @return          Return value of the method invocation.
     * @throws SynapseException If method invocation fails.
     */
    public static Object invokeInstanceMethod(Object instance, Method method, Object[] args) throws
                                                                                  SynapseException {
        Class[] paramTypes = method.getParameterTypes();

        if (paramTypes.length != args.length) {
            throw new SynapseException("Provided argument count does not match method the " +
                    "parameter count of method '" + method.getName() + "'. Argument count = " +
                    args.length + ", method parameter count = " + paramTypes.length + ".");
        }

        Object[] processedArgs = new Object[paramTypes.length];

        for (int i = 0; i < paramTypes.length; ++i) {

            if (args[i] == null || paramTypes[i].isAssignableFrom(args[i].getClass())) {
                processedArgs[i] = args[i];
            } else if (SimpleTypeMapper.isSimpleType(paramTypes[i])) {
                processedArgs[i] = SimpleTypeMapper.getSimpleTypeObject(paramTypes[i], args[i].toString());
            } else {
                throw new SynapseException("Incompatible argument found in argument " + i +
                        " for '" + method.getName() + "' method.");
            }
        }

        try {
            return method.invoke(instance, processedArgs);
        } catch (IllegalAccessException e) {
            throw new SynapseException("Error while invoking '" + method.getName() + "' method " +
                    "via reflection.", e);
        } catch (InvocationTargetException e) {
            throw new SynapseException("Error while invoking '" + method.getName() + "' method " +
                    "via reflection.", e);
        }
    }

    /**
     * Finds a method in the given class with the given method name and argument count. Fails to
     * resolve the method if two or more overloaded methods are present with the given name and
     * argument count.
     *
     * @param clazz      Class to search for the method in.
     * @param methodName Method name to search for.
     * @param argCount   Length of the argument list.
     * @return           The resolved method, or null if no matching method is found.
     * @throws SynapseException If two or more overloaded methods are found with the given name and
     * argument count.
     */
    public static Method resolveMethod(Class clazz, String methodName, int argCount) throws
                                                                                  SynapseException {
        Method resolvedMethod = null;

        for (Method method : clazz.getMethods()) {

            if (method.getName().equals(methodName) &&
                    method.getParameterTypes().length == argCount) {

                if (resolvedMethod == null) {
                    resolvedMethod = method;
                } else {
                    throw new SynapseException("More than one '" + methodName + "' methods " +
                            "taking " + argCount + " arguments are found in '" +
                            clazz.getName() + "' class.");
                }

            }
        }

        return resolvedMethod;
    }

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy