From 092c444722bd41281f89a584f3e3e8957fc9c909 Mon Sep 17 00:00:00 2001
From: chenshijun <csj_sky@126.com>
Date: 星期四, 10 十月 2019 20:43:13 +0800
Subject: [PATCH] 增加分组的接口

---
 gb28181Api.go |  252 ++++++++++++++++++++++++++++++++++++++++++++++----
 1 files changed, 231 insertions(+), 21 deletions(-)

diff --git a/gb28181Api.go b/gb28181Api.go
index 4093c7b..d9d6560 100644
--- a/gb28181Api.go
+++ b/gb28181Api.go
@@ -4,6 +4,7 @@
 	"bytes"
 	"encoding/json"
 	"fmt"
+	"log"
 	"strconv"
 )
 
@@ -42,12 +43,12 @@
 	var res GbResult
 	// fmt.Println("body", string(body))
 	if err = json.Unmarshal(body, &res); err != nil {
-		fmt.Println("jsonErr:", err)
+		log.Println("jsonErr:", err)
 		return false
 	}
 
 	if res.ErrCode != 0 {
-		fmt.Println("errcode: ", res.ErrCode, " errdesc: ", res.ErrDesc)
+		log.Println("errcode: ", res.ErrCode, " errdesc: ", res.ErrDesc)
 		return false
 	}
 
@@ -67,18 +68,18 @@
 	var info GbServerInfo
 	body, err := client.DoGetRequest(url, nil, nil)
 	if err != nil {
-		fmt.Println("err:", err)
+		log.Println("err:", err)
 		return info, false
 	}
 
 	//瑙f瀽retGbServerInfo
 	var res retGbServerInfo
 	if err = json.Unmarshal(body, &res); err != nil {
-		fmt.Println("jsonErr:", err)
+		log.Println("jsonErr:", err)
 		return info, false
 	}
 	if res.ErrCode != 0 {
-		fmt.Println("errcode: ", res.ErrCode, " errdesc: ", res.ErrDesc)
+		log.Println("errcode: ", res.ErrCode, " errdesc: ", res.ErrDesc)
 		return info, false
 	}
 
@@ -94,17 +95,17 @@
 	var devicesPerPage DevicesInOnePage
 	body, err := client.DoGetRequest(url, nil, nil)
 	if err != nil {
-		fmt.Println("err:", err)
+		log.Println("err:", err)
 		return devicesPerPage, false
 	}
 
 	//瑙f瀽 DevicesInOnePage
 	if err = json.Unmarshal(body, &devicesPerPage); err != nil {
-		fmt.Println("jsonErr:", err)
+		log.Println("jsonErr:", err)
 		return devicesPerPage, false
 	}
 	if devicesPerPage.ErrCode != 0 {
-		fmt.Println("errcode: ", devicesPerPage.ErrCode, " errdesc: ", devicesPerPage.ErrDesc)
+		log.Println("errcode: ", devicesPerPage.ErrCode, " errdesc: ", devicesPerPage.ErrDesc)
 		return devicesPerPage, false
 	}
 
@@ -116,7 +117,7 @@
 	var deviceSlice []DeviceInfo
 	devicesPerPage, flag := api.GetDevicesByPageNO(1)
 	if !flag {
-		fmt.Println("GetDevicesByPageNO Error, deviceSlice is nil")
+		log.Println("GetDevicesByPageNO Error, deviceSlice is nil")
 		return deviceSlice, false
 	}
 	deviceSlice = devicesPerPage.Data
