From cab6eea89a0d82710369604ecb51f1cdb122e433 Mon Sep 17 00:00:00 2001
From: zhangqian <zhangqian@123.com>
Date: 星期四, 19 十月 2023 17:26:34 +0800
Subject: [PATCH] fix

---
 service/device_plc.go |   17 ++++++++++++++---
 1 files changed, 14 insertions(+), 3 deletions(-)

diff --git a/service/device_plc.go b/service/device_plc.go
index db1fd71..90c3e51 100644
--- a/service/device_plc.go
+++ b/service/device_plc.go
@@ -7,7 +7,8 @@
 	"apsClient/pkg/logx"
 	"apsClient/pkg/structx"
 	"encoding/json"
-	"gorm.io/gorm"
+	"errors"
+	"github.com/jinzhu/gorm"
 )
 
 type DevicePlcService struct{}
@@ -16,11 +17,10 @@
 	return DevicePlcService{}
 }
 
-func (DevicePlcService) GetDevicePlc() (*model.DevicePlc, int) {
+func (slf DevicePlcService) GetDevicePlc() (*model.DevicePlc, int) {
 	DevicePlc, err := model.NewDevicePlcSearch().SetOrder("id desc").First()
 	if err == gorm.ErrRecordNotFound {
 		return &model.DevicePlc{
-			Id:         0,
 			Brand:      "",
 			Method:     "",
 			Address:    "",
@@ -39,6 +39,17 @@
 	return DevicePlc, ecode.OK
 }
 
+func (slf DevicePlcService) GetDeviceChannelAmount() (int, error) {
+	plcConfig, code := slf.GetDevicePlc()
+	if code != ecode.OK || plcConfig.ID == 0 {
+		return 0, errors.New("鏈幏鍙栧埌PLC鍦板潃锛岃鍦ㄥ伐鑹烘ā鍨嬪簱涓笂浼狅紒")
+	}
+	if len(plcConfig.Details) == 0 {
+		return 0, errors.New("鏈幏鍙栧埌PLC鍦板潃锛岃鍦ㄥ伐鑹烘ā鍨嬪簱涓笂浼狅紒")
+	}
+	return len(plcConfig.Details) / 2, nil
+}
+
 func (DevicePlcService) UpdateDevicePlc(plc *request.UpdatePlc) int {
 	var record model.DevicePlc
 	err := structx.AssignTo(plc, &record)

--
Gitblit v1.8.0