heyujie
2021-11-26 e904a0672267d8f1b25fe92d0b08282f8b5b8d18
deviceCtlApi.go
@@ -1,7 +1,7 @@
package bhomedbapi
import (
   "basic.com/valib/bhshmq.git/proto/source/bhome_msg"
   "basic.com/valib/c_bhomebus.git/proto/source/bhome_msg"
   "encoding/json"
)
@@ -9,11 +9,21 @@
}
func (api DeviceCtlApi) DevAuthApply(paramBody map[string]interface{}) (bool,interface{}) {
func (api DeviceCtlApi) DevAuthApply(targetIp string, fromDevId string, fromIp string, key string) (bool,interface{}) {
   url := DATA_URL_PREFIX + "/devAuth/apply"
   netNode := getNetNode(url2Topic(Topic_System_Service,url))
   dest := &bhome_msg.BHAddress{
      Ip: []byte(targetIp),
   }
   netNode := append([]*bhome_msg.MsgQueryTopicReply_BHNodeAddress{}, &bhome_msg.MsgQueryTopicReply_BHNodeAddress{
      Addr: dest,
   })
   client := NewClient(WithNodes(netNode))
   paramBody := map[string]interface{} {
      "key":       key,
      "fromDevId": fromDevId,
      "fromIp":    fromIp,
   }
   body,err := client.DoPutRequest(url,CONTENT_TYPE_JSON, paramBody,nil)
   if err != nil {
      return false,nil
@@ -27,12 +37,21 @@
   return res.Success,res.Data
}
func (api DeviceCtlApi) DevDetail(paramBody map[string]interface{}) (bool, interface{}) {
func (api DeviceCtlApi) DevDetail(targetIp string, devId string) (bool, interface{}) {
   url := DATA_URL_PREFIX + "/device/detail"
   netNode := getNetNode(url2Topic(Topic_System_Service,url))
   dest := &bhome_msg.BHAddress{
      Ip: []byte(targetIp),
   }
   netNode := append([]*bhome_msg.MsgQueryTopicReply_BHNodeAddress{}, &bhome_msg.MsgQueryTopicReply_BHNodeAddress{
      Addr: dest,
   })
   paramQuery := map[string]string {
      "devId": devId,
   }
   client := NewClient(WithNodes(netNode))
   body,err := client.DoPutRequest(url,CONTENT_TYPE_JSON, paramBody,nil)
   body,err := client.DoGetRequest(url,paramQuery,nil)
   if err != nil {
      return false,nil
   }
@@ -48,9 +67,11 @@
//控制其他节点创建集群
func (api DeviceCtlApi) RemoteCreateCluster(devId string, ip string, paramBody map[string]interface{}) (bool, interface{}) {
   url := DATA_URL_PREFIX + "/cluster/createCluster"
   netNode := append([]bhome_msg.BHAddress{}, bhome_msg.BHAddress{
   dest := &bhome_msg.BHAddress{
      Ip: []byte(ip),
   }
   netNode := append([]*bhome_msg.MsgQueryTopicReply_BHNodeAddress{}, &bhome_msg.MsgQueryTopicReply_BHNodeAddress{
      Addr: dest,
   })
   client := NewClient(WithNodes(netNode))
@@ -71,9 +92,11 @@
//控制其他节点搜索集群
func (api DeviceCtlApi) RemoteSearchCluster(devId string, ip string, paramBody map[string]interface{}) (bool, interface{}) {
   url := DATA_URL_PREFIX + "/cluster/search"
   netNode := append([]bhome_msg.BHAddress{}, bhome_msg.BHAddress{
   dest := &bhome_msg.BHAddress{
      Ip: []byte(ip),
   }
   netNode := append([]*bhome_msg.MsgQueryTopicReply_BHNodeAddress{}, &bhome_msg.MsgQueryTopicReply_BHNodeAddress{
      Addr: dest,
   })
   client := NewClient(WithNodes(netNode))
@@ -94,9 +117,11 @@
//获取远程设备搜索到集群节点列表
func (api DeviceCtlApi) RemoteGetSearchNodes(devId string, ip string, paramBody map[string]interface{}) (bool, interface{}) {
   url := DATA_URL_PREFIX + "/cluster/getSearchNodes"
   netNode := append([]bhome_msg.BHAddress{}, bhome_msg.BHAddress{
   dest := &bhome_msg.BHAddress{
      Ip: []byte(ip),
   }
   netNode := append([]*bhome_msg.MsgQueryTopicReply_BHNodeAddress{}, &bhome_msg.MsgQueryTopicReply_BHNodeAddress{
      Addr: dest,
   })
   client := NewClient(WithNodes(netNode))
@@ -117,9 +142,11 @@
//控制其他节点设备加入集群
func (api DeviceCtlApi) RemoteJoinCluster(devId string, ip string, paramBody map[string]interface{}) (bool, interface{}) {
   url := DATA_URL_PREFIX + "/cluster/joinCluster"
   netNode := append([]bhome_msg.BHAddress{}, bhome_msg.BHAddress{
   dest := &bhome_msg.BHAddress{
      Ip: []byte(ip),
   }
   netNode := append([]*bhome_msg.MsgQueryTopicReply_BHNodeAddress{}, &bhome_msg.MsgQueryTopicReply_BHNodeAddress{
      Addr: dest,
   })
   client := NewClient(WithNodes(netNode))
@@ -140,9 +167,11 @@
//远程控制设备重启
func (api DeviceCtlApi) RemoteReboot(devId string, ip string) (bool, interface{}) {
   url := DATA_URL_PREFIX + "/sysset/reboot"
   netNode := append([]bhome_msg.BHAddress{}, bhome_msg.BHAddress{
   dest := &bhome_msg.BHAddress{
      Ip: []byte(ip),
   }
   netNode := append([]*bhome_msg.MsgQueryTopicReply_BHNodeAddress{}, &bhome_msg.MsgQueryTopicReply_BHNodeAddress{
      Addr: dest,
   })
   client := NewClient(WithNodes(netNode))
@@ -165,9 +194,11 @@
//远程控制算法或应用卸载
func (api DeviceCtlApi) RemoteUninstall(devId string, ip string, id string) (bool, interface{}) {
   url := DATA_URL_PREFIX + "/sdk/remoteUninstall"
   netNode := append([]bhome_msg.BHAddress{}, bhome_msg.BHAddress{
   dest := &bhome_msg.BHAddress{
      Ip: []byte(ip),
   }
   netNode := append([]*bhome_msg.MsgQueryTopicReply_BHNodeAddress{}, &bhome_msg.MsgQueryTopicReply_BHNodeAddress{
      Addr: dest,
   })
   client := NewClient(WithNodes(netNode))
@@ -190,10 +221,13 @@
//远程控制设备系统更新
func (api DeviceCtlApi) RemoteSysUpdate(devId string, ip string) (bool, interface{}) {
   url := DATA_URL_PREFIX + "/sysset/remoteSysUpdate"
   netNode := append([]bhome_msg.BHAddress{}, bhome_msg.BHAddress{
   dest := &bhome_msg.BHAddress{
      Ip: []byte(ip),
   }
   netNode := append([]*bhome_msg.MsgQueryTopicReply_BHNodeAddress{}, &bhome_msg.MsgQueryTopicReply_BHNodeAddress{
      Addr: dest,
   })
   client := NewClient(WithNodes(netNode))
   body,err := client.DoPutRequest(url,CONTENT_TYPE_JSON, nil,nil)