@@ -124,7 +125,7 @@
 	for i := 1; i < devicesPerPage.TotalPage; i++ {
 		devicesPerPage, flag := api.GetDevicesByPageNO(i + 1)
 		if !flag {
-			fmt.Println("GetDevicesByPageNO Error,pageno:" + strconv.Itoa(i+1) + " ,deviceSlice is not completed")
+			log.Println("GetDevicesByPageNO Error,pageno:" + strconv.Itoa(i+1) + " ,deviceSlice is not completed")
 			return deviceSlice, false
 		}
 		deviceSlice = append(deviceSlice, devicesPerPage.Data...)
@@ -145,25 +146,25 @@
 	var camerasPerPage CamerasInOnePage
 	body, err := client.DoGetRequest(url, nil, nil)
 	if err != nil {
-		fmt.Println("err:", err)
+		log.Println("err:", err)
 		return camerasPerPage, false
 	}
 
 	//瑙f瀽 CamerasInOnePage
 	if err = json.Unmarshal(body, &camerasPerPage); err != nil {
-		fmt.Println("jsonErr:", err)
+		log.Println("jsonErr:", err)
 		return camerasPerPage, false
 	}
 	if camerasPerPage.ErrCode != 0 {
-		fmt.Println("errcode: ", camerasPerPage.ErrCode, " errdesc: ", camerasPerPage.ErrDesc)
+		log.Println("errcode: ", camerasPerPage.ErrCode, " errdesc: ", camerasPerPage.ErrDesc)
 		return camerasPerPage, false
 	}
 
 	if len(camerasPerPage.Data) > 0 {
-		for i, v := range camerasPerPage.Data {
-			if v.ResType == 2 {
-				fmt.Println("v.restype == 2")
+		for i := 0; i < len(camerasPerPage.Data); i++ {
+			if camerasPerPage.Data[i].ResType == 2 {
 				camerasPerPage.Data = append(camerasPerPage.Data[:i], camerasPerPage.Data[i+1:]...)
+				i--
 			}
 		}
 	}
@@ -177,7 +178,7 @@
 	var cameraSlice []CameraInfo
 	camerasPerPage, flag := api.GetCamsByDevAndPage(devID, "all", 1)
 	if !flag {
-		fmt.Println("GetCamsByDevAndPage Error, deviceSlice is nil")
+		log.Println("GetCamsByDevAndPage Error, deviceSlice is nil")
 		return cameraSlice, false
 	}
 	cameraSlice = camerasPerPage.Data
@@ -185,7 +186,216 @@
 	for i := 1; i < camerasPerPage.TotalPage; i++ {
 		camerasPerPage, flag := api.GetCamsByDevAndPage(devID, "all", i+1)
 		if !flag {
-			fmt.Println("GetCamsByDevAndPage Error! devID:" + devID + ",type:all,pageno:" + strconv.Itoa(i+1) + " ,cameraSlice is not completed")
+			log.Println("GetCamsByDevAndPage Error! devID:" + devID + ",type:all,pageno:" + strconv.Itoa(i+1) + " ,cameraSlice is not completed")
+			return cameraSlice, false
+		}
+		cameraSlice = append(cameraSlice, camerasPerPage.Data...)
+	}
+
+	return cameraSlice, true
+}
+
+//GetAllDomainUnit get all domainunit 鑾峰彇鎵�鏈夎鏀垮尯鍩�
+func (api Gb28181Api) GetAllDomainUnit() ([]DomainUnit, bool) {
+	url := BASIC_URL + DATA_URL_PREFIX + "/get_all_domainunit"
+	client := NewClient()
+
+	var dmUnit DomainUnitInfo
+	body, err := client.DoGetRequest(url, nil, nil)
+	if err != nil {
+		log.Println("err:", err)
+		return dmUnit.Data, false
+	}
+
+	//瑙f瀽 dmUnit
+	if err = json.Unmarshal(body, &dmUnit); err != nil {
+		log.Println("jsonErr:", err)
+		return dmUnit.Data, false
+	}
+	if dmUnit.ErrCode != 0 {
+		log.Println("errcode: ", dmUnit.ErrCode, " errdesc: ", dmUnit.ErrDesc)
+		return dmUnit.Data, false
+	}
+
+	return dmUnit.Data, true
+}
+
+//GetAllCamerasByDomainUnit  get all cameras by domainunit 鑾峰彇鎵�鏈夎鏀垮尯鍩熶笅鐨勮澶�
+func (api Gb28181Api) GetAllCamerasByDomainUnitAndPage(domainpubid string, pageNo int) (CamerasInOnePage, bool) {
+	url := BASIC_URL + DATA_URL_PREFIX + "/get_domainunit_channel/" + domainpubid + "/" + strconv.Itoa(pageNo)
+	client := NewClient()
+
+	var camerasPerPage CamerasInOnePage
+	body, err := client.DoGetRequest(url, nil, nil)
+	if err != nil {
+		log.Println("err:", err)
+		return camerasPerPage, false
+	}
+
+	//瑙f瀽 CamerasInOnePage
+	if err = json.Unmarshal(body, &camerasPerPage); err != nil {
+		log.Println("jsonErr:", err)
+		return camerasPerPage, false
+	}
+	if camerasPerPage.ErrCode != 0 {
+		log.Println("errcode: ", camerasPerPage.ErrCode, " errdesc: ", camerasPerPage.ErrDesc)
+		return camerasPerPage, false
+	}
+
+	return camerasPerPage, true
+}
+
+//GetAllCamerasByDevID 鑾峰彇鎸囧畾琛屾斂鍖哄煙鐨勬憚鍍忔満鍒楄〃
+func (api Gb28181Api) GetAllCamerasByDomainUnit(domainpubid string) ([]CameraInfo, bool) {
+	var cameraSlice []CameraInfo
+	camerasPerPage, flag := api.GetAllCamerasByDomainUnitAndPage(domainpubid, 1)
+	if !flag {
+		log.Println("GetCamsByDevAndPage Error, deviceSlice is nil")
+		return cameraSlice, false
+	}
+	cameraSlice = camerasPerPage.Data
+
+	for i := 1; i < camerasPerPage.TotalPage; i++ {
+		camerasPerPage, flag := api.GetAllCamerasByDomainUnitAndPage(domainpubid, i+1)
+		if !flag {
+			log.Println("GetCamsByDevAndPage Error! devID:" + domainpubid + ",type:all,pageno:" + strconv.Itoa(i+1) + " ,cameraSlice is not completed")
+			return cameraSlice, false
+		}
+		cameraSlice = append(cameraSlice, camerasPerPage.Data...)
+	}
+
+	return cameraSlice, true
+}
+
+//getAllGroupBygroupIDAndpage get all group by groupID ang page 鎸夐〉鍜岀粍id鑾峰彇涓嬪睘鍒嗙粍
+func (api Gb28181Api) getAllGroupBygroupIDAndpage(groupID string, pageNo int) ([]DomainUnit, bool) {
+	url := BASIC_URL + DATA_URL_PREFIX + "/get_all_channel/" + groupID + "/node/" + strconv.Itoa(pageNo)
+	client := NewClient()
+
+	var camerasPerPage CamerasInOnePage
+	body, err := client.DoGetRequest(url, nil, nil)
+	if err != nil {
+		log.Println("err:", err)
+		return nil, false
+	}
+
+	if camerasPerPage.ErrCode != 0 {
+		log.Println("errcode: ", camerasPerPage.ErrCode, " errdesc: ", camerasPerPage.ErrDesc)
+		return nil, false
+	}
+
+	//瑙f瀽 cameras
+	//log.Println("body:", body)
+	if err = json.Unmarshal(body, &camerasPerPage); err != nil {
+		log.Println("jsonErr:", err)
+		return nil, false
+	}
+
+	//cameraInfo 杞� DomainUnit
+	var dmUnits []DomainUnit
+	var tmpUnit DomainUnit
+	for _, cam := range camerasPerPage.Data {
+		if cam.ResType == 2 {
+			tmpUnit.Name = cam.Name
+			tmpUnit.DevPubID = cam.DevPubID
+			tmpUnit.OnlineNum = 0
+			tmpUnit.ParentID = cam.ParentID
+			tmpUnit.PublicID = cam.PublicID
+			tmpUnit.ResType = cam.ResType
+			tmpUnit.TotalNum = 0
+			dmUnits = append(dmUnits, tmpUnit)
+		}
+	}
+
+	return dmUnits, true
+}
+
+//GetAllGroupByDevID  鎸夌粍id鑾峰彇涓嬪睘鍒嗙粍
+func (api Gb28181Api) getAllGroupByGroupID(groupID string) []DomainUnit {
+	var dmUnitAll []DomainUnit
+	pageNo := 1
+	for {
+		dmUnitsPerPage, flag := api.getAllGroupBygroupIDAndpage(groupID, pageNo)
+		if !flag || dmUnitsPerPage == nil {
+			break
+		}
+		dmUnitAll = append(dmUnitAll, dmUnitsPerPage...)
+		pageNo++
+	}
+
+	return dmUnitAll
+}
+
+//
+func (api Gb28181Api) getGroupsByGroupID(groupID string, groupsAll *[]DomainUnit) {
+	if groupID != "" {
+		groups := api.getAllGroupByGroupID(groupID)
+		if groups == nil {
+			return
+		}
+		if len(groups) > 0 {
+			*groupsAll = append(*groupsAll, groups...)
+			for _, groupid := range groups {
+				api.getGroupsByGroupID(groupid.PublicID, groupsAll)
+			}
+		}
+	}
+}
+
+//GetAllGroupByDevID get all group by devid 鎸夎澶噄d鑾峰彇鍒嗙粍
+func (api Gb28181Api) GetAllGroupBydevID(devID string) []DomainUnit {
+	var dmUnitAll []DomainUnit
+
+	api.getGroupsByGroupID(devID, &dmUnitAll)
+
+	return dmUnitAll
+}
+
+//getAllCamerasByGroupIDAndPage 鎸夊垎缁勫拰椤佃幏鍙栨憚鍍忔満鍒楄〃
+func (api Gb28181Api) getAllCamerasByGroupIDAndPage(groupID string, pageNo int) (CamerasInOnePage, bool) {
+	url := BASIC_URL + DATA_URL_PREFIX + "/get_all_channel/" + groupID + "/node/" + strconv.Itoa(pageNo)
+	client := NewClient()
+
+	var camerasPerPage CamerasInOnePage
+	body, err := client.DoGetRequest(url, nil, nil)
+	if err != nil {
+		log.Println("err:", err)
+		return camerasPerPage, false
+	}
+
+	//瑙f瀽 cameras
+	if err = json.Unmarshal(body, &camerasPerPage); err != nil {
+		log.Println("jsonErr:", err)
+		return camerasPerPage, false
+	}
+
+	if len(camerasPerPage.Data) > 0 {
+		for i := 0; i < len(camerasPerPage.Data); i++ {
+			if camerasPerPage.Data[i].ResType == 2 {
+				camerasPerPage.Data = append(camerasPerPage.Data[:i], camerasPerPage.Data[i+1:]...)
+				i--
+			}
+		}
+	}
+
+	return camerasPerPage, true
+}
+
+//GetAllGroupByDevID get all group by devid 鎸夎澶噄d鑾峰彇鍒嗙粍
+func (api Gb28181Api) GetAllCamerasByGroupID(groupID string) ([]CameraInfo, bool) {
+
+	var cameraSlice []CameraInfo
+	camerasPerPage, flag := api.getAllCamerasByGroupIDAndPage(groupID, 1)
+	if !flag {
+		log.Println("GetCamsByDevAndPage Error, deviceSlice is nil")
+		return cameraSlice, false
+	}
+	cameraSlice = camerasPerPage.Data
+
+	for i := 1; i < camerasPerPage.TotalPage; i++ {
+		camerasPerPage, flag := api.getAllCamerasByGroupIDAndPage(groupID, i+1)
+		if !flag {
+			log.Println("getAllCamerasByGroupIDAndPage Error! devID:" + groupID + ",type:all,pageno:" + strconv.Itoa(i+1) + " ,cameraSlice is not completed")
 			return cameraSlice, false
 		}
 		cameraSlice = append(cameraSlice, camerasPerPage.Data...)
@@ -205,18 +415,18 @@
 
 	body, err := client.DoGetRequest(url, nil, nil)
 	if err != nil {
-		fmt.Println("err:", err)
+		log.Println("err:", err)
 		return false
 	}
 
 	//瑙f瀽 CamerasInOnePage
 	var res GbResult
 	if err = json.Unmarshal(body, &res); err != nil {
-		fmt.Println("jsonErr:", err)
+		log.Println("jsonErr:", err)
 		return false
 	}
 	if res.ErrCode != 0 {
-		fmt.Println("errcode: ", res.ErrCode, " errdesc: ", res.ErrDesc)
+		log.Println("errcode: ", res.ErrCode, " errdesc: ", res.ErrDesc)
 		return false
 	}
 

--
Gitblit v1.8.0