data.go 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342
  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, 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. //// 3. 判断是否全部任务已结案,若已全部结案则触发项目结案
  112. //// 查询task_stage<15的任务数量
  113. //unFinishedTaskNumber, err1 := db.GetUnfinishedTaskNumber(ctx, request.ProjectId)
  114. //if err1 != nil {
  115. // logrus.WithContext(ctx).Errorf("[Data service] call GetUnfinishedTaskNumber error,err:%+v", err)
  116. // return nil, err
  117. //}
  118. //if *unFinishedTaskNumber == 0 { // 若为0则触发项目结案
  119. // err := db.SetSpecialProjectFinish(ctx, request.ProjectId)
  120. // if err1 != nil {
  121. // logrus.WithContext(ctx).Errorf("[Data service] call SetProjectFinish error,err:%+v", err)
  122. // return nil, err
  123. // }
  124. // //res.IsEnd = 1
  125. //}
  126. } else {
  127. // 2. 更新YoungeeTaskInfo表,将任务结案
  128. //fmt.Printf("acc request %+v", TaskIDList)
  129. err = db.SetTaskFinish(ctx, TaskIDList)
  130. if err != nil {
  131. logrus.WithContext(ctx).Errorf("[Data service] call SetTaskFinish error,err:%+v", err)
  132. return nil, err
  133. }
  134. err = db.SetTalentIncome(ctx, TaskIDList)
  135. if err != nil {
  136. logrus.WithContext(ctx).Errorf("[Data service] call SetTalentIncome error,err:%+v", err)
  137. return nil, err
  138. }
  139. err = db.SetSpecialTaskSettleNum(ctx, TaskIDList)
  140. if err != nil {
  141. logrus.WithContext(ctx).Errorf("[Data service] call SetSpecialTaskSettleNum error,err:%+v", err)
  142. return nil, err
  143. }
  144. // 3. 判断是否全部任务已结案,若已全部结案则触发项目结案
  145. // 查询task_stage<15的任务数量
  146. //unFinishedTaskNumber, err1 := db.GetUnfinishedTaskNumber(ctx, request.ProjectId)
  147. //if err1 != nil {
  148. // logrus.WithContext(ctx).Errorf("[Data service] call GetUnfinishedTaskNumber error,err:%+v", err)
  149. // return nil, err
  150. //}
  151. //if *unFinishedTaskNumber == 0 { // 若为0则触发项目结案
  152. // err := db.SetProjectFinish(ctx, request.ProjectId)
  153. // if err1 != nil {
  154. // logrus.WithContext(ctx).Errorf("[Data service] call SetProjectFinish error,err:%+v", err)
  155. // return nil, err
  156. // }
  157. // res.IsEnd = 1
  158. //}
  159. }
  160. return res, nil
  161. }
  162. // 任务结案service
  163. func (*data) LocalAcceptData(ctx context.Context, request http_model.LocalAcceptDataRequest) (*http_model.LocalAcceptDataData, error) {
  164. var TaskIDList []string
  165. TaskIDs := strings.Split(request.TaskIds, ",")
  166. for _, taskId := range TaskIDs {
  167. TaskIDList = append(TaskIDList, taskId)
  168. }
  169. // 1. 更新YounggeeDataInfo表,通过数据
  170. fmt.Printf("acc request %+v", TaskIDList)
  171. err := db.AcceptData(ctx, TaskIDList, request.OperatorId, request.OperateType)
  172. if err != nil {
  173. logrus.WithContext(ctx).Errorf("[Data service] call AcceptData error,err:%+v", err)
  174. return nil, err
  175. }
  176. // 记录任务日志和达人消息
  177. for _, taskId := range TaskIDList {
  178. err = db.CreateTaskLog(ctx, taskId, "数据通过")
  179. if err != nil {
  180. logrus.WithContext(ctx).Errorf("[Data service] call CreateTaskLog error,err:%+v", err)
  181. return nil, err
  182. }
  183. err = db.CreateMessageByTaskId(ctx, 5, 1, taskId)
  184. if err != nil {
  185. logrus.WithContext(ctx).Errorf("[Script service] call CreateTaskLog error,err:%+v", err)
  186. return nil, err
  187. }
  188. }
  189. res := &http_model.LocalAcceptDataData{
  190. TaskIds: TaskIDList,
  191. //IsEnd: 0,
  192. }
  193. if request.IsSpecial == 1 {
  194. // 2. 更新YoungeeTaskInfo表,将任务结案
  195. err = db.SetSpecialLocalTaskFinish(ctx, TaskIDList)
  196. if err != nil {
  197. logrus.WithContext(ctx).Errorf("[Data service] call SetTaskFinish error,err:%+v", err)
  198. return nil, err
  199. }
  200. err = db.SetSpecialLocalTaskSettleNum(ctx, TaskIDList)
  201. if err != nil {
  202. logrus.WithContext(ctx).Errorf("[Data service] call SetSpecialTaskSettleNum error,err:%+v", err)
  203. return nil, err
  204. }
  205. //// 3. 判断是否全部任务已结案,若已全部结案则触发项目结案
  206. //// 查询task_stage<15的任务数量
  207. //unFinishedTaskNumber, err1 := db.GetUnfinishedTaskNumber(ctx, request.ProjectId)
  208. //if err1 != nil {
  209. // logrus.WithContext(ctx).Errorf("[Data service] call GetUnfinishedTaskNumber error,err:%+v", err)
  210. // return nil, err
  211. //}
  212. //if *unFinishedTaskNumber == 0 { // 若为0则触发项目结案
  213. // err := db.SetSpecialProjectFinish(ctx, request.ProjectId)
  214. // if err1 != nil {
  215. // logrus.WithContext(ctx).Errorf("[Data service] call SetProjectFinish error,err:%+v", err)
  216. // return nil, err
  217. // }
  218. // res.IsEnd = 1
  219. //}
  220. } else {
  221. // 2. 更新YoungeeTaskInfo表,将任务结案
  222. fmt.Printf("acc request %+v", TaskIDList)
  223. err = db.SetLocalTaskFinish(ctx, TaskIDList)
  224. if err != nil {
  225. logrus.WithContext(ctx).Errorf("[Data service] call SetTaskFinish error,err:%+v", err)
  226. return nil, err
  227. }
  228. err = db.SetLocalTalentIncome(ctx, TaskIDList)
  229. if err != nil {
  230. logrus.WithContext(ctx).Errorf("[Data service] call SetTalentIncome error,err:%+v", err)
  231. return nil, err
  232. }
  233. err = db.SetSpecialLocalTaskSettleNum(ctx, TaskIDList)
  234. if err != nil {
  235. logrus.WithContext(ctx).Errorf("[Data service] call SetSpecialTaskSettleNum error,err:%+v", err)
  236. return nil, err
  237. }
  238. //// 3. 判断是否全部任务已结案,若已全部结案则触发项目结案
  239. //// 查询task_stage<15的任务数量
  240. //unFinishedTaskNumber, err1 := db.GetUnfinishedTaskNumber(ctx, request.ProjectId)
  241. //if err1 != nil {
  242. // logrus.WithContext(ctx).Errorf("[Data service] call GetUnfinishedTaskNumber error,err:%+v", err)
  243. // return nil, err
  244. //}
  245. //if *unFinishedTaskNumber == 0 { // 若为0则触发项目结案
  246. // err := db.SetProjectFinish(ctx, request.ProjectId)
  247. // if err1 != nil {
  248. // logrus.WithContext(ctx).Errorf("[Data service] call SetProjectFinish error,err:%+v", err)
  249. // return nil, err
  250. // }
  251. // res.IsEnd = 1
  252. //}
  253. }
  254. return res, nil
  255. }
  256. // RejectData
  257. func (*data) RejectData(ctx context.Context, request http_model.RejectDataRequest) (*http_model.RejectDataData, error) {
  258. var TaskIDList []string
  259. TaskIDs := strings.Split(request.TaskIds, ",")
  260. for _, taskId := range TaskIDs {
  261. TaskIDList = append(TaskIDList, taskId)
  262. }
  263. //fmt.Printf("acc request %+v", TaskIDList)
  264. err := db.RejectData(ctx, TaskIDList, request.OperatorId, request.OperateType, request.ProjectId)
  265. if err != nil {
  266. logrus.WithContext(ctx).Errorf("[Link service] call CreateLink error,err:%+v", err)
  267. return nil, err
  268. }
  269. // 记录任务日志
  270. for _, taskId := range TaskIDList {
  271. err = db.CreateTaskLog(ctx, taskId, "数据驳回")
  272. if err != nil {
  273. logrus.WithContext(ctx).Errorf("[Link service] call CreateTaskLog error,err:%+v", err)
  274. return nil, err
  275. }
  276. err = db.CreateMessageByTaskId(ctx, 19, 3, taskId)
  277. if err != nil {
  278. logrus.WithContext(ctx).Errorf("[Script service] call CreateTaskLog error,err:%+v", err)
  279. return nil, err
  280. }
  281. }
  282. res := &http_model.RejectDataData{
  283. TaskIds: TaskIDList,
  284. }
  285. return res, nil
  286. }
  287. // RejectData
  288. func (*data) LocalRejectData(ctx context.Context, request http_model.LocalRejectDataRequest) (*http_model.LocalRejectDataData, error) {
  289. var TaskIDList []string
  290. TaskIDs := strings.Split(request.TaskIds, ",")
  291. for _, taskId := range TaskIDs {
  292. TaskIDList = append(TaskIDList, taskId)
  293. }
  294. fmt.Printf("acc request %+v", TaskIDList)
  295. err := db.LocalRejectData(ctx, TaskIDList, request.OperatorId, request.OperateType, request.ProjectId)
  296. if err != nil {
  297. logrus.WithContext(ctx).Errorf("[Link service] call CreateLink error,err:%+v", err)
  298. return nil, err
  299. }
  300. // 记录任务日志
  301. for _, taskId := range TaskIDList {
  302. err = db.CreateTaskLog(ctx, taskId, "数据驳回")
  303. if err != nil {
  304. logrus.WithContext(ctx).Errorf("[Link service] call CreateTaskLog error,err:%+v", err)
  305. return nil, err
  306. }
  307. err = db.CreateMessageByTaskId(ctx, 19, 3, taskId)
  308. if err != nil {
  309. logrus.WithContext(ctx).Errorf("[Script service] call CreateTaskLog error,err:%+v", err)
  310. return nil, err
  311. }
  312. }
  313. res := &http_model.LocalRejectDataData{
  314. TaskIds: TaskIDList,
  315. }
  316. return res, nil
  317. }