From 93262f2823b1f1e2a780172fe5669d59853fdaf1 Mon Sep 17 00:00:00 2001
From: 龙赣华 <slongertian@gmail.com>
Date: 星期二, 28 五月 2019 12:01:42 +0800
Subject: [PATCH] merge esclient.go

---
 esutil/EsClient.go |  114 +++++++++++++++++++++++++++++++++++++++++++++++++++++++--
 1 files changed, 110 insertions(+), 4 deletions(-)

diff --git a/esutil/EsClient.go b/esutil/EsClient.go
index fdf50d6..ef5c658 100644
--- a/esutil/EsClient.go
+++ b/esutil/EsClient.go
@@ -1,6 +1,7 @@
 package esutil
 
 import (
+	"bytes"
 	"encoding/json"
 	"errors"
 	"fmt"
@@ -14,7 +15,7 @@
 	log "github.com/long/test/log"
 )
 
-func GetEsDataReq(url string, parama string, isSource bool) (error, map[string]interface{}) {
+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))
 
@@ -63,6 +64,7 @@
 			}
 
 			source["id"] = value.(map[string]interface{})["_id"]
+
 			sdkType := source["sdkType"]
 			if sdkType != nil {
 				sdk, err := strconv.Atoi(sdkType.(string))
@@ -72,6 +74,28 @@
 
 				source["sdkType"] = sdkTypeToValue(sdk)
 			}
+
+			pmax, exist := source["picMaxUrl"].(string)
+			if !exist {
+				return errors.New("picMaxurl is not string"), nil
+			}
+
+			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
+			}
+			//videoUrl := getVideoUrl(source)
+			source["videoNum"] = getVideoUrl(source)
+
 			sources = append(sources, source)
 		}
 		data["datalist"] = sources
@@ -81,6 +105,87 @@
 	}
 }
 
+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
+
+	var deviceMap map[string]string
+	deviceMap["DSVAD010120181119"] = "http://58.118.225.79:41241/ManCarAnaly/perVideoPic/uploadRtnVideo"
+	deviceMap["DSVAD010220181119"] = "http://58.118.225.79:41242/ManCarAnaly/perVideoPic/uploadRtnVideo"
+	deviceMap["DSVAD010320181119"] = "http://58.118.225.79:41243/ManCarAnaly/perVideoPic/uploadRtnVideo"
+	deviceMap["DSVAD010420181119"] = "http://58.118.225.79:41244/ManCarAnaly/perVideoPic/uploadRtnVideo"
+
+	reqUrl := deviceMap[indeviceId]
+	var paramMap map[string]interface{}
+	paramMap["imgKey"] = imgKey
+	paramMap["picDate"] = picDte
+	paramMap["videoPath"] = cameraId
+
+	respBytes, err := doPostRequest(reqUrl, "application/x-www-form-urlencoded", paramMap, nil, nil)
+	if err != nil {
+		return ""
+	}
+	var resp RespVideo
+	err = json.Unmarshal(respBytes, &resp)
+	if err != nil {
+		return ""
+	}
+	return resp.VideoPath
+}
+
+type RespVideo struct {
+	Code      int32  `json:"code"`
+	ErrorStr  string `json:"errorStr"`
+	Msg       string `json:"msg"`
+	Resp      interface{}
+	Status    string `json:"status"`
+	VideoPath string `json:"videoPath"`
+}
+
+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绫诲瀷
 func sdkTypeToValue(i int) string {
 	value := []string{"浜鸿劯", "杞﹁締", "浜轰綋", "鍏ヤ镜", "鎷ユ尋", "闈犲彸琛�", "浜哄憳寮傚父", "涓綋闈欐"}
@@ -88,16 +193,17 @@
 	return value[i-1]
 }
 
-func PostAction(sec int, Eurl string) []byte {
+func PostAction(sec int, Eurl string, picurl string) []byte {
 	index := "videopersons,personaction"
 	url := fmt.Sprintf("%s%s%s", Eurl, index, "/_search")
 
 	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\",\"sdkType\",\"ageDescription\",\"content\",\"ID\",\"picAddress\",\"picMaxUrl\",\"picDate\",\"race\",\"videoNum\",\"picSmUrl\",\"taskName\",\"personIsHub\",\"IDCard\",\"videoIp\",\"videoReqNum\"]" +
+		"\"_source\":[\"baseInfo\",\"gender\",\"indeviceName\",\"imageKey\",\"sdkType\",\"ageDescription\",\"indeviceid\",\"content\",\"ID\",\"picAddress\",\"picMaxUrl\",\"picDate\",\"race\",\"videoNum\",\"picSmUrl\",\"taskName\",\"personIsHub\",\"IDCard\",\"videoIp\",\"videoReqNum\"]" +
 		"}"
-	err, tokenRes := GetEsDataReq(url, prama, true)
+	err, tokenRes := GetEsDataReq(url, prama, picurl, true)
+
 	if err != nil {
 		log.Log.Errorln(err)
 		return nil

--
Gitblit v1.8.0