package rule import ( "basic.com/valib/logger.git" "fmt" "ruleModelEngine/config" "ruleModelEngine/data" "ruleModelEngine/db" "ruleModelEngine/task" "strconv" ) // //// 检查规则表书否存在异常 //func checkRuleValidity(rules []db.PersonnelStatusRule) bool { // for i := 0; i < len(rules); i++ { // for j := i + 1; j < len(rules); j++ { // ruleI := rules[i] // ruleJ := rules[j] // //fmt.Println(ruleI.DetectionDaysStart,ruleI.DetectionDaysEnd) // //fmt.Println(ruleJ.DetectionDaysStart,ruleJ.DetectionDaysEnd) // if (ruleI.DetectionDaysStart <= ruleJ.DetectionDaysEnd && ruleI.DetectionDaysStart >= ruleJ.DetectionDaysStart) || // (ruleI.DetectionDaysEnd <= ruleJ.DetectionDaysEnd && ruleI.DetectionDaysEnd >= ruleJ.DetectionDaysStart) || // (ruleI.DetectionDaysStart <= ruleJ.DetectionDaysStart && ruleI.DetectionDaysEnd >= ruleJ.DetectionDaysEnd) { // return false // } // } // } // return true //} // 执行程序入口 func ExecuteTask() { //进出异常布控任务,暂时归类到标签计算部分 fmt.Println("进出异常开始入口!!!!!!") tasks, err := db.GetAllTaskData() if err != nil { logger.Error("GetAllTaskData Error", err) } var tkInfo db.Task for _, taskInfo := range tasks { if taskInfo.Name == "进出异常" { tkInfo.Id = taskInfo.Id tkInfo.Name = taskInfo.Name } } fmt.Println("tkInfo: ", tkInfo) days := config.Api.AInterval docNumIdMap, err := db.QueryLastIdByDayRange(days, days-1) if err != nil { logger.Error("QueryByDayRange err: ", err) } fmt.Println("docNumIdMap: ", len(docNumIdMap)) for docNumber, id := range docNumIdMap { //fmt.Println(docNumber, id) alarmRules := make([]db.AlarmRule, 0) flag := task.EnteringButNotLeaving(docNumber, id, days) if flag == true { alarmRules = append(alarmRules, db.AlarmRule{RuleId: strconv.Itoa(tkInfo.Id), RuleText: tkInfo.Name, AlarmLevel: "0"}) } addFlag, err := db.AddAlarmRules(alarmRules, id) if err != nil { logger.Error("AddAlarmRules err: ", err) } if addFlag == true { logger.Info("AddAlarmRules success: ", id) } } //return ruleInfo, err := db.GetAllData() if err != nil { logger.Error("GetAllData Error", err) } fmt.Println("ruleInfo: ", ruleInfo) communityIDs, err := db.GetCommunityIDs() //fmt.Println("communityIDs:", communityIDs) if err != nil { logger.Error("GetCommunityIDs Error", err) } labeManage, err := db.GetLabelManageIdentity(2) if err != nil { logger.Error("GetDBPersonStatusData Error", err) } //fmt.Println(labeManage) for _, communityID := range communityIDs { //万全社区 //if communityID != "50010101010000001001" { // continue //} //查询社区内人员档案,方便数据更新 personStatus, err := db.GetDBPersonStatusData(communityID) if err != nil { logger.Error("GetDBPersonStatusData Error", err) } //fmt.Println(labeManage) //fmt.Println("personStatus: ", personStatus) //fmt.Println("CcmmunityIDs: ", cmmunityID) //按社区id查询近一个月es数据 captureInfos, err := db.Query1MDataByCommunityId(communityID) //fmt.Println("captureInfos: ", captureInfos) //residentCount := 0 for i := range captureInfos { //fmt.Println(captureInfos[i].DocumentNumber) captureDays, overnightCount := data.CalculateCaptureDays(captureInfos[i].CaptureDetail) captureInfos[i].CaptureDays = captureDays captureInfos[i].OvernightStays = overnightCount //if captureInfos[i].CaptureDays <= 10 && captureInfos[i].OvernightStays >= 1 { // fmt.Println(captureInfos[i].DocumentNumber) // fmt.Println("该人员出现天数为", captureInfos[i].CaptureDays) // fmt.Println("该人员过夜天数为", captureInfos[i].OvernightStays) //} captureInfos[i].Status = data.SetStatus(captureDays, ruleInfo) if captureInfos[i].OvernightStays >= 5 && (captureInfos[i].CaptureDays <= 14 && captureInfos[i].CaptureDays >= 5) { captureInfos[i].Status = "resident" } //if captureInfos[i].Status == "resident" { // residentCount++ //} age, err := db.QueryAgeById(captureInfos[i].DocumentNumber) if err != nil { logger.Error("QueryAgeById ERROR", err) } captureInfos[i].Age = age data.SetFrequentAddress(&captureInfos[i]) //fmt.Println("captureInfos[i].Age: ", captureInfos[i].Age) } //fmt.Println("residentCount: ", residentCount) if err != nil { logger.Error("MatchAllTargets Error", err) } if len(captureInfos) == 0 { continue } //fmt.Println("captureInfosQ: ", captureInfos) for _, identity := range labeManage { switch identity.Name { case "服务人员": identity, attribute := CreateLinearModel(captureInfos, communityID, 2.68, identity.ValidDays, identity.Id) errIdentity := db.UpdateDBPersonLabel(identity) if errIdentity != nil { logger.Error("UpdateDBPersonLabel Error", errIdentity) } captureInfos = attribute } } identity := CreateProcessModel(captureInfos, 30, communityID, labeManage) errIdentity := db.UpdateDBPersonLabel(identity) if errIdentity != nil { logger.Error("UpdateDBPersonLabel Error", errIdentity) } //continue //fmt.Println("captureInfos: ", captureInfos) postCaptureInfos := data.ProcessData(captureInfos, personStatus, ruleInfo, communityID) //fmt.Println("postCaptureInfos: ", postCaptureInfos) //fmt.Println("共过滤条数:", len(captureInfos)-len(postCaptureInfos)) UpdatePersonInfoErr := db.UpdatePersonInfo(postCaptureInfos, communityID) if UpdatePersonInfoErr != nil { logger.Error("MatchPermanentResidentTargets Error: ", UpdatePersonInfoErr) } resident, DocNumberErr := db.GetResidentData("resident", communityID) //fmt.Println(resident) //return if DocNumberErr != nil { logger.Error("GetDocNumberFromPersonStatus Error: ", DocNumberErr) } //fmt.Println(resident) //fmt.Println("resident: ", resident) mio := processResidentStatus(resident) //fmt.Println("mip: ", mio) UpdateMoveInoutErr := db.UpdateMoveInout(mio) if UpdateMoveInoutErr != nil { logger.Error("UpdateMoveInoutErr Error: ", UpdateMoveInoutErr) } } }