Showing
100 changed files
with
1315 additions
and
307 deletions
Too many changes to show.
To preserve performance only 100 of 110 files are displayed.
@@ -58,6 +58,7 @@ import org.thingsboard.server.dao.customer.CustomerService; | @@ -58,6 +58,7 @@ import org.thingsboard.server.dao.customer.CustomerService; | ||
58 | import org.thingsboard.server.dao.dashboard.DashboardService; | 58 | import org.thingsboard.server.dao.dashboard.DashboardService; |
59 | import org.thingsboard.server.dao.device.ClaimDevicesService; | 59 | import org.thingsboard.server.dao.device.ClaimDevicesService; |
60 | import org.thingsboard.server.dao.device.DeviceService; | 60 | import org.thingsboard.server.dao.device.DeviceService; |
61 | +import org.thingsboard.server.dao.edge.EdgeEventService; | ||
61 | import org.thingsboard.server.dao.edge.EdgeService; | 62 | import org.thingsboard.server.dao.edge.EdgeService; |
62 | import org.thingsboard.server.dao.entityview.EntityViewService; | 63 | import org.thingsboard.server.dao.entityview.EntityViewService; |
63 | import org.thingsboard.server.dao.event.EventService; | 64 | import org.thingsboard.server.dao.event.EventService; |
@@ -258,6 +259,11 @@ public class ActorSystemContext { | @@ -258,6 +259,11 @@ public class ActorSystemContext { | ||
258 | @Getter | 259 | @Getter |
259 | private EdgeService edgeService; | 260 | private EdgeService edgeService; |
260 | 261 | ||
262 | + @Lazy | ||
263 | + @Autowired | ||
264 | + @Getter | ||
265 | + private EdgeEventService edgeEventService; | ||
266 | + | ||
261 | @Value("${actors.session.max_concurrent_sessions_per_device:1}") | 267 | @Value("${actors.session.max_concurrent_sessions_per_device:1}") |
262 | @Getter | 268 | @Getter |
263 | private long maxConcurrentSessionsPerDevice; | 269 | private long maxConcurrentSessionsPerDevice; |
@@ -51,6 +51,7 @@ import org.thingsboard.server.dao.cassandra.CassandraCluster; | @@ -51,6 +51,7 @@ import org.thingsboard.server.dao.cassandra.CassandraCluster; | ||
51 | import org.thingsboard.server.dao.customer.CustomerService; | 51 | import org.thingsboard.server.dao.customer.CustomerService; |
52 | import org.thingsboard.server.dao.dashboard.DashboardService; | 52 | import org.thingsboard.server.dao.dashboard.DashboardService; |
53 | import org.thingsboard.server.dao.device.DeviceService; | 53 | import org.thingsboard.server.dao.device.DeviceService; |
54 | +import org.thingsboard.server.dao.edge.EdgeEventService; | ||
54 | import org.thingsboard.server.dao.edge.EdgeService; | 55 | import org.thingsboard.server.dao.edge.EdgeService; |
55 | import org.thingsboard.server.dao.entityview.EntityViewService; | 56 | import org.thingsboard.server.dao.entityview.EntityViewService; |
56 | import org.thingsboard.server.dao.nosql.CassandraStatementTask; | 57 | import org.thingsboard.server.dao.nosql.CassandraStatementTask; |
@@ -407,6 +408,11 @@ class DefaultTbContext implements TbContext { | @@ -407,6 +408,11 @@ class DefaultTbContext implements TbContext { | ||
407 | } | 408 | } |
408 | 409 | ||
409 | @Override | 410 | @Override |
411 | + public EdgeEventService getEdgeEventService() { | ||
412 | + return mainCtx.getEdgeEventService(); | ||
413 | + } | ||
414 | + | ||
415 | + @Override | ||
410 | public EventLoopGroup getSharedEventLoop() { | 416 | public EventLoopGroup getSharedEventLoop() { |
411 | return mainCtx.getSharedEventLoopGroupService().getSharedEventLoopGroup(); | 417 | return mainCtx.getSharedEventLoopGroupService().getSharedEventLoopGroup(); |
412 | } | 418 | } |
@@ -18,14 +18,11 @@ package org.thingsboard.server.actors.ruleChain; | @@ -18,14 +18,11 @@ package org.thingsboard.server.actors.ruleChain; | ||
18 | import akka.actor.ActorContext; | 18 | import akka.actor.ActorContext; |
19 | import akka.actor.ActorRef; | 19 | import akka.actor.ActorRef; |
20 | import akka.actor.Props; | 20 | import akka.actor.Props; |
21 | -import com.google.common.util.concurrent.FutureCallback; | ||
22 | -import com.sun.istack.Nullable; | ||
23 | import lombok.extern.slf4j.Slf4j; | 21 | import lombok.extern.slf4j.Slf4j; |
24 | import org.thingsboard.rule.engine.api.TbRelationTypes; | 22 | import org.thingsboard.rule.engine.api.TbRelationTypes; |
25 | import org.thingsboard.server.actors.ActorSystemContext; | 23 | import org.thingsboard.server.actors.ActorSystemContext; |
26 | import org.thingsboard.server.actors.service.DefaultActorService; | 24 | import org.thingsboard.server.actors.service.DefaultActorService; |
27 | import org.thingsboard.server.actors.shared.ComponentMsgProcessor; | 25 | import org.thingsboard.server.actors.shared.ComponentMsgProcessor; |
28 | -import org.thingsboard.server.common.data.DataConstants; | ||
29 | import org.thingsboard.server.common.data.EntityType; | 26 | import org.thingsboard.server.common.data.EntityType; |
30 | import org.thingsboard.server.common.data.id.EntityId; | 27 | import org.thingsboard.server.common.data.id.EntityId; |
31 | import org.thingsboard.server.common.data.id.RuleChainId; | 28 | import org.thingsboard.server.common.data.id.RuleChainId; |
@@ -102,7 +99,7 @@ public class RuleChainActorMessageProcessor extends ComponentMsgProcessor<RuleCh | @@ -102,7 +99,7 @@ public class RuleChainActorMessageProcessor extends ComponentMsgProcessor<RuleCh | ||
102 | if (!started) { | 99 | if (!started) { |
103 | RuleChain ruleChain = service.findRuleChainById(tenantId, entityId); | 100 | RuleChain ruleChain = service.findRuleChainById(tenantId, entityId); |
104 | if (ruleChain != null) { | 101 | if (ruleChain != null) { |
105 | - if (ruleChain.getType().equals(RuleChainType.SYSTEM)) { | 102 | + if (ruleChain.getType().equals(RuleChainType.CORE)) { |
106 | List<RuleNode> ruleNodeList = service.getRuleChainNodes(tenantId, entityId); | 103 | List<RuleNode> ruleNodeList = service.getRuleChainNodes(tenantId, entityId); |
107 | log.trace("[{}][{}] Starting rule chain with {} nodes", tenantId, entityId, ruleNodeList.size()); | 104 | log.trace("[{}][{}] Starting rule chain with {} nodes", tenantId, entityId, ruleNodeList.size()); |
108 | // Creating and starting the actors; | 105 | // Creating and starting the actors; |
@@ -124,7 +121,7 @@ public class RuleChainActorMessageProcessor extends ComponentMsgProcessor<RuleCh | @@ -124,7 +121,7 @@ public class RuleChainActorMessageProcessor extends ComponentMsgProcessor<RuleCh | ||
124 | public void onUpdate(ActorContext context) { | 121 | public void onUpdate(ActorContext context) { |
125 | RuleChain ruleChain = service.findRuleChainById(tenantId, entityId); | 122 | RuleChain ruleChain = service.findRuleChainById(tenantId, entityId); |
126 | if (ruleChain != null) { | 123 | if (ruleChain != null) { |
127 | - if (ruleChain.getType().equals(RuleChainType.SYSTEM)) { | 124 | + if (ruleChain.getType().equals(RuleChainType.CORE)) { |
128 | ruleChainName = ruleChain.getName(); | 125 | ruleChainName = ruleChain.getName(); |
129 | List<RuleNode> ruleNodeList = service.getRuleChainNodes(tenantId, entityId); | 126 | List<RuleNode> ruleNodeList = service.getRuleChainNodes(tenantId, entityId); |
130 | log.trace("[{}][{}] Updating rule chain with {} nodes", tenantId, entityId, ruleNodeList.size()); | 127 | log.trace("[{}][{}] Updating rule chain with {} nodes", tenantId, entityId, ruleNodeList.size()); |
@@ -224,7 +221,6 @@ public class RuleChainActorMessageProcessor extends ComponentMsgProcessor<RuleCh | @@ -224,7 +221,6 @@ public class RuleChainActorMessageProcessor extends ComponentMsgProcessor<RuleCh | ||
224 | if (targetCtx != null) { | 221 | if (targetCtx != null) { |
225 | log.trace("[{}][{}] Pushing message to target rule node", entityId, targetId); | 222 | log.trace("[{}][{}] Pushing message to target rule node", entityId, targetId); |
226 | pushMsgToNode(targetCtx, msg, ""); | 223 | pushMsgToNode(targetCtx, msg, ""); |
227 | - pushUpdatesToEdges(msg); | ||
228 | } else { | 224 | } else { |
229 | log.trace("[{}][{}] Rule node does not exist. Probably old message", entityId, targetId); | 225 | log.trace("[{}][{}] Rule node does not exist. Probably old message", entityId, targetId); |
230 | msg.getCallback().onSuccess(); | 226 | msg.getCallback().onSuccess(); |
@@ -354,30 +350,6 @@ public class RuleChainActorMessageProcessor extends ComponentMsgProcessor<RuleCh | @@ -354,30 +350,6 @@ public class RuleChainActorMessageProcessor extends ComponentMsgProcessor<RuleCh | ||
354 | } | 350 | } |
355 | } | 351 | } |
356 | 352 | ||
357 | - private void pushUpdatesToEdges(TbMsg msg) { | ||
358 | - switch (msg.getType()) { | ||
359 | - case DataConstants.ENTITY_CREATED: | ||
360 | - case DataConstants.ENTITY_UPDATED: | ||
361 | - case DataConstants.ENTITY_DELETED: | ||
362 | - case DataConstants.ENTITY_ASSIGNED_TO_EDGE: | ||
363 | - case DataConstants.ENTITY_UNASSIGNED_FROM_EDGE: | ||
364 | - case DataConstants.ALARM_ACK: | ||
365 | - case DataConstants.ALARM_CLEAR: | ||
366 | - edgeService.pushEventToEdge(tenantId, msg, new FutureCallback<Void>() { | ||
367 | - @Override | ||
368 | - public void onSuccess(@Nullable Void aVoid) { | ||
369 | - log.debug("Event saved successfully!"); | ||
370 | - } | ||
371 | - | ||
372 | - @Override | ||
373 | - public void onFailure(Throwable t) { | ||
374 | - log.debug("Failure during event save", t); | ||
375 | - } | ||
376 | - }); | ||
377 | - } | ||
378 | - | ||
379 | - } | ||
380 | - | ||
381 | @Override | 353 | @Override |
382 | protected RuleNodeException getInactiveException() { | 354 | protected RuleNodeException getInactiveException() { |
383 | RuleNode firstRuleNode = firstNode != null ? firstNode.getSelf() : null; | 355 | RuleNode firstRuleNode = firstNode != null ? firstNode.getSelf() : null; |
@@ -56,7 +56,7 @@ public abstract class RuleChainManagerActor extends ContextAwareActor { | @@ -56,7 +56,7 @@ public abstract class RuleChainManagerActor extends ContextAwareActor { | ||
56 | } | 56 | } |
57 | 57 | ||
58 | protected void initRuleChains() { | 58 | protected void initRuleChains() { |
59 | - for (RuleChain ruleChain : new PageDataIterable<>(link -> ruleChainService.findTenantRuleChainsByType(tenantId, RuleChainType.SYSTEM, link), ContextAwareActor.ENTITY_PACK_LIMIT)) { | 59 | + for (RuleChain ruleChain : new PageDataIterable<>(link -> ruleChainService.findTenantRuleChainsByType(tenantId, RuleChainType.CORE, link), ContextAwareActor.ENTITY_PACK_LIMIT)) { |
60 | RuleChainId ruleChainId = ruleChain.getId(); | 60 | RuleChainId ruleChainId = ruleChain.getId(); |
61 | log.debug("[{}|{}] Creating rule chain actor", ruleChainId.getEntityType(), ruleChain.getId()); | 61 | log.debug("[{}|{}] Creating rule chain actor", ruleChainId.getEntityType(), ruleChain.getId()); |
62 | //TODO: remove this cast making UUIDBased subclass of EntityId an interface and vice versa. | 62 | //TODO: remove this cast making UUIDBased subclass of EntityId an interface and vice versa. |
@@ -67,7 +67,7 @@ public abstract class RuleChainManagerActor extends ContextAwareActor { | @@ -67,7 +67,7 @@ public abstract class RuleChainManagerActor extends ContextAwareActor { | ||
67 | } | 67 | } |
68 | 68 | ||
69 | protected void visit(RuleChain entity, ActorRef actorRef) { | 69 | protected void visit(RuleChain entity, ActorRef actorRef) { |
70 | - if (entity != null && entity.isRoot() && entity.getType().equals(RuleChainType.SYSTEM)) { | 70 | + if (entity != null && entity.isRoot() && entity.getType().equals(RuleChainType.CORE)) { |
71 | rootChain = entity; | 71 | rootChain = entity; |
72 | rootChainActor = actorRef; | 72 | rootChainActor = actorRef; |
73 | } | 73 | } |
@@ -206,7 +206,7 @@ public class TenantActor extends RuleChainManagerActor { | @@ -206,7 +206,7 @@ public class TenantActor extends RuleChainManagerActor { | ||
206 | if (msg.getEntityId().getEntityType() == EntityType.RULE_CHAIN) { | 206 | if (msg.getEntityId().getEntityType() == EntityType.RULE_CHAIN) { |
207 | RuleChain ruleChain = systemContext.getRuleChainService(). | 207 | RuleChain ruleChain = systemContext.getRuleChainService(). |
208 | findRuleChainById(tenantId, new RuleChainId(msg.getEntityId().getId())); | 208 | findRuleChainById(tenantId, new RuleChainId(msg.getEntityId().getId())); |
209 | - if (ruleChain != null && ruleChain.getType().equals(RuleChainType.SYSTEM)) { | 209 | + if (ruleChain != null && ruleChain.getType().equals(RuleChainType.CORE)) { |
210 | visit(ruleChain, target); | 210 | visit(ruleChain, target); |
211 | } | 211 | } |
212 | } | 212 | } |
@@ -125,6 +125,8 @@ public class AlarmController extends BaseController { | @@ -125,6 +125,8 @@ public class AlarmController extends BaseController { | ||
125 | alarmService.ackAlarm(getCurrentUser().getTenantId(), alarmId, ackTs).get(); | 125 | alarmService.ackAlarm(getCurrentUser().getTenantId(), alarmId, ackTs).get(); |
126 | alarm.setAckTs(ackTs); | 126 | alarm.setAckTs(ackTs); |
127 | logEntityAction(alarmId, alarm, getCurrentUser().getCustomerId(), ActionType.ALARM_ACK, null); | 127 | logEntityAction(alarmId, alarm, getCurrentUser().getCustomerId(), ActionType.ALARM_ACK, null); |
128 | + | ||
129 | + sendNotificationMsgToEdgeService(getTenantId(), alarmId, ActionType.ALARM_ACK); | ||
128 | } catch (Exception e) { | 130 | } catch (Exception e) { |
129 | throw handleException(e); | 131 | throw handleException(e); |
130 | } | 132 | } |
@@ -142,6 +144,8 @@ public class AlarmController extends BaseController { | @@ -142,6 +144,8 @@ public class AlarmController extends BaseController { | ||
142 | alarmService.clearAlarm(getCurrentUser().getTenantId(), alarmId, null, clearTs).get(); | 144 | alarmService.clearAlarm(getCurrentUser().getTenantId(), alarmId, null, clearTs).get(); |
143 | alarm.setClearTs(clearTs); | 145 | alarm.setClearTs(clearTs); |
144 | logEntityAction(alarmId, alarm, getCurrentUser().getCustomerId(), ActionType.ALARM_CLEAR, null); | 146 | logEntityAction(alarmId, alarm, getCurrentUser().getCustomerId(), ActionType.ALARM_CLEAR, null); |
147 | + | ||
148 | + sendNotificationMsgToEdgeService(getTenantId(), alarmId, ActionType.ALARM_CLEAR); | ||
145 | } catch (Exception e) { | 149 | } catch (Exception e) { |
146 | throw handleException(e); | 150 | throw handleException(e); |
147 | } | 151 | } |
@@ -27,12 +27,14 @@ import org.springframework.web.bind.annotation.ResponseBody; | @@ -27,12 +27,14 @@ import org.springframework.web.bind.annotation.ResponseBody; | ||
27 | import org.springframework.web.bind.annotation.ResponseStatus; | 27 | import org.springframework.web.bind.annotation.ResponseStatus; |
28 | import org.springframework.web.bind.annotation.RestController; | 28 | import org.springframework.web.bind.annotation.RestController; |
29 | import org.thingsboard.server.common.data.Customer; | 29 | import org.thingsboard.server.common.data.Customer; |
30 | +import org.thingsboard.server.common.data.DataConstants; | ||
30 | import org.thingsboard.server.common.data.EntitySubtype; | 31 | import org.thingsboard.server.common.data.EntitySubtype; |
31 | import org.thingsboard.server.common.data.EntityType; | 32 | import org.thingsboard.server.common.data.EntityType; |
32 | import org.thingsboard.server.common.data.asset.Asset; | 33 | import org.thingsboard.server.common.data.asset.Asset; |
33 | import org.thingsboard.server.common.data.asset.AssetSearchQuery; | 34 | import org.thingsboard.server.common.data.asset.AssetSearchQuery; |
34 | import org.thingsboard.server.common.data.audit.ActionType; | 35 | import org.thingsboard.server.common.data.audit.ActionType; |
35 | import org.thingsboard.server.common.data.edge.Edge; | 36 | import org.thingsboard.server.common.data.edge.Edge; |
37 | +import org.thingsboard.server.common.data.edge.EdgeEventType; | ||
36 | import org.thingsboard.server.common.data.exception.ThingsboardException; | 38 | import org.thingsboard.server.common.data.exception.ThingsboardException; |
37 | import org.thingsboard.server.common.data.id.AssetId; | 39 | import org.thingsboard.server.common.data.id.AssetId; |
38 | import org.thingsboard.server.common.data.id.CustomerId; | 40 | import org.thingsboard.server.common.data.id.CustomerId; |
@@ -86,6 +88,8 @@ public class AssetController extends BaseController { | @@ -86,6 +88,8 @@ public class AssetController extends BaseController { | ||
86 | 88 | ||
87 | Asset savedAsset = checkNotNull(assetService.saveAsset(asset)); | 89 | Asset savedAsset = checkNotNull(assetService.saveAsset(asset)); |
88 | 90 | ||
91 | + sendNotificationMsgToEdgeService(savedAsset.getTenantId(), savedAsset.getId(), EdgeEventType.ASSET, asset.getId() == null ? ActionType.ADDED : ActionType.UPDATED); | ||
92 | + | ||
89 | logEntityAction(savedAsset.getId(), savedAsset, | 93 | logEntityAction(savedAsset.getId(), savedAsset, |
90 | savedAsset.getCustomerId(), | 94 | savedAsset.getCustomerId(), |
91 | asset.getId() == null ? ActionType.ADDED : ActionType.UPDATED, null); | 95 | asset.getId() == null ? ActionType.ADDED : ActionType.UPDATED, null); |
@@ -112,6 +116,7 @@ public class AssetController extends BaseController { | @@ -112,6 +116,7 @@ public class AssetController extends BaseController { | ||
112 | asset.getCustomerId(), | 116 | asset.getCustomerId(), |
113 | ActionType.DELETED, null, strAssetId); | 117 | ActionType.DELETED, null, strAssetId); |
114 | 118 | ||
119 | + sendNotificationMsgToEdgeService(getTenantId(), assetId, EdgeEventType.ASSET, ActionType.DELETED); | ||
115 | } catch (Exception e) { | 120 | } catch (Exception e) { |
116 | logEntityAction(emptyId(EntityType.ASSET), | 121 | logEntityAction(emptyId(EntityType.ASSET), |
117 | null, | 122 | null, |
@@ -354,6 +359,8 @@ public class AssetController extends BaseController { | @@ -354,6 +359,8 @@ public class AssetController extends BaseController { | ||
354 | savedAsset.getCustomerId(), | 359 | savedAsset.getCustomerId(), |
355 | ActionType.ASSIGNED_TO_EDGE, null, strAssetId, strEdgeId, edge.getName()); | 360 | ActionType.ASSIGNED_TO_EDGE, null, strAssetId, strEdgeId, edge.getName()); |
356 | 361 | ||
362 | + sendNotificationMsgToEdgeService(getTenantId(), savedAsset.getId(), EdgeEventType.ASSET, ActionType.ASSIGNED_TO_EDGE); | ||
363 | + | ||
357 | return savedAsset; | 364 | return savedAsset; |
358 | } catch (Exception e) { | 365 | } catch (Exception e) { |
359 | 366 | ||
@@ -385,6 +392,8 @@ public class AssetController extends BaseController { | @@ -385,6 +392,8 @@ public class AssetController extends BaseController { | ||
385 | asset.getCustomerId(), | 392 | asset.getCustomerId(), |
386 | ActionType.UNASSIGNED_FROM_EDGE, null, strAssetId, edge.getId().toString(), edge.getName()); | 393 | ActionType.UNASSIGNED_FROM_EDGE, null, strAssetId, edge.getId().toString(), edge.getName()); |
387 | 394 | ||
395 | + sendNotificationMsgToEdgeService(getTenantId(), savedAsset.getId(), EdgeEventType.ASSET, ActionType.UNASSIGNED_FROM_EDGE); | ||
396 | + | ||
388 | return savedAsset; | 397 | return savedAsset; |
389 | } catch (Exception e) { | 398 | } catch (Exception e) { |
390 | 399 |
@@ -39,6 +39,7 @@ import org.thingsboard.server.common.data.HasTenantId; | @@ -39,6 +39,7 @@ import org.thingsboard.server.common.data.HasTenantId; | ||
39 | import org.thingsboard.server.common.data.Tenant; | 39 | import org.thingsboard.server.common.data.Tenant; |
40 | import org.thingsboard.server.common.data.User; | 40 | import org.thingsboard.server.common.data.User; |
41 | import org.thingsboard.server.common.data.alarm.Alarm; | 41 | import org.thingsboard.server.common.data.alarm.Alarm; |
42 | +import org.thingsboard.server.common.data.edge.EdgeEventType; | ||
42 | import org.thingsboard.server.common.data.id.AlarmId; | 43 | import org.thingsboard.server.common.data.id.AlarmId; |
43 | import org.thingsboard.server.common.data.alarm.AlarmInfo; | 44 | import org.thingsboard.server.common.data.alarm.AlarmInfo; |
44 | import org.thingsboard.server.common.data.asset.Asset; | 45 | import org.thingsboard.server.common.data.asset.Asset; |
@@ -66,6 +67,7 @@ import org.thingsboard.server.common.data.page.TextPageLink; | @@ -66,6 +67,7 @@ import org.thingsboard.server.common.data.page.TextPageLink; | ||
66 | import org.thingsboard.server.common.data.page.TimePageLink; | 67 | import org.thingsboard.server.common.data.page.TimePageLink; |
67 | import org.thingsboard.server.common.data.plugin.ComponentDescriptor; | 68 | import org.thingsboard.server.common.data.plugin.ComponentDescriptor; |
68 | import org.thingsboard.server.common.data.plugin.ComponentType; | 69 | import org.thingsboard.server.common.data.plugin.ComponentType; |
70 | +import org.thingsboard.server.common.data.relation.EntityRelation; | ||
69 | import org.thingsboard.server.common.data.rule.RuleChain; | 71 | import org.thingsboard.server.common.data.rule.RuleChain; |
70 | import org.thingsboard.server.common.data.rule.RuleChainType; | 72 | import org.thingsboard.server.common.data.rule.RuleChainType; |
71 | import org.thingsboard.server.common.data.rule.RuleNode; | 73 | import org.thingsboard.server.common.data.rule.RuleNode; |
@@ -83,6 +85,7 @@ import org.thingsboard.server.dao.dashboard.DashboardService; | @@ -83,6 +85,7 @@ import org.thingsboard.server.dao.dashboard.DashboardService; | ||
83 | import org.thingsboard.server.dao.device.ClaimDevicesService; | 85 | import org.thingsboard.server.dao.device.ClaimDevicesService; |
84 | import org.thingsboard.server.dao.device.DeviceCredentialsService; | 86 | import org.thingsboard.server.dao.device.DeviceCredentialsService; |
85 | import org.thingsboard.server.dao.device.DeviceService; | 87 | import org.thingsboard.server.dao.device.DeviceService; |
88 | +import org.thingsboard.server.dao.edge.EdgeEventService; | ||
86 | import org.thingsboard.server.dao.edge.EdgeService; | 89 | import org.thingsboard.server.dao.edge.EdgeService; |
87 | import org.thingsboard.server.dao.entityview.EntityViewService; | 90 | import org.thingsboard.server.dao.entityview.EntityViewService; |
88 | import org.thingsboard.server.dao.exception.DataValidationException; | 91 | import org.thingsboard.server.dao.exception.DataValidationException; |
@@ -95,10 +98,12 @@ import org.thingsboard.server.dao.user.UserService; | @@ -95,10 +98,12 @@ import org.thingsboard.server.dao.user.UserService; | ||
95 | import org.thingsboard.server.dao.widget.WidgetTypeService; | 98 | import org.thingsboard.server.dao.widget.WidgetTypeService; |
96 | import org.thingsboard.server.dao.widget.WidgetsBundleService; | 99 | import org.thingsboard.server.dao.widget.WidgetsBundleService; |
97 | import org.thingsboard.server.exception.ThingsboardErrorResponseHandler; | 100 | import org.thingsboard.server.exception.ThingsboardErrorResponseHandler; |
101 | +import org.thingsboard.server.gen.transport.TransportProtos; | ||
98 | import org.thingsboard.server.queue.discovery.PartitionService; | 102 | import org.thingsboard.server.queue.discovery.PartitionService; |
99 | import org.thingsboard.server.queue.provider.TbQueueProducerProvider; | 103 | import org.thingsboard.server.queue.provider.TbQueueProducerProvider; |
100 | import org.thingsboard.server.queue.util.TbCoreComponent; | 104 | import org.thingsboard.server.queue.util.TbCoreComponent; |
101 | import org.thingsboard.server.service.component.ComponentDiscoveryService; | 105 | import org.thingsboard.server.service.component.ComponentDiscoveryService; |
106 | +import org.thingsboard.server.service.edge.EdgeNotificationService; | ||
102 | import org.thingsboard.server.service.queue.TbClusterService; | 107 | import org.thingsboard.server.service.queue.TbClusterService; |
103 | import org.thingsboard.server.service.security.model.SecurityUser; | 108 | import org.thingsboard.server.service.security.model.SecurityUser; |
104 | import org.thingsboard.server.service.security.permission.AccessControlService; | 109 | import org.thingsboard.server.service.security.permission.AccessControlService; |
@@ -108,6 +113,7 @@ import org.thingsboard.server.service.state.DeviceStateService; | @@ -108,6 +113,7 @@ import org.thingsboard.server.service.state.DeviceStateService; | ||
108 | import org.thingsboard.server.service.telemetry.TelemetrySubscriptionService; | 113 | import org.thingsboard.server.service.telemetry.TelemetrySubscriptionService; |
109 | 114 | ||
110 | import javax.mail.MessagingException; | 115 | import javax.mail.MessagingException; |
116 | +import javax.management.relation.Relation; | ||
111 | import javax.servlet.http.HttpServletResponse; | 117 | import javax.servlet.http.HttpServletResponse; |
112 | import java.util.List; | 118 | import java.util.List; |
113 | import java.util.Optional; | 119 | import java.util.Optional; |
@@ -200,6 +206,12 @@ public abstract class BaseController { | @@ -200,6 +206,12 @@ public abstract class BaseController { | ||
200 | @Autowired | 206 | @Autowired |
201 | protected EdgeService edgeService; | 207 | protected EdgeService edgeService; |
202 | 208 | ||
209 | + @Autowired | ||
210 | + protected EdgeNotificationService edgeNotificationService; | ||
211 | + | ||
212 | + @Autowired | ||
213 | + protected EdgeEventService edgeEventService; | ||
214 | + | ||
203 | @Value("${server.log_controller_error_stack_trace}") | 215 | @Value("${server.log_controller_error_stack_trace}") |
204 | @Getter | 216 | @Getter |
205 | private boolean logControllerErrorStackTrace; | 217 | private boolean logControllerErrorStackTrace; |
@@ -559,7 +571,6 @@ public abstract class BaseController { | @@ -559,7 +571,6 @@ public abstract class BaseController { | ||
559 | } | 571 | } |
560 | if (e == null) { | 572 | if (e == null) { |
561 | pushEntityActionToRuleEngine(entityId, entity, user, customerId, actionType, additionalInfo); | 573 | pushEntityActionToRuleEngine(entityId, entity, user, customerId, actionType, additionalInfo); |
562 | - // TODO: voba - refactor to push events to edge queue directly, instead of the rule engine flow | ||
563 | } | 574 | } |
564 | auditLogService.logEntityAction(user.getTenantId(), customerId, user.getId(), user.getName(), entityId, entity, actionType, e, additionalInfo); | 575 | auditLogService.logEntityAction(user.getTenantId(), customerId, user.getId(), user.getName(), entityId, entity, actionType, e, additionalInfo); |
565 | } | 576 | } |
@@ -600,16 +611,6 @@ public abstract class BaseController { | @@ -600,16 +611,6 @@ public abstract class BaseController { | ||
600 | case ALARM_CLEAR: | 611 | case ALARM_CLEAR: |
601 | msgType = DataConstants.ALARM_CLEAR; | 612 | msgType = DataConstants.ALARM_CLEAR; |
602 | break; | 613 | break; |
603 | - case ASSIGNED_TO_EDGE: | ||
604 | - msgType = DataConstants.ENTITY_ASSIGNED_TO_EDGE; | ||
605 | - break; | ||
606 | - case UNASSIGNED_FROM_EDGE: | ||
607 | - msgType = DataConstants.ENTITY_UNASSIGNED_FROM_EDGE; | ||
608 | - break; | ||
609 | - case CREDENTIALS_UPDATED: | ||
610 | - //TODO: voba - this is not efficient way to do this. Refactor on later stages | ||
611 | - msgType = DataConstants.ENTITY_UPDATED; | ||
612 | - break; | ||
613 | } | 614 | } |
614 | if (!StringUtils.isEmpty(msgType)) { | 615 | if (!StringUtils.isEmpty(msgType)) { |
615 | try { | 616 | try { |
@@ -698,5 +699,42 @@ public abstract class BaseController { | @@ -698,5 +699,42 @@ public abstract class BaseController { | ||
698 | return result; | 699 | return result; |
699 | } | 700 | } |
700 | 701 | ||
702 | + protected void sendNotificationMsgToEdgeService(TenantId tenantId, EntityRelation relation, ActionType edgeEventAction) { | ||
703 | + try { | ||
704 | + sendNotificationMsgToEdgeService(tenantId, null, json.writeValueAsString(relation), EdgeEventType.RELATION, edgeEventAction); | ||
705 | + } catch (Exception e) { | ||
706 | + log.warn("Failed to push relation to core: {}", relation, e); | ||
707 | + } | ||
708 | + } | ||
709 | + | ||
710 | + protected void sendNotificationMsgToEdgeService(TenantId tenantId, EntityId entityId, ActionType edgeEventAction) { | ||
711 | + EdgeEventType edgeEventType = edgeEventService.getEdgeEventTypeByEntityType(entityId.getEntityType()); | ||
712 | + if (edgeEventType != null) { | ||
713 | + sendNotificationMsgToEdgeService(tenantId, entityId, null, edgeEventType, edgeEventAction); | ||
714 | + } | ||
715 | + } | ||
716 | + | ||
717 | + protected void sendNotificationMsgToEdgeService(TenantId tenantId, EntityId entityId, EdgeEventType edgeEventType, ActionType edgeEventAction) { | ||
718 | + sendNotificationMsgToEdgeService(tenantId, entityId, null, edgeEventType, edgeEventAction); | ||
719 | + } | ||
720 | + | ||
721 | + private void sendNotificationMsgToEdgeService(TenantId tenantId, EntityId entityId, String entityBody, EdgeEventType edgeEventType, ActionType edgeEventAction) { | ||
722 | + TransportProtos.EdgeNotificationMsgProto.Builder builder = TransportProtos.EdgeNotificationMsgProto.newBuilder(); | ||
723 | + builder.setTenantIdMSB(tenantId.getId().getMostSignificantBits()); | ||
724 | + builder.setTenantIdLSB(tenantId.getId().getLeastSignificantBits()); | ||
725 | + builder.setEdgeEventType(edgeEventType.name()); | ||
726 | + builder.setEdgeEventAction(edgeEventAction.name()); | ||
727 | + if (entityId != null) { | ||
728 | + builder.setEntityIdMSB(entityId.getId().getMostSignificantBits()); | ||
729 | + builder.setEntityIdLSB(entityId.getId().getLeastSignificantBits()); | ||
730 | + builder.setEntityType(entityId.getEntityType().name()); | ||
731 | + } | ||
732 | + if (entityBody != null) { | ||
733 | + builder.setEntityBody(entityBody); | ||
734 | + } | ||
735 | + TransportProtos.EdgeNotificationMsgProto msg = builder.build(); | ||
736 | + tbClusterService.pushMsgToCore(tenantId, entityId != null ? entityId : tenantId, | ||
737 | + TransportProtos.ToCoreMsg.newBuilder().setEdgeNotificationMsg(msg).build(), null); | ||
738 | + } | ||
701 | 739 | ||
702 | } | 740 | } |
@@ -34,6 +34,7 @@ import org.thingsboard.server.common.data.ShortCustomerInfo; | @@ -34,6 +34,7 @@ import org.thingsboard.server.common.data.ShortCustomerInfo; | ||
34 | import org.thingsboard.server.common.data.ShortEdgeInfo; | 34 | import org.thingsboard.server.common.data.ShortEdgeInfo; |
35 | import org.thingsboard.server.common.data.audit.ActionType; | 35 | import org.thingsboard.server.common.data.audit.ActionType; |
36 | import org.thingsboard.server.common.data.edge.Edge; | 36 | import org.thingsboard.server.common.data.edge.Edge; |
37 | +import org.thingsboard.server.common.data.edge.EdgeEventType; | ||
37 | import org.thingsboard.server.common.data.exception.ThingsboardException; | 38 | import org.thingsboard.server.common.data.exception.ThingsboardException; |
38 | import org.thingsboard.server.common.data.id.CustomerId; | 39 | import org.thingsboard.server.common.data.id.CustomerId; |
39 | import org.thingsboard.server.common.data.id.DashboardId; | 40 | import org.thingsboard.server.common.data.id.DashboardId; |
@@ -116,6 +117,9 @@ public class DashboardController extends BaseController { | @@ -116,6 +117,9 @@ public class DashboardController extends BaseController { | ||
116 | null, | 117 | null, |
117 | dashboard.getId() == null ? ActionType.ADDED : ActionType.UPDATED, null); | 118 | dashboard.getId() == null ? ActionType.ADDED : ActionType.UPDATED, null); |
118 | 119 | ||
120 | + sendNotificationMsgToEdgeService(savedDashboard.getTenantId(), savedDashboard.getId(), | ||
121 | + EdgeEventType.DASHBOARD, savedDashboard.getId() == null ? ActionType.ADDED : ActionType.UPDATED); | ||
122 | + | ||
119 | return savedDashboard; | 123 | return savedDashboard; |
120 | } catch (Exception e) { | 124 | } catch (Exception e) { |
121 | logEntityAction(emptyId(EntityType.DASHBOARD), dashboard, | 125 | logEntityAction(emptyId(EntityType.DASHBOARD), dashboard, |
@@ -139,6 +143,7 @@ public class DashboardController extends BaseController { | @@ -139,6 +143,7 @@ public class DashboardController extends BaseController { | ||
139 | null, | 143 | null, |
140 | ActionType.DELETED, null, strDashboardId); | 144 | ActionType.DELETED, null, strDashboardId); |
141 | 145 | ||
146 | + sendNotificationMsgToEdgeService(getTenantId(), dashboardId, EdgeEventType.DASHBOARD, ActionType.DELETED); | ||
142 | } catch (Exception e) { | 147 | } catch (Exception e) { |
143 | 148 | ||
144 | logEntityAction(emptyId(EntityType.DASHBOARD), | 149 | logEntityAction(emptyId(EntityType.DASHBOARD), |
@@ -495,6 +500,7 @@ public class DashboardController extends BaseController { | @@ -495,6 +500,7 @@ public class DashboardController extends BaseController { | ||
495 | null, | 500 | null, |
496 | ActionType.ASSIGNED_TO_EDGE, null, strDashboardId, strEdgeId, edge.getName()); | 501 | ActionType.ASSIGNED_TO_EDGE, null, strDashboardId, strEdgeId, edge.getName()); |
497 | 502 | ||
503 | + sendNotificationMsgToEdgeService(getTenantId(), savedDashboard.getId(), EdgeEventType.DASHBOARD, ActionType.ASSIGNED_TO_EDGE); | ||
498 | 504 | ||
499 | return savedDashboard; | 505 | return savedDashboard; |
500 | } catch (Exception e) { | 506 | } catch (Exception e) { |
@@ -526,6 +532,8 @@ public class DashboardController extends BaseController { | @@ -526,6 +532,8 @@ public class DashboardController extends BaseController { | ||
526 | null, | 532 | null, |
527 | ActionType.UNASSIGNED_FROM_EDGE, null, strDashboardId, edge.getId().toString(), edge.getName()); | 533 | ActionType.UNASSIGNED_FROM_EDGE, null, strDashboardId, edge.getId().toString(), edge.getName()); |
528 | 534 | ||
535 | + sendNotificationMsgToEdgeService(getTenantId(), savedDashboard.getId(), EdgeEventType.DASHBOARD, ActionType.UNASSIGNED_FROM_EDGE); | ||
536 | + | ||
529 | return savedDashboard; | 537 | return savedDashboard; |
530 | } catch (Exception e) { | 538 | } catch (Exception e) { |
531 | 539 |
@@ -42,6 +42,7 @@ import org.thingsboard.server.common.data.EntityType; | @@ -42,6 +42,7 @@ import org.thingsboard.server.common.data.EntityType; | ||
42 | import org.thingsboard.server.common.data.audit.ActionType; | 42 | import org.thingsboard.server.common.data.audit.ActionType; |
43 | import org.thingsboard.server.common.data.device.DeviceSearchQuery; | 43 | import org.thingsboard.server.common.data.device.DeviceSearchQuery; |
44 | import org.thingsboard.server.common.data.edge.Edge; | 44 | import org.thingsboard.server.common.data.edge.Edge; |
45 | +import org.thingsboard.server.common.data.edge.EdgeEventType; | ||
45 | import org.thingsboard.server.common.data.exception.ThingsboardException; | 46 | import org.thingsboard.server.common.data.exception.ThingsboardException; |
46 | import org.thingsboard.server.common.data.id.CustomerId; | 47 | import org.thingsboard.server.common.data.id.CustomerId; |
47 | import org.thingsboard.server.common.data.id.DeviceId; | 48 | import org.thingsboard.server.common.data.id.DeviceId; |
@@ -57,6 +58,7 @@ import org.thingsboard.server.dao.device.claim.ClaimResponse; | @@ -57,6 +58,7 @@ import org.thingsboard.server.dao.device.claim.ClaimResponse; | ||
57 | import org.thingsboard.server.dao.device.claim.ClaimResult; | 58 | import org.thingsboard.server.dao.device.claim.ClaimResult; |
58 | import org.thingsboard.server.dao.exception.IncorrectParameterException; | 59 | import org.thingsboard.server.dao.exception.IncorrectParameterException; |
59 | import org.thingsboard.server.dao.model.ModelConstants; | 60 | import org.thingsboard.server.dao.model.ModelConstants; |
61 | +import org.thingsboard.server.gen.transport.TransportProtos; | ||
60 | import org.thingsboard.server.queue.util.TbCoreComponent; | 62 | import org.thingsboard.server.queue.util.TbCoreComponent; |
61 | import org.thingsboard.server.service.security.model.SecurityUser; | 63 | import org.thingsboard.server.service.security.model.SecurityUser; |
62 | import org.thingsboard.server.service.security.permission.Operation; | 64 | import org.thingsboard.server.service.security.permission.Operation; |
@@ -106,6 +108,8 @@ public class DeviceController extends BaseController { | @@ -106,6 +108,8 @@ public class DeviceController extends BaseController { | ||
106 | tbClusterService.pushMsgToCore(new DeviceNameOrTypeUpdateMsg(savedDevice.getTenantId(), | 108 | tbClusterService.pushMsgToCore(new DeviceNameOrTypeUpdateMsg(savedDevice.getTenantId(), |
107 | savedDevice.getId(), savedDevice.getName(), savedDevice.getType()), null); | 109 | savedDevice.getId(), savedDevice.getName(), savedDevice.getType()), null); |
108 | 110 | ||
111 | + sendNotificationMsgToEdgeService(savedDevice.getTenantId(), savedDevice.getId(), EdgeEventType.DEVICE, device.getId() == null ? ActionType.ADDED : ActionType.UPDATED); | ||
112 | + | ||
109 | logEntityAction(savedDevice.getId(), savedDevice, | 113 | logEntityAction(savedDevice.getId(), savedDevice, |
110 | savedDevice.getCustomerId(), | 114 | savedDevice.getCustomerId(), |
111 | device.getId() == null ? ActionType.ADDED : ActionType.UPDATED, null); | 115 | device.getId() == null ? ActionType.ADDED : ActionType.UPDATED, null); |
@@ -137,6 +141,8 @@ public class DeviceController extends BaseController { | @@ -137,6 +141,8 @@ public class DeviceController extends BaseController { | ||
137 | device.getCustomerId(), | 141 | device.getCustomerId(), |
138 | ActionType.DELETED, null, strDeviceId); | 142 | ActionType.DELETED, null, strDeviceId); |
139 | 143 | ||
144 | + sendNotificationMsgToEdgeService(getTenantId(), deviceId, EdgeEventType.DEVICE, ActionType.DELETED); | ||
145 | + | ||
140 | deviceStateService.onDeviceDeleted(device); | 146 | deviceStateService.onDeviceDeleted(device); |
141 | } catch (Exception e) { | 147 | } catch (Exception e) { |
142 | logEntityAction(emptyId(EntityType.DEVICE), | 148 | logEntityAction(emptyId(EntityType.DEVICE), |
@@ -260,6 +266,8 @@ public class DeviceController extends BaseController { | @@ -260,6 +266,8 @@ public class DeviceController extends BaseController { | ||
260 | 266 | ||
261 | tbClusterService.pushMsgToCore(new DeviceCredentialsUpdateNotificationMsg(getCurrentUser().getTenantId(), deviceCredentials.getDeviceId()), null); | 267 | tbClusterService.pushMsgToCore(new DeviceCredentialsUpdateNotificationMsg(getCurrentUser().getTenantId(), deviceCredentials.getDeviceId()), null); |
262 | 268 | ||
269 | + sendNotificationMsgToEdgeService(getTenantId(), device.getId(), EdgeEventType.DEVICE, ActionType.CREDENTIALS_UPDATED); | ||
270 | + | ||
263 | logEntityAction(device.getId(), device, | 271 | logEntityAction(device.getId(), device, |
264 | device.getCustomerId(), | 272 | device.getCustomerId(), |
265 | ActionType.CREDENTIALS_UPDATED, null, deviceCredentials); | 273 | ActionType.CREDENTIALS_UPDATED, null, deviceCredentials); |
@@ -509,6 +517,8 @@ public class DeviceController extends BaseController { | @@ -509,6 +517,8 @@ public class DeviceController extends BaseController { | ||
509 | savedDevice.getCustomerId(), | 517 | savedDevice.getCustomerId(), |
510 | ActionType.ASSIGNED_TO_EDGE, null, strDeviceId, strEdgeId, edge.getName()); | 518 | ActionType.ASSIGNED_TO_EDGE, null, strDeviceId, strEdgeId, edge.getName()); |
511 | 519 | ||
520 | + sendNotificationMsgToEdgeService(getTenantId(), savedDevice.getId(), EdgeEventType.DEVICE, ActionType.ASSIGNED_TO_EDGE); | ||
521 | + | ||
512 | return savedDevice; | 522 | return savedDevice; |
513 | } catch (Exception e) { | 523 | } catch (Exception e) { |
514 | logEntityAction(emptyId(EntityType.DEVICE), null, | 524 | logEntityAction(emptyId(EntityType.DEVICE), null, |
@@ -538,6 +548,8 @@ public class DeviceController extends BaseController { | @@ -538,6 +548,8 @@ public class DeviceController extends BaseController { | ||
538 | device.getCustomerId(), | 548 | device.getCustomerId(), |
539 | ActionType.UNASSIGNED_FROM_EDGE, null, strDeviceId, edge.getId().toString(), edge.getName()); | 549 | ActionType.UNASSIGNED_FROM_EDGE, null, strDeviceId, edge.getId().toString(), edge.getName()); |
540 | 550 | ||
551 | + sendNotificationMsgToEdgeService(getTenantId(), savedDevice.getId(), EdgeEventType.DEVICE, ActionType.UNASSIGNED_FROM_EDGE); | ||
552 | + | ||
541 | return savedDevice; | 553 | return savedDevice; |
542 | } catch (Exception e) { | 554 | } catch (Exception e) { |
543 | logEntityAction(emptyId(EntityType.DEVICE), null, | 555 | logEntityAction(emptyId(EntityType.DEVICE), null, |
@@ -97,7 +97,7 @@ public class EdgeController extends BaseController { | @@ -97,7 +97,7 @@ public class EdgeController extends BaseController { | ||
97 | 97 | ||
98 | if (created) { | 98 | if (created) { |
99 | ruleChainService.assignRuleChainToEdge(tenantId, defaultRootEdgeRuleChain.getId(), savedEdge.getId()); | 99 | ruleChainService.assignRuleChainToEdge(tenantId, defaultRootEdgeRuleChain.getId(), savedEdge.getId()); |
100 | - edgeService.setEdgeRootRuleChain(tenantId, savedEdge, defaultRootEdgeRuleChain.getId()); | 100 | + edgeNotificationService.setEdgeRootRuleChain(tenantId, savedEdge, defaultRootEdgeRuleChain.getId()); |
101 | edgeService.assignDefaultRuleChainsToEdge(tenantId, savedEdge.getId()); | 101 | edgeService.assignDefaultRuleChainsToEdge(tenantId, savedEdge.getId()); |
102 | } | 102 | } |
103 | 103 | ||
@@ -257,8 +257,7 @@ public class EdgeController extends BaseController { | @@ -257,8 +257,7 @@ public class EdgeController extends BaseController { | ||
257 | @PreAuthorize("hasAuthority('TENANT_ADMIN')") | 257 | @PreAuthorize("hasAuthority('TENANT_ADMIN')") |
258 | @RequestMapping(value = "/tenant/edges", params = {"edgeName"}, method = RequestMethod.GET) | 258 | @RequestMapping(value = "/tenant/edges", params = {"edgeName"}, method = RequestMethod.GET) |
259 | @ResponseBody | 259 | @ResponseBody |
260 | - public Edge getTenantEdge( | ||
261 | - @RequestParam String edgeName) throws ThingsboardException { | 260 | + public Edge getTenantEdge(@RequestParam String edgeName) throws ThingsboardException { |
262 | try { | 261 | try { |
263 | TenantId tenantId = getCurrentUser().getTenantId(); | 262 | TenantId tenantId = getCurrentUser().getTenantId(); |
264 | return checkNotNull(edgeService.findEdgeByTenantIdAndName(tenantId, edgeName)); | 263 | return checkNotNull(edgeService.findEdgeByTenantIdAndName(tenantId, edgeName)); |
@@ -283,7 +282,7 @@ public class EdgeController extends BaseController { | @@ -283,7 +282,7 @@ public class EdgeController extends BaseController { | ||
283 | accessControlService.checkPermission(getCurrentUser(), Resource.EDGE, Operation.WRITE, | 282 | accessControlService.checkPermission(getCurrentUser(), Resource.EDGE, Operation.WRITE, |
284 | edge.getId(), edge); | 283 | edge.getId(), edge); |
285 | 284 | ||
286 | - Edge updatedEdge = edgeService.setEdgeRootRuleChain(getTenantId(), edge, ruleChainId); | 285 | + Edge updatedEdge = edgeNotificationService.setEdgeRootRuleChain(getTenantId(), edge, ruleChainId); |
287 | 286 | ||
288 | logEntityAction(updatedEdge.getId(), updatedEdge, null, ActionType.UPDATED, null); | 287 | logEntityAction(updatedEdge.getId(), updatedEdge, null, ActionType.UPDATED, null); |
289 | 288 |
@@ -24,7 +24,9 @@ import org.springframework.web.bind.annotation.RequestParam; | @@ -24,7 +24,9 @@ import org.springframework.web.bind.annotation.RequestParam; | ||
24 | import org.springframework.web.bind.annotation.ResponseBody; | 24 | import org.springframework.web.bind.annotation.ResponseBody; |
25 | import org.springframework.web.bind.annotation.ResponseStatus; | 25 | import org.springframework.web.bind.annotation.ResponseStatus; |
26 | import org.springframework.web.bind.annotation.RestController; | 26 | import org.springframework.web.bind.annotation.RestController; |
27 | +import org.thingsboard.server.common.data.DataConstants; | ||
27 | import org.thingsboard.server.common.data.audit.ActionType; | 28 | import org.thingsboard.server.common.data.audit.ActionType; |
29 | +import org.thingsboard.server.common.data.edge.EdgeEventType; | ||
28 | import org.thingsboard.server.common.data.exception.ThingsboardErrorCode; | 30 | import org.thingsboard.server.common.data.exception.ThingsboardErrorCode; |
29 | import org.thingsboard.server.common.data.exception.ThingsboardException; | 31 | import org.thingsboard.server.common.data.exception.ThingsboardException; |
30 | import org.thingsboard.server.common.data.id.EntityId; | 32 | import org.thingsboard.server.common.data.id.EntityId; |
@@ -63,10 +65,13 @@ public class EntityRelationController extends BaseController { | @@ -63,10 +65,13 @@ public class EntityRelationController extends BaseController { | ||
63 | relation.setTypeGroup(RelationTypeGroup.COMMON); | 65 | relation.setTypeGroup(RelationTypeGroup.COMMON); |
64 | } | 66 | } |
65 | relationService.saveRelation(getTenantId(), relation); | 67 | relationService.saveRelation(getTenantId(), relation); |
68 | + | ||
66 | logEntityAction(relation.getFrom(), null, getCurrentUser().getCustomerId(), | 69 | logEntityAction(relation.getFrom(), null, getCurrentUser().getCustomerId(), |
67 | ActionType.RELATION_ADD_OR_UPDATE, null, relation); | 70 | ActionType.RELATION_ADD_OR_UPDATE, null, relation); |
68 | logEntityAction(relation.getTo(), null, getCurrentUser().getCustomerId(), | 71 | logEntityAction(relation.getTo(), null, getCurrentUser().getCustomerId(), |
69 | ActionType.RELATION_ADD_OR_UPDATE, null, relation); | 72 | ActionType.RELATION_ADD_OR_UPDATE, null, relation); |
73 | + | ||
74 | + sendNotificationMsgToEdgeService(getTenantId(), relation, ActionType.RELATION_ADD_OR_UPDATE); | ||
70 | } catch (Exception e) { | 75 | } catch (Exception e) { |
71 | logEntityAction(relation.getFrom(), null, getCurrentUser().getCustomerId(), | 76 | logEntityAction(relation.getFrom(), null, getCurrentUser().getCustomerId(), |
72 | ActionType.RELATION_ADD_OR_UPDATE, e, relation); | 77 | ActionType.RELATION_ADD_OR_UPDATE, e, relation); |
@@ -104,6 +109,8 @@ public class EntityRelationController extends BaseController { | @@ -104,6 +109,8 @@ public class EntityRelationController extends BaseController { | ||
104 | ActionType.RELATION_DELETED, null, relation); | 109 | ActionType.RELATION_DELETED, null, relation); |
105 | logEntityAction(relation.getTo(), null, getCurrentUser().getCustomerId(), | 110 | logEntityAction(relation.getTo(), null, getCurrentUser().getCustomerId(), |
106 | ActionType.RELATION_DELETED, null, relation); | 111 | ActionType.RELATION_DELETED, null, relation); |
112 | + | ||
113 | + sendNotificationMsgToEdgeService(getTenantId(), relation, ActionType.RELATION_DELETED); | ||
107 | } catch (Exception e) { | 114 | } catch (Exception e) { |
108 | logEntityAction(relation.getFrom(), null, getCurrentUser().getCustomerId(), | 115 | logEntityAction(relation.getFrom(), null, getCurrentUser().getCustomerId(), |
109 | ActionType.RELATION_DELETED, e, relation); | 116 | ActionType.RELATION_DELETED, e, relation); |
@@ -125,6 +132,8 @@ public class EntityRelationController extends BaseController { | @@ -125,6 +132,8 @@ public class EntityRelationController extends BaseController { | ||
125 | try { | 132 | try { |
126 | relationService.deleteEntityRelations(getTenantId(), entityId); | 133 | relationService.deleteEntityRelations(getTenantId(), entityId); |
127 | logEntityAction(entityId, null, getCurrentUser().getCustomerId(), ActionType.RELATIONS_DELETED, null); | 134 | logEntityAction(entityId, null, getCurrentUser().getCustomerId(), ActionType.RELATIONS_DELETED, null); |
135 | + | ||
136 | + sendNotificationMsgToEdgeService(getTenantId(), entityId, ActionType.RELATIONS_DELETED); | ||
128 | } catch (Exception e) { | 137 | } catch (Exception e) { |
129 | logEntityAction(entityId, null, getCurrentUser().getCustomerId(), ActionType.RELATIONS_DELETED, e); | 138 | logEntityAction(entityId, null, getCurrentUser().getCustomerId(), ActionType.RELATIONS_DELETED, e); |
130 | throw handleException(e); | 139 | throw handleException(e); |
@@ -37,6 +37,7 @@ import org.thingsboard.server.common.data.EntityType; | @@ -37,6 +37,7 @@ import org.thingsboard.server.common.data.EntityType; | ||
37 | import org.thingsboard.server.common.data.EntityView; | 37 | import org.thingsboard.server.common.data.EntityView; |
38 | import org.thingsboard.server.common.data.audit.ActionType; | 38 | import org.thingsboard.server.common.data.audit.ActionType; |
39 | import org.thingsboard.server.common.data.edge.Edge; | 39 | import org.thingsboard.server.common.data.edge.Edge; |
40 | +import org.thingsboard.server.common.data.edge.EdgeEventType; | ||
40 | import org.thingsboard.server.common.data.entityview.EntityViewSearchQuery; | 41 | import org.thingsboard.server.common.data.entityview.EntityViewSearchQuery; |
41 | import org.thingsboard.server.common.data.exception.ThingsboardException; | 42 | import org.thingsboard.server.common.data.exception.ThingsboardException; |
42 | import org.thingsboard.server.common.data.id.CustomerId; | 43 | import org.thingsboard.server.common.data.id.CustomerId; |
@@ -116,6 +117,8 @@ public class EntityViewController extends BaseController { | @@ -116,6 +117,8 @@ public class EntityViewController extends BaseController { | ||
116 | 117 | ||
117 | logEntityAction(savedEntityView.getId(), savedEntityView, null, | 118 | logEntityAction(savedEntityView.getId(), savedEntityView, null, |
118 | entityView.getId() == null ? ActionType.ADDED : ActionType.UPDATED, null); | 119 | entityView.getId() == null ? ActionType.ADDED : ActionType.UPDATED, null); |
120 | + | ||
121 | + sendNotificationMsgToEdgeService(getTenantId(), savedEntityView.getId(), EdgeEventType.ENTITY_VIEW, entityView.getId() == null ? ActionType.ADDED : ActionType.UPDATED); | ||
119 | return savedEntityView; | 122 | return savedEntityView; |
120 | } catch (Exception e) { | 123 | } catch (Exception e) { |
121 | logEntityAction(emptyId(EntityType.ENTITY_VIEW), entityView, null, | 124 | logEntityAction(emptyId(EntityType.ENTITY_VIEW), entityView, null, |
@@ -185,6 +188,8 @@ public class EntityViewController extends BaseController { | @@ -185,6 +188,8 @@ public class EntityViewController extends BaseController { | ||
185 | entityViewService.deleteEntityView(getTenantId(), entityViewId); | 188 | entityViewService.deleteEntityView(getTenantId(), entityViewId); |
186 | logEntityAction(entityViewId, entityView, entityView.getCustomerId(), | 189 | logEntityAction(entityViewId, entityView, entityView.getCustomerId(), |
187 | ActionType.DELETED, null, strEntityViewId); | 190 | ActionType.DELETED, null, strEntityViewId); |
191 | + | ||
192 | + sendNotificationMsgToEdgeService(getTenantId(), entityViewId, EdgeEventType.ENTITY_VIEW, ActionType.DELETED); | ||
188 | } catch (Exception e) { | 193 | } catch (Exception e) { |
189 | logEntityAction(emptyId(EntityType.ENTITY_VIEW), | 194 | logEntityAction(emptyId(EntityType.ENTITY_VIEW), |
190 | null, | 195 | null, |
@@ -389,6 +394,9 @@ public class EntityViewController extends BaseController { | @@ -389,6 +394,9 @@ public class EntityViewController extends BaseController { | ||
389 | logEntityAction(entityViewId, savedEntityView, | 394 | logEntityAction(entityViewId, savedEntityView, |
390 | savedEntityView.getCustomerId(), | 395 | savedEntityView.getCustomerId(), |
391 | ActionType.ASSIGNED_TO_EDGE, null, strEntityViewId, strEdgeId, edge.getName()); | 396 | ActionType.ASSIGNED_TO_EDGE, null, strEntityViewId, strEdgeId, edge.getName()); |
397 | + | ||
398 | + sendNotificationMsgToEdgeService(getTenantId(), savedEntityView.getId(), EdgeEventType.ENTITY_VIEW, ActionType.ASSIGNED_TO_EDGE); | ||
399 | + | ||
392 | return savedEntityView; | 400 | return savedEntityView; |
393 | } catch (Exception e) { | 401 | } catch (Exception e) { |
394 | logEntityAction(emptyId(EntityType.ENTITY_VIEW), null, | 402 | logEntityAction(emptyId(EntityType.ENTITY_VIEW), null, |
@@ -417,6 +425,8 @@ public class EntityViewController extends BaseController { | @@ -417,6 +425,8 @@ public class EntityViewController extends BaseController { | ||
417 | entityView.getCustomerId(), | 425 | entityView.getCustomerId(), |
418 | ActionType.UNASSIGNED_FROM_EDGE, null, strEntityViewId, edge.getId().toString(), edge.getName()); | 426 | ActionType.UNASSIGNED_FROM_EDGE, null, strEntityViewId, edge.getId().toString(), edge.getName()); |
419 | 427 | ||
428 | + sendNotificationMsgToEdgeService(getTenantId(), savedEntityView.getId(), EdgeEventType.ENTITY_VIEW, ActionType.UNASSIGNED_FROM_EDGE); | ||
429 | + | ||
420 | return savedEntityView; | 430 | return savedEntityView; |
421 | } catch (Exception e) { | 431 | } catch (Exception e) { |
422 | logEntityAction(emptyId(EntityType.ENTITY_VIEW), null, | 432 | logEntityAction(emptyId(EntityType.ENTITY_VIEW), null, |
@@ -41,6 +41,7 @@ import org.thingsboard.server.common.data.EntityType; | @@ -41,6 +41,7 @@ import org.thingsboard.server.common.data.EntityType; | ||
41 | import org.thingsboard.server.common.data.Event; | 41 | import org.thingsboard.server.common.data.Event; |
42 | import org.thingsboard.server.common.data.audit.ActionType; | 42 | import org.thingsboard.server.common.data.audit.ActionType; |
43 | import org.thingsboard.server.common.data.edge.Edge; | 43 | import org.thingsboard.server.common.data.edge.Edge; |
44 | +import org.thingsboard.server.common.data.edge.EdgeEventType; | ||
44 | import org.thingsboard.server.common.data.exception.ThingsboardException; | 45 | import org.thingsboard.server.common.data.exception.ThingsboardException; |
45 | import org.thingsboard.server.common.data.id.EdgeId; | 46 | import org.thingsboard.server.common.data.id.EdgeId; |
46 | import org.thingsboard.server.common.data.id.RuleChainId; | 47 | import org.thingsboard.server.common.data.id.RuleChainId; |
@@ -134,7 +135,7 @@ public class RuleChainController extends BaseController { | @@ -134,7 +135,7 @@ public class RuleChainController extends BaseController { | ||
134 | 135 | ||
135 | RuleChain savedRuleChain = checkNotNull(ruleChainService.saveRuleChain(ruleChain)); | 136 | RuleChain savedRuleChain = checkNotNull(ruleChainService.saveRuleChain(ruleChain)); |
136 | 137 | ||
137 | - if (RuleChainType.SYSTEM.equals(savedRuleChain.getType())) { | 138 | + if (RuleChainType.CORE.equals(savedRuleChain.getType())) { |
138 | tbClusterService.onEntityStateChange(ruleChain.getTenantId(), savedRuleChain.getId(), | 139 | tbClusterService.onEntityStateChange(ruleChain.getTenantId(), savedRuleChain.getId(), |
139 | created ? ComponentLifecycleEvent.CREATED : ComponentLifecycleEvent.UPDATED); | 140 | created ? ComponentLifecycleEvent.CREATED : ComponentLifecycleEvent.UPDATED); |
140 | } | 141 | } |
@@ -143,6 +144,12 @@ public class RuleChainController extends BaseController { | @@ -143,6 +144,12 @@ public class RuleChainController extends BaseController { | ||
143 | null, | 144 | null, |
144 | created ? ActionType.ADDED : ActionType.UPDATED, null); | 145 | created ? ActionType.ADDED : ActionType.UPDATED, null); |
145 | 146 | ||
147 | + if (RuleChainType.EDGE.equals(savedRuleChain.getType())) { | ||
148 | + sendNotificationMsgToEdgeService(savedRuleChain.getTenantId(), | ||
149 | + savedRuleChain.getId(), EdgeEventType.RULE_CHAIN, | ||
150 | + savedRuleChain.getId() == null ? ActionType.ADDED : ActionType.UPDATED); | ||
151 | + } | ||
152 | + | ||
146 | return savedRuleChain; | 153 | return savedRuleChain; |
147 | } catch (Exception e) { | 154 | } catch (Exception e) { |
148 | 155 | ||
@@ -209,7 +216,7 @@ public class RuleChainController extends BaseController { | @@ -209,7 +216,7 @@ public class RuleChainController extends BaseController { | ||
209 | RuleChain ruleChain = checkRuleChain(ruleChainMetaData.getRuleChainId(), Operation.WRITE); | 216 | RuleChain ruleChain = checkRuleChain(ruleChainMetaData.getRuleChainId(), Operation.WRITE); |
210 | RuleChainMetaData savedRuleChainMetaData = checkNotNull(ruleChainService.saveRuleChainMetaData(tenantId, ruleChainMetaData)); | 217 | RuleChainMetaData savedRuleChainMetaData = checkNotNull(ruleChainService.saveRuleChainMetaData(tenantId, ruleChainMetaData)); |
211 | 218 | ||
212 | - if (RuleChainType.SYSTEM.equals(ruleChain.getType())) { | 219 | + if (RuleChainType.CORE.equals(ruleChain.getType())) { |
213 | tbClusterService.onEntityStateChange(ruleChain.getTenantId(), ruleChain.getId(), ComponentLifecycleEvent.UPDATED); | 220 | tbClusterService.onEntityStateChange(ruleChain.getTenantId(), ruleChain.getId(), ComponentLifecycleEvent.UPDATED); |
214 | } | 221 | } |
215 | 222 | ||
@@ -217,6 +224,12 @@ public class RuleChainController extends BaseController { | @@ -217,6 +224,12 @@ public class RuleChainController extends BaseController { | ||
217 | null, | 224 | null, |
218 | ActionType.UPDATED, null, ruleChainMetaData); | 225 | ActionType.UPDATED, null, ruleChainMetaData); |
219 | 226 | ||
227 | + if (RuleChainType.EDGE.equals(ruleChain.getType())) { | ||
228 | + sendNotificationMsgToEdgeService(ruleChain.getTenantId(), | ||
229 | + ruleChain.getId(), EdgeEventType.RULE_CHAIN, | ||
230 | + ActionType.UPDATED); | ||
231 | + } | ||
232 | + | ||
220 | return savedRuleChainMetaData; | 233 | return savedRuleChainMetaData; |
221 | } catch (Exception e) { | 234 | } catch (Exception e) { |
222 | 235 | ||
@@ -243,7 +256,7 @@ public class RuleChainController extends BaseController { | @@ -243,7 +256,7 @@ public class RuleChainController extends BaseController { | ||
243 | RuleChainType type = RuleChainType.valueOf(typeStr); | 256 | RuleChainType type = RuleChainType.valueOf(typeStr); |
244 | return checkNotNull(ruleChainService.findTenantRuleChainsByType(tenantId, type, pageLink)); | 257 | return checkNotNull(ruleChainService.findTenantRuleChainsByType(tenantId, type, pageLink)); |
245 | } else { | 258 | } else { |
246 | - return checkNotNull(ruleChainService.findTenantRuleChainsByType(tenantId, RuleChainType.SYSTEM, pageLink)); | 259 | + return checkNotNull(ruleChainService.findTenantRuleChainsByType(tenantId, RuleChainType.CORE, pageLink)); |
247 | } | 260 | } |
248 | } catch (Exception e) { | 261 | } catch (Exception e) { |
249 | throw handleException(e); | 262 | throw handleException(e); |
@@ -267,7 +280,7 @@ public class RuleChainController extends BaseController { | @@ -267,7 +280,7 @@ public class RuleChainController extends BaseController { | ||
267 | 280 | ||
268 | referencingRuleChainIds.remove(ruleChain.getId()); | 281 | referencingRuleChainIds.remove(ruleChain.getId()); |
269 | 282 | ||
270 | - if (RuleChainType.SYSTEM.equals(ruleChain.getType())) { | 283 | + if (RuleChainType.CORE.equals(ruleChain.getType())) { |
271 | referencingRuleChainIds.forEach(referencingRuleChainId -> | 284 | referencingRuleChainIds.forEach(referencingRuleChainId -> |
272 | tbClusterService.onEntityStateChange(ruleChain.getTenantId(), referencingRuleChainId, ComponentLifecycleEvent.UPDATED)); | 285 | tbClusterService.onEntityStateChange(ruleChain.getTenantId(), referencingRuleChainId, ComponentLifecycleEvent.UPDATED)); |
273 | 286 | ||
@@ -278,6 +291,12 @@ public class RuleChainController extends BaseController { | @@ -278,6 +291,12 @@ public class RuleChainController extends BaseController { | ||
278 | null, | 291 | null, |
279 | ActionType.DELETED, null, strRuleChainId); | 292 | ActionType.DELETED, null, strRuleChainId); |
280 | 293 | ||
294 | + if (RuleChainType.EDGE.equals(ruleChain.getType())) { | ||
295 | + sendNotificationMsgToEdgeService(ruleChain.getTenantId(), | ||
296 | + ruleChain.getId(), EdgeEventType.RULE_CHAIN, | ||
297 | + ActionType.DELETED); | ||
298 | + } | ||
299 | + | ||
281 | } catch (Exception e) { | 300 | } catch (Exception e) { |
282 | logEntityAction(emptyId(EntityType.RULE_CHAIN), | 301 | logEntityAction(emptyId(EntityType.RULE_CHAIN), |
283 | null, | 302 | null, |
@@ -407,6 +426,8 @@ public class RuleChainController extends BaseController { | @@ -407,6 +426,8 @@ public class RuleChainController extends BaseController { | ||
407 | null, | 426 | null, |
408 | ActionType.ASSIGNED_TO_EDGE, null, strRuleChainId, strEdgeId, edge.getName()); | 427 | ActionType.ASSIGNED_TO_EDGE, null, strRuleChainId, strEdgeId, edge.getName()); |
409 | 428 | ||
429 | + sendNotificationMsgToEdgeService(getTenantId(), savedRuleChain.getId(), | ||
430 | + EdgeEventType.RULE_CHAIN, ActionType.ASSIGNED_TO_EDGE); | ||
410 | 431 | ||
411 | return savedRuleChain; | 432 | return savedRuleChain; |
412 | } catch (Exception e) { | 433 | } catch (Exception e) { |
@@ -438,6 +459,9 @@ public class RuleChainController extends BaseController { | @@ -438,6 +459,9 @@ public class RuleChainController extends BaseController { | ||
438 | null, | 459 | null, |
439 | ActionType.UNASSIGNED_FROM_EDGE, null, strRuleChainId, edge.getId().toString(), edge.getName()); | 460 | ActionType.UNASSIGNED_FROM_EDGE, null, strRuleChainId, edge.getId().toString(), edge.getName()); |
440 | 461 | ||
462 | + sendNotificationMsgToEdgeService(getTenantId(), savedRuleChain.getId(), | ||
463 | + EdgeEventType.RULE_CHAIN, ActionType.UNASSIGNED_FROM_EDGE); | ||
464 | + | ||
441 | return savedRuleChain; | 465 | return savedRuleChain; |
442 | } catch (Exception e) { | 466 | } catch (Exception e) { |
443 | 467 |
@@ -116,7 +116,7 @@ public class AnnotationComponentDiscoveryService implements ComponentDiscoverySe | @@ -116,7 +116,7 @@ public class AnnotationComponentDiscoveryService implements ComponentDiscoverySe | ||
116 | } | 116 | } |
117 | 117 | ||
118 | private void putComponentIntoMaps(ComponentType type, RuleNode ruleNodeAnnotation, ComponentDescriptor component) { | 118 | private void putComponentIntoMaps(ComponentType type, RuleNode ruleNodeAnnotation, ComponentDescriptor component) { |
119 | - if (ruleChainTypeContainsArray(RuleChainType.SYSTEM, ruleNodeAnnotation.ruleChainTypes())) { | 119 | + if (ruleChainTypeContainsArray(RuleChainType.CORE, ruleNodeAnnotation.ruleChainTypes())) { |
120 | systemComponentsMap.computeIfAbsent(type, k -> new ArrayList<>()).add(component); | 120 | systemComponentsMap.computeIfAbsent(type, k -> new ArrayList<>()).add(component); |
121 | } | 121 | } |
122 | if (ruleChainTypeContainsArray(RuleChainType.EDGE, ruleNodeAnnotation.ruleChainTypes())) { | 122 | if (ruleChainTypeContainsArray(RuleChainType.EDGE, ruleNodeAnnotation.ruleChainTypes())) { |
@@ -225,7 +225,7 @@ public class AnnotationComponentDiscoveryService implements ComponentDiscoverySe | @@ -225,7 +225,7 @@ public class AnnotationComponentDiscoveryService implements ComponentDiscoverySe | ||
225 | 225 | ||
226 | @Override | 226 | @Override |
227 | public List<ComponentDescriptor> getComponents(Set<ComponentType> types, RuleChainType ruleChainType) { | 227 | public List<ComponentDescriptor> getComponents(Set<ComponentType> types, RuleChainType ruleChainType) { |
228 | - if (RuleChainType.SYSTEM.equals(ruleChainType)) { | 228 | + if (RuleChainType.CORE.equals(ruleChainType)) { |
229 | return getComponents(types, systemComponentsMap); | 229 | return getComponents(types, systemComponentsMap); |
230 | } else if (RuleChainType.EDGE.equals(ruleChainType)) { | 230 | } else if (RuleChainType.EDGE.equals(ruleChainType)) { |
231 | return getComponents(types, edgeComponentsMap); | 231 | return getComponents(types, edgeComponentsMap); |
1 | +/** | ||
2 | + * Copyright © 2016-2020 The Thingsboard Authors | ||
3 | + * | ||
4 | + * Licensed under the Apache License, Version 2.0 (the "License"); | ||
5 | + * you may not use this file except in compliance with the License. | ||
6 | + * You may obtain a copy of the License at | ||
7 | + * | ||
8 | + * http://www.apache.org/licenses/LICENSE-2.0 | ||
9 | + * | ||
10 | + * Unless required by applicable law or agreed to in writing, software | ||
11 | + * distributed under the License is distributed on an "AS IS" BASIS, | ||
12 | + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||
13 | + * See the License for the specific language governing permissions and | ||
14 | + * limitations under the License. | ||
15 | + */ | ||
1 | package org.thingsboard.server.service.edge; | 16 | package org.thingsboard.server.service.edge; |
2 | 17 | ||
3 | import com.fasterxml.jackson.databind.ObjectMapper; | 18 | import com.fasterxml.jackson.databind.ObjectMapper; |
@@ -17,9 +32,10 @@ import org.thingsboard.server.common.data.EntityView; | @@ -17,9 +32,10 @@ import org.thingsboard.server.common.data.EntityView; | ||
17 | import org.thingsboard.server.common.data.Event; | 32 | import org.thingsboard.server.common.data.Event; |
18 | import org.thingsboard.server.common.data.alarm.Alarm; | 33 | import org.thingsboard.server.common.data.alarm.Alarm; |
19 | import org.thingsboard.server.common.data.asset.Asset; | 34 | import org.thingsboard.server.common.data.asset.Asset; |
35 | +import org.thingsboard.server.common.data.audit.ActionType; | ||
20 | import org.thingsboard.server.common.data.edge.Edge; | 36 | import org.thingsboard.server.common.data.edge.Edge; |
21 | -import org.thingsboard.server.common.data.edge.EdgeQueueEntityType; | ||
22 | -import org.thingsboard.server.common.data.edge.EdgeQueueEntry; | 37 | +import org.thingsboard.server.common.data.edge.EdgeEvent; |
38 | +import org.thingsboard.server.common.data.edge.EdgeEventType; | ||
23 | import org.thingsboard.server.common.data.id.EdgeId; | 39 | import org.thingsboard.server.common.data.id.EdgeId; |
24 | import org.thingsboard.server.common.data.id.EntityId; | 40 | import org.thingsboard.server.common.data.id.EntityId; |
25 | import org.thingsboard.server.common.data.id.RuleChainId; | 41 | import org.thingsboard.server.common.data.id.RuleChainId; |
@@ -36,6 +52,7 @@ import org.thingsboard.server.common.msg.queue.TbCallback; | @@ -36,6 +52,7 @@ import org.thingsboard.server.common.msg.queue.TbCallback; | ||
36 | import org.thingsboard.server.common.msg.session.SessionMsgType; | 52 | import org.thingsboard.server.common.msg.session.SessionMsgType; |
37 | import org.thingsboard.server.dao.asset.AssetService; | 53 | import org.thingsboard.server.dao.asset.AssetService; |
38 | import org.thingsboard.server.dao.device.DeviceService; | 54 | import org.thingsboard.server.dao.device.DeviceService; |
55 | +import org.thingsboard.server.dao.edge.EdgeEventService; | ||
39 | import org.thingsboard.server.dao.edge.EdgeService; | 56 | import org.thingsboard.server.dao.edge.EdgeService; |
40 | import org.thingsboard.server.dao.entityview.EntityViewService; | 57 | import org.thingsboard.server.dao.entityview.EntityViewService; |
41 | import org.thingsboard.server.dao.event.EventService; | 58 | import org.thingsboard.server.dao.event.EventService; |
@@ -79,7 +96,7 @@ public class DefaultEdgeNotificationService implements EdgeNotificationService { | @@ -79,7 +96,7 @@ public class DefaultEdgeNotificationService implements EdgeNotificationService { | ||
79 | private RelationService relationService; | 96 | private RelationService relationService; |
80 | 97 | ||
81 | @Autowired | 98 | @Autowired |
82 | - private EventService eventService; | 99 | + private EdgeEventService edgeEventService; |
83 | 100 | ||
84 | private ExecutorService tsCallBackExecutor; | 101 | private ExecutorService tsCallBackExecutor; |
85 | 102 | ||
@@ -96,8 +113,8 @@ public class DefaultEdgeNotificationService implements EdgeNotificationService { | @@ -96,8 +113,8 @@ public class DefaultEdgeNotificationService implements EdgeNotificationService { | ||
96 | } | 113 | } |
97 | 114 | ||
98 | @Override | 115 | @Override |
99 | - public TimePageData<Event> findQueueEvents(TenantId tenantId, EdgeId edgeId, TimePageLink pageLink) { | ||
100 | - return eventService.findEvents(tenantId, edgeId, DataConstants.EDGE_QUEUE_EVENT_TYPE, pageLink); | 116 | + public TimePageData<EdgeEvent> findEdgeEvents(TenantId tenantId, EdgeId edgeId, TimePageLink pageLink) { |
117 | + return edgeEventService.findEdgeEvents(tenantId, edgeId, pageLink); | ||
101 | } | 118 | } |
102 | 119 | ||
103 | @Override | 120 | @Override |
@@ -105,7 +122,7 @@ public class DefaultEdgeNotificationService implements EdgeNotificationService { | @@ -105,7 +122,7 @@ public class DefaultEdgeNotificationService implements EdgeNotificationService { | ||
105 | edge.setRootRuleChainId(ruleChainId); | 122 | edge.setRootRuleChainId(ruleChainId); |
106 | Edge savedEdge = edgeService.saveEdge(edge); | 123 | Edge savedEdge = edgeService.saveEdge(edge); |
107 | RuleChain ruleChain = ruleChainService.findRuleChainById(tenantId, ruleChainId); | 124 | RuleChain ruleChain = ruleChainService.findRuleChainById(tenantId, ruleChainId); |
108 | - saveEventToEdgeQueue(tenantId, edge.getId(), EdgeQueueEntityType.RULE_CHAIN, DataConstants.ENTITY_UPDATED, mapper.writeValueAsString(ruleChain), new FutureCallback<Void>() { | 125 | + saveEventToEdgeQueue(tenantId, edge.getId(), EdgeEventType.RULE_CHAIN, DataConstants.ENTITY_UPDATED, mapper.writeValueAsString(ruleChain), new FutureCallback<Void>() { |
109 | @Override | 126 | @Override |
110 | public void onSuccess(@Nullable Void aVoid) { | 127 | public void onSuccess(@Nullable Void aVoid) { |
111 | log.debug("Event saved successfully!"); | 128 | log.debug("Event saved successfully!"); |
@@ -119,28 +136,28 @@ public class DefaultEdgeNotificationService implements EdgeNotificationService { | @@ -119,28 +136,28 @@ public class DefaultEdgeNotificationService implements EdgeNotificationService { | ||
119 | return savedEdge; | 136 | return savedEdge; |
120 | } | 137 | } |
121 | 138 | ||
122 | - private void saveEventToEdgeQueue(TenantId tenantId, EdgeId edgeId, EdgeQueueEntityType entityType, String type, String data, FutureCallback<Void> callback) throws IOException { | 139 | + private void saveEventToEdgeQueue(TenantId tenantId, EdgeId edgeId, EdgeEventType entityType, String type, String data, FutureCallback<Void> callback) throws IOException { |
123 | log.debug("Pushing single event to edge queue. tenantId [{}], edgeId [{}], entityType [{}], type[{}], data [{}]", tenantId, edgeId, entityType, type, data); | 140 | log.debug("Pushing single event to edge queue. tenantId [{}], edgeId [{}], entityType [{}], type[{}], data [{}]", tenantId, edgeId, entityType, type, data); |
124 | 141 | ||
125 | - EdgeQueueEntry queueEntry = new EdgeQueueEntry(); | ||
126 | - queueEntry.setEntityType(entityType); | ||
127 | - queueEntry.setType(type); | ||
128 | - queueEntry.setData(data); | 142 | +// EdgeEQueueEntry queueEntry = new EdgeQueueEntry(); |
143 | +// queueEntry.setEntityType(entityType); | ||
144 | +// queueEntry.setType(type); | ||
145 | +// queueEntry.setData(data); | ||
129 | 146 | ||
130 | - Event event = new Event(); | ||
131 | - event.setEntityId(edgeId); | ||
132 | - event.setTenantId(tenantId); | ||
133 | - event.setType(DataConstants.EDGE_QUEUE_EVENT_TYPE); | ||
134 | - event.setBody(mapper.valueToTree(queueEntry)); | ||
135 | - ListenableFuture<Event> saveFuture = eventService.saveAsync(event); | 147 | + EdgeEvent edgeEvent = new EdgeEvent(); |
148 | + edgeEvent.setEdgeId(edgeId); | ||
149 | + edgeEvent.setTenantId(tenantId); | ||
150 | +// event.setType(DataConstants.EDGE_QUEUE_EVENT_TYPE); | ||
151 | +// event.setBody(mapper.valueToTree(queueEntry)); | ||
152 | + ListenableFuture<EdgeEvent> saveFuture = edgeEventService.saveAsync(edgeEvent); | ||
136 | 153 | ||
137 | addMainCallback(saveFuture, callback); | 154 | addMainCallback(saveFuture, callback); |
138 | } | 155 | } |
139 | 156 | ||
140 | - private void addMainCallback(ListenableFuture<Event> saveFuture, final FutureCallback<Void> callback) { | ||
141 | - Futures.addCallback(saveFuture, new FutureCallback<Event>() { | 157 | + private void addMainCallback(ListenableFuture<EdgeEvent> saveFuture, final FutureCallback<Void> callback) { |
158 | + Futures.addCallback(saveFuture, new FutureCallback<EdgeEvent>() { | ||
142 | @Override | 159 | @Override |
143 | - public void onSuccess(@Nullable Event result) { | 160 | + public void onSuccess(@Nullable EdgeEvent result) { |
144 | callback.onSuccess(null); | 161 | callback.onSuccess(null); |
145 | } | 162 | } |
146 | 163 | ||
@@ -153,52 +170,52 @@ public class DefaultEdgeNotificationService implements EdgeNotificationService { | @@ -153,52 +170,52 @@ public class DefaultEdgeNotificationService implements EdgeNotificationService { | ||
153 | 170 | ||
154 | @Override | 171 | @Override |
155 | public void pushNotificationToEdge(TransportProtos.EdgeNotificationMsgProto edgeNotificationMsg, TbCallback callback) { | 172 | public void pushNotificationToEdge(TransportProtos.EdgeNotificationMsgProto edgeNotificationMsg, TbCallback callback) { |
156 | - if (tbMsg.getType().equals(SessionMsgType.POST_TELEMETRY_REQUEST.name()) || | ||
157 | - tbMsg.getType().equals(SessionMsgType.POST_ATTRIBUTES_REQUEST.name()) || | ||
158 | - tbMsg.getType().equals(DataConstants.ATTRIBUTES_UPDATED) || | ||
159 | - tbMsg.getType().equals(DataConstants.ATTRIBUTES_DELETED)) { | ||
160 | - processCustomTbMsg(tenantId, tbMsg, callback); | ||
161 | - } else { | ||
162 | - try { | ||
163 | - switch (tbMsg.getOriginator().getEntityType()) { | ||
164 | - case EDGE: | ||
165 | - processEdge(tenantId, tbMsg, callback); | ||
166 | - break; | ||
167 | - case ASSET: | ||
168 | - processAsset(tenantId, tbMsg, callback); | ||
169 | - break; | ||
170 | - case DEVICE: | ||
171 | - processDevice(tenantId, tbMsg, callback); | ||
172 | - break; | ||
173 | - case DASHBOARD: | ||
174 | - processDashboard(tenantId, tbMsg, callback); | ||
175 | - break; | ||
176 | - case RULE_CHAIN: | ||
177 | - processRuleChain(tenantId, tbMsg, callback); | ||
178 | - break; | ||
179 | - case ENTITY_VIEW: | ||
180 | - processEntityView(tenantId, tbMsg, callback); | ||
181 | - break; | ||
182 | - case ALARM: | ||
183 | - processAlarm(tenantId, tbMsg, callback); | ||
184 | - break; | ||
185 | - default: | ||
186 | - log.debug("Entity type [{}] is not designed to be pushed to edge", tbMsg.getOriginator().getEntityType()); | ||
187 | - } | ||
188 | - } catch (IOException e) { | ||
189 | - log.error("Can't push to edge updates, entity type [{}], data [{}]", tbMsg.getOriginator().getEntityType(), tbMsg.getData(), e); | ||
190 | - } | ||
191 | - } | 173 | +// if (tbMsg.getType().equals(SessionMsgType.POST_TELEMETRY_REQUEST.name()) || |
174 | +// tbMsg.getType().equals(SessionMsgType.POST_ATTRIBUTES_REQUEST.name()) || | ||
175 | +// tbMsg.getType().equals(DataConstants.ATTRIBUTES_UPDATED) || | ||
176 | +// tbMsg.getType().equals(DataConstants.ATTRIBUTES_DELETED)) { | ||
177 | +// processCustomTbMsg(tenantId, tbMsg, callback); | ||
178 | +// } else { | ||
179 | +// try { | ||
180 | +// switch (tbMsg.getOriginator().getEntityType()) { | ||
181 | +// case EDGE: | ||
182 | +// processEdge(tenantId, tbMsg, callback); | ||
183 | +// break; | ||
184 | +// case ASSET: | ||
185 | +// processAsset(tenantId, tbMsg, callback); | ||
186 | +// break; | ||
187 | +// case DEVICE: | ||
188 | +// processDevice(tenantId, tbMsg, callback); | ||
189 | +// break; | ||
190 | +// case DASHBOARD: | ||
191 | +// processDashboard(tenantId, tbMsg, callback); | ||
192 | +// break; | ||
193 | +// case RULE_CHAIN: | ||
194 | +// processRuleChain(tenantId, tbMsg, callback); | ||
195 | +// break; | ||
196 | +// case ENTITY_VIEW: | ||
197 | +// processEntityView(tenantId, tbMsg, callback); | ||
198 | +// break; | ||
199 | +// case ALARM: | ||
200 | +// processAlarm(tenantId, tbMsg, callback); | ||
201 | +// break; | ||
202 | +// default: | ||
203 | +// log.debug("Entity type [{}] is not designed to be pushed to edge", tbMsg.getOriginator().getEntityType()); | ||
204 | +// } | ||
205 | +// } catch (IOException e) { | ||
206 | +// log.error("Can't push to edge updates, entity type [{}], data [{}]", tbMsg.getOriginator().getEntityType(), tbMsg.getData(), e); | ||
207 | +// } | ||
208 | +// } | ||
192 | } | 209 | } |
193 | 210 | ||
194 | 211 | ||
195 | private void processCustomTbMsg(TenantId tenantId, TbMsg tbMsg, FutureCallback<Void> callback) { | 212 | private void processCustomTbMsg(TenantId tenantId, TbMsg tbMsg, FutureCallback<Void> callback) { |
196 | ListenableFuture<EdgeId> edgeIdFuture = getEdgeIdByOriginatorId(tenantId, tbMsg.getOriginator()); | 213 | ListenableFuture<EdgeId> edgeIdFuture = getEdgeIdByOriginatorId(tenantId, tbMsg.getOriginator()); |
197 | Futures.transform(edgeIdFuture, edgeId -> { | 214 | Futures.transform(edgeIdFuture, edgeId -> { |
198 | - EdgeQueueEntityType edgeQueueEntityType = getEdgeQueueTypeByEntityType(tbMsg.getOriginator().getEntityType()); | ||
199 | - if (edgeId != null && edgeQueueEntityType != null) { | 215 | + EdgeEventType edgeEventType = getEdgeQueueTypeByEntityType(tbMsg.getOriginator().getEntityType()); |
216 | + if (edgeId != null && edgeEventType != null) { | ||
200 | try { | 217 | try { |
201 | - saveEventToEdgeQueue(tenantId, edgeId, edgeQueueEntityType, tbMsg.getType(), Base64.encodeBase64String(TbMsg.toByteArray(tbMsg)), callback); | 218 | + saveEventToEdgeQueue(tenantId, edgeId, edgeEventType, tbMsg.getType(), Base64.encodeBase64String(TbMsg.toByteArray(tbMsg)), callback); |
202 | } catch (IOException e) { | 219 | } catch (IOException e) { |
203 | log.error("Error while saving custom tbMsg into Edge Queue", e); | 220 | log.error("Error while saving custom tbMsg into Edge Queue", e); |
204 | } | 221 | } |
@@ -211,13 +228,13 @@ public class DefaultEdgeNotificationService implements EdgeNotificationService { | @@ -211,13 +228,13 @@ public class DefaultEdgeNotificationService implements EdgeNotificationService { | ||
211 | switch (tbMsg.getType()) { | 228 | switch (tbMsg.getType()) { |
212 | case DataConstants.ENTITY_ASSIGNED_TO_EDGE: | 229 | case DataConstants.ENTITY_ASSIGNED_TO_EDGE: |
213 | case DataConstants.ENTITY_UNASSIGNED_FROM_EDGE: | 230 | case DataConstants.ENTITY_UNASSIGNED_FROM_EDGE: |
214 | - processAssignedEntity(tenantId, tbMsg, EdgeQueueEntityType.DEVICE, callback); | 231 | + processAssignedEntity(tenantId, tbMsg, EdgeEventType.DEVICE, callback); |
215 | break; | 232 | break; |
216 | case DataConstants.ENTITY_DELETED: | 233 | case DataConstants.ENTITY_DELETED: |
217 | case DataConstants.ENTITY_CREATED: | 234 | case DataConstants.ENTITY_CREATED: |
218 | case DataConstants.ENTITY_UPDATED: | 235 | case DataConstants.ENTITY_UPDATED: |
219 | Device device = mapper.readValue(tbMsg.getData(), Device.class); | 236 | Device device = mapper.readValue(tbMsg.getData(), Device.class); |
220 | - pushEventToEdge(tenantId, device.getId(), EdgeQueueEntityType.DEVICE, tbMsg, callback); | 237 | + pushEventToEdge(tenantId, device.getId(), EdgeEventType.DEVICE, tbMsg, callback); |
221 | break; | 238 | break; |
222 | default: | 239 | default: |
223 | log.warn("Unsupported msgType [{}], tbMsg [{}]", tbMsg.getType(), tbMsg); | 240 | log.warn("Unsupported msgType [{}], tbMsg [{}]", tbMsg.getType(), tbMsg); |
@@ -240,13 +257,13 @@ public class DefaultEdgeNotificationService implements EdgeNotificationService { | @@ -240,13 +257,13 @@ public class DefaultEdgeNotificationService implements EdgeNotificationService { | ||
240 | switch (tbMsg.getType()) { | 257 | switch (tbMsg.getType()) { |
241 | case DataConstants.ENTITY_ASSIGNED_TO_EDGE: | 258 | case DataConstants.ENTITY_ASSIGNED_TO_EDGE: |
242 | case DataConstants.ENTITY_UNASSIGNED_FROM_EDGE: | 259 | case DataConstants.ENTITY_UNASSIGNED_FROM_EDGE: |
243 | - processAssignedEntity(tenantId, tbMsg, EdgeQueueEntityType.ASSET, callback); | 260 | + processAssignedEntity(tenantId, tbMsg, EdgeEventType.ASSET, callback); |
244 | break; | 261 | break; |
245 | case DataConstants.ENTITY_DELETED: | 262 | case DataConstants.ENTITY_DELETED: |
246 | case DataConstants.ENTITY_CREATED: | 263 | case DataConstants.ENTITY_CREATED: |
247 | case DataConstants.ENTITY_UPDATED: | 264 | case DataConstants.ENTITY_UPDATED: |
248 | Asset asset = mapper.readValue(tbMsg.getData(), Asset.class); | 265 | Asset asset = mapper.readValue(tbMsg.getData(), Asset.class); |
249 | - pushEventToEdge(tenantId, asset.getId(), EdgeQueueEntityType.ASSET, tbMsg, callback); | 266 | + pushEventToEdge(tenantId, asset.getId(), EdgeEventType.ASSET, tbMsg, callback); |
250 | break; | 267 | break; |
251 | default: | 268 | default: |
252 | log.warn("Unsupported msgType [{}], tbMsg [{}]", tbMsg.getType(), tbMsg); | 269 | log.warn("Unsupported msgType [{}], tbMsg [{}]", tbMsg.getType(), tbMsg); |
@@ -257,13 +274,13 @@ public class DefaultEdgeNotificationService implements EdgeNotificationService { | @@ -257,13 +274,13 @@ public class DefaultEdgeNotificationService implements EdgeNotificationService { | ||
257 | switch (tbMsg.getType()) { | 274 | switch (tbMsg.getType()) { |
258 | case DataConstants.ENTITY_ASSIGNED_TO_EDGE: | 275 | case DataConstants.ENTITY_ASSIGNED_TO_EDGE: |
259 | case DataConstants.ENTITY_UNASSIGNED_FROM_EDGE: | 276 | case DataConstants.ENTITY_UNASSIGNED_FROM_EDGE: |
260 | - processAssignedEntity(tenantId, tbMsg, EdgeQueueEntityType.ENTITY_VIEW, callback); | 277 | + processAssignedEntity(tenantId, tbMsg, EdgeEventType.ENTITY_VIEW, callback); |
261 | break; | 278 | break; |
262 | case DataConstants.ENTITY_DELETED: | 279 | case DataConstants.ENTITY_DELETED: |
263 | case DataConstants.ENTITY_CREATED: | 280 | case DataConstants.ENTITY_CREATED: |
264 | case DataConstants.ENTITY_UPDATED: | 281 | case DataConstants.ENTITY_UPDATED: |
265 | EntityView entityView = mapper.readValue(tbMsg.getData(), EntityView.class); | 282 | EntityView entityView = mapper.readValue(tbMsg.getData(), EntityView.class); |
266 | - pushEventToEdge(tenantId, entityView.getId(), EdgeQueueEntityType.ENTITY_VIEW, tbMsg, callback); | 283 | + pushEventToEdge(tenantId, entityView.getId(), EdgeEventType.ENTITY_VIEW, tbMsg, callback); |
267 | break; | 284 | break; |
268 | default: | 285 | default: |
269 | log.warn("Unsupported msgType [{}], tbMsg [{}]", tbMsg.getType(), tbMsg); | 286 | log.warn("Unsupported msgType [{}], tbMsg [{}]", tbMsg.getType(), tbMsg); |
@@ -278,9 +295,9 @@ public class DefaultEdgeNotificationService implements EdgeNotificationService { | @@ -278,9 +295,9 @@ public class DefaultEdgeNotificationService implements EdgeNotificationService { | ||
278 | case DataConstants.ALARM_ACK: | 295 | case DataConstants.ALARM_ACK: |
279 | case DataConstants.ALARM_CLEAR: | 296 | case DataConstants.ALARM_CLEAR: |
280 | Alarm alarm = mapper.readValue(tbMsg.getData(), Alarm.class); | 297 | Alarm alarm = mapper.readValue(tbMsg.getData(), Alarm.class); |
281 | - EdgeQueueEntityType edgeQueueEntityType = getEdgeQueueTypeByEntityType(alarm.getOriginator().getEntityType()); | ||
282 | - if (edgeQueueEntityType != null) { | ||
283 | - pushEventToEdge(tenantId, alarm.getOriginator(), EdgeQueueEntityType.ALARM, tbMsg, callback); | 298 | + EdgeEventType edgeEventType = getEdgeQueueTypeByEntityType(alarm.getOriginator().getEntityType()); |
299 | + if (edgeEventType != null) { | ||
300 | + pushEventToEdge(tenantId, alarm.getOriginator(), EdgeEventType.ALARM, tbMsg, callback); | ||
284 | } | 301 | } |
285 | break; | 302 | break; |
286 | default: | 303 | default: |
@@ -292,7 +309,7 @@ public class DefaultEdgeNotificationService implements EdgeNotificationService { | @@ -292,7 +309,7 @@ public class DefaultEdgeNotificationService implements EdgeNotificationService { | ||
292 | switch (tbMsg.getType()) { | 309 | switch (tbMsg.getType()) { |
293 | case DataConstants.ENTITY_ASSIGNED_TO_EDGE: | 310 | case DataConstants.ENTITY_ASSIGNED_TO_EDGE: |
294 | case DataConstants.ENTITY_UNASSIGNED_FROM_EDGE: | 311 | case DataConstants.ENTITY_UNASSIGNED_FROM_EDGE: |
295 | - processAssignedEntity(tenantId, tbMsg, EdgeQueueEntityType.DASHBOARD, callback); | 312 | + processAssignedEntity(tenantId, tbMsg, EdgeEventType.DASHBOARD, callback); |
296 | break; | 313 | break; |
297 | case DataConstants.ENTITY_DELETED: | 314 | case DataConstants.ENTITY_DELETED: |
298 | case DataConstants.ENTITY_CREATED: | 315 | case DataConstants.ENTITY_CREATED: |
@@ -303,7 +320,7 @@ public class DefaultEdgeNotificationService implements EdgeNotificationService { | @@ -303,7 +320,7 @@ public class DefaultEdgeNotificationService implements EdgeNotificationService { | ||
303 | if (edges != null && edges.getData() != null && !edges.getData().isEmpty()) { | 320 | if (edges != null && edges.getData() != null && !edges.getData().isEmpty()) { |
304 | try { | 321 | try { |
305 | for (Edge edge : edges.getData()) { | 322 | for (Edge edge : edges.getData()) { |
306 | - pushEventToEdge(tenantId, edge.getId(), EdgeQueueEntityType.DASHBOARD, tbMsg, callback); | 323 | + pushEventToEdge(tenantId, edge.getId(), EdgeEventType.DASHBOARD, tbMsg, callback); |
307 | } | 324 | } |
308 | } catch (IOException e) { | 325 | } catch (IOException e) { |
309 | log.error("Can't push event to edge", e); | 326 | log.error("Can't push event to edge", e); |
@@ -321,7 +338,7 @@ public class DefaultEdgeNotificationService implements EdgeNotificationService { | @@ -321,7 +338,7 @@ public class DefaultEdgeNotificationService implements EdgeNotificationService { | ||
321 | switch (tbMsg.getType()) { | 338 | switch (tbMsg.getType()) { |
322 | case DataConstants.ENTITY_ASSIGNED_TO_EDGE: | 339 | case DataConstants.ENTITY_ASSIGNED_TO_EDGE: |
323 | case DataConstants.ENTITY_UNASSIGNED_FROM_EDGE: | 340 | case DataConstants.ENTITY_UNASSIGNED_FROM_EDGE: |
324 | - processAssignedEntity(tenantId, tbMsg, EdgeQueueEntityType.RULE_CHAIN, callback); | 341 | + processAssignedEntity(tenantId, tbMsg, EdgeEventType.RULE_CHAIN, callback); |
325 | break; | 342 | break; |
326 | case DataConstants.ENTITY_DELETED: | 343 | case DataConstants.ENTITY_DELETED: |
327 | case DataConstants.ENTITY_CREATED: | 344 | case DataConstants.ENTITY_CREATED: |
@@ -333,7 +350,7 @@ public class DefaultEdgeNotificationService implements EdgeNotificationService { | @@ -333,7 +350,7 @@ public class DefaultEdgeNotificationService implements EdgeNotificationService { | ||
333 | if (edges != null && edges.getData() != null && !edges.getData().isEmpty()) { | 350 | if (edges != null && edges.getData() != null && !edges.getData().isEmpty()) { |
334 | try { | 351 | try { |
335 | for (Edge edge : edges.getData()) { | 352 | for (Edge edge : edges.getData()) { |
336 | - pushEventToEdge(tenantId, edge.getId(), EdgeQueueEntityType.RULE_CHAIN, tbMsg, callback); | 353 | + pushEventToEdge(tenantId, edge.getId(), EdgeEventType.RULE_CHAIN, tbMsg, callback); |
337 | } | 354 | } |
338 | } catch (IOException e) { | 355 | } catch (IOException e) { |
339 | log.error("Can't push event to edge", e); | 356 | log.error("Can't push event to edge", e); |
@@ -349,7 +366,7 @@ public class DefaultEdgeNotificationService implements EdgeNotificationService { | @@ -349,7 +366,7 @@ public class DefaultEdgeNotificationService implements EdgeNotificationService { | ||
349 | } | 366 | } |
350 | 367 | ||
351 | 368 | ||
352 | - private void processAssignedEntity(TenantId tenantId, TbMsg tbMsg, EdgeQueueEntityType entityType, FutureCallback<Void> callback) throws IOException { | 369 | + private void processAssignedEntity(TenantId tenantId, TbMsg tbMsg, EdgeEventType entityType, FutureCallback<Void> callback) throws IOException { |
353 | EdgeId edgeId; | 370 | EdgeId edgeId; |
354 | switch (tbMsg.getType()) { | 371 | switch (tbMsg.getType()) { |
355 | case DataConstants.ENTITY_ASSIGNED_TO_EDGE: | 372 | case DataConstants.ENTITY_ASSIGNED_TO_EDGE: |
@@ -364,13 +381,12 @@ public class DefaultEdgeNotificationService implements EdgeNotificationService { | @@ -364,13 +381,12 @@ public class DefaultEdgeNotificationService implements EdgeNotificationService { | ||
364 | } | 381 | } |
365 | } | 382 | } |
366 | 383 | ||
367 | - | ||
368 | - private void pushEventToEdge(TenantId tenantId, EntityId originatorId, EdgeQueueEntityType edgeQueueEntityType, TbMsg tbMsg, FutureCallback<Void> callback) { | 384 | + private void pushEventToEdge(TenantId tenantId, EntityId originatorId, EdgeEventType edgeEventType, TbMsg tbMsg, FutureCallback<Void> callback) { |
369 | ListenableFuture<EdgeId> edgeIdFuture = getEdgeIdByOriginatorId(tenantId, originatorId); | 385 | ListenableFuture<EdgeId> edgeIdFuture = getEdgeIdByOriginatorId(tenantId, originatorId); |
370 | Futures.transform(edgeIdFuture, edgeId -> { | 386 | Futures.transform(edgeIdFuture, edgeId -> { |
371 | if (edgeId != null) { | 387 | if (edgeId != null) { |
372 | try { | 388 | try { |
373 | - pushEventToEdge(tenantId, edgeId, edgeQueueEntityType, tbMsg, callback); | 389 | + pushEventToEdge(tenantId, edgeId, edgeEventType, tbMsg, callback); |
374 | } catch (Exception e) { | 390 | } catch (Exception e) { |
375 | log.error("Failed to push event to edge, edgeId [{}], tbMsg [{}]", edgeId, tbMsg, e); | 391 | log.error("Failed to push event to edge, edgeId [{}], tbMsg [{}]", edgeId, tbMsg, e); |
376 | } | 392 | } |
@@ -380,7 +396,6 @@ public class DefaultEdgeNotificationService implements EdgeNotificationService { | @@ -380,7 +396,6 @@ public class DefaultEdgeNotificationService implements EdgeNotificationService { | ||
380 | MoreExecutors.directExecutor()); | 396 | MoreExecutors.directExecutor()); |
381 | } | 397 | } |
382 | 398 | ||
383 | - | ||
384 | private ListenableFuture<EdgeId> getEdgeIdByOriginatorId(TenantId tenantId, EntityId originatorId) { | 399 | private ListenableFuture<EdgeId> getEdgeIdByOriginatorId(TenantId tenantId, EntityId originatorId) { |
385 | List<EntityRelation> originatorEdgeRelations = relationService.findByToAndType(tenantId, originatorId, EntityRelation.CONTAINS_TYPE, RelationTypeGroup.EDGE); | 400 | List<EntityRelation> originatorEdgeRelations = relationService.findByToAndType(tenantId, originatorId, EntityRelation.CONTAINS_TYPE, RelationTypeGroup.EDGE); |
386 | if (originatorEdgeRelations != null && originatorEdgeRelations.size() > 0) { | 401 | if (originatorEdgeRelations != null && originatorEdgeRelations.size() > 0) { |
@@ -391,12 +406,12 @@ public class DefaultEdgeNotificationService implements EdgeNotificationService { | @@ -391,12 +406,12 @@ public class DefaultEdgeNotificationService implements EdgeNotificationService { | ||
391 | } | 406 | } |
392 | 407 | ||
393 | 408 | ||
394 | - private void pushEventToEdge(TenantId tenantId, EdgeId edgeId, EdgeQueueEntityType entityType, TbMsg tbMsg, FutureCallback<Void> callback) throws IOException { | 409 | + private void pushEventToEdge(TenantId tenantId, EdgeId edgeId, EdgeEventType entityType, TbMsg tbMsg, FutureCallback<Void> callback) throws IOException { |
395 | log.debug("Pushing event(s) to edge queue. tenantId [{}], edgeId [{}], entityType [{}], tbMsg [{}]", tenantId, edgeId, entityType, tbMsg); | 410 | log.debug("Pushing event(s) to edge queue. tenantId [{}], edgeId [{}], entityType [{}], tbMsg [{}]", tenantId, edgeId, entityType, tbMsg); |
396 | 411 | ||
397 | saveEventToEdgeQueue(tenantId, edgeId, entityType, tbMsg.getType(), tbMsg.getData(), callback); | 412 | saveEventToEdgeQueue(tenantId, edgeId, entityType, tbMsg.getType(), tbMsg.getData(), callback); |
398 | 413 | ||
399 | - if (entityType.equals(EdgeQueueEntityType.RULE_CHAIN)) { | 414 | + if (entityType.equals(EdgeEventType.RULE_CHAIN)) { |
400 | pushRuleChainMetadataToEdge(tenantId, edgeId, tbMsg, callback); | 415 | pushRuleChainMetadataToEdge(tenantId, edgeId, tbMsg, callback); |
401 | } | 416 | } |
402 | } | 417 | } |
@@ -408,7 +423,7 @@ public class DefaultEdgeNotificationService implements EdgeNotificationService { | @@ -408,7 +423,7 @@ public class DefaultEdgeNotificationService implements EdgeNotificationService { | ||
408 | case DataConstants.ENTITY_UNASSIGNED_FROM_EDGE: | 423 | case DataConstants.ENTITY_UNASSIGNED_FROM_EDGE: |
409 | case DataConstants.ENTITY_UPDATED: | 424 | case DataConstants.ENTITY_UPDATED: |
410 | RuleChainMetaData ruleChainMetaData = ruleChainService.loadRuleChainMetaData(tenantId, ruleChain.getId()); | 425 | RuleChainMetaData ruleChainMetaData = ruleChainService.loadRuleChainMetaData(tenantId, ruleChain.getId()); |
411 | - saveEventToEdgeQueue(tenantId, edgeId, EdgeQueueEntityType.RULE_CHAIN_METADATA, tbMsg.getType(), mapper.writeValueAsString(ruleChainMetaData), callback); | 426 | + saveEventToEdgeQueue(tenantId, edgeId, EdgeEventType.RULE_CHAIN_METADATA, tbMsg.getType(), mapper.writeValueAsString(ruleChainMetaData), callback); |
412 | break; | 427 | break; |
413 | default: | 428 | default: |
414 | log.warn("Unsupported msgType [{}], tbMsg [{}]", tbMsg.getType(), tbMsg); | 429 | log.warn("Unsupported msgType [{}], tbMsg [{}]", tbMsg.getType(), tbMsg); |
@@ -416,14 +431,14 @@ public class DefaultEdgeNotificationService implements EdgeNotificationService { | @@ -416,14 +431,14 @@ public class DefaultEdgeNotificationService implements EdgeNotificationService { | ||
416 | } | 431 | } |
417 | 432 | ||
418 | 433 | ||
419 | - private EdgeQueueEntityType getEdgeQueueTypeByEntityType(EntityType entityType) { | 434 | + private EdgeEventType getEdgeQueueTypeByEntityType(EntityType entityType) { |
420 | switch (entityType) { | 435 | switch (entityType) { |
421 | case DEVICE: | 436 | case DEVICE: |
422 | - return EdgeQueueEntityType.DEVICE; | 437 | + return EdgeEventType.DEVICE; |
423 | case ASSET: | 438 | case ASSET: |
424 | - return EdgeQueueEntityType.ASSET; | 439 | + return EdgeEventType.ASSET; |
425 | case ENTITY_VIEW: | 440 | case ENTITY_VIEW: |
426 | - return EdgeQueueEntityType.ENTITY_VIEW; | 441 | + return EdgeEventType.ENTITY_VIEW; |
427 | default: | 442 | default: |
428 | log.info("Unsupported entity type: [{}]", entityType); | 443 | log.info("Unsupported entity type: [{}]", entityType); |
429 | return null; | 444 | return null; |
1 | +/** | ||
2 | + * Copyright © 2016-2020 The Thingsboard Authors | ||
3 | + * | ||
4 | + * Licensed under the Apache License, Version 2.0 (the "License"); | ||
5 | + * you may not use this file except in compliance with the License. | ||
6 | + * You may obtain a copy of the License at | ||
7 | + * | ||
8 | + * http://www.apache.org/licenses/LICENSE-2.0 | ||
9 | + * | ||
10 | + * Unless required by applicable law or agreed to in writing, software | ||
11 | + * distributed under the License is distributed on an "AS IS" BASIS, | ||
12 | + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||
13 | + * See the License for the specific language governing permissions and | ||
14 | + * limitations under the License. | ||
15 | + */ | ||
1 | package org.thingsboard.server.service.edge; | 16 | package org.thingsboard.server.service.edge; |
2 | 17 | ||
3 | import org.thingsboard.server.common.data.Event; | 18 | import org.thingsboard.server.common.data.Event; |
4 | import org.thingsboard.server.common.data.edge.Edge; | 19 | import org.thingsboard.server.common.data.edge.Edge; |
20 | +import org.thingsboard.server.common.data.edge.EdgeEvent; | ||
5 | import org.thingsboard.server.common.data.id.EdgeId; | 21 | import org.thingsboard.server.common.data.id.EdgeId; |
6 | import org.thingsboard.server.common.data.id.RuleChainId; | 22 | import org.thingsboard.server.common.data.id.RuleChainId; |
7 | import org.thingsboard.server.common.data.id.TenantId; | 23 | import org.thingsboard.server.common.data.id.TenantId; |
@@ -14,7 +30,7 @@ import java.io.IOException; | @@ -14,7 +30,7 @@ import java.io.IOException; | ||
14 | 30 | ||
15 | public interface EdgeNotificationService { | 31 | public interface EdgeNotificationService { |
16 | 32 | ||
17 | - TimePageData<Event> findQueueEvents(TenantId tenantId, EdgeId edgeId, TimePageLink pageLink); | 33 | + TimePageData<EdgeEvent> findEdgeEvents(TenantId tenantId, EdgeId edgeId, TimePageLink pageLink); |
18 | 34 | ||
19 | Edge setEdgeRootRuleChain(TenantId tenantId, Edge edge, RuleChainId ruleChainId) throws IOException; | 35 | Edge setEdgeRootRuleChain(TenantId tenantId, Edge edge, RuleChainId ruleChainId) throws IOException; |
20 | 36 |
@@ -33,14 +33,14 @@ import org.thingsboard.server.common.data.DataConstants; | @@ -33,14 +33,14 @@ import org.thingsboard.server.common.data.DataConstants; | ||
33 | import org.thingsboard.server.common.data.Device; | 33 | import org.thingsboard.server.common.data.Device; |
34 | import org.thingsboard.server.common.data.EntityType; | 34 | import org.thingsboard.server.common.data.EntityType; |
35 | import org.thingsboard.server.common.data.EntityView; | 35 | import org.thingsboard.server.common.data.EntityView; |
36 | -import org.thingsboard.server.common.data.Event; | ||
37 | import org.thingsboard.server.common.data.User; | 36 | import org.thingsboard.server.common.data.User; |
38 | import org.thingsboard.server.common.data.alarm.Alarm; | 37 | import org.thingsboard.server.common.data.alarm.Alarm; |
39 | import org.thingsboard.server.common.data.alarm.AlarmSeverity; | 38 | import org.thingsboard.server.common.data.alarm.AlarmSeverity; |
40 | import org.thingsboard.server.common.data.alarm.AlarmStatus; | 39 | import org.thingsboard.server.common.data.alarm.AlarmStatus; |
41 | import org.thingsboard.server.common.data.asset.Asset; | 40 | import org.thingsboard.server.common.data.asset.Asset; |
41 | +import org.thingsboard.server.common.data.audit.ActionType; | ||
42 | import org.thingsboard.server.common.data.edge.Edge; | 42 | import org.thingsboard.server.common.data.edge.Edge; |
43 | -import org.thingsboard.server.common.data.edge.EdgeQueueEntry; | 43 | +import org.thingsboard.server.common.data.edge.EdgeEvent; |
44 | import org.thingsboard.server.common.data.id.AssetId; | 44 | import org.thingsboard.server.common.data.id.AssetId; |
45 | import org.thingsboard.server.common.data.id.DeviceId; | 45 | import org.thingsboard.server.common.data.id.DeviceId; |
46 | import org.thingsboard.server.common.data.id.EdgeId; | 46 | import org.thingsboard.server.common.data.id.EdgeId; |
@@ -63,7 +63,6 @@ import org.thingsboard.server.common.msg.TbMsg; | @@ -63,7 +63,6 @@ import org.thingsboard.server.common.msg.TbMsg; | ||
63 | import org.thingsboard.server.common.msg.TbMsgDataType; | 63 | import org.thingsboard.server.common.msg.TbMsgDataType; |
64 | import org.thingsboard.server.common.msg.TbMsgMetaData; | 64 | import org.thingsboard.server.common.msg.TbMsgMetaData; |
65 | import org.thingsboard.server.common.msg.queue.TbMsgCallback; | 65 | import org.thingsboard.server.common.msg.queue.TbMsgCallback; |
66 | -import org.thingsboard.server.common.msg.session.SessionMsgType; | ||
67 | import org.thingsboard.server.gen.edge.AlarmUpdateMsg; | 66 | import org.thingsboard.server.gen.edge.AlarmUpdateMsg; |
68 | import org.thingsboard.server.gen.edge.ConnectRequestMsg; | 67 | import org.thingsboard.server.gen.edge.ConnectRequestMsg; |
69 | import org.thingsboard.server.gen.edge.ConnectResponseCode; | 68 | import org.thingsboard.server.gen.edge.ConnectResponseCode; |
@@ -169,36 +168,28 @@ public final class EdgeGrpcSession implements Closeable { | @@ -169,36 +168,28 @@ public final class EdgeGrpcSession implements Closeable { | ||
169 | void processHandleMessages() throws ExecutionException, InterruptedException { | 168 | void processHandleMessages() throws ExecutionException, InterruptedException { |
170 | Long queueStartTs = getQueueStartTs().get(); | 169 | Long queueStartTs = getQueueStartTs().get(); |
171 | TimePageLink pageLink = new TimePageLink(ctx.getEdgeEventStorageSettings().getMaxReadRecordsCount(), queueStartTs, null, true); | 170 | TimePageLink pageLink = new TimePageLink(ctx.getEdgeEventStorageSettings().getMaxReadRecordsCount(), queueStartTs, null, true); |
172 | - TimePageData<Event> pageData; | 171 | + TimePageData<EdgeEvent> pageData; |
173 | UUID ifOffset = null; | 172 | UUID ifOffset = null; |
174 | do { | 173 | do { |
175 | - pageData = ctx.getEdgeNotificationService().findQueueEvents(edge.getTenantId(), edge.getId(), pageLink); | 174 | + pageData = ctx.getEdgeNotificationService().findEdgeEvents(edge.getTenantId(), edge.getId(), pageLink); |
176 | if (isConnected() && !pageData.getData().isEmpty()) { | 175 | if (isConnected() && !pageData.getData().isEmpty()) { |
177 | log.trace("[{}] [{}] event(s) are going to be processed.", this.sessionId, pageData.getData().size()); | 176 | log.trace("[{}] [{}] event(s) are going to be processed.", this.sessionId, pageData.getData().size()); |
178 | - for (Event event : pageData.getData()) { | ||
179 | - log.trace("[{}] Processing event [{}]", this.sessionId, event); | 177 | + for (EdgeEvent edgeEvent : pageData.getData()) { |
178 | + log.trace("[{}] Processing edge event [{}]", this.sessionId, edgeEvent); | ||
180 | try { | 179 | try { |
181 | - EdgeQueueEntry entry = objectMapper.treeToValue(event.getBody(), EdgeQueueEntry.class); | ||
182 | - UpdateMsgType msgType = getResponseMsgType(entry.getType()); | ||
183 | - switch (msgType) { | ||
184 | - case ENTITY_DELETED_RPC_MESSAGE: | ||
185 | - case ENTITY_UPDATED_RPC_MESSAGE: | ||
186 | - case ENTITY_CREATED_RPC_MESSAGE: | ||
187 | - case ALARM_ACK_RPC_MESSAGE: | ||
188 | - case ALARM_CLEAR_RPC_MESSAGE: | ||
189 | - processEntityCRUDMessage(entry, msgType); | ||
190 | - break; | ||
191 | - case RULE_CHAIN_CUSTOM_MESSAGE: | ||
192 | - processCustomDownlinkMessage(entry); | ||
193 | - break; | 180 | + UpdateMsgType msgType = getResponseMsgType(ActionType.valueOf(edgeEvent.getEdgeEventAction())); |
181 | + if (msgType == null) { | ||
182 | + processTelemetryMessage(edgeEvent); | ||
183 | + } else { | ||
184 | + processEntityCRUDMessage(edgeEvent, msgType); | ||
194 | } | 185 | } |
195 | if (ENTITY_CREATED_RPC_MESSAGE.equals(msgType)) { | 186 | if (ENTITY_CREATED_RPC_MESSAGE.equals(msgType)) { |
196 | - pushEntityAttributesToEdge(entry); | 187 | + pushEntityAttributesToEdge(edgeEvent); |
197 | } | 188 | } |
198 | } catch (Exception e) { | 189 | } catch (Exception e) { |
199 | log.error("Exception during processing records from queue", e); | 190 | log.error("Exception during processing records from queue", e); |
200 | } | 191 | } |
201 | - ifOffset = event.getUuidId(); | 192 | + ifOffset = edgeEvent.getUuidId(); |
202 | } | 193 | } |
203 | } | 194 | } |
204 | if (isConnected() && pageData.hasNext()) { | 195 | if (isConnected() && pageData.hasNext()) { |
@@ -222,10 +213,10 @@ public final class EdgeGrpcSession implements Closeable { | @@ -222,10 +213,10 @@ public final class EdgeGrpcSession implements Closeable { | ||
222 | } | 213 | } |
223 | } | 214 | } |
224 | 215 | ||
225 | - private void pushEntityAttributesToEdge(EdgeQueueEntry entry) throws IOException { | 216 | + private void pushEntityAttributesToEdge(EdgeEvent edgeEvent) throws IOException { |
226 | EntityId entityId = null; | 217 | EntityId entityId = null; |
227 | String entityName = null; | 218 | String entityName = null; |
228 | - switch (entry.getEntityType()) { | 219 | + switch (edgeEvent.getEdgeEventType()) { |
229 | case EDGE: | 220 | case EDGE: |
230 | Edge edge = objectMapper.readValue(entry.getData(), Edge.class); | 221 | Edge edge = objectMapper.readValue(entry.getData(), Edge.class); |
231 | entityId = edge.getId(); | 222 | entityId = edge.getId(); |
@@ -277,7 +268,7 @@ public final class EdgeGrpcSession implements Closeable { | @@ -277,7 +268,7 @@ public final class EdgeGrpcSession implements Closeable { | ||
277 | , objectMapper.writeValueAsString(entityNode)); | 268 | , objectMapper.writeValueAsString(entityNode)); |
278 | log.debug("Sending donwlink entity data msg, entityName [{}], tbMsg [{}]", finalEntityName, tbMsg); | 269 | log.debug("Sending donwlink entity data msg, entityName [{}], tbMsg [{}]", finalEntityName, tbMsg); |
279 | outputStream.onNext(ResponseMsg.newBuilder() | 270 | outputStream.onNext(ResponseMsg.newBuilder() |
280 | - .setDownlinkMsg(constructDownlinkEntityDataMsg(finalEntityName, finalEntityId, tbMsg)) | 271 | + .setDownlinkMsg(constructEntityDataProtoMsg(finalEntityName, finalEntityId, tbMsg)) |
281 | .build()); | 272 | .build()); |
282 | } catch (Exception e) { | 273 | } catch (Exception e) { |
283 | log.error("[{}] Failed to send attribute updates to the edge", edge.getName(), e); | 274 | log.error("[{}] Failed to send attribute updates to the edge", edge.getName(), e); |
@@ -290,12 +281,12 @@ public final class EdgeGrpcSession implements Closeable { | @@ -290,12 +281,12 @@ public final class EdgeGrpcSession implements Closeable { | ||
290 | } | 281 | } |
291 | } | 282 | } |
292 | 283 | ||
293 | - private void processCustomDownlinkMessage(EdgeQueueEntry entry) throws IOException { | ||
294 | - log.trace("Executing processCustomDownlinkMessage, entry [{}]", entry); | 284 | + private void processTelemetryMessage(EdgeEvent edgeEvent) throws IOException { |
285 | + log.trace("Executing processTelemetryMessage, edgeEvent [{}]", edgeEvent); | ||
295 | TbMsg tbMsg = TbMsg.fromBytes(Base64.decodeBase64(entry.getData()), TbMsgCallback.EMPTY); | 286 | TbMsg tbMsg = TbMsg.fromBytes(Base64.decodeBase64(entry.getData()), TbMsgCallback.EMPTY); |
296 | String entityName = null; | 287 | String entityName = null; |
297 | EntityId entityId = null; | 288 | EntityId entityId = null; |
298 | - switch (entry.getEntityType()) { | 289 | + switch (edgeEvent.getEdgeEventType()) { |
299 | case DEVICE: | 290 | case DEVICE: |
300 | Device device = ctx.getDeviceService().findDeviceById(edge.getTenantId(), new DeviceId(tbMsg.getOriginator().getId())); | 291 | Device device = ctx.getDeviceService().findDeviceById(edge.getTenantId(), new DeviceId(tbMsg.getOriginator().getId())); |
301 | entityName = device.getName(); | 292 | entityName = device.getName(); |
@@ -316,14 +307,14 @@ public final class EdgeGrpcSession implements Closeable { | @@ -316,14 +307,14 @@ public final class EdgeGrpcSession implements Closeable { | ||
316 | if (entityName != null && entityId != null) { | 307 | if (entityName != null && entityId != null) { |
317 | log.debug("Sending downlink entity data msg, entityName [{}], tbMsg [{}]", entityName, tbMsg); | 308 | log.debug("Sending downlink entity data msg, entityName [{}], tbMsg [{}]", entityName, tbMsg); |
318 | outputStream.onNext(ResponseMsg.newBuilder() | 309 | outputStream.onNext(ResponseMsg.newBuilder() |
319 | - .setDownlinkMsg(constructDownlinkEntityDataMsg(entityName, entityId, tbMsg)) | 310 | + .setDownlinkMsg(constructEntityDataProtoMsg(entityName, entityId, tbMsg)) |
320 | .build()); | 311 | .build()); |
321 | } | 312 | } |
322 | } | 313 | } |
323 | 314 | ||
324 | - private void processEntityCRUDMessage(EdgeQueueEntry entry, UpdateMsgType msgType) throws java.io.IOException { | ||
325 | - log.trace("Executing processEntityCRUDMessage, entry [{}], msgType [{}]", entry, msgType); | ||
326 | - switch (entry.getEntityType()) { | 315 | + private void processEntityCRUDMessage(EdgeEvent edgeEvent, UpdateMsgType msgType) throws java.io.IOException { |
316 | + log.trace("Executing processEntityCRUDMessage, edgeEvent [{}], msgType [{}]", edgeEvent, msgType); | ||
317 | + switch (edgeEvent.getEdgeEventType()) { | ||
327 | case EDGE: | 318 | case EDGE: |
328 | Edge edge = objectMapper.readValue(entry.getData(), Edge.class); | 319 | Edge edge = objectMapper.readValue(entry.getData(), Edge.class); |
329 | onEdgeUpdated(msgType, edge); | 320 | onEdgeUpdated(msgType, edge); |
@@ -476,33 +467,30 @@ public final class EdgeGrpcSession implements Closeable { | @@ -476,33 +467,30 @@ public final class EdgeGrpcSession implements Closeable { | ||
476 | .build()); | 467 | .build()); |
477 | } | 468 | } |
478 | 469 | ||
479 | - private UpdateMsgType getResponseMsgType(String msgType) { | ||
480 | - if (msgType.equals(SessionMsgType.POST_TELEMETRY_REQUEST.name()) || | ||
481 | - msgType.equals(SessionMsgType.POST_ATTRIBUTES_REQUEST.name()) || | ||
482 | - msgType.equals(DataConstants.ATTRIBUTES_UPDATED) || | ||
483 | - msgType.equals(DataConstants.ATTRIBUTES_DELETED)) { | ||
484 | - return UpdateMsgType.RULE_CHAIN_CUSTOM_MESSAGE; | ||
485 | - } else { | ||
486 | - switch (msgType) { | ||
487 | - case DataConstants.ENTITY_UPDATED: | ||
488 | - return UpdateMsgType.ENTITY_UPDATED_RPC_MESSAGE; | ||
489 | - case DataConstants.ENTITY_CREATED: | ||
490 | - case DataConstants.ENTITY_ASSIGNED_TO_EDGE: | ||
491 | - return ENTITY_CREATED_RPC_MESSAGE; | ||
492 | - case DataConstants.ENTITY_DELETED: | ||
493 | - case DataConstants.ENTITY_UNASSIGNED_FROM_EDGE: | ||
494 | - return UpdateMsgType.ENTITY_DELETED_RPC_MESSAGE; | ||
495 | - case DataConstants.ALARM_ACK: | ||
496 | - return UpdateMsgType.ALARM_ACK_RPC_MESSAGE; | ||
497 | - case DataConstants.ALARM_CLEAR: | ||
498 | - return UpdateMsgType.ALARM_CLEAR_RPC_MESSAGE; | ||
499 | - default: | ||
500 | - throw new RuntimeException("Unsupported msgType [" + msgType + "]"); | ||
501 | - } | 470 | + private UpdateMsgType getResponseMsgType(ActionType actionType) { |
471 | + switch (actionType) { | ||
472 | + case ADDED: | ||
473 | + return UpdateMsgType.ENTITY_UPDATED_RPC_MESSAGE; | ||
474 | + case UPDATED: | ||
475 | + case ASSIGNED_TO_EDGE: | ||
476 | + return ENTITY_CREATED_RPC_MESSAGE; | ||
477 | + case DELETED: | ||
478 | + case UNASSIGNED_FROM_EDGE: | ||
479 | + return UpdateMsgType.ENTITY_DELETED_RPC_MESSAGE; | ||
480 | + case ALARM_ACK: | ||
481 | + return UpdateMsgType.ALARM_ACK_RPC_MESSAGE; | ||
482 | + case ALARM_CLEAR: | ||
483 | + return UpdateMsgType.ALARM_CLEAR_RPC_MESSAGE; | ||
484 | + case ATTRIBUTES_UPDATED: | ||
485 | + case ATTRIBUTES_DELETED: | ||
486 | + case TIMESERIES_DELETED: | ||
487 | + return null; | ||
488 | + default: | ||
489 | + throw new RuntimeException("Unsupported actionType [" + actionType + "]"); | ||
502 | } | 490 | } |
503 | } | 491 | } |
504 | 492 | ||
505 | - private DownlinkMsg constructDownlinkEntityDataMsg(String entityName, EntityId entityId, TbMsg tbMsg) { | 493 | + private DownlinkMsg constructEntityDataProtoMsg(String entityName, EntityId entityId, TbMsg tbMsg) { |
506 | EntityDataProto entityData = EntityDataProto.newBuilder() | 494 | EntityDataProto entityData = EntityDataProto.newBuilder() |
507 | .setEntityName(entityName) | 495 | .setEntityName(entityName) |
508 | .setTbMsg(ByteString.copyFrom(TbMsg.toByteArray(tbMsg))) | 496 | .setTbMsg(ByteString.copyFrom(TbMsg.toByteArray(tbMsg))) |
@@ -239,7 +239,7 @@ public class SqlDatabaseUpgradeService implements DatabaseEntitiesUpgradeService | @@ -239,7 +239,7 @@ public class SqlDatabaseUpgradeService implements DatabaseEntitiesUpgradeService | ||
239 | schemaUpdateFile = Paths.get(installScripts.getDataDir(), "upgrade", "2.6.0", SCHEMA_UPDATE_SQL); | 239 | schemaUpdateFile = Paths.get(installScripts.getDataDir(), "upgrade", "2.6.0", SCHEMA_UPDATE_SQL); |
240 | loadSql(schemaUpdateFile, conn); | 240 | loadSql(schemaUpdateFile, conn); |
241 | try { | 241 | try { |
242 | - conn.createStatement().execute("ALTER TABLE rule_chain ADD type varchar(255) DEFAULT 'SYSTEM'"); //NOSONAR, ignoring because method used to execute thingsboard database upgrade script | 242 | + conn.createStatement().execute("ALTER TABLE rule_chain ADD type varchar(255) DEFAULT 'CORE'"); //NOSONAR, ignoring because method used to execute thingsboard database upgrade script |
243 | } catch (Exception e) {} | 243 | } catch (Exception e) {} |
244 | log.info("Schema updated."); | 244 | log.info("Schema updated."); |
245 | } | 245 | } |
1 | +/** | ||
2 | + * Copyright © 2016-2020 The Thingsboard Authors | ||
3 | + * | ||
4 | + * Licensed under the Apache License, Version 2.0 (the "License"); | ||
5 | + * you may not use this file except in compliance with the License. | ||
6 | + * You may obtain a copy of the License at | ||
7 | + * | ||
8 | + * http://www.apache.org/licenses/LICENSE-2.0 | ||
9 | + * | ||
10 | + * Unless required by applicable law or agreed to in writing, software | ||
11 | + * distributed under the License is distributed on an "AS IS" BASIS, | ||
12 | + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||
13 | + * See the License for the specific language governing permissions and | ||
14 | + * limitations under the License. | ||
15 | + */ | ||
16 | +package org.thingsboard.server.dao.edge; | ||
17 | + | ||
18 | +import com.google.common.util.concurrent.ListenableFuture; | ||
19 | +import org.thingsboard.server.common.data.EntityType; | ||
20 | +import org.thingsboard.server.common.data.edge.EdgeEvent; | ||
21 | +import org.thingsboard.server.common.data.edge.EdgeEventType; | ||
22 | +import org.thingsboard.server.common.data.id.EdgeId; | ||
23 | +import org.thingsboard.server.common.data.id.TenantId; | ||
24 | +import org.thingsboard.server.common.data.page.TimePageData; | ||
25 | +import org.thingsboard.server.common.data.page.TimePageLink; | ||
26 | + | ||
27 | +public interface EdgeEventService { | ||
28 | + | ||
29 | + EdgeEventType getEdgeEventTypeByEntityType(EntityType entityType); | ||
30 | + | ||
31 | + ListenableFuture<EdgeEvent> saveAsync(EdgeEvent edgeEvent); | ||
32 | + | ||
33 | + TimePageData<EdgeEvent> findEdgeEvents(TenantId tenantId, EdgeId edgeId, TimePageLink pageLink); | ||
34 | + | ||
35 | +} |
@@ -5,7 +5,7 @@ | @@ -5,7 +5,7 @@ | ||
5 | * you may not use this file except in compliance with the License. | 5 | * you may not use this file except in compliance with the License. |
6 | * You may obtain a copy of the License at | 6 | * You may obtain a copy of the License at |
7 | * | 7 | * |
8 | - * http://www.apache.org/licenses/LICENSE-2.0 | 8 | + * http://www.apache.org/licenses/LICENSE-2.0 |
9 | * | 9 | * |
10 | * Unless required by applicable law or agreed to in writing, software | 10 | * Unless required by applicable law or agreed to in writing, software |
11 | * distributed under the License is distributed on an "AS IS" BASIS, | 11 | * distributed under the License is distributed on an "AS IS" BASIS, |
@@ -65,7 +65,4 @@ public class DataConstants { | @@ -65,7 +65,4 @@ public class DataConstants { | ||
65 | public static final String DEFAULT_SECRET_KEY = ""; | 65 | public static final String DEFAULT_SECRET_KEY = ""; |
66 | public static final String SECRET_KEY_FIELD_NAME = "secretKey"; | 66 | public static final String SECRET_KEY_FIELD_NAME = "secretKey"; |
67 | public static final String DURATION_MS_FIELD_NAME = "durationMs"; | 67 | public static final String DURATION_MS_FIELD_NAME = "durationMs"; |
68 | - | ||
69 | - public static final String EDGE_QUEUE_EVENT_TYPE = "EDGE_QUEUE"; | ||
70 | - | ||
71 | } | 68 | } |
@@ -24,6 +24,7 @@ public enum ActionType { | @@ -24,6 +24,7 @@ public enum ActionType { | ||
24 | UPDATED(false), // log entity | 24 | UPDATED(false), // log entity |
25 | ATTRIBUTES_UPDATED(false), // log attributes/values | 25 | ATTRIBUTES_UPDATED(false), // log attributes/values |
26 | ATTRIBUTES_DELETED(false), // log attributes | 26 | ATTRIBUTES_DELETED(false), // log attributes |
27 | + TIMESERIES_UPDATED(false), // log timeseries | ||
27 | TIMESERIES_DELETED(false), // log timeseries | 28 | TIMESERIES_DELETED(false), // log timeseries |
28 | RPC_CALL(false), // log method and params | 29 | RPC_CALL(false), // log method and params |
29 | CREDENTIALS_UPDATED(false), // log new credentials | 30 | CREDENTIALS_UPDATED(false), // log new credentials |
1 | +/** | ||
2 | + * Copyright © 2016-2020 The Thingsboard Authors | ||
3 | + * | ||
4 | + * Licensed under the Apache License, Version 2.0 (the "License"); | ||
5 | + * you may not use this file except in compliance with the License. | ||
6 | + * You may obtain a copy of the License at | ||
7 | + * | ||
8 | + * http://www.apache.org/licenses/LICENSE-2.0 | ||
9 | + * | ||
10 | + * Unless required by applicable law or agreed to in writing, software | ||
11 | + * distributed under the License is distributed on an "AS IS" BASIS, | ||
12 | + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||
13 | + * See the License for the specific language governing permissions and | ||
14 | + * limitations under the License. | ||
15 | + */ | ||
16 | +package org.thingsboard.server.common.data.edge; | ||
17 | + | ||
18 | +import com.fasterxml.jackson.databind.JsonNode; | ||
19 | +import lombok.Data; | ||
20 | +import org.thingsboard.server.common.data.BaseData; | ||
21 | +import org.thingsboard.server.common.data.id.EdgeEventId; | ||
22 | +import org.thingsboard.server.common.data.id.EdgeId; | ||
23 | +import org.thingsboard.server.common.data.id.EntityId; | ||
24 | +import org.thingsboard.server.common.data.id.TenantId; | ||
25 | + | ||
26 | +import java.util.UUID; | ||
27 | + | ||
28 | +@Data | ||
29 | +public class EdgeEvent extends BaseData<EdgeEventId> { | ||
30 | + | ||
31 | + private TenantId tenantId; | ||
32 | + private EdgeId edgeId; | ||
33 | + private String edgeEventAction; | ||
34 | + private UUID entityId; | ||
35 | + private EdgeEventType edgeEventType; | ||
36 | + private transient JsonNode entityBody; | ||
37 | + | ||
38 | + public EdgeEvent() { | ||
39 | + super(); | ||
40 | + } | ||
41 | + | ||
42 | + public EdgeEvent(EdgeEventId id) { | ||
43 | + super(id); | ||
44 | + } | ||
45 | + | ||
46 | + public EdgeEvent(EdgeEvent event) { | ||
47 | + super(event); | ||
48 | + } | ||
49 | + | ||
50 | +} |
common/data/src/main/java/org/thingsboard/server/common/data/edge/EdgeEventType.java
renamed from
common/data/src/main/java/org/thingsboard/server/common/data/edge/EdgeQueueEntityType.java
@@ -15,6 +15,6 @@ | @@ -15,6 +15,6 @@ | ||
15 | */ | 15 | */ |
16 | package org.thingsboard.server.common.data.edge; | 16 | package org.thingsboard.server.common.data.edge; |
17 | 17 | ||
18 | -public enum EdgeQueueEntityType { | 18 | +public enum EdgeEventType { |
19 | DASHBOARD, ASSET, DEVICE, ENTITY_VIEW, ALARM, RULE_CHAIN, RULE_CHAIN_METADATA, EDGE, USER, CUSTOMER, RELATION | 19 | DASHBOARD, ASSET, DEVICE, ENTITY_VIEW, ALARM, RULE_CHAIN, RULE_CHAIN_METADATA, EDGE, USER, CUSTOMER, RELATION |
20 | } | 20 | } |
1 | +/** | ||
2 | + * Copyright © 2016-2020 The Thingsboard Authors | ||
3 | + * | ||
4 | + * Licensed under the Apache License, Version 2.0 (the "License"); | ||
5 | + * you may not use this file except in compliance with the License. | ||
6 | + * You may obtain a copy of the License at | ||
7 | + * | ||
8 | + * http://www.apache.org/licenses/LICENSE-2.0 | ||
9 | + * | ||
10 | + * Unless required by applicable law or agreed to in writing, software | ||
11 | + * distributed under the License is distributed on an "AS IS" BASIS, | ||
12 | + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||
13 | + * See the License for the specific language governing permissions and | ||
14 | + * limitations under the License. | ||
15 | + */ | ||
16 | +package org.thingsboard.server.common.data.id; | ||
17 | + | ||
18 | +import com.fasterxml.jackson.annotation.JsonCreator; | ||
19 | +import com.fasterxml.jackson.annotation.JsonProperty; | ||
20 | + | ||
21 | +import java.util.UUID; | ||
22 | + | ||
23 | +public class EdgeEventId extends UUIDBased { | ||
24 | + | ||
25 | + private static final long serialVersionUID = 1L; | ||
26 | + | ||
27 | + @JsonCreator | ||
28 | + public EdgeEventId(@JsonProperty("id") UUID id) { | ||
29 | + super(id); | ||
30 | + } | ||
31 | + | ||
32 | + public static EdgeEventId fromString(String edgeEventId) { | ||
33 | + return new EdgeEventId(UUID.fromString(edgeEventId)); | ||
34 | + } | ||
35 | +} |
@@ -42,6 +42,10 @@ | @@ -42,6 +42,10 @@ | ||
42 | </dependency> | 42 | </dependency> |
43 | <dependency> | 43 | <dependency> |
44 | <groupId>org.thingsboard.common</groupId> | 44 | <groupId>org.thingsboard.common</groupId> |
45 | + <artifactId>queue</artifactId> | ||
46 | + </dependency> | ||
47 | + <dependency> | ||
48 | + <groupId>org.thingsboard.common</groupId> | ||
45 | <artifactId>message</artifactId> | 49 | <artifactId>message</artifactId> |
46 | </dependency> | 50 | </dependency> |
47 | <dependency> | 51 | <dependency> |
@@ -19,6 +19,8 @@ option java_package = "org.thingsboard.server.gen.edge"; | @@ -19,6 +19,8 @@ option java_package = "org.thingsboard.server.gen.edge"; | ||
19 | option java_multiple_files = true; | 19 | option java_multiple_files = true; |
20 | option java_outer_classname = "EdgeProtos"; | 20 | option java_outer_classname = "EdgeProtos"; |
21 | 21 | ||
22 | +import "queue.proto"; | ||
23 | + | ||
22 | package edge; | 24 | package edge; |
23 | 25 | ||
24 | // Interface exported by the ThingsBoard Edge Transport. | 26 | // Interface exported by the ThingsBoard Edge Transport. |
@@ -94,15 +96,16 @@ enum UpdateMsgType { | @@ -94,15 +96,16 @@ enum UpdateMsgType { | ||
94 | ENTITY_DELETED_RPC_MESSAGE = 2; | 96 | ENTITY_DELETED_RPC_MESSAGE = 2; |
95 | ALARM_ACK_RPC_MESSAGE = 3; | 97 | ALARM_ACK_RPC_MESSAGE = 3; |
96 | ALARM_CLEAR_RPC_MESSAGE = 4; | 98 | ALARM_CLEAR_RPC_MESSAGE = 4; |
97 | - RULE_CHAIN_CUSTOM_MESSAGE = 5; | ||
98 | - DEVICE_CONFLICT_RPC_MESSAGE = 6; | 99 | + DEVICE_CONFLICT_RPC_MESSAGE = 5; |
99 | } | 100 | } |
100 | 101 | ||
101 | message EntityDataProto { | 102 | message EntityDataProto { |
102 | string entityName = 1; | 103 | string entityName = 1; |
103 | int64 entityIdMSB = 2; | 104 | int64 entityIdMSB = 2; |
104 | int64 entityIdLSB = 3; | 105 | int64 entityIdLSB = 3; |
105 | - bytes tbMsg = 4; | 106 | + transport.PostTelemetryMsg postTelemetryMsg = 4; |
107 | + transport.PostAttributeMsg postAttributesMsg = 5; | ||
108 | + // transport.ToDeviceRpcRequestMsg ??? | ||
106 | } | 109 | } |
107 | 110 | ||
108 | message RuleChainUpdateMsg { | 111 | message RuleChainUpdateMsg { |
@@ -356,6 +356,14 @@ message FromDeviceRPCResponseProto { | @@ -356,6 +356,14 @@ message FromDeviceRPCResponseProto { | ||
356 | message EdgeNotificationMsgProto { | 356 | message EdgeNotificationMsgProto { |
357 | int64 tenantIdMSB = 1; | 357 | int64 tenantIdMSB = 1; |
358 | int64 tenantIdLSB = 2; | 358 | int64 tenantIdLSB = 2; |
359 | + string edgeEventType = 3; | ||
360 | + string edgeEventAction = 4; | ||
361 | + int64 entityIdMSB = 5; | ||
362 | + int64 entityIdLSB = 6; | ||
363 | + string entityType = 7; | ||
364 | + string entityBody = 8; | ||
365 | + PostTelemetryMsg postTelemetryMsg = 9; | ||
366 | + PostAttributeMsg postAttributesMsg = 10; | ||
359 | } | 367 | } |
360 | 368 | ||
361 | /** | 369 | /** |
1 | +/** | ||
2 | + * Copyright © 2016-2020 The Thingsboard Authors | ||
3 | + * | ||
4 | + * Licensed under the Apache License, Version 2.0 (the "License"); | ||
5 | + * you may not use this file except in compliance with the License. | ||
6 | + * You may obtain a copy of the License at | ||
7 | + * | ||
8 | + * http://www.apache.org/licenses/LICENSE-2.0 | ||
9 | + * | ||
10 | + * Unless required by applicable law or agreed to in writing, software | ||
11 | + * distributed under the License is distributed on an "AS IS" BASIS, | ||
12 | + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||
13 | + * See the License for the specific language governing permissions and | ||
14 | + * limitations under the License. | ||
15 | + */ | ||
16 | +package org.thingsboard.server.dao.edge; | ||
17 | + | ||
18 | +import com.google.common.util.concurrent.ListenableFuture; | ||
19 | +import lombok.extern.slf4j.Slf4j; | ||
20 | +import org.apache.commons.lang3.StringUtils; | ||
21 | +import org.springframework.beans.factory.annotation.Autowired; | ||
22 | +import org.springframework.stereotype.Service; | ||
23 | +import org.thingsboard.server.common.data.EntityType; | ||
24 | +import org.thingsboard.server.common.data.edge.EdgeEvent; | ||
25 | +import org.thingsboard.server.common.data.edge.EdgeEventType; | ||
26 | +import org.thingsboard.server.common.data.id.EdgeId; | ||
27 | +import org.thingsboard.server.common.data.id.TenantId; | ||
28 | +import org.thingsboard.server.common.data.page.TimePageData; | ||
29 | +import org.thingsboard.server.common.data.page.TimePageLink; | ||
30 | +import org.thingsboard.server.dao.exception.DataValidationException; | ||
31 | +import org.thingsboard.server.dao.service.DataValidator; | ||
32 | + | ||
33 | +import java.util.List; | ||
34 | + | ||
35 | +@Service | ||
36 | +@Slf4j | ||
37 | +public class BaseEdgeEventService implements EdgeEventService { | ||
38 | + | ||
39 | + @Autowired | ||
40 | + public EdgeEventDao edgeEventDao; | ||
41 | + | ||
42 | + @Override | ||
43 | + public EdgeEventType getEdgeEventTypeByEntityType(EntityType entityType) { | ||
44 | + switch (entityType) { | ||
45 | + case DEVICE: | ||
46 | + return EdgeEventType.DEVICE; | ||
47 | + case ASSET: | ||
48 | + return EdgeEventType.ASSET; | ||
49 | + case ENTITY_VIEW: | ||
50 | + return EdgeEventType.ENTITY_VIEW; | ||
51 | + case DASHBOARD: | ||
52 | + return EdgeEventType.DASHBOARD; | ||
53 | + case USER: | ||
54 | + return EdgeEventType.USER; | ||
55 | + default: | ||
56 | + log.warn("Failed to push notification to edge service. Unsupported entity type [{}]", entityType); | ||
57 | + return null; | ||
58 | + } | ||
59 | + } | ||
60 | + | ||
61 | + @Override | ||
62 | + public ListenableFuture<EdgeEvent> saveAsync(EdgeEvent edgeEvent) { | ||
63 | + edgeEventValidator.validate(edgeEvent, EdgeEvent::getTenantId); | ||
64 | + return edgeEventDao.saveAsync(edgeEvent); | ||
65 | + } | ||
66 | + | ||
67 | + @Override | ||
68 | + public TimePageData<EdgeEvent> findEdgeEvents(TenantId tenantId, EdgeId edgeId, TimePageLink pageLink) { | ||
69 | + List<EdgeEvent> events = edgeEventDao.findEdgeEvents(tenantId.getId(), edgeId, pageLink); | ||
70 | + return new TimePageData<>(events, pageLink); | ||
71 | + } | ||
72 | + | ||
73 | + private DataValidator<EdgeEvent> edgeEventValidator = | ||
74 | + new DataValidator<EdgeEvent>() { | ||
75 | + @Override | ||
76 | + protected void validateDataImpl(TenantId tenantId, EdgeEvent edgeEvent) { | ||
77 | + if (edgeEvent.getEdgeId() == null) { | ||
78 | + throw new DataValidationException("Edge id should be specified!"); | ||
79 | + } | ||
80 | + if (StringUtils.isEmpty(edgeEvent.getEdgeEventAction())) { | ||
81 | + throw new DataValidationException("Edge Event action should be specified!"); | ||
82 | + } | ||
83 | + } | ||
84 | + }; | ||
85 | +} |
1 | +/** | ||
2 | + * Copyright © 2016-2020 The Thingsboard Authors | ||
3 | + * | ||
4 | + * Licensed under the Apache License, Version 2.0 (the "License"); | ||
5 | + * you may not use this file except in compliance with the License. | ||
6 | + * You may obtain a copy of the License at | ||
7 | + * | ||
8 | + * http://www.apache.org/licenses/LICENSE-2.0 | ||
9 | + * | ||
10 | + * Unless required by applicable law or agreed to in writing, software | ||
11 | + * distributed under the License is distributed on an "AS IS" BASIS, | ||
12 | + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||
13 | + * See the License for the specific language governing permissions and | ||
14 | + * limitations under the License. | ||
15 | + */ | ||
16 | +package org.thingsboard.server.dao.edge; | ||
17 | + | ||
18 | +import com.google.common.util.concurrent.ListenableFuture; | ||
19 | +import org.thingsboard.server.common.data.edge.EdgeEvent; | ||
20 | +import org.thingsboard.server.common.data.id.EdgeId; | ||
21 | +import org.thingsboard.server.common.data.page.TimePageLink; | ||
22 | +import org.thingsboard.server.dao.Dao; | ||
23 | + | ||
24 | +import java.util.List; | ||
25 | +import java.util.UUID; | ||
26 | + | ||
27 | +/** | ||
28 | + * The Interface EdgeEventDao. | ||
29 | + */ | ||
30 | +public interface EdgeEventDao extends Dao<EdgeEvent> { | ||
31 | + | ||
32 | + /** | ||
33 | + * Save or update edge event object async | ||
34 | + * | ||
35 | + * @param edgeEvent the event object | ||
36 | + * @return saved edge event object future | ||
37 | + */ | ||
38 | + ListenableFuture<EdgeEvent> saveAsync(EdgeEvent edgeEvent); | ||
39 | + | ||
40 | + | ||
41 | + /** | ||
42 | + * Find edge events by tenantId, edgeId and pageLink. | ||
43 | + * | ||
44 | + * @param tenantId the tenantId | ||
45 | + * @param edgeId the edgeId | ||
46 | + * @param pageLink the pageLink | ||
47 | + * @return the event list | ||
48 | + */ | ||
49 | + List<EdgeEvent> findEdgeEvents(UUID tenantId, EdgeId edgeId, TimePageLink pageLink); | ||
50 | + | ||
51 | +} |
@@ -5,7 +5,7 @@ | @@ -5,7 +5,7 @@ | ||
5 | * you may not use this file except in compliance with the License. | 5 | * you may not use this file except in compliance with the License. |
6 | * You may obtain a copy of the License at | 6 | * You may obtain a copy of the License at |
7 | * | 7 | * |
8 | - * http://www.apache.org/licenses/LICENSE-2.0 | 8 | + * http://www.apache.org/licenses/LICENSE-2.0 |
9 | * | 9 | * |
10 | * Unless required by applicable law or agreed to in writing, software | 10 | * Unless required by applicable law or agreed to in writing, software |
11 | * distributed under the License is distributed on an "AS IS" BASIS, | 11 | * distributed under the License is distributed on an "AS IS" BASIS, |
@@ -372,6 +372,16 @@ public class ModelConstants { | @@ -372,6 +372,16 @@ public class ModelConstants { | ||
372 | public static final String EDGE_ROUTING_KEY_PROPERTY = "routing_key"; | 372 | public static final String EDGE_ROUTING_KEY_PROPERTY = "routing_key"; |
373 | public static final String EDGE_SECRET_PROPERTY = "secret"; | 373 | public static final String EDGE_SECRET_PROPERTY = "secret"; |
374 | 374 | ||
375 | + /** | ||
376 | + * Cassandra edge queue constants. | ||
377 | + */ | ||
378 | + public static final String EDGE_EVENT_COLUMN_FAMILY_NAME = "edge_event"; | ||
379 | + public static final String EDGE_EVENT_TENANT_ID_PROPERTY = TENANT_ID_PROPERTY; | ||
380 | + public static final String EDGE_EVENT_EDGE_ID_PROPERTY = "edge_id"; | ||
381 | + public static final String EDGE_EVENT_TYPE_PROPERTY = "edge_event_type"; | ||
382 | + public static final String EDGE_EVENT_ACTION_PROPERTY = "edge_event_action"; | ||
383 | + public static final String EDGE_EVENT_ENTITY_ID_PROPERTY = "entity_id"; | ||
384 | + public static final String EDGE_EVENT_ENTITY_BODY_PROPERTY = "entity_body"; | ||
375 | 385 | ||
376 | /** | 386 | /** |
377 | * Cassandra attributes and timeseries constants. | 387 | * Cassandra attributes and timeseries constants. |
1 | +/** | ||
2 | + * Copyright © 2016-2020 The Thingsboard Authors | ||
3 | + * | ||
4 | + * Licensed under the Apache License, Version 2.0 (the "License"); | ||
5 | + * you may not use this file except in compliance with the License. | ||
6 | + * You may obtain a copy of the License at | ||
7 | + * | ||
8 | + * http://www.apache.org/licenses/LICENSE-2.0 | ||
9 | + * | ||
10 | + * Unless required by applicable law or agreed to in writing, software | ||
11 | + * distributed under the License is distributed on an "AS IS" BASIS, | ||
12 | + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||
13 | + * See the License for the specific language governing permissions and | ||
14 | + * limitations under the License. | ||
15 | + */ | ||
16 | +package org.thingsboard.server.dao.model.nosql; | ||
17 | + | ||
18 | +import com.datastax.driver.core.utils.UUIDs; | ||
19 | +import com.datastax.driver.mapping.annotations.ClusteringColumn; | ||
20 | +import com.datastax.driver.mapping.annotations.Column; | ||
21 | +import com.datastax.driver.mapping.annotations.PartitionKey; | ||
22 | +import com.datastax.driver.mapping.annotations.Table; | ||
23 | +import com.fasterxml.jackson.databind.JsonNode; | ||
24 | +import lombok.Data; | ||
25 | +import lombok.NoArgsConstructor; | ||
26 | +import org.thingsboard.server.common.data.EntityType; | ||
27 | +import org.thingsboard.server.common.data.Event; | ||
28 | +import org.thingsboard.server.common.data.edge.EdgeEvent; | ||
29 | +import org.thingsboard.server.common.data.edge.EdgeEventType; | ||
30 | +import org.thingsboard.server.common.data.id.EdgeEventId; | ||
31 | +import org.thingsboard.server.common.data.id.EdgeId; | ||
32 | +import org.thingsboard.server.common.data.id.EntityIdFactory; | ||
33 | +import org.thingsboard.server.common.data.id.EventId; | ||
34 | +import org.thingsboard.server.common.data.id.TenantId; | ||
35 | +import org.thingsboard.server.dao.model.BaseEntity; | ||
36 | +import org.thingsboard.server.dao.model.type.EdgeEventTypeCodec; | ||
37 | +import org.thingsboard.server.dao.model.type.EntityTypeCodec; | ||
38 | +import org.thingsboard.server.dao.model.type.JsonCodec; | ||
39 | + | ||
40 | +import java.util.UUID; | ||
41 | + | ||
42 | +import static org.thingsboard.server.dao.model.ModelConstants.EDGE_EVENT_ACTION_PROPERTY; | ||
43 | +import static org.thingsboard.server.dao.model.ModelConstants.EDGE_EVENT_COLUMN_FAMILY_NAME; | ||
44 | +import static org.thingsboard.server.dao.model.ModelConstants.EDGE_EVENT_EDGE_ID_PROPERTY; | ||
45 | +import static org.thingsboard.server.dao.model.ModelConstants.EDGE_EVENT_ENTITY_BODY_PROPERTY; | ||
46 | +import static org.thingsboard.server.dao.model.ModelConstants.EDGE_EVENT_ENTITY_ID_PROPERTY; | ||
47 | +import static org.thingsboard.server.dao.model.ModelConstants.EDGE_EVENT_TENANT_ID_PROPERTY; | ||
48 | +import static org.thingsboard.server.dao.model.ModelConstants.EDGE_EVENT_TYPE_PROPERTY; | ||
49 | +import static org.thingsboard.server.dao.model.ModelConstants.EVENT_BODY_PROPERTY; | ||
50 | +import static org.thingsboard.server.dao.model.ModelConstants.EVENT_COLUMN_FAMILY_NAME; | ||
51 | +import static org.thingsboard.server.dao.model.ModelConstants.EVENT_ENTITY_ID_PROPERTY; | ||
52 | +import static org.thingsboard.server.dao.model.ModelConstants.EVENT_ENTITY_TYPE_PROPERTY; | ||
53 | +import static org.thingsboard.server.dao.model.ModelConstants.EVENT_TENANT_ID_PROPERTY; | ||
54 | +import static org.thingsboard.server.dao.model.ModelConstants.EVENT_TYPE_PROPERTY; | ||
55 | +import static org.thingsboard.server.dao.model.ModelConstants.EVENT_UID_PROPERTY; | ||
56 | +import static org.thingsboard.server.dao.model.ModelConstants.ID_PROPERTY; | ||
57 | + | ||
58 | +@Data | ||
59 | +@NoArgsConstructor | ||
60 | +@Table(name = EDGE_EVENT_COLUMN_FAMILY_NAME) | ||
61 | +public class EdgeEventEntity implements BaseEntity<EdgeEvent> { | ||
62 | + | ||
63 | + @Column(name = ID_PROPERTY) | ||
64 | + private UUID id; | ||
65 | + | ||
66 | + @PartitionKey() | ||
67 | + @Column(name = EDGE_EVENT_TENANT_ID_PROPERTY) | ||
68 | + private UUID tenantId; | ||
69 | + | ||
70 | + @PartitionKey(value = 1) | ||
71 | + @Column(name = EDGE_EVENT_EDGE_ID_PROPERTY) | ||
72 | + private UUID edgeId; | ||
73 | + | ||
74 | + @PartitionKey(value = 2) | ||
75 | + @Column(name = EDGE_EVENT_TYPE_PROPERTY, codec = EdgeEventTypeCodec.class) | ||
76 | + private EdgeEventType edgeEventType; | ||
77 | + | ||
78 | + @PartitionKey(value = 3) | ||
79 | + @Column(name = EDGE_EVENT_ENTITY_ID_PROPERTY) | ||
80 | + private UUID entityId; | ||
81 | + | ||
82 | + @ClusteringColumn() | ||
83 | + @Column(name = EDGE_EVENT_ACTION_PROPERTY) | ||
84 | + private String edgeEventAction; | ||
85 | + | ||
86 | + // TODO | ||
87 | + @ClusteringColumn(value = 1) | ||
88 | + @Column(name = EVENT_UID_PROPERTY) | ||
89 | + private String eventUid; | ||
90 | + | ||
91 | + @Column(name = EDGE_EVENT_ENTITY_BODY_PROPERTY, codec = JsonCodec.class) | ||
92 | + private JsonNode entityBody; | ||
93 | + | ||
94 | + public EdgeEventEntity(EdgeEvent edgeEvent) { | ||
95 | + if (edgeEvent.getId() != null) { | ||
96 | + this.id = edgeEvent.getId().getId(); | ||
97 | + } | ||
98 | + if (edgeEvent.getTenantId() != null) { | ||
99 | + this.tenantId = edgeEvent.getTenantId().getId(); | ||
100 | + } | ||
101 | + if (edgeEvent.getEdgeId() != null) { | ||
102 | + this.edgeId = edgeEvent.getEdgeId().getId(); | ||
103 | + } | ||
104 | +// if (event.getEntityId() != null) { | ||
105 | +// this.entityType = event.getEntityId().getEntityType(); | ||
106 | +// this.entityId = event.getEntityId().getId(); | ||
107 | +// } | ||
108 | +// this.edgeEventType = edgeEvent.getEdgeEventType(); | ||
109 | +// this.edgeEventAction = edgeEvent.getEdgeEventAction(); | ||
110 | +// this.entityBody = edgeEvent.getEntityBody(); | ||
111 | + } | ||
112 | + | ||
113 | + @Override | ||
114 | + public UUID getUuid() { | ||
115 | + return id; | ||
116 | + } | ||
117 | + | ||
118 | + @Override | ||
119 | + public void setUuid(UUID id) { | ||
120 | + this.id = id; | ||
121 | + } | ||
122 | + | ||
123 | + @Override | ||
124 | + public EdgeEvent toData() { | ||
125 | + EdgeEvent edgeEvent = new EdgeEvent(new EdgeEventId(id)); | ||
126 | +// edgeEvent.setCreatedTime(UUIDs.unixTimestamp(id)); | ||
127 | +// edgeEvent.setTenantId(new TenantId(tenantId)); | ||
128 | +// edgeEvent.setEdgeId(new EdgeId(edgeId)); | ||
129 | +// edgeEvent.setEntityId(entityId); | ||
130 | +// event.setBody(body); | ||
131 | +// event.setType(eventType); | ||
132 | +// event.setUid(eventUid); | ||
133 | + return edgeEvent; | ||
134 | + } | ||
135 | +} |
1 | +/** | ||
2 | + * Copyright © 2016-2020 The Thingsboard Authors | ||
3 | + * | ||
4 | + * Licensed under the Apache License, Version 2.0 (the "License"); | ||
5 | + * you may not use this file except in compliance with the License. | ||
6 | + * You may obtain a copy of the License at | ||
7 | + * | ||
8 | + * http://www.apache.org/licenses/LICENSE-2.0 | ||
9 | + * | ||
10 | + * Unless required by applicable law or agreed to in writing, software | ||
11 | + * distributed under the License is distributed on an "AS IS" BASIS, | ||
12 | + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||
13 | + * See the License for the specific language governing permissions and | ||
14 | + * limitations under the License. | ||
15 | + */ | ||
16 | +package org.thingsboard.server.dao.model.sql; | ||
17 | + | ||
18 | +import com.datastax.driver.core.utils.UUIDs; | ||
19 | +import com.fasterxml.jackson.databind.JsonNode; | ||
20 | +import lombok.Data; | ||
21 | +import lombok.EqualsAndHashCode; | ||
22 | +import lombok.NoArgsConstructor; | ||
23 | +import org.hibernate.annotations.Type; | ||
24 | +import org.hibernate.annotations.TypeDef; | ||
25 | +import org.thingsboard.server.common.data.edge.EdgeEvent; | ||
26 | +import org.thingsboard.server.common.data.edge.EdgeEventType; | ||
27 | +import org.thingsboard.server.common.data.id.EdgeEventId; | ||
28 | +import org.thingsboard.server.common.data.id.EdgeId; | ||
29 | +import org.thingsboard.server.common.data.id.TenantId; | ||
30 | +import org.thingsboard.server.dao.model.BaseEntity; | ||
31 | +import org.thingsboard.server.dao.model.BaseSqlEntity; | ||
32 | +import org.thingsboard.server.dao.util.mapping.JsonStringType; | ||
33 | + | ||
34 | +import javax.persistence.Column; | ||
35 | +import javax.persistence.Entity; | ||
36 | +import javax.persistence.EnumType; | ||
37 | +import javax.persistence.Enumerated; | ||
38 | +import javax.persistence.Table; | ||
39 | +import java.util.UUID; | ||
40 | + | ||
41 | +import static org.thingsboard.server.dao.model.ModelConstants.EDGE_EVENT_ACTION_PROPERTY; | ||
42 | +import static org.thingsboard.server.dao.model.ModelConstants.EDGE_EVENT_COLUMN_FAMILY_NAME; | ||
43 | +import static org.thingsboard.server.dao.model.ModelConstants.EDGE_EVENT_EDGE_ID_PROPERTY; | ||
44 | +import static org.thingsboard.server.dao.model.ModelConstants.EDGE_EVENT_ENTITY_BODY_PROPERTY; | ||
45 | +import static org.thingsboard.server.dao.model.ModelConstants.EDGE_EVENT_ENTITY_ID_PROPERTY; | ||
46 | +import static org.thingsboard.server.dao.model.ModelConstants.EDGE_EVENT_TENANT_ID_PROPERTY; | ||
47 | +import static org.thingsboard.server.dao.model.ModelConstants.EDGE_EVENT_TYPE_PROPERTY; | ||
48 | +import static org.thingsboard.server.dao.model.ModelConstants.EPOCH_DIFF; | ||
49 | +import static org.thingsboard.server.dao.model.ModelConstants.TS_COLUMN; | ||
50 | + | ||
51 | +@Data | ||
52 | +@EqualsAndHashCode(callSuper = true) | ||
53 | +@Entity | ||
54 | +@TypeDef(name = "json", typeClass = JsonStringType.class) | ||
55 | +@Table(name = EDGE_EVENT_COLUMN_FAMILY_NAME) | ||
56 | +@NoArgsConstructor | ||
57 | +public class EdgeEventEntity extends BaseSqlEntity<EdgeEvent> implements BaseEntity<EdgeEvent> { | ||
58 | + | ||
59 | + @Column(name = EDGE_EVENT_TENANT_ID_PROPERTY) | ||
60 | + private String tenantId; | ||
61 | + | ||
62 | + @Column(name = EDGE_EVENT_EDGE_ID_PROPERTY) | ||
63 | + private String edgeId; | ||
64 | + | ||
65 | + @Column(name = EDGE_EVENT_ENTITY_ID_PROPERTY) | ||
66 | + private String entityId; | ||
67 | + | ||
68 | + @Enumerated(EnumType.STRING) | ||
69 | + @Column(name = EDGE_EVENT_TYPE_PROPERTY) | ||
70 | + private EdgeEventType edgeEventType; | ||
71 | + | ||
72 | + @Column(name = EDGE_EVENT_ACTION_PROPERTY) | ||
73 | + private String edgeEventAction; | ||
74 | + | ||
75 | + @Type(type = "json") | ||
76 | + @Column(name = EDGE_EVENT_ENTITY_BODY_PROPERTY) | ||
77 | + private JsonNode entityBody; | ||
78 | + | ||
79 | + @Column(name = TS_COLUMN) | ||
80 | + private long ts; | ||
81 | + | ||
82 | + public EdgeEventEntity(EdgeEvent edgeEvent) { | ||
83 | + if (edgeEvent.getId() != null) { | ||
84 | + this.setUuid(edgeEvent.getId().getId()); | ||
85 | + this.ts = getTs(edgeEvent.getId().getId()); | ||
86 | + } else { | ||
87 | + this.ts = System.currentTimeMillis(); | ||
88 | + } | ||
89 | + if (edgeEvent.getTenantId() != null) { | ||
90 | + this.tenantId = toString(edgeEvent.getTenantId().getId()); | ||
91 | + } | ||
92 | + if (edgeEvent.getEdgeId() != null) { | ||
93 | + this.edgeId = toString(edgeEvent.getEdgeId().getId()); | ||
94 | + } | ||
95 | + if (edgeEvent.getEntityId() != null) { | ||
96 | + this.entityId = toString(edgeEvent.getEntityId()); | ||
97 | + } | ||
98 | + this.edgeEventType = edgeEvent.getEdgeEventType(); | ||
99 | + this.edgeEventAction = edgeEvent.getEdgeEventAction(); | ||
100 | + this.entityBody = edgeEvent.getEntityBody(); | ||
101 | + } | ||
102 | + | ||
103 | + @Override | ||
104 | + public EdgeEvent toData() { | ||
105 | + EdgeEvent edgeEvent = new EdgeEvent(new EdgeEventId(this.getUuid())); | ||
106 | + edgeEvent.setCreatedTime(UUIDs.unixTimestamp(this.getUuid())); | ||
107 | + edgeEvent.setTenantId(new TenantId(toUUID(tenantId))); | ||
108 | + edgeEvent.setEdgeId(new EdgeId(toUUID(edgeId))); | ||
109 | + if (entityId != null) { | ||
110 | + edgeEvent.setEntityId(toUUID(entityId)); | ||
111 | + } | ||
112 | + edgeEvent.setEdgeEventType(edgeEventType); | ||
113 | + edgeEvent.setEdgeEventAction(edgeEventAction); | ||
114 | + edgeEvent.setEntityBody(entityBody); | ||
115 | + return edgeEvent; | ||
116 | + } | ||
117 | + | ||
118 | + private static long getTs(UUID uuid) { | ||
119 | + return (uuid.timestamp() - EPOCH_DIFF) / 10000; | ||
120 | + } | ||
121 | +} |
dao/src/main/java/org/thingsboard/server/dao/model/type/EdgeEventTypeCodec.java
renamed from
rule-engine/rule-engine-components/src/main/java/org/thingsboard/rule/engine/edge/PushToEdgeNodeCallback.java
@@ -13,29 +13,15 @@ | @@ -13,29 +13,15 @@ | ||
13 | * See the License for the specific language governing permissions and | 13 | * See the License for the specific language governing permissions and |
14 | * limitations under the License. | 14 | * limitations under the License. |
15 | */ | 15 | */ |
16 | -package org.thingsboard.rule.engine.edge; | 16 | +package org.thingsboard.server.dao.model.type; |
17 | 17 | ||
18 | -import com.google.common.util.concurrent.FutureCallback; | ||
19 | -import lombok.Data; | ||
20 | -import org.thingsboard.rule.engine.api.TbContext; | ||
21 | -import org.thingsboard.server.common.msg.TbMsg; | 18 | +import com.datastax.driver.extras.codecs.enums.EnumNameCodec; |
19 | +import org.thingsboard.server.common.data.edge.EdgeEventType; | ||
22 | 20 | ||
23 | -import javax.annotation.Nullable; | 21 | +public class EdgeEventTypeCodec extends EnumNameCodec<EdgeEventType> { |
24 | 22 | ||
25 | -import static org.thingsboard.rule.engine.api.TbRelationTypes.SUCCESS; | ||
26 | - | ||
27 | -@Data | ||
28 | -class PushToEdgeNodeCallback implements FutureCallback<Void> { | ||
29 | - private final TbContext ctx; | ||
30 | - private final TbMsg msg; | ||
31 | - | ||
32 | - @Override | ||
33 | - public void onSuccess(@Nullable Void result) { | ||
34 | - ctx.tellNext(msg, SUCCESS); | 23 | + public EdgeEventTypeCodec() { |
24 | + super(EdgeEventType.class); | ||
35 | } | 25 | } |
36 | 26 | ||
37 | - @Override | ||
38 | - public void onFailure(Throwable t) { | ||
39 | - ctx.tellFailure(msg, t); | ||
40 | - } | ||
41 | } | 27 | } |
@@ -289,7 +289,7 @@ public class BaseRuleChainService extends AbstractEntityService implements RuleC | @@ -289,7 +289,7 @@ public class BaseRuleChainService extends AbstractEntityService implements RuleC | ||
289 | 289 | ||
290 | @Override | 290 | @Override |
291 | public RuleChain getRootTenantRuleChain(TenantId tenantId) { | 291 | public RuleChain getRootTenantRuleChain(TenantId tenantId) { |
292 | - return getRootRuleChainByType(tenantId, RuleChainType.SYSTEM); | 292 | + return getRootRuleChainByType(tenantId, RuleChainType.CORE); |
293 | } | 293 | } |
294 | 294 | ||
295 | private RuleChain getRootRuleChainByType(TenantId tenantId, RuleChainType type) { | 295 | private RuleChain getRootRuleChainByType(TenantId tenantId, RuleChainType type) { |
@@ -566,7 +566,7 @@ public class BaseRuleChainService extends AbstractEntityService implements RuleC | @@ -566,7 +566,7 @@ public class BaseRuleChainService extends AbstractEntityService implements RuleC | ||
566 | throw new DataValidationException("Rule chain name should be specified!"); | 566 | throw new DataValidationException("Rule chain name should be specified!"); |
567 | } | 567 | } |
568 | if (ruleChain.getType() == null) { | 568 | if (ruleChain.getType() == null) { |
569 | - ruleChain.setType(RuleChainType.SYSTEM); | 569 | + ruleChain.setType(RuleChainType.CORE); |
570 | } | 570 | } |
571 | if (ruleChain.getTenantId() == null || ruleChain.getTenantId().isNullUid()) { | 571 | if (ruleChain.getTenantId() == null || ruleChain.getTenantId().isNullUid()) { |
572 | throw new DataValidationException("Rule chain should be assigned to tenant!"); | 572 | throw new DataValidationException("Rule chain should be assigned to tenant!"); |
@@ -575,7 +575,7 @@ public class BaseRuleChainService extends AbstractEntityService implements RuleC | @@ -575,7 +575,7 @@ public class BaseRuleChainService extends AbstractEntityService implements RuleC | ||
575 | if (tenant == null) { | 575 | if (tenant == null) { |
576 | throw new DataValidationException("Rule chain is referencing to non-existent tenant!"); | 576 | throw new DataValidationException("Rule chain is referencing to non-existent tenant!"); |
577 | } | 577 | } |
578 | - if (ruleChain.isRoot() && RuleChainType.SYSTEM.equals(ruleChain.getType())) { | 578 | + if (ruleChain.isRoot() && RuleChainType.CORE.equals(ruleChain.getType())) { |
579 | RuleChain rootRuleChain = getRootTenantRuleChain(ruleChain.getTenantId()); | 579 | RuleChain rootRuleChain = getRootTenantRuleChain(ruleChain.getTenantId()); |
580 | if (rootRuleChain != null && !rootRuleChain.getId().equals(ruleChain.getId())) { | 580 | if (rootRuleChain != null && !rootRuleChain.getId().equals(ruleChain.getId())) { |
581 | throw new DataValidationException("Another root rule chain is present in scope of current tenant!"); | 581 | throw new DataValidationException("Another root rule chain is present in scope of current tenant!"); |
1 | +/** | ||
2 | + * Copyright © 2016-2020 The Thingsboard Authors | ||
3 | + * | ||
4 | + * Licensed under the Apache License, Version 2.0 (the "License"); | ||
5 | + * you may not use this file except in compliance with the License. | ||
6 | + * You may obtain a copy of the License at | ||
7 | + * | ||
8 | + * http://www.apache.org/licenses/LICENSE-2.0 | ||
9 | + * | ||
10 | + * Unless required by applicable law or agreed to in writing, software | ||
11 | + * distributed under the License is distributed on an "AS IS" BASIS, | ||
12 | + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||
13 | + * See the License for the specific language governing permissions and | ||
14 | + * limitations under the License. | ||
15 | + */ | ||
16 | +package org.thingsboard.server.dao.sql.edge; | ||
17 | + | ||
18 | +import org.springframework.data.jpa.repository.JpaSpecificationExecutor; | ||
19 | +import org.springframework.data.repository.CrudRepository; | ||
20 | +import org.thingsboard.server.dao.model.sql.EdgeEventEntity; | ||
21 | +import org.thingsboard.server.dao.util.SqlDao; | ||
22 | + | ||
23 | +@SqlDao | ||
24 | +public interface EdgeEventRepository extends CrudRepository<EdgeEventEntity, String>, JpaSpecificationExecutor<EdgeEventEntity> { | ||
25 | + | ||
26 | +} |
1 | +/** | ||
2 | + * Copyright © 2016-2020 The Thingsboard Authors | ||
3 | + * | ||
4 | + * Licensed under the Apache License, Version 2.0 (the "License"); | ||
5 | + * you may not use this file except in compliance with the License. | ||
6 | + * You may obtain a copy of the License at | ||
7 | + * | ||
8 | + * http://www.apache.org/licenses/LICENSE-2.0 | ||
9 | + * | ||
10 | + * Unless required by applicable law or agreed to in writing, software | ||
11 | + * distributed under the License is distributed on an "AS IS" BASIS, | ||
12 | + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||
13 | + * See the License for the specific language governing permissions and | ||
14 | + * limitations under the License. | ||
15 | + */ | ||
16 | +package org.thingsboard.server.dao.sql.edge; | ||
17 | + | ||
18 | +import com.datastax.driver.core.utils.UUIDs; | ||
19 | +import com.google.common.util.concurrent.ListenableFuture; | ||
20 | +import lombok.extern.slf4j.Slf4j; | ||
21 | +import org.springframework.beans.factory.annotation.Autowired; | ||
22 | +import org.springframework.data.domain.PageRequest; | ||
23 | +import org.springframework.data.domain.Pageable; | ||
24 | +import org.springframework.data.domain.Sort; | ||
25 | +import org.springframework.data.jpa.domain.Specification; | ||
26 | +import org.springframework.data.repository.CrudRepository; | ||
27 | +import org.springframework.stereotype.Component; | ||
28 | +import org.thingsboard.server.common.data.UUIDConverter; | ||
29 | +import org.thingsboard.server.common.data.edge.EdgeEvent; | ||
30 | +import org.thingsboard.server.common.data.id.EdgeEventId; | ||
31 | +import org.thingsboard.server.common.data.id.EdgeId; | ||
32 | +import org.thingsboard.server.common.data.page.TimePageLink; | ||
33 | +import org.thingsboard.server.dao.DaoUtil; | ||
34 | +import org.thingsboard.server.dao.edge.EdgeEventDao; | ||
35 | +import org.thingsboard.server.dao.model.sql.EdgeEventEntity; | ||
36 | +import org.thingsboard.server.dao.sql.JpaAbstractSearchTimeDao; | ||
37 | +import org.thingsboard.server.dao.util.SqlDao; | ||
38 | + | ||
39 | +import javax.persistence.criteria.Predicate; | ||
40 | +import java.util.ArrayList; | ||
41 | +import java.util.List; | ||
42 | +import java.util.Optional; | ||
43 | +import java.util.UUID; | ||
44 | + | ||
45 | +import static org.thingsboard.server.dao.model.ModelConstants.ID_PROPERTY; | ||
46 | +import static org.thingsboard.server.dao.model.ModelConstants.NULL_UUID; | ||
47 | + | ||
48 | +@Slf4j | ||
49 | +@Component | ||
50 | +@SqlDao | ||
51 | +public class JpaBaseEdgeEventDao extends JpaAbstractSearchTimeDao<EdgeEventEntity, EdgeEvent> implements EdgeEventDao { | ||
52 | + | ||
53 | + private final UUID systemTenantId = NULL_UUID; | ||
54 | + | ||
55 | + @Autowired | ||
56 | + private EdgeEventRepository edgeEventRepository; | ||
57 | + | ||
58 | + @Override | ||
59 | + protected Class<EdgeEventEntity> getEntityClass() { | ||
60 | + return EdgeEventEntity.class; | ||
61 | + } | ||
62 | + | ||
63 | + @Override | ||
64 | + protected CrudRepository<EdgeEventEntity, String> getCrudRepository() { | ||
65 | + return edgeEventRepository; | ||
66 | + } | ||
67 | + | ||
68 | + @Override | ||
69 | + public ListenableFuture<EdgeEvent> saveAsync(EdgeEvent edgeEvent) { | ||
70 | + log.debug("Save edge event [{}] ", edgeEvent); | ||
71 | + if (edgeEvent.getId() == null) { | ||
72 | + edgeEvent.setId(new EdgeEventId(UUIDs.timeBased())); | ||
73 | + } | ||
74 | + return service.submit(() -> save(new EdgeEventEntity(edgeEvent)).orElse(null)); | ||
75 | + } | ||
76 | + | ||
77 | + @Override | ||
78 | + public List<EdgeEvent> findEdgeEvents(UUID tenantId, EdgeId edgeId, TimePageLink pageLink) { | ||
79 | + Specification<EdgeEventEntity> timeSearchSpec = JpaAbstractSearchTimeDao.getTimeSearchPageSpec(pageLink, "id"); | ||
80 | + Specification<EdgeEventEntity> fieldsSpec = getEntityFieldsSpec(tenantId, edgeId); | ||
81 | + Sort.Direction sortDirection = pageLink.isAscOrder() ? Sort.Direction.ASC : Sort.Direction.DESC; | ||
82 | + Pageable pageable = PageRequest.of(0, pageLink.getLimit(), sortDirection, ID_PROPERTY); | ||
83 | + return DaoUtil.convertDataList(edgeEventRepository.findAll(Specification.where(timeSearchSpec).and(fieldsSpec), pageable).getContent()); | ||
84 | + } | ||
85 | + | ||
86 | + public Optional<EdgeEvent> save(EdgeEventEntity entity) { | ||
87 | + log.debug("Save edge event [{}] ", entity); | ||
88 | + if (entity.getTenantId() == null) { | ||
89 | + log.trace("Save system edge event with predefined id {}", systemTenantId); | ||
90 | + entity.setTenantId(UUIDConverter.fromTimeUUID(systemTenantId)); | ||
91 | + } | ||
92 | + if (entity.getUuid() == null) { | ||
93 | + entity.setUuid(UUIDs.timeBased()); | ||
94 | + } | ||
95 | + return Optional.of(DaoUtil.getData(edgeEventRepository.save(entity))); | ||
96 | + } | ||
97 | + | ||
98 | + private Specification<EdgeEventEntity> getEntityFieldsSpec(UUID tenantId, EdgeId edgeId) { | ||
99 | + return (root, criteriaQuery, criteriaBuilder) -> { | ||
100 | + List<Predicate> predicates = new ArrayList<>(); | ||
101 | + if (tenantId != null) { | ||
102 | + Predicate tenantIdPredicate = criteriaBuilder.equal(root.get("tenantId"), UUIDConverter.fromTimeUUID(tenantId)); | ||
103 | + predicates.add(tenantIdPredicate); | ||
104 | + } | ||
105 | + if (edgeId != null) { | ||
106 | + Predicate entityIdPredicate = criteriaBuilder.equal(root.get("edgeId"), UUIDConverter.fromTimeUUID(edgeId.getId())); | ||
107 | + predicates.add(entityIdPredicate); | ||
108 | + } | ||
109 | + return criteriaBuilder.and(predicates.toArray(new Predicate[]{})); | ||
110 | + }; | ||
111 | + } | ||
112 | +} |
@@ -270,3 +270,14 @@ CREATE TABLE IF NOT EXISTS edge ( | @@ -270,3 +270,14 @@ CREATE TABLE IF NOT EXISTS edge ( | ||
270 | CONSTRAINT edge_name_unq_key UNIQUE (tenant_id, name), | 270 | CONSTRAINT edge_name_unq_key UNIQUE (tenant_id, name), |
271 | CONSTRAINT edge_routing_key_unq_key UNIQUE (routing_key) | 271 | CONSTRAINT edge_routing_key_unq_key UNIQUE (routing_key) |
272 | ); | 272 | ); |
273 | + | ||
274 | +CREATE TABLE IF NOT EXISTS edge_event ( | ||
275 | + id varchar(31) NOT NULL CONSTRAINT edge_event_pkey PRIMARY KEY, | ||
276 | + edge_id varchar(31), | ||
277 | + edge_event_type varchar(255), | ||
278 | + entity_id varchar(31), | ||
279 | + edge_event_action varchar(255), | ||
280 | + entity_body varchar(10000000), | ||
281 | + tenant_id varchar(31), | ||
282 | + ts bigint NOT NULL | ||
283 | +); |
@@ -271,6 +271,18 @@ CREATE TABLE IF NOT EXISTS edge ( | @@ -271,6 +271,18 @@ CREATE TABLE IF NOT EXISTS edge ( | ||
271 | CONSTRAINT edge_routing_key_unq_key UNIQUE (routing_key) | 271 | CONSTRAINT edge_routing_key_unq_key UNIQUE (routing_key) |
272 | ); | 272 | ); |
273 | 273 | ||
274 | +CREATE TABLE IF NOT EXISTS edge_event ( | ||
275 | + id varchar(31) NOT NULL CONSTRAINT edge_event_pkey PRIMARY KEY, | ||
276 | + edge_id varchar(31), | ||
277 | + edge_event_type varchar(255), | ||
278 | + entity_id varchar(31), | ||
279 | + edge_event_action varchar(255), | ||
280 | + entity_body varchar(10000000), | ||
281 | + tenant_id varchar(31), | ||
282 | + ts bigint NOT NULL | ||
283 | +); | ||
284 | + | ||
285 | + | ||
274 | CREATE OR REPLACE PROCEDURE cleanup_events_by_ttl(IN ttl bigint, IN debug_ttl bigint, INOUT deleted bigint) | 286 | CREATE OR REPLACE PROCEDURE cleanup_events_by_ttl(IN ttl bigint, IN debug_ttl bigint, INOUT deleted bigint) |
275 | LANGUAGE plpgsql AS | 287 | LANGUAGE plpgsql AS |
276 | $$ | 288 | $$ |
@@ -45,6 +45,7 @@ import org.thingsboard.server.dao.customer.CustomerService; | @@ -45,6 +45,7 @@ import org.thingsboard.server.dao.customer.CustomerService; | ||
45 | import org.thingsboard.server.dao.dashboard.DashboardService; | 45 | import org.thingsboard.server.dao.dashboard.DashboardService; |
46 | import org.thingsboard.server.dao.device.DeviceCredentialsService; | 46 | import org.thingsboard.server.dao.device.DeviceCredentialsService; |
47 | import org.thingsboard.server.dao.device.DeviceService; | 47 | import org.thingsboard.server.dao.device.DeviceService; |
48 | +import org.thingsboard.server.dao.edge.EdgeEventService; | ||
48 | import org.thingsboard.server.dao.edge.EdgeService; | 49 | import org.thingsboard.server.dao.edge.EdgeService; |
49 | import org.thingsboard.server.dao.entityview.EntityViewService; | 50 | import org.thingsboard.server.dao.entityview.EntityViewService; |
50 | import org.thingsboard.server.dao.event.EventService; | 51 | import org.thingsboard.server.dao.event.EventService; |
@@ -126,6 +127,9 @@ public abstract class AbstractServiceTest { | @@ -126,6 +127,9 @@ public abstract class AbstractServiceTest { | ||
126 | protected EdgeService edgeService; | 127 | protected EdgeService edgeService; |
127 | 128 | ||
128 | @Autowired | 129 | @Autowired |
130 | + protected EdgeEventService edgeEventService; | ||
131 | + | ||
132 | + @Autowired | ||
129 | private ComponentDescriptorService componentDescriptorService; | 133 | private ComponentDescriptorService componentDescriptorService; |
130 | 134 | ||
131 | class IdComparator<D extends BaseData<? extends UUIDBased>> implements Comparator<D> { | 135 | class IdComparator<D extends BaseData<? extends UUIDBased>> implements Comparator<D> { |
1 | +/** | ||
2 | + * Copyright © 2016-2020 The Thingsboard Authors | ||
3 | + * | ||
4 | + * Licensed under the Apache License, Version 2.0 (the "License"); | ||
5 | + * you may not use this file except in compliance with the License. | ||
6 | + * You may obtain a copy of the License at | ||
7 | + * | ||
8 | + * http://www.apache.org/licenses/LICENSE-2.0 | ||
9 | + * | ||
10 | + * Unless required by applicable law or agreed to in writing, software | ||
11 | + * distributed under the License is distributed on an "AS IS" BASIS, | ||
12 | + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||
13 | + * See the License for the specific language governing permissions and | ||
14 | + * limitations under the License. | ||
15 | + */ | ||
16 | +package org.thingsboard.server.dao.service; | ||
17 | + | ||
18 | +import com.datastax.driver.core.utils.UUIDs; | ||
19 | +import org.junit.Assert; | ||
20 | +import org.junit.Test; | ||
21 | +import org.thingsboard.server.common.data.DataConstants; | ||
22 | +import org.thingsboard.server.common.data.edge.EdgeEvent; | ||
23 | +import org.thingsboard.server.common.data.edge.EdgeEventType; | ||
24 | +import org.thingsboard.server.common.data.id.DeviceId; | ||
25 | +import org.thingsboard.server.common.data.id.EdgeEventId; | ||
26 | +import org.thingsboard.server.common.data.id.EdgeId; | ||
27 | +import org.thingsboard.server.common.data.id.EntityId; | ||
28 | +import org.thingsboard.server.common.data.id.TenantId; | ||
29 | +import org.thingsboard.server.common.data.page.TimePageData; | ||
30 | +import org.thingsboard.server.common.data.page.TimePageLink; | ||
31 | + | ||
32 | +import java.io.IOException; | ||
33 | +import java.time.LocalDateTime; | ||
34 | +import java.time.Month; | ||
35 | +import java.time.ZoneOffset; | ||
36 | + | ||
37 | +public abstract class BaseEdgeEventServiceTest extends AbstractServiceTest { | ||
38 | + | ||
39 | + @Test | ||
40 | + public void saveEdgeEvent() throws Exception { | ||
41 | + EdgeId edgeId = new EdgeId(UUIDs.timeBased()); | ||
42 | + DeviceId deviceId = new DeviceId(UUIDs.timeBased()); | ||
43 | + EdgeEvent edgeEvent = generateEdgeEvent(null, edgeId, deviceId, DataConstants.ENTITY_CREATED); | ||
44 | + EdgeEvent saved = edgeEventService.saveAsync(edgeEvent).get(); | ||
45 | + Assert.assertEquals(saved.getTenantId(), edgeEvent.getTenantId()); | ||
46 | + Assert.assertEquals(saved.getEdgeId(), edgeEvent.getEdgeId()); | ||
47 | + Assert.assertEquals(saved.getEntityId(), edgeEvent.getEntityId()); | ||
48 | + Assert.assertEquals(saved.getEdgeEventType(), edgeEvent.getEdgeEventType()); | ||
49 | + Assert.assertEquals(saved.getEdgeEventAction(), edgeEvent.getEdgeEventAction()); | ||
50 | + Assert.assertEquals(saved.getEntityBody(), edgeEvent.getEntityBody()); | ||
51 | + } | ||
52 | + | ||
53 | + protected EdgeEvent generateEdgeEvent(TenantId tenantId, EdgeId edgeId, EntityId entityId, String edgeEventAction) throws IOException { | ||
54 | + if (tenantId == null) { | ||
55 | + tenantId = new TenantId(UUIDs.timeBased()); | ||
56 | + } | ||
57 | + EdgeEvent edgeEvent = new EdgeEvent(); | ||
58 | + edgeEvent.setTenantId(tenantId); | ||
59 | + edgeEvent.setEdgeId(edgeId); | ||
60 | + edgeEvent.setEntityId(entityId.getId()); | ||
61 | + edgeEvent.setEdgeEventType(EdgeEventType.DEVICE); | ||
62 | + edgeEvent.setEdgeEventAction(edgeEventAction); | ||
63 | + edgeEvent.setEntityBody(readFromResource("TestJsonData.json")); | ||
64 | + return edgeEvent; | ||
65 | + } | ||
66 | + | ||
67 | + | ||
68 | + @Test | ||
69 | + public void findEdgeEventsByTimeDescOrder() throws Exception { | ||
70 | + long timeBeforeStartTime = LocalDateTime.of(2020, Month.NOVEMBER, 1, 11, 30).toEpochSecond(ZoneOffset.UTC); | ||
71 | + long startTime = LocalDateTime.of(2020, Month.NOVEMBER, 1, 12, 0).toEpochSecond(ZoneOffset.UTC); | ||
72 | + long eventTime = LocalDateTime.of(2020, Month.NOVEMBER, 1, 12, 30).toEpochSecond(ZoneOffset.UTC); | ||
73 | + long endTime = LocalDateTime.of(2020, Month.NOVEMBER, 1, 13, 0).toEpochSecond(ZoneOffset.UTC); | ||
74 | + long timeAfterEndTime = LocalDateTime.of(2020, Month.NOVEMBER, 1, 13, 30).toEpochSecond(ZoneOffset.UTC); | ||
75 | + | ||
76 | + EdgeId edgeId = new EdgeId(UUIDs.timeBased()); | ||
77 | + DeviceId deviceId = new DeviceId(UUIDs.timeBased()); | ||
78 | + TenantId tenantId = new TenantId(UUIDs.timeBased()); | ||
79 | + saveEdgeEventWithProvidedTime(timeBeforeStartTime, edgeId, deviceId, tenantId); | ||
80 | + EdgeEvent savedEdgeEvent = saveEdgeEventWithProvidedTime(eventTime, edgeId, deviceId, tenantId); | ||
81 | + EdgeEvent savedEdgeEvent2 = saveEdgeEventWithProvidedTime(eventTime + 1, edgeId, deviceId, tenantId); | ||
82 | + EdgeEvent savedEdgeEvent3 = saveEdgeEventWithProvidedTime(eventTime + 2, edgeId, deviceId, tenantId); | ||
83 | + saveEdgeEventWithProvidedTime(timeAfterEndTime, edgeId, deviceId, tenantId); | ||
84 | + | ||
85 | + TimePageData<EdgeEvent> edgeEvents = edgeEventService.findEdgeEvents(tenantId, edgeId, new TimePageLink(2, startTime, endTime, false)); | ||
86 | + | ||
87 | + Assert.assertNotNull(edgeEvents.getData()); | ||
88 | + Assert.assertTrue(edgeEvents.getData().size() == 2); | ||
89 | + Assert.assertTrue(edgeEvents.getData().get(0).getUuidId().equals(savedEdgeEvent3.getUuidId())); | ||
90 | + Assert.assertTrue(edgeEvents.getData().get(1).getUuidId().equals(savedEdgeEvent2.getUuidId())); | ||
91 | + Assert.assertTrue(edgeEvents.hasNext()); | ||
92 | + Assert.assertNotNull(edgeEvents.getNextPageLink()); | ||
93 | + | ||
94 | + edgeEvents = edgeEventService.findEdgeEvents(tenantId, edgeId, edgeEvents.getNextPageLink()); | ||
95 | + | ||
96 | + Assert.assertNotNull(edgeEvents.getData()); | ||
97 | + Assert.assertTrue(edgeEvents.getData().size() == 1); | ||
98 | + Assert.assertTrue(edgeEvents.getData().get(0).getUuidId().equals(savedEdgeEvent.getUuidId())); | ||
99 | + Assert.assertFalse(edgeEvents.hasNext()); | ||
100 | + Assert.assertNull(edgeEvents.getNextPageLink()); | ||
101 | + } | ||
102 | + | ||
103 | + private EdgeEvent saveEdgeEventWithProvidedTime(long time, EdgeId edgeId, EntityId entityId, TenantId tenantId) throws Exception { | ||
104 | + EdgeEvent edgeEvent = generateEdgeEvent(tenantId, edgeId, entityId, DataConstants.ENTITY_CREATED); | ||
105 | + edgeEvent.setId(new EdgeEventId(UUIDs.startOf(time))); | ||
106 | + return edgeEventService.saveAsync(edgeEvent).get(); | ||
107 | + } | ||
108 | +} |
dao/src/test/java/org/thingsboard/server/dao/service/BaseEdgeServiceTest.java
renamed from
dao/src/test/java/org/thingsboard/server/dao/service/EdgeServiceImplTest.java
@@ -37,7 +37,7 @@ import java.util.List; | @@ -37,7 +37,7 @@ import java.util.List; | ||
37 | 37 | ||
38 | import static org.thingsboard.server.dao.model.ModelConstants.NULL_UUID; | 38 | import static org.thingsboard.server.dao.model.ModelConstants.NULL_UUID; |
39 | 39 | ||
40 | -public abstract class EdgeServiceImplTest extends AbstractServiceTest { | 40 | +public abstract class BaseEdgeServiceTest extends AbstractServiceTest { |
41 | 41 | ||
42 | private IdComparator<Edge> idComparator = new IdComparator<>(); | 42 | private IdComparator<Edge> idComparator = new IdComparator<>(); |
43 | 43 |
@@ -145,7 +145,7 @@ public abstract class BaseRuleChainServiceTest extends AbstractServiceTest { | @@ -145,7 +145,7 @@ public abstract class BaseRuleChainServiceTest extends AbstractServiceTest { | ||
145 | TextPageLink pageLink = new TextPageLink(16); | 145 | TextPageLink pageLink = new TextPageLink(16); |
146 | TextPageData<RuleChain> pageData = null; | 146 | TextPageData<RuleChain> pageData = null; |
147 | do { | 147 | do { |
148 | - pageData = ruleChainService.findTenantRuleChainsByType(tenantId, RuleChainType.SYSTEM, pageLink); | 148 | + pageData = ruleChainService.findTenantRuleChainsByType(tenantId, RuleChainType.CORE, pageLink); |
149 | loadedRuleChains.addAll(pageData.getData()); | 149 | loadedRuleChains.addAll(pageData.getData()); |
150 | if (pageData.hasNext()) { | 150 | if (pageData.hasNext()) { |
151 | pageLink = pageData.getNextPageLink(); | 151 | pageLink = pageData.getNextPageLink(); |
@@ -160,7 +160,7 @@ public abstract class BaseRuleChainServiceTest extends AbstractServiceTest { | @@ -160,7 +160,7 @@ public abstract class BaseRuleChainServiceTest extends AbstractServiceTest { | ||
160 | ruleChainService.deleteRuleChainsByTenantId(tenantId); | 160 | ruleChainService.deleteRuleChainsByTenantId(tenantId); |
161 | 161 | ||
162 | pageLink = new TextPageLink(31); | 162 | pageLink = new TextPageLink(31); |
163 | - pageData = ruleChainService.findTenantRuleChainsByType(tenantId, RuleChainType.SYSTEM, pageLink); | 163 | + pageData = ruleChainService.findTenantRuleChainsByType(tenantId, RuleChainType.CORE, pageLink); |
164 | Assert.assertFalse(pageData.hasNext()); | 164 | Assert.assertFalse(pageData.hasNext()); |
165 | Assert.assertTrue(pageData.getData().isEmpty()); | 165 | Assert.assertTrue(pageData.getData().isEmpty()); |
166 | 166 | ||
@@ -196,7 +196,7 @@ public abstract class BaseRuleChainServiceTest extends AbstractServiceTest { | @@ -196,7 +196,7 @@ public abstract class BaseRuleChainServiceTest extends AbstractServiceTest { | ||
196 | TextPageLink pageLink = new TextPageLink(19, name1); | 196 | TextPageLink pageLink = new TextPageLink(19, name1); |
197 | TextPageData<RuleChain> pageData = null; | 197 | TextPageData<RuleChain> pageData = null; |
198 | do { | 198 | do { |
199 | - pageData = ruleChainService.findTenantRuleChainsByType(tenantId, RuleChainType.SYSTEM, pageLink); | 199 | + pageData = ruleChainService.findTenantRuleChainsByType(tenantId, RuleChainType.CORE, pageLink); |
200 | loadedRuleChainsName1.addAll(pageData.getData()); | 200 | loadedRuleChainsName1.addAll(pageData.getData()); |
201 | if (pageData.hasNext()) { | 201 | if (pageData.hasNext()) { |
202 | pageLink = pageData.getNextPageLink(); | 202 | pageLink = pageData.getNextPageLink(); |
@@ -211,7 +211,7 @@ public abstract class BaseRuleChainServiceTest extends AbstractServiceTest { | @@ -211,7 +211,7 @@ public abstract class BaseRuleChainServiceTest extends AbstractServiceTest { | ||
211 | List<RuleChain> loadedRuleChainsName2 = new ArrayList<>(); | 211 | List<RuleChain> loadedRuleChainsName2 = new ArrayList<>(); |
212 | pageLink = new TextPageLink(4, name2); | 212 | pageLink = new TextPageLink(4, name2); |
213 | do { | 213 | do { |
214 | - pageData = ruleChainService.findTenantRuleChainsByType(tenantId, RuleChainType.SYSTEM, pageLink); | 214 | + pageData = ruleChainService.findTenantRuleChainsByType(tenantId, RuleChainType.CORE, pageLink); |
215 | loadedRuleChainsName2.addAll(pageData.getData()); | 215 | loadedRuleChainsName2.addAll(pageData.getData()); |
216 | if (pageData.hasNext()) { | 216 | if (pageData.hasNext()) { |
217 | pageLink = pageData.getNextPageLink(); | 217 | pageLink = pageData.getNextPageLink(); |
@@ -228,7 +228,7 @@ public abstract class BaseRuleChainServiceTest extends AbstractServiceTest { | @@ -228,7 +228,7 @@ public abstract class BaseRuleChainServiceTest extends AbstractServiceTest { | ||
228 | } | 228 | } |
229 | 229 | ||
230 | pageLink = new TextPageLink(4, name1); | 230 | pageLink = new TextPageLink(4, name1); |
231 | - pageData = ruleChainService.findTenantRuleChainsByType(tenantId, RuleChainType.SYSTEM, pageLink); | 231 | + pageData = ruleChainService.findTenantRuleChainsByType(tenantId, RuleChainType.CORE, pageLink); |
232 | Assert.assertFalse(pageData.hasNext()); | 232 | Assert.assertFalse(pageData.hasNext()); |
233 | Assert.assertEquals(0, pageData.getData().size()); | 233 | Assert.assertEquals(0, pageData.getData().size()); |
234 | 234 | ||
@@ -237,7 +237,7 @@ public abstract class BaseRuleChainServiceTest extends AbstractServiceTest { | @@ -237,7 +237,7 @@ public abstract class BaseRuleChainServiceTest extends AbstractServiceTest { | ||
237 | } | 237 | } |
238 | 238 | ||
239 | pageLink = new TextPageLink(4, name2); | 239 | pageLink = new TextPageLink(4, name2); |
240 | - pageData = ruleChainService.findTenantRuleChainsByType(tenantId, RuleChainType.SYSTEM, pageLink); | 240 | + pageData = ruleChainService.findTenantRuleChainsByType(tenantId, RuleChainType.CORE, pageLink); |
241 | Assert.assertFalse(pageData.hasNext()); | 241 | Assert.assertFalse(pageData.hasNext()); |
242 | Assert.assertEquals(0, pageData.getData().size()); | 242 | Assert.assertEquals(0, pageData.getData().size()); |
243 | } | 243 | } |
dao/src/test/java/org/thingsboard/server/dao/service/nosql/EdgeEventServiceNoSqlTest.java
renamed from
common/data/src/main/java/org/thingsboard/server/common/data/edge/EdgeQueueEntry.java
@@ -13,13 +13,11 @@ | @@ -13,13 +13,11 @@ | ||
13 | * See the License for the specific language governing permissions and | 13 | * See the License for the specific language governing permissions and |
14 | * limitations under the License. | 14 | * limitations under the License. |
15 | */ | 15 | */ |
16 | -package org.thingsboard.server.common.data.edge; | 16 | +package org.thingsboard.server.dao.service.nosql; |
17 | 17 | ||
18 | -import lombok.Data; | 18 | +import org.thingsboard.server.dao.service.BaseEdgeEventServiceTest; |
19 | +import org.thingsboard.server.dao.service.DaoNoSqlTest; | ||
19 | 20 | ||
20 | -@Data | ||
21 | -public class EdgeQueueEntry { | ||
22 | - private String type; | ||
23 | - private EdgeQueueEntityType entityType; | ||
24 | - private String data; | 21 | +@DaoNoSqlTest |
22 | +public class EdgeEventServiceNoSqlTest extends BaseEdgeEventServiceTest { | ||
25 | } | 23 | } |
@@ -15,9 +15,9 @@ | @@ -15,9 +15,9 @@ | ||
15 | */ | 15 | */ |
16 | package org.thingsboard.server.dao.service.nosql; | 16 | package org.thingsboard.server.dao.service.nosql; |
17 | 17 | ||
18 | -import org.thingsboard.server.dao.service.EdgeServiceImplTest; | 18 | +import org.thingsboard.server.dao.service.BaseEdgeServiceTest; |
19 | import org.thingsboard.server.dao.service.DaoNoSqlTest; | 19 | import org.thingsboard.server.dao.service.DaoNoSqlTest; |
20 | 20 | ||
21 | @DaoNoSqlTest | 21 | @DaoNoSqlTest |
22 | -public class EdgeServiceNoSqlTest extends EdgeServiceImplTest { | 22 | +public class EdgeServiceNoSqlTest extends BaseEdgeServiceTest { |
23 | } | 23 | } |
1 | +/** | ||
2 | + * Copyright © 2016-2020 The Thingsboard Authors | ||
3 | + * | ||
4 | + * Licensed under the Apache License, Version 2.0 (the "License"); | ||
5 | + * you may not use this file except in compliance with the License. | ||
6 | + * You may obtain a copy of the License at | ||
7 | + * | ||
8 | + * http://www.apache.org/licenses/LICENSE-2.0 | ||
9 | + * | ||
10 | + * Unless required by applicable law or agreed to in writing, software | ||
11 | + * distributed under the License is distributed on an "AS IS" BASIS, | ||
12 | + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||
13 | + * See the License for the specific language governing permissions and | ||
14 | + * limitations under the License. | ||
15 | + */ | ||
16 | +package org.thingsboard.server.dao.service.sql; | ||
17 | + | ||
18 | +import org.thingsboard.server.dao.service.BaseEdgeEventServiceTest; | ||
19 | +import org.thingsboard.server.dao.service.DaoSqlTest; | ||
20 | + | ||
21 | +@DaoSqlTest | ||
22 | +public class EdgeEventServiceSqlTest extends BaseEdgeEventServiceTest { | ||
23 | +} |
@@ -15,9 +15,9 @@ | @@ -15,9 +15,9 @@ | ||
15 | */ | 15 | */ |
16 | package org.thingsboard.server.dao.service.sql; | 16 | package org.thingsboard.server.dao.service.sql; |
17 | 17 | ||
18 | -import org.thingsboard.server.dao.service.EdgeServiceImplTest; | 18 | +import org.thingsboard.server.dao.service.BaseEdgeServiceTest; |
19 | import org.thingsboard.server.dao.service.DaoSqlTest; | 19 | import org.thingsboard.server.dao.service.DaoSqlTest; |
20 | 20 | ||
21 | @DaoSqlTest | 21 | @DaoSqlTest |
22 | -public class EdgeServiceSqlTest extends EdgeServiceImplTest { | 22 | +public class EdgeServiceSqlTest extends BaseEdgeServiceTest { |
23 | } | 23 | } |
@@ -20,4 +20,5 @@ DROP TABLE IF EXISTS widgets_bundle; | @@ -20,4 +20,5 @@ DROP TABLE IF EXISTS widgets_bundle; | ||
20 | DROP TABLE IF EXISTS rule_node; | 20 | DROP TABLE IF EXISTS rule_node; |
21 | DROP TABLE IF EXISTS rule_chain; | 21 | DROP TABLE IF EXISTS rule_chain; |
22 | DROP TABLE IF EXISTS entity_view; | 22 | DROP TABLE IF EXISTS entity_view; |
23 | -DROP TABLE IF EXISTS edge; | ||
23 | +DROP TABLE IF EXISTS edge; | ||
24 | +DROP TABLE IF EXISTS edge_event; |
@@ -58,6 +58,6 @@ public @interface RuleNode { | @@ -58,6 +58,6 @@ public @interface RuleNode { | ||
58 | 58 | ||
59 | boolean customRelations() default false; | 59 | boolean customRelations() default false; |
60 | 60 | ||
61 | - RuleChainType[] ruleChainTypes() default RuleChainType.SYSTEM; | 61 | + RuleChainType[] ruleChainTypes() default RuleChainType.CORE; |
62 | 62 | ||
63 | } | 63 | } |
@@ -35,6 +35,7 @@ import org.thingsboard.server.dao.cassandra.CassandraCluster; | @@ -35,6 +35,7 @@ import org.thingsboard.server.dao.cassandra.CassandraCluster; | ||
35 | import org.thingsboard.server.dao.customer.CustomerService; | 35 | import org.thingsboard.server.dao.customer.CustomerService; |
36 | import org.thingsboard.server.dao.dashboard.DashboardService; | 36 | import org.thingsboard.server.dao.dashboard.DashboardService; |
37 | import org.thingsboard.server.dao.device.DeviceService; | 37 | import org.thingsboard.server.dao.device.DeviceService; |
38 | +import org.thingsboard.server.dao.edge.EdgeEventService; | ||
38 | import org.thingsboard.server.dao.edge.EdgeService; | 39 | import org.thingsboard.server.dao.edge.EdgeService; |
39 | import org.thingsboard.server.dao.entityview.EntityViewService; | 40 | import org.thingsboard.server.dao.entityview.EntityViewService; |
40 | import org.thingsboard.server.dao.nosql.CassandraStatementTask; | 41 | import org.thingsboard.server.dao.nosql.CassandraStatementTask; |
@@ -190,6 +191,8 @@ public interface TbContext { | @@ -190,6 +191,8 @@ public interface TbContext { | ||
190 | 191 | ||
191 | EdgeService getEdgeService(); | 192 | EdgeService getEdgeService(); |
192 | 193 | ||
194 | + EdgeEventService getEdgeEventService(); | ||
195 | + | ||
193 | ListeningExecutor getJsExecutor(); | 196 | ListeningExecutor getJsExecutor(); |
194 | 197 | ||
195 | ListeningExecutor getMailExecutor(); | 198 | ListeningExecutor getMailExecutor(); |
@@ -38,7 +38,7 @@ import org.thingsboard.server.common.msg.TbMsg; | @@ -38,7 +38,7 @@ import org.thingsboard.server.common.msg.TbMsg; | ||
38 | uiResources = {"static/rulenode/rulenode-core-config.js"}, | 38 | uiResources = {"static/rulenode/rulenode-core-config.js"}, |
39 | configDirective = "tbActionNodeAssignToCustomerConfig", | 39 | configDirective = "tbActionNodeAssignToCustomerConfig", |
40 | icon = "add_circle", | 40 | icon = "add_circle", |
41 | - ruleChainTypes = {RuleChainType.SYSTEM, RuleChainType.EDGE} | 41 | + ruleChainTypes = {RuleChainType.CORE, RuleChainType.EDGE} |
42 | ) | 42 | ) |
43 | public class TbAssignToCustomerNode extends TbAbstractCustomerActionNode<TbAssignToCustomerNodeConfiguration> { | 43 | public class TbAssignToCustomerNode extends TbAbstractCustomerActionNode<TbAssignToCustomerNodeConfiguration> { |
44 | 44 |
@@ -46,7 +46,7 @@ import org.thingsboard.server.common.msg.TbMsg; | @@ -46,7 +46,7 @@ import org.thingsboard.server.common.msg.TbMsg; | ||
46 | uiResources = {"static/rulenode/rulenode-core-config.js"}, | 46 | uiResources = {"static/rulenode/rulenode-core-config.js"}, |
47 | configDirective = "tbActionNodeClearAlarmConfig", | 47 | configDirective = "tbActionNodeClearAlarmConfig", |
48 | icon = "notifications_off", | 48 | icon = "notifications_off", |
49 | - ruleChainTypes = {RuleChainType.SYSTEM, RuleChainType.EDGE} | 49 | + ruleChainTypes = {RuleChainType.CORE, RuleChainType.EDGE} |
50 | ) | 50 | ) |
51 | public class TbClearAlarmNode extends TbAbstractAlarmNode<TbClearAlarmNodeConfiguration> { | 51 | public class TbClearAlarmNode extends TbAbstractAlarmNode<TbClearAlarmNodeConfiguration> { |
52 | 52 |
@@ -58,7 +58,7 @@ import static org.thingsboard.rule.engine.api.TbRelationTypes.SUCCESS; | @@ -58,7 +58,7 @@ import static org.thingsboard.rule.engine.api.TbRelationTypes.SUCCESS; | ||
58 | uiResources = {"static/rulenode/rulenode-core-config.js"}, | 58 | uiResources = {"static/rulenode/rulenode-core-config.js"}, |
59 | configDirective = "tbNodeEmptyConfig", | 59 | configDirective = "tbNodeEmptyConfig", |
60 | icon = "content_copy", | 60 | icon = "content_copy", |
61 | - ruleChainTypes = {RuleChainType.SYSTEM, RuleChainType.EDGE} | 61 | + ruleChainTypes = {RuleChainType.CORE, RuleChainType.EDGE} |
62 | ) | 62 | ) |
63 | public class TbCopyAttributesToEntityViewNode implements TbNode { | 63 | public class TbCopyAttributesToEntityViewNode implements TbNode { |
64 | 64 |
@@ -52,7 +52,7 @@ import java.util.List; | @@ -52,7 +52,7 @@ import java.util.List; | ||
52 | uiResources = {"static/rulenode/rulenode-core-config.js"}, | 52 | uiResources = {"static/rulenode/rulenode-core-config.js"}, |
53 | configDirective = "tbActionNodeCreateAlarmConfig", | 53 | configDirective = "tbActionNodeCreateAlarmConfig", |
54 | icon = "notifications_active", | 54 | icon = "notifications_active", |
55 | - ruleChainTypes = {RuleChainType.SYSTEM, RuleChainType.EDGE} | 55 | + ruleChainTypes = {RuleChainType.CORE, RuleChainType.EDGE} |
56 | ) | 56 | ) |
57 | public class TbCreateAlarmNode extends TbAbstractAlarmNode<TbCreateAlarmNodeConfiguration> { | 57 | public class TbCreateAlarmNode extends TbAbstractAlarmNode<TbCreateAlarmNodeConfiguration> { |
58 | 58 |
@@ -55,7 +55,7 @@ import java.util.List; | @@ -55,7 +55,7 @@ import java.util.List; | ||
55 | uiResources = {"static/rulenode/rulenode-core-config.js"}, | 55 | uiResources = {"static/rulenode/rulenode-core-config.js"}, |
56 | configDirective = "tbActionNodeCreateRelationConfig", | 56 | configDirective = "tbActionNodeCreateRelationConfig", |
57 | icon = "add_circle", | 57 | icon = "add_circle", |
58 | - ruleChainTypes = {RuleChainType.SYSTEM, RuleChainType.EDGE} | 58 | + ruleChainTypes = {RuleChainType.CORE, RuleChainType.EDGE} |
59 | ) | 59 | ) |
60 | public class TbCreateRelationNode extends TbAbstractRelationActionNode<TbCreateRelationNodeConfiguration> { | 60 | public class TbCreateRelationNode extends TbAbstractRelationActionNode<TbCreateRelationNodeConfiguration> { |
61 | 61 |
@@ -45,7 +45,7 @@ import java.util.List; | @@ -45,7 +45,7 @@ import java.util.List; | ||
45 | uiResources = {"static/rulenode/rulenode-core-config.js"}, | 45 | uiResources = {"static/rulenode/rulenode-core-config.js"}, |
46 | configDirective = "tbActionNodeDeleteRelationConfig", | 46 | configDirective = "tbActionNodeDeleteRelationConfig", |
47 | icon = "remove_circle", | 47 | icon = "remove_circle", |
48 | - ruleChainTypes = {RuleChainType.SYSTEM, RuleChainType.EDGE} | 48 | + ruleChainTypes = {RuleChainType.CORE, RuleChainType.EDGE} |
49 | ) | 49 | ) |
50 | public class TbDeleteRelationNode extends TbAbstractRelationActionNode<TbDeleteRelationNodeConfiguration> { | 50 | public class TbDeleteRelationNode extends TbAbstractRelationActionNode<TbDeleteRelationNodeConfiguration> { |
51 | 51 |
@@ -38,7 +38,7 @@ import static org.thingsboard.rule.engine.api.TbRelationTypes.SUCCESS; | @@ -38,7 +38,7 @@ import static org.thingsboard.rule.engine.api.TbRelationTypes.SUCCESS; | ||
38 | uiResources = {"static/rulenode/rulenode-core-config.js"}, | 38 | uiResources = {"static/rulenode/rulenode-core-config.js"}, |
39 | configDirective = "tbActionNodeLogConfig", | 39 | configDirective = "tbActionNodeLogConfig", |
40 | icon = "menu", | 40 | icon = "menu", |
41 | - ruleChainTypes = {RuleChainType.SYSTEM, RuleChainType.EDGE} | 41 | + ruleChainTypes = {RuleChainType.CORE, RuleChainType.EDGE} |
42 | ) | 42 | ) |
43 | 43 | ||
44 | public class TbLogNode implements TbNode { | 44 | public class TbLogNode implements TbNode { |
@@ -44,7 +44,7 @@ import static org.thingsboard.rule.engine.api.TbRelationTypes.SUCCESS; | @@ -44,7 +44,7 @@ import static org.thingsboard.rule.engine.api.TbRelationTypes.SUCCESS; | ||
44 | icon = "functions", | 44 | icon = "functions", |
45 | uiResources = {"static/rulenode/rulenode-core-config.js"}, | 45 | uiResources = {"static/rulenode/rulenode-core-config.js"}, |
46 | configDirective = "tbActionNodeMsgCountConfig", | 46 | configDirective = "tbActionNodeMsgCountConfig", |
47 | - ruleChainTypes = {RuleChainType.SYSTEM, RuleChainType.EDGE} | 47 | + ruleChainTypes = {RuleChainType.CORE, RuleChainType.EDGE} |
48 | ) | 48 | ) |
49 | public class TbMsgCountNode implements TbNode { | 49 | public class TbMsgCountNode implements TbNode { |
50 | 50 |
@@ -35,7 +35,7 @@ import org.thingsboard.server.common.msg.TbMsg; | @@ -35,7 +35,7 @@ import org.thingsboard.server.common.msg.TbMsg; | ||
35 | uiResources = {"static/rulenode/rulenode-core-config.js"}, | 35 | uiResources = {"static/rulenode/rulenode-core-config.js"}, |
36 | configDirective = "tbActionNodeUnAssignToCustomerConfig", | 36 | configDirective = "tbActionNodeUnAssignToCustomerConfig", |
37 | icon = "remove_circle", | 37 | icon = "remove_circle", |
38 | - ruleChainTypes = {RuleChainType.SYSTEM, RuleChainType.EDGE} | 38 | + ruleChainTypes = {RuleChainType.CORE, RuleChainType.EDGE} |
39 | ) | 39 | ) |
40 | public class TbUnassignFromCustomerNode extends TbAbstractCustomerActionNode<TbUnassignFromCustomerNodeConfiguration> { | 40 | public class TbUnassignFromCustomerNode extends TbAbstractCustomerActionNode<TbUnassignFromCustomerNodeConfiguration> { |
41 | 41 |
@@ -47,7 +47,7 @@ import static org.thingsboard.common.util.DonAsynchron.withCallback; | @@ -47,7 +47,7 @@ import static org.thingsboard.common.util.DonAsynchron.withCallback; | ||
47 | uiResources = {"static/rulenode/rulenode-core-config.js"}, | 47 | uiResources = {"static/rulenode/rulenode-core-config.js"}, |
48 | configDirective = "tbActionNodeSnsConfig", | 48 | configDirective = "tbActionNodeSnsConfig", |
49 | iconUrl = "", | 49 | iconUrl = "", |
50 | - ruleChainTypes = {RuleChainType.SYSTEM, RuleChainType.EDGE} | 50 | + ruleChainTypes = {RuleChainType.CORE, RuleChainType.EDGE} |
51 | ) | 51 | ) |
52 | public class TbSnsNode implements TbNode { | 52 | public class TbSnsNode implements TbNode { |
53 | 53 |
@@ -52,7 +52,7 @@ import static org.thingsboard.common.util.DonAsynchron.withCallback; | @@ -52,7 +52,7 @@ import static org.thingsboard.common.util.DonAsynchron.withCallback; | ||
52 | uiResources = {"static/rulenode/rulenode-core-config.js"}, | 52 | uiResources = {"static/rulenode/rulenode-core-config.js"}, |
53 | configDirective = "tbActionNodeSqsConfig", | 53 | configDirective = "tbActionNodeSqsConfig", |
54 | iconUrl = "", | 54 | iconUrl = "", |
55 | - ruleChainTypes = {RuleChainType.SYSTEM, RuleChainType.EDGE} | 55 | + ruleChainTypes = {RuleChainType.CORE, RuleChainType.EDGE} |
56 | ) | 56 | ) |
57 | public class TbSqsNode implements TbNode { | 57 | public class TbSqsNode implements TbNode { |
58 | 58 |
@@ -45,7 +45,7 @@ import static org.thingsboard.rule.engine.api.TbRelationTypes.SUCCESS; | @@ -45,7 +45,7 @@ import static org.thingsboard.rule.engine.api.TbRelationTypes.SUCCESS; | ||
45 | uiResources = {"static/rulenode/rulenode-core-config.js", "static/rulenode/rulenode-core-config.css"}, | 45 | uiResources = {"static/rulenode/rulenode-core-config.js", "static/rulenode/rulenode-core-config.css"}, |
46 | configDirective = "tbActionNodeGeneratorConfig", | 46 | configDirective = "tbActionNodeGeneratorConfig", |
47 | icon = "repeat", | 47 | icon = "repeat", |
48 | - ruleChainTypes = {RuleChainType.SYSTEM, RuleChainType.EDGE} | 48 | + ruleChainTypes = {RuleChainType.CORE, RuleChainType.EDGE} |
49 | ) | 49 | ) |
50 | 50 | ||
51 | public class TbMsgGeneratorNode implements TbNode { | 51 | public class TbMsgGeneratorNode implements TbNode { |
@@ -46,7 +46,7 @@ import static org.thingsboard.rule.engine.api.TbRelationTypes.SUCCESS; | @@ -46,7 +46,7 @@ import static org.thingsboard.rule.engine.api.TbRelationTypes.SUCCESS; | ||
46 | icon = "pause", | 46 | icon = "pause", |
47 | uiResources = {"static/rulenode/rulenode-core-config.js"}, | 47 | uiResources = {"static/rulenode/rulenode-core-config.js"}, |
48 | configDirective = "tbActionNodeMsgDelayConfig", | 48 | configDirective = "tbActionNodeMsgDelayConfig", |
49 | - ruleChainTypes = {RuleChainType.SYSTEM, RuleChainType.EDGE} | 49 | + ruleChainTypes = {RuleChainType.CORE, RuleChainType.EDGE} |
50 | ) | 50 | ) |
51 | 51 | ||
52 | public class TbMsgDelayNode implements TbNode { | 52 | public class TbMsgDelayNode implements TbNode { |
@@ -15,6 +15,10 @@ | @@ -15,6 +15,10 @@ | ||
15 | */ | 15 | */ |
16 | package org.thingsboard.rule.engine.edge; | 16 | package org.thingsboard.rule.engine.edge; |
17 | 17 | ||
18 | +import com.fasterxml.jackson.databind.ObjectMapper; | ||
19 | +import com.google.common.util.concurrent.FutureCallback; | ||
20 | +import com.google.common.util.concurrent.Futures; | ||
21 | +import com.google.common.util.concurrent.ListenableFuture; | ||
18 | import lombok.extern.slf4j.Slf4j; | 22 | import lombok.extern.slf4j.Slf4j; |
19 | import org.thingsboard.rule.engine.api.EmptyNodeConfiguration; | 23 | import org.thingsboard.rule.engine.api.EmptyNodeConfiguration; |
20 | import org.thingsboard.rule.engine.api.RuleNode; | 24 | import org.thingsboard.rule.engine.api.RuleNode; |
@@ -23,10 +27,25 @@ import org.thingsboard.rule.engine.api.TbNode; | @@ -23,10 +27,25 @@ import org.thingsboard.rule.engine.api.TbNode; | ||
23 | import org.thingsboard.rule.engine.api.TbNodeConfiguration; | 27 | import org.thingsboard.rule.engine.api.TbNodeConfiguration; |
24 | import org.thingsboard.rule.engine.api.TbNodeException; | 28 | import org.thingsboard.rule.engine.api.TbNodeException; |
25 | import org.thingsboard.rule.engine.api.util.TbNodeUtils; | 29 | import org.thingsboard.rule.engine.api.util.TbNodeUtils; |
30 | +import org.thingsboard.server.common.data.DataConstants; | ||
31 | +import org.thingsboard.server.common.data.EntityType; | ||
32 | +import org.thingsboard.server.common.data.audit.ActionType; | ||
33 | +import org.thingsboard.server.common.data.edge.EdgeEvent; | ||
34 | +import org.thingsboard.server.common.data.edge.EdgeEventType; | ||
35 | +import org.thingsboard.server.common.data.id.EdgeId; | ||
36 | +import org.thingsboard.server.common.data.id.EntityId; | ||
37 | +import org.thingsboard.server.common.data.id.TenantId; | ||
26 | import org.thingsboard.server.common.data.plugin.ComponentType; | 38 | import org.thingsboard.server.common.data.plugin.ComponentType; |
39 | +import org.thingsboard.server.common.data.relation.EntityRelation; | ||
40 | +import org.thingsboard.server.common.data.relation.RelationTypeGroup; | ||
27 | import org.thingsboard.server.common.msg.TbMsg; | 41 | import org.thingsboard.server.common.msg.TbMsg; |
28 | import org.thingsboard.server.common.msg.session.SessionMsgType; | 42 | import org.thingsboard.server.common.msg.session.SessionMsgType; |
29 | 43 | ||
44 | +import javax.annotation.Nullable; | ||
45 | +import java.util.List; | ||
46 | + | ||
47 | +import static org.thingsboard.rule.engine.api.TbRelationTypes.SUCCESS; | ||
48 | + | ||
30 | @Slf4j | 49 | @Slf4j |
31 | @RuleNode( | 50 | @RuleNode( |
32 | type = ComponentType.ACTION, | 51 | type = ComponentType.ACTION, |
@@ -40,13 +59,10 @@ import org.thingsboard.server.common.msg.session.SessionMsgType; | @@ -40,13 +59,10 @@ import org.thingsboard.server.common.msg.session.SessionMsgType; | ||
40 | ) | 59 | ) |
41 | public class TbMsgPushToEdgeNode implements TbNode { | 60 | public class TbMsgPushToEdgeNode implements TbNode { |
42 | 61 | ||
43 | - private static final String CLOUD_MSG_SOURCE = "cloud"; | ||
44 | - private static final String EDGE_MSG_SOURCE = "edge"; | ||
45 | - private static final String MSG_SOURCE_KEY = "source"; | ||
46 | - private static final String TS_METADATA_KEY = "ts"; | ||
47 | - | ||
48 | private EmptyNodeConfiguration config; | 62 | private EmptyNodeConfiguration config; |
49 | 63 | ||
64 | + private static final ObjectMapper json = new ObjectMapper(); | ||
65 | + | ||
50 | @Override | 66 | @Override |
51 | public void init(TbContext ctx, TbNodeConfiguration configuration) throws TbNodeException { | 67 | public void init(TbContext ctx, TbNodeConfiguration configuration) throws TbNodeException { |
52 | this.config = TbNodeUtils.convert(configuration, EmptyNodeConfiguration.class); | 68 | this.config = TbNodeUtils.convert(configuration, EmptyNodeConfiguration.class); |
@@ -54,14 +70,71 @@ public class TbMsgPushToEdgeNode implements TbNode { | @@ -54,14 +70,71 @@ public class TbMsgPushToEdgeNode implements TbNode { | ||
54 | 70 | ||
55 | @Override | 71 | @Override |
56 | public void onMsg(TbContext ctx, TbMsg msg) { | 72 | public void onMsg(TbContext ctx, TbMsg msg) { |
57 | - if (EDGE_MSG_SOURCE.equalsIgnoreCase(msg.getMetaData().getValue(MSG_SOURCE_KEY))) { | ||
58 | - return; | ||
59 | - } | ||
60 | - if (msg.getType().equals(SessionMsgType.POST_TELEMETRY_REQUEST.name())) { | ||
61 | - msg.getMetaData().putValue(TS_METADATA_KEY, Long.toString(System.currentTimeMillis())); | 73 | + if (EntityType.DEVICE.equals(msg.getOriginator().getEntityType()) || |
74 | + EntityType.DEVICE.equals(msg.getOriginator().getEntityType()) || | ||
75 | + EntityType.DEVICE.equals(msg.getOriginator().getEntityType()) || | ||
76 | + EntityType.DEVICE.equals(msg.getOriginator().getEntityType())) { | ||
77 | + if (SessionMsgType.POST_TELEMETRY_REQUEST.name().equals(msg.getType()) || | ||
78 | + SessionMsgType.POST_ATTRIBUTES_REQUEST.name().equals(msg.getType()) || | ||
79 | + DataConstants.ATTRIBUTES_UPDATED.equals(msg.getType()) || | ||
80 | + DataConstants.ATTRIBUTES_DELETED.equals(msg.getType())) { | ||
81 | + ListenableFuture<EdgeId> getEdgeIdFuture = getEdgeIdByOriginatorId(ctx, ctx.getTenantId(), msg.getOriginator()); | ||
82 | + Futures.transform(getEdgeIdFuture, edgeId -> { | ||
83 | + EdgeEventType edgeEventTypeByEntityType = ctx.getEdgeEventService().getEdgeEventTypeByEntityType(msg.getOriginator().getEntityType()); | ||
84 | + if (edgeEventTypeByEntityType == null) { | ||
85 | + log.debug("Edge event type is null. Entity Type {}", msg.getOriginator().getEntityType()); | ||
86 | + ctx.tellFailure(msg, new RuntimeException("Edge event type is null. Entity Type '"+ msg.getOriginator().getEntityType() + "'")); | ||
87 | + } | ||
88 | + ActionType actionType; | ||
89 | + if (SessionMsgType.POST_TELEMETRY_REQUEST.name().equals(msg.getType())) { | ||
90 | + actionType = ActionType.TIMESERIES_UPDATED; | ||
91 | + } else if (SessionMsgType.POST_ATTRIBUTES_REQUEST.name().equals(msg.getType()) || | ||
92 | + DataConstants.ATTRIBUTES_UPDATED.equals(msg.getType())) { | ||
93 | + actionType = ActionType.ATTRIBUTES_UPDATED; | ||
94 | + } else { | ||
95 | + actionType = ActionType.ATTRIBUTES_DELETED; | ||
96 | + } | ||
97 | + EdgeEvent edgeEvent = new EdgeEvent(); | ||
98 | + edgeEvent.setTenantId(ctx.getTenantId()); | ||
99 | + edgeEvent.setEdgeId(edgeId); | ||
100 | + edgeEvent.setEdgeEventAction(actionType.name()); | ||
101 | + edgeEvent.setEntityId(msg.getOriginator().getId()); | ||
102 | + edgeEvent.setEdgeEventType(edgeEventTypeByEntityType); | ||
103 | + edgeEvent.setEntityBody(json.valueToTree(msg.getData())); | ||
104 | + ListenableFuture<EdgeEvent> saveFuture = ctx.getEdgeEventService().saveAsync(edgeEvent); | ||
105 | + Futures.addCallback(saveFuture, new FutureCallback<EdgeEvent>() { | ||
106 | + @Override | ||
107 | + public void onSuccess(@Nullable EdgeEvent event) { | ||
108 | + ctx.tellNext(msg, SUCCESS); | ||
109 | + } | ||
110 | + | ||
111 | + @Override | ||
112 | + public void onFailure(Throwable th) { | ||
113 | + log.error("Could not save edge event", th); | ||
114 | + ctx.tellFailure(msg, th); | ||
115 | + } | ||
116 | + }, ctx.getDbCallbackExecutor()); | ||
117 | + return null; | ||
118 | + }, ctx.getDbCallbackExecutor()); | ||
119 | + } else { | ||
120 | + log.debug("Unsupported msg type {}", msg.getType()); | ||
121 | + ctx.tellFailure(msg, new RuntimeException("Unsupported msg type '" + msg.getType() + "'")); | ||
122 | + } | ||
123 | + } else { | ||
124 | + log.debug("Unsupported originator type {}", msg.getOriginator().getEntityType()); | ||
125 | + ctx.tellFailure(msg, new RuntimeException("Unsupported originator type '" + msg.getOriginator().getEntityType() + "'")); | ||
62 | } | 126 | } |
63 | - msg.getMetaData().putValue(MSG_SOURCE_KEY, CLOUD_MSG_SOURCE); | ||
64 | - ctx.getEdgeService().pushEventToEdge(ctx.getTenantId(), msg, new PushToEdgeNodeCallback(ctx, msg)); | 127 | + } |
128 | + | ||
129 | + private ListenableFuture<EdgeId> getEdgeIdByOriginatorId(TbContext ctx, TenantId tenantId, EntityId originatorId) { | ||
130 | + ListenableFuture<List<EntityRelation>> future = ctx.getRelationService().findByToAndTypeAsync(tenantId, originatorId, EntityRelation.CONTAINS_TYPE, RelationTypeGroup.EDGE); | ||
131 | + return Futures.transform(future, relations -> { | ||
132 | + if (relations != null && relations.size() > 0) { | ||
133 | + return new EdgeId(relations.get(0).getFrom().getId()); | ||
134 | + } else { | ||
135 | + return null; | ||
136 | + } | ||
137 | + }, ctx.getDbCallbackExecutor()); | ||
65 | } | 138 | } |
66 | 139 | ||
67 | @Override | 140 | @Override |
@@ -41,7 +41,7 @@ import java.util.Map; | @@ -41,7 +41,7 @@ import java.util.Map; | ||
41 | "Else if the checkbox is not selected, and at least one of the keys from data or metadata of the message exists - send Message via <b>True</b> chain, otherwise, <b>False</b> chain is used. ", | 41 | "Else if the checkbox is not selected, and at least one of the keys from data or metadata of the message exists - send Message via <b>True</b> chain, otherwise, <b>False</b> chain is used. ", |
42 | uiResources = {"static/rulenode/rulenode-core-config.js"}, | 42 | uiResources = {"static/rulenode/rulenode-core-config.js"}, |
43 | configDirective = "tbFilterNodeCheckMessageConfig", | 43 | configDirective = "tbFilterNodeCheckMessageConfig", |
44 | - ruleChainTypes = {RuleChainType.SYSTEM, RuleChainType.EDGE} | 44 | + ruleChainTypes = {RuleChainType.CORE, RuleChainType.EDGE} |
45 | ) | 45 | ) |
46 | public class TbCheckMessageNode implements TbNode { | 46 | public class TbCheckMessageNode implements TbNode { |
47 | 47 |
@@ -53,7 +53,7 @@ import static org.thingsboard.common.util.DonAsynchron.withCallback; | @@ -53,7 +53,7 @@ import static org.thingsboard.common.util.DonAsynchron.withCallback; | ||
53 | nodeDetails = "If at least one relation exists - send Message via <b>True</b> chain, otherwise <b>False</b> chain is used.", | 53 | nodeDetails = "If at least one relation exists - send Message via <b>True</b> chain, otherwise <b>False</b> chain is used.", |
54 | uiResources = {"static/rulenode/rulenode-core-config.js"}, | 54 | uiResources = {"static/rulenode/rulenode-core-config.js"}, |
55 | configDirective = "tbFilterNodeCheckRelationConfig", | 55 | configDirective = "tbFilterNodeCheckRelationConfig", |
56 | - ruleChainTypes = {RuleChainType.SYSTEM, RuleChainType.EDGE} | 56 | + ruleChainTypes = {RuleChainType.CORE, RuleChainType.EDGE} |
57 | ) | 57 | ) |
58 | public class TbCheckRelationNode implements TbNode { | 58 | public class TbCheckRelationNode implements TbNode { |
59 | 59 |
@@ -38,7 +38,7 @@ import static org.thingsboard.common.util.DonAsynchron.withCallback; | @@ -38,7 +38,7 @@ import static org.thingsboard.common.util.DonAsynchron.withCallback; | ||
38 | "Message type can be accessed via <code>msgType</code> property.", | 38 | "Message type can be accessed via <code>msgType</code> property.", |
39 | uiResources = {"static/rulenode/rulenode-core-config.js"}, | 39 | uiResources = {"static/rulenode/rulenode-core-config.js"}, |
40 | configDirective = "tbFilterNodeScriptConfig", | 40 | configDirective = "tbFilterNodeScriptConfig", |
41 | - ruleChainTypes = {RuleChainType.SYSTEM, RuleChainType.EDGE} | 41 | + ruleChainTypes = {RuleChainType.CORE, RuleChainType.EDGE} |
42 | ) | 42 | ) |
43 | 43 | ||
44 | public class TbJsFilterNode implements TbNode { | 44 | public class TbJsFilterNode implements TbNode { |
@@ -41,7 +41,7 @@ import static org.thingsboard.common.util.DonAsynchron.withCallback; | @@ -41,7 +41,7 @@ import static org.thingsboard.common.util.DonAsynchron.withCallback; | ||
41 | "Message type can be accessed via <code>msgType</code> property.", | 41 | "Message type can be accessed via <code>msgType</code> property.", |
42 | uiResources = {"static/rulenode/rulenode-core-config.js"}, | 42 | uiResources = {"static/rulenode/rulenode-core-config.js"}, |
43 | configDirective = "tbFilterNodeSwitchConfig", | 43 | configDirective = "tbFilterNodeSwitchConfig", |
44 | - ruleChainTypes = {RuleChainType.SYSTEM, RuleChainType.EDGE} | 44 | + ruleChainTypes = {RuleChainType.CORE, RuleChainType.EDGE} |
45 | ) | 45 | ) |
46 | public class TbJsSwitchNode implements TbNode { | 46 | public class TbJsSwitchNode implements TbNode { |
47 | 47 |
@@ -35,7 +35,7 @@ import org.thingsboard.server.common.msg.TbMsg; | @@ -35,7 +35,7 @@ import org.thingsboard.server.common.msg.TbMsg; | ||
35 | nodeDetails = "If incoming MessageType is expected - send Message via <b>True</b> chain, otherwise <b>False</b> chain is used.", | 35 | nodeDetails = "If incoming MessageType is expected - send Message via <b>True</b> chain, otherwise <b>False</b> chain is used.", |
36 | uiResources = {"static/rulenode/rulenode-core-config.js", "static/rulenode/rulenode-core-config.css"}, | 36 | uiResources = {"static/rulenode/rulenode-core-config.js", "static/rulenode/rulenode-core-config.css"}, |
37 | configDirective = "tbFilterNodeMessageTypeConfig", | 37 | configDirective = "tbFilterNodeMessageTypeConfig", |
38 | - ruleChainTypes = {RuleChainType.SYSTEM, RuleChainType.EDGE} | 38 | + ruleChainTypes = {RuleChainType.CORE, RuleChainType.EDGE} |
39 | ) | 39 | ) |
40 | public class TbMsgTypeFilterNode implements TbNode { | 40 | public class TbMsgTypeFilterNode implements TbNode { |
41 | 41 |
@@ -36,7 +36,7 @@ import org.thingsboard.server.common.msg.session.SessionMsgType; | @@ -36,7 +36,7 @@ import org.thingsboard.server.common.msg.session.SessionMsgType; | ||
36 | nodeDetails = "Sends messages with message types <b>\"Post attributes\", \"Post telemetry\", \"RPC Request\"</b> etc. via corresponding chain, otherwise <b>Other</b> chain is used.", | 36 | nodeDetails = "Sends messages with message types <b>\"Post attributes\", \"Post telemetry\", \"RPC Request\"</b> etc. via corresponding chain, otherwise <b>Other</b> chain is used.", |
37 | uiResources = {"static/rulenode/rulenode-core-config.js"}, | 37 | uiResources = {"static/rulenode/rulenode-core-config.js"}, |
38 | configDirective = "tbNodeEmptyConfig", | 38 | configDirective = "tbNodeEmptyConfig", |
39 | - ruleChainTypes = {RuleChainType.SYSTEM, RuleChainType.EDGE} | 39 | + ruleChainTypes = {RuleChainType.CORE, RuleChainType.EDGE} |
40 | ) | 40 | ) |
41 | public class TbMsgTypeSwitchNode implements TbNode { | 41 | public class TbMsgTypeSwitchNode implements TbNode { |
42 | 42 |
@@ -33,7 +33,7 @@ import org.thingsboard.server.common.msg.TbMsg; | @@ -33,7 +33,7 @@ import org.thingsboard.server.common.msg.TbMsg; | ||
33 | nodeDetails = "If Originator Type of incoming message is expected - send Message via <b>True</b> chain, otherwise <b>False</b> chain is used.", | 33 | nodeDetails = "If Originator Type of incoming message is expected - send Message via <b>True</b> chain, otherwise <b>False</b> chain is used.", |
34 | uiResources = {"static/rulenode/rulenode-core-config.js", "static/rulenode/rulenode-core-config.css"}, | 34 | uiResources = {"static/rulenode/rulenode-core-config.js", "static/rulenode/rulenode-core-config.css"}, |
35 | configDirective = "tbFilterNodeOriginatorTypeConfig", | 35 | configDirective = "tbFilterNodeOriginatorTypeConfig", |
36 | - ruleChainTypes = {RuleChainType.SYSTEM, RuleChainType.EDGE} | 36 | + ruleChainTypes = {RuleChainType.CORE, RuleChainType.EDGE} |
37 | ) | 37 | ) |
38 | public class TbOriginatorTypeFilterNode implements TbNode { | 38 | public class TbOriginatorTypeFilterNode implements TbNode { |
39 | 39 |
@@ -33,7 +33,7 @@ import org.thingsboard.server.common.msg.TbMsg; | @@ -33,7 +33,7 @@ import org.thingsboard.server.common.msg.TbMsg; | ||
33 | nodeDetails = "Routes messages to chain according to the originator type ('Device', 'Asset', etc.).", | 33 | nodeDetails = "Routes messages to chain according to the originator type ('Device', 'Asset', etc.).", |
34 | uiResources = {"static/rulenode/rulenode-core-config.js"}, | 34 | uiResources = {"static/rulenode/rulenode-core-config.js"}, |
35 | configDirective = "tbNodeEmptyConfig", | 35 | configDirective = "tbNodeEmptyConfig", |
36 | - ruleChainTypes = {RuleChainType.SYSTEM, RuleChainType.EDGE} | 36 | + ruleChainTypes = {RuleChainType.CORE, RuleChainType.EDGE} |
37 | ) | 37 | ) |
38 | public class TbOriginatorTypeSwitchNode implements TbNode { | 38 | public class TbOriginatorTypeSwitchNode implements TbNode { |
39 | 39 |
@@ -51,7 +51,7 @@ import static org.thingsboard.common.util.DonAsynchron.withCallback; | @@ -51,7 +51,7 @@ import static org.thingsboard.common.util.DonAsynchron.withCallback; | ||
51 | uiResources = {"static/rulenode/rulenode-core-config.js"}, | 51 | uiResources = {"static/rulenode/rulenode-core-config.js"}, |
52 | configDirective = "tbActionNodePubSubConfig", | 52 | configDirective = "tbActionNodePubSubConfig", |
53 | iconUrl = "", | 53 | iconUrl = "", |
54 | - ruleChainTypes = {RuleChainType.SYSTEM, RuleChainType.EDGE} | 54 | + ruleChainTypes = {RuleChainType.CORE, RuleChainType.EDGE} |
55 | ) | 55 | ) |
56 | public class TbPubSubNode implements TbNode { | 56 | public class TbPubSubNode implements TbNode { |
57 | 57 |
@@ -53,7 +53,7 @@ import java.util.concurrent.TimeoutException; | @@ -53,7 +53,7 @@ import java.util.concurrent.TimeoutException; | ||
53 | nodeDetails = "Extracts latitude and longitude parameters from incoming message and returns different events based on configuration parameters", | 53 | nodeDetails = "Extracts latitude and longitude parameters from incoming message and returns different events based on configuration parameters", |
54 | uiResources = {"static/rulenode/rulenode-core-config.js"}, | 54 | uiResources = {"static/rulenode/rulenode-core-config.js"}, |
55 | configDirective = "tbActionNodeGpsGeofencingConfig", | 55 | configDirective = "tbActionNodeGpsGeofencingConfig", |
56 | - ruleChainTypes = {RuleChainType.SYSTEM, RuleChainType.EDGE} | 56 | + ruleChainTypes = {RuleChainType.CORE, RuleChainType.EDGE} |
57 | ) | 57 | ) |
58 | public class TbGpsGeofencingActionNode extends AbstractGeofencingNode<TbGpsGeofencingActionNodeConfiguration> { | 58 | public class TbGpsGeofencingActionNode extends AbstractGeofencingNode<TbGpsGeofencingActionNodeConfiguration> { |
59 | 59 |
@@ -54,7 +54,7 @@ import java.util.List; | @@ -54,7 +54,7 @@ import java.util.List; | ||
54 | nodeDetails = "Extracts latitude and longitude parameters from incoming message and returns 'True' if they are inside configured perimeters, 'False' otherwise.", | 54 | nodeDetails = "Extracts latitude and longitude parameters from incoming message and returns 'True' if they are inside configured perimeters, 'False' otherwise.", |
55 | uiResources = {"static/rulenode/rulenode-core-config.js"}, | 55 | uiResources = {"static/rulenode/rulenode-core-config.js"}, |
56 | configDirective = "tbFilterNodeGpsGeofencingConfig", | 56 | configDirective = "tbFilterNodeGpsGeofencingConfig", |
57 | - ruleChainTypes = {RuleChainType.SYSTEM, RuleChainType.EDGE} | 57 | + ruleChainTypes = {RuleChainType.CORE, RuleChainType.EDGE} |
58 | ) | 58 | ) |
59 | public class TbGpsGeofencingFilterNode extends AbstractGeofencingNode<TbGpsGeofencingFilterNodeConfiguration> { | 59 | public class TbGpsGeofencingFilterNode extends AbstractGeofencingNode<TbGpsGeofencingFilterNodeConfiguration> { |
60 | 60 |
@@ -53,7 +53,7 @@ import java.util.Properties; | @@ -53,7 +53,7 @@ import java.util.Properties; | ||
53 | uiResources = {"static/rulenode/rulenode-core-config.js"}, | 53 | uiResources = {"static/rulenode/rulenode-core-config.js"}, |
54 | configDirective = "tbActionNodeKafkaConfig", | 54 | configDirective = "tbActionNodeKafkaConfig", |
55 | iconUrl = "", | 55 | iconUrl = "", |
56 | - ruleChainTypes = {RuleChainType.SYSTEM, RuleChainType.EDGE} | 56 | + ruleChainTypes = {RuleChainType.CORE, RuleChainType.EDGE} |
57 | ) | 57 | ) |
58 | public class TbKafkaNode implements TbNode { | 58 | public class TbKafkaNode implements TbNode { |
59 | 59 |
@@ -42,7 +42,7 @@ import static org.thingsboard.rule.engine.mail.TbSendEmailNode.SEND_EMAIL_TYPE; | @@ -42,7 +42,7 @@ import static org.thingsboard.rule.engine.mail.TbSendEmailNode.SEND_EMAIL_TYPE; | ||
42 | uiResources = {"static/rulenode/rulenode-core-config.js"}, | 42 | uiResources = {"static/rulenode/rulenode-core-config.js"}, |
43 | configDirective = "tbTransformationNodeToEmailConfig", | 43 | configDirective = "tbTransformationNodeToEmailConfig", |
44 | icon = "email", | 44 | icon = "email", |
45 | - ruleChainTypes = {RuleChainType.SYSTEM, RuleChainType.EDGE} | 45 | + ruleChainTypes = {RuleChainType.CORE, RuleChainType.EDGE} |
46 | ) | 46 | ) |
47 | public class TbMsgToEmailNode implements TbNode { | 47 | public class TbMsgToEmailNode implements TbNode { |
48 | 48 |
@@ -48,7 +48,7 @@ import static org.thingsboard.common.util.DonAsynchron.withCallback; | @@ -48,7 +48,7 @@ import static org.thingsboard.common.util.DonAsynchron.withCallback; | ||
48 | uiResources = {"static/rulenode/rulenode-core-config.js"}, | 48 | uiResources = {"static/rulenode/rulenode-core-config.js"}, |
49 | configDirective = "tbActionNodeSendEmailConfig", | 49 | configDirective = "tbActionNodeSendEmailConfig", |
50 | icon = "send", | 50 | icon = "send", |
51 | - ruleChainTypes = {RuleChainType.SYSTEM, RuleChainType.EDGE} | 51 | + ruleChainTypes = {RuleChainType.CORE, RuleChainType.EDGE} |
52 | ) | 52 | ) |
53 | public class TbSendEmailNode implements TbNode { | 53 | public class TbSendEmailNode implements TbNode { |
54 | 54 |
@@ -42,7 +42,7 @@ import org.thingsboard.server.common.msg.TbMsg; | @@ -42,7 +42,7 @@ import org.thingsboard.server.common.msg.TbMsg; | ||
42 | "<code>metadata.cs_temperature</code> or <code>metadata.shared_limit</code> ", | 42 | "<code>metadata.cs_temperature</code> or <code>metadata.shared_limit</code> ", |
43 | uiResources = {"static/rulenode/rulenode-core-config.js"}, | 43 | uiResources = {"static/rulenode/rulenode-core-config.js"}, |
44 | configDirective = "tbEnrichmentNodeOriginatorAttributesConfig", | 44 | configDirective = "tbEnrichmentNodeOriginatorAttributesConfig", |
45 | - ruleChainTypes = {RuleChainType.SYSTEM, RuleChainType.EDGE} | 45 | + ruleChainTypes = {RuleChainType.CORE, RuleChainType.EDGE} |
46 | ) | 46 | ) |
47 | public class TbGetAttributesNode extends TbAbstractGetAttributesNode<TbGetAttributesNodeConfiguration, EntityId> { | 47 | public class TbGetAttributesNode extends TbAbstractGetAttributesNode<TbGetAttributesNodeConfiguration, EntityId> { |
48 | 48 |
@@ -35,7 +35,7 @@ import org.thingsboard.server.common.data.rule.RuleChainType; | @@ -35,7 +35,7 @@ import org.thingsboard.server.common.data.rule.RuleChainType; | ||
35 | "<code>metadata.temperature</code>.", | 35 | "<code>metadata.temperature</code>.", |
36 | uiResources = {"static/rulenode/rulenode-core-config.js", "static/rulenode/rulenode-core-config.css"}, | 36 | uiResources = {"static/rulenode/rulenode-core-config.js", "static/rulenode/rulenode-core-config.css"}, |
37 | configDirective = "tbEnrichmentNodeCustomerAttributesConfig", | 37 | configDirective = "tbEnrichmentNodeCustomerAttributesConfig", |
38 | - ruleChainTypes = {RuleChainType.SYSTEM, RuleChainType.EDGE} | 38 | + ruleChainTypes = {RuleChainType.CORE, RuleChainType.EDGE} |
39 | ) | 39 | ) |
40 | public class TbGetCustomerAttributeNode extends TbEntityGetAttrNode<CustomerId> { | 40 | public class TbGetCustomerAttributeNode extends TbEntityGetAttrNode<CustomerId> { |
41 | 41 |
@@ -44,7 +44,7 @@ import org.thingsboard.server.common.msg.TbMsg; | @@ -44,7 +44,7 @@ import org.thingsboard.server.common.msg.TbMsg; | ||
44 | "If the originator of the message is not assigned to Customer, or originator type is not supported - Message will be forwarded to <b>Failure</b> chain, otherwise, <b>Success</b> chain will be used.", | 44 | "If the originator of the message is not assigned to Customer, or originator type is not supported - Message will be forwarded to <b>Failure</b> chain, otherwise, <b>Success</b> chain will be used.", |
45 | uiResources = {"static/rulenode/rulenode-core-config.js"}, | 45 | uiResources = {"static/rulenode/rulenode-core-config.js"}, |
46 | configDirective = "tbEnrichmentNodeEntityDetailsConfig", | 46 | configDirective = "tbEnrichmentNodeEntityDetailsConfig", |
47 | - ruleChainTypes = {RuleChainType.SYSTEM, RuleChainType.EDGE} | 47 | + ruleChainTypes = {RuleChainType.CORE, RuleChainType.EDGE} |
48 | ) | 48 | ) |
49 | public class TbGetCustomerDetailsNode extends TbAbstractGetEntityDetailsNode<TbGetCustomerDetailsNodeConfiguration> { | 49 | public class TbGetCustomerDetailsNode extends TbAbstractGetEntityDetailsNode<TbGetCustomerDetailsNodeConfiguration> { |
50 | 50 |
@@ -40,7 +40,7 @@ import org.thingsboard.server.common.msg.TbMsg; | @@ -40,7 +40,7 @@ import org.thingsboard.server.common.msg.TbMsg; | ||
40 | "<code>metadata.cs_temperature</code> or <code>metadata.shared_limit</code> ", | 40 | "<code>metadata.cs_temperature</code> or <code>metadata.shared_limit</code> ", |
41 | uiResources = {"static/rulenode/rulenode-core-config.js"}, | 41 | uiResources = {"static/rulenode/rulenode-core-config.js"}, |
42 | configDirective = "tbEnrichmentNodeDeviceAttributesConfig", | 42 | configDirective = "tbEnrichmentNodeDeviceAttributesConfig", |
43 | - ruleChainTypes = {RuleChainType.SYSTEM, RuleChainType.EDGE} | 43 | + ruleChainTypes = {RuleChainType.CORE, RuleChainType.EDGE} |
44 | ) | 44 | ) |
45 | public class TbGetDeviceAttrNode extends TbAbstractGetAttributesNode<TbGetDeviceAttrNodeConfiguration, DeviceId> { | 45 | public class TbGetDeviceAttrNode extends TbAbstractGetAttributesNode<TbGetDeviceAttrNodeConfiguration, DeviceId> { |
46 | 46 |
@@ -45,7 +45,7 @@ import static org.thingsboard.rule.engine.api.TbRelationTypes.SUCCESS; | @@ -45,7 +45,7 @@ import static org.thingsboard.rule.engine.api.TbRelationTypes.SUCCESS; | ||
45 | nodeDetails = "Will fetch fields values specified in mapping. If specified field is not part of originator fields it will be ignored.", | 45 | nodeDetails = "Will fetch fields values specified in mapping. If specified field is not part of originator fields it will be ignored.", |
46 | uiResources = {"static/rulenode/rulenode-core-config.js"}, | 46 | uiResources = {"static/rulenode/rulenode-core-config.js"}, |
47 | configDirective = "tbEnrichmentNodeOriginatorFieldsConfig", | 47 | configDirective = "tbEnrichmentNodeOriginatorFieldsConfig", |
48 | - ruleChainTypes = {RuleChainType.SYSTEM, RuleChainType.EDGE} | 48 | + ruleChainTypes = {RuleChainType.CORE, RuleChainType.EDGE} |
49 | ) | 49 | ) |
50 | public class TbGetOriginatorFieldsNode implements TbNode { | 50 | public class TbGetOriginatorFieldsNode implements TbNode { |
51 | 51 |
@@ -37,7 +37,7 @@ import org.thingsboard.server.common.data.rule.RuleChainType; | @@ -37,7 +37,7 @@ import org.thingsboard.server.common.data.rule.RuleChainType; | ||
37 | "<code>metadata.temperature</code>.", | 37 | "<code>metadata.temperature</code>.", |
38 | uiResources = {"static/rulenode/rulenode-core-config.js", "static/rulenode/rulenode-core-config.css"}, | 38 | uiResources = {"static/rulenode/rulenode-core-config.js", "static/rulenode/rulenode-core-config.css"}, |
39 | configDirective = "tbEnrichmentNodeRelatedAttributesConfig", | 39 | configDirective = "tbEnrichmentNodeRelatedAttributesConfig", |
40 | - ruleChainTypes = {RuleChainType.SYSTEM, RuleChainType.EDGE} | 40 | + ruleChainTypes = {RuleChainType.CORE, RuleChainType.EDGE} |
41 | ) | 41 | ) |
42 | 42 | ||
43 | public class TbGetRelatedAttributeNode extends TbEntityGetAttrNode<EntityId> { | 43 | public class TbGetRelatedAttributeNode extends TbEntityGetAttrNode<EntityId> { |
@@ -68,7 +68,7 @@ import static org.thingsboard.server.common.data.kv.Aggregation.NONE; | @@ -68,7 +68,7 @@ import static org.thingsboard.server.common.data.kv.Aggregation.NONE; | ||
68 | "<b>Note</b>: The maximum size of the fetched array is 1000 records.\n ", | 68 | "<b>Note</b>: The maximum size of the fetched array is 1000 records.\n ", |
69 | uiResources = {"static/rulenode/rulenode-core-config.js"}, | 69 | uiResources = {"static/rulenode/rulenode-core-config.js"}, |
70 | configDirective = "tbEnrichmentNodeGetTelemetryFromDatabase", | 70 | configDirective = "tbEnrichmentNodeGetTelemetryFromDatabase", |
71 | - ruleChainTypes = {RuleChainType.SYSTEM, RuleChainType.EDGE} | 71 | + ruleChainTypes = {RuleChainType.CORE, RuleChainType.EDGE} |
72 | ) | 72 | ) |
73 | public class TbGetTelemetryNode implements TbNode { | 73 | public class TbGetTelemetryNode implements TbNode { |
74 | 74 |
@@ -37,7 +37,7 @@ import org.thingsboard.server.common.data.rule.RuleChainType; | @@ -37,7 +37,7 @@ import org.thingsboard.server.common.data.rule.RuleChainType; | ||
37 | "<code>metadata.temperature</code>.", | 37 | "<code>metadata.temperature</code>.", |
38 | uiResources = {"static/rulenode/rulenode-core-config.js", "static/rulenode/rulenode-core-config.css"}, | 38 | uiResources = {"static/rulenode/rulenode-core-config.js", "static/rulenode/rulenode-core-config.css"}, |
39 | configDirective = "tbEnrichmentNodeTenantAttributesConfig", | 39 | configDirective = "tbEnrichmentNodeTenantAttributesConfig", |
40 | - ruleChainTypes = {RuleChainType.SYSTEM, RuleChainType.EDGE} | 40 | + ruleChainTypes = {RuleChainType.CORE, RuleChainType.EDGE} |
41 | ) | 41 | ) |
42 | public class TbGetTenantAttributeNode extends TbEntityGetAttrNode<TenantId> { | 42 | public class TbGetTenantAttributeNode extends TbEntityGetAttrNode<TenantId> { |
43 | 43 |
@@ -39,7 +39,7 @@ import org.thingsboard.server.common.msg.TbMsg; | @@ -39,7 +39,7 @@ import org.thingsboard.server.common.msg.TbMsg; | ||
39 | "If the originator of the message is not assigned to Tenant, or originator type is not supported - Message will be forwarded to <b>Failure</b> chain, otherwise, <b>Success</b> chain will be used.", | 39 | "If the originator of the message is not assigned to Tenant, or originator type is not supported - Message will be forwarded to <b>Failure</b> chain, otherwise, <b>Success</b> chain will be used.", |
40 | uiResources = {"static/rulenode/rulenode-core-config.js"}, | 40 | uiResources = {"static/rulenode/rulenode-core-config.js"}, |
41 | configDirective = "tbEnrichmentNodeEntityDetailsConfig", | 41 | configDirective = "tbEnrichmentNodeEntityDetailsConfig", |
42 | - ruleChainTypes = {RuleChainType.SYSTEM, RuleChainType.EDGE} | 42 | + ruleChainTypes = {RuleChainType.CORE, RuleChainType.EDGE} |
43 | ) | 43 | ) |
44 | public class TbGetTenantDetailsNode extends TbAbstractGetEntityDetailsNode<TbGetTenantDetailsNodeConfiguration> { | 44 | public class TbGetTenantDetailsNode extends TbAbstractGetEntityDetailsNode<TbGetTenantDetailsNodeConfiguration> { |
45 | 45 |
@@ -51,7 +51,7 @@ import java.util.concurrent.TimeoutException; | @@ -51,7 +51,7 @@ import java.util.concurrent.TimeoutException; | ||
51 | uiResources = {"static/rulenode/rulenode-core-config.js", "static/rulenode/rulenode-core-config.css"}, | 51 | uiResources = {"static/rulenode/rulenode-core-config.js", "static/rulenode/rulenode-core-config.css"}, |
52 | configDirective = "tbActionNodeMqttConfig", | 52 | configDirective = "tbActionNodeMqttConfig", |
53 | icon = "call_split", | 53 | icon = "call_split", |
54 | - ruleChainTypes = {RuleChainType.SYSTEM, RuleChainType.EDGE} | 54 | + ruleChainTypes = {RuleChainType.CORE, RuleChainType.EDGE} |
55 | ) | 55 | ) |
56 | public class TbMqttNode implements TbNode { | 56 | public class TbMqttNode implements TbNode { |
57 | 57 |
@@ -41,7 +41,7 @@ import static org.thingsboard.common.util.DonAsynchron.withCallback; | @@ -41,7 +41,7 @@ import static org.thingsboard.common.util.DonAsynchron.withCallback; | ||
41 | uiResources = {"static/rulenode/rulenode-core-config.js"}, | 41 | uiResources = {"static/rulenode/rulenode-core-config.js"}, |
42 | configDirective = "tbActionNodeRabbitMqConfig", | 42 | configDirective = "tbActionNodeRabbitMqConfig", |
43 | iconUrl = "", | 43 | iconUrl = "", |
44 | - ruleChainTypes = {RuleChainType.SYSTEM, RuleChainType.EDGE} | 44 | + ruleChainTypes = {RuleChainType.CORE, RuleChainType.EDGE} |
45 | ) | 45 | ) |
46 | public class TbRabbitMqNode implements TbNode { | 46 | public class TbRabbitMqNode implements TbNode { |
47 | 47 |
@@ -41,7 +41,7 @@ import org.thingsboard.server.common.msg.TbMsg; | @@ -41,7 +41,7 @@ import org.thingsboard.server.common.msg.TbMsg; | ||
41 | uiResources = {"static/rulenode/rulenode-core-config.js"}, | 41 | uiResources = {"static/rulenode/rulenode-core-config.js"}, |
42 | configDirective = "tbActionNodeRestApiCallConfig", | 42 | configDirective = "tbActionNodeRestApiCallConfig", |
43 | iconUrl = "", | 43 | iconUrl = "", |
44 | - ruleChainTypes = {RuleChainType.SYSTEM, RuleChainType.EDGE} | 44 | + ruleChainTypes = {RuleChainType.CORE, RuleChainType.EDGE} |
45 | ) | 45 | ) |
46 | public class TbRestApiCallNode implements TbNode { | 46 | public class TbRestApiCallNode implements TbNode { |
47 | 47 |
@@ -41,7 +41,7 @@ import java.util.UUID; | @@ -41,7 +41,7 @@ import java.util.UUID; | ||
41 | uiResources = {"static/rulenode/rulenode-core-config.js"}, | 41 | uiResources = {"static/rulenode/rulenode-core-config.js"}, |
42 | configDirective = "tbActionNodeRpcReplyConfig", | 42 | configDirective = "tbActionNodeRpcReplyConfig", |
43 | icon = "call_merge", | 43 | icon = "call_merge", |
44 | - ruleChainTypes = {RuleChainType.SYSTEM, RuleChainType.EDGE} | 44 | + ruleChainTypes = {RuleChainType.CORE, RuleChainType.EDGE} |
45 | ) | 45 | ) |
46 | public class TbSendRPCReplyNode implements TbNode { | 46 | public class TbSendRPCReplyNode implements TbNode { |
47 | 47 |
@@ -52,7 +52,7 @@ import java.util.concurrent.TimeUnit; | @@ -52,7 +52,7 @@ import java.util.concurrent.TimeUnit; | ||
52 | uiResources = {"static/rulenode/rulenode-core-config.js"}, | 52 | uiResources = {"static/rulenode/rulenode-core-config.js"}, |
53 | configDirective = "tbActionNodeRpcRequestConfig", | 53 | configDirective = "tbActionNodeRpcRequestConfig", |
54 | icon = "call_made", | 54 | icon = "call_made", |
55 | - ruleChainTypes = {RuleChainType.SYSTEM, RuleChainType.EDGE} | 55 | + ruleChainTypes = {RuleChainType.CORE, RuleChainType.EDGE} |
56 | ) | 56 | ) |
57 | public class TbSendRPCRequestNode implements TbNode { | 57 | public class TbSendRPCRequestNode implements TbNode { |
58 | 58 |
@@ -46,7 +46,7 @@ import java.util.Set; | @@ -46,7 +46,7 @@ import java.util.Set; | ||
46 | uiResources = {"static/rulenode/rulenode-core-config.js", "static/rulenode/rulenode-core-config.css"}, | 46 | uiResources = {"static/rulenode/rulenode-core-config.js", "static/rulenode/rulenode-core-config.css"}, |
47 | configDirective = "tbActionNodeAttributesConfig", | 47 | configDirective = "tbActionNodeAttributesConfig", |
48 | icon = "file_upload", | 48 | icon = "file_upload", |
49 | - ruleChainTypes = {RuleChainType.SYSTEM, RuleChainType.EDGE} | 49 | + ruleChainTypes = {RuleChainType.CORE, RuleChainType.EDGE} |
50 | ) | 50 | ) |
51 | public class TbMsgAttributesNode implements TbNode { | 51 | public class TbMsgAttributesNode implements TbNode { |
52 | 52 |
@@ -47,7 +47,7 @@ import java.util.Map; | @@ -47,7 +47,7 @@ import java.util.Map; | ||
47 | uiResources = {"static/rulenode/rulenode-core-config.js", "static/rulenode/rulenode-core-config.css"}, | 47 | uiResources = {"static/rulenode/rulenode-core-config.js", "static/rulenode/rulenode-core-config.css"}, |
48 | configDirective = "tbActionNodeTimeseriesConfig", | 48 | configDirective = "tbActionNodeTimeseriesConfig", |
49 | icon = "file_upload", | 49 | icon = "file_upload", |
50 | - ruleChainTypes = {RuleChainType.SYSTEM, RuleChainType.EDGE} | 50 | + ruleChainTypes = {RuleChainType.CORE, RuleChainType.EDGE} |
51 | ) | 51 | ) |
52 | public class TbMsgTimeseriesNode implements TbNode { | 52 | public class TbMsgTimeseriesNode implements TbNode { |
53 | 53 |
@@ -40,7 +40,7 @@ import static org.thingsboard.rule.engine.api.TbRelationTypes.SUCCESS; | @@ -40,7 +40,7 @@ import static org.thingsboard.rule.engine.api.TbRelationTypes.SUCCESS; | ||
40 | "Size of the queue per originator and timeout values are configurable on a system level", | 40 | "Size of the queue per originator and timeout values are configurable on a system level", |
41 | uiResources = {"static/rulenode/rulenode-core-config.js"}, | 41 | uiResources = {"static/rulenode/rulenode-core-config.js"}, |
42 | configDirective = "tbNodeEmptyConfig", | 42 | configDirective = "tbNodeEmptyConfig", |
43 | - ruleChainTypes = {RuleChainType.SYSTEM, RuleChainType.EDGE} | 43 | + ruleChainTypes = {RuleChainType.CORE, RuleChainType.EDGE} |
44 | ) | 44 | ) |
45 | @Deprecated | 45 | @Deprecated |
46 | public class TbSynchronizationBeginNode implements TbNode { | 46 | public class TbSynchronizationBeginNode implements TbNode { |
@@ -40,7 +40,7 @@ import static org.thingsboard.rule.engine.api.TbRelationTypes.SUCCESS; | @@ -40,7 +40,7 @@ import static org.thingsboard.rule.engine.api.TbRelationTypes.SUCCESS; | ||
40 | nodeDetails = "", | 40 | nodeDetails = "", |
41 | uiResources = {"static/rulenode/rulenode-core-config.js"}, | 41 | uiResources = {"static/rulenode/rulenode-core-config.js"}, |
42 | configDirective = ("tbNodeEmptyConfig"), | 42 | configDirective = ("tbNodeEmptyConfig"), |
43 | - ruleChainTypes = {RuleChainType.SYSTEM, RuleChainType.EDGE} | 43 | + ruleChainTypes = {RuleChainType.CORE, RuleChainType.EDGE} |
44 | ) | 44 | ) |
45 | @Deprecated | 45 | @Deprecated |
46 | public class TbSynchronizationEndNode implements TbNode { | 46 | public class TbSynchronizationEndNode implements TbNode { |
@@ -48,7 +48,7 @@ import java.util.HashSet; | @@ -48,7 +48,7 @@ import java.util.HashSet; | ||
48 | uiResources = {"static/rulenode/rulenode-core-config.js", "static/rulenode/rulenode-core-config.css"}, | 48 | uiResources = {"static/rulenode/rulenode-core-config.js", "static/rulenode/rulenode-core-config.css"}, |
49 | configDirective = "tbTransformationNodeChangeOriginatorConfig", | 49 | configDirective = "tbTransformationNodeChangeOriginatorConfig", |
50 | icon = "find_replace", | 50 | icon = "find_replace", |
51 | - ruleChainTypes = {RuleChainType.SYSTEM, RuleChainType.EDGE} | 51 | + ruleChainTypes = {RuleChainType.CORE, RuleChainType.EDGE} |
52 | ) | 52 | ) |
53 | public class TbChangeOriginatorNode extends TbAbstractTransformNode { | 53 | public class TbChangeOriginatorNode extends TbAbstractTransformNode { |
54 | 54 |