panlei
2019-11-01 e6982607fbbeaa96d3d14409df780266646b793d
labelFilter/ruleForLabel.go
@@ -3,35 +3,44 @@
import (
   "basic.com/dbapi.git"
   "basic.com/pubsub/protomsg.git"
   "basic.com/valib/logger.git"
   "github.com/knetic/govaluate"
   "os"
   "ruleprocess/logger"
   "ruleprocess/ruleserver"
   "ruleprocess/structure"
   "strconv"
   "time"
)
func Judge(result ruleserver.ResultMsg){
func PushSomthing(msg structure.ResultMsg) {
   defer func() {
      if err := recover(); err != nil {
         logger.Error("事件推送模块儿的异常捕获:",err)
      }
   }()
   // 装配成自己可以识别的数据
   label := new(Label)
   label.DataFormatToLabel(result)
   logger.Info("label的信息:",label.CameraName,label.DefenceLevel,label.Time)
   label.DataFormatToLabel(msg)
   logger.Info("label的信息:", label.CameraName, label.DefenceLevel, label.Time)
   if label.CameraName == "" {
      logger.Error("无效数据,直接返回")
      return
   }
   //拿到所有规则组
   var api dbapi.EventPushApi
   b,allRules := api.FindAllDetails()
   logger.Info("查看所有规则组:",allRules)
   b, allRules := api.FindAllDetails()
   logger.Info("查看所有规则组:", allRules)
   if !b {
      logger.Error("查询时间推送规则失败!")
   }
   //遍历所有的规则组,看看符合哪个规则组,就把数据插入到哪个规则组的目标机器上
   for _,ruleGroup := range allRules {
      if ruleGroup.Enable {  // 大规则开关开启状态
   for _, ruleGroup := range allRules {
      if ruleGroup.Enable { // 大规则开关开启状态
         // 先过时间规则
         timeJudge(label,ruleGroup)
         timeFlag := timeJudge(label, ruleGroup)
         if !timeFlag {
            logger.Info("不在规则的时间范围内,不推送!")
            continue
         }
         result := ""
         var Connector string
         if ruleGroup.IsSatisfyAll {
@@ -39,44 +48,45 @@
         } else {
            Connector = "||"
         }
         for _,rule := range ruleGroup.Rules {
         for _, rule := range ruleGroup.Rules {
            // 过每一个小规则
            if rule.TopicType == "camera" {
               result = Connector + cameraJudge(label,rule)
               result += Connector + cameraJudge(label, rule)
            }
            if rule.TopicType == "baseLibrary" {
               result = Connector + baseJudge(label,rule)
            if rule.TopicType == "dbtable" {
               result += Connector + baseJudge(label, rule)
            }
            if rule.TopicType == "task" {
               result = Connector + taskJudge(label,rule)
               result += Connector + taskJudge(label, rule)
            }
            if rule.TopicType == "person" {
               result = Connector + taskJudge(label,rule)
               result += Connector + taskJudge(label, rule)
            }
            if rule.TopicType == "defence" {
               result = Connector + defenceJudge(label,rule)
            if rule.TopicType == "alarmLevel" {
               result += Connector + defenceJudge(label, rule)
            }
         }
         // 得出总的判断结果
         if result != "" {
            logger.Info("总的判断结果:",result)
            logger.Info("总的判断结果:", result)
            result = result[2:] // 把前两位字符去掉
            expression, err:= govaluate.NewEvaluableExpression(result);
            expression, err := govaluate.NewEvaluableExpression(result);
            if err != nil {
               logger.Error("表达式有误,请检查!")
               return
            }
            result, err1:= expression.Evaluate(nil)
            result, err1 := expression.Evaluate(nil)
            if err1 != nil {
               logger.Error("带入参数有误")
            }
            if result.(bool) {
               logger.Info("通过规则,表达式为:",result)
               logger.Info("通过规则,表达式为:", result)
               // 推送服务器
               pushData(ruleGroup.Urls,result.(ruleserver.ResultMsg))
               os.Exit(1)
               pushData(ruleGroup.Urls, msg)
               //os.Exit(1)
            } else {
               logger.Info("没通过规则,表达式为:",result)
               os.Exit(1)
               logger.Info("没通过规则,表达式为:", result)
               //os.Exit(1)
            }
         }
      }
@@ -84,28 +94,32 @@
   //符合本规则组的就把数据推送到该目的服务器上
}
// 是否符合时间规则
func timeJudge(label *Label,groupRule protomsg.EventPush) string{
func timeJudge(label *Label, groupRule protomsg.EventPush) bool {
   timeNow := time.Now().Format("2006-01-02 15:04:05")
   flag1 := isBefore(groupRule.TimeStart,timeNow)
   flag2 := isBefore(timeNow,groupRule.TimeEnd)
   logger.Info("标签过滤器起始时间为:",groupRule.TimeStart,groupRule.TimeEnd)
   flag1 := isBefore(groupRule.TimeStart, timeNow)
   flag2 := isBefore(timeNow, groupRule.TimeEnd)
   if flag1 && flag2 {
      return "true"
      return true
   } else {
      logger.Info("不在规定的时间范围内!")
      return "false"
      return false
   }
}
// 传入两个时间的字符串,判断第一个时间是否小于第二个时间
func isBefore(time1 string,time2 string) bool{
   expression, err:= govaluate.NewEvaluableExpression("t1 < t2");
func isBefore(time1 string, time2 string) bool {
   expression, err := govaluate.NewEvaluableExpression("t1 < t2");
   if err != nil {
      logger.Error("表达式有误,请检查!")
      return false
   }
   parameters := make(map[string]interface{},8)
   parameters := make(map[string]interface{}, 8)
   parameters["t1"] = time1
   parameters["t2"] = time2
   result, err1:= expression.Evaluate(parameters)
   result, err1 := expression.Evaluate(parameters)
   if err1 != nil {
      logger.Error("带入参数有误")
   }
@@ -113,66 +127,131 @@
}
// 是否符合摄像机规则
func cameraJudge(label *Label,rule *protomsg.EventPushRule) string{
   if rule.TopicArg == "cameraName" {
      if label.CameraName == rule.RuleValue {
         logger.Info("符合摄像机名称规则")
         return "true"
      } else {
         logger.Info("不符合摄像机名称规则")
         return "false"
      }
func cameraJudge(label *Label, rule *protomsg.EventPushRule) string {
   formula := ""
   if rule.TopicArg == "name" {
      formula = "'" + label.CameraName + "'" + rule.Operator + "'" + rule.RuleValue + "'"
   }
   if rule.TopicArg == "cameraLocation" {
      if label.CameraAddr == rule.RuleValue {
         logger.Info("符合摄像机位置规则")
         return "true"
      } else {
         logger.Info("不符合摄像机位置规则")
         return "false"
      }
   if rule.TopicArg == "addr" {
      formula = "'" + label.CameraAddr + "'" + rule.Operator + "'" + rule.RuleValue + "'"
   }
   return ""
   logger.Info("-------打印摄像机规则公式:",formula)
   expression, err := govaluate.NewEvaluableExpression(formula);
   if err != nil {
      logger.Error("表达式有误,请检查!", formula)
      return "false"
   }
   result, err1 := expression.Evaluate(nil)
   if err1 != nil {
      logger.Error("带入参数有误")
      return "false"
   }
   if result.(bool) {
      logger.Info("符合摄像机规则!")
      return "true"
   }
   logger.Info("不符合摄像机规则!")
   return "false"
}
// 是否符合底库规则
func baseJudge(label *Label,rule *protomsg.EventPushRule) string{
   flag := "false"
   for _,personGroup := range label.Persons  {
      for _,arg := range personGroup.Args {
         for _,liker := range arg.Liker{
            if liker.TableId == rule.RuleValue {
               logger.Info("符合底库规则!")
               flag = "true"
func baseJudge(label *Label, rule *protomsg.EventPushRule) string {
   if rule.RuleValue == "all" {
      for _, personGroup := range label.Persons {
         for _, arg := range personGroup.Args {
            if len(arg.Liker) > 0 {
               logger.Info("满足全部底库规则")
               return "true"
            }
         }
      }
      return "false"
   } else {
      for _, personGroup := range label.Persons {
         for _, arg := range personGroup.Args {
            for _, liker := range arg.Liker {
               formula := "'" + liker.TableId + "'" + rule.Operator + "'" + rule.RuleValue + "'"
               expression, err := govaluate.NewEvaluableExpression(formula);
               logger.Info("-------打印底库规则公式:",formula)
               if err != nil {
                  logger.Error("表达式有误,请检查!", formula)
                  return "false"
               }
               result, err1 := expression.Evaluate(nil)
               if err1 != nil {
                  logger.Error("带入参数有误")
                  //return "false"
               }
               if result.(bool) {
                  logger.Info("符合底库规则!")
                  return "true"
               }
            }
         }
      }
      logger.Info("不符合底库规则!")
      return "false"
   }
   return flag
}
//是否符合人员规则
func personJudge(label *Label,rule *protomsg.EventPushRule) string{
   for _,personGroup := range label.Persons  {
      for _,person := range personGroup.Args {
         if rule.TopicArg == "sex" && strconv.Itoa(int(person.ThftRes.Gender)) == rule.RuleValue{
            logger.Info("符合人员性别规则!")
            return  "true"
func personJudge(label *Label, rule *protomsg.EventPushRule) string {
   for _, personGroup := range label.Persons {
      for _, person := range personGroup.Args {
         formula := ""
         if rule.TopicArg == "sex" {
            formula = strconv.Itoa(int(person.ThftRes.Gender)) + rule.Operator + rule.RuleValue
         }
         if rule.TopicArg == "race" && strconv.Itoa(int(person.ThftRes.Race)) == rule.RuleValue {
            logger.Info("符合人员种族规则!")
            return "true"
         if rule.TopicArg == "race" {
            formula = strconv.Itoa(int(person.ThftRes.Race)) + rule.Operator + rule.RuleValue
         }
         if rule.TopicArg == "age" && strconv.Itoa(int(person.ThftRes.Age)) == rule.RuleValue {
            logger.Info("符合人员年龄规则!")
            return "true"
         if rule.TopicArg == "age" {
            formula = strconv.Itoa(int(person.ThftRes.Age)) + rule.Operator + rule.RuleValue
         }
         if rule.TopicArg == "others" {
         if rule.TopicArg == "otherInfo" {
            // 其他这个值先这么处理
            return "true"
         }
         logger.Info("-------打印人员规则公式:",formula)
         expression, err := govaluate.NewEvaluableExpression(formula);
         if err != nil {
            logger.Error("表达式有误,请检查!", formula)
            return "false"
         }
         result, err1 := expression.Evaluate(nil)
         if err1 != nil {
            logger.Error("带入参数有误")
            //return "false"
         }
         if result.(bool) {
            logger.Info("符合人员规则!", formula)
            return "true"
         }
      }
      if strconv.Itoa(int(personGroup.AlarmLevel)) == rule.RuleValue {
      if rule.TopicArg == "monitorLevel" {
         if rule.RuleValue == "all" {
            if len(personGroup.Args) > 0 {
               logger.Info("符合人员等级为全部的规则")
               return "true"
            }
         } else {
            formula := strconv.Itoa(int(personGroup.AlarmLevel)) + rule.Operator + formate(rule.RuleValue)
            logger.Info("-------打印人员等级规则公式:",formula)
            expression, err := govaluate.NewEvaluableExpression(formula);
            if err != nil {
               logger.Error("表达式有误,请检查!", formula)
               return "false"
            }
            result, err1 := expression.Evaluate(nil)
            if err1 != nil {
               logger.Error("带入参数有误")
               //return "false"
            }
            if result.(bool) {
               logger.Info("符合人员等级规则!")
               return "true"
            }
         }
         logger.Info("符合人员报警等级规则!")
         return "true"
      }
@@ -182,28 +261,87 @@
}
// 是否符合布防等级规则
func defenceJudge(label *Label,rule *protomsg.EventPushRule) string{
   for _,def := range label.DefenceLevel {
      if strconv.Itoa(int(def)) == rule.RuleValue {
         logger.Info("符合布防等级规则!")
func defenceJudge(label *Label, rule *protomsg.EventPushRule) string {
   if rule.RuleValue == "all" { // 布防等级为全部时只有有布防等级即为通过
      if len(label.DefenceLevel) > 0 {
         logger.Info("符合布防等级规则,布防等级为全部")
         return "true"
      } else {
         logger.Info("不符合布防等级规则")
         return "false"
      }
   } else {
      for _, def := range label.DefenceLevel {
         formula := strconv.Itoa(int(def)) + rule.Operator + rule.RuleValue
         logger.Info("-------打印布防等级规则公式:",formula)
         expression, err := govaluate.NewEvaluableExpression(formula);
         if err != nil {
            logger.Error("表达式有误,请检查!", formula)
            return "false"
         }
         result, err1 := expression.Evaluate(nil)
         if err1 != nil {
            logger.Error("带入参数有误")
            //return "false"
         }
         if result.(bool) {
            logger.Info("符合布防等级规则!")
            return "true"
         }
      }
      logger.Info("不符合布防等级规则")
      return "false"
   }
   logger.Info("不符合布防等级规则")
   return "false"
}
// 是否符合任务规则
func taskJudge(label *Label,rule *protomsg.EventPushRule) string{
   if label.TaskId == rule.RuleValue {
func taskJudge(label *Label, rule *protomsg.EventPushRule) string {
   formula := "'"+label.TaskId +"'"+ rule.Operator +"'"+ rule.RuleValue+"'"
   expression, err := govaluate.NewEvaluableExpression(formula);
   logger.Info("-------打印任务规则公式:",formula)
   if err != nil {
      logger.Error("表达式有误,请检查!", formula)
      return "false"
   }
   result, err1 := expression.Evaluate(nil)
   if err1 != nil {
      logger.Error("带入参数有误")
      return "false"
   }
   if result.(bool) {
      logger.Info("符合任务规则!")
      return "true"
   }
   logger.Info("不符合任务规则")
   return "false"
}
// 调用目标服务器的插入接口
func pushData (urls []*protomsg.PushUrl, data ruleserver.ResultMsg){
   for _,url := range urls {
      Push(url.Url,data)
func pushData(urls []*protomsg.PushUrl, data structure.ResultMsg) {
   for _, url := range urls {
      logger.Debug("看看推送地址:",url.Url)
      pool <- &data
      //logger.Info("urlPool大小: ", len(urlPool[url.Url]))
   }
}
}
// 把报警等级转化成汉字
func formate(str string) string {
   var i string
   if str == "一级" {
      i = "1"
   }
   if str == "二级" {
      i = "2"
   }
   if str == "三级" {
      i = "3"
   }
   if str == "四级" {
      i = "4"
   }
   if str == "五级" {
      i = "5"
   }
   return i
}