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

nl.vpro.api.client.frontend.NpoApiClientsAspect Maven / Gradle / Ivy

package nl.vpro.api.client.frontend;

import lombok.extern.slf4j.Slf4j;

import java.lang.annotation.Annotation;
import java.lang.reflect.*;

import javax.ws.rs.*;

import static nl.vpro.domain.api.Constants.*;

/**
 * This Proxy:
 * - throttles all calls
 * - automaticly fills some common arguments (recognized by @QueryParam annotations)
 * - if the return type is Response, it also checks the status code
 * @author Michiel Meeuwissen
 * @since 4.9
 */
@Slf4j
class NpoApiClientsAspect implements InvocationHandler {

    private final T proxied;
    private final NpoApiClients clients;

    NpoApiClientsAspect(NpoApiClients clients, T proxied) {
        this.proxied = proxied;
        this.clients = clients;
    }

    public static  T proxy(NpoApiClients clients, T proxied, Class service) {
        return (T) Proxy.newProxyInstance(NpoApiClientsAspect.class.getClassLoader(),
            new Class[]{service}, new NpoApiClientsAspect(clients, proxied));
    }


    @Override
    public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
        try {
            fillImplicitParameters(method, args);
            return method.invoke(proxied, args);
        } catch (InvocationTargetException itc) {
            throw itc.getCause();
        } catch(WebApplicationException ise) {
            log.error(ise.getResponse().getEntity().toString(), ise);
            throw ise;
        }
    }

    protected void fillImplicitParameters(Method method, Object[] args) {
        Annotation[][] annotations = method.getParameterAnnotations();
        if (args != null) {
            for (int i = 0; i < args.length; i++) {
                for (int j = 0; j < annotations[i].length; j++) {
                    if (annotations[i][j] instanceof QueryParam && args[i] == null) {
                        QueryParam queryParam = (QueryParam) annotations[i][j];
                        if (args[i] == null) {
                            if (PROPERTIES.equals(queryParam.value())) {
                                log.debug("Implicitely set properties parameter to {}", clients.getProperties());
                                args[i] = clients.getProperties();
                            } else if (PROFILE.equals(queryParam.value())) {
                                log.debug("Implicitely set profile parameter to {}", clients.getProfile());
                                args[i] = clients.getProfile();
                            } else if (MAX.equals(queryParam.value())) {
                                log.debug("Implicitely set max parameter to {}", clients.getMax());
                                args[i] = clients.getMax();
                            }
                        }
                    }
                }

            }
        }

    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy