From b04d36589f44e3dbc163a0a2a64fc765773d8c64 Mon Sep 17 00:00:00 2001
From: liuxiaolong <736321739@qq.com>
Date: 星期二, 02 七月 2019 11:45:29 +0800
Subject: [PATCH] add camera and localconfig cache

---
 cache/cache.go |   39 +++++++++++++++++++++++++++++++++++++++
 1 files changed, 39 insertions(+), 0 deletions(-)

diff --git a/cache/cache.go b/cache/cache.go
index f72a1e0..70af5aa 100644
--- a/cache/cache.go
+++ b/cache/cache.go
@@ -11,9 +11,11 @@
 	"strconv"
 )
 const (
+	PREFIX_CAMERA = "CAMERA_"
 	PREFIX_POLYGON = "POLYGON_"
 	PREFIX_TIME = "TIME_"
 	PREFIX_RULE = "RULE_"
+	SERVER_KEY = "SERVERINFO"
 )
 
 var cMap *shardmap.ShardMap
@@ -44,6 +46,10 @@
 
 	initCameraTaskRules()//鍒濆鍖栨憚鍍忔満浠诲姟瑙勫垯缂撳瓨
 
+	initCamera()//鍒濆鍖栨憚鍍忔満淇℃伅
+
+	initServerInfo()//鍒濆鍖栨湇鍔″櫒閰嶇疆淇℃伅
+
 	initChan <- true
 }
 
@@ -64,6 +70,22 @@
 	default:
 		fmt.Println("unknown operation")
 
+	}
+}
+
+func initServerInfo() {
+	var api dbapi.SysSetApi
+	b, s := api.GetServerInfo()
+	if b{
+		cMap.Set(SERVER_KEY,s)
+	}
+}
+
+func initCamera() {
+	var api dbapi.CameraApi
+	cameras := api.FindAll()
+	for _,cam := range cameras {
+		cMap.Set(PREFIX_CAMERA + cam.Id,cam)
 	}
 }
 
@@ -104,7 +126,24 @@
 	}
 }
 
+func GetServerInfo() *protomsg.LocalConfig {
+	config, b := cMap.Get(SERVER_KEY)
+	if b {
+		return config.(*protomsg.LocalConfig)
+	} else {
+		return nil
+	}
+}
 
+//閫氳繃cameraId鑾峰彇鎽勫儚鏈轰俊鎭�
+func GetCameraById(cameraId string) *protomsg.Camera {
+	cam, b := cMap.Get(PREFIX_CAMERA + cameraId)
+	if b {
+		return cam.(*protomsg.Camera)
+	} else {
+		return nil
+	}
+}
 
 func GetPolygonsByCameraId(cameraId string) []protomsg.CameraPolygon{
 	obj, b := cMap.Get(PREFIX_POLYGON + cameraId)

--
Gitblit v1.8.0