From a88cd5f3c40d32fb48e80873667455f1424ae1cf Mon Sep 17 00:00:00 2001
From: sunty <1172534965@qq.com>
Date: 星期日, 23 八月 2020 16:28:40 +0800
Subject: [PATCH] add w h

---
 EsClient.go |  213 +++++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 212 insertions(+), 1 deletions(-)

diff --git a/EsClient.go b/EsClient.go
index 0d608a9..09b1861 100644
--- a/EsClient.go
+++ b/EsClient.go
@@ -8,6 +8,7 @@
 	"fmt"
 	"io"
 	"io/ioutil"
+	"math"
 	"net/http"
 	"strings"
 	"time"
@@ -475,6 +476,149 @@
 	return tmpinfos
 }
 
+func SourceAggregations(buf [] byte, thresholdTime float64) (sources map[string]interface{}, err error) {
+	s := make(map[string]interface{})
+	loc, err := time.LoadLocation("Asia/Shanghai")
+	if err != nil {
+		return nil, errors.New("鏃跺尯璁剧疆閿欒")
+	}
+	var info interface{}
+	json.Unmarshal(buf, &info)
+	out, ok := info.(map[string]interface{})
+	if !ok {
+		return nil, errors.New("http response interface can not change map[string]interface{}")
+	}
+	middle, ok := out["aggregations"].(map[string]interface{})
+	if !ok {
+		return nil, errors.New("first hits change error!")
+	}
+	bucketsAggs := middle["buckets_aggs"].(map[string]interface{})
+	buckets := bucketsAggs["buckets"].([]interface{})
+	if len(buckets) == 0 {
+		return nil, nil
+	}
+	allSource := make([]map[string]interface{}, 0)
+	for _, inf := range buckets {
+		//tmpSources := make(map[string]interface{}, 0)
+		hitsSources := make([]map[string]interface{}, 0)
+		//groupKey := inf.(map[string]interface{})["key"].(map[string]interface{})
+		//docCount := int(inf.(map[string]interface{})["doc_count"].(float64))
+		topAttentionHits := inf.(map[string]interface{})["top_attention_hits"].(map[string]interface{})
+		middleHits := topAttentionHits["hits"].(map[string]interface{})
+		finalHits := middleHits["hits"].([]interface{})
+		tmpHitSource := make(map[string]interface{})
+		startTime := ""
+		for _, in := range finalHits {
+			tmpbuf, ok := in.(map[string]interface{})
+			if !ok {
+				fmt.Println("change to source error!")
+				continue
+			}
+			source, ok := tmpbuf["_source"].(map[string]interface{})
+			if !ok {
+				fmt.Println("change _source error!")
+				continue
+			}
+			baseInfo := source["baseInfo"].([]interface{})[0].(map[string]interface{})
+			targetInfo := source["targetInfo"].([]interface{})[0].(map[string]interface{})
+			tmpTime := source["picDate"].(string)
+			mTime, err := time.ParseInLocation("2006-01-02 15:04:05", tmpTime, loc)
+			if err != nil {
+				return nil, errors.New("鏃堕棿瑙f瀽閿欒")
+			}
+
+			sTime := tmpTime
+			eTime := tmpTime
+			stayTime := 0.0
+			if startTime != "" {
+				sinTime, _ := time.ParseInLocation("2006-01-02 15:04:05", startTime, loc)
+				stayTime = math.Abs(sinTime.Sub(mTime).Seconds())
+				if stayTime <= thresholdTime {
+					startTime = tmpTime
+					hitsSources[len(hitsSources)-1]["endTime"] = tmpTime
+					continue
+				} else {
+					if sinTime.Sub(mTime).Seconds() == 0 {
+						sinTime.Add(time.Second * 1)
+						sinTime.Format("2006-01-02 15:04:05")
+						hitsSources[len(hitsSources)-1]["endTime"] = sinTime
+					}
+				}
+			}
+			startTime = tmpTime
+			tmpHitSource["personId"] = baseInfo["targetId"].(string)
+			tmpHitSource["cameraId"] = source["cameraId"].(string)
+			tmpHitSource["cameraName"] = source["cameraName"].(string)
+			tmpHitSource["cameraAddr"] = source["cameraAddr"].(string)
+			tmpHitSource["targetScore"] = int(targetInfo["targetScore"].(float64))
+			tmpHitSource["properties"] = source["showLabels"].(string)
+			tmpHitSource["tableId"] = baseInfo["tableId"].(string)
+			tmpHitSource["tableName"] = baseInfo["tableName"].(string)
+			tmpHitSource["bwType"] = baseInfo["bwType"].(string)
+			tmpHitSource["personName"] = baseInfo["targetName"].(string)
+			tmpHitSource["compareScore"] = int(baseInfo["compareScore"].(float64))
+			tmpHitSource["startTime"] = sTime
+			tmpHitSource["startBackGroundPicUrl"] = source["picMaxUrl"].([]interface{})
+			tmpHitSource["startFacePicUrl"] = targetInfo["picSmUrl"].(string)
+			tmpHitSource["endTime"] = eTime
+			tmpHitSource["stayTime"] = stayTime
+			tmpHitSource["endTBackGroundPicUrl"] = source["picMaxUrl"].([]interface{})
+			tmpHitSource["endTFacePicUrl"] = targetInfo["picSmUrl"].(string)
+			if source["picWH"] != nil {
+			tmpHitSource["picWH"] = source["picWH"].(map[string]interface{})
+			}
+			hitsSources = append(hitsSources, tmpHitSource)
+		}
+		allSource = append(allSource, hitsSources...)
+		//	tmpSources["groupKey"] = groupKey
+		//	tmpSources["doc_count"] = docCount
+		//	tmpSources["hits_sources"] = hitsSources
+		//	sources = append(sources, tmpSources)
+	}
+	count := len(allSource)
+	fmt.Println(count)
+	s["count"] = count
+	s["allSource"] = allSource
+
+	return s, nil
+}
+
+//瑙f瀽鎶撴媿搴撲汉鍛樼粨鏋�
+func PerSonAnalysis(preData []map[string]interface{}) (sources []map[string]interface{}, err error) {
+	loc, err := time.LoadLocation("Asia/Shanghai")
+	if err != nil {
+		return nil, errors.New("鏃跺尯璁剧疆閿欒")
+	}
+	for _, key := range preData {
+		source := make(map[string]interface{}, 0)
+		info := key
+		targetInfo := info["targetInfo"].([]interface{})[0].(map[string]interface{})
+		startTime := info["picDate"].(string)
+		endTime := info["updateTime"].(string)
+		source["personId"] = targetInfo["belongsTargetId"].(string)
+		source["cameraId"] = info["cameraId"].(string)
+		source["cameraName"] = info["cameraName"].(string)
+		source["cameraAddr"] = info["cameraAddr"].(string)
+		source["targetScore"] = int(targetInfo["targetScore"].(float64))
+		source["personRect"] = targetInfo["targetLocation"].(map[string]interface{})
+		source["startTime"] = startTime
+		pixMaxUrl := info["picMaxUrl"].([]interface{})
+		source["startBackGroundPicUrl"] = pixMaxUrl[0]
+		source["endTime"] = endTime
+		startT, _ := time.ParseInLocation("2006-01-02 15:04:05", startTime, loc)
+		endT, _ := time.ParseInLocation("2006-01-02 15:04:05", endTime, loc)
+		stayTime := endT.Sub(startT).Seconds()
+		source["stayTime"] = stayTime
+		source["endBackGroundPicUrl"] = pixMaxUrl[len(pixMaxUrl)-1]
+		if info["picWH"] != nil {
+			source["picWH"] = info["picWH"].(map[string]interface{})
+		}
+		sources = append(sources, source)
+	}
+
+	return sources, nil
+}
+
 func Sourcelist(buf []byte) (sources []map[string]interface{}, err error) {
 	var info interface{}
 	json.Unmarshal(buf, &info)
@@ -542,9 +686,76 @@
 	return data, nil
 }
 
+func SourceCreated(buf []byte) (result bool, err error) {
+	var info interface{}
+	json.Unmarshal(buf, &info)
+	out, ok := info.(map[string]interface{})
+	if !ok {
+		return false, errors.New("http response interface can not change map[string]interface{}")
+	}
+
+	middle, ok := out["result"].(string)
+	if !ok {
+		return false, errors.New("first total change error!")
+	}
+	if middle == "created" || middle == "updated" {
+		result = true
+	}
+	return result, nil
+}
+
+func SourceDeleted(buf []byte) (total int, err error) {
+	var info interface{}
+	json.Unmarshal(buf, &info)
+	out, ok := info.(map[string]interface{})
+	if !ok {
+		return -1, errors.New("http response interface can not change map[string]interface{}")
+	}
+
+	middle, ok := out["deleted"].(float64)
+	if !ok {
+		return -1, errors.New("first total change error!")
+	}
+	total = int(middle)
+	return total, nil
+}
+
+func SourceUpdated(buf []byte) (total int, err error) {
+	var info interface{}
+	json.Unmarshal(buf, &info)
+	out, ok := info.(map[string]interface{})
+	if !ok {
+		return -1, errors.New("http response interface can not change map[string]interface{}")
+	}
+
+	middle, ok := out["updated"].(float64)
+	if !ok {
+		return -1, errors.New("first total change error!")
+	}
+	total = int(middle)
+	return total, nil
+}
+
+func SourceTotal(buf []byte) (total int, err error) {
+	var info interface{}
+	json.Unmarshal(buf, &info)
+	out, ok := info.(map[string]interface{})
+	if !ok {
+		return -1, errors.New("http response interface can not change map[string]interface{}")
+	}
+
+	middle, ok := out["hits"].(map[string]interface{})
+	if !ok {
+		return -1, errors.New("first total change error!")
+	}
+	tmp := middle["total"].(float64)
+	total = int(tmp)
+	return total, nil
+}
+
 func EsReq(method string, url string, parama []byte) (buf []byte, err error) {
 	//defer elapsed("page")()
-	timeout := time.Duration(10 * time.Second)
+	timeout := time.Duration(100 * time.Second)
 	client := http.Client{
 		Timeout: timeout,
 	}

--
Gitblit v1.8.0