package org.nvg.service.aspect;
import lombok.extern.slf4j.Slf4j;
import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.annotation.Around;
import org.aspectj.lang.annotation.Aspect;
import org.hzero.core.util.Results;
import org.nvg.service.domain.entity.Share;
import org.nvg.service.domain.entity.ShareLog;
import org.nvg.service.domain.entity.ShareProject;
import org.nvg.service.domain.entity.ShareProjectLog;
import org.nvg.service.domain.repository.ShareLogRepository;
import org.nvg.service.domain.repository.ShareProjectLogRepository;
import org.springframework.beans.BeanUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;
/**
* @author: smy
*/
@Aspect
@Component
@Slf4j
public class CuxShareAspect {
@Autowired
private ShareLogRepository shareLogRepository;
@Autowired
private ShareProjectLogRepository shareProjectLogRepository;
@Around(" execution(* org.nvg.service.api.controller.v1.ShareController.create(..)) ")
public Object aspectShareCreate(ProceedingJoinPoint point) throws Throwable {
point.proceed();
Share share = (Share)point.getArgs()[0];
ShareLog shareLog = new ShareLog();
BeanUtils.copyProperties(share,shareLog,new String[]{"id"});
//主从关联
shareLog.setShareId(share.getId());
ShareProjectLog shareProjectLog = new ShareProjectLog();
for (ShareProject project : share.getShareProjects()) {
BeanUtils.copyProperties(project,shareProjectLog,new String[]{"id"});
//主从关联
shareProjectLog.setShareProjectId(project.getId());
shareProjectLogRepository.insertSelective(shareProjectLog);
}
shareLogRepository.insertSelective(shareLog);
return Results.success(share);
}
}