Clean up shared package
This commit is contained in:
parent
75d1ad3f71
commit
9b18b2a863
@ -16,7 +16,6 @@
|
|||||||
package org.thingsboard.server.actors.rule;
|
package org.thingsboard.server.actors.rule;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Collections;
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
|
|
||||||
@ -26,7 +25,7 @@ public class SimpleRuleActorChain implements RuleActorChain {
|
|||||||
|
|
||||||
public SimpleRuleActorChain(Set<RuleActorMetaData> ruleSet) {
|
public SimpleRuleActorChain(Set<RuleActorMetaData> ruleSet) {
|
||||||
rules = new ArrayList<>(ruleSet);
|
rules = new ArrayList<>(ruleSet);
|
||||||
Collections.sort(rules, RuleActorMetaData.RULE_ACTOR_MD_COMPARATOR);
|
rules.sort(RuleActorMetaData.RULE_ACTOR_MD_COMPARATOR);
|
||||||
}
|
}
|
||||||
|
|
||||||
public int size() {
|
public int size() {
|
||||||
|
|||||||
@ -19,7 +19,6 @@ import akka.actor.ActorContext;
|
|||||||
import akka.actor.ActorRef;
|
import akka.actor.ActorRef;
|
||||||
import akka.actor.Scheduler;
|
import akka.actor.Scheduler;
|
||||||
import akka.event.LoggingAdapter;
|
import akka.event.LoggingAdapter;
|
||||||
import com.fasterxml.jackson.core.JsonProcessingException;
|
|
||||||
import com.fasterxml.jackson.databind.JsonNode;
|
import com.fasterxml.jackson.databind.JsonNode;
|
||||||
import com.fasterxml.jackson.databind.ObjectMapper;
|
import com.fasterxml.jackson.databind.ObjectMapper;
|
||||||
import lombok.AllArgsConstructor;
|
import lombok.AllArgsConstructor;
|
||||||
|
|||||||
@ -15,9 +15,9 @@
|
|||||||
*/
|
*/
|
||||||
package org.thingsboard.server.actors.shared.plugin;
|
package org.thingsboard.server.actors.shared.plugin;
|
||||||
|
|
||||||
import java.util.HashMap;
|
import akka.actor.ActorContext;
|
||||||
import java.util.Map;
|
import akka.actor.ActorRef;
|
||||||
|
import akka.actor.Props;
|
||||||
import lombok.extern.slf4j.Slf4j;
|
import lombok.extern.slf4j.Slf4j;
|
||||||
import org.thingsboard.server.actors.ActorSystemContext;
|
import org.thingsboard.server.actors.ActorSystemContext;
|
||||||
import org.thingsboard.server.actors.plugin.PluginActor;
|
import org.thingsboard.server.actors.plugin.PluginActor;
|
||||||
@ -29,12 +29,9 @@ import org.thingsboard.server.common.data.page.PageDataIterable;
|
|||||||
import org.thingsboard.server.common.data.page.PageDataIterable.FetchFunction;
|
import org.thingsboard.server.common.data.page.PageDataIterable.FetchFunction;
|
||||||
import org.thingsboard.server.common.data.plugin.PluginMetaData;
|
import org.thingsboard.server.common.data.plugin.PluginMetaData;
|
||||||
import org.thingsboard.server.dao.plugin.PluginService;
|
import org.thingsboard.server.dao.plugin.PluginService;
|
||||||
import org.slf4j.Logger;
|
|
||||||
import org.slf4j.LoggerFactory;
|
|
||||||
|
|
||||||
import akka.actor.ActorContext;
|
import java.util.HashMap;
|
||||||
import akka.actor.ActorRef;
|
import java.util.Map;
|
||||||
import akka.actor.Props;
|
|
||||||
|
|
||||||
@Slf4j
|
@Slf4j
|
||||||
public abstract class PluginManager {
|
public abstract class PluginManager {
|
||||||
@ -64,13 +61,9 @@ public abstract class PluginManager {
|
|||||||
abstract TenantId getTenantId();
|
abstract TenantId getTenantId();
|
||||||
|
|
||||||
public ActorRef getOrCreatePluginActor(ActorContext context, PluginId pluginId) {
|
public ActorRef getOrCreatePluginActor(ActorContext context, PluginId pluginId) {
|
||||||
ActorRef pluginActor = pluginActors.get(pluginId);
|
return pluginActors.computeIfAbsent(pluginId, pId ->
|
||||||
if (pluginActor == null) {
|
context.actorOf(Props.create(new PluginActor.ActorCreator(systemContext, getTenantId(), pId))
|
||||||
pluginActor = context.actorOf(Props.create(new PluginActor.ActorCreator(systemContext, getTenantId(), pluginId))
|
.withDispatcher(DefaultActorService.PLUGIN_DISPATCHER_NAME), pId.toString()));
|
||||||
.withDispatcher(DefaultActorService.PLUGIN_DISPATCHER_NAME), pluginId.toString());
|
|
||||||
pluginActors.put(pluginId, pluginActor);
|
|
||||||
}
|
|
||||||
return pluginActor;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public void broadcast(Object msg) {
|
public void broadcast(Object msg) {
|
||||||
|
|||||||
@ -20,7 +20,6 @@ import org.thingsboard.server.common.data.id.TenantId;
|
|||||||
import org.thingsboard.server.common.data.page.PageDataIterable.FetchFunction;
|
import org.thingsboard.server.common.data.page.PageDataIterable.FetchFunction;
|
||||||
import org.thingsboard.server.common.data.plugin.PluginMetaData;
|
import org.thingsboard.server.common.data.plugin.PluginMetaData;
|
||||||
import org.thingsboard.server.dao.plugin.BasePluginService;
|
import org.thingsboard.server.dao.plugin.BasePluginService;
|
||||||
import org.thingsboard.server.dao.plugin.PluginService;
|
|
||||||
|
|
||||||
public class SystemPluginManager extends PluginManager {
|
public class SystemPluginManager extends PluginManager {
|
||||||
|
|
||||||
@ -30,7 +29,7 @@ public class SystemPluginManager extends PluginManager {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
FetchFunction<PluginMetaData> getFetchPluginsFunction() {
|
FetchFunction<PluginMetaData> getFetchPluginsFunction() {
|
||||||
return link -> pluginService.findSystemPlugins(link);
|
return pluginService::findSystemPlugins;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|||||||
@ -18,8 +18,7 @@ package org.thingsboard.server.actors.shared.rule;
|
|||||||
import akka.actor.ActorContext;
|
import akka.actor.ActorContext;
|
||||||
import akka.actor.ActorRef;
|
import akka.actor.ActorRef;
|
||||||
import akka.actor.Props;
|
import akka.actor.Props;
|
||||||
import org.slf4j.Logger;
|
import lombok.extern.slf4j.Slf4j;
|
||||||
import org.slf4j.LoggerFactory;
|
|
||||||
import org.thingsboard.server.actors.ActorSystemContext;
|
import org.thingsboard.server.actors.ActorSystemContext;
|
||||||
import org.thingsboard.server.actors.rule.RuleActor;
|
import org.thingsboard.server.actors.rule.RuleActor;
|
||||||
import org.thingsboard.server.actors.rule.RuleActorChain;
|
import org.thingsboard.server.actors.rule.RuleActorChain;
|
||||||
@ -38,10 +37,9 @@ import org.thingsboard.server.dao.rule.RuleService;
|
|||||||
|
|
||||||
import java.util.*;
|
import java.util.*;
|
||||||
|
|
||||||
|
@Slf4j
|
||||||
public abstract class RuleManager {
|
public abstract class RuleManager {
|
||||||
|
|
||||||
protected static final Logger logger = LoggerFactory.getLogger(RuleManager.class);
|
|
||||||
|
|
||||||
protected final ActorSystemContext systemContext;
|
protected final ActorSystemContext systemContext;
|
||||||
protected final RuleService ruleService;
|
protected final RuleService ruleService;
|
||||||
protected final Map<RuleId, ActorRef> ruleActors;
|
protected final Map<RuleId, ActorRef> ruleActors;
|
||||||
@ -63,11 +61,11 @@ public abstract class RuleManager {
|
|||||||
ruleMap = new HashMap<>();
|
ruleMap = new HashMap<>();
|
||||||
|
|
||||||
for (RuleMetaData rule : ruleIterator) {
|
for (RuleMetaData rule : ruleIterator) {
|
||||||
logger.debug("[{}] Creating rule actor {}", rule.getId(), rule);
|
log.debug("[{}] Creating rule actor {}", rule.getId(), rule);
|
||||||
ActorRef ref = getOrCreateRuleActor(context, rule.getId());
|
ActorRef ref = getOrCreateRuleActor(context, rule.getId());
|
||||||
RuleActorMetaData actorMd = RuleActorMetaData.systemRule(rule.getId(), rule.getWeight(), ref);
|
RuleActorMetaData actorMd = RuleActorMetaData.systemRule(rule.getId(), rule.getWeight(), ref);
|
||||||
ruleMap.put(rule, actorMd);
|
ruleMap.put(rule, actorMd);
|
||||||
logger.debug("[{}] Rule actor created.", rule.getId());
|
log.debug("[{}] Rule actor created.", rule.getId());
|
||||||
}
|
}
|
||||||
|
|
||||||
refreshRuleChain();
|
refreshRuleChain();
|
||||||
@ -79,8 +77,11 @@ public abstract class RuleManager {
|
|||||||
rule = systemContext.getRuleService().findRuleById(ruleId);
|
rule = systemContext.getRuleService().findRuleById(ruleId);
|
||||||
}
|
}
|
||||||
if (rule == null) {
|
if (rule == null) {
|
||||||
rule = ruleMap.keySet().stream().filter(r -> r.getId().equals(ruleId)).findFirst().orElse(null);
|
rule = ruleMap.keySet().stream()
|
||||||
rule.setState(ComponentLifecycleState.SUSPENDED);
|
.filter(r -> r.getId().equals(ruleId))
|
||||||
|
.peek(r -> r.setState(ComponentLifecycleState.SUSPENDED))
|
||||||
|
.findFirst()
|
||||||
|
.orElse(null);
|
||||||
}
|
}
|
||||||
if (rule != null) {
|
if (rule != null) {
|
||||||
RuleActorMetaData actorMd = ruleMap.get(rule);
|
RuleActorMetaData actorMd = ruleMap.get(rule);
|
||||||
@ -92,7 +93,7 @@ public abstract class RuleManager {
|
|||||||
refreshRuleChain();
|
refreshRuleChain();
|
||||||
return Optional.of(actorMd.getActorRef());
|
return Optional.of(actorMd.getActorRef());
|
||||||
} else {
|
} else {
|
||||||
logger.warn("[{}] Can't process unknown rule!", rule.getId());
|
log.warn("[{}] Can't process unknown rule!", ruleId);
|
||||||
return Optional.empty();
|
return Optional.empty();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -100,13 +101,9 @@ public abstract class RuleManager {
|
|||||||
abstract FetchFunction<RuleMetaData> getFetchRulesFunction();
|
abstract FetchFunction<RuleMetaData> getFetchRulesFunction();
|
||||||
|
|
||||||
public ActorRef getOrCreateRuleActor(ActorContext context, RuleId ruleId) {
|
public ActorRef getOrCreateRuleActor(ActorContext context, RuleId ruleId) {
|
||||||
ActorRef ruleActor = ruleActors.get(ruleId);
|
return ruleActors.computeIfAbsent(ruleId, rId ->
|
||||||
if (ruleActor == null) {
|
context.actorOf(Props.create(new RuleActor.ActorCreator(systemContext, tenantId, rId))
|
||||||
ruleActor = context.actorOf(Props.create(new RuleActor.ActorCreator(systemContext, tenantId, ruleId))
|
.withDispatcher(DefaultActorService.RULE_DISPATCHER_NAME), rId.toString()));
|
||||||
.withDispatcher(DefaultActorService.RULE_DISPATCHER_NAME), ruleId.toString());
|
|
||||||
ruleActors.put(ruleId, ruleActor);
|
|
||||||
}
|
|
||||||
return ruleActor;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public RuleActorChain getRuleChain() {
|
public RuleActorChain getRuleChain() {
|
||||||
|
|||||||
@ -29,7 +29,7 @@ public class SystemRuleManager extends RuleManager {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
FetchFunction<RuleMetaData> getFetchRulesFunction() {
|
FetchFunction<RuleMetaData> getFetchRulesFunction() {
|
||||||
return link -> ruleService.findSystemRules(link);
|
return ruleService::findSystemRules;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user