From 3817b0e527eadc47d7fe32cd5d73278b3d867b58 Mon Sep 17 00:00:00 2001
From: zhangqian <zhangqian@123.com>
Date: 星期四, 09 十一月 2023 14:21:45 +0800
Subject: [PATCH] 按是否需求设置工艺参数的配置决定是否下发工艺参数

---
 service/device.go        |   11 +++++++++++
 model/response/common.go |    6 +++---
 api/v1/task.go           |   24 +++++++++++++++++-------
 3 files changed, 31 insertions(+), 10 deletions(-)

diff --git a/api/v1/task.go b/api/v1/task.go
index 439a8d7..60f6b8d 100644
--- a/api/v1/task.go
+++ b/api/v1/task.go
@@ -271,22 +271,32 @@
 		ctx.Ok()
 		return
 	}
-	processModel, err := taskService.GetProcessParams(procedure, order)
-	if err != nil || processModel == nil || processModel.ParamsMap == nil {
-		ctx.FailWithMsg(ecode.ParamsErr, "鏈幏鍙栧埌宸ヨ壓鍙傛暟锛岃鍦ㄥ伐鑹烘ā鍨嬪簱涓笂浼狅紒")
-		return
-	}
+
 	plcConfig, code := service.NewDevicePlcService().GetDevicePlc()
 	if code != ecode.OK || plcConfig.ID == 0 {
 		ctx.FailWithMsg(ecode.NeedConfirmedErr, "璇峰厛閰嶇疆PLC")
 		return
 	}
 	plcConfig.MaxTryTimes = 2
-	err = SendParams(processModel.ParamsMap, plcConfig)
+
+	device, err := service.GetCurrentDevice()
 	if err != nil {
-		ctx.FailWithMsg(ecode.NeedConfirmedErr, "PLC璇锋眰澶辫触锛岃妫�鏌LC閰嶇疆锛�")
+		ctx.FailWithMsg(ecode.DBErr, err.Error())
 		return
 	}
+	if device.NeedSetProcessParams {
+		processModel, err := taskService.GetProcessParams(procedure, order)
+		if err != nil || processModel == nil || processModel.ParamsMap == nil {
+			ctx.FailWithMsg(ecode.ParamsErr, "鏈幏鍙栧埌宸ヨ壓鍙傛暟锛岃鍦ㄥ伐鑹烘ā鍨嬪簱涓笂浼狅紒")
+			return
+		}
+		err = SendParams(processModel.ParamsMap, plcConfig)
+		if err != nil {
+			ctx.FailWithMsg(ecode.NeedConfirmedErr, "PLC璇锋眰澶辫触锛岃妫�鏌LC閰嶇疆锛�")
+			return
+		}
+	}
+
 	plcConfig.CurrentTryTimes = 0
 	err = service.PlcWrite(plcConfig, constvar.PlcStartAddressTypeTotalNumber, procedure.Channel, order.Amount.IntPart())
 	if err != nil {
diff --git a/model/response/common.go b/model/response/common.go
index 7c1e634..79457c5 100644
--- a/model/response/common.go
+++ b/model/response/common.go
@@ -80,9 +80,9 @@
 )
 
 type Device struct {
-	DeviceID             string `json:"deviceID,omitempty"`
-	DeviceName           string `json:"deviceName,omitempty"`
-	NeedSetProcessParams bool   `json:"needSetProcessParams,omitempty"` //鏄惁闇�瑕佽缃伐鑹哄弬鏁�
+	DeviceID             string `json:"deviceID"`
+	DeviceName           string `json:"deviceName"`
+	NeedSetProcessParams bool   `json:"needSetProcessParams"` //鏄惁闇�瑕佽缃伐鑹哄弬鏁�
 }
 
 type DeviceListResponse struct {
diff --git a/service/device.go b/service/device.go
index f09559e..99e7891 100644
--- a/service/device.go
+++ b/service/device.go
@@ -95,3 +95,14 @@
 	device.NeedSetProcessParams = needSetProcessParams
 	return model.NewDeviceSearch().SetID(device.ID).Save(device)
 }
+
+func GetCurrentDevice() (device *model.Device, err error) {
+	if conf.Conf.CurrentDeviceID == "" {
+		return nil, errors.New("褰撳墠璁惧ID涓嶅瓨鍦紝璇锋鏌�")
+	}
+	device, err = model.NewDeviceSearch().SetDeviceId(conf.Conf.CurrentDeviceID).First()
+	if err == gorm.ErrRecordNotFound {
+		return nil, errors.New("璁惧涓嶅瓨鍦�")
+	}
+	return device, nil
+}

--
Gitblit v1.8.0