data.go 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312
  1. package service
  2. import (
  3. "context"
  4. "fmt"
  5. "strings"
  6. "youngee_m_api/db"
  7. "youngee_m_api/model/gorm_model"
  8. "youngee_m_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, request.OperatorId, request.OperateType, request.ProjectId)
  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. err = db.CreateMessageByTaskId(ctx, 19, 3, Data.TaskID)
  32. if err != nil {
  33. logrus.WithContext(ctx).Errorf("[Data service] call CreateMessageByTaskId error,err:%+v", err)
  34. return nil, err
  35. }
  36. res := &http_model.DataOpinionData{
  37. TaskID: Data.TaskID,
  38. }
  39. return res, nil
  40. }
  41. // DataOpinion 在上传脚本表上提交修改意见
  42. func (*data) LocalDataOpinion(ctx context.Context, request http_model.LocalDataOpinionRequest) (*http_model.LocalDataOpinionData, error) {
  43. Data := gorm_model.YounggeeDataInfo{
  44. TaskID: request.TaskID,
  45. ReviseOpinion: request.LocalDataOpinion,
  46. }
  47. err := db.LocalDataOpinion(ctx, Data.TaskID, Data.ReviseOpinion, request.OperatorId, request.OperateType, request.ProjectId)
  48. if err != nil {
  49. logrus.WithContext(ctx).Errorf("[Data service] call CreateData error,err:%+v", err)
  50. return nil, err
  51. }
  52. // 记录任务日志
  53. err = db.CreateTaskLog(ctx, Data.TaskID, "数据驳回")
  54. if err != nil {
  55. logrus.WithContext(ctx).Errorf("[Link service] call CreateTaskLog error,err:%+v", err)
  56. return nil, err
  57. }
  58. err = db.CreateMessageByTaskId(ctx, 19, 3, Data.TaskID)
  59. if err != nil {
  60. logrus.WithContext(ctx).Errorf("[Data service] call CreateMessageByTaskId error,err:%+v", err)
  61. return nil, err
  62. }
  63. res := &http_model.LocalDataOpinionData{
  64. TaskID: Data.TaskID,
  65. }
  66. return res, nil
  67. }
  68. // 任务结案service
  69. func (*data) AcceptData(ctx context.Context, request http_model.AcceptDataRequest) (*http_model.AcceptDataData, error) {
  70. var TaskIDList []string
  71. TaskIDs := strings.Split(request.TaskIds, ",")
  72. for _, taskId := range TaskIDs {
  73. TaskIDList = append(TaskIDList, taskId)
  74. }
  75. // 1. 更新YounggeeDataInfo表,通过数据
  76. //fmt.Printf("acc request %+v", TaskIDList)
  77. err := db.AcceptData(ctx, TaskIDList, request.OperatorId, request.OperateType)
  78. if err != nil {
  79. logrus.WithContext(ctx).Errorf("[Data service] call AcceptData error,err:%+v", err)
  80. return nil, err
  81. }
  82. // 记录任务日志和达人消息
  83. for _, taskId := range TaskIDList {
  84. err = db.CreateTaskLog(ctx, taskId, "数据通过")
  85. if err != nil {
  86. logrus.WithContext(ctx).Errorf("[Data service] call CreateTaskLog error,err:%+v", err)
  87. return nil, err
  88. }
  89. err = db.CreateMessageByTaskId(ctx, 5, 1, taskId)
  90. if err != nil {
  91. logrus.WithContext(ctx).Errorf("[Script service] call CreateTaskLog error,err:%+v", err)
  92. return nil, err
  93. }
  94. }
  95. res := &http_model.AcceptDataData{
  96. TaskIds: TaskIDList,
  97. //IsEnd: 0,
  98. }
  99. if request.IsSpecial == 1 {
  100. // 2. 更新YoungeeTaskInfo表,将任务结案
  101. err = db.SetSpecialTaskFinish(ctx, TaskIDList)
  102. if err != nil {
  103. logrus.WithContext(ctx).Errorf("[Data service] call SetTaskFinish error,err:%+v", err)
  104. return nil, err
  105. }
  106. err = db.SetSpecialTaskSettleNum(ctx, TaskIDList)
  107. if err != nil {
  108. logrus.WithContext(ctx).Errorf("[Data service] call SetSpecialTaskSettleNum error,err:%+v", err)
  109. return nil, err
  110. }
  111. } else {
  112. // 2. 更新YoungeeTaskInfo表,将任务结案
  113. fmt.Printf("acc request %+v", TaskIDList)
  114. err = db.SetTaskFinish(ctx, TaskIDList)
  115. if err != nil {
  116. logrus.WithContext(ctx).Errorf("[Data service] call SetTaskFinish error,err:%+v", err)
  117. return nil, err
  118. }
  119. err = db.SetTalentIncome(ctx, TaskIDList)
  120. if err != nil {
  121. logrus.WithContext(ctx).Errorf("[Data service] call SetTalentIncome error,err:%+v", err)
  122. return nil, err
  123. }
  124. err = db.SetSpecialTaskSettleNum(ctx, TaskIDList)
  125. if err != nil {
  126. logrus.WithContext(ctx).Errorf("[Data service] call SetSpecialTaskSettleNum error,err:%+v", err)
  127. return nil, err
  128. }
  129. }
  130. return res, nil
  131. }
  132. // RejectData
  133. func (*data) RejectData(ctx context.Context, request http_model.RejectDataRequest) (*http_model.RejectDataData, error) {
  134. var TaskIDList []string
  135. TaskIDs := strings.Split(request.TaskIds, ",")
  136. for _, taskId := range TaskIDs {
  137. TaskIDList = append(TaskIDList, taskId)
  138. }
  139. //fmt.Printf("acc request %+v", TaskIDList)
  140. err := db.RejectData(ctx, TaskIDList, request.OperatorId, request.OperateType, request.ProjectId)
  141. if err != nil {
  142. logrus.WithContext(ctx).Errorf("[Link service] call CreateLink error,err:%+v", err)
  143. return nil, err
  144. }
  145. // 记录任务日志
  146. for _, taskId := range TaskIDList {
  147. err = db.CreateTaskLog(ctx, taskId, "数据驳回")
  148. if err != nil {
  149. logrus.WithContext(ctx).Errorf("[Link service] call CreateTaskLog error,err:%+v", err)
  150. return nil, err
  151. }
  152. err = db.CreateMessageByTaskId(ctx, 19, 3, taskId)
  153. if err != nil {
  154. logrus.WithContext(ctx).Errorf("[Script service] call CreateTaskLog error,err:%+v", err)
  155. return nil, err
  156. }
  157. }
  158. res := &http_model.RejectDataData{
  159. TaskIds: TaskIDList,
  160. }
  161. return res, nil
  162. }
  163. // 任务结案service
  164. func (*data) LocalAcceptData(ctx context.Context, request http_model.LocalAcceptDataRequest) (*http_model.LocalAcceptDataData, error) {
  165. var TaskIDList []string
  166. TaskIDs := strings.Split(request.TaskIds, ",")
  167. for _, taskId := range TaskIDs {
  168. TaskIDList = append(TaskIDList, taskId)
  169. }
  170. // 1. 更新YounggeeDataInfo表,通过数据
  171. //fmt.Printf("acc request %+v", TaskIDList)
  172. err := db.AcceptData(ctx, TaskIDList, request.OperatorId, request.OperateType)
  173. if err != nil {
  174. logrus.WithContext(ctx).Errorf("[Data service] call AcceptData error,err:%+v", err)
  175. return nil, err
  176. }
  177. // 记录任务日志和达人消息
  178. for _, taskId := range TaskIDList {
  179. err = db.CreateTaskLog(ctx, taskId, "数据通过")
  180. if err != nil {
  181. logrus.WithContext(ctx).Errorf("[Data service] call CreateTaskLog error,err:%+v", err)
  182. return nil, err
  183. }
  184. err = db.CreateMessageByTaskId(ctx, 5, 1, taskId)
  185. if err != nil {
  186. logrus.WithContext(ctx).Errorf("[Script service] call CreateTaskLog error,err:%+v", err)
  187. return nil, err
  188. }
  189. }
  190. res := &http_model.LocalAcceptDataData{
  191. TaskIds: TaskIDList,
  192. //IsEnd: 0,
  193. }
  194. if request.IsSpecial == 1 {
  195. // 2. 更新YoungeeTaskInfo表,将任务结案
  196. err = db.SetSpecialLocalTaskFinish(ctx, TaskIDList)
  197. if err != nil {
  198. logrus.WithContext(ctx).Errorf("[Data service] call SetTaskFinish error,err:%+v", err)
  199. return nil, err
  200. }
  201. err = db.SetSpecialLocalTaskSettleNum(ctx, TaskIDList)
  202. if err != nil {
  203. logrus.WithContext(ctx).Errorf("[Data service] call SetSpecialTaskSettleNum error,err:%+v", err)
  204. return nil, err
  205. }
  206. //// 3. 判断是否全部任务已结案,若已全部结案则触发项目结案
  207. //// 查询task_stage<15的任务数量
  208. //unFinishedTaskNumber, err1 := db.GetUnfinishedTaskNumber(ctx, request.ProjectId)
  209. //if err1 != nil {
  210. // logrus.WithContext(ctx).Errorf("[Data service] call GetUnfinishedTaskNumber error,err:%+v", err)
  211. // return nil, err
  212. //}
  213. //if *unFinishedTaskNumber == 0 { // 若为0则触发项目结案
  214. // err := db.SetSpecialProjectFinish(ctx, request.ProjectId)
  215. // if err1 != nil {
  216. // logrus.WithContext(ctx).Errorf("[Data service] call SetProjectFinish error,err:%+v", err)
  217. // return nil, err
  218. // }
  219. // res.IsEnd = 1
  220. //}
  221. } else {
  222. // 2. 更新YoungeeTaskInfo表,将任务结案
  223. fmt.Printf("acc request %+v", TaskIDList)
  224. err = db.SetLocalTaskFinish(ctx, TaskIDList)
  225. if err != nil {
  226. logrus.WithContext(ctx).Errorf("[Data service] call SetTaskFinish error,err:%+v", err)
  227. return nil, err
  228. }
  229. err = db.SetLocalTalentIncome(ctx, TaskIDList)
  230. if err != nil {
  231. logrus.WithContext(ctx).Errorf("[Data service] call SetTalentIncome error,err:%+v", err)
  232. return nil, err
  233. }
  234. err = db.SetSpecialLocalTaskSettleNum(ctx, TaskIDList)
  235. if err != nil {
  236. logrus.WithContext(ctx).Errorf("[Data service] call SetSpecialTaskSettleNum error,err:%+v", err)
  237. return nil, err
  238. }
  239. //// 3. 判断是否全部任务已结案,若已全部结案则触发项目结案
  240. //// 查询task_stage<15的任务数量
  241. //unFinishedTaskNumber, err1 := db.GetUnfinishedTaskNumber(ctx, request.ProjectId)
  242. //if err1 != nil {
  243. // logrus.WithContext(ctx).Errorf("[Data service] call GetUnfinishedTaskNumber error,err:%+v", err)
  244. // return nil, err
  245. //}
  246. //if *unFinishedTaskNumber == 0 { // 若为0则触发项目结案
  247. // err := db.SetProjectFinish(ctx, request.ProjectId)
  248. // if err1 != nil {
  249. // logrus.WithContext(ctx).Errorf("[Data service] call SetProjectFinish error,err:%+v", err)
  250. // return nil, err
  251. // }
  252. // res.IsEnd = 1
  253. //}
  254. }
  255. return res, nil
  256. }
  257. // RejectData
  258. func (*data) LocalRejectData(ctx context.Context, request http_model.LocalRejectDataRequest) (*http_model.LocalRejectDataData, error) {
  259. var TaskIDList []string
  260. TaskIDs := strings.Split(request.TaskIds, ",")
  261. for _, taskId := range TaskIDs {
  262. TaskIDList = append(TaskIDList, taskId)
  263. }
  264. fmt.Printf("acc request %+v", TaskIDList)
  265. err := db.LocalRejectData(ctx, TaskIDList, request.OperatorId, request.OperateType, request.ProjectId)
  266. if err != nil {
  267. logrus.WithContext(ctx).Errorf("[Link service] call CreateLink error,err:%+v", err)
  268. return nil, err
  269. }
  270. // 记录任务日志
  271. for _, taskId := range TaskIDList {
  272. err = db.CreateTaskLog(ctx, taskId, "数据驳回")
  273. if err != nil {
  274. logrus.WithContext(ctx).Errorf("[Link service] call CreateTaskLog error,err:%+v", err)
  275. return nil, err
  276. }
  277. err = db.CreateMessageByTaskId(ctx, 19, 3, taskId)
  278. if err != nil {
  279. logrus.WithContext(ctx).Errorf("[Script service] call CreateTaskLog error,err:%+v", err)
  280. return nil, err
  281. }
  282. }
  283. res := &http_model.LocalRejectDataData{
  284. TaskIds: TaskIDList,
  285. }
  286. return res, nil
  287. }