From 77a05fa27d55ea7e39aee47f71cb5f74308e5e0e Mon Sep 17 00:00:00 2001
From: panlei <2799247126@qq.com>
Date: 星期五, 30 八月 2019 11:08:06 +0800
Subject: [PATCH] stop bigcache init

---
 cache/cache.go |   66 +++++++++++++++++++++++++++++---
 1 files changed, 59 insertions(+), 7 deletions(-)

diff --git a/cache/cache.go b/cache/cache.go
index 2071d96..aeceb67 100644
--- a/cache/cache.go
+++ b/cache/cache.go
@@ -9,6 +9,7 @@
 	"fmt"
 	"github.com/gogo/protobuf/proto"
 	"github.com/satori/go.uuid"
+	"ruleprocess/logger"
 	"strconv"
 )
 const (
@@ -17,6 +18,8 @@
 	PREFIX_TIME = "TIME_"
 	PREFIX_RULE = "RULE_"
 	SERVER_KEY = "SERVERINFO"
+	PREFIX_SDK = "SDK_"
+	PREFIX_SO = "SO"
 )
 
 var cMap *shardmap.ShardMap
@@ -51,6 +54,10 @@
 
 	initServerInfo()//鍒濆鍖栨湇鍔″櫒閰嶇疆淇℃伅
 
+	initSdks() //鍒濆鍖杝dk鍒楄〃淇℃伅
+
+	initSoData()
+
 	initChan <- true
 }
 
@@ -62,12 +69,20 @@
 		return
 	}
 	switch newUpdateMsg.Table {
+	case protomsg.TableChanged_T_Server:
+		initServerInfo()
+	case protomsg.TableChanged_T_Camera:
+		initCamera()
 	case protomsg.TableChanged_T_CameraPolygon://鏇存柊鎽勫儚鏈哄鍙樺舰
 		initPolygons()
 	case protomsg.TableChanged_T_TimeRule://鏇存柊鏃堕棿瑙勫垯
 		initTimeRules()
+	case protomsg.TableChanged_T_CameraTask://鏇存柊鎽勫儚鏈鸿鍒欓厤缃弬鏁�
+		initCameraTaskRules()
 	case protomsg.TableChanged_T_CameraTaskArgs://鏇存柊鎽勫儚鏈鸿鍒欓厤缃弬鏁�
 		initCameraTaskRules()
+	case protomsg.TableChanged_T_Sdk://鏇存柊sdk閰嶇疆
+		initSdks()
 	default:
 		fmt.Println("unknown operation")
 
@@ -93,18 +108,19 @@
 func initPolygons(){
 	var api dbapi.CameraApi
 	data := api.FindAllPolygons()
+	pMap :=make(map[string][]protomsg.CameraPolygon,0)
 	for _, item := range data {
 		if item.Type != "line" {
 			cameraId :=item.CameraId
-			arr, b := cMap.Get(PREFIX_POLYGON + cameraId)
-			if b {
-				list := arr.([]protomsg.CameraPolygon)
-				list = append(list,item)
-				cMap.Set(PREFIX_POLYGON + cameraId,list)
-			} else {
-				cMap.Set(PREFIX_POLYGON + cameraId,[]protomsg.CameraPolygon{ item })
+			if _,ok :=pMap[cameraId];ok{
+				pMap[cameraId] = append(pMap[cameraId],item)
+			} else{
+				pMap[cameraId]=[]protomsg.CameraPolygon{item}
 			}
 		}
+	}
+	for k,v :=range pMap{
+		cMap.Set(PREFIX_POLYGON + k,v)
 	}
 }
 
@@ -124,6 +140,14 @@
 
 	for _, taskArg := range all {
 		cMap.Set(PREFIX_RULE+taskArg.CameraId,taskArg.TaskArgs)
+	}
+}
+
+func initSdks(){
+	var api dbapi.SdkApi
+	sdks := api.FindAll("")
+	for _,sdk :=range sdks {
+		cMap.Set(PREFIX_SDK+sdk.Id,sdk)
 	}
 }
 
@@ -173,4 +197,32 @@
 	} else {
 		return nil
 	}
+}
+
+func GetSdkById(sdkId string) (sdk protomsg.Sdk,err error){
+	obj,b :=cMap.Get(PREFIX_SDK + sdkId)
+	if b {
+		return obj.(protomsg.Sdk),nil
+	} else {
+		return sdk,errors.New("sdk not found")
+	}
+}
+
+func initSoData() {
+	var api dbapi.SoApi
+	soinfos := api.FindAll()
+	logger.Debug("=====================娉ㄥ唽琛ㄤ俊鎭細")
+	for _,soinfo :=range soinfos {
+		logger.Debug(soinfo)
+		cMap.Set(PREFIX_SO+soinfo.SdkId,soinfo)
+	}
+}
+
+func GetSoInfoById(sdkId string) (sdk protomsg.SoInfo,err error){
+	obj,b :=cMap.Get(PREFIX_SO + sdkId)
+	if b {
+		return obj.(protomsg.SoInfo),nil
+	} else {
+		return sdk,errors.New("sdk not found")
+	}
 }
\ No newline at end of file

--
Gitblit v1.8.0