data.go 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. package service
  2. import (
  3. "context"
  4. "fmt"
  5. "strings"
  6. "youngee_b_api/db"
  7. "youngee_b_api/model/gorm_model"
  8. "youngee_b_api/model/http_model"
  9. "github.com/sirupsen/logrus"
  10. )
  11. var Data *data
  12. type data struct {
  13. }
  14. // DataOpinion 在上传脚本表上提交修改意见
  15. func (*data) DataOpinion(ctx context.Context, request http_model.DataOpinionRequest) (*http_model.DataOpinionData, error) {
  16. Data := gorm_model.YounggeeDataInfo{
  17. TaskID: request.TaskID,
  18. ReviseOpinion: request.DataOpinion,
  19. }
  20. err := db.DataOpinion(ctx, Data.TaskID, Data.ReviseOpinion)
  21. if err != nil {
  22. logrus.WithContext(ctx).Errorf("[Data service] call CreateData error,err:%+v", err)
  23. return nil, err
  24. }
  25. // 记录任务日志
  26. err = db.CreateTaskLog(ctx, Data.TaskID, "数据驳回")
  27. if err != nil {
  28. logrus.WithContext(ctx).Errorf("[Link service] call CreateTaskLog error,err:%+v", err)
  29. return nil, err
  30. }
  31. res := &http_model.DataOpinionData{
  32. TaskID: Data.TaskID,
  33. }
  34. return res, nil
  35. }
  36. // 任务结案service
  37. func (*data) AcceptData(ctx context.Context, request http_model.AcceptDataRequest) (*http_model.AcceptDataData, error) {
  38. var TaskIDList []string
  39. TaskIDs := strings.Split(request.TaskIds, ",")
  40. for _, taskId := range TaskIDs {
  41. TaskIDList = append(TaskIDList, taskId)
  42. }
  43. // 1. 更新YounggeeDataInfo表,通过数据
  44. fmt.Printf("acc request %+v", TaskIDList)
  45. err := db.AcceptData(ctx, TaskIDList)
  46. if err != nil {
  47. logrus.WithContext(ctx).Errorf("[Data service] call AcceptData error,err:%+v", err)
  48. return nil, err
  49. }
  50. // 记录任务日志
  51. for _, taskId := range TaskIDList {
  52. err = db.CreateTaskLog(ctx, taskId, "数据通过")
  53. if err != nil {
  54. logrus.WithContext(ctx).Errorf("[Data service] call CreateTaskLog error,err:%+v", err)
  55. return nil, err
  56. }
  57. }
  58. // 2. 更新YoungeeTaskInfo表,将任务结案
  59. fmt.Printf("acc request %+v", TaskIDList)
  60. err = db.SetTaskFinish(ctx, TaskIDList)
  61. if err != nil {
  62. logrus.WithContext(ctx).Errorf("[Data service] call SetTaskFinish error,err:%+v", err)
  63. return nil, err
  64. }
  65. res := &http_model.AcceptDataData{
  66. TaskIds: TaskIDList,
  67. IsEnd: 0,
  68. }
  69. err = db.SetTalentIncome(ctx, TaskIDList)
  70. if err != nil {
  71. logrus.WithContext(ctx).Errorf("[Data service] call SetTalentIncome error,err:%+v", err)
  72. return nil, err
  73. }
  74. // 3. 判断是否全部任务已结案,若已全部结案则触发项目结案
  75. // 查询task_stage<15的任务数量
  76. unFinishedTaskNumber, err1 := db.GetUnfinishedTaskNumber(ctx, request.ProjectId)
  77. if err1 != nil {
  78. logrus.WithContext(ctx).Errorf("[Data service] call GetUnfinishedTaskNumber error,err:%+v", err)
  79. return nil, err
  80. }
  81. if *unFinishedTaskNumber == 0 { // 若为0则触发项目结案
  82. err := db.SetProjectFinish(ctx, request.ProjectId)
  83. if err1 != nil {
  84. logrus.WithContext(ctx).Errorf("[Data service] call SetProjectFinish error,err:%+v", err)
  85. return nil, err
  86. }
  87. res.IsEnd = 1
  88. }
  89. return res, nil
  90. }