package youngee_task_service import ( "youngmini_server/app/dao" "youngmini_server/app/model" "youngmini_server/app/model/youngee_talent_model" "github.com/gogf/gf/frame/g" "github.com/gogf/gf/net/ghttp" "github.com/gogf/gf/os/gtime" ) // 添加链接service func AddTaskLink(r *ghttp.Request) *TalentHttpResult { var LinkInfoReq *youngee_talent_model.AddTaskLinkRequest err := r.ParseForm(&LinkInfoReq) if err != nil { return &TalentHttpResult{Code: -1, Msg: err.Error()} } // 查询该任务id是否有未提交链接 // 查询该任务是否有未提交脚本,无则插入,有则更新 unSubmitLink, err := g.DB().Model(model.YounggeeLinkInfo{}).Where("task_id = ? and is_submit = 0", LinkInfoReq.TaskId).One() if err != nil { return &TalentHttpResult{Code: -2, Msg: "YounggeeLinkInfo find failed"} } if unSubmitLink != nil { _, err = g.DB().Model(model.YounggeeLinkInfo{}).Where("link_id = ?", unSubmitLink[dao.YounggeeLinkInfo.Columns.LinkId]).Delete() if err != nil { return &TalentHttpResult{Code: -3, Msg: "YounggeeLinkInfo delete failed"} } } // 如果无未提交链接,则直接插入 LinkInfo := model.YounggeeLinkInfo{ TaskId: LinkInfoReq.TaskId, LinkUrl: LinkInfoReq.LinkUrl, PhotoUrl: LinkInfoReq.PhotoUrl, CreateAt: gtime.Now(), IsReview: 0, IsSubmit: 0, IsOk: 0, } _, err = g.DB().Model(model.YounggeeLinkInfo{}).Data(LinkInfo).Insert() if err != nil { return &TalentHttpResult{Code: -3, Msg: "YounggeeLinkInfo insert failed"} } LinkStatus, err := g.DB().Model(model.YoungeeTaskInfo{}).Fields("link_status").Where("task_id = ?", LinkInfoReq.TaskId).Value() if err != nil { return &TalentHttpResult{Code: -5, Msg: "Get task info failed"} } if LinkStatus.Int64() == 1 { _, err = g.Model(dao.YoungeeTaskInfo.Table).Where("task_id = ?", LinkInfoReq.TaskId).Update(g.Map{"link_status": 2}) if err != nil { return &TalentHttpResult{Code: -6, Msg: "YoungeeTaskInfo update failed"} } } else if LinkStatus.Int64() == 3 { _, err = g.Model(dao.YoungeeTaskInfo.Table).Where("task_id = ?", LinkInfoReq.TaskId).Update(g.Map{"link_status": 4}) if err != nil { return &TalentHttpResult{Code: -6, Msg: "YoungeeTaskInfo update failed"} } } return &TalentHttpResult{Code: 0, Msg: "success"} } // 提交链接service func SubmitTaskLink(r *ghttp.Request) *TalentHttpResult { taskId, _ := r.Get("task_id").(string) taskInfo := model.YoungeeTaskInfo{} // 查询是否处于违约状态 err1 := g.DB().Model(model.YoungeeTaskInfo{}).Where("task_id = ?", taskId).Scan(&taskInfo) if err1 != nil { return &TalentHttpResult{Code: -1, Msg: "YoungeeTaskInfo find failed"} } if taskInfo.CurDefaultType == 5 || taskInfo.CurDefaultType == 9 { // 若处于违约状态则解除并更新企业应支付金额 _, err1 = g.DB().Model(model.YoungeeTaskInfo{}).Data(g.Map{"cur_default_type": "0", "real_payment": taskInfo.AllPayment, "err_break_rate": 0}).Where("task_id = ?", taskId).Update() if err1 != nil { return &TalentHttpResult{Code: -2, Msg: "YoungeeTaskInfo update failed"} } // 更新违约记录表 _, err1 = g.DB().Model(model.YoungeeContractInfo{}).Data(g.Map{"default_status": 2}).Where("task_id = ? and default_status in (?)", taskId, g.Slice{1, 3, 4}).Update() if err1 != nil { return &TalentHttpResult{Code: -2, Msg: "YoungeeContractInfo update failed"} } } // 查询该任务是否有已添加或已修改链接 res, err := g.DB().Model(model.YounggeeLinkInfo{}).Where("task_id = ? and is_submit = 0", taskId).Count() if err != nil { return &TalentHttpResult{Code: -1, Msg: "YounggeeLinkInfo find failed"} } if res == 1 && (taskInfo.LinkStatus == 2 || taskInfo.LinkStatus == 4) { _, err = g.DB().Model(model.YounggeeLinkInfo{}).Data(g.Map{"is_submit": "1", "submit_at": gtime.Now()}).Where("task_id = ? and is_submit = 0", taskId).Update() if err != nil { return &TalentHttpResult{Code: -3, Msg: "YounggeeLinkInfo update failed"} } _, err = g.DB().Model(model.YoungeeTaskInfo{}).Data(g.Map{"task_stage": "12"}).Where("task_id = ?", taskId).Update() if err != nil { return &TalentHttpResult{Code: -4, Msg: "YoungeeTaskInfo update failed"} } // 记录任务日志-上传链接 taskLog := model.YounggeeTaskLog{ TaskId: taskId, Content: "上传链接", LogAt: gtime.Now(), } _, err = g.DB().Model(dao.YounggeeTaskLog.Table).Data(&taskLog).Insert() if err != nil { return &TalentHttpResult{Code: -5, Msg: "YounggeeTaskLog insert failed"} } projectInfo := model.ProjectInfo{} err1 = g.DB().Model(model.ProjectInfo{}).Where("project_id = ?", taskInfo.ProjectId).Scan(&projectInfo) if err1 != nil { return &TalentHttpResult{Code: -8, Msg: "ProjectInfo find failed"} } messageInfo := model.YounggeeMessageInfo{ MessageId: 12, MessageType: 2, CreatedAt: gtime.Now(), TalentId: taskInfo.TalentId, ProjectName: projectInfo.ProjectName, IsReaded: 0, IsDeleted: 0, } _, err = g.DB().Model(dao.YounggeeMessageInfo.Table).Data(&messageInfo).Insert() if err != nil { return &TalentHttpResult{Code: -9, Msg: "YounggeeMessageInfo insert failed"} } } return &TalentHttpResult{Code: 0, Msg: "success"} } // 查询链接提交审阅记录service func GetTaskLink(r *ghttp.Request) *TalentHttpResult { taskId := r.Get("task_id") res, err := g.DB().Model(dao.YounggeeLinkInfo.Table).Where("is_submit = 1 and is_review = 1 and task_id = ?", taskId).OrderAsc("submit_at").All() if err != nil { return &TalentHttpResult{Code: -1, Msg: err.Error()} } return &TalentHttpResult{Code: 0, Msg: "success", Data: res} } // 查询未提交链接service func GetUnSubmitTaskLink(r *ghttp.Request) *TalentHttpResult { taskId := r.Get("task_id") res, err := g.DB().Model(dao.YounggeeLinkInfo.Table).Where("is_review = 0 and task_id = ?", taskId).One() if err != nil { return &TalentHttpResult{Code: -1, Msg: err.Error()} } return &TalentHttpResult{Code: 0, Msg: "success", Data: res} }