panlei
2019-12-16 e583c3d63a64553efb95d46850fc6ee910805bc0
labelFilter/ruleForLabel.go
@@ -3,14 +3,21 @@
import (
   "basic.com/dbapi.git"
   "basic.com/pubsub/protomsg.git"
   "ruleprocess/logger"
   "basic.com/valib/logger.git"
   "github.com/golang/protobuf/proto"
   "github.com/knetic/govaluate"
   "ruleprocess/structure"
   "strconv"
   "time"
)
func Judge(msg structure.ResultMsg) {
func PushSomthing(msg structure.ResultMsg) {
   defer func() {
      if err := recover(); err != nil {
         logger.Error("事件推送模块儿的异常捕获:",err)
      }
   }()
   start := time.Now()
   // 装配成自己可以识别的数据
   label := new(Label)
   label.DataFormatToLabel(msg)
@@ -33,7 +40,7 @@
         timeFlag := timeJudge(label, ruleGroup)
         if !timeFlag {
            logger.Info("不在规则的时间范围内,不推送!")
            return
            continue
         }
         result := ""
         var Connector string
@@ -77,6 +84,7 @@
               logger.Info("通过规则,表达式为:", result)
               // 推送服务器
               pushData(ruleGroup.Urls, msg)
               logger.Info("时间推送所用时间:",time.Since(start))
               //os.Exit(1)
            } else {
               logger.Info("没通过规则,表达式为:", result)
@@ -152,7 +160,7 @@
func baseJudge(label *Label, rule *protomsg.EventPushRule) string {
   if rule.RuleValue == "all" {
      for _, personGroup := range label.Persons {
         for _, arg := range personGroup.Args {
         for _, arg := range personGroup.AlarmObj {
            if len(arg.Liker) > 0 {
               logger.Info("满足全部底库规则")
               return "true"
@@ -162,7 +170,7 @@
      return "false"
   } else {
      for _, personGroup := range label.Persons {
         for _, arg := range personGroup.Args {
         for _, arg := range personGroup.AlarmObj {
            for _, liker := range arg.Liker {
               formula := "'" + liker.TableId + "'" + rule.Operator + "'" + rule.RuleValue + "'"
               expression, err := govaluate.NewEvaluableExpression(formula);
@@ -191,7 +199,7 @@
//是否符合人员规则
func personJudge(label *Label, rule *protomsg.EventPushRule) string {
   for _, personGroup := range label.Persons {
      for _, person := range personGroup.Args {
      for _, person := range personGroup.AlarmObj {
         formula := ""
         if rule.TopicArg == "sex" {
            formula = strconv.Itoa(int(person.ThftRes.Gender)) + rule.Operator + rule.RuleValue
@@ -224,7 +232,7 @@
      }
      if rule.TopicArg == "monitorLevel" {
         if rule.RuleValue == "all" {
            if len(personGroup.Args) > 0 {
            if len(personGroup.AlarmObj) > 0 {
               logger.Info("符合人员等级为全部的规则")
               return "true"
            }
@@ -258,10 +266,10 @@
func defenceJudge(label *Label, rule *protomsg.EventPushRule) string {
   if rule.RuleValue == "all" { // 布防等级为全部时只有有布防等级即为通过
      if len(label.DefenceLevel) > 0 {
         logger.Info("符合布防等级规则,布防等级为全部")
         //logger.Info("符合布防等级规则,布防等级为全部")
         return "true"
      } else {
         logger.Info("不符合布防等级规则")
         //logger.Info("不符合布防等级规则")
         return "false"
      }
   } else {
@@ -279,11 +287,11 @@
            //return "false"
         }
         if result.(bool) {
            logger.Info("符合布防等级规则!")
            //logger.Info("符合布防等级规则!")
            return "true"
         }
      }
      logger.Info("不符合布防等级规则")
      //logger.Info("不符合布防等级规则")
      return "false"
   }
}
@@ -303,19 +311,27 @@
      return "false"
   }
   if result.(bool) {
      logger.Info("符合任务规则!")
      //logger.Info("符合任务规则!")
      return "true"
   }
   logger.Info("不符合任务规则")
   //logger.Info("不符合任务规则")
   return "false"
}
// 调用目标服务器的插入接口
func pushData(urls []*protomsg.PushUrl, data structure.ResultMsg) {
   for _, url := range urls {
      logger.Debug("看看推送地址:",url.Url)
      Push("tcp://192.168.1.123:40012", data)
      //logger.Debug("推送地址:",url.Url)
      bytes,err1 := proto.Marshal(data)
      if err1 != nil {
         logger.Info("序列化失败:",err1)
      }
      if _, ok := urlPool[url.Url] ; ok {
         urlPool[url.Url] <- bytes
      }
   }
}
// 把报警等级转化成汉字