package service
|
|
import (
|
"apsClient/conf"
|
"apsClient/constvar"
|
"apsClient/model"
|
"apsClient/model/common"
|
"apsClient/model/response"
|
"apsClient/nsq"
|
"apsClient/pkg/ecode"
|
"apsClient/pkg/logx"
|
"apsClient/pkg/structx"
|
"encoding/json"
|
"fmt"
|
"gorm.io/gorm"
|
"time"
|
)
|
|
type TaskService struct {
|
}
|
|
func NewTaskService() *TaskService {
|
return &TaskService{}
|
}
|
|
// GetTask 获取任务,未完成的开始时间最早的任务
|
func (slf TaskService) GetTask() (taskData *response.TaskData, code int) {
|
if v, ok := TaskCacheGet(); ok {
|
return v, ecode.OK
|
}
|
|
nowTs := time.Now().Unix()
|
var (
|
err error
|
order *model.Order
|
procedure *model.Procedures
|
)
|
procedure, err = model.NewProceduresSearch(nil).SetOrder("start_time asc").
|
SetStartTimeMax(nowTs).
|
SetDeviceId(conf.Conf.System.DeviceId).
|
SetStatusNot(model.ProcedureStatusFinished).
|
First()
|
if err == gorm.ErrRecordNotFound {
|
return nil, ecode.OK
|
}
|
|
order, err = model.NewOrderSearch(nil).SetWorkOrderId(procedure.WorkOrderID).First() //由工序反推工单
|
if err == gorm.ErrRecordNotFound {
|
err = nil
|
return nil, ecode.OK
|
}
|
if err != nil {
|
return nil, ecode.DBErr
|
}
|
taskData = new(response.TaskData)
|
taskData.Order = order
|
taskData.Procedure = procedure
|
TaskCacheSet(taskData)
|
return taskData, ecode.OK
|
}
|
|
func (slf TaskService) GetProcedureById(id int) (*model.Procedures, int) {
|
procedure, err := model.NewProceduresSearch(nil).SetId(id).First()
|
if err != nil {
|
return nil, ecode.DBErr
|
}
|
return procedure, ecode.OK
|
}
|
|
func (slf TaskService) UpdateProcedureStatus(db *gorm.DB, id int, status model.ProcedureStatus) error {
|
if status == model.ProcedureStatusFinished {
|
TaskCacheUnset()
|
ProgressCacheUnset()
|
}
|
return model.NewProceduresSearch(db).SetId(id).UpdateByMap(map[string]interface{}{
|
"status": status,
|
})
|
}
|
|
func (slf TaskService) UpdateOrderStatus(db *gorm.DB, id uint, status model.OrderStatus) error {
|
return model.NewOrderSearch(db).SetId(id).UpdateByMap(map[string]interface{}{
|
"status": status,
|
})
|
}
|
|
func (slf TaskService) GetOrderByWorkOrderId(workOrderId string) (order *model.Order, err error) {
|
return model.NewOrderSearch(nil).SetWorkOrderId(workOrderId).First()
|
}
|
|
func (slf TaskService) GetProcessParams(procedure *model.Procedures, order *model.Order) (processModel *model.ProcessModel, err error) {
|
data, err := model.NewProcessModelSearch().
|
SetWorkOrder(procedure.WorkOrderID).
|
SetDevice(procedure.ProceduresInfo.DeviceName).
|
SetOrderId(procedure.OrderID).
|
SetProcedure(procedure.ProceduresInfo.ProcedureName).
|
SetProduct(order.ProductName).
|
SetOrder("id desc").First()
|
if err != nil && err != gorm.ErrRecordNotFound {
|
logx.Errorf("TaskStart GetProcessModel err:%v", err)
|
return nil, err
|
}
|
if err == nil {
|
err = json.Unmarshal([]byte(data.Params), &data.ParamsMap)
|
if err != nil {
|
logx.Errorf("process model json.Unmarshal:%v", err)
|
return
|
}
|
return data, nil
|
}
|
|
if err == gorm.ErrRecordNotFound { //如果数据库没有从云端获取
|
caller := nsq.NewCaller(fmt.Sprintf(constvar.NsqTopicProcessParamsRequest, conf.Conf.NsqConf.NodeId), fmt.Sprintf(constvar.NsqTopicProcessParamsResponse, conf.Conf.NsqConf.NodeId))
|
var result common.ResponseProcessParams
|
err = caller.Call(common.RequestProcessParams{
|
WorkOrder: procedure.WorkOrderID,
|
OrderId: procedure.OrderID,
|
Product: order.ProductName,
|
Procedure: procedure.ProceduresInfo.ProcedureName,
|
Device: procedure.ProceduresInfo.DeviceName,
|
DeviceId: conf.Conf.System.DeviceId,
|
}, &result, time.Second*3)
|
if err != nil {
|
logx.Errorf("TaskStart GetProcessModel error:%v", err.Error())
|
return
|
}
|
if result.ParamsMap == nil {
|
logx.Errorf("TaskStart GetProcessModel response miss process params:%v", result)
|
return
|
}
|
processModel = new(model.ProcessModel)
|
err = structx.AssignTo(result, &processModel)
|
return processModel, err
|
}
|
return
|
}
|
|
// GetNextTask 获取未开始的任务
|
func (slf TaskService) GetNextTask() (workOrder *model.Order, err error) {
|
nowTs := time.Now().Unix()
|
orderSearch := model.NewOrderSearch(nil)
|
return orderSearch.SetOrder("start_time asc").
|
SetStartTimeMin(nowTs).
|
SetStatus(model.OrderStatusWaitProcess).First()
|
}
|