|
@@ -2,14 +2,19 @@ package cn.iocoder.yudao.module.crm.service.customer;
|
|
|
|
|
|
import cn.hutool.core.lang.Assert;
|
|
|
import cn.iocoder.yudao.framework.common.pojo.PageResult;
|
|
|
+import cn.iocoder.yudao.framework.common.util.object.BeanUtils;
|
|
|
import cn.iocoder.yudao.module.crm.controller.admin.customer.vo.limitconfig.CrmCustomerLimitConfigPageReqVO;
|
|
|
import cn.iocoder.yudao.module.crm.controller.admin.customer.vo.limitconfig.CrmCustomerLimitConfigSaveReqVO;
|
|
|
import cn.iocoder.yudao.module.crm.convert.customer.CrmCustomerLimitConfigConvert;
|
|
|
import cn.iocoder.yudao.module.crm.dal.dataobject.customer.CrmCustomerLimitConfigDO;
|
|
|
import cn.iocoder.yudao.module.crm.dal.mysql.customer.CrmCustomerLimitConfigMapper;
|
|
|
+import cn.iocoder.yudao.module.crm.enums.customer.CrmCustomerLimitConfigTypeEnum;
|
|
|
import cn.iocoder.yudao.module.system.api.dept.DeptApi;
|
|
|
import cn.iocoder.yudao.module.system.api.user.AdminUserApi;
|
|
|
import cn.iocoder.yudao.module.system.api.user.dto.AdminUserRespDTO;
|
|
|
+import com.mzt.logapi.context.LogRecordContext;
|
|
|
+import com.mzt.logapi.service.impl.DiffParseFunction;
|
|
|
+import com.mzt.logapi.starter.annotation.LogRecord;
|
|
|
import jakarta.annotation.Resource;
|
|
|
import org.springframework.stereotype.Service;
|
|
|
import org.springframework.validation.annotation.Validated;
|
|
@@ -19,6 +24,7 @@ import java.util.List;
|
|
|
|
|
|
import static cn.iocoder.yudao.framework.common.exception.util.ServiceExceptionUtil.exception;
|
|
|
import static cn.iocoder.yudao.module.crm.enums.ErrorCodeConstants.CUSTOMER_LIMIT_CONFIG_NOT_EXISTS;
|
|
|
+import static cn.iocoder.yudao.module.crm.enums.LogRecordConstants.*;
|
|
|
|
|
|
/**
|
|
|
* 客户限制配置 Service 实现类
|
|
@@ -38,34 +44,44 @@ public class CrmCustomerLimitConfigServiceImpl implements CrmCustomerLimitConfig
|
|
|
private AdminUserApi adminUserApi;
|
|
|
|
|
|
@Override
|
|
|
- // TODO @puhui999:操作日志
|
|
|
+ @LogRecord(type = CRM_CUSTOMER_LIMIT_CONFIG_TYPE, subType = CRM_CUSTOMER_LIMIT_CONFIG_CREATE_SUB_TYPE, bizNo = "{{#limitId}}", success = CRM_CUSTOMER_LIMIT_CONFIG_CREATE_SUCCESS)
|
|
|
public Long createCustomerLimitConfig(CrmCustomerLimitConfigSaveReqVO createReqVO) {
|
|
|
validateUserAndDept(createReqVO.getUserIds(), createReqVO.getDeptIds());
|
|
|
// 插入
|
|
|
CrmCustomerLimitConfigDO customerLimitConfig = CrmCustomerLimitConfigConvert.INSTANCE.convert(createReqVO);
|
|
|
customerLimitConfigMapper.insert(customerLimitConfig);
|
|
|
+
|
|
|
+ // 记录操作日志上下文
|
|
|
+ LogRecordContext.putVariable("limitType", CrmCustomerLimitConfigTypeEnum.getNameByType(customerLimitConfig.getType()));
|
|
|
+ LogRecordContext.putVariable("limitId", customerLimitConfig.getId());
|
|
|
// 返回
|
|
|
return customerLimitConfig.getId();
|
|
|
}
|
|
|
|
|
|
@Override
|
|
|
- // TODO @puhui999:操作日志
|
|
|
+ @LogRecord(type = CRM_CUSTOMER_LIMIT_CONFIG_TYPE, subType = CRM_CUSTOMER_LIMIT_CONFIG_UPDATE_SUB_TYPE, bizNo = "{{#updateReqVO.id}}", success = CRM_CUSTOMER_LIMIT_CONFIG_UPDATE_SUCCESS)
|
|
|
public void updateCustomerLimitConfig(CrmCustomerLimitConfigSaveReqVO updateReqVO) {
|
|
|
// 校验存在
|
|
|
- validateCustomerLimitConfigExists(updateReqVO.getId());
|
|
|
+ CrmCustomerLimitConfigDO oldLimitConfig = validateCustomerLimitConfigExists(updateReqVO.getId());
|
|
|
validateUserAndDept(updateReqVO.getUserIds(), updateReqVO.getDeptIds());
|
|
|
// 更新
|
|
|
CrmCustomerLimitConfigDO updateObj = CrmCustomerLimitConfigConvert.INSTANCE.convert(updateReqVO);
|
|
|
customerLimitConfigMapper.updateById(updateObj);
|
|
|
+
|
|
|
+ // 记录操作日志上下文
|
|
|
+ LogRecordContext.putVariable(DiffParseFunction.OLD_OBJECT, BeanUtils.toBean(oldLimitConfig, CrmCustomerLimitConfigSaveReqVO.class));
|
|
|
}
|
|
|
|
|
|
@Override
|
|
|
- // TODO @puhui999:操作日志
|
|
|
+ @LogRecord(type = CRM_CUSTOMER_LIMIT_CONFIG_TYPE, subType = CRM_CUSTOMER_LIMIT_CONFIG_DELETE_SUB_TYPE, bizNo = "{{#id}}", success = CRM_CUSTOMER_LIMIT_CONFIG_DELETE_SUCCESS)
|
|
|
public void deleteCustomerLimitConfig(Long id) {
|
|
|
// 校验存在
|
|
|
- validateCustomerLimitConfigExists(id);
|
|
|
+ CrmCustomerLimitConfigDO limitConfigDO = validateCustomerLimitConfigExists(id);
|
|
|
// 删除
|
|
|
customerLimitConfigMapper.deleteById(id);
|
|
|
+
|
|
|
+ // 记录操作日志上下文
|
|
|
+ LogRecordContext.putVariable("limitType", CrmCustomerLimitConfigTypeEnum.getNameByType(limitConfigDO.getType()));
|
|
|
}
|
|
|
|
|
|
@Override
|
|
@@ -78,10 +94,12 @@ public class CrmCustomerLimitConfigServiceImpl implements CrmCustomerLimitConfig
|
|
|
return customerLimitConfigMapper.selectPage(pageReqVO);
|
|
|
}
|
|
|
|
|
|
- private void validateCustomerLimitConfigExists(Long id) {
|
|
|
- if (customerLimitConfigMapper.selectById(id) == null) {
|
|
|
+ private CrmCustomerLimitConfigDO validateCustomerLimitConfigExists(Long id) {
|
|
|
+ CrmCustomerLimitConfigDO limitConfigDO = customerLimitConfigMapper.selectById(id);
|
|
|
+ if (limitConfigDO == null) {
|
|
|
throw exception(CUSTOMER_LIMIT_CONFIG_NOT_EXISTS);
|
|
|
}
|
|
|
+ return limitConfigDO;
|
|
|
}
|
|
|
|
|
|
/**
|