From cd60b7e3a0bbc09f4501f66260b5d961d58aaf49 Mon Sep 17 00:00:00 2001
From: panlei <2799247126@qq.com>
Date: 星期二, 17 十二月 2019 13:38:07 +0800
Subject: [PATCH] ---

---
 insertdata/insertDataToEs.go |  531 ++--------------------------------------------------------
 1 files changed, 26 insertions(+), 505 deletions(-)

diff --git a/insertdata/insertDataToEs.go b/insertdata/insertDataToEs.go
index 9a9bec8..05a014e 100644
--- a/insertdata/insertDataToEs.go
+++ b/insertdata/insertDataToEs.go
@@ -1,520 +1,41 @@
 package insertdata
 
 import (
-	"encoding/json"
-	"errors"
-	"fmt"
-	"io/ioutil"
-	"net"
+	"plugin"
 	"ruleprocess/cache"
-	"ruleprocess/logger"
-	"strings"
-	"time"
-
-	"basic.com/pubsub/protomsg.git"
-	"github.com/go-yaml/yaml"
-	"github.com/golang/protobuf/proto"
-	"github.com/satori/go.uuid"
-	"ruleprocess/ruleserver"
-	"ruleprocess/util"
+	"basic.com/valib/logger.git"
+	"ruleprocess/structure"
+	"strconv"
 )
 
-var weedfsUrl, videoPersonUrl, personAction string
-
-type conf struct {
-	PhotoUrl       string `yaml:"photoUrl"`
-	VideoPersons   string `yaml:"videoPersons"`
-	PersonAction   string `yaml:"personAction"`
-	ServerIp       string `yaml:"serverIp"`
-	ServerPort     string `yaml:"serverPort"`
-	DbTablePersons string `yaml:"dbTablePersons"`
-}
-
-func init() {
-	data, err := ioutil.ReadFile("./config/conf.yml")
-	if err != nil {
-		fmt.Println("璇诲彇閰嶇疆鏂囦欢鍑洪敊--", err)
-		logger.Error("璇诲彇閰嶇疆鏂囦欢鍑洪敊--", err)
-	}
-	c := conf{}
-	//鎶妝aml褰㈠紡鐨勫瓧绗︿覆瑙f瀽鎴恠truct绫诲瀷
-	yaml.Unmarshal(data, &c)
-	weedfsUrl = c.PhotoUrl
-	videoPersonUrl = c.VideoPersons
-	personAction = c.PersonAction
-}
-
-// 浜鸿劯鐨勬暟鎹粨鏋�
-type PerVideoPicture struct {
-	Id              string                 `json:"id"`
-	CameraId        string                 `json:"cameraId"`
-	CameraAddr      string                 `json:"cameraAddr"`
-	PicDate         string                 `json:"picDate"`
-	PicMaxUrl       string                 `json:"picMaxUrl"`
-	TaskId          string                 `json:"taskId"`
-	TaskName        string                 `json:"taskName"`
-	SdkName         string                 `json:"sdkName"`
-	Content         string                 `json:"content"`
-	LikeDate        string                 `json:"likeDate"`
-	Sex             string                 `json:"sex"`
-	Age             int32                  `json:"age"`
-	AgeDescription  string                 `json:"ageDescription"`
-	Race            string                 `json:"race"`
-	SmileLevel      int32                  `json:"smileLevel"`
-	BeautyLevel     int32                  `json:"beautyLevel"`
-	FaceFeature     string                 `json:"faceFeature"`
-	PicSmUrl        []string               `json:"picSmUrl"`
-	VideoUrl        string                 `json:"videoUrl"`
-	AnalyServerId   string                 `json:"analyServerId"`
-	AnalyServerName string                 `json:"analyServerName"`
-	AnalyServerIp   string                 `json:"analyServerIp"`
-	ClusterId       string                 `json:"clusterId"`
-	DetectScore     float64                `json:"detectScore"`
-	IsAlarm         int                    `json:"isAlarm"`
-	IsAckAlarm      int                    `json:"isAckAlarm"`
-	IsCollect       int                    `json:"isCollect"`
-	IsDelete        int                    `json:"isDelete"`
-	BaseInfo        []*ruleserver.BaseInfo `json:"baseInfo"`
-}
-
-//  yolo琛屼负鐨勬暟鎹粨鏋�
-type Personaction struct {
-	Id              string      `json:"id"`
-	CameraId        string      `json:"cameraId"`
-	CameraName      string      `json:"cameraName"`
-	CameraAddr      string      `json:"cameraAddr"`
-	TaskId          string      `json:"taskId"`
-	TaskName        string      `json:"taskName"`
-	SdkName         string      `json:"sdkName"`
-	Content         string      `json:"content"`
-	AlarmRules      []AlarmRule `json:"alarmRules"`
-	AnalyServerId   string      `json:"analyServerId"`
-	AnalyServerName string      `json:"analyServerName"`
-	AnalyServerIp   string      `json:"analyServerIp"`
-	ClusterId       string      `json:"clusterId"`
-	PicSmUrl        []string    `json:"picSmUrl"`
-	PicDate         string      `json:"picDate"`
-	VideoUrl        string      `json:"videoUrl"`
-	IsAlarm         int         `json:"isAlarm"`
-	IsAckAlarm      int         `json:"isAckAlarm"`
-	IsCollect       int         `json:"isCollect"`
-	IsDelete        int         `json:"isDelete"`
-}
-
-type AlarmRule struct {
-	GroupId    string `json:"groupId"`
-	AlarmLevel string `json:"alarmLevel"`
-	RuleText   string `json:"ruleText"`
-}
-
-// 寰�ES鎻掓暟鎹�
-func InsertToEs(msg ruleserver.ResultMsg) {
-	var timeLabel string
-	// 鐩存帴浠庤鍒欑殑鏍囩鏁版嵁閲屾嬁绗﹀悎瑙勫垯鐨勪汉鑴哥粨鏋�
-	if msg.RuleResult["timeLabel"] != nil {
-		timeLabel = msg.RuleResult["timeLabel"].(string)
-	}
-	logger.Debug("鎻掑叆鏁版嵁鍓嶇湅鐪嬫姤璀︽爣蹇椾綅锛�", timeLabel)
-	if timeLabel == "01" { // 鏃犲畾鏃跺櫒鐘舵�佽鎻掑叆鐨勬姤璀︽暟鎹�
-		InsertFace(msg)
-		InsertYolo(msg)
-	}
-	if timeLabel == "10" { // 瀹氭椂鍣ㄧ姸鎬佽鎻掑叆鐨勯甯ф姤璀︽暟鎹�傝繛甯︾潃瀹氭椂鍣ㄥ紑鍚椂鐨勯偅甯�
-		InsertFace(msg)
-		InsertYolo(msg)
-
-	}
-	if timeLabel == "12" { // 骞堕潪鎶ヨ鏁版嵁锛屽彧鏄姸鎬佹敼鍙樼殑鏁版嵁
-		//ChangeStatusFace(msg)
-		ChangeStatusYolo(msg)
-	}
-}
-
-// 寰�es涓彃鍏ヤ汉鑴告暟鎹�
-func InsertFace(msg ruleserver.ResultMsg) {
-	if msg.RuleResult["face"] != nil && len(msg.RuleResult["face"].([]ruleserver.Arg)) > 0 {
-		logger.Info("寰�ES鎻掍汉鑴告暟鎹�")
-		for _, face := range msg.RuleResult["face"].([]ruleserver.Arg) {
-			// 涓婁紶澶у浘
-			// 瑙e帇缂╁苟涓婁紶鍥剧墖
-			bdata, err := util.UnCompress(msg.Data)
-			if err != nil {
-				panic("瑙e帇缂╁浘鐗囨椂鍑虹幇閿欒")
-			}
-			i := protomsg.Image{}
-			err = proto.Unmarshal(bdata, &i)
-			bigPhotoUrl := make(map[string]interface{})
-			bigPhotoUrl, err = util.PostFormBufferData(weedfsUrl, i, uuid.NewV4().String())
-			logger.Debug("========澶у浘璺緞锛�", bigPhotoUrl)
-			// 浜鸿劯妫�娴嬶紝娌℃湁鐩镐技鐨勫簳搴撲汉鍛�
-			localConfig, err := cache.GetServerInfo()
-			if err != nil {
-				logger.Error("鏌ヨ鏈満淇℃伅澶辫触锛�")
-			}
-			serverIp, err := GetLocalIP()
-			// 鏌ヨcameraName
-			camera, err := cache.GetCameraById(msg.Cid)
-			if err != nil {
-				logger.Error("鏌ヨ鎽勫儚鏈轰俊鎭け璐�")
-			}
-			bytes := util.SubImg(i, int(face.Location.X), int(face.Location.Y), int(face.Location.X+face.Location.Width), int(face.Location.Y+face.Location.Height))
-			resp, err := util.PostFormBufferData1(weedfsUrl, bytes, uuid.NewV4().String())
-			if err != nil {
-				logger.Error("涓婁紶灏忓浘鍑洪敊")
-			}
-			logger.Info("================灏忓浘鍦板潃:", resp["fileUrl"].(string))
-			sex := ""
-			if face.ThftRes.Gender == 1 {
-				sex = "鐢�"
-			} else {
-				sex = "濂�"
-			}
-			race := getRaceString(face.ThftRes.Race)
-			ageDescription := getDescription(face.ThftRes.Age)
-
-			pervideo := PerVideoPicture{
-				uuid.NewV4().String(),
-				msg.Cid,
-				camera.Addr,
-				i.Timestamp,
-				strings.Split(bigPhotoUrl["fileUrl"].(string), "/")[1],
-				msg.Tasklab.Taskid,
-				msg.Tasklab.Taskname,
-				"浜鸿劯",
-				"",
-				time.Now().Format("2006-01-02 15:04:05"), // 鍙娴嬶紝娌℃湁姣斿鏃堕棿
-				sex,
-				face.ThftRes.Age,
-				ageDescription,
-				race,
-				face.ThftRes.Smile,
-				face.ThftRes.Beauty,
-				string(face.Feature),
-				[]string{strings.Split(resp["fileUrl"].(string), "/")[1]},
-				"鏆傛棤闆嗙兢",
-				localConfig.ServerId,
-				localConfig.ServerName,
-				serverIp,
-				"",
-				face.Score,
-				1,
-				0,
-				0,
-				0,
-				face.Liker,
-			}
-			requstbody, err := json.Marshal(pervideo)
-
-			if err != nil {
-				logger.Info("json parse error ", err)
-				return
-			}
-			err1 := EsReq("POST", videoPersonUrl, requstbody)
-			if err1 != nil {
-				logger.Error("涓婁紶ES鍑洪敊锛�---", err1)
-			}
+//var weedfsUrl, videoPersonUrl, personAction string
+//var serverIp string
+//var serverPort string
+func InsertToEs(msg structure.ResultMsg) {
+	defer func() {
+		if err := recover(); err != nil {
+			logger.Error("es妯″潡鍎跨殑寮傚父鎹曡幏锛�", err)
 		}
+	}()
+	localConfig1, err := cache.GetServerInfo()
+	if err != nil {
+		panic("閰嶇疆鏂囦欢涓嶅悎娉�")
 	}
+	weedfsUrl := "http://" + localConfig1.WebPicIp + ":" + strconv.Itoa(int(localConfig1.WebPicPort)) + "/submit"
+	videoPersonUrl := "http://" + localConfig1.AlarmIp + ":" + strconv.Itoa(int(localConfig1.AlarmPort)) + "/" + structure.EsInfo.EsIndex.AIOcean.IndexName + "/" + structure.EsInfo.EsIndex.AIOcean.IndexType+"?refresh=true"
+	serverIp := localConfig1.AlarmIp
+	serverPort := strconv.Itoa(int(localConfig1.AlarmPort))
+	handle(msg,weedfsUrl,videoPersonUrl,serverIp,serverPort)
 }
-func ChangeStatusFace(msg ruleserver.ResultMsg) {
-	logger.Info("寰�ES鎻掑叆浜鸿劯闈炴姤璀︿絾鏄姸鎬佽浆鎹㈡暟鎹�")
-	// 涓婁紶澶у浘
-	// 瑙e帇缂╁苟涓婁紶鍥剧墖
-	bdata, err := util.UnCompress(msg.Data)
-	if err != nil {
-		panic("瑙e帇缂╁浘鐗囨椂鍑虹幇閿欒")
-	}
-	i := protomsg.Image{}
-	err = proto.Unmarshal(bdata, &i)
-	bigPhotoUrl := make(map[string]interface{})
-	bigPhotoUrl, err = util.PostFormBufferData(weedfsUrl, i, uuid.NewV4().String())
-	logger.Debug("========澶у浘璺緞锛�", bigPhotoUrl)
-	// 浜鸿劯妫�娴嬶紝娌℃湁鐩镐技鐨勫簳搴撲汉鍛�
-	localConfig, err := cache.GetServerInfo()
-	if err != nil {
-		logger.Error("鏌ヨ鏈満淇℃伅澶辫触锛�")
-	}
-	serverIp, err := GetLocalIP()
-	// 鏌ヨcameraName
-	camera, err := cache.GetCameraById(msg.Cid)
-	if err != nil {
-		logger.Error("鏌ヨ鎽勫儚鏈轰俊鎭け璐�")
-	}
 
-	pervideo := PerVideoPicture{
-		uuid.NewV4().String(),
-		msg.Cid,
-		camera.Addr,
-		i.Timestamp,
-		strings.Split(bigPhotoUrl["fileUrl"].(string), "/")[1],
-		msg.Tasklab.Taskid,
-		msg.Tasklab.Taskname,
-		"浜鸿劯",
-		"鐘舵�佽浆鎹㈡暟鎹紝闈炴姤璀︽暟鎹�",
-		time.Now().Format("2006-01-02 15:04:05"), // 鍙娴嬶紝娌℃湁姣斿鏃堕棿
-		"",
-		0,
-		"",
-		"",
-		0,
-		0,
-		"",
-		[]string{""},
-		"鏆傛棤闆嗙兢",
-		localConfig.ServerId,
-		localConfig.ServerName,
-		serverIp,
-		"",
-		0,
-		1,
-		0,
-		0,
-		0,
-		[]*ruleserver.BaseInfo{},
-	}
-	requstbody, err := json.Marshal(pervideo)
-
+func handle (msg structure.ResultMsg,weedfsUrl,videoPersonUrl,serverIp,serverPort string) {
+	p,err :=  plugin.Open("./algorithm/middleware.so")
 	if err != nil {
-		logger.Info("json parse error ", err)
-		return
+		panic(err)
 	}
-	err1 := EsReq("POST", videoPersonUrl, requstbody)
+	f,err1 := p.Lookup("InsertToEs")
 	if err1 != nil {
-		logger.Error("涓婁紶ES鍑洪敊锛�---", err1)
+		panic("娌℃湁鎵惧埌涓棿浠剁殑鏍煎紡鍖栨暟鎹嚱鏁�")
 	}
-	//if msg.RuleResult["cacheData"] != nil {
-	//	InsertFace(msg.RuleResult["cacheData"].(ruleserver.ResultMsg))
-	//}
-}
-
-// 寰�es涓彃鍏olo鏁版嵁
-func InsertYolo(msg ruleserver.ResultMsg) {
-	if msg.RuleResult["yolo"] != nil && len(msg.RuleResult["yolo"].([]ruleserver.Result)) > 0 {
-		logger.Info("寰�ES鎻抷olo鏁版嵁")
-		var sdkNames string = ""
-		alarmRules := []AlarmRule{}
-		for _, yoloResult := range msg.RuleResult["yolo"].([]ruleserver.Result) {
-			sdkNames = sdkNames + yoloResult.SdkName
-			alarm := ChangeToString(yoloResult.AlarmLevel)
-			alarmRules = append(alarmRules, AlarmRule{yoloResult.RuleGroupId, alarm, yoloResult.RuleText})
-		}
-		isAlarm := 0
-		resp := make(map[string]interface{})
-		// 瑙e帇缂╁苟涓婁紶鍥剧墖
-		bdata, err := util.UnCompress(msg.Data)
-		if err != nil {
-			panic("瑙e帇缂╁浘鐗囨椂鍑虹幇閿欒")
-		}
-		i := protomsg.Image{}
-		err = proto.Unmarshal(bdata, &i)
-		if len(alarmRules) > 0 {
-			isAlarm = 1
-			//resp, err = util.PostFormBufferData(weedfsUrl, i, uuid.NewV4().String())
-			resp, err = util.DrawPolygonOnImage(msg.Cid, i, msg.RuleResult["yolo"].([]ruleserver.Result), weedfsUrl)
-			if err != nil {
-				logger.Error("鐢绘鎴栦笂浼犲浘鐗囨湇鍔″櫒鍑洪敊", err)
-			} else {
-				logger.Info("涓婁紶鐨勫浘鐗囦俊鎭細", resp)
-			}
-		} else {
-			isAlarm = 0
-			// 涓嶆槸鎶ヨ鏁版嵁涓嶅瓨
-			return
-		}
-		// logger.Println("鍥剧墖涓婁紶杩斿洖鍊硷細", resp)
-		// 鏌ヨ鏈満淇℃伅
-		localConfig, err := cache.GetServerInfo()
-		if err != nil {
-			logger.Error("鏌ヨ鏈満淇℃伅澶辫触锛�")
-		}
-		// 鏌ヨcameraName
-		camera, err := cache.GetCameraById(msg.Cid)
-		if err != nil {
-			logger.Error("鏌ヨ鎽勫儚鏈轰俊鎭け璐�")
-		}
-		serverIp, err := GetLocalIP()
-		peraction := Personaction{
-			uuid.NewV4().String(),
-			msg.Cid,
-			camera.Name,
-			camera.Addr,
-			msg.Tasklab.Taskid,
-			msg.Tasklab.Taskname,
-			sdkNames,
-			"",
-			alarmRules,
-			localConfig.ServerId,
-			localConfig.ServerName,
-			serverIp,
-			"",
-			[]string{strings.Split(resp["fileUrl"].(string), "/")[1]},
-			i.Timestamp,
-			"",
-			isAlarm,
-			0,
-			0,
-			0,
-		}
-		requstbody, err := json.Marshal(peraction)
-
-		if err != nil {
-			logger.Info("json parse error ", err)
-			return
-
-		}
-		err = EsReq("POST", personAction, requstbody)
-		if err != nil {
-			logger.Error("寰�ES鎻掑叆鏁版嵁澶辫触", err)
-		} else {
-			logger.Warn("__________________________________________寰�ES鎻掑叆yolo鏁版嵁鎴愬姛")
-			//os.Exit(1)
-		}
-		if msg.RuleResult["cacheData"] != nil {
-			InsertYolo(msg.RuleResult["cacheData"].(ruleserver.ResultMsg))
-		}
-	}
-}
-func ChangeStatusYolo(msg ruleserver.ResultMsg) {
-	logger.Info("寰�ES鎻抷olo闈炴姤璀︾姸鎬佹敼鍙樻暟鎹�")
-	var sdkNames string = ""
-	alarmRules := []AlarmRule{}
-	bdata, err := util.UnCompress(msg.Data)
-	if err != nil {
-		panic("瑙e帇缂╁浘鐗囨椂鍑虹幇閿欒")
-	}
-	i := protomsg.Image{}
-	err = proto.Unmarshal(bdata, &i)
-	//resp, err = util.PostFormBufferData(weedfsUrl, i, uuid.NewV4().String())
-	resp, err := util.DrawPolygonOnImage(msg.Cid, i, msg.RuleResult["yolo"].([]ruleserver.Result), weedfsUrl)
-	if err != nil {
-		logger.Error("鐢绘鎴栦笂浼犲浘鐗囨湇鍔″櫒鍑洪敊", err)
-	} else {
-		logger.Info("涓婁紶鐨勫浘鐗囦俊鎭細", resp)
-	}
-	// logger.Println("鍥剧墖涓婁紶杩斿洖鍊硷細", resp)
-	// 鏌ヨ鏈満淇℃伅
-	localConfig, err := cache.GetServerInfo()
-	if err != nil {
-		logger.Error("鏌ヨ鏈満淇℃伅澶辫触锛�")
-	}
-	// 鏌ヨcameraName
-	camera, err := cache.GetCameraById(msg.Cid)
-	if err != nil {
-		logger.Error("鏌ヨ鎽勫儚鏈轰俊鎭け璐�")
-	}
-	serverIp, err := GetLocalIP()
-	peraction := Personaction{
-		uuid.NewV4().String(),
-		msg.Cid,
-		camera.Name,
-		camera.Addr,
-		msg.Tasklab.Taskid,
-		msg.Tasklab.Taskname,
-		sdkNames,
-		"yolo闈炴姤璀︾姸鎬佹敼鍙樻暟鎹�",
-		alarmRules,
-		localConfig.ServerId,
-		localConfig.ServerName,
-		serverIp,
-		"",
-		[]string{strings.Split(resp["fileUrl"].(string), "/")[1]},
-		i.Timestamp,
-		"",
-		0,
-		0,
-		0,
-		0,
-	}
-	requstbody, err := json.Marshal(peraction)
-
-	if err != nil {
-		logger.Info("json parse error ", err)
-		return
-
-	}
-	err = EsReq("POST", personAction, requstbody)
-	if err != nil {
-		logger.Error("寰�ES鎻掑叆鏁版嵁澶辫触", err)
-	} else {
-		logger.Warn("__________________________________________寰�ES鎻掑叆yolo鏁版嵁鎴愬姛")
-		//os.Exit(1)
-	}
-}
-
-// 鑾峰彇鏈満ip
-func GetLocalIP() (ipv4 string, err error) {
-	var (
-		addrs   []net.Addr
-		addr    net.Addr
-		ipNet   *net.IPNet // IP鍦板潃
-		isIpNet bool
-	)
-	// 鑾峰彇鎵�鏈夌綉鍗�
-	if addrs, err = net.InterfaceAddrs(); err != nil {
-		return
-	}
-	// 鍙栫涓�涓潪lo鐨勭綉鍗P
-	for _, addr = range addrs {
-		// 杩欎釜缃戠粶鍦板潃鏄疘P鍦板潃: ipv4, ipv6
-		if ipNet, isIpNet = addr.(*net.IPNet); isIpNet && !ipNet.IP.IsLoopback() {
-			// 璺宠繃IPV6
-			if ipNet.IP.To4() != nil {
-				ipv4 = ipNet.IP.String() // 192.168.1.1
-				return
-			}
-		}
-	}
-
-	err = errors.New("ipv4 not found")
-	return
-}
-
-// 鎶婃姤璀︾瓑绾ц浆鍖栨垚姹夊瓧
-func ChangeToString(i int32) string {
-	alarm := ""
-	if i == 1 {
-		alarm = "涓�绾�"
-	}
-	if i == 2 {
-		alarm = "浜岀骇"
-	}
-	if i == 3 {
-		alarm = "涓夌骇"
-	}
-	if i == 4 {
-		alarm = "鍥涚骇"
-	}
-	if i == 5 {
-		alarm = "浜旂骇"
-	}
-	return alarm
-}
-
-//鑾峰彇骞撮緞鎻忚堪
-func getDescription(age int32) string {
-	ageInfo := "闈掑勾"
-	if age > 0 && age < 7 {
-		ageInfo = "绔ュ勾"
-	} else if age >= 7 && age < 18 {
-		ageInfo = "灏戝勾"
-	} else if age >= 18 && age < 40 {
-		ageInfo = "闈掑勾"
-	} else if age >= 40 && age < 65 {
-		ageInfo = "涓勾"
-	} else if age >= 65 {
-		ageInfo = "鑰佸勾"
-	}
-	return ageInfo
-}
-
-func getRaceString(i int32) string {
-	race := ""
-	if i == 1 {
-		race = "鐧戒汉"
-	} else if i == 2 {
-		race = "榛勪汉"
-	} else {
-		race = "榛戜汉"
-	}
-	return race
+	f.(func(msg structure.ResultMsg,weedfsUrl,videoPersonUrl,serverIp,serverPort string))(msg,weedfsUrl,videoPersonUrl,serverIp,serverPort)
 }

--
Gitblit v1.8.0