houzhongyi
2024-07-11 e7c1260db32209a078a962aaa0ad5492c35774fb
提交 | 用户 | 时间
e7c126 1 package com.iailab.module.infra.service.logger;
H 2
3 import cn.hutool.core.util.StrUtil;
4 import com.iailab.framework.common.pojo.PageResult;
5 import com.iailab.framework.common.util.object.BeanUtils;
6 import com.iailab.module.infra.api.logger.dto.ApiAccessLogCreateReqDTO;
7 import com.iailab.module.infra.controller.admin.logger.vo.apiaccesslog.ApiAccessLogPageReqVO;
8 import com.iailab.module.infra.dal.dataobject.logger.ApiAccessLogDO;
9 import com.iailab.module.infra.dal.mysql.logger.ApiAccessLogMapper;
10 import lombok.extern.slf4j.Slf4j;
11 import org.springframework.stereotype.Service;
12 import org.springframework.validation.annotation.Validated;
13
14 import javax.annotation.Resource;
15 import java.time.LocalDateTime;
16
17 import static com.iailab.module.infra.dal.dataobject.logger.ApiAccessLogDO.REQUEST_PARAMS_MAX_LENGTH;
18 import static com.iailab.module.infra.dal.dataobject.logger.ApiAccessLogDO.RESULT_MSG_MAX_LENGTH;
19
20 /**
21  * API 访问日志 Service 实现类
22  *
23  * @author iailab
24  */
25 @Slf4j
26 @Service
27 @Validated
28 public class ApiAccessLogServiceImpl implements ApiAccessLogService {
29
30     @Resource
31     private ApiAccessLogMapper apiAccessLogMapper;
32
33     @Override
34     public void createApiAccessLog(ApiAccessLogCreateReqDTO createDTO) {
35         ApiAccessLogDO apiAccessLog = BeanUtils.toBean(createDTO, ApiAccessLogDO.class);
36         apiAccessLog.setRequestParams(StrUtil.maxLength(apiAccessLog.getRequestParams(), REQUEST_PARAMS_MAX_LENGTH));
37         apiAccessLog.setResultMsg(StrUtil.maxLength(apiAccessLog.getResultMsg(), RESULT_MSG_MAX_LENGTH));
38         apiAccessLogMapper.insert(apiAccessLog);
39     }
40
41     @Override
42     public PageResult<ApiAccessLogDO> getApiAccessLogPage(ApiAccessLogPageReqVO pageReqVO) {
43         return apiAccessLogMapper.selectPage(pageReqVO);
44     }
45
46     @Override
47     @SuppressWarnings("DuplicatedCode")
48     public Integer cleanAccessLog(Integer exceedDay, Integer deleteLimit) {
49         int count = 0;
50         LocalDateTime expireDate = LocalDateTime.now().minusDays(exceedDay);
51         // 循环删除,直到没有满足条件的数据
52         for (int i = 0; i < Short.MAX_VALUE; i++) {
53             int deleteCount = apiAccessLogMapper.deleteByCreateTimeLt(expireDate, deleteLimit);
54             count += deleteCount;
55             // 达到删除预期条数,说明到底了
56             if (deleteCount < deleteLimit) {
57                 break;
58             }
59         }
60         return count;
61     }
62
63 }