From c51eac62d2d750b2324f464c0aa4562c7b957216 Mon Sep 17 00:00:00 2001
From: panlei <2799247126@qq.com>
Date: 星期五, 15 十一月 2019 18:18:52 +0800
Subject: [PATCH] ---
---
cache/cache.go | 66 +++++++++++++++++++++++++++++---
1 files changed, 59 insertions(+), 7 deletions(-)
diff --git a/cache/cache.go b/cache/cache.go
index 2071d96..ffb0912 100644
--- a/cache/cache.go
+++ b/cache/cache.go
@@ -5,6 +5,7 @@
"basic.com/pubsub/cache.git/shardmap"
"basic.com/pubsub/protomsg.git"
"basic.com/valib/gopherdiscovery.git"
+ "basic.com/valib/logger.git"
"errors"
"fmt"
"github.com/gogo/protobuf/proto"
@@ -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