auto_task.go 39 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870
  1. package db
  2. import (
  3. "context"
  4. "fmt"
  5. "github.com/issue9/conv"
  6. "time"
  7. "youngee_b_api/model/gorm_model"
  8. log "github.com/sirupsen/logrus"
  9. )
  10. func AutoUpdateStatus() error {
  11. db := GetReadDB(context.Background())
  12. // 查找所有到达招募截止时间的项目id
  13. var projectIds []string
  14. db = db.Debug().Model(gorm_model.ProjectInfo{}).Select("project_id").Where("project_status = 6").Find(&projectIds)
  15. //fmt.Println("projectIds",projectIds)
  16. if len(projectIds) != 0 {
  17. for _, projectId := range projectIds {
  18. db1 := GetReadDB(context.Background())
  19. db1 = db1.Debug().Model(gorm_model.YoungeeTaskInfo{}).Where("project_id = ? and task_status = 1", projectId).Update("task_status", 3)
  20. }
  21. }
  22. db1 := GetReadDB(context.Background())
  23. // 更新招募中项目状态为待支付
  24. err := db1.Debug().Model(gorm_model.ProjectInfo{}).
  25. Where("project_status = ? AND recruit_ddl < ?", 4, time.Now()).Update("project_status", 6).Error
  26. if err != nil {
  27. log.Println("DB AutoUpdateStatus error :", err)
  28. return err
  29. }
  30. return nil
  31. }
  32. func GetLastAutoTaskID() (int, error) {
  33. db := GetReadDB(context.Background())
  34. // 查找最后一个
  35. LastTask := gorm_model.InfoAutoTask{}
  36. result := db.Last(&LastTask)
  37. err := result.Error
  38. if err != nil {
  39. log.Println("DB GetLastAutoTaskID:", err)
  40. return 0, err
  41. }
  42. //fmt.Printf("auto task %+v %+v", result, LastTask)
  43. return LastTask.AutoTaskID, nil
  44. }
  45. func AutoUpdateApplyTimes() error {
  46. db := GetReadDB(context.Background())
  47. // 查询task表信息
  48. db = db.Debug().Model(gorm_model.YoungeeTalentInfo{})
  49. err := db.Where("1 = 1").Update("apply_num", 5).Error
  50. if err != nil {
  51. log.Println("DB AutoUpdateStatus error :", err)
  52. return err
  53. }
  54. return nil
  55. }
  56. func AutoCompleteSelection() error {
  57. db := GetReadDB(context.Background())
  58. // 查询selection表,查询所有到截至时间的选品项目
  59. var completedSelectionList []gorm_model.YounggeeSelectionInfo
  60. err := db.Model(gorm_model.YounggeeSelectionInfo{}).Where("task_ddl < ?", time.Now()).Scan(&completedSelectionList).Error
  61. if err != nil {
  62. log.Println("DB AutoCompleteSelection error :", err)
  63. return err
  64. }
  65. // 遍历结束选品列表
  66. for _, v := range completedSelectionList {
  67. if v.SelectionStatus == 6 { // 若处于执行中阶段
  68. // 查询该选品下所有待结算任务
  69. var settleSecTaskList []gorm_model.YounggeeSecTaskInfo
  70. err = db.Model(gorm_model.YounggeeSecTaskInfo{}).Where("selection_id = ? and task_stage = 9", v.SelectionID).Scan(&settleSecTaskList).Error
  71. if err != nil {
  72. log.Println("DB AutoCompleteSelection error :", err)
  73. return err
  74. }
  75. // 结算选品
  76. for _, w := range settleSecTaskList {
  77. // 更新任务信息
  78. updateSecTaskData := gorm_model.YounggeeSecTaskInfo{
  79. TaskID: w.TaskID,
  80. TaskStage: 10,
  81. AssignmentStatus: 5,
  82. IsPayReward: 0,
  83. IsPayPayment: 0,
  84. CompleteDate: time.Now(),
  85. }
  86. _, err = UpdateSecTask(context.Background(), updateSecTaskData)
  87. if err != nil {
  88. log.Println("DB AutoCompleteSelection error :", err)
  89. return err
  90. }
  91. // 添加任务日志和达人消息
  92. err = CreateTaskLog(context.Background(), w.TaskID, "结算时间")
  93. if err != nil {
  94. log.Println("DB AutoCompleteSelection error :", err)
  95. }
  96. err = CreateMessageBySecTaskId(context.Background(), 5, 1, w.TaskID)
  97. if err != nil {
  98. log.Println("DB AutoCompleteSelection error :", err)
  99. return err
  100. }
  101. }
  102. // 计算结算金额,并返还剩余冻结资金
  103. var leftMoney float64 = conv.MustFloat64(v.EstimatedCost, 0) - conv.MustFloat64(v.SettlementAmount, 0)
  104. _, err = UpdateEnterpriseBalance(context.Background(), v.EnterpriseID, 0, leftMoney, -leftMoney)
  105. if err != nil {
  106. log.Println("DB AutoCompleteSelection error :", err)
  107. return err
  108. }
  109. // 更新选品阶段为已结案
  110. updateSelectionInfo := gorm_model.YounggeeSelectionInfo{
  111. SelectionID: v.SelectionID,
  112. SelectionStatus: 8,
  113. FinishAt: time.Now(),
  114. }
  115. err = UpdateSelection(context.Background(), updateSelectionInfo)
  116. if err != nil {
  117. log.Println("DB AutoCompleteSelection error :", err)
  118. return err
  119. }
  120. } else { // 否则
  121. // 更新选品阶段为失效,失效原因为逾期未支付
  122. updateSelectionInfo := gorm_model.YounggeeSelectionInfo{
  123. SelectionID: v.SelectionID,
  124. SelectionStatus: 7,
  125. FailReason: 1,
  126. FinishAt: time.Now(),
  127. }
  128. err = UpdateSelection(context.Background(), updateSelectionInfo)
  129. if err != nil {
  130. log.Println("DB AutoCompleteSelection error :", err)
  131. return err
  132. }
  133. }
  134. }
  135. return nil
  136. }
  137. // GetAutoDraftDefaultTask 品牌种草-商品寄拍 初稿超时违约
  138. func GetAutoDraftDefaultTask() error {
  139. fmt.Println("GetAutoDraftDefaultInPicTask Running")
  140. db := GetReadDB(context.Background())
  141. // 1. 根据种草任务形式取出对应的Project
  142. var projectInfos []*gorm_model.ProjectInfo
  143. projectInfoErr := db.Model(gorm_model.ProjectInfo{}).Where("project_type = ? AND project_form = ? ", 1, 1).Find(&projectInfos).Error
  144. if projectInfoErr != nil {
  145. return projectInfoErr
  146. }
  147. // 2. 构建查询map
  148. var projectIds []string
  149. projectIdToAutoTaskIdMap := map[string]int{} // 项目id 对 定时任务id 的map
  150. projectIdToAutoDefaultIdMap := map[string]int{} // 项目id 对 违约扣款设置id 的map
  151. taskIdToFeeFormMap := make(map[string]int) // taskId 对 稿费形式的 map
  152. TaskIdToProjectId := make(map[string]string) // taskId 对 项目id的 map
  153. var taskNeedModIds []string // 首次提交初稿的任务记录id
  154. var submitTaskNeedModIds []string // 修改后提交初稿的任务记录id
  155. for _, projectInfo := range projectInfos {
  156. projectIds = append(projectIds, projectInfo.ProjectID)
  157. projectIdToAutoTaskIdMap[projectInfo.ProjectID] = int(projectInfo.AutoTaskID)
  158. projectIdToAutoDefaultIdMap[projectInfo.ProjectID] = int(projectInfo.AutoDefaultID)
  159. }
  160. for _, projectId := range projectIds {
  161. db1 := GetReadDB(context.Background())
  162. var taskInfos []gorm_model.YoungeeTaskInfo
  163. db1.Model(gorm_model.YoungeeTaskInfo{}).Where("project_id = ? AND task_status = ? AND task_stage = ? AND cur_default_type = ? AND logistics_status = 3", projectId, 2, 9, 0).Find(&taskInfos)
  164. for _, taskInfo := range taskInfos {
  165. TaskIdToProjectId[taskInfo.TaskID] = projectId
  166. taskNeedMod := gorm_model.YoungeeTaskInfo{}
  167. db2 := GetReadDB(context.Background())
  168. // 保存所有满足物流状态为 3 且 初稿上传状态为 1或 3 的任务记录的id
  169. db2.Model(gorm_model.YoungeeTaskInfo{}).Where("task_id = ?", taskInfo.TaskID).First(&taskNeedMod)
  170. taskIdToFeeFormMap[taskInfo.TaskID] = taskInfo.FeeForm
  171. if taskNeedMod.TaskStage == 9 && taskNeedMod.SketchStatus == 1 {
  172. taskNeedModIds = append(taskNeedModIds, taskInfo.TaskID)
  173. }
  174. if taskNeedMod.TaskStage == 9 && taskNeedMod.SketchStatus == 3 {
  175. submitTaskNeedModIds = append(submitTaskNeedModIds, taskInfo.TaskID)
  176. }
  177. }
  178. }
  179. // 3. 对初次初稿未上传的操作
  180. for _, taskNeedModId := range taskNeedModIds {
  181. // 获取taskId对应的autoTaskId
  182. autoTaskId := projectIdToAutoTaskIdMap[TaskIdToProjectId[taskNeedModId]]
  183. // 根据autoTaskId去查找对应的初稿违约小时数
  184. dbStart := GetReadDB(context.Background())
  185. var DraftDefaultInPic int32
  186. dbStart.Model(gorm_model.InfoAutoTask{}).Select("draft_default").Where("auto_task_id = ?", autoTaskId).First(&DraftDefaultInPic)
  187. // 根据taskId查询taskInfo
  188. db3 := GetReadDB(context.Background())
  189. taskLogisticNeedMod := gorm_model.YoungeeTaskInfo{}
  190. db3.Model(gorm_model.YoungeeTaskInfo{}).Where("task_id = ?", taskNeedModId).First(&taskLogisticNeedMod)
  191. // 获取task对应的autoDefaultId 并取出违约扣款比例
  192. autoDefaultHandle := gorm_model.InfoAutoDefaultHandle{}
  193. db6 := GetReadDB(context.Background())
  194. db6.Model(gorm_model.InfoAutoDefaultHandle{}).Where("auto_default_id = ?", projectIdToAutoDefaultIdMap[TaskIdToProjectId[taskNeedModId]]).Find(&autoDefaultHandle)
  195. var sketchDefaultRate int
  196. var sketchErrRate int
  197. // 稿费形式为产品置换
  198. if taskIdToFeeFormMap[taskNeedModId] == 1 {
  199. sketchDefaultRate = autoDefaultHandle.SketchReplaceTimeOut
  200. sketchErrRate = autoDefaultHandle.SketchReplaceNotUpload
  201. // db6 := GetReadDB(context.Background())
  202. // db6.Model(gorm_model.InfoAutoDefaultHandle{}).Select("sketch_replace_time_out", "sketch_replace_not_upload").Where("auto_default_id = ?", projectIdToAutoDefaultIdMap[TaskIdToProjectId[taskNeedModId]]).Find(&autoDefaultHandle)
  203. } else {
  204. // 稿费形式为其他
  205. sketchDefaultRate = autoDefaultHandle.SketchOtherTimeOut
  206. sketchErrRate = autoDefaultHandle.SketchOtherNotUpload
  207. // db6 := GetReadDB(context.Background())
  208. // db6.Model(gorm_model.InfoAutoDefaultHandle{}).Select("sketch_other_time_out", "sketch_other_not_upload").Where("auto_default_id = ?", projectIdToAutoDefaultIdMap[TaskIdToProjectId[taskNeedModId]]).Find(&sketchDefaultRate, &sketchErrRate)
  209. }
  210. // 若无违约自动处理时间 则添加初稿违约自动处理时间
  211. if taskLogisticNeedMod.TaskID != "" && taskLogisticNeedMod.SketchMissingTime.IsZero() {
  212. dd, _ := time.ParseDuration(conv.MustString(DraftDefaultInPic, "") + "h")
  213. db4 := GetReadDB(context.Background())
  214. t := taskLogisticNeedMod.SignedTime.Add(dd)
  215. db4.Where("task_id = ?", taskNeedModId).Updates(&gorm_model.YoungeeTaskInfo{
  216. SketchMissingTime: t,
  217. })
  218. taskLogisticNeedMod.SketchMissingTime = t
  219. fmt.Println("已添加 品牌种草-商品寄拍-初次初稿未上传 初稿违约自动处理时间")
  220. fmt.Println(sketchDefaultRate, sketchErrRate)
  221. }
  222. // 判断是否超时违约
  223. if taskLogisticNeedMod.TaskID != "" && taskLogisticNeedMod.SketchMissingTime.Sub(time.Now()) <= 0 {
  224. fmt.Println("taskId: ", taskLogisticNeedMod.TaskID, "超时违约触发")
  225. taskInfo := gorm_model.YoungeeTaskInfo{}
  226. dbt := GetReadDB(context.Background())
  227. err2 := dbt.Model(gorm_model.YoungeeTaskInfo{}).Where("task_id = ?", taskLogisticNeedMod.TaskID).Find(&taskInfo).Error
  228. if err2 != nil {
  229. return err2
  230. }
  231. // 计算违约扣款后的达人所得
  232. settleAmount := taskInfo.DraftFee * (1.0 - float64(taskInfo.LinkBreakRate+taskInfo.DataBreakRate+sketchDefaultRate+taskInfo.ScriptBreakRate)/100)
  233. if settleAmount <= 0 {
  234. settleAmount = 0.0
  235. }
  236. // 计算违约扣款后的服务商所得
  237. realServiceCharge := taskInfo.ServiceCharge * (1.0 - float64(taskInfo.LinkBreakRate+taskInfo.DataBreakRate+sketchDefaultRate+taskInfo.ScriptBreakRate)/100)
  238. if realServiceCharge <= 0 {
  239. realServiceCharge = 0.0
  240. }
  241. // 计算企业需要实际支付金额
  242. realPayment := settleAmount + realServiceCharge
  243. if realPayment <= 0 {
  244. realPayment = 0.0
  245. }
  246. db8 := GetReadDB(context.Background())
  247. fmt.Println("待更新的taskId: ", taskLogisticNeedMod.TaskID)
  248. db8.Model(gorm_model.YoungeeTaskInfo{}).Where("task_id = ?", taskLogisticNeedMod.TaskID).Updates(
  249. map[string]interface{}{
  250. "sketch_missing_status": 1,
  251. "cur_default_type": 3,
  252. "sketch_break_rate": sketchDefaultRate,
  253. "settle_amount": settleAmount,
  254. "err_break_rate": sketchErrRate,
  255. "real_service_charge": realServiceCharge,
  256. "real_payment": realPayment,
  257. })
  258. createTaskLogErr := CreateTaskLog(context.Background(), taskLogisticNeedMod.TaskID, "初稿逾期")
  259. if createTaskLogErr != nil {
  260. log.WithContext(context.Background()).Errorf("[operate db] call CreateTaskLog error,err:%+v", createTaskLogErr)
  261. }
  262. createMessageByTaskIdErr := CreateMessageByTaskId(context.Background(), 22, 4, taskLogisticNeedMod.TaskID)
  263. if createMessageByTaskIdErr != nil {
  264. log.WithContext(context.Background()).Errorf("[operate db] call CreateMessageByTaskId error,err:%+v", createMessageByTaskIdErr)
  265. }
  266. fmt.Println("已创建 品牌种草-商品寄拍-初次初稿未上传 初稿违约记录")
  267. }
  268. }
  269. // 4. 判断应该修改后上传的任务
  270. for _, submitTaskNeedModId := range submitTaskNeedModIds {
  271. // 获取 autoTaskId 及其对应的限制时间
  272. db2 := GetReadDB(context.Background())
  273. var DraftDefaultInMv int32
  274. db2.Model(&gorm_model.InfoAutoTask{}).Select("draft_default").Where("auto_task_id = ?", projectIdToAutoTaskIdMap[TaskIdToProjectId[submitTaskNeedModId]]).First(&DraftDefaultInMv)
  275. dd, _ := time.ParseDuration(conv.MustString(DraftDefaultInMv, "") + "h")
  276. // 查询违约扣款比例
  277. autoDefaultHandle := gorm_model.InfoAutoDefaultHandle{}
  278. db6 := GetReadDB(context.Background())
  279. db6.Model(gorm_model.InfoAutoDefaultHandle{}).Where("auto_default_id = ?", projectIdToAutoDefaultIdMap[TaskIdToProjectId[submitTaskNeedModId]]).Find(&autoDefaultHandle)
  280. var sketchDefaultRate int
  281. var sketchErrRate int
  282. if taskIdToFeeFormMap[submitTaskNeedModId] == 1 {
  283. sketchDefaultRate = autoDefaultHandle.SketchReplaceTimeOut
  284. sketchErrRate = autoDefaultHandle.SketchReplaceNotUpload
  285. // db6 := GetReadDB(context.Background())
  286. // db6.Model(gorm_model.InfoAutoDefaultHandle{}).Select("sketch_replace_time_out", "sketch_replace_not_upload").Where("auto_default_id = ?", projectIdToAutoDefaultIdMap[TaskIdToProjectId[submitTaskNeedModId]]).Find(&sketchDefaultRate, &sketchErrRate)
  287. } else {
  288. sketchDefaultRate = autoDefaultHandle.SketchOtherTimeOut
  289. sketchErrRate = autoDefaultHandle.SketchOtherNotUpload
  290. // db6 := GetReadDB(context.Background())
  291. // db6.Model(gorm_model.InfoAutoDefaultHandle{}).Select("sketch_other_time_out", "sketch_other_not_upload").Where("auto_default_id = ?", projectIdToAutoDefaultIdMap[TaskIdToProjectId[submitTaskNeedModId]]).Find(&sketchDefaultRate, &sketchErrRate)
  292. }
  293. // 添加初稿违约自动处理时间
  294. db1 := GetReadDB(context.Background())
  295. var taskSketchInfo gorm_model.YounggeeSketchInfo
  296. db1.Model(gorm_model.YounggeeSketchInfo{}).Where("task_id = ? and is_review = 1", submitTaskNeedModId).Order("reject_at desc").First(&taskSketchInfo)
  297. if taskSketchInfo.AutoSketchBreakAt.IsZero() {
  298. err4 := db1.Where("task_id = ?", submitTaskNeedModId).Updates(&gorm_model.YounggeeSketchInfo{AutoSketchBreakAt: taskSketchInfo.RejectAt.Add(dd)}).Error
  299. if err4 != nil {
  300. return err4
  301. }
  302. taskSketchInfo.AutoSketchBreakAt = taskSketchInfo.RejectAt.Add(dd)
  303. fmt.Println("已添加 品牌种草-商品寄拍-修改后上传初稿未上传自动处理时间")
  304. }
  305. // 判断是否违约
  306. if taskSketchInfo.TaskID != "" && taskSketchInfo.AutoSketchBreakAt.Sub(time.Now()) <= 0 {
  307. db4 := GetReadDB(context.Background())
  308. err1 := db4.Model(gorm_model.YoungeeContractInfo{}).Create(&gorm_model.YoungeeContractInfo{
  309. TaskID: submitTaskNeedModId, ProjectID: TaskIdToProjectId[submitTaskNeedModId], BreakType: 2, BreakAt: time.Now(), DefaultStatus: 1}).Error
  310. if err1 != nil {
  311. return err1
  312. }
  313. taskInfo := gorm_model.YoungeeTaskInfo{}
  314. dbt := GetReadDB(context.Background())
  315. err2 := dbt.Model(gorm_model.YoungeeTaskInfo{}).Where("task_id = ?", submitTaskNeedModId).Find(&taskInfo).Error
  316. if err2 != nil {
  317. return err2
  318. }
  319. // 计算违约扣款后的达人所得
  320. settleAmount := taskInfo.DraftFee * (1.0 - float64(sketchDefaultRate+taskInfo.DataBreakRate+taskInfo.LinkBreakRate+taskInfo.ScriptBreakRate)/100)
  321. if settleAmount <= 0 {
  322. settleAmount = 0.
  323. }
  324. // 计算违约扣款后的服务商所得
  325. realServiceCharge := taskInfo.ServiceCharge * (1.0 - float64(taskInfo.LinkBreakRate+taskInfo.DataBreakRate+sketchDefaultRate+taskInfo.ScriptBreakRate)/100)
  326. if realServiceCharge <= 0 {
  327. realServiceCharge = 0.0
  328. }
  329. // 计算企业需要实际支付金额
  330. realPayment := settleAmount + realServiceCharge
  331. if realPayment <= 0 {
  332. realPayment = 0.0
  333. }
  334. db3 := GetReadDB(context.Background())
  335. err2 = db3.Model(gorm_model.YoungeeTaskInfo{}).Where("task_id = ?", submitTaskNeedModId).Updates(
  336. map[string]interface{}{
  337. "sketch_missing_status": 1,
  338. "cur_default_type": 3,
  339. "sketch_break_rate": sketchDefaultRate,
  340. "settle_amount": settleAmount,
  341. "err_break_rate": sketchErrRate,
  342. "real_service_charge": realServiceCharge,
  343. "real_payment": realPayment,
  344. }).Error
  345. if err2 != nil {
  346. return err2
  347. }
  348. createTaskLogErr := CreateTaskLog(context.Background(), submitTaskNeedModId, "初稿逾期")
  349. if createTaskLogErr != nil {
  350. log.WithContext(context.Background()).Errorf("[operate db] call CreateTaskLog error,err:%+v", createTaskLogErr)
  351. }
  352. createMessageByTaskIdErr := CreateMessageByTaskId(context.Background(), 22, 4, submitTaskNeedModId)
  353. if createMessageByTaskIdErr != nil {
  354. log.WithContext(context.Background()).Errorf("[operate db] call CreateMessageByTaskId error,err:%+v", createMessageByTaskIdErr)
  355. }
  356. fmt.Println("创建已提交初稿的初稿违约记录")
  357. }
  358. }
  359. return nil
  360. }
  361. // GetAutoLinkDefaultTask 品牌种草 链接超时违约
  362. func GetAutoLinkDefaultTask() error {
  363. // 1. 筛选出可能链接超时违约的子任务,首次/修改
  364. db := GetReadDB(context.Background())
  365. var projectInfos []*gorm_model.ProjectInfo
  366. err := db.Model(gorm_model.ProjectInfo{}).Where("project_type = ?", 1).Find(&projectInfos).Error
  367. if err != nil {
  368. return err
  369. }
  370. var projectIds []string
  371. // 任务id 对 项目id 的map
  372. taskIdToProjectIdMap := map[string]string{}
  373. // 项目id 对 定时任务id 的map
  374. projectIdToAutoTaskIdMap := map[string]int{}
  375. // 项目id 对 违约定时任务id 的map
  376. projectIdToAutoDefaultIdMap := map[string]int{}
  377. var taskIds []string
  378. // taskId 对 稿费形式的 map
  379. taskIdToFeeFormMap := make(map[string]int)
  380. for _, projectInfo := range projectInfos {
  381. projectIds = append(projectIds, projectInfo.ProjectID)
  382. projectIdToAutoTaskIdMap[projectInfo.ProjectID] = int(projectInfo.AutoTaskID)
  383. projectIdToAutoDefaultIdMap[projectInfo.ProjectID] = int(projectInfo.AutoDefaultID)
  384. var taskInfos []*gorm_model.YoungeeTaskInfo
  385. db1 := GetReadDB(context.Background())
  386. db1.Model(&gorm_model.YoungeeTaskInfo{}).Where("project_id = ? AND task_status = ? AND task_stage = ? AND cur_default_type = ? ", projectInfo.ProjectID, 2, 11, 0).Find(&taskInfos)
  387. for _, taskInfo := range taskInfos {
  388. taskIdToProjectIdMap[taskInfo.TaskID] = projectInfo.ProjectID
  389. taskIds = append(taskIds, taskInfo.TaskID)
  390. taskIdToFeeFormMap[taskInfo.TaskID] = taskInfo.FeeForm
  391. }
  392. }
  393. // 首次提交链接的任务记录id
  394. var taskNeedModIds []string
  395. // 已提交链接的任务记录id
  396. var submitTaskNeedModIds []string
  397. for _, taskId := range taskIds {
  398. var taskInfo gorm_model.YoungeeTaskInfo
  399. db3 := GetReadDB(context.Background())
  400. // 保存所有链接上传状态为 1 且任务状态为12 的任务记录的id
  401. db3.Model(gorm_model.YoungeeTaskInfo{}).Where("task_id = ?", taskId).First(&taskInfo)
  402. if taskInfo.LinkStatus == 1 && taskInfo.TaskStage == 11 {
  403. taskNeedModIds = append(taskNeedModIds, taskId)
  404. }
  405. // 保存所有链接上传状态为 3 且任务状态为12 的任务记录的id
  406. if taskInfo.LinkStatus == 3 && taskInfo.TaskStage == 11 {
  407. submitTaskNeedModIds = append(submitTaskNeedModIds, taskId)
  408. }
  409. }
  410. // 2. 对于需要初次上传链接但是未上传的子任务
  411. for _, taskNeedModId := range taskNeedModIds {
  412. db2 := GetReadDB(context.Background())
  413. var linkBreach int32
  414. db2.Model(&gorm_model.InfoAutoTask{}).Select("link_breach").Where("auto_task_id = ?", projectIdToAutoTaskIdMap[taskIdToProjectIdMap[taskNeedModId]]).First(&linkBreach)
  415. dd, _ := time.ParseDuration(conv.MustString(linkBreach, "") + "h")
  416. autoDefaultHandle := gorm_model.InfoAutoDefaultHandle{}
  417. db6 := GetReadDB(context.Background())
  418. db6.Model(gorm_model.InfoAutoDefaultHandle{}).Where("auto_default_id = ?", projectIdToAutoDefaultIdMap[taskIdToProjectIdMap[taskNeedModId]]).Find(&autoDefaultHandle)
  419. var linkDefaultRate int
  420. var linkErrRate int
  421. if taskIdToFeeFormMap[taskNeedModId] == 1 {
  422. linkDefaultRate = autoDefaultHandle.LinkReplaceTimeOut
  423. linkErrRate = autoDefaultHandle.LinkReplaceNotUpload
  424. // db6 := GetReadDB(context.Background())
  425. // db6.Model(gorm_model.InfoAutoDefaultHandle{}).Select("link_replace_time_out", "link_replace_not_upload").Where("auto_default_id = ?", projectIdToAutoDefaultIdMap[taskIdToProjectIdMap[taskNeedModId]]).Find(&linkDefaultRate, &linkErrRate)
  426. } else {
  427. linkDefaultRate = autoDefaultHandle.LinkOtherTimeOut
  428. linkErrRate = autoDefaultHandle.LinkOtherNotUpload
  429. // db6 := GetReadDB(context.Background())
  430. // db6.Model(gorm_model.InfoAutoDefaultHandle{}).Select("link_other_time_out", "link_other_not_uploadsg").Where("auto_default_id = ?", projectIdToAutoDefaultIdMap[taskIdToProjectIdMap[taskNeedModId]]).Find(&linkDefaultRate, &linkErrRate)
  431. }
  432. db1 := GetReadDB(context.Background())
  433. var taskSketchInfo gorm_model.YounggeeSketchInfo
  434. db1.Model(gorm_model.YounggeeSketchInfo{}).Where("task_id = ? AND is_ok = ?", taskNeedModId, 1).Find(&taskSketchInfo)
  435. dbTask := GetReadDB(context.Background())
  436. var taskInfoCurr gorm_model.YoungeeTaskInfo
  437. dbTask.Model(gorm_model.YoungeeTaskInfo{}).Where("task_id = ?", taskNeedModId).Find(&taskInfoCurr)
  438. if taskInfoCurr.LinkMissingTime.IsZero() {
  439. // db1.Where("task_id = ?", taskNeedModId).Updates(&gorm_model.YounggeeSketchInfo{AutoLinkBreakAt: taskSketchInfo.AgreeAt.Add(dd)})
  440. dbTask.Where("task_id = ?", taskNeedModId).Updates(&gorm_model.YoungeeTaskInfo{LinkMissingTime: taskSketchInfo.AgreeAt.Add(dd)})
  441. fmt.Println("已添加链接违约自动处理时间")
  442. } else {
  443. if taskInfoCurr.TaskID != "" && taskInfoCurr.LinkMissingTime.Sub(time.Now()) <= 0 {
  444. //db4 := GetReadDB(context.Background())
  445. //err1 := db4.Model(gorm_model.YoungeeContractInfo{}).Create(&gorm_model.YoungeeContractInfo{
  446. // TaskID: taskNeedModId, ProjectID: taskIdToProjectIdMap[taskNeedModId], BreakType: 3, BreakAt: time.Now(), DefaultStatus: 1}).Error
  447. //if err1 != nil {
  448. // return err1
  449. //}
  450. taskInfo := gorm_model.YoungeeTaskInfo{}
  451. dbt := GetReadDB(context.Background())
  452. err2 := dbt.Model(gorm_model.YoungeeTaskInfo{}).Where("task_id = ?", taskNeedModId).Find(&taskInfo).Error
  453. if err2 != nil {
  454. return err2
  455. }
  456. // 达人实际所得
  457. settleAmount := taskInfo.DraftFee * (1.0 - float64(linkDefaultRate+taskInfo.DataBreakRate+taskInfo.SketchBreakRate+taskInfo.ScriptBreakRate)/100)
  458. if settleAmount <= 0 {
  459. settleAmount = 0.0
  460. }
  461. // 服务商实际所得
  462. realServiceCharge := taskInfo.ServiceCharge * (1.0 - float64(taskInfo.LinkBreakRate+taskInfo.DataBreakRate+linkDefaultRate+taskInfo.ScriptBreakRate)/100)
  463. if realServiceCharge <= 0 {
  464. realServiceCharge = 0.0
  465. }
  466. // 企业实际支付
  467. realPayment := settleAmount + realServiceCharge
  468. if realPayment <= 0 {
  469. realPayment = 0.0
  470. }
  471. db3 := GetReadDB(context.Background())
  472. err2 = db3.Model(gorm_model.YoungeeTaskInfo{}).Where("task_id = ?", taskNeedModId).Updates(
  473. map[string]interface{}{
  474. "link_missing_status": 1,
  475. "cur_default_type": 5,
  476. "link_break_rate": linkDefaultRate,
  477. "settle_amount": settleAmount,
  478. "real_service_charge": realServiceCharge,
  479. "err_break_rate": linkErrRate,
  480. "real_payment": realPayment,
  481. }).Error
  482. if err2 != nil {
  483. return err2
  484. }
  485. err = CreateTaskLog(context.Background(), taskNeedModId, "链接逾期")
  486. if err != nil {
  487. log.WithContext(context.Background()).Errorf("[operate db] call CreateTaskLog error,err:%+v", err)
  488. }
  489. err = CreateMessageByTaskId(context.Background(), 23, 4, taskNeedModId)
  490. if err != nil {
  491. log.WithContext(context.Background()).Errorf("[operate db] call CreateMessageByTaskId error,err:%+v", err)
  492. }
  493. fmt.Println("已创建链接违约记录")
  494. }
  495. }
  496. }
  497. // 3. 对于需要修改后上传的链接
  498. for _, submitTaskNeedModId := range submitTaskNeedModIds {
  499. db2 := GetReadDB(context.Background())
  500. var LinkBreach int32
  501. db2.Model(&gorm_model.InfoAutoTask{}).Select("link_breach").Where("auto_task_id = ?", projectIdToAutoTaskIdMap[taskIdToProjectIdMap[submitTaskNeedModId]]).First(&LinkBreach)
  502. dd, _ := time.ParseDuration(conv.MustString(LinkBreach, "") + "h")
  503. autoDefaultHandle := gorm_model.InfoAutoDefaultHandle{}
  504. db6 := GetReadDB(context.Background())
  505. db6.Model(gorm_model.InfoAutoDefaultHandle{}).Where("auto_default_id = ?", projectIdToAutoDefaultIdMap[taskIdToProjectIdMap[submitTaskNeedModId]]).Find(&autoDefaultHandle)
  506. var linkDefaultRate int
  507. var linkErrRate int
  508. if taskIdToFeeFormMap[submitTaskNeedModId] == 1 {
  509. linkDefaultRate = autoDefaultHandle.LinkReplaceTimeOut
  510. linkErrRate = autoDefaultHandle.LinkReplaceNotUpload
  511. // db6 := GetReadDB(context.Background())
  512. // db6.Model(gorm_model.InfoAutoDefaultHandle{}).Select("link_replace_time_out", "link_replace_not_upload").Where("auto_default_id = ?", projectIdToAutoDefaultIdMap[taskIdToProjectIdMap[submitTaskNeedModId]]).Find(&linkDefaultRate, &linkErrRate)
  513. } else {
  514. linkDefaultRate = autoDefaultHandle.LinkOtherTimeOut
  515. linkErrRate = autoDefaultHandle.LinkOtherNotUpload
  516. // db6 := GetReadDB(context.Background())
  517. // db6.Model(gorm_model.InfoAutoDefaultHandle{}).Select("link_other_time_out", "link_other_not_upload").Where("auto_default_id = ?", projectIdToAutoDefaultIdMap[taskIdToProjectIdMap[submitTaskNeedModId]]).Find(&linkDefaultRate, &linkErrRate)
  518. }
  519. db1 := GetReadDB(context.Background())
  520. var taskLinkInfo gorm_model.YounggeeLinkInfo
  521. db1.Model(gorm_model.YounggeeLinkInfo{}).Where("task_id = ?", submitTaskNeedModId).Order("reject_at desc").First(&taskLinkInfo)
  522. dbTask := GetReadDB(context.Background())
  523. var taskInfoCurr gorm_model.YoungeeTaskInfo
  524. dbTask.Model(gorm_model.YoungeeTaskInfo{}).Where("task_id = ?", submitTaskNeedModId).Find(&taskInfoCurr)
  525. if taskLinkInfo.AutoLinkBreakAt.IsZero() {
  526. err4 := db1.Where("task_id = ?", submitTaskNeedModId).Updates(&gorm_model.YounggeeLinkInfo{AutoLinkBreakAt: taskLinkInfo.RejectAt.Add(dd)}).Error
  527. if err4 != nil {
  528. return err4
  529. }
  530. taskInfoCurrErr := dbTask.Where("task_id = ?", submitTaskNeedModId).Updates(&gorm_model.YoungeeTaskInfo{LinkMissingTime: taskLinkInfo.RejectAt.Add(dd)}).Error
  531. if taskInfoCurrErr != nil {
  532. return taskInfoCurrErr
  533. }
  534. fmt.Println("已添加链接违约自动处理时间")
  535. } else {
  536. if taskLinkInfo.TaskID != "" && taskLinkInfo.AutoLinkBreakAt.Sub(time.Now()) <= 0 {
  537. //db4 := GetReadDB(context.Background())
  538. //err1 := db4.Model(gorm_model.YoungeeContractInfo{}).Create(&gorm_model.YoungeeContractInfo{
  539. // TaskID: submitTaskNeedModId, ProjectID: taskIdToProjectIdMap[submitTaskNeedModId], BreakType: 3, BreakAt: time.Now(), DefaultStatus: 1}).Error
  540. //if err1 != nil {
  541. // return err1
  542. //}
  543. taskInfo := gorm_model.YoungeeTaskInfo{}
  544. dbt := GetReadDB(context.Background())
  545. err2 := dbt.Model(gorm_model.YoungeeTaskInfo{}).Where("task_id = ?", submitTaskNeedModId).Find(&taskInfo).Error
  546. if err2 != nil {
  547. return err2
  548. }
  549. // 达人实际所得
  550. settleAmount := taskInfo.DraftFee * (1.0 - float64(linkDefaultRate+taskInfo.DataBreakRate+taskInfo.SketchBreakRate+taskInfo.ScriptBreakRate)/100)
  551. if settleAmount <= 0 {
  552. settleAmount = 0.0
  553. }
  554. // 服务商实际所得
  555. realServiceCharge := taskInfo.ServiceCharge * (1.0 - float64(taskInfo.LinkBreakRate+taskInfo.DataBreakRate+linkDefaultRate+taskInfo.ScriptBreakRate)/100)
  556. if realServiceCharge <= 0 {
  557. realServiceCharge = 0.0
  558. }
  559. // 企业实际支付
  560. realPayment := settleAmount + realServiceCharge
  561. if realPayment <= 0 {
  562. realPayment = 0.0
  563. }
  564. db3 := GetReadDB(context.Background())
  565. err2 = db3.Model(gorm_model.YoungeeTaskInfo{}).Where("task_id = ?", submitTaskNeedModId).Updates(
  566. map[string]interface{}{
  567. "link_missing_status": 1,
  568. "cur_default_type": 5,
  569. "link_break_rate": linkDefaultRate,
  570. "settle_amount": settleAmount,
  571. "real_service_charge": realServiceCharge,
  572. "err_break_rate": linkErrRate,
  573. "real_payment": realPayment,
  574. }).Error
  575. if err2 != nil {
  576. return err2
  577. }
  578. err = CreateTaskLog(context.Background(), submitTaskNeedModId, "链接逾期")
  579. if err != nil {
  580. log.WithContext(context.Background()).Errorf("[operate db] call CreateTaskLog error,err:%+v", err)
  581. }
  582. err = CreateMessageByTaskId(context.Background(), 23, 4, submitTaskNeedModId)
  583. if err != nil {
  584. log.WithContext(context.Background()).Errorf("[operate db] call CreateMessageByTaskId error,err:%+v", err)
  585. }
  586. fmt.Println("创建已提交链接的链接违约记录")
  587. }
  588. }
  589. }
  590. return nil
  591. }
  592. // GetAutoCaseCloseDefaultTask 品牌种草 数据超时违约
  593. func GetAutoCaseCloseDefaultTask() error {
  594. // 1. 筛选出可能数据违约的种草子任务 待上传/待修改
  595. db := GetReadDB(context.Background())
  596. var projectInfos []*gorm_model.ProjectInfo
  597. err := db.Model(gorm_model.ProjectInfo{}).Where("project_type = ?", 1).Find(&projectInfos).Error
  598. if err != nil {
  599. return err
  600. }
  601. var projectIds []string
  602. // 任务id 对 项目id 的map
  603. taskIdToProjectIdMap := map[string]string{}
  604. // 项目id 对 定时任务id 的map
  605. projectIdToAutoTaskIdMap := map[string]int{}
  606. // 项目id 对 违约定时任务id 的map
  607. projectIdToAutoDefaultIdMap := map[string]int{}
  608. var taskIds []string
  609. for _, projectInfo := range projectInfos {
  610. projectIds = append(projectIds, projectInfo.ProjectID)
  611. projectIdToAutoTaskIdMap[projectInfo.ProjectID] = int(projectInfo.AutoTaskID)
  612. projectIdToAutoDefaultIdMap[projectInfo.ProjectID] = int(projectInfo.AutoDefaultID)
  613. var taskInfos []string
  614. db1 := GetReadDB(context.Background())
  615. db1.Select("task_id").Model(&gorm_model.YoungeeTaskInfo{}).Where("project_id = ? AND task_status = ? AND task_stage = ? AND cur_default_type = ? ", projectInfo.ProjectID, 2, 13, 0).Find(&taskInfos)
  616. for _, taskInfo := range taskInfos {
  617. taskIdToProjectIdMap[taskInfo] = projectInfo.ProjectID
  618. taskIds = append(taskIds, taskInfo)
  619. }
  620. }
  621. // 首次提交链接的任务记录id
  622. var taskNeedModIds []string
  623. // 已提交链接的任务记录id
  624. var submitTaskNeedModIds []string
  625. // taskId 对 稿费形式的 map
  626. taskIdToFeeFormMap := make(map[string]int)
  627. for _, taskId := range taskIds {
  628. var taskInfo gorm_model.YoungeeTaskInfo
  629. db3 := GetReadDB(context.Background())
  630. // 保存所有数据上传状态为 1 且任务状态为14 的任务记录的id
  631. db3.Model(gorm_model.YoungeeTaskInfo{}).Where("task_id = ?", taskId).First(&taskInfo)
  632. if taskInfo.DataStatus == 1 && taskInfo.TaskStage == 13 {
  633. taskNeedModIds = append(taskNeedModIds, taskId)
  634. }
  635. // 保存所有数据上传状态为 3 且任务状态为14 的任务记录的id
  636. if taskInfo.DataStatus == 3 && taskInfo.TaskStage == 13 {
  637. submitTaskNeedModIds = append(submitTaskNeedModIds, taskId)
  638. }
  639. taskIdToFeeFormMap[taskId] = taskInfo.FeeForm
  640. }
  641. // 2. 对待上传数据的子任务判断
  642. for _, taskNeedModId := range taskNeedModIds {
  643. db2 := GetReadDB(context.Background())
  644. var CaseCloseDefault int32
  645. db2.Model(&gorm_model.InfoAutoTask{}).Select("case_close_default").Where("auto_task_id = ?", projectIdToAutoTaskIdMap[taskIdToProjectIdMap[taskNeedModId]]).First(&CaseCloseDefault)
  646. dd, _ := time.ParseDuration(conv.MustString(CaseCloseDefault, "") + "h")
  647. autoDefaultHandle := gorm_model.InfoAutoDefaultHandle{}
  648. db6 := GetReadDB(context.Background())
  649. db6.Model(gorm_model.InfoAutoDefaultHandle{}).Where("auto_default_id = ?", projectIdToAutoDefaultIdMap[taskIdToProjectIdMap[taskNeedModId]]).Find(&autoDefaultHandle)
  650. var dataDefaultRate int
  651. var dataErrRate int
  652. if taskIdToFeeFormMap[taskNeedModId] == 1 {
  653. dataDefaultRate = autoDefaultHandle.DataReplaceTimeOut
  654. dataErrRate = autoDefaultHandle.DataReplaceNotUpload
  655. // db6 := GetReadDB(context.Background())
  656. // db6.Model(gorm_model.InfoAutoDefaultHandle{}).Select("data_replace_time_out", "data_replace_not_upload").Where("auto_default_id = ?", projectIdToAutoDefaultIdMap[taskIdToProjectIdMap[taskNeedModId]]).Find(&dataDefaultRate, &dataErrRate)
  657. } else {
  658. dataDefaultRate = autoDefaultHandle.DataOtherTimeOut
  659. dataErrRate = autoDefaultHandle.DataOtherNotUpload
  660. // db6 := GetReadDB(context.Background())
  661. // db6.Model(gorm_model.InfoAutoDefaultHandle{}).Select("data_other_time_out", "data_other_not_upload").Where("auto_default_id = ?", projectIdToAutoDefaultIdMap[taskIdToProjectIdMap[taskNeedModId]]).Find(&dataDefaultRate, &dataErrRate)
  662. }
  663. //fmt.Println("dataDefaultRate:", dataDefaultRate)
  664. db1 := GetReadDB(context.Background())
  665. var taskLinkInfo gorm_model.YounggeeLinkInfo
  666. db1.Model(gorm_model.YounggeeLinkInfo{}).Where("task_id = ? AND is_ok = ?", taskNeedModId, 1).Find(&taskLinkInfo)
  667. dbTask := GetReadDB(context.Background())
  668. var taskInfoCurr gorm_model.YoungeeTaskInfo
  669. dbTask.Model(gorm_model.YoungeeTaskInfo{}).Where("task_id = ?", taskNeedModId).Find(&taskInfoCurr)
  670. if taskInfoCurr.DataMissingTime.IsZero() {
  671. db1.Where("task_id = ?", taskNeedModId).Updates(&gorm_model.YounggeeLinkInfo{AutoDataBreakAt: taskLinkInfo.AgreeAt.Add(dd)})
  672. dbTask.Where("task_id = ?", taskNeedModId).Updates(&gorm_model.YoungeeTaskInfo{DataMissingTime: taskLinkInfo.AgreeAt.Add(dd)})
  673. fmt.Println("已添加数据违约自动处理时间")
  674. } else {
  675. if taskInfoCurr.TaskID != "" && taskInfoCurr.DataMissingTime.Sub(time.Now()) <= 0 {
  676. //db4 := GetReadDB(context.Background())
  677. //err1 := db4.Model(gorm_model.YoungeeContractInfo{}).Create(&gorm_model.YoungeeContractInfo{
  678. // TaskID: taskNeedModId, ProjectID: taskIdToProjectIdMap[taskNeedModId], BreakType: 4, BreakAt: time.Now(), DefaultStatus: 1}).Error
  679. //if err1 != nil {
  680. // return err1
  681. //}
  682. taskInfo := gorm_model.YoungeeTaskInfo{}
  683. dbt := GetReadDB(context.Background())
  684. err2 := dbt.Model(gorm_model.YoungeeTaskInfo{}).Where("task_id = ?", taskNeedModId).Find(&taskInfo).Error
  685. if err2 != nil {
  686. return err2
  687. }
  688. // 达人实际所得
  689. settleAmount := taskInfo.DraftFee * (1.0 - float64(dataDefaultRate+taskInfo.DataBreakRate+taskInfo.SketchBreakRate+taskInfo.ScriptBreakRate)/100)
  690. if settleAmount <= 0 {
  691. settleAmount = 0.0
  692. }
  693. // 服务商实际所得
  694. realServiceCharge := taskInfo.ServiceCharge * (1.0 - float64(taskInfo.LinkBreakRate+taskInfo.DataBreakRate+dataDefaultRate+taskInfo.ScriptBreakRate)/100)
  695. if realServiceCharge <= 0 {
  696. realServiceCharge = 0.0
  697. }
  698. // 企业实际支付
  699. realPayment := settleAmount + realServiceCharge
  700. if realPayment <= 0 {
  701. realPayment = 0.0
  702. }
  703. fmt.Println("settleAmount: ", settleAmount)
  704. db3 := GetReadDB(context.Background())
  705. err2 = db3.Model(gorm_model.YoungeeTaskInfo{}).Where("task_id = ?", taskNeedModId).Updates(
  706. map[string]interface{}{
  707. "data_missing_status": 1,
  708. "cur_default_type": 7,
  709. "sketch_break_rate": dataDefaultRate,
  710. "settle_amount": settleAmount,
  711. "err_break_rate": dataErrRate,
  712. "real_payment": realPayment,
  713. "real_service_charge": realServiceCharge,
  714. }).Error
  715. if err2 != nil {
  716. return err2
  717. }
  718. err = CreateTaskLog(context.Background(), taskNeedModId, "数据逾期")
  719. if err != nil {
  720. log.WithContext(context.Background()).Errorf("[operate db] call CreateTaskLog error,err:%+v", err)
  721. }
  722. err = CreateMessageByTaskId(context.Background(), 24, 4, taskNeedModId)
  723. if err != nil {
  724. log.WithContext(context.Background()).Errorf("[operate db] call CreateMessageByTaskId error,err:%+v", err)
  725. }
  726. fmt.Println("已创建数据违约记录")
  727. }
  728. }
  729. }
  730. // 3. 针对待修改的子任务
  731. for _, submitTaskNeedModId := range submitTaskNeedModIds {
  732. db2 := GetReadDB(context.Background())
  733. var LinkBreach int32
  734. db2.Model(&gorm_model.InfoAutoTask{}).Select("case_close_default").Where("auto_task_id = ?", projectIdToAutoTaskIdMap[taskIdToProjectIdMap[submitTaskNeedModId]]).First(&LinkBreach)
  735. dd, _ := time.ParseDuration(conv.MustString(LinkBreach, "") + "h")
  736. autoDefaultHandle := gorm_model.InfoAutoDefaultHandle{}
  737. db6 := GetReadDB(context.Background())
  738. db6.Model(gorm_model.InfoAutoDefaultHandle{}).Where("auto_default_id = ?", projectIdToAutoDefaultIdMap[taskIdToProjectIdMap[submitTaskNeedModId]]).Find(&autoDefaultHandle)
  739. var dataDefaultRate int
  740. var dataErrRate int
  741. if taskIdToFeeFormMap[submitTaskNeedModId] == 1 {
  742. dataDefaultRate = autoDefaultHandle.DataReplaceTimeOut
  743. dataErrRate = autoDefaultHandle.DataReplaceNotUpload
  744. // db6 := GetReadDB(context.Background())
  745. // db6.Model(gorm_model.InfoAutoDefaultHandle{}).Select("data_replace_time_out", "data_replace_not_upload").Where("auto_default_id = ?", projectIdToAutoDefaultIdMap[taskIdToProjectIdMap[submitTaskNeedModId]]).Find(&dataDefaultRate, &dataErrRate)
  746. } else {
  747. dataDefaultRate = autoDefaultHandle.DataOtherTimeOut
  748. dataErrRate = autoDefaultHandle.DataOtherNotUpload
  749. // db6 := GetReadDB(context.Background())
  750. // db6.Model(gorm_model.InfoAutoDefaultHandle{}).Select("data_other_time_out", "data_other_not_upload").Where("auto_default_id = ?", projectIdToAutoDefaultIdMap[taskIdToProjectIdMap[submitTaskNeedModId]]).Find(&dataDefaultRate, &dataErrRate)
  751. }
  752. db1 := GetReadDB(context.Background())
  753. var taskDataInfo gorm_model.YounggeeDataInfo
  754. db1.Model(gorm_model.YounggeeDataInfo{}).Where("task_id = ? and is_review = 1", submitTaskNeedModId).Order("reject_at desc").First(&taskDataInfo)
  755. if taskDataInfo.AutoDataBreakAt.IsZero() {
  756. err4 := db1.Where("task_id = ?", submitTaskNeedModId).Updates(&gorm_model.YounggeeDataInfo{AutoDataBreakAt: taskDataInfo.RejectAt.Add(dd)}).Error
  757. if err4 != nil {
  758. return err4
  759. }
  760. fmt.Println("已添加数据违约自动处理时间")
  761. } else {
  762. if taskDataInfo.TaskID != "" && taskDataInfo.AutoDataBreakAt.Sub(time.Now()) <= 0 {
  763. db4 := GetReadDB(context.Background())
  764. err1 := db4.Model(gorm_model.YoungeeContractInfo{}).Create(&gorm_model.YoungeeContractInfo{
  765. TaskID: submitTaskNeedModId, ProjectID: taskIdToProjectIdMap[submitTaskNeedModId], BreakType: 4, BreakAt: time.Now(), DefaultStatus: 1}).Error
  766. if err1 != nil {
  767. return err1
  768. }
  769. taskInfo := gorm_model.YoungeeTaskInfo{}
  770. dbt := GetReadDB(context.Background())
  771. err2 := dbt.Model(gorm_model.YoungeeTaskInfo{}).Where("task_id = ?", submitTaskNeedModId).Find(&taskInfo).Error
  772. if err2 != nil {
  773. return err2
  774. }
  775. // 达人实际所得
  776. settleAmount := taskInfo.DraftFee * (1.0 - float64(dataDefaultRate+taskInfo.DataBreakRate+taskInfo.SketchBreakRate+taskInfo.ScriptBreakRate)/100)
  777. if settleAmount <= 0 {
  778. settleAmount = 0.0
  779. }
  780. // 服务商实际所得
  781. realServiceCharge := taskInfo.ServiceCharge * (1.0 - float64(taskInfo.LinkBreakRate+taskInfo.DataBreakRate+dataDefaultRate+taskInfo.ScriptBreakRate)/100)
  782. if realServiceCharge <= 0 {
  783. realServiceCharge = 0.0
  784. }
  785. // 企业实际支付
  786. realPayment := settleAmount + realServiceCharge
  787. if realPayment <= 0 {
  788. realPayment = 0.0
  789. }
  790. db3 := GetReadDB(context.Background())
  791. err2 = db3.Model(gorm_model.YoungeeTaskInfo{}).Where("task_id = ?", submitTaskNeedModId).Updates(
  792. map[string]interface{}{
  793. "data_missing_status": 1,
  794. "cur_default_type": 7,
  795. "sketch_break_rate": dataDefaultRate,
  796. "settle_amount": settleAmount,
  797. "err_break_rate": dataErrRate,
  798. "real_payment": realPayment,
  799. "real_service_charge": realServiceCharge,
  800. }).Error
  801. if err2 != nil {
  802. return err2
  803. }
  804. err = CreateTaskLog(context.Background(), submitTaskNeedModId, "数据逾期")
  805. if err != nil {
  806. log.WithContext(context.Background()).Errorf("[operate db] call CreateTaskLog error,err:%+v", err)
  807. }
  808. err = CreateMessageByTaskId(context.Background(), 24, 4, submitTaskNeedModId)
  809. if err != nil {
  810. log.WithContext(context.Background()).Errorf("[operate db] call CreateMessageByTaskId error,err:%+v", err)
  811. }
  812. fmt.Println("创建已提交数据的数据违约记录")
  813. }
  814. }
  815. }
  816. return nil
  817. }