// Copyright 2019 getensh.com. All rights reserved. // Use of this source code is governed by getensh.com. package suggestion import ( "context" "encoding/json" "fmt" "gorm.io/gorm" "property-garden/errors" "property-garden/impl/v1/oss_utils" "property-garden/impl/v1/public_msg" "property-garden/impl/v1/statistic" dbmodel "property-garden/model" pb_v1 "property-garden/pb/v1" "property-garden/utils" "time" "git.getensh.com/common/gopkgs/database" "git.getensh.com/common/gopkgs/logger" "go.uber.org/zap" "google.golang.org/grpc/status" ) func checkSuggestionOrderFinishParam(req *pb_v1.SuggestionOrderFinishRequest) error { switch { case req.Id == 0: return status.Error(10003, "id 不能为空") case req.GardenId == 0: return status.Error(10003, "小区不能为空") case req.LastUid < 1: return status.Error(10003, "当前操作人不能为空") } return nil } func SuggestionOrderFinish(ctx context.Context, req *pb_v1.SuggestionOrderFinishRequest) (reply *pb_v1.SuggestionOrderFinishReply, err error) { reply = &pb_v1.SuggestionOrderFinishReply{} // 捕获各个task中的异常并返回给调用者 defer func() { if r := recover(); r != nil { err = fmt.Errorf("%+v", r) e := &status.Status{} if er := json.Unmarshal([]byte(err.Error()), e); er != nil { logger.Error("err", zap.String("system_err", err.Error()), zap.Stack("stacktrace")) } } }() // 参数检查 err = checkSuggestionOrderFinishParam(req) if err != nil { return nil, err } dbname := utils.GetGardenDbName(req.GardenId) // 获取旧数据 old := dbmodel.NewSuggestionOrder(dbname) where := map[string]interface{}{ "id": req.Id, } err = old.Find(database.DB(), where) if err != nil && err != gorm.ErrRecordNotFound { return nil, errors.DataBaseError } if old.ID == 0 { return nil, errors.ErrRecordNotFound } if old.Status != SuggestionOrderStatusSend { return nil, status.Error(10003, "当前状态不支持该操作") } // 工单流水线 pipelineArray := []SuggestionOrderPipelineData{} json.Unmarshal([]byte(old.Pipeline), &pipelineArray) now := time.Now() pipeline := SuggestionOrderPipelineData{LastUid: req.LastUid, Status: SuggestionPipelineStatusFinish, LastByCompany: req.ByCompany, Feedback: req.Feedback, HandleTime: now.Format("2006-01-02 15:04:05")} pipelineArray = append(pipelineArray, pipeline) bytes, _ := json.Marshal(pipelineArray) // 更新新数据 repairOrder := dbmodel.NewSuggestionOrder(dbname) values := map[string]interface{}{ "status": SuggestionOrderStatusFinish, "last_uid": req.LastUid, "feedback": req.Feedback, "updated_at": now, "pipeline": string(bytes), "handle_pic": utils.StringJoin(req.HandlePic, ";"), "last_uid_is_company": req.ByCompany, "current_uid": 0, } if !req.ByCompany { values["current_uid"] = req.LastUid } where = map[string]interface{}{ "id": req.Id, } db := database.DB().Begin() err = repairOrder.Update(db, where, values) if err != nil { db.Rollback() return nil, errors.DataBaseError } statisticReq := pb_v1.RepairStatisticSetRequest{ HandleType: statistic.HandleTypeSuggestion, FinishIncrease: 1, GardenId: req.GardenId, } err = statistic.RepairStatisticSetWithDb(&statisticReq, db) if err != nil { db.Rollback() return nil, err } if err := oss_utils.OssObjAdd(req.HandlePic, nil); err != nil { db.Rollback() return nil, err } db.Commit() if old.HouseholdUid > 0 { serviceInfo := public_msg.ServiceInfo{ Name: "投诉建议", State: "已完成", } public_msg.SendMsgWx(old.HouseholdUid, req.GardenId, serviceInfo) } return reply, nil }