From 39d53cf7a2080b49224dec6c395fc4ed2463a424 Mon Sep 17 00:00:00 2001 From: zhangzengfei <zhangzengfei@smartai.com> Date: 星期三, 18 十二月 2024 18:23:20 +0800 Subject: [PATCH] 修改参数的获取逻辑 --- models/gather_model.go | 63 ++++++++++++++++++++++--------- 1 files changed, 44 insertions(+), 19 deletions(-) diff --git a/models/gather_model.go b/models/gather_model.go index c384db2..b22f24c 100644 --- a/models/gather_model.go +++ b/models/gather_model.go @@ -6,28 +6,30 @@ "encoding/json" "errors" "fmt" - "github.com/elastic/go-elasticsearch/v6" "log" + "strings" + "sync" + "time" + + "github.com/elastic/go-elasticsearch/v6" + "model-engine/config" "model-engine/db" "model-engine/pkg/set" "model-engine/service" - "strings" - "sync" - "time" ) type GatherModel struct { OrgIds []interface{} `json:"-"` AreaIds []interface{} `json:"-"` - Building string `gorm:"type:varchar(255)" json:"building"` //妤兼爧 - Floor string `gorm:"type:varchar(255)" json:"floor"` //妤煎眰 - AlarmType db.AlarmType `gorm:"type:varchar(255);" json:"alarmType"` //棰勮鏂瑰紡 - PersonType string `gorm:"type:varchar(255);" json:"personType"` //浜哄憳绫诲瀷 - GatherPersons int `gorm:"type:int;" json:"gatherPersons"` //鑱氶泦浜烘暟 - AppearInterval int `gorm:"type:int;" json:"appearInterval"` //鍑虹幇闂撮殧锛屽崟浣嶄负绉� - DaysWindow int `gorm:"type:int;" json:"daysWindow" ` //杩戝嚑澶╁唴 - Threshold int `gorm:"type:int;" json:"threshold" ` //杈惧嚑娆� + Building string `gorm:"type:varchar(255)" json:"building"` // 妤兼爧 + Floor string `gorm:"type:varchar(255)" json:"floor"` // 妤煎眰 + AlarmType db.AlarmType `gorm:"type:varchar(255);" json:"alarmType"` // 棰勮鏂瑰紡 + PersonType string `gorm:"type:varchar(255);" json:"personType"` // 浜哄憳绫诲瀷 + GatherPersons int `gorm:"type:int;" json:"gatherPersons"` // 鑱氶泦浜烘暟 + AppearInterval int `gorm:"type:int;" json:"appearInterval"` // 锛屽崟浣嶄负绉� + DaysWindow int `gorm:"type:int;" json:"daysWindow" ` // 杩戝嚑澶╁唴 + Threshold int `gorm:"type:int;" json:"threshold" ` // 杈惧嚑娆� Task *db.ModelTask } @@ -52,11 +54,34 @@ m.Floor = task.Floor m.AlarmType = task.AlarmType m.PersonType = task.PersonType - m.GatherPersons = task.GatherPersons - m.AppearInterval = task.AppearInterval - m.DaysWindow = task.DaysWindow - m.Threshold = task.Threshold - fmt.Println("GatherModel init finish ...") + + for _, v := range task.Rules { + if v.Alias == "gatherPersons" { + if val, ok := v.Value.(float64); ok { + m.GatherPersons = int(val) + } + } + + if v.Alias == "appearInterval" { + if val, ok := v.Value.(float64); ok { + m.AppearInterval = int(val) + } + } + + if v.Alias == "daysWindow" { + if val, ok := v.Value.(float64); ok { + m.DaysWindow = int(val) + } + } + + if v.Alias == "threshold" { + if val, ok := v.Value.(float64); ok { + m.Threshold = int(val) + } + } + } + + fmt.Printf("GatherModel init finish ... rule:%+v\n", m) return nil } @@ -68,8 +93,8 @@ OrgId string `json:"orgId"` Building string `json:"building"` Floor string `json:"floor"` - GatherPersons int `gorm:"type:int;" json:"gatherPersons"` //鑱氶泦浜烘暟 - AppearInterval int `gorm:"type:int;" json:"appearInterval"` //鍑虹幇闂撮殧锛屽崟浣嶄负绉� + GatherPersons int `gorm:"type:int;" json:"gatherPersons"` // 鑱氶泦浜烘暟 + AppearInterval int `gorm:"type:int;" json:"appearInterval"` // 鍑虹幇闂撮殧锛屽崟浣嶄负绉� } var ( -- Gitblit v1.8.0