From f308c3d7ac1dc86e7b151f736fa3ad96309245f4 Mon Sep 17 00:00:00 2001 From: liuxiaolong <736321739@qq.com> Date: 星期二, 28 五月 2019 18:11:01 +0800 Subject: [PATCH] test rm personIsHub=1 --- esutil/EsClient.go | 153 ++++++++++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 151 insertions(+), 2 deletions(-) diff --git a/esutil/EsClient.go b/esutil/EsClient.go index fa64d44..be812d8 100644 --- a/esutil/EsClient.go +++ b/esutil/EsClient.go @@ -1,6 +1,7 @@ package esutil import ( + "bytes" "encoding/json" "errors" "fmt" @@ -75,6 +76,7 @@ } pmax, exist := source["picMaxUrl"].(string) + //fmt.Println("picMaxUrl: ",pmax) if !exist { return errors.New("picMaxurl is not string"), nil } @@ -93,6 +95,16 @@ source["picSmUrl"] = picurl + psm } + source["videoNum"] = getVideoUrl(source) + timeFormat := "2019-05-28 15:04:05" + picDateStr, err := time.Parse(timeFormat, source["picDate"].(string)) + if err == nil { + source["picDate"] = picDateStr + } + + baseInfo := getSourceBaseInfo(source) + source["baseInfo"] = baseInfo + sources = append(sources, source) } data["datalist"] = sources @@ -100,6 +112,142 @@ } else { return nil, dat } +} + +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"` +} + +func getSourceBaseInfo(source map[string]interface{}) (baseInfoJson string) { + sdkType := source["sdkType"].(string) + if sdkType == "浜鸿劯" { + var baseInfo = BaseInfo{ + TaskId:"",//2.0鏂板瓧娈� + TaskName:"",//2.0鏂板瓧娈� + LikePer:source["likePer"].(string), + TableId:"",//2.0鏂板瓧娈� + TableName:source["BaseName"].(string), + PersonId:source["personId"].(string), + PersonName:source["idcard"].(string),//浜哄憳濮撳悕锛屼粠绠$悊骞冲彴鑾峰彇 + PersonPicUrl:source["personPicUrl"].(string), + Gender:source["Gender"].(string), + PhoneNum:"",//鎵嬫満鍙凤紝浠庣鐞嗗钩鍙拌幏鍙� + IDCard:source["idcard"].(string), + MonitorLevel:"",//2.0鏂板瓧娈� + Content:source["content"].(string), + } + bytes, err := json.Marshal(baseInfo) + if err !=nil { + return "" + } + return string(bytes) + } + return "" +} + +func getVideoUrl(source map[string]interface{}) (videoUrl string){ + imgKey := source["imgKey"].(string) + picDte := source["picDate"].(string)//鎶撴媿鏃ユ湡 + cameraId := source["videoReqNum"].(string)//鎽勫儚鏈篿d + indeviceId := source["indeviceid"].(string)//鍒嗘瀽璁惧id + deviceMap := make(map[string]string,0) + deviceMap["DSVAD010120181119"] = "http://172.17.50.241:11111/getRecordVideoPath" + deviceMap["DSVAD010220181119"] = "http://172.17.50.242:11111/getRecordVideoPath" + deviceMap["DSVAD010320181119"] = "http://172.17.50.243:11111/getRecordVideoPath" + deviceMap["DSVAD010420181119"] = "http://172.17.50.244:11111/getRecordVideoPath" + + ngxMap := make(map[string]string,0) + ngxMap["DSVAD010120181119"] = "http://58.118.225.79:44180/videosource" + ngxMap["DSVAD010220181119"] = "http://58.118.225.79:44280/videosource" + ngxMap["DSVAD010320181119"] = "http://58.118.225.79:44380/videosource" + ngxMap["DSVAD010420181119"] = "http://58.118.225.79:44480/videosource" + + + reqUrl := deviceMap[indeviceId] + paramMap := make(map[string]interface{},0) + paramMap["imgKey"] = imgKey + paramMap["picDate"] = picDte + 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 + + if !strings.Contains(filePath, "/cut"){ + return "" + } else { + strArr := strings.Split(filePath, "/cut") + ngxUrl := ngxMap[indeviceId] + if ngxUrl !="" && len(strArr) >0 { + return ngxUrl + strArr[1] + } + } + + return "" +} + +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 { + return resultBytes, err + } + } + request, err := http.NewRequest("POST", url, bytes.NewBuffer(bodyJson)) + if err != nil { + 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) + } + } + client := &http.Client{} + resp, err := client.Do(request) + if err != nil { + return resultBytes, err + } + defer resp.Body.Close() + resultBytes, err = ioutil.ReadAll(resp.Body) + if err != nil { + return resultBytes, err + } + return resultBytes, nil } //sdk绫诲瀷 @@ -115,10 +263,11 @@ seccond := strconv.Itoa(sec) - prama := "{\"query\":{\"bool\":{\"filter\":[{\"term\":{\"personIsHub\":\"1\"}},{\"range\":{\"picDate\":{\"gte\":\"now+8h-" + seccond + "s\",\"lt\":\"now+8h\"}}}]}},\"size\":\"1000\",\"sort\":[{\"picDate\":{\"order\":\"desc\"}}]," + - "\"_source\":[\"baseInfo\",\"gender\",\"indeviceName\",\"imageKey\",\"sdkType\",\"ageDescription\",\"indeviceid\",\"content\",\"ID\",\"picAddress\",\"picMaxUrl\",\"picDate\",\"race\",\"videoNum\",\"picSmUrl\",\"taskName\",\"personIsHub\",\"IDCard\",\"videoIp\",\"videoReqNum\"]" + + prama := "{\"query\":{\"bool\":{\"filter\":[{\"range\":{\"picDate\":{\"gte\":\"now+8h-" + seccond + "s\",\"lt\":\"now+8h\"}}}]}},\"size\":\"1000\",\"sort\":[{\"picDate\":{\"order\":\"desc\"}}]," + + "\"_source\":[\"baseInfo\",\"Gender\",\"personId\",\"personPicUrl\",\"indeviceName\",\"imgKey\",\"sdkType\",\"ageDescription\",\"indeviceid\",\"content\",\"Id\",\"picAddress\",\"picMaxUrl\",\"picDate\",\"Race\",\"videoNum\",\"picSmUrl\",\"taskName\",\"personIsHub\",\"idcard\",\"videoIp\",\"videoReqNum\"]" + "}" err, tokenRes := GetEsDataReq(url, prama, picurl, true) + if err != nil { log.Log.Errorln(err) return nil -- Gitblit v1.8.0