2 * Copyright 2017 ZTE Corporation.
\r
4 * Licensed under the Apache License, Version 2.0 (the "License");
\r
5 * you may not use this file except in compliance with the License.
\r
6 * You may obtain a copy of the License at
\r
8 * http://www.apache.org/licenses/LICENSE-2.0
\r
10 * Unless required by applicable law or agreed to in writing, software
\r
11 * distributed under the License is distributed on an "AS IS" BASIS,
\r
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
\r
13 * See the License for the specific language governing permissions and
\r
14 * limitations under the License.
\r
16 package org.onap.holmes.engine.manager;
\r
19 import java.io.StringReader;
\r
20 import java.util.HashSet;
\r
21 import java.util.List;
\r
22 import java.util.Locale;
\r
23 import java.util.Set;
\r
24 import javax.annotation.PostConstruct;
\r
25 import javax.inject.Inject;
\r
26 import lombok.extern.slf4j.Slf4j;
\r
27 import org.drools.KnowledgeBase;
\r
28 import org.drools.KnowledgeBaseConfiguration;
\r
29 import org.drools.KnowledgeBaseFactory;
\r
30 import org.drools.builder.KnowledgeBuilder;
\r
31 import org.drools.builder.KnowledgeBuilderFactory;
\r
32 import org.drools.builder.ResourceType;
\r
33 import org.drools.conf.EventProcessingOption;
\r
34 import org.drools.definition.KnowledgePackage;
\r
35 import org.drools.io.Resource;
\r
36 import org.drools.io.ResourceFactory;
\r
37 import org.drools.runtime.StatefulKnowledgeSession;
\r
38 import org.drools.runtime.rule.FactHandle;
\r
39 import org.jvnet.hk2.annotations.Service;
\r
40 import org.onap.holmes.common.api.stat.VesAlarm;
\r
41 import org.onap.holmes.common.dmaap.DmaapService;
\r
42 import org.onap.holmes.engine.request.DeployRuleRequest;
\r
43 import org.onap.holmes.common.api.entity.CorrelationRule;
\r
44 import org.onap.holmes.common.exception.CorrelationException;
\r
45 import org.onap.holmes.common.utils.ExceptionUtil;
\r
46 import org.onap.holmes.engine.wrapper.RuleMgtWrapper;
\r
50 public class DroolsEngine {
\r
52 private final static int ENABLE = 1;
\r
53 private final Set<String> packageNames = new HashSet<String>();
\r
55 private RuleMgtWrapper ruleMgtWrapper;
\r
56 private KnowledgeBase kbase;
\r
57 private KnowledgeBaseConfiguration kconf;
\r
58 private StatefulKnowledgeSession ksession;
\r
61 private void init() {
\r
65 } catch (Exception e) {
\r
66 log.error("Failed to start the service: " + e.getMessage(), e);
\r
67 throw ExceptionUtil.buildExceptionResponse("Failed to start the drools engine!");
\r
71 private void start() throws CorrelationException {
\r
72 log.info("Drools Engine Initialize Beginning...");
\r
74 initEngineParameter();
\r
77 log.info("Business Rule Engine Initialize Successfully.");
\r
80 public void stop() {
\r
81 this.ksession.dispose();
\r
84 private void initEngineParameter() {
\r
85 this.kconf = KnowledgeBaseFactory.newKnowledgeBaseConfiguration();
\r
87 this.kconf.setOption(EventProcessingOption.STREAM);
\r
89 this.kconf.setProperty("drools.assertBehaviour", "equality");
\r
91 this.kbase = KnowledgeBaseFactory.newKnowledgeBase("D-ENGINE", this.kconf);
\r
93 this.ksession = kbase.newStatefulKnowledgeSession();
\r
96 private void initDeployRule() throws CorrelationException {
\r
97 List<CorrelationRule> rules = ruleMgtWrapper.queryRuleByEnable(ENABLE);
\r
99 if (rules.isEmpty()) {
\r
102 for (CorrelationRule rule : rules) {
\r
103 if (rule.getContent() != null) {
\r
104 deployRuleFromDB(rule.getContent());
\r
105 DmaapService.loopControlNames.put(rule.getPackageName(), rule.getClosedControlLoopName());
\r
110 private void deployRuleFromDB(String ruleContent) throws CorrelationException {
\r
111 StringReader reader = new StringReader(ruleContent);
\r
112 Resource res = ResourceFactory.newReaderResource(reader);
\r
114 KnowledgeBuilder kbuilder = KnowledgeBuilderFactory.newKnowledgeBuilder();
\r
116 kbuilder.add(res, ResourceType.DRL);
\r
120 kbase.addKnowledgePackages(kbuilder.getKnowledgePackages());
\r
121 } catch (Exception e) {
\r
122 throw new CorrelationException(e.getMessage(), e);
\r
124 ksession.fireAllRules();
\r
127 public synchronized String deployRule(DeployRuleRequest rule, Locale locale)
\r
128 throws CorrelationException {
\r
129 StringReader reader = new StringReader(rule.getContent());
\r
130 Resource res = ResourceFactory.newReaderResource(reader);
\r
132 KnowledgeBuilder kbuilder = KnowledgeBuilderFactory.newKnowledgeBuilder();
\r
134 kbuilder.add(res, ResourceType.DRL);
\r
136 judgeRuleContent(locale, kbuilder, true);
\r
138 String packageName = kbuilder.getKnowledgePackages().iterator().next().getName();
\r
140 packageNames.add(packageName);
\r
141 kbase.addKnowledgePackages(kbuilder.getKnowledgePackages());
\r
142 } catch (Exception e) {
\r
143 throw new CorrelationException("Failed to deploy the rule.", e);
\r
146 ksession.fireAllRules();
\r
147 return packageName;
\r
150 public synchronized void undeployRule(String packageName, Locale locale)
\r
151 throws CorrelationException {
\r
153 KnowledgePackage pkg = kbase.getKnowledgePackage(packageName);
\r
156 throw new CorrelationException("The rule " + packageName + " does not exist!");
\r
160 kbase.removeKnowledgePackage(pkg.getName());
\r
161 } catch (Exception e) {
\r
162 throw new CorrelationException("Failed to delete the rule: " + packageName, e);
\r
164 packageNames.remove(pkg.getName());
\r
167 public void compileRule(String content, Locale locale)
\r
168 throws CorrelationException {
\r
169 StringReader reader = new StringReader(content);
\r
170 Resource res = ResourceFactory.newReaderResource(reader);
\r
172 KnowledgeBuilder kbuilder = KnowledgeBuilderFactory.newKnowledgeBuilder();
\r
174 kbuilder.add(res, ResourceType.DRL);
\r
176 judgeRuleContent(locale, kbuilder, false);
\r
179 private void judgeRuleContent(Locale locale, KnowledgeBuilder kbuilder, boolean judgePackageName)
\r
180 throws CorrelationException {
\r
181 if (kbuilder.hasErrors()) {
\r
182 String errorMsg = "There are errors in the rule: " + kbuilder.getErrors().toString();
\r
183 log.error(errorMsg);
\r
184 throw new CorrelationException(errorMsg);
\r
187 String packageName = kbuilder.getKnowledgePackages().iterator().next().getName();
\r
189 if (packageNames.contains(packageName) && judgePackageName) {
\r
190 throw new CorrelationException("The rule " + packageName + " already exists in the drools engine.");
\r
194 public void putRaisedIntoStream(VesAlarm raiseAlarm) {
\r
195 FactHandle factHandle = this.ksession.getFactHandle(raiseAlarm);
\r
196 if (factHandle != null) {
\r
197 Object obj = this.ksession.getObject(factHandle);
\r
198 if (obj != null && obj instanceof VesAlarm) {
\r
199 raiseAlarm.setRootFlag(((VesAlarm) obj).getRootFlag());
\r
201 this.ksession.retract(factHandle);
\r
203 this.ksession.insert(raiseAlarm);
\r
204 this.ksession.fireAllRules();
\r