Files
PandaX/apps/device/api/device_cmd.go

78 lines
2.4 KiB
Go

package api
// ==========================================================================
import (
"github.com/PandaXGO/PandaKit/biz"
"github.com/PandaXGO/PandaKit/model"
"github.com/PandaXGO/PandaKit/restfulx"
"pandax/iothub/client/mqttclient"
"pandax/iothub/client/tcpclient"
"pandax/pkg/global"
"pandax/pkg/tool"
"strings"
"time"
"pandax/apps/device/entity"
"pandax/apps/device/services"
)
type DeviceCmdLogApi struct {
DeviceCmdLogApp services.DeviceCmdLogModel
DeviceApp services.DeviceModel
}
// GetDeviceCmdLogList 告警列表数据
func (p *DeviceCmdLogApi) GetDeviceCmdLogList(rc *restfulx.ReqCtx) {
data := entity.DeviceCmdLog{}
pageNum := restfulx.QueryInt(rc, "pageNum", 1)
pageSize := restfulx.QueryInt(rc, "pageSize", 10)
data.DeviceId = restfulx.QueryParam(rc, "deviceId")
data.State = restfulx.QueryParam(rc, "state")
data.Type = restfulx.QueryParam(rc, "type")
list, total := p.DeviceCmdLogApp.FindListPage(pageNum, pageSize, data)
rc.ResData = model.ResultPage{
Total: total,
PageNum: int64(pageNum),
PageSize: int64(pageSize),
Data: list,
}
}
// InsertDeviceCmdLog 添加DeviceCmdLog
func (p *DeviceCmdLogApi) InsertDeviceCmdLog(rc *restfulx.ReqCtx) {
var data entity.DeviceCmdLog
restfulx.BindJsonAndValid(rc, &data)
data.Id = tool.GenerateID()
data.State = "2"
data.RequestTime = time.Now().Format("2006-01-02 15:04:05")
one := p.DeviceApp.FindOne(data.DeviceId)
biz.IsTrue(one.LinkStatus == global.ONLINE, "设备不在线无法下发指令")
if one.Product.ProtocolName == global.TCPProtocol {
err := tcpclient.Send(data.DeviceId, data.CmdContent)
biz.ErrIsNil(err, "指令下发失败")
data.State = "0"
data.ResponseTime = time.Now().Format("2006-01-02 15:04:05.000")
}
if one.Product.ProtocolName == global.MQTTProtocol {
// 下发指令
var rpc = &mqttclient.RpcRequest{Client: mqttclient.MqttClient, Mode: data.Mode}
rpc.GetRequestId()
res, err := rpc.RequestCmd(mqttclient.RpcPayload{Method: data.CmdName, Params: data.CmdContent})
biz.ErrIsNil(err, "指令下发失败")
data.State = "0"
data.ResponseTime = time.Now().Format("2006-01-02 15:04:05.000")
data.CmdContent = res
}
err := p.DeviceCmdLogApp.Insert(data)
biz.ErrIsNil(err, "添加指令记录失败")
}
// DeleteDeviceCmdLog 删除告警
func (p *DeviceCmdLogApi) DeleteDeviceCmdLog(rc *restfulx.ReqCtx) {
id := restfulx.PathParam(rc, "id")
ids := strings.Split(id, ",")
p.DeviceCmdLogApp.Delete(ids)
}