1. 设备model增加地址字段, 用于保存硬件地址
2. 优化前端界面
This commit is contained in:
@@ -25,6 +25,11 @@ type DeviceRequest struct {
|
||||
Name string `json:"name" binding:"required"` // 设备名称,必填
|
||||
Type model.DeviceType `json:"type" binding:"required"` // 设备类型,必填
|
||||
ParentID *uint `json:"parent_id,omitempty"` // 父设备ID,可选
|
||||
Address *string `json:"address,omitempty"` // 设备地址,可选
|
||||
|
||||
// 485总线设备的额外字段
|
||||
BusNumber *int `json:"bus_number,omitempty"` // 485总线号
|
||||
DeviceAddress *string `json:"device_address,omitempty"` // 485设备地址
|
||||
}
|
||||
|
||||
// BindAndValidate 绑定并验证请求数据
|
||||
@@ -64,6 +69,45 @@ func (req *DeviceRequest) BindAndValidate(data []byte) error {
|
||||
}
|
||||
}
|
||||
|
||||
// 特殊处理address字段
|
||||
if addressVal, exists := raw["address"]; exists && addressVal != nil {
|
||||
switch v := addressVal.(type) {
|
||||
case string:
|
||||
// 如果是字符串,直接赋值
|
||||
if v != "" {
|
||||
req.Address = &v
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// 特殊处理bus_number字段
|
||||
if busNumberVal, exists := raw["bus_number"]; exists && busNumberVal != nil {
|
||||
switch v := busNumberVal.(type) {
|
||||
case float64:
|
||||
// JSON数字默认是float64类型
|
||||
busNumber := int(v)
|
||||
req.BusNumber = &busNumber
|
||||
case string:
|
||||
// 如果是字符串,尝试转换为int
|
||||
if v != "" && v != "null" {
|
||||
if busNumber, err := strconv.Atoi(v); err == nil {
|
||||
req.BusNumber = &busNumber
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// 特殊处理device_address字段
|
||||
if deviceAddressVal, exists := raw["device_address"]; exists && deviceAddressVal != nil {
|
||||
switch v := deviceAddressVal.(type) {
|
||||
case string:
|
||||
// 如果是字符串,直接赋值
|
||||
if v != "" {
|
||||
req.DeviceAddress = &v
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return nil
|
||||
}
|
||||
|
||||
@@ -113,12 +157,17 @@ func (c *Controller) Create(ctx *gin.Context) {
|
||||
return
|
||||
}
|
||||
|
||||
// TODO: 设备状态应该由系统自动获取,而不是由用户指定
|
||||
// 这里设置默认状态为active,后续需要实现自动状态检测
|
||||
device := &model.Device{
|
||||
Name: req.Name,
|
||||
Type: req.Type,
|
||||
ParentID: req.ParentID,
|
||||
Address: req.Address,
|
||||
}
|
||||
|
||||
// 如果是485总线设备且提供了总线号和设备地址,则合并为一个地址
|
||||
if (req.Type == model.DeviceTypeFan || req.Type == model.DeviceTypeWaterCurtain) &&
|
||||
req.BusNumber != nil && req.DeviceAddress != nil {
|
||||
device.Set485Address(*req.BusNumber, *req.DeviceAddress)
|
||||
}
|
||||
|
||||
if err := c.deviceRepo.Create(device); err != nil {
|
||||
@@ -175,6 +224,14 @@ func (c *Controller) Update(ctx *gin.Context) {
|
||||
device.Name = req.Name
|
||||
device.Type = req.Type
|
||||
device.ParentID = req.ParentID
|
||||
device.Address = req.Address
|
||||
// 如果是485总线设备且提供了总线号和设备地址,则合并为一个地址
|
||||
if (req.Type == model.DeviceTypeFan || req.Type == model.DeviceTypeWaterCurtain) &&
|
||||
req.BusNumber != nil && req.DeviceAddress != nil {
|
||||
device.Set485Address(*req.BusNumber, *req.DeviceAddress)
|
||||
}
|
||||
// TODO: 设备状态应该由系统自动获取,而不是由用户指定
|
||||
// 这里保持设备原有状态,后续需要实现自动状态检测
|
||||
// 设备状态现在只在内存中维护,不持久化到数据库
|
||||
|
||||
if err := c.deviceRepo.Update(device); err != nil {
|
||||
|
||||
Reference in New Issue
Block a user