From 5c56e5e1e66c8c0322e0aeee002c39ec210820c2 Mon Sep 17 00:00:00 2001 From: "chen.ma" Date: Sat, 6 Aug 2022 13:45:42 +0800 Subject: [PATCH] Remove custom log component (#460) --- README.md | 2 +- hippo4j-config/pom.xml | 10 +- ...ordMapper.java => OperationLogMapper.java} | 6 +- .../hippo4j/config}/model/LogRecordInfo.java | 54 +++-- ...zService.java => OperationLogService.java} | 16 +- .../service/biz/impl/ConfigServiceImpl.java | 44 ++-- .../biz/impl/LogRecordServiceImpl.java | 43 ---- ...Impl.java => OperationLogServiceImpl.java} | 18 +- .../service/biz/impl/TenantServiceImpl.java | 4 +- .../biz/impl/ThreadPoolServiceImpl.java | 37 ++- .../handler/CustomOperatorGetServiceImpl.java | 42 ---- .../handler/TenantIdFunctionServiceImpl.java | 56 ----- .../controller/LogRecordController.java | 6 +- .../cn/hippo4j/server/ServerApplication.java | 6 - hippo4j-tool/log-record-tool/pom.xml | 55 ----- .../tools/logrecord/annotation/LogField.java | 29 --- .../tools/logrecord/annotation/LogRecord.java | 98 -------- .../tools/logrecord/aop/LogRecordAspect.java | 224 ------------------ .../logrecord/config/LogRecordConfig.java | 86 ------- .../logrecord/context/LogRecordContext.java | 63 ----- .../logrecord/enums/LogRecordTypeEnum.java | 38 --- .../tools/logrecord/model/LogRecordOps.java | 49 ---- .../logrecord/model/MethodExecuteResult.java | 50 ---- .../tools/logrecord/model/Operator.java | 40 ---- .../parse/LogRecordEvaluationContext.java | 49 ---- .../parse/LogRecordExpressionEvaluator.java | 70 ------ .../parse/LogRecordOperationSource.java | 88 ------- .../logrecord/parse/LogRecordValueParser.java | 124 ---------- .../logrecord/service/FunctionService.java | 45 ---- .../logrecord/service/LogRecordService.java | 37 --- .../logrecord/service/OperatorGetService.java | 37 --- .../logrecord/service/ParseFunction.java | 52 ---- .../impl/DefaultFunctionServiceImpl.java | 49 ---- .../impl/DefaultLogRecordServiceImpl.java | 38 --- .../impl/DefaultOperatorGetServiceImpl.java | 36 --- .../service/impl/DefaultParseFunction.java | 45 ---- .../service/impl/ParseFunctionFactory.java | 73 ------ hippo4j-tool/pom.xml | 22 -- pom.xml | 2 - 39 files changed, 124 insertions(+), 1719 deletions(-) rename hippo4j-config/src/main/java/cn/hippo4j/config/mapper/{LogRecordMapper.java => OperationLogMapper.java} (87%) rename {hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord => hippo4j-config/src/main/java/cn/hippo4j/config}/model/LogRecordInfo.java (67%) rename hippo4j-config/src/main/java/cn/hippo4j/config/service/biz/{LogRecordBizService.java => OperationLogService.java} (82%) delete mode 100644 hippo4j-config/src/main/java/cn/hippo4j/config/service/biz/impl/LogRecordServiceImpl.java rename hippo4j-config/src/main/java/cn/hippo4j/config/service/biz/impl/{LogRecordBizServiceImpl.java => OperationLogServiceImpl.java} (79%) delete mode 100644 hippo4j-config/src/main/java/cn/hippo4j/config/service/handler/CustomOperatorGetServiceImpl.java delete mode 100644 hippo4j-config/src/main/java/cn/hippo4j/config/service/handler/TenantIdFunctionServiceImpl.java delete mode 100644 hippo4j-tool/log-record-tool/pom.xml delete mode 100644 hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/annotation/LogField.java delete mode 100644 hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/annotation/LogRecord.java delete mode 100644 hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/aop/LogRecordAspect.java delete mode 100644 hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/config/LogRecordConfig.java delete mode 100644 hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/context/LogRecordContext.java delete mode 100644 hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/enums/LogRecordTypeEnum.java delete mode 100644 hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/model/LogRecordOps.java delete mode 100644 hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/model/MethodExecuteResult.java delete mode 100644 hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/model/Operator.java delete mode 100644 hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/parse/LogRecordEvaluationContext.java delete mode 100644 hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/parse/LogRecordExpressionEvaluator.java delete mode 100644 hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/parse/LogRecordOperationSource.java delete mode 100644 hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/parse/LogRecordValueParser.java delete mode 100644 hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/service/FunctionService.java delete mode 100644 hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/service/LogRecordService.java delete mode 100644 hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/service/OperatorGetService.java delete mode 100644 hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/service/ParseFunction.java delete mode 100644 hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/service/impl/DefaultFunctionServiceImpl.java delete mode 100644 hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/service/impl/DefaultLogRecordServiceImpl.java delete mode 100644 hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/service/impl/DefaultOperatorGetServiceImpl.java delete mode 100644 hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/service/impl/DefaultParseFunction.java delete mode 100644 hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/service/impl/ParseFunctionFactory.java delete mode 100644 hippo4j-tool/pom.xml diff --git a/README.md b/README.md index ea99eb3a..9a70ef8d 100644 --- a/README.md +++ b/README.md @@ -65,7 +65,7 @@ Hippo-4J 获得了一些宝贵的荣誉,这属于每一位对 Hippo-4J 做出 ## 鸣谢 -Hippo-4J 项目基于或参考以下项目:[nacos](https://github.com/alibaba/nacos)、[eureka](https://github.com/Netflix/Eureka)、[mzt-biz-log](https://github.com/mouzt/mzt-biz-log)。 +Hippo-4J 项目基于或参考以下项目:[nacos](https://github.com/alibaba/nacos)、[eureka](https://github.com/Netflix/Eureka)。 感谢 JetBrains 提供的免费开源 License: diff --git a/hippo4j-config/pom.xml b/hippo4j-config/pom.xml index 5a32ebec..e947529a 100644 --- a/hippo4j-config/pom.xml +++ b/hippo4j-config/pom.xml @@ -55,11 +55,6 @@ lombok - - cn.hippo4j - log-record-tool - - cn.hippo4j hippo4j-adapter-base @@ -69,5 +64,10 @@ io.netty netty-all + + + org.hibernate.validator + hibernate-validator + diff --git a/hippo4j-config/src/main/java/cn/hippo4j/config/mapper/LogRecordMapper.java b/hippo4j-config/src/main/java/cn/hippo4j/config/mapper/OperationLogMapper.java similarity index 87% rename from hippo4j-config/src/main/java/cn/hippo4j/config/mapper/LogRecordMapper.java rename to hippo4j-config/src/main/java/cn/hippo4j/config/mapper/OperationLogMapper.java index 32b302b4..4e30d7d8 100644 --- a/hippo4j-config/src/main/java/cn/hippo4j/config/mapper/LogRecordMapper.java +++ b/hippo4j-config/src/main/java/cn/hippo4j/config/mapper/OperationLogMapper.java @@ -17,16 +17,16 @@ package cn.hippo4j.config.mapper; +import cn.hippo4j.config.model.LogRecordInfo; import com.baomidou.mybatisplus.core.mapper.BaseMapper; -import cn.hippo4j.tools.logrecord.model.LogRecordInfo; import org.apache.ibatis.annotations.Mapper; /** - * Log record mapper. + * Operation log mapper. * * @author chen.ma * @date 2021/10/24 21:01 */ @Mapper -public interface LogRecordMapper extends BaseMapper { +public interface OperationLogMapper extends BaseMapper { } diff --git a/hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/model/LogRecordInfo.java b/hippo4j-config/src/main/java/cn/hippo4j/config/model/LogRecordInfo.java similarity index 67% rename from hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/model/LogRecordInfo.java rename to hippo4j-config/src/main/java/cn/hippo4j/config/model/LogRecordInfo.java index bfec0d2f..5edef209 100644 --- a/hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/model/LogRecordInfo.java +++ b/hippo4j-config/src/main/java/cn/hippo4j/config/model/LogRecordInfo.java @@ -15,53 +15,71 @@ * limitations under the License. */ -package cn.hippo4j.tools.logrecord.model; +package cn.hippo4j.config.model; +import com.baomidou.mybatisplus.annotation.IdType; +import com.baomidou.mybatisplus.annotation.TableId; +import com.baomidou.mybatisplus.annotation.TableName; import lombok.AllArgsConstructor; import lombok.Builder; import lombok.Data; import lombok.NoArgsConstructor; -import org.hibernate.validator.constraints.Length; -import javax.validation.constraints.NotBlank; import java.util.Date; /** - * 日志记录实体. - * - * @author chen.ma - * @date 2021/10/24 17:47 + * Log record info. */ @Data @Builder -@AllArgsConstructor @NoArgsConstructor +@AllArgsConstructor +@TableName("log_record_info") public class LogRecordInfo { + /** + * ID + */ + @TableId(type = IdType.AUTO) private Long id; + /** + * Tenant + */ private String tenant; - @NotBlank(message = "bizKey required") - @Length(max = 200, message = "appKey max length is 200") + /** + * Biz key + */ private String bizKey; - @NotBlank(message = "bizNo required") - @Length(max = 200, message = "bizNo max length is 200") + /** + * Biz no + */ private String bizNo; - @NotBlank(message = "operator required") - @Length(max = 63, message = "operator max length 63") + /** + * Operator + */ private String operator; - @NotBlank(message = "opAction required") - @Length(max = 511, message = "operator max length 511") + /** + * Action + */ private String action; + /** + * Category + */ private String category; - private Date createTime; - + /** + * Detail + */ private String detail; + /** + * Create time + */ + private Date createTime; } diff --git a/hippo4j-config/src/main/java/cn/hippo4j/config/service/biz/LogRecordBizService.java b/hippo4j-config/src/main/java/cn/hippo4j/config/service/biz/OperationLogService.java similarity index 82% rename from hippo4j-config/src/main/java/cn/hippo4j/config/service/biz/LogRecordBizService.java rename to hippo4j-config/src/main/java/cn/hippo4j/config/service/biz/OperationLogService.java index f7eccea5..42bdf484 100644 --- a/hippo4j-config/src/main/java/cn/hippo4j/config/service/biz/LogRecordBizService.java +++ b/hippo4j-config/src/main/java/cn/hippo4j/config/service/biz/OperationLogService.java @@ -17,24 +17,28 @@ package cn.hippo4j.config.service.biz; +import cn.hippo4j.config.model.LogRecordInfo; import cn.hippo4j.config.model.biz.log.LogRecordQueryReqDTO; import cn.hippo4j.config.model.biz.log.LogRecordRespDTO; import com.baomidou.mybatisplus.core.metadata.IPage; /** - * 操作日志. - * - * @author chen.ma - * @date 2021/11/17 21:41 + * Operation log. */ -public interface LogRecordBizService { +public interface OperationLogService { /** - * 查询操作日志. + * Query operation log. * * @param pageQuery * @return */ IPage queryPage(LogRecordQueryReqDTO pageQuery); + /** + * Record. + * + * @param requestParam + */ + void record(LogRecordInfo requestParam); } diff --git a/hippo4j-config/src/main/java/cn/hippo4j/config/service/biz/impl/ConfigServiceImpl.java b/hippo4j-config/src/main/java/cn/hippo4j/config/service/biz/impl/ConfigServiceImpl.java index eaef6b99..1ad3fcd8 100644 --- a/hippo4j-config/src/main/java/cn/hippo4j/config/service/biz/impl/ConfigServiceImpl.java +++ b/hippo4j-config/src/main/java/cn/hippo4j/config/service/biz/impl/ConfigServiceImpl.java @@ -27,11 +27,12 @@ import cn.hippo4j.config.mapper.ConfigInstanceMapper; import cn.hippo4j.config.model.ConfigAllInfo; import cn.hippo4j.config.model.ConfigInfoBase; import cn.hippo4j.config.model.ConfigInstanceInfo; +import cn.hippo4j.config.model.LogRecordInfo; import cn.hippo4j.config.service.ConfigCacheService; import cn.hippo4j.config.service.ConfigChangePublisher; import cn.hippo4j.config.service.biz.ConfigService; +import cn.hippo4j.config.service.biz.OperationLogService; import cn.hippo4j.config.toolkit.BeanUtil; -import cn.hippo4j.tools.logrecord.annotation.LogRecord; import cn.hutool.core.util.StrUtil; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper; @@ -41,9 +42,7 @@ import lombok.AllArgsConstructor; import lombok.extern.slf4j.Slf4j; import org.springframework.stereotype.Service; -import java.util.List; -import java.util.Map; -import java.util.Objects; +import java.util.*; import java.util.concurrent.LinkedTransferQueue; import java.util.concurrent.SynchronousQueue; import java.util.stream.Collectors; @@ -53,9 +52,6 @@ import static cn.hippo4j.config.service.ConfigCacheService.getContent; /** * Config service impl. - * - * @author chen.ma - * @date 2021/6/20 15:21 */ @Slf4j @Service @@ -66,6 +62,8 @@ public class ConfigServiceImpl implements ConfigService { private final ConfigInstanceMapper configInstanceMapper; + private final OperationLogService operationLogService; + @Override public ConfigAllInfo findConfigAllInfo(String tpId, String itemId, String tenantId) { LambdaQueryWrapper wrapper = Wrappers.lambdaQuery(ConfigAllInfo.class) @@ -100,7 +98,7 @@ public class ConfigServiceImpl implements ConfigService { } ConfigAllInfo configAllInfo = findConfigAllInfo(params[0], params[1], params[2]); if (configAllInfo == null && configInstance == null) { - throw new ServiceException("Thread pool configuration is not defined."); + throw new ServiceException("Thread pool configuration is not defined"); } else if (configAllInfo != null && configInstance == null) { resultConfig = configAllInfo; } else if (configAllInfo == null && configInstance != null) { @@ -138,7 +136,7 @@ public class ConfigServiceImpl implements ConfigService { private void verification(String identify) { if (StringUtil.isNotBlank(identify)) { Map content = getContent(identify); - Assert.isTrue(CollectionUtil.isNotEmpty(content), "线程池实例不存在, 请尝试页面刷新."); + Assert.isTrue(CollectionUtil.isNotEmpty(content), "线程池实例不存在, 请尝试页面刷新"); } } @@ -146,13 +144,13 @@ public class ConfigServiceImpl implements ConfigService { config.setContent(ContentUtil.getPoolContent(config)); config.setMd5(Md5Util.getTpContentMd5(config)); try { - // 当前为单体应用, 后续支持集群部署时切换分布式锁. + // Currently it is a single application, and it supports switching distributed locks during cluster deployment in the future. synchronized (ConfigService.class) { ConfigAllInfo configAllInfo = configInfoMapper.selectOne( Wrappers.lambdaQuery(ConfigAllInfo.class) .eq(ConfigAllInfo::getTpId, config.getTpId()) .eq(ConfigAllInfo::getDelFlag, DelEnum.NORMAL.getIntCode())); - Assert.isNull(configAllInfo, "线程池配置已存在."); + Assert.isNull(configAllInfo, "线程池配置已存在"); if (SqlHelper.retBool(configInfoMapper.insert(config))) { return config.getId(); } @@ -164,7 +162,6 @@ public class ConfigServiceImpl implements ConfigService { return null; } - @LogRecord(bizNo = "{{#config.itemId}}_{{#config.tpId}}", category = "THREAD_POOL_UPDATE", success = "核心线程: {{#config.coreSize}}, 最大线程: {{#config.maxSize}}, 队列类型: {{#config.queueType}}, 队列容量: {{#config.capacity}}, 拒绝策略: {{#config.rejectedType}}", detail = "{{#config.toString()}}") public void updateConfigInfo(String identify, boolean isChangeNotice, ConfigAllInfo config) { LambdaUpdateWrapper wrapper = Wrappers.lambdaUpdate(ConfigAllInfo.class) .eq(ConfigAllInfo::getTpId, config.getTpId()) @@ -173,8 +170,10 @@ public class ConfigServiceImpl implements ConfigService { config.setGmtCreate(null); config.setContent(ContentUtil.getPoolContent(config)); config.setMd5(Md5Util.getTpContentMd5(config)); + recordOperationLog(config); try { - // 创建线程池配置实例临时配置, 也可以当作历史配置, 不过针对的是单节点 + // Create a temporary configuration of a thread pool configuration instance, + // which can also be used as a historical configuration, but it is aimed at a single node. if (StringUtil.isNotBlank(identify)) { ConfigInstanceInfo instanceInfo = BeanUtil.convert(config, ConfigInstanceInfo.class); instanceInfo.setInstanceId(identify); @@ -198,10 +197,23 @@ public class ConfigServiceImpl implements ConfigService { } } + private void recordOperationLog(ConfigAllInfo requestParam) { + LogRecordInfo logRecordInfo = LogRecordInfo.builder() + .bizKey(requestParam.getItemId() + "_" + requestParam.getTpId()) + .bizNo(requestParam.getItemId() + "_" + requestParam.getTpId()) + .operator(Optional.ofNullable(UserContext.getUserName()).orElse("-")) + .action(String.format("核心线程: %d, 最大线程: %d, 队列类型: %d, 队列容量: %d, 拒绝策略: %d", requestParam.getCoreSize(), requestParam.getMaxSize(), requestParam.getQueueType(), requestParam.getCapacity(), requestParam.getRejectedType())) + .category("THREAD_POOL_UPDATE") + .detail(JSONUtil.toJSONString(requestParam)) + .createTime(new Date()) + .build(); + operationLogService.record(logRecordInfo); + } + /** - * 根据队列类型获取队列大小. - *

- * 不支持设置队列大小 {@link SynchronousQueue} {@link LinkedTransferQueue} + * Get queue size based on queue type. + * + *

不支持设置队列大小 {@link SynchronousQueue} {@link LinkedTransferQueue} * * @param config * @return diff --git a/hippo4j-config/src/main/java/cn/hippo4j/config/service/biz/impl/LogRecordServiceImpl.java b/hippo4j-config/src/main/java/cn/hippo4j/config/service/biz/impl/LogRecordServiceImpl.java deleted file mode 100644 index d0f1d405..00000000 --- a/hippo4j-config/src/main/java/cn/hippo4j/config/service/biz/impl/LogRecordServiceImpl.java +++ /dev/null @@ -1,43 +0,0 @@ -/* - * Licensed to the Apache Software Foundation (ASF) under one or more - * contributor license agreements. See the NOTICE file distributed with - * this work for additional information regarding copyright ownership. - * The ASF licenses this file to You under the Apache License, Version 2.0 - * (the "License"); you may not use this file except in compliance with - * the License. You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -package cn.hippo4j.config.service.biz.impl; - -import cn.hippo4j.config.mapper.LogRecordMapper; -import cn.hippo4j.tools.logrecord.model.LogRecordInfo; -import cn.hippo4j.tools.logrecord.service.LogRecordService; -import lombok.AllArgsConstructor; -import org.springframework.stereotype.Service; - -/** - * 操作日志保存数据库. - * - * @author chen.ma - * @date 2021/10/24 20:57 - */ -@Service -@AllArgsConstructor -public class LogRecordServiceImpl implements LogRecordService { - - private final LogRecordMapper logRecordMapper; - - @Override - public void record(LogRecordInfo logRecordInfo) { - logRecordMapper.insert(logRecordInfo); - } - -} diff --git a/hippo4j-config/src/main/java/cn/hippo4j/config/service/biz/impl/LogRecordBizServiceImpl.java b/hippo4j-config/src/main/java/cn/hippo4j/config/service/biz/impl/OperationLogServiceImpl.java similarity index 79% rename from hippo4j-config/src/main/java/cn/hippo4j/config/service/biz/impl/LogRecordBizServiceImpl.java rename to hippo4j-config/src/main/java/cn/hippo4j/config/service/biz/impl/OperationLogServiceImpl.java index 760eb5d5..dd0ed0f0 100644 --- a/hippo4j-config/src/main/java/cn/hippo4j/config/service/biz/impl/LogRecordBizServiceImpl.java +++ b/hippo4j-config/src/main/java/cn/hippo4j/config/service/biz/impl/OperationLogServiceImpl.java @@ -17,12 +17,12 @@ package cn.hippo4j.config.service.biz.impl; -import cn.hippo4j.config.mapper.LogRecordMapper; +import cn.hippo4j.config.mapper.OperationLogMapper; +import cn.hippo4j.config.model.LogRecordInfo; import cn.hippo4j.config.model.biz.log.LogRecordQueryReqDTO; import cn.hippo4j.config.model.biz.log.LogRecordRespDTO; -import cn.hippo4j.config.service.biz.LogRecordBizService; +import cn.hippo4j.config.service.biz.OperationLogService; import cn.hippo4j.config.toolkit.BeanUtil; -import cn.hippo4j.tools.logrecord.model.LogRecordInfo; import cn.hutool.core.util.StrUtil; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.baomidou.mybatisplus.core.metadata.IPage; @@ -31,16 +31,16 @@ import lombok.AllArgsConstructor; import org.springframework.stereotype.Service; /** - * 操作日志. + * Operation log service impl. * * @author chen.ma * @date 2021/11/17 21:50 */ @Service @AllArgsConstructor -public class LogRecordBizServiceImpl implements LogRecordBizService { +public class OperationLogServiceImpl implements OperationLogService { - private final LogRecordMapper logRecordMapper; + private final OperationLogMapper operationLogMapper; @Override public IPage queryPage(LogRecordQueryReqDTO pageQuery) { @@ -49,8 +49,12 @@ public class LogRecordBizServiceImpl implements LogRecordBizService { .eq(StrUtil.isNotBlank(pageQuery.getCategory()), LogRecordInfo::getCategory, pageQuery.getCategory()) .eq(StrUtil.isNotBlank(pageQuery.getOperator()), LogRecordInfo::getOperator, pageQuery.getOperator()) .orderByDesc(LogRecordInfo::getCreateTime); - IPage selectPage = logRecordMapper.selectPage(pageQuery, queryWrapper); + IPage selectPage = operationLogMapper.selectPage(pageQuery, queryWrapper); return selectPage.convert(each -> BeanUtil.convert(each, LogRecordRespDTO.class)); } + @Override + public void record(LogRecordInfo requestParam) { + operationLogMapper.insert(requestParam); + } } diff --git a/hippo4j-config/src/main/java/cn/hippo4j/config/service/biz/impl/TenantServiceImpl.java b/hippo4j-config/src/main/java/cn/hippo4j/config/service/biz/impl/TenantServiceImpl.java index 6a9501f3..85950f2f 100644 --- a/hippo4j-config/src/main/java/cn/hippo4j/config/service/biz/impl/TenantServiceImpl.java +++ b/hippo4j-config/src/main/java/cn/hippo4j/config/service/biz/impl/TenantServiceImpl.java @@ -17,8 +17,8 @@ package cn.hippo4j.config.service.biz.impl; -import cn.hippo4j.common.toolkit.Assert; import cn.hippo4j.common.enums.DelEnum; +import cn.hippo4j.common.toolkit.Assert; import cn.hippo4j.config.mapper.TenantInfoMapper; import cn.hippo4j.config.model.TenantInfo; import cn.hippo4j.config.model.biz.item.ItemQueryReqDTO; @@ -30,7 +30,6 @@ import cn.hippo4j.config.model.biz.tenant.TenantUpdateReqDTO; import cn.hippo4j.config.service.biz.ItemService; import cn.hippo4j.config.service.biz.TenantService; import cn.hippo4j.config.toolkit.BeanUtil; -import cn.hippo4j.tools.logrecord.annotation.LogRecord; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.baomidou.mybatisplus.core.metadata.IPage; import com.baomidou.mybatisplus.core.toolkit.CollectionUtils; @@ -102,7 +101,6 @@ public class TenantServiceImpl implements TenantService { } @Override - @LogRecord(prefix = "item", bizNo = "{{#reqDTO.tenantId}}_{{#reqDTO.tenantName}}", category = "TENANT_UPDATE", success = "更新租户, ID :: {{#reqDTO.id}}, 租户名称由 :: {TENANT{#reqDTO.id}} -> {{#reqDTO.tenantName}}", detail = "{{#reqDTO.toString()}}") public void updateTenant(TenantUpdateReqDTO reqDTO) { TenantInfo tenantInfo = BeanUtil.convert(reqDTO, TenantInfo.class); int updateResult = tenantInfoMapper.update(tenantInfo, Wrappers diff --git a/hippo4j-config/src/main/java/cn/hippo4j/config/service/biz/impl/ThreadPoolServiceImpl.java b/hippo4j-config/src/main/java/cn/hippo4j/config/service/biz/impl/ThreadPoolServiceImpl.java index ebecdf8d..8e704112 100644 --- a/hippo4j-config/src/main/java/cn/hippo4j/config/service/biz/impl/ThreadPoolServiceImpl.java +++ b/hippo4j-config/src/main/java/cn/hippo4j/config/service/biz/impl/ThreadPoolServiceImpl.java @@ -18,16 +18,19 @@ package cn.hippo4j.config.service.biz.impl; import cn.hippo4j.common.enums.DelEnum; +import cn.hippo4j.common.toolkit.JSONUtil; +import cn.hippo4j.common.toolkit.UserContext; import cn.hippo4j.config.mapper.ConfigInfoMapper; import cn.hippo4j.config.model.ConfigAllInfo; +import cn.hippo4j.config.model.LogRecordInfo; import cn.hippo4j.config.model.biz.threadpool.ThreadPoolDelReqDTO; import cn.hippo4j.config.model.biz.threadpool.ThreadPoolQueryReqDTO; import cn.hippo4j.config.model.biz.threadpool.ThreadPoolRespDTO; import cn.hippo4j.config.model.biz.threadpool.ThreadPoolSaveOrUpdateReqDTO; import cn.hippo4j.config.service.biz.ConfigService; +import cn.hippo4j.config.service.biz.OperationLogService; import cn.hippo4j.config.service.biz.ThreadPoolService; import cn.hippo4j.config.toolkit.BeanUtil; -import cn.hippo4j.tools.logrecord.annotation.LogRecord; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.baomidou.mybatisplus.core.metadata.IPage; import com.baomidou.mybatisplus.core.toolkit.StringUtils; @@ -35,13 +38,12 @@ import com.baomidou.mybatisplus.core.toolkit.Wrappers; import lombok.AllArgsConstructor; import org.springframework.stereotype.Service; +import java.util.Date; import java.util.List; +import java.util.Optional; /** * Thread pool service impl. - * - * @author chen.ma - * @date 2021/6/30 21:26 */ @Service @AllArgsConstructor @@ -51,6 +53,8 @@ public class ThreadPoolServiceImpl implements ThreadPoolService { private final ConfigInfoMapper configInfoMapper; + private final OperationLogService operationLogService; + @Override public IPage queryThreadPoolPage(ThreadPoolQueryReqDTO reqDTO) { LambdaQueryWrapper wrapper = Wrappers.lambdaQuery(ConfigAllInfo.class) @@ -59,7 +63,6 @@ public class ThreadPoolServiceImpl implements ThreadPoolService { .eq(!StringUtils.isBlank(reqDTO.getTpId()), ConfigAllInfo::getTpId, reqDTO.getTpId()) .eq(ConfigAllInfo::getDelFlag, DelEnum.NORMAL) .orderByDesc(ConfigAllInfo::getGmtCreate); - return configInfoMapper.selectPage(reqDTO, wrapper).convert(each -> BeanUtil.convert(each, ThreadPoolRespDTO.class)); } @@ -73,7 +76,6 @@ public class ThreadPoolServiceImpl implements ThreadPoolService { public List getThreadPoolByItemId(String itemId) { LambdaQueryWrapper queryWrapper = Wrappers.lambdaQuery(ConfigAllInfo.class) .eq(ConfigAllInfo::getItemId, itemId); - List selectList = configInfoMapper.selectList(queryWrapper); return BeanUtil.convert(selectList, ThreadPoolRespDTO.class); } @@ -83,14 +85,27 @@ public class ThreadPoolServiceImpl implements ThreadPoolService { configService.insertOrUpdate(identify, false, BeanUtil.convert(reqDTO, ConfigAllInfo.class)); } - @LogRecord(bizNo = "{{#reqDTO.itemId}}_{{#reqDTO.tpId}}", category = "THREAD_POOL_DELETE", success = "删除线程池: {{#reqDTO.tpId}}", detail = "{{#reqDTO.toString()}}") @Override - public void deletePool(ThreadPoolDelReqDTO reqDTO) { + public void deletePool(ThreadPoolDelReqDTO requestParam) { configInfoMapper.delete( Wrappers.lambdaUpdate(ConfigAllInfo.class) - .eq(ConfigAllInfo::getTenantId, reqDTO.getTenantId()) - .eq(ConfigAllInfo::getItemId, reqDTO.getItemId()) - .eq(ConfigAllInfo::getTpId, reqDTO.getTpId())); + .eq(ConfigAllInfo::getTenantId, requestParam.getTenantId()) + .eq(ConfigAllInfo::getItemId, requestParam.getItemId()) + .eq(ConfigAllInfo::getTpId, requestParam.getTpId())); + recordOperationLog(requestParam); + } + + private void recordOperationLog(ThreadPoolDelReqDTO requestParam) { + LogRecordInfo logRecordInfo = LogRecordInfo.builder() + .bizKey(requestParam.getItemId() + "_" + requestParam.getTpId()) + .bizNo(requestParam.getItemId() + "_" + requestParam.getTpId()) + .operator(Optional.ofNullable(UserContext.getUserName()).orElse("-")) + .action("删除线程池: " + requestParam.getTpId()) + .category("THREAD_POOL_DELETE") + .detail(JSONUtil.toJSONString(requestParam)) + .createTime(new Date()) + .build(); + operationLogService.record(logRecordInfo); } @Override diff --git a/hippo4j-config/src/main/java/cn/hippo4j/config/service/handler/CustomOperatorGetServiceImpl.java b/hippo4j-config/src/main/java/cn/hippo4j/config/service/handler/CustomOperatorGetServiceImpl.java deleted file mode 100644 index 86cb7835..00000000 --- a/hippo4j-config/src/main/java/cn/hippo4j/config/service/handler/CustomOperatorGetServiceImpl.java +++ /dev/null @@ -1,42 +0,0 @@ -/* - * Licensed to the Apache Software Foundation (ASF) under one or more - * contributor license agreements. See the NOTICE file distributed with - * this work for additional information regarding copyright ownership. - * The ASF licenses this file to You under the Apache License, Version 2.0 - * (the "License"); you may not use this file except in compliance with - * the License. You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -package cn.hippo4j.config.service.handler; - -import cn.hippo4j.common.toolkit.StringUtil; -import cn.hippo4j.common.toolkit.UserContext; -import cn.hippo4j.tools.logrecord.model.Operator; -import cn.hippo4j.tools.logrecord.service.OperatorGetService; -import org.springframework.stereotype.Component; - -/** - * Custom operator get service. - * - * @author chen.ma - * @date 2021/11/28 17:57 - */ -@Component -public class CustomOperatorGetServiceImpl implements OperatorGetService { - - @Override - public Operator getUser() { - String userName = UserContext.getUserName(); - userName = StringUtil.isEmpty(userName) ? "-" : userName; - return new Operator(userName); - } - -} diff --git a/hippo4j-config/src/main/java/cn/hippo4j/config/service/handler/TenantIdFunctionServiceImpl.java b/hippo4j-config/src/main/java/cn/hippo4j/config/service/handler/TenantIdFunctionServiceImpl.java deleted file mode 100644 index e9073dfe..00000000 --- a/hippo4j-config/src/main/java/cn/hippo4j/config/service/handler/TenantIdFunctionServiceImpl.java +++ /dev/null @@ -1,56 +0,0 @@ -/* - * Licensed to the Apache Software Foundation (ASF) under one or more - * contributor license agreements. See the NOTICE file distributed with - * this work for additional information regarding copyright ownership. - * The ASF licenses this file to You under the Apache License, Version 2.0 - * (the "License"); you may not use this file except in compliance with - * the License. You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -package cn.hippo4j.config.service.handler; - -import cn.hippo4j.config.model.biz.tenant.TenantRespDTO; -import cn.hippo4j.config.service.biz.TenantService; -import cn.hippo4j.tools.logrecord.service.ParseFunction; -import lombok.AllArgsConstructor; -import org.springframework.stereotype.Component; - -import java.util.Optional; - -/** - * 查找原租户名称. - * - * @author chen.ma - * @date 2021/10/24 22:07 - */ -@Component -@AllArgsConstructor -public class TenantIdFunctionServiceImpl implements ParseFunction { - - private final TenantService tenantService; - - @Override - public boolean executeBefore() { - return true; - } - - @Override - public String functionName() { - return "TENANT"; - } - - @Override - public String apply(String tenantId) { - TenantRespDTO tenant = tenantService.getTenantById(tenantId); - return Optional.ofNullable(tenant).map(TenantRespDTO::getTenantName).orElse(""); - } - -} diff --git a/hippo4j-console/src/main/java/cn/hippo4j/console/controller/LogRecordController.java b/hippo4j-console/src/main/java/cn/hippo4j/console/controller/LogRecordController.java index 52dffbc7..de972232 100644 --- a/hippo4j-console/src/main/java/cn/hippo4j/console/controller/LogRecordController.java +++ b/hippo4j-console/src/main/java/cn/hippo4j/console/controller/LogRecordController.java @@ -22,7 +22,7 @@ import cn.hippo4j.common.web.base.Result; import cn.hippo4j.common.web.base.Results; import cn.hippo4j.config.model.biz.log.LogRecordQueryReqDTO; import cn.hippo4j.config.model.biz.log.LogRecordRespDTO; -import cn.hippo4j.config.service.biz.LogRecordBizService; +import cn.hippo4j.config.service.biz.OperationLogService; import com.baomidou.mybatisplus.core.metadata.IPage; import lombok.AllArgsConstructor; import org.springframework.web.bind.annotation.PostMapping; @@ -38,10 +38,10 @@ import org.springframework.web.bind.annotation.RestController; @RequestMapping(Constants.BASE_PATH + "/log") public class LogRecordController { - private final LogRecordBizService logRecordBizService; + private final OperationLogService operationLogService; @PostMapping("/query/page") public Result> queryPage(@RequestBody LogRecordQueryReqDTO queryReqDTO) { - return Results.success(logRecordBizService.queryPage(queryReqDTO)); + return Results.success(operationLogService.queryPage(queryReqDTO)); } } diff --git a/hippo4j-server/src/main/java/cn/hippo4j/server/ServerApplication.java b/hippo4j-server/src/main/java/cn/hippo4j/server/ServerApplication.java index 9871d0d6..239a632f 100644 --- a/hippo4j-server/src/main/java/cn/hippo4j/server/ServerApplication.java +++ b/hippo4j-server/src/main/java/cn/hippo4j/server/ServerApplication.java @@ -22,12 +22,6 @@ import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.transaction.annotation.EnableTransactionManagement; -/** - * Example application. - * - * @author chen.ma - * @date 2022/01/23 21:06 - */ @EnableTransactionManagement @SpringBootApplication(scanBasePackages = "cn.hippo4j") @MapperScan(basePackages = {"cn.hippo4j.config.mapper", "cn.hippo4j.auth.mapper"}) diff --git a/hippo4j-tool/log-record-tool/pom.xml b/hippo4j-tool/log-record-tool/pom.xml deleted file mode 100644 index 4dbf4844..00000000 --- a/hippo4j-tool/log-record-tool/pom.xml +++ /dev/null @@ -1,55 +0,0 @@ - - - 4.0.0 - - cn.hippo4j - hippo4j-tool - ${revision} - - log-record-tool - jar - log-record-tool - - - true - - - - - org.springframework.boot - spring-boot-starter - - - - org.springframework.boot - spring-boot-starter-test - test - - - - org.aspectj - aspectjweaver - - - - org.projectlombok - lombok - - - - com.alibaba - transmittable-thread-local - - - - com.google.guava - guava - - - - org.hibernate.validator - hibernate-validator - - - diff --git a/hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/annotation/LogField.java b/hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/annotation/LogField.java deleted file mode 100644 index 48bf9ee7..00000000 --- a/hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/annotation/LogField.java +++ /dev/null @@ -1,29 +0,0 @@ -/* - * Licensed to the Apache Software Foundation (ASF) under one or more - * contributor license agreements. See the NOTICE file distributed with - * this work for additional information regarding copyright ownership. - * The ASF licenses this file to You under the Apache License, Version 2.0 - * (the "License"); you may not use this file except in compliance with - * the License. You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -package cn.hippo4j.tools.logrecord.annotation; - -/** - * Log field, used to mark entity properties that need to be compared. - * - * @author chen.ma - * @date 2021/10/23 21:29 - */ -public @interface LogField { - - String name(); -} diff --git a/hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/annotation/LogRecord.java b/hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/annotation/LogRecord.java deleted file mode 100644 index 7a30ee1f..00000000 --- a/hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/annotation/LogRecord.java +++ /dev/null @@ -1,98 +0,0 @@ -/* - * Licensed to the Apache Software Foundation (ASF) under one or more - * contributor license agreements. See the NOTICE file distributed with - * this work for additional information regarding copyright ownership. - * The ASF licenses this file to You under the Apache License, Version 2.0 - * (the "License"); you may not use this file except in compliance with - * the License. You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -package cn.hippo4j.tools.logrecord.annotation; - -import cn.hippo4j.tools.logrecord.enums.LogRecordTypeEnum; - -import java.lang.annotation.*; - -/** - * 日志记录注解. - * - * @author chen.ma - * @date 2021/10/23 21:29 - */ -@Documented -@Target({ElementType.METHOD}) -@Retention(RetentionPolicy.RUNTIME) -public @interface LogRecord { - - /** - * 业务前缀 - * - * @return - */ - String prefix() default ""; - - /** - * 操作日志文本模版 - * - * @return - */ - String success(); - - /** - * 操作日志失败的文本 - * - * @return - */ - String fail() default ""; - - /** - * 操作人 - * - * @return - */ - String operator() default ""; - - /** - * 业务码 - * - * @return - */ - String bizNo(); - - /** - * 日志详情 - * - * @return - */ - String detail() default ""; - - /** - * 日志种类 - * - * @return - */ - String category(); - - /** - * 记录类型 - * - * @return - */ - LogRecordTypeEnum recordType() default LogRecordTypeEnum.COMPLETE; - - /** - * 记录日志条件 - * - * @return - */ - String condition() default ""; - -} diff --git a/hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/aop/LogRecordAspect.java b/hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/aop/LogRecordAspect.java deleted file mode 100644 index 510dfad2..00000000 --- a/hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/aop/LogRecordAspect.java +++ /dev/null @@ -1,224 +0,0 @@ -/* - * Licensed to the Apache Software Foundation (ASF) under one or more - * contributor license agreements. See the NOTICE file distributed with - * this work for additional information regarding copyright ownership. - * The ASF licenses this file to You under the Apache License, Version 2.0 - * (the "License"); you may not use this file except in compliance with - * the License. You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -package cn.hippo4j.tools.logrecord.aop; - -import cn.hippo4j.tools.logrecord.annotation.LogRecord; -import cn.hippo4j.tools.logrecord.context.LogRecordContext; -import cn.hippo4j.tools.logrecord.model.LogRecordInfo; -import cn.hippo4j.tools.logrecord.model.LogRecordOps; -import cn.hippo4j.tools.logrecord.model.MethodExecuteResult; -import cn.hippo4j.tools.logrecord.parse.LogRecordOperationSource; -import cn.hippo4j.tools.logrecord.parse.LogRecordValueParser; -import cn.hippo4j.tools.logrecord.service.LogRecordService; -import cn.hippo4j.tools.logrecord.service.OperatorGetService; -import com.google.common.base.Preconditions; -import com.google.common.collect.Lists; -import com.google.common.collect.Maps; -import lombok.AllArgsConstructor; -import lombok.extern.slf4j.Slf4j; -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.springframework.aop.framework.AopProxyUtils; -import org.springframework.core.env.ConfigurableEnvironment; -import org.springframework.stereotype.Component; -import org.springframework.util.CollectionUtils; -import org.springframework.util.StringUtils; - -import java.lang.reflect.Method; -import java.util.*; - -/** - * 日志记录切面. - * - * @author chen.ma - * @date 2021/10/23 22:00 - */ -@Slf4j -@Aspect -@Component -@AllArgsConstructor -public class LogRecordAspect { - - private final LogRecordService bizLogService; - - private final LogRecordValueParser logRecordValueParser; - - private final OperatorGetService operatorGetService; - - private final LogRecordOperationSource logRecordOperationSource; - - private final ConfigurableEnvironment environment; - - @Around("@annotation(logRecord)") - public Object logRecord(ProceedingJoinPoint joinPoint, LogRecord logRecord) throws Throwable { - MethodSignature methodSignature = (MethodSignature) joinPoint.getSignature(); - Method method = methodSignature.getMethod(); - Object target = joinPoint.getTarget(); - Class targetClass = AopProxyUtils.ultimateTargetClass(target); - Object[] args = joinPoint.getArgs(); - - LogRecordContext.putEmptySpan(); - - Object result = null; - Collection operations = Lists.newArrayList(); - Map functionNameAndReturnMap = Maps.newHashMap(); - MethodExecuteResult methodExecuteResult = new MethodExecuteResult(true); - - try { - operations = logRecordOperationSource.computeLogRecordOperations(method, targetClass); - List spElTemplates = getBeforeExecuteFunctionTemplate(operations); - functionNameAndReturnMap = logRecordValueParser.processBeforeExecuteFunctionTemplate(spElTemplates, targetClass, method, args); - - } catch (Exception ex) { - log.error("Log record parse before function exception.", ex); - } - - try { - result = joinPoint.proceed(); - } catch (Exception ex) { - methodExecuteResult = new MethodExecuteResult(false, ex, ex.getMessage()); - } - - try { - if (!CollectionUtils.isEmpty(operations)) { - recordExecute(result, method, args, operations, targetClass, - methodExecuteResult.isSuccess(), methodExecuteResult.getErrorMsg(), functionNameAndReturnMap); - } - } catch (Exception ex) { - log.error("Log record parse exception.", ex); - } finally { - LogRecordContext.clear(); - } - - if (methodExecuteResult.getThrowable() != null) { - throw methodExecuteResult.getThrowable(); - } - - return result; - - } - - private List getBeforeExecuteFunctionTemplate(Collection operations) { - List spElTemplates = new ArrayList(); - for (LogRecordOps operation : operations) { - // 执行之前的函数 - List templates = getSpElTemplates(operation, operation.getSuccessLogTemplate()); - if (!CollectionUtils.isEmpty(templates)) { - spElTemplates.addAll(templates); - } - } - - return spElTemplates; - } - - private List getSpElTemplates(LogRecordOps operation, String action) { - List spElTemplates = Lists.newArrayList(operation.getBizKey(), operation.getBizNo(), action, operation.getDetail()); - - if (!StringUtils.isEmpty(operation.getCondition())) { - spElTemplates.add(operation.getCondition()); - } - - return spElTemplates; - } - - /** - * 记录日志. - * - * @param ret - * @param method - * @param args - * @param operations - * @param targetClass - * @param success - * @param errorMsg - * @param functionNameAndReturnMap - */ - private void recordExecute(Object ret, Method method, Object[] args, Collection operations, - Class targetClass, boolean success, String errorMsg, Map functionNameAndReturnMap) { - for (LogRecordOps operation : operations) { - try { - String action = getActionContent(success, operation); - if (StringUtils.isEmpty(action)) { - // 没有日志内容则忽略 - continue; - } - // 获取需要解析的表达式 - List spElTemplates = getSpElTemplates(operation, action); - String operatorIdFromService = getOperatorIdFromServiceAndPutTemplate(operation, spElTemplates); - - Map expressionValues = logRecordValueParser.processTemplate(spElTemplates, ret, targetClass, method, args, errorMsg, functionNameAndReturnMap); - if (logConditionPassed(operation.getCondition(), expressionValues)) { - String tenant = environment.getProperty("tenant"); - LogRecordInfo logRecordInfo = LogRecordInfo.builder() - .tenant(StringUtils.isEmpty(tenant) ? "hippo4j" : tenant) - .bizKey(expressionValues.get(operation.getBizKey())) - .bizNo(expressionValues.get(operation.getBizNo())) - .operator(getRealOperatorId(operation, operatorIdFromService, expressionValues)) - .category(operation.getCategory()) - .detail(expressionValues.get(operation.getDetail())) - .action(expressionValues.get(action)) - .createTime(new Date()) - .build(); - - // 如果 action 为空, 不记录日志 - if (StringUtils.isEmpty(logRecordInfo.getAction())) { - continue; - } - // save log 需要新开事务, 失败日志不能因为事务回滚而丢失 - Preconditions.checkNotNull(bizLogService, "bizLogService not init"); - bizLogService.record(logRecordInfo); - } - } catch (Exception t) { - log.error("log record execute exception", t); - } - } - } - - private String getActionContent(boolean success, LogRecordOps operation) { - if (success) { - return operation.getSuccessLogTemplate(); - } - - return operation.getFailLogTemplate(); - } - - private String getOperatorIdFromServiceAndPutTemplate(LogRecordOps operation, List spElTemplates) { - String realOperatorId = ""; - if (StringUtils.isEmpty(operation.getOperatorId())) { - realOperatorId = operatorGetService.getUser().getOperatorId(); - if (StringUtils.isEmpty(realOperatorId)) { - throw new IllegalArgumentException("LogRecord operator is null"); - } - } else { - spElTemplates.add(operation.getOperatorId()); - } - - return realOperatorId; - } - - private boolean logConditionPassed(String condition, Map expressionValues) { - return StringUtils.isEmpty(condition) || StringUtils.endsWithIgnoreCase(expressionValues.get(condition), "true"); - } - - private String getRealOperatorId(LogRecordOps operation, String operatorIdFromService, Map expressionValues) { - return !StringUtils.isEmpty(operatorIdFromService) ? operatorIdFromService : expressionValues.get(operation.getOperatorId()); - } - -} diff --git a/hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/config/LogRecordConfig.java b/hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/config/LogRecordConfig.java deleted file mode 100644 index ff09136c..00000000 --- a/hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/config/LogRecordConfig.java +++ /dev/null @@ -1,86 +0,0 @@ -/* - * Licensed to the Apache Software Foundation (ASF) under one or more - * contributor license agreements. See the NOTICE file distributed with - * this work for additional information regarding copyright ownership. - * The ASF licenses this file to You under the Apache License, Version 2.0 - * (the "License"); you may not use this file except in compliance with - * the License. You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -package cn.hippo4j.tools.logrecord.config; - -import cn.hippo4j.tools.logrecord.parse.LogRecordOperationSource; -import cn.hippo4j.tools.logrecord.parse.LogRecordValueParser; -import cn.hippo4j.tools.logrecord.service.FunctionService; -import cn.hippo4j.tools.logrecord.service.LogRecordService; -import cn.hippo4j.tools.logrecord.service.OperatorGetService; -import cn.hippo4j.tools.logrecord.service.ParseFunction; -import cn.hippo4j.tools.logrecord.service.impl.*; -import org.springframework.beans.factory.annotation.Autowired; -import org.springframework.beans.factory.config.BeanDefinition; -import org.springframework.boot.autoconfigure.condition.ConditionalOnMissingBean; -import org.springframework.context.annotation.Bean; -import org.springframework.context.annotation.Configuration; -import org.springframework.context.annotation.Role; - -import java.util.List; - -/** - * 日志记录配置. - * - * @author chen.ma - * @date 2021/10/23 22:49 - */ -@Configuration -public class LogRecordConfig { - - @Bean - @ConditionalOnMissingBean(ParseFunction.class) - public DefaultParseFunction parseFunction() { - return new DefaultParseFunction(); - } - - @Bean - public ParseFunctionFactory parseFunctionFactory(@Autowired List parseFunctions) { - return new ParseFunctionFactory(parseFunctions); - } - - @Bean - @ConditionalOnMissingBean(FunctionService.class) - public FunctionService functionService(ParseFunctionFactory parseFunctionFactory) { - return new DefaultFunctionServiceImpl(parseFunctionFactory); - } - - @Bean - @Role(BeanDefinition.ROLE_APPLICATION) - @ConditionalOnMissingBean(OperatorGetService.class) - public OperatorGetService operatorGetService() { - return new DefaultOperatorGetServiceImpl(); - } - - @Bean - @ConditionalOnMissingBean(LogRecordService.class) - @Role(BeanDefinition.ROLE_APPLICATION) - public LogRecordService recordService() { - return new DefaultLogRecordServiceImpl(); - } - - @Bean - public LogRecordValueParser logRecordValueParser() { - return new LogRecordValueParser(); - } - - @Bean - public LogRecordOperationSource logRecordOperationSource() { - return new LogRecordOperationSource(); - } - -} diff --git a/hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/context/LogRecordContext.java b/hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/context/LogRecordContext.java deleted file mode 100644 index 07b819d5..00000000 --- a/hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/context/LogRecordContext.java +++ /dev/null @@ -1,63 +0,0 @@ -/* - * Licensed to the Apache Software Foundation (ASF) under one or more - * contributor license agreements. See the NOTICE file distributed with - * this work for additional information regarding copyright ownership. - * The ASF licenses this file to You under the Apache License, Version 2.0 - * (the "License"); you may not use this file except in compliance with - * the License. You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -package cn.hippo4j.tools.logrecord.context; - -import com.alibaba.ttl.TransmittableThreadLocal; -import com.google.common.collect.Maps; - -import java.util.Map; -import java.util.Stack; - -/** - * 日志记录上下文. - * - * @author chen.ma - * @date 2021/10/23 21:47 - */ -public class LogRecordContext { - - private static final ThreadLocal>> VARIABLE_MAP_STACK = new TransmittableThreadLocal(); - - /** - * 出栈. - */ - public static void clear() { - if (VARIABLE_MAP_STACK.get() != null) { - VARIABLE_MAP_STACK.get().pop(); - } - } - - /** - * 初始化. - */ - public static void putEmptySpan() { - Stack> mapStack = VARIABLE_MAP_STACK.get(); - if (mapStack == null) { - Stack> stack = new Stack<>(); - VARIABLE_MAP_STACK.set(stack); - } - - VARIABLE_MAP_STACK.get().push(Maps.newHashMap()); - } - - public static Map getVariables() { - Stack> mapStack = VARIABLE_MAP_STACK.get(); - return mapStack.peek(); - } - -} diff --git a/hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/enums/LogRecordTypeEnum.java b/hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/enums/LogRecordTypeEnum.java deleted file mode 100644 index b59af750..00000000 --- a/hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/enums/LogRecordTypeEnum.java +++ /dev/null @@ -1,38 +0,0 @@ -/* - * Licensed to the Apache Software Foundation (ASF) under one or more - * contributor license agreements. See the NOTICE file distributed with - * this work for additional information regarding copyright ownership. - * The ASF licenses this file to You under the Apache License, Version 2.0 - * (the "License"); you may not use this file except in compliance with - * the License. You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -package cn.hippo4j.tools.logrecord.enums; - -/** - * 日志记录类型. - * - * @author chen.ma - * @date 2021/10/24 21:54 - */ -public enum LogRecordTypeEnum { - - /** - * 按照文字模版记录 - */ - TEMPLATE, - - /** - * 比较修改前后所有区别 - */ - COMPLETE - -} diff --git a/hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/model/LogRecordOps.java b/hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/model/LogRecordOps.java deleted file mode 100644 index 82983b8a..00000000 --- a/hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/model/LogRecordOps.java +++ /dev/null @@ -1,49 +0,0 @@ -/* - * Licensed to the Apache Software Foundation (ASF) under one or more - * contributor license agreements. See the NOTICE file distributed with - * this work for additional information regarding copyright ownership. - * The ASF licenses this file to You under the Apache License, Version 2.0 - * (the "License"); you may not use this file except in compliance with - * the License. You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -package cn.hippo4j.tools.logrecord.model; - -import lombok.Builder; -import lombok.Data; - -/** - * 日志操作记录. - * - * @author chen.ma - * @date 2021/10/24 21:07 - */ -@Data -@Builder -public class LogRecordOps { - - private String successLogTemplate; - - private String failLogTemplate; - - private String operatorId; - - private String bizKey; - - private String bizNo; - - private String category; - - private String detail; - - private String condition; - -} diff --git a/hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/model/MethodExecuteResult.java b/hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/model/MethodExecuteResult.java deleted file mode 100644 index 41664fd1..00000000 --- a/hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/model/MethodExecuteResult.java +++ /dev/null @@ -1,50 +0,0 @@ -/* - * Licensed to the Apache Software Foundation (ASF) under one or more - * contributor license agreements. See the NOTICE file distributed with - * this work for additional information regarding copyright ownership. - * The ASF licenses this file to You under the Apache License, Version 2.0 - * (the "License"); you may not use this file except in compliance with - * the License. You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -package cn.hippo4j.tools.logrecord.model; - -import lombok.*; - -/** - * 方法执行结果. - * - * @author chen.ma - * @date 2021/10/24 21:59 - */ -@Data -@NoArgsConstructor -@AllArgsConstructor -@RequiredArgsConstructor -public class MethodExecuteResult { - - /** - * 是否成功 - */ - @NonNull - private boolean success; - - /** - * 异常 - */ - private Throwable throwable; - - /** - * 错误日志 - */ - private String errorMsg; - -} diff --git a/hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/model/Operator.java b/hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/model/Operator.java deleted file mode 100644 index 02a7c232..00000000 --- a/hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/model/Operator.java +++ /dev/null @@ -1,40 +0,0 @@ -/* - * Licensed to the Apache Software Foundation (ASF) under one or more - * contributor license agreements. See the NOTICE file distributed with - * this work for additional information regarding copyright ownership. - * The ASF licenses this file to You under the Apache License, Version 2.0 - * (the "License"); you may not use this file except in compliance with - * the License. You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -package cn.hippo4j.tools.logrecord.model; - -import lombok.AllArgsConstructor; -import lombok.Data; -import lombok.NoArgsConstructor; - -/** - * 操作人. - * - * @author chen.ma - * @date 2021/10/24 21:44 - */ -@Data -@NoArgsConstructor -@AllArgsConstructor -public class Operator { - - /** - * 操作人 Id - */ - private String operatorId; - -} diff --git a/hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/parse/LogRecordEvaluationContext.java b/hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/parse/LogRecordEvaluationContext.java deleted file mode 100644 index ff9d87de..00000000 --- a/hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/parse/LogRecordEvaluationContext.java +++ /dev/null @@ -1,49 +0,0 @@ -/* - * Licensed to the Apache Software Foundation (ASF) under one or more - * contributor license agreements. See the NOTICE file distributed with - * this work for additional information regarding copyright ownership. - * The ASF licenses this file to You under the Apache License, Version 2.0 - * (the "License"); you may not use this file except in compliance with - * the License. You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -package cn.hippo4j.tools.logrecord.parse; - -import cn.hippo4j.tools.logrecord.context.LogRecordContext; -import org.springframework.context.expression.MethodBasedEvaluationContext; -import org.springframework.core.ParameterNameDiscoverer; - -import java.lang.reflect.Method; -import java.util.Map; - -/** - * Log record evaluation context. - * - * @author chen.ma - * @date 2021/10/24 21:25 - */ -public class LogRecordEvaluationContext extends MethodBasedEvaluationContext { - - public LogRecordEvaluationContext(Object rootObject, Method method, Object[] arguments, - ParameterNameDiscoverer parameterNameDiscoverer, Object ret, String errorMsg) { - super(rootObject, method, arguments, parameterNameDiscoverer); - - Map variables = LogRecordContext.getVariables(); - if (variables != null && variables.size() > 0) { - for (Map.Entry entry : variables.entrySet()) { - setVariable(entry.getKey(), entry.getValue()); - } - } - - setVariable("_ret", ret); - setVariable("_errorMsg", errorMsg); - } -} diff --git a/hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/parse/LogRecordExpressionEvaluator.java b/hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/parse/LogRecordExpressionEvaluator.java deleted file mode 100644 index dddcba54..00000000 --- a/hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/parse/LogRecordExpressionEvaluator.java +++ /dev/null @@ -1,70 +0,0 @@ -/* - * Licensed to the Apache Software Foundation (ASF) under one or more - * contributor license agreements. See the NOTICE file distributed with - * this work for additional information regarding copyright ownership. - * The ASF licenses this file to You under the Apache License, Version 2.0 - * (the "License"); you may not use this file except in compliance with - * the License. You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -package cn.hippo4j.tools.logrecord.parse; - -import com.google.common.collect.Maps; -import org.springframework.aop.support.AopUtils; -import org.springframework.beans.factory.BeanFactory; -import org.springframework.context.expression.AnnotatedElementKey; -import org.springframework.context.expression.BeanFactoryResolver; -import org.springframework.context.expression.CachedExpressionEvaluator; -import org.springframework.expression.EvaluationContext; -import org.springframework.expression.Expression; - -import java.lang.reflect.Method; -import java.util.Map; - -/** - * Log record expression evaluator. - * - * @author chen.ma - * @date 2021/10/24 22:22 - */ -public class LogRecordExpressionEvaluator extends CachedExpressionEvaluator { - - private Map expressionCache = Maps.newConcurrentMap(); - - private final Map targetMethodCache = Maps.newConcurrentMap(); - - public String parseExpression(String conditionExpression, AnnotatedElementKey methodKey, EvaluationContext evalContext) { - Object value = getExpression(this.expressionCache, methodKey, conditionExpression).getValue(evalContext, Object.class); - return value == null ? "" : value.toString(); - } - - public EvaluationContext createEvaluationContext(Method method, Object[] args, Class targetClass, - Object result, String errorMsg, BeanFactory beanFactory) { - Method targetMethod = getTargetMethod(targetClass, method); - LogRecordEvaluationContext evaluationContext = new LogRecordEvaluationContext( - null, targetMethod, args, getParameterNameDiscoverer(), result, errorMsg); - if (beanFactory != null) { - evaluationContext.setBeanResolver(new BeanFactoryResolver(beanFactory)); - } - return evaluationContext; - } - - private Method getTargetMethod(Class targetClass, Method method) { - AnnotatedElementKey methodKey = new AnnotatedElementKey(method, targetClass); - Method targetMethod = this.targetMethodCache.get(methodKey); - if (targetMethod == null) { - targetMethod = AopUtils.getMostSpecificMethod(method, targetClass); - this.targetMethodCache.put(methodKey, targetMethod); - } - return targetMethod; - } - -} diff --git a/hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/parse/LogRecordOperationSource.java b/hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/parse/LogRecordOperationSource.java deleted file mode 100644 index 2e8837b2..00000000 --- a/hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/parse/LogRecordOperationSource.java +++ /dev/null @@ -1,88 +0,0 @@ -/* - * Licensed to the Apache Software Foundation (ASF) under one or more - * contributor license agreements. See the NOTICE file distributed with - * this work for additional information regarding copyright ownership. - * The ASF licenses this file to You under the Apache License, Version 2.0 - * (the "License"); you may not use this file except in compliance with - * the License. You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -package cn.hippo4j.tools.logrecord.parse; - -import cn.hippo4j.tools.logrecord.annotation.LogRecord; -import cn.hippo4j.tools.logrecord.model.LogRecordOps; -import org.springframework.core.BridgeMethodResolver; -import org.springframework.core.annotation.AnnotatedElementUtils; -import org.springframework.util.ClassUtils; -import org.springframework.util.StringUtils; - -import java.lang.reflect.AnnotatedElement; -import java.lang.reflect.Method; -import java.lang.reflect.Modifier; -import java.util.ArrayList; -import java.util.Collection; - -/** - * 日志记录操作解析. - * - * @author chen.ma - * @date 2021/10/23 22:02 - */ -public class LogRecordOperationSource { - - public Collection computeLogRecordOperations(Method method, Class targetClass) { - if (!Modifier.isPublic(method.getModifiers())) { - return null; - } - - Method specificMethod = ClassUtils.getMostSpecificMethod(method, targetClass); - specificMethod = BridgeMethodResolver.findBridgedMethod(specificMethod); - - return parseLogRecordAnnotations(specificMethod); - } - - private Collection parseLogRecordAnnotations(AnnotatedElement ae) { - Collection logRecordAnnotations = AnnotatedElementUtils.getAllMergedAnnotations(ae, LogRecord.class); - Collection ret = null; - if (!logRecordAnnotations.isEmpty()) { - ret = new ArrayList(1); - for (LogRecord logRecord : logRecordAnnotations) { - ret.add(parseLogRecordAnnotation(ae, logRecord)); - } - } - - return ret; - } - - private LogRecordOps parseLogRecordAnnotation(AnnotatedElement ae, LogRecord logRecord) { - LogRecordOps recordOps = LogRecordOps.builder() - .successLogTemplate(logRecord.success()) - .failLogTemplate(logRecord.fail()) - .bizKey(logRecord.prefix().concat(logRecord.bizNo())) - .bizNo(logRecord.bizNo()) - .operatorId(logRecord.operator()) - .category(StringUtils.isEmpty(logRecord.category()) ? logRecord.prefix() : logRecord.category()) - .detail(logRecord.detail()) - .condition(logRecord.condition()) - .build(); - - validateLogRecordOperation(ae, recordOps); - return recordOps; - } - - private void validateLogRecordOperation(AnnotatedElement ae, LogRecordOps recordOps) { - if (!StringUtils.hasText(recordOps.getSuccessLogTemplate()) && !StringUtils.hasText(recordOps.getFailLogTemplate())) { - throw new IllegalStateException("Invalid logRecord annotation configuration on '" + - ae.toString() + "'. 'one of successTemplate and failLogTemplate' attribute must be set."); - } - } - -} diff --git a/hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/parse/LogRecordValueParser.java b/hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/parse/LogRecordValueParser.java deleted file mode 100644 index a6ddee5c..00000000 --- a/hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/parse/LogRecordValueParser.java +++ /dev/null @@ -1,124 +0,0 @@ -/* - * Licensed to the Apache Software Foundation (ASF) under one or more - * contributor license agreements. See the NOTICE file distributed with - * this work for additional information regarding copyright ownership. - * The ASF licenses this file to You under the Apache License, Version 2.0 - * (the "License"); you may not use this file except in compliance with - * the License. You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -package cn.hippo4j.tools.logrecord.parse; - -import cn.hippo4j.tools.logrecord.service.FunctionService; -import com.google.common.base.Strings; -import com.google.common.collect.Maps; -import org.springframework.beans.BeansException; -import org.springframework.beans.factory.BeanFactory; -import org.springframework.beans.factory.BeanFactoryAware; -import org.springframework.beans.factory.annotation.Autowired; -import org.springframework.context.expression.AnnotatedElementKey; -import org.springframework.expression.EvaluationContext; -import org.springframework.util.StringUtils; - -import java.lang.reflect.Method; -import java.util.Collection; -import java.util.HashMap; -import java.util.Map; -import java.util.regex.Matcher; -import java.util.regex.Pattern; - -/** - * Log record value parser. - * - * @author chen.ma - * @date 2021/10/24 21:27 - */ -public class LogRecordValueParser implements BeanFactoryAware { - - @Autowired - private FunctionService functionService; - - protected BeanFactory beanFactory; - - private final LogRecordExpressionEvaluator expressionEvaluator = new LogRecordExpressionEvaluator(); - - private static final Pattern PATTERN = Pattern.compile("\\{\\s*(\\w*)\\s*\\{(.*?)}}"); - - public Map processTemplate(Collection templates, Object ret, - Class targetClass, Method method, Object[] args, String errorMsg, - Map beforeFunctionNameAndReturnMap) { - Map expressionValues = Maps.newHashMap(); - EvaluationContext evaluationContext = expressionEvaluator.createEvaluationContext(method, args, targetClass, ret, errorMsg, beanFactory); - - for (String expressionTemplate : templates) { - if (expressionTemplate.contains("{")) { - Matcher matcher = PATTERN.matcher(expressionTemplate); - StringBuffer parsedStr = new StringBuffer(); - while (matcher.find()) { - String expression = matcher.group(2); - AnnotatedElementKey annotatedElementKey = new AnnotatedElementKey(method, targetClass); - String value = expressionEvaluator.parseExpression(expression, annotatedElementKey, evaluationContext); - String functionReturnValue = getFunctionReturnValue(beforeFunctionNameAndReturnMap, value, matcher.group(1)); - matcher.appendReplacement(parsedStr, Strings.nullToEmpty(functionReturnValue)); - } - matcher.appendTail(parsedStr); - expressionValues.put(expressionTemplate, parsedStr.toString()); - } else { - expressionValues.put(expressionTemplate, expressionTemplate); - } - } - - return expressionValues; - } - - public Map processBeforeExecuteFunctionTemplate(Collection templates, Class targetClass, Method method, Object[] args) { - Map functionNameAndReturnValueMap = new HashMap(16); - EvaluationContext evaluationContext = expressionEvaluator.createEvaluationContext(method, args, targetClass, null, null, beanFactory); - - for (String expressionTemplate : templates) { - if (expressionTemplate.contains("{")) { - Matcher matcher = PATTERN.matcher(expressionTemplate); - while (matcher.find()) { - String expression = matcher.group(2); - if (expression.contains("#_ret") || expression.contains("#_errorMsg")) { - continue; - } - AnnotatedElementKey annotatedElementKey = new AnnotatedElementKey(method, targetClass); - String functionName = matcher.group(1); - if (functionService.beforeFunction(functionName)) { - String value = expressionEvaluator.parseExpression(expression, annotatedElementKey, evaluationContext); - String functionReturnValue = getFunctionReturnValue(null, value, functionName); - functionNameAndReturnValueMap.put(functionName, functionReturnValue); - } - } - } - } - - return functionNameAndReturnValueMap; - } - - private String getFunctionReturnValue(Map beforeFunctionNameAndReturnMap, String value, String functionName) { - String functionReturnValue = ""; - if (beforeFunctionNameAndReturnMap != null) { - functionReturnValue = beforeFunctionNameAndReturnMap.get(functionName); - } - if (StringUtils.isEmpty(functionReturnValue)) { - functionReturnValue = functionService.apply(functionName, value); - } - return functionReturnValue; - } - - @Override - public void setBeanFactory(BeanFactory beanFactory) throws BeansException { - this.beanFactory = beanFactory; - } - -} diff --git a/hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/service/FunctionService.java b/hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/service/FunctionService.java deleted file mode 100644 index f2e0d5ad..00000000 --- a/hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/service/FunctionService.java +++ /dev/null @@ -1,45 +0,0 @@ -/* - * Licensed to the Apache Software Foundation (ASF) under one or more - * contributor license agreements. See the NOTICE file distributed with - * this work for additional information regarding copyright ownership. - * The ASF licenses this file to You under the Apache License, Version 2.0 - * (the "License"); you may not use this file except in compliance with - * the License. You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -package cn.hippo4j.tools.logrecord.service; - -/** - * 函数服务. - * - * @author chen.ma - * @date 2021/10/24 21:30 - */ -public interface FunctionService { - - /** - * 执行. - * - * @param functionName - * @param value - * @return - */ - String apply(String functionName, String value); - - /** - * 是否提前执行. - * - * @param functionName - * @return - */ - boolean beforeFunction(String functionName); - -} diff --git a/hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/service/LogRecordService.java b/hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/service/LogRecordService.java deleted file mode 100644 index 8d12f6ff..00000000 --- a/hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/service/LogRecordService.java +++ /dev/null @@ -1,37 +0,0 @@ -/* - * Licensed to the Apache Software Foundation (ASF) under one or more - * contributor license agreements. See the NOTICE file distributed with - * this work for additional information regarding copyright ownership. - * The ASF licenses this file to You under the Apache License, Version 2.0 - * (the "License"); you may not use this file except in compliance with - * the License. You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -package cn.hippo4j.tools.logrecord.service; - -import cn.hippo4j.tools.logrecord.model.LogRecordInfo; - -/** - * 日志记录. - * - * @author chen.ma - * @date 2021/10/23 22:43 - */ -public interface LogRecordService { - - /** - * 保存日志. - * - * @param logRecordInfo - */ - void record(LogRecordInfo logRecordInfo); - -} diff --git a/hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/service/OperatorGetService.java b/hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/service/OperatorGetService.java deleted file mode 100644 index 592b48d1..00000000 --- a/hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/service/OperatorGetService.java +++ /dev/null @@ -1,37 +0,0 @@ -/* - * Licensed to the Apache Software Foundation (ASF) under one or more - * contributor license agreements. See the NOTICE file distributed with - * this work for additional information regarding copyright ownership. - * The ASF licenses this file to You under the Apache License, Version 2.0 - * (the "License"); you may not use this file except in compliance with - * the License. You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -package cn.hippo4j.tools.logrecord.service; - -import cn.hippo4j.tools.logrecord.model.Operator; - -/** - * 获取操作人. - * - * @author chen.ma - * @date 2021/10/23 22:46 - */ -public interface OperatorGetService { - - /** - * 获取操作人. - * - * @return - */ - Operator getUser(); - -} diff --git a/hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/service/ParseFunction.java b/hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/service/ParseFunction.java deleted file mode 100644 index bff082f2..00000000 --- a/hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/service/ParseFunction.java +++ /dev/null @@ -1,52 +0,0 @@ -/* - * Licensed to the Apache Software Foundation (ASF) under one or more - * contributor license agreements. See the NOTICE file distributed with - * this work for additional information regarding copyright ownership. - * The ASF licenses this file to You under the Apache License, Version 2.0 - * (the "License"); you may not use this file except in compliance with - * the License. You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -package cn.hippo4j.tools.logrecord.service; - -/** - * 函数解析. - * - * @author chen.ma - * @date 2021/10/23 22:40 - */ -public interface ParseFunction { - - /** - * 是否先执行. - * - * @return - */ - default boolean executeBefore() { - return false; - } - - /** - * 函数名称. - * - * @return - */ - String functionName(); - - /** - * 执行. - * - * @param value - * @return - */ - String apply(String value); - -} diff --git a/hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/service/impl/DefaultFunctionServiceImpl.java b/hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/service/impl/DefaultFunctionServiceImpl.java deleted file mode 100644 index 59069211..00000000 --- a/hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/service/impl/DefaultFunctionServiceImpl.java +++ /dev/null @@ -1,49 +0,0 @@ -/* - * Licensed to the Apache Software Foundation (ASF) under one or more - * contributor license agreements. See the NOTICE file distributed with - * this work for additional information regarding copyright ownership. - * The ASF licenses this file to You under the Apache License, Version 2.0 - * (the "License"); you may not use this file except in compliance with - * the License. You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -package cn.hippo4j.tools.logrecord.service.impl; - -import cn.hippo4j.tools.logrecord.service.FunctionService; -import cn.hippo4j.tools.logrecord.service.ParseFunction; -import lombok.AllArgsConstructor; - -/** - * 默认实现函数接口. - * - * @author chen.ma - * @date 2021/10/24 21:54 - */ -@AllArgsConstructor -public class DefaultFunctionServiceImpl implements FunctionService { - - private final ParseFunctionFactory parseFunctionFactory; - - @Override - public String apply(String functionName, String value) { - ParseFunction function = parseFunctionFactory.getFunction(functionName); - if (function == null) { - return value; - } - return function.apply(value); - } - - @Override - public boolean beforeFunction(String functionName) { - return parseFunctionFactory.isBeforeFunction(functionName); - } - -} diff --git a/hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/service/impl/DefaultLogRecordServiceImpl.java b/hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/service/impl/DefaultLogRecordServiceImpl.java deleted file mode 100644 index e37c0b9a..00000000 --- a/hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/service/impl/DefaultLogRecordServiceImpl.java +++ /dev/null @@ -1,38 +0,0 @@ -/* - * Licensed to the Apache Software Foundation (ASF) under one or more - * contributor license agreements. See the NOTICE file distributed with - * this work for additional information regarding copyright ownership. - * The ASF licenses this file to You under the Apache License, Version 2.0 - * (the "License"); you may not use this file except in compliance with - * the License. You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -package cn.hippo4j.tools.logrecord.service.impl; - -import cn.hippo4j.tools.logrecord.model.LogRecordInfo; -import cn.hippo4j.tools.logrecord.service.LogRecordService; -import lombok.extern.slf4j.Slf4j; - -/** - * 默认实现日志存储. - * - * @author chen.ma - * @date 2021/10/24 17:59 - */ -@Slf4j -public class DefaultLogRecordServiceImpl implements LogRecordService { - - @Override - public void record(LogRecordInfo logRecordInfo) { - log.info("Log print :: {}", logRecordInfo); - } - -} diff --git a/hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/service/impl/DefaultOperatorGetServiceImpl.java b/hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/service/impl/DefaultOperatorGetServiceImpl.java deleted file mode 100644 index 313823e5..00000000 --- a/hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/service/impl/DefaultOperatorGetServiceImpl.java +++ /dev/null @@ -1,36 +0,0 @@ -/* - * Licensed to the Apache Software Foundation (ASF) under one or more - * contributor license agreements. See the NOTICE file distributed with - * this work for additional information regarding copyright ownership. - * The ASF licenses this file to You under the Apache License, Version 2.0 - * (the "License"); you may not use this file except in compliance with - * the License. You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -package cn.hippo4j.tools.logrecord.service.impl; - -import cn.hippo4j.tools.logrecord.model.Operator; -import cn.hippo4j.tools.logrecord.service.OperatorGetService; - -/** - * 默认实现. - * - * @author chen.ma - * @date 2021/10/24 17:58 - */ -public class DefaultOperatorGetServiceImpl implements OperatorGetService { - - @Override - public Operator getUser() { - return new Operator("-"); - } - -} diff --git a/hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/service/impl/DefaultParseFunction.java b/hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/service/impl/DefaultParseFunction.java deleted file mode 100644 index 9334083e..00000000 --- a/hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/service/impl/DefaultParseFunction.java +++ /dev/null @@ -1,45 +0,0 @@ -/* - * Licensed to the Apache Software Foundation (ASF) under one or more - * contributor license agreements. See the NOTICE file distributed with - * this work for additional information regarding copyright ownership. - * The ASF licenses this file to You under the Apache License, Version 2.0 - * (the "License"); you may not use this file except in compliance with - * the License. You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -package cn.hippo4j.tools.logrecord.service.impl; - -import cn.hippo4j.tools.logrecord.service.ParseFunction; - -/** - * 默认实现. - * - * @author chen.ma - * @date 2021/10/24 17:57 - */ -public class DefaultParseFunction implements ParseFunction { - - @Override - public boolean executeBefore() { - return true; - } - - @Override - public String functionName() { - return null; - } - - @Override - public String apply(String value) { - return null; - } - -} diff --git a/hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/service/impl/ParseFunctionFactory.java b/hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/service/impl/ParseFunctionFactory.java deleted file mode 100644 index 64067aa8..00000000 --- a/hippo4j-tool/log-record-tool/src/main/java/cn/hippo4j/tools/logrecord/service/impl/ParseFunctionFactory.java +++ /dev/null @@ -1,73 +0,0 @@ -/* - * Licensed to the Apache Software Foundation (ASF) under one or more - * contributor license agreements. See the NOTICE file distributed with - * this work for additional information regarding copyright ownership. - * The ASF licenses this file to You under the Apache License, Version 2.0 - * (the "License"); you may not use this file except in compliance with - * the License. You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -package cn.hippo4j.tools.logrecord.service.impl; - -import cn.hippo4j.tools.logrecord.service.ParseFunction; -import com.google.common.collect.Maps; -import org.springframework.util.CollectionUtils; -import org.springframework.util.StringUtils; - -import java.util.List; -import java.util.Map; - -/** - * 函数解析工厂. - * - * @author chen.ma - * @date 2021/10/23 22:39 - */ -public class ParseFunctionFactory { - - private Map allFunctionMap; - - public ParseFunctionFactory(List parseFunctions) { - if (CollectionUtils.isEmpty(parseFunctions)) { - return; - } - - allFunctionMap = Maps.newHashMap(); - for (ParseFunction parseFunction : parseFunctions) { - if (StringUtils.isEmpty(parseFunction.functionName())) { - continue; - } - - allFunctionMap.put(parseFunction.functionName(), parseFunction); - } - } - - /** - * 获取函数实例. - * - * @param functionName - * @return - */ - public ParseFunction getFunction(String functionName) { - return allFunctionMap.get(functionName); - } - - /** - * 是否提前执行. - * - * @param functionName - * @return - */ - public boolean isBeforeFunction(String functionName) { - return allFunctionMap.get(functionName) != null && allFunctionMap.get(functionName).executeBefore(); - } - -} diff --git a/hippo4j-tool/pom.xml b/hippo4j-tool/pom.xml deleted file mode 100644 index 15cf1d1c..00000000 --- a/hippo4j-tool/pom.xml +++ /dev/null @@ -1,22 +0,0 @@ - - - 4.0.0 - - cn.hippo4j - hippo4j-all - ${revision} - - hippo4j-tool - pom - ${project.artifactId} - Dynamic thread pool tool class module - - - log-record-tool - - - - true - - diff --git a/pom.xml b/pom.xml index 3b771897..119bf973 100644 --- a/pom.xml +++ b/pom.xml @@ -7,7 +7,6 @@ hippo4j-all ${revision} pom - ${project.artifactId} Dynamic observable thread pool framework @@ -23,7 +22,6 @@ hippo4j-monitor hippo4j-server hippo4j-spring-boot - hippo4j-tool