From 4e30b339ac10cdbce8a6aa1078a8ebcdafc37350 Mon Sep 17 00:00:00 2001
From: liuxiaolong <736321739@qq.com>
Date: 星期三, 29 五月 2019 10:11:50 +0800
Subject: [PATCH] fix dateformat

---
 esutil/EsClient.go |  173 ++++++++++++++++++++++++++++++++++++++++++++++++---------
 1 files changed, 146 insertions(+), 27 deletions(-)

diff --git a/esutil/EsClient.go b/esutil/EsClient.go
index ef5c658..c57bd2a 100644
--- a/esutil/EsClient.go
+++ b/esutil/EsClient.go
@@ -76,6 +76,7 @@
 			}
 
 			pmax, exist := source["picMaxUrl"].(string)
+			//fmt.Println("picMaxUrl: ",pmax)
 			if !exist {
 				return errors.New("picMaxurl is not string"), nil
 			}
@@ -93,8 +94,24 @@
 			if !strings.HasPrefix(psm, "http") {
 				source["picSmUrl"] = picurl + psm
 			}
-			//videoUrl := getVideoUrl(source)
+
+			prace, exist := source["Race"]
+			if exist {
+				source["race"] = prace
+			}
+
+			source["ageDescription"] = getAgeDesc(source["Age"])
+
 			source["videoNum"] = getVideoUrl(source)
+
+			picDateStr, err := time.Parse("2006-01-02 15:04:05", source["picDate"].(string))
+			fmt.Println("picDate: ", picDateStr)
+			if err == nil {
+				source["picDate"] = picDateStr
+			}
+
+			baseInfo := getSourceBaseInfo(source)
+			source["baseInfo"] = baseInfo
 
 			sources = append(sources, source)
 		}
@@ -105,45 +122,147 @@
 	}
 }
 
-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
+func getAgeDesc(age interface{})(ageDesc string) {
+	fmt.Println("ageInterface: ", age)
+	if age !=nil {
+		ageInt := age.(int)
+		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 = ""
+		}
+	}
+	fmt.Println("ageDescription: ", ageDesc)
+	return ageDesc
+}
 
-	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"
+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)
+	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,
+		}
+
+		baseInfoArr = append(baseInfoArr, baseInfo)
+		bytes, err := json.Marshal(baseInfoArr)
+		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]
-	var paramMap map[string]interface{}
+	paramMap := make(map[string]interface{},0)
 	paramMap["imgKey"] = imgKey
 	paramMap["picDate"] = picDte
-	paramMap["videoPath"] = cameraId
+	paramMap["videoNum"] = cameraId
 
-	respBytes, err := doPostRequest(reqUrl, "application/x-www-form-urlencoded", paramMap, nil, nil)
-	if err != nil {
+	respBytes, err := doPostRequest(reqUrl, "application/json", paramMap, nil, nil)
+	if err !=nil{
 		return ""
 	}
 	var resp RespVideo
 	err = json.Unmarshal(respBytes, &resp)
-	if err != nil {
+	if err !=nil {
 		return ""
 	}
-	return resp.VideoPath
+	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 {
-	Code      int32  `json:"code"`
-	ErrorStr  string `json:"errorStr"`
-	Msg       string `json:"msg"`
-	Resp      interface{}
-	Status    string `json:"status"`
-	VideoPath string `json:"videoPath"`
+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
@@ -199,8 +318,8 @@
 
 	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)
 

--
Gitblit v1.8.0