data.go 12 KB

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