| | |
| | | package esutil |
| | | |
| | | import ( |
| | | "bytes" |
| | | "encoding/json" |
| | | "errors" |
| | | "fmt" |
| | |
| | | "net/http" |
| | | "strconv" |
| | | "strings" |
| | | "sync" |
| | | "time" |
| | | "andriodServer/extend/config" |
| | | |
| | | log "andriodServer/log" |
| | | ) |
| | | |
| | | func GetEsDataReq(url string, parama string, picurl string, isSource bool) (error, map[string]interface{}) { |
| | | //log.Log.Infoln("es 查询请求路径" + url) // 配置信息 获取 |
| | | req, err := http.NewRequest("POST", url, strings.NewReader(parama)) |
| | | func GetEsDataReq(url string, param string, isSource bool) (error, map[string]interface{}) { |
| | | req, err := http.NewRequest("POST", url, strings.NewReader(param)) |
| | | |
| | | if err != nil { |
| | | return err, nil |
| | |
| | | data["total"] = dat["total"] |
| | | sources := []interface{}{} |
| | | for _, value := range dat["hits"].([]interface{}) { |
| | | d := make(map[string]interface{}) |
| | | source, ok := value.(map[string]interface{})["_source"].(map[string]interface{}) |
| | | if !ok { |
| | | return errors.New("value is not type of map[string]interface{}"), nil |
| | | } |
| | | |
| | | source["id"] = value.(map[string]interface{})["_id"] |
| | | d["id"] = value.(map[string]interface{})["_id"] |
| | | |
| | | sdkType := source["sdkType"] |
| | | if sdkType != nil { |
| | | sdk, err := strconv.Atoi(sdkType.(string)) |
| | | if err != nil { |
| | | return err, nil |
| | | pmax, exist := source["picMaxUrl"] |
| | | if !exist { |
| | | continue |
| | | } |
| | | pmArr := pmax.([]string) |
| | | if len(pmArr) > 0 { |
| | | d["picMaxUrl"] = pmArr[0] |
| | | } |
| | | |
| | | tB, err := json.Marshal(source["targetInfo"]) |
| | | if err != nil { |
| | | continue |
| | | } |
| | | |
| | | ti := TargetInfo{} |
| | | err = json.Unmarshal(tB, &ti) |
| | | if err !=nil { |
| | | continue |
| | | } |
| | | |
| | | d["picSmUrl"] = ti.PicSmUrl |
| | | if ti.TargetType == "face" { |
| | | sLabelStr, ok := source["showLabels"] |
| | | if ok { |
| | | labelArr := strings.Split(sLabelStr.(string), "/") |
| | | if len(labelArr) == 3 { |
| | | d["gender"] = labelArr[0] |
| | | d["ageDescription"] = labelArr[1] |
| | | d["race"] = labelArr[2] |
| | | } |
| | | } |
| | | |
| | | source["sdkType"] = sdkTypeToValue(sdk) |
| | | if bInfos,ok := source["baseInfo"]; ok && bInfos != nil { |
| | | d["baseInfo"] = getSourceBaseInfo(bInfos) |
| | | } else { |
| | | d["baseInfo"] = []interface{}{} |
| | | } |
| | | } |
| | | |
| | | pmax, exist := source["picMaxUrl"].(string) |
| | | //fmt.Println("picMaxUrl: ",pmax) |
| | | if !exist { |
| | | return errors.New("picMaxurl is not string"), nil |
| | | } |
| | | d["videoNum"] = source["videoUrl"] |
| | | |
| | | |
| | | if !strings.HasPrefix(pmax, "http") { |
| | | source["picMaxUrl"] = picurl + pmax |
| | | |
| | | } |
| | | |
| | | psm, exist := source["picSmUrl"].(string) |
| | | if !exist { |
| | | return errors.New("picSmUrl is not string"), nil |
| | | } |
| | | |
| | | if !strings.HasPrefix(psm, "http") { |
| | | source["picSmUrl"] = picurl + psm |
| | | } |
| | | |
| | | if source["sdkType"] != "人脸" {//行为没有存储大图 |
| | | source["picMaxUrl"] = source["picSmUrl"] |
| | | } |
| | | |
| | | prace, exist := source["Race"] |
| | | if exist { |
| | | source["race"] = prace |
| | | } |
| | | |
| | | pGender, exist := source["Gender"] |
| | | if exist { |
| | | source["gender"] = pGender |
| | | } |
| | | |
| | | source["ageDescription"] = getAgeDesc(source["Age"]) |
| | | |
| | | source["videoNum"] = getVideoUrl(source) |
| | | //picDate := source["picDate"].(string) |
| | | //lastIdx := strings.LastIndex(picDate,":") |
| | | //picDateStr := picDate[:lastIdx] |
| | | //if err == nil { |
| | | // source["picDate"] = picDateStr |
| | | //} |
| | | |
| | | baseInfo := getSourceBaseInfo(source) |
| | | source["baseInfo"] = baseInfo |
| | | |
| | | sources = append(sources, source) |
| | | sources = append(sources, d) |
| | | } |
| | | data["datalist"] = sources |
| | | return nil, data |
| | |
| | | } |
| | | } |
| | | |
| | | func getAgeDesc(age interface{})(ageDesc string) { |
| | | if age !=nil { |
| | | ageInt := age.(float64) |
| | | if ageInt >0 && ageInt<7 { |
| | | ageDesc = "童年" |
| | | } else if ageInt >=7 && ageInt<18 { |
| | | ageDesc = "少年" |
| | | } else if ageInt >=18 && ageInt<40 { |
| | | ageDesc = "青年" |
| | | } else if ageInt >=40 && ageInt<65 { |
| | | ageDesc = "中年" |
| | | } else if ageInt >=65 { |
| | | ageDesc = "老年" |
| | | } else { |
| | | ageDesc = "" |
| | | } |
| | | } |
| | | return ageDesc |
| | | type TargetInfo struct { |
| | | TargetId string `json:"targetId"` |
| | | TargetType string `json:"targetType"` |
| | | PicSmUrl string `json:"picSmUrl"` |
| | | TargetScore float32 `json:"targetScore"` |
| | | } |
| | | |
| | | type BaseInfo struct { |
| | | TaskId string `json:"taskId"` |
| | | TaskName string `json:"taskName"` |
| | | LikePer string `json:"likePer"` |
| | | TableId string `json:"tableId"` |
| | | TableName string `json:"tableName"` |
| | | PersonId string `json:"personId"` |
| | | PersonPicUrl string `json:"personPicUrl"` |
| | | PersonName string `json:"personName"` |
| | | Gender string `json:"gender"` |
| | | PhoneNum string `json:"phoneNum"` |
| | | IDCard string `json:"IDCard"` |
| | | MonitorLevel string `json:"monitorLevel"` |
| | | Content string `json:"content"` |
| | | TaskId string `json:"taskId"` |
| | | TaskName string `json:"taskName"` |
| | | LikePer string `json:"likePer"` |
| | | TableId string `json:"tableId"` |
| | | TableName string `json:"tableName"` |
| | | PersonId string `json:"personId"` |
| | | PersonPicUrl string `json:"personPicUrl"` |
| | | PersonName string `json:"personName"` |
| | | Gender string `json:"gender"` |
| | | PhoneNum string `json:"phoneNum"` |
| | | IDCard string `json:"IDCard"` |
| | | MonitorLevel string `json:"monitorLevel"` |
| | | Content string `json:"content"` |
| | | } |
| | | |
| | | func getSourceBaseInfo(source map[string]interface{}) []BaseInfo { |
| | | sdkType := source["sdkType"].(string) |
| | | baseInfoArr := make([]BaseInfo,0) |
| | | if sdkType == "人脸" { |
| | | likePer,baseName,personId,idCard,personPicUrl,gender,content :="","","","","","","" |
| | | if source["likePer"] !=nil { |
| | | likePer = source["likePer"].(string) |
| | | } |
| | | if source["BaseName"] !=nil { |
| | | baseName = source["BaseName"].(string) |
| | | } |
| | | if source["personId"] !=nil { |
| | | personId = source["personId"].(string) |
| | | } |
| | | if source["idcard"] !=nil { |
| | | idCard = source["idcard"].(string) |
| | | } |
| | | if source["personPicUrl"] !=nil { |
| | | personPicUrl = source["personPicUrl"].(string) |
| | | } |
| | | if source["Gender"] !=nil { |
| | | gender = source["Gender"].(string) |
| | | } |
| | | if source["content"] !=nil { |
| | | content = source["content"].(string) |
| | | } |
| | | var baseInfo = BaseInfo{ |
| | | TaskId:"",//2.0新字段 |
| | | TaskName:"",//2.0新字段 |
| | | LikePer:likePer, |
| | | TableId:"",//2.0新字段 |
| | | TableName:baseName, |
| | | PersonId:personId, |
| | | PersonName:idCard,//人员姓名,从管理平台获取 |
| | | PersonPicUrl:personPicUrl, |
| | | Gender:gender, |
| | | PhoneNum:"",//手机号,从管理平台获取 |
| | | IDCard:idCard, |
| | | MonitorLevel:"",//2.0新字段 |
| | | Content:content, |
| | | } |
| | | type TI struct { |
| | | BwType string `json:"bwType"` |
| | | TargetPicUrl string `json:"targetPicUrl"` |
| | | TargetName string `json:"targetName"` |
| | | TargetId string `json:"targetId"` |
| | | TableId string `json:"tableId"` |
| | | CompareScore string `json:"compareScore"` |
| | | MonitorLevel string `json:"monitorLevel"` |
| | | Content string `json:"content"` |
| | | TableName string `json:"tableName"` |
| | | Labels string `json:"labels"` |
| | | } |
| | | |
| | | baseInfoArr = append(baseInfoArr, baseInfo) |
| | | //bytes, err := json.Marshal(baseInfoArr) |
| | | //if err !=nil { |
| | | // return "" |
| | | //} |
| | | func getSourceBaseInfo(bInfos interface{}) []BaseInfo { |
| | | baseInfoArr := make([]BaseInfo,0) |
| | | |
| | | b, err := json.Marshal(bInfos) |
| | | if err == nil { |
| | | var targetArr []TI |
| | | if err = json.Unmarshal(b, &targetArr); err == nil && len(targetArr) >0 { |
| | | for _,t := range targetArr { |
| | | idCard,sex := "","" |
| | | if t.Labels != "" { |
| | | arr := strings.Split(t.Labels, "/") |
| | | if len(arr) > 0 { |
| | | for _,str := range arr { |
| | | if str == "男" || str == "女" { |
| | | sex = str |
| | | break |
| | | } |
| | | } |
| | | for _,str := range arr { |
| | | if len(str) == 18 { |
| | | idCard = str |
| | | break |
| | | } |
| | | } |
| | | } |
| | | } |
| | | baseInfoArr = append(baseInfoArr, BaseInfo{ |
| | | TaskId: "",//2.0新字段 |
| | | TaskName: "",//2.0新字段 |
| | | LikePer: t.CompareScore, |
| | | TableId: "",//2.0新字段 |
| | | TableName: t.TableName, |
| | | PersonId: t.TargetId, |
| | | PersonName: t.TargetName,//人员姓名,从管理平台获取 |
| | | PersonPicUrl: t.TargetPicUrl, |
| | | Gender: sex, |
| | | PhoneNum: "",//手机号,从管理平台获取 |
| | | IDCard: idCard, |
| | | MonitorLevel: t.MonitorLevel,//2.0新字段 |
| | | Content: t.Content, |
| | | }) |
| | | } |
| | | } |
| | | } |
| | | |
| | | return baseInfoArr |
| | | } |
| | | |
| | | var videoCacheMap = make(map[string]string,0) |
| | | var lock sync.RWMutex |
| | | |
| | | func setVideoCache(imgKey string, url string) { |
| | | lock.Lock() |
| | | defer lock.Unlock() |
| | | videoCacheMap[imgKey] = url |
| | | } |
| | | |
| | | func getVideoFromCache(imgKey string) string { |
| | | lock.Lock() |
| | | defer lock.Unlock() |
| | | if v,ok := videoCacheMap[imgKey];ok { |
| | | return v |
| | | } |
| | | return "" |
| | | } |
| | | |
| | | func getVideoUrl(source map[string]interface{}) (videoUrl string){ |
| | | imgKey := source["imgKey"].(string) |
| | | |
| | | //先从缓存里面取 |
| | | cacheUrl := getVideoFromCache(imgKey) |
| | | if cacheUrl !="" { |
| | | return cacheUrl |
| | | } |
| | | |
| | | picDate := source["picDate"].(string)//抓拍日期 |
| | | cameraId := source["videoReqNum"].(string)//摄像机id |
| | | indeviceId := source["indeviceid"].(string)//分析设备id |
| | | |
| | | reqUrl := "" |
| | | if url,ok := config.ServerMap[indeviceId];!ok { |
| | | return "" |
| | | } else { |
| | | reqUrl = url |
| | | } |
| | | log.Log.Infoln("reqUrl:",reqUrl) |
| | | |
| | | paramMap := make(map[string]interface{},0) |
| | | paramMap["imgKey"] = imgKey |
| | | paramMap["picDate"] = picDate |
| | | paramMap["videoNum"] = cameraId |
| | | |
| | | respBytes, err := doPostRequest(reqUrl, "application/json", paramMap, nil, nil) |
| | | if err !=nil{ |
| | | return "" |
| | | } |
| | | |
| | | var resp RespVideo |
| | | err = json.Unmarshal(respBytes, &resp) |
| | | if err !=nil { |
| | | return "" |
| | | } |
| | | |
| | | filePath := resp.FilePath |
| | | videoUrl = "" |
| | | if !strings.Contains(filePath, "/cut"){ |
| | | videoUrl = "" |
| | | fmt.Printf("videoReqUrl:%s ,imgKey:%s ,picDate:%s ,cameraId:%s ,filePath:%s \n ",reqUrl,imgKey,picDate,cameraId,filePath) |
| | | } else { |
| | | strArr := strings.Split(filePath, "/cut") |
| | | ngxUrl := config.NgxMap[indeviceId] |
| | | log.Log.Infoln("ngxUrl:",ngxUrl) |
| | | if ngxUrl !="" && len(strArr) >0 { |
| | | videoUrl = ngxUrl + strArr[1] |
| | | } |
| | | } |
| | | if videoUrl == ""{ |
| | | respMap := make(map[string]interface{},0) |
| | | err := json.Unmarshal(respBytes, &respMap) |
| | | if err !=nil { |
| | | fmt.Println("resp UnmarshalToMap err: ",err) |
| | | } |
| | | fmt.Println("resp: ",respMap) |
| | | } |
| | | setVideoCache(imgKey, videoUrl) |
| | | return videoUrl |
| | | } |
| | | |
| | | type RespVideo struct{ |
| | | FilePath string `json:"file_path"` |
| | | } |
| | | func doPostRequest(url string, contentType string, body map[string]interface{}, params map[string]string, headers map[string]string) ([]byte, error) { |
| | | var resultBytes []byte |
| | | var bodyJson []byte |
| | | if body != nil { |
| | | var err error |
| | | bodyJson, err = json.Marshal(body) |
| | | if err != nil { |
| | | log.Log.Errorln("doPostRequestMarshal err:",err) |
| | | return resultBytes, err |
| | | } |
| | | } |
| | | request, err := http.NewRequest("POST", url, bytes.NewBuffer(bodyJson)) |
| | | if err != nil { |
| | | log.Log.Errorln("NewRequest ERR:",err) |
| | | return resultBytes, err |
| | | } |
| | | request.Header.Set("Content-type", contentType) |
| | | //add params |
| | | q := request.URL.Query() |
| | | if params != nil { |
| | | for key, val := range params { |
| | | q.Add(key, val) |
| | | } |
| | | request.URL.RawQuery = q.Encode() |
| | | } |
| | | // add headers |
| | | if headers != nil { |
| | | for key, val := range headers { |
| | | request.Header.Add(key, val) |
| | | } |
| | | } |
| | | timeOut:= time.Duration(8*time.Second)//set request timeout |
| | | client := &http.Client{ |
| | | Timeout:timeOut, |
| | | } |
| | | resp, err := client.Do(request) |
| | | if err != nil { |
| | | log.Log.Errorln("DoRequest ERR:",err) |
| | | return resultBytes, err |
| | | } |
| | | defer resp.Body.Close() |
| | | resultBytes, err = ioutil.ReadAll(resp.Body) |
| | | if err != nil { |
| | | log.Log.Errorln("ReadAll ERR:",err) |
| | | return resultBytes, err |
| | | } |
| | | return resultBytes, nil |
| | | } |
| | | |
| | | //sdk类型 |
| | | func sdkTypeToValue(i int) string { |
| | | value := []string{"人脸", "车辆", "人体", "入侵", "拥挤", "靠右行", "人员异常", "个体静止"} |
| | | |
| | | return value[i-1] |
| | | } |
| | | |
| | | func PostAction(sec int, Eurl string, picurl string, ishub string, size int, lastT time.Time, curTime time.Time) []byte { |
| | | //lastTimeStr := lastT.Format("2006-01-02 15:04:05") |
| | | //curTimeStr := curTime.Format("2006-01-02 15:04:05") |
| | | index := "videopersons,personaction" |
| | | func PostAction(sec int, Eurl string, ishub string, size int, lastT time.Time, curTime time.Time) []byte { |
| | | index := "ai_ocean" |
| | | url := fmt.Sprintf("%s%s%s", Eurl, index, "/_search") |
| | | |
| | | sizeStr :="" |
| | |
| | | preSec = strconv.Itoa(sec) |
| | | } |
| | | var filterArr []string |
| | | //是否查报警数据 |
| | | if ishub == "hub" { |
| | | filterArr = append(filterArr,"{\"term\":{\"personIsHub\":\"1\"}}") |
| | | filterArr = append(filterArr,"{\"term\":{\"alarmRules.alarmLevel.raw\":\"一级\"}}") |
| | | } |
| | | |
| | | filterArr = append(filterArr, "{\"range\":{\"picDate\":{\"gte\":\"now+8h-"+preSec+"s\",\"lt\":\"now+8h\"}}}") |
| | |
| | | if len(filterArr) >0 { |
| | | filterStr = strings.Join(filterArr, ",") |
| | | } |
| | | sourceArr := []string{ |
| | | "baseInfo", |
| | | "targetInfo", |
| | | "content", |
| | | "id", |
| | | "picMaxUrl", |
| | | "picDate", |
| | | "showLabels", |
| | | "taskName", |
| | | } |
| | | sourceStr := strings.Join(sourceArr, ",") |
| | | log.Log.Infoln("filterArr:", filterStr) |
| | | prama := "{\"query\":{\"bool\":{\"filter\":["+filterStr+"]}},\"size\":\""+sizeStr+"\",\"sort\":[{\"picDate\":{\"order\":\"desc\"}}]," + |
| | | "\"_source\":[\"baseInfo\",\"Gender\",\"BaseName\",\"Age\",\"personId\",\"personPicUrl\",\"indeviceName\",\"imgKey\",\"sdkType\",\"ageDescription\",\"indeviceid\",\"content\",\"Id\",\"picAddress\",\"picMaxUrl\",\"picDate\",\"Race\",\"videoNum\",\"picSmUrl\",\"taskName\",\"personIsHub\",\"idcard\",\"videoIp\",\"videoReqNum\"]" + |
| | | param := "{\"query\":{\"bool\":{\"filter\":["+filterStr+"]}},\"size\":\""+sizeStr+"\",\"sort\":[{\"picDate\":{\"order\":\"desc\"}}]," + |
| | | "\"_source\":{\"includes\":["+sourceStr+"],\"excludes\":[\"*.feature\",\"*.attachTarget\",\"*.targetLocation\",\"alarmRules\"]}" + |
| | | "}" |
| | | err, tokenRes := GetEsDataReq(url, prama, picurl, true) |
| | | err, tokenRes := GetEsDataReq(url, param, true) |
| | | |
| | | if err != nil { |
| | | log.Log.Errorln(err) |