Clean up shared package

This commit is contained in:
ytalashko 2016-12-08 00:53:01 +02:00
parent 75d1ad3f71
commit 9b18b2a863
6 changed files with 24 additions and 37 deletions

View File

@ -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() {

View File

@ -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;

View File

@ -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) {

View File

@ -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

View File

@ -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() {

View File

@ -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;
} }
} }