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

com.wavemaker.runtime.data.aop.CRUDAspectManager Maven / Gradle / Ivy

There is a newer version: 11.9.5.ee
Show newest version
package com.wavemaker.runtime.data.aop;

import java.lang.reflect.Method;
import java.util.List;
import java.util.Optional;

import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.annotation.Around;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.reflect.MethodSignature;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;

import com.wavemaker.runtime.data.annotations.EntityService;

@Aspect
public class CRUDAspectManager {

    private static final Logger logger = LoggerFactory.getLogger(CRUDAspectManager.class);

    @Autowired
    private List crudMethodInvocationHandlerList;


    @Around("execution(public * *(..)) && @within(entityService)")
    public Object crudMethodAccessAdvice(
            final ProceedingJoinPoint joinPoint, EntityService entityService) throws Throwable {
        MethodSignature methodSignature = (MethodSignature) joinPoint.getSignature();
        Method method = methodSignature.getMethod();
        Object[] args = joinPoint.getArgs();
        String serviceId = entityService.serviceId();
        Class entityClass = entityService.entityClass();
        logger.debug("Inside around for method {}", method.getName());
        Optional crudMethodInvocationHandlerOptional = findMatchingCRUDMethodInvocationHandler(entityClass, method);
        crudMethodInvocationHandlerOptional.ifPresent(crudMethodInvocationHandler ->  {
            logger.debug("Calling preHandler in handler {}", crudMethodInvocationHandler);
            crudMethodInvocationHandler.preHandle(serviceId, entityClass, method, args);
        });
        logger.debug("Calling target method {}", method.getName());
        Object retVal = joinPoint.proceed(args);
        crudMethodInvocationHandlerOptional.ifPresent(crudMethodInvocationHandler -> {
            logger.debug("Calling postHandler in handler {}", crudMethodInvocationHandler);
            crudMethodInvocationHandler.postHandle(serviceId, entityClass, method, retVal);
        });
        return retVal;
    }

    private Optional findMatchingCRUDMethodInvocationHandler( Class entityClass, Method method) {
        for (CRUDMethodInvocationHandler crudMethodInvocationHandler : crudMethodInvocationHandlerList) {
            if (crudMethodInvocationHandler.matches(entityClass, method)) {
                return Optional.of(crudMethodInvocationHandler);
            }
        }
        return Optional.empty();
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy