From 7e8b0d59a42c33d725bcef1a194931f7825da6a4 Mon Sep 17 00:00:00 2001 From: Yuriy Lytvynchuk Date: Mon, 5 Sep 2022 15:05:55 +0300 Subject: [PATCH] refactor code --- .../rule/engine/transform/TbCopyKeysNode.java | 43 +++++++++---------- 1 file changed, 21 insertions(+), 22 deletions(-) diff --git a/rule-engine/rule-engine-components/src/main/java/org/thingsboard/rule/engine/transform/TbCopyKeysNode.java b/rule-engine/rule-engine-components/src/main/java/org/thingsboard/rule/engine/transform/TbCopyKeysNode.java index 8072f72ec6..10a046d8d3 100644 --- a/rule-engine/rule-engine-components/src/main/java/org/thingsboard/rule/engine/transform/TbCopyKeysNode.java +++ b/rule-engine/rule-engine-components/src/main/java/org/thingsboard/rule/engine/transform/TbCopyKeysNode.java @@ -30,11 +30,10 @@ import org.thingsboard.server.common.msg.TbMsg; import org.thingsboard.server.common.msg.TbMsgMetaData; import java.util.ArrayList; +import java.util.Iterator; import java.util.List; import java.util.Map; -import java.util.Optional; import java.util.concurrent.ExecutionException; -import java.util.concurrent.atomic.AtomicBoolean; import java.util.regex.Pattern; @Slf4j @@ -44,8 +43,7 @@ import java.util.regex.Pattern; configClazz = TbCopyKeysNodeConfiguration.class, nodeDescription = "Copies the msg or metadata keys with specified key names selected in the list", nodeDetails = "Will fetch fields values specified in list. If specified field is not part of msg or metadata fields it will be ignored." + - "If the msg is not a JSON object returns the incoming message as outbound message with Failure chain, " + - "otherwise returns transformed messages via Success chain", + "Returns transformed messages via Success chain", uiResources = {"static/rulenode/rulenode-core-config.js"}, configDirective = "tbTransformationNodeCopyKeysConfig", icon = "content_copy" @@ -53,13 +51,14 @@ import java.util.regex.Pattern; public class TbCopyKeysNode implements TbNode { TbCopyKeysNodeConfiguration config; - List patternKeys = new ArrayList<>(); + List patternKeys; boolean fromMetadata; @Override public void init(TbContext ctx, TbNodeConfiguration configuration) throws TbNodeException { this.config = TbNodeUtils.convert(configuration, TbCopyKeysNodeConfiguration.class); this.fromMetadata = config.isFromMetadata(); + this.patternKeys = new ArrayList<>(); config.getKeys().forEach(key -> { this.patternKeys.add(Pattern.compile(key)); }); @@ -69,30 +68,33 @@ public class TbCopyKeysNode implements TbNode { public void onMsg(TbContext ctx, TbMsg msg) throws ExecutionException, InterruptedException, TbNodeException { TbMsgMetaData metaData = msg.getMetaData(); String msgData = msg.getData(); - AtomicBoolean msgChanged = new AtomicBoolean(false); + boolean msgChanged = false; JsonNode dataNode = JacksonUtil.toJsonNode(msgData); if (dataNode.isObject()) { if (fromMetadata) { ObjectNode msgDataNode = (ObjectNode) dataNode; Map metaDataMap = metaData.getData(); - metaDataMap.forEach((keyMetaData, valueMetaData) -> { - if (checkKey(keyMetaData)) { - msgChanged.set(true); - msgDataNode.put(keyMetaData, valueMetaData); - } - }); - msgData = JacksonUtil.toString(msgDataNode); - } else { - dataNode.fields().forEachRemaining(entry -> { + for (Map.Entry entry : metaDataMap.entrySet()) { String keyData = entry.getKey(); if (checkKey(keyData)) { - msgChanged.set(true); + msgChanged = true; + msgDataNode.put(keyData, entry.getValue()); + } + } + msgData = JacksonUtil.toString(msgDataNode); + } else { + Iterator> iteratorNode = dataNode.fields(); + while (iteratorNode.hasNext()) { + Map.Entry entry = iteratorNode.next(); + String keyData = entry.getKey(); + if (checkKey(keyData)) { + msgChanged = true; metaData.putValue(keyData, JacksonUtil.toString(entry.getValue())); } - }); + } } } - if (msgChanged.get()) { + if (msgChanged) { ctx.tellSuccess(TbMsg.transformMsg(msg, msg.getType(), msg.getOriginator(), metaData, msgData)); } else { ctx.tellSuccess(msg); @@ -100,10 +102,7 @@ public class TbCopyKeysNode implements TbNode { } boolean checkKey(String key) { - Optional currentPattern = patternKeys.stream() - .filter(pattern -> pattern.matcher(key).matches()) - .findFirst(); - return currentPattern.isPresent(); + return patternKeys.stream().anyMatch(pattern -> pattern.matcher(key).matches()); } @Override