task.go 26 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691
  1. package db
  2. import (
  3. "context"
  4. "fmt"
  5. "github.com/tidwall/gjson"
  6. "reflect"
  7. "strconv"
  8. "strings"
  9. "time"
  10. "youngee_m_api/model/common_model"
  11. "youngee_m_api/model/gorm_model"
  12. "youngee_m_api/model/http_model"
  13. "youngee_m_api/pack"
  14. "youngee_m_api/util"
  15. "github.com/caixw/lib.go/conv"
  16. "gorm.io/gorm"
  17. "github.com/sirupsen/logrus"
  18. )
  19. func GetTaskList(ctx context.Context, projectID string) ([]gorm_model.YoungeeTaskInfo, error) {
  20. db := GetReadDB(ctx)
  21. var tasks []gorm_model.YoungeeTaskInfo
  22. err := db.Where("project_id = ? AND task_status = 2", projectID).Find(&tasks).Error
  23. if err != nil {
  24. return nil, err
  25. }
  26. return tasks, nil
  27. }
  28. func UpdateLogisticsStatus(ctx context.Context, taskID string, status int64) error {
  29. db := GetReadDB(ctx)
  30. err := db.Model(gorm_model.YoungeeTaskInfo{}).Where("task_id = ?", taskID).Update("logistics_status", status).Error
  31. if err != nil {
  32. logrus.WithContext(ctx).Errorf("[task db] call UpdateLogisticsStatus error,err:%+v", err)
  33. return err
  34. }
  35. return nil
  36. }
  37. func UpdateLogisticsDate(ctx context.Context, taskID string) error {
  38. db := GetReadDB(ctx)
  39. err := db.Model(gorm_model.YoungeeTaskInfo{}).Where("task_id = ?", taskID).Update("delivery_date", time.Now()).Error
  40. if err != nil {
  41. logrus.WithContext(ctx).Errorf("[task db] call UpdateLogisticsDate error,err:%+v", err)
  42. return err
  43. }
  44. return nil
  45. }
  46. func GetProjectIdByTaskId(ctx context.Context, taskID string) (*string, error) {
  47. db := GetReadDB(ctx)
  48. task := &gorm_model.YoungeeTaskInfo{}
  49. err := db.Model(gorm_model.YoungeeTaskInfo{}).Where("task_id = ?", taskID).Scan(task).Error
  50. if err != nil {
  51. logrus.WithContext(ctx).Errorf("[task db] call UpdateLogisticsStatus error,err:%+v", err)
  52. return nil, err
  53. }
  54. return &task.ProjectId, nil
  55. }
  56. func ChangeTaskStatus(ctx context.Context, taskIds []string, taskStatus string) ([]int64, error) {
  57. db := GetReadDB(ctx)
  58. taskSta := conv.MustInt(taskStatus, 0)
  59. if err := db.Debug().Model(&gorm_model.YoungeeTaskInfo{}).Where("task_id IN ?", taskIds).
  60. Updates(gorm_model.YoungeeTaskInfo{TaskStatus: taskSta}).Error; err != nil {
  61. logrus.WithContext(ctx).Errorf("[ChangeTaskStatus]2 error query mysql total, err:%+v", err)
  62. return nil, err
  63. }
  64. var taskInfos []gorm_model.YoungeeTaskInfo
  65. err := db.Debug().Model(&gorm_model.YoungeeTaskInfo{}).Where("task_id IN ?", taskIds).Find(&taskInfos).Error
  66. if err != nil {
  67. logrus.WithContext(ctx).Errorf("[ChangeTaskStatus]3 error query mysql total, err:%+v", err)
  68. return nil, err
  69. }
  70. var recruitStrategysIDs []int64
  71. recruitStrategys := gorm_model.RecruitStrategy{}
  72. for _, taskInfo := range taskInfos {
  73. err2 := db.Debug().Model(gorm_model.RecruitStrategy{}).Where("project_id=? AND strategy_id=?", taskInfo.ProjectId, taskInfo.StrategyId).Scan(&recruitStrategys).Error
  74. if err2 != nil {
  75. logrus.WithContext(ctx).Errorf("[ChangeTaskStatus]4 error query mysql total, err:%+v", err2)
  76. return nil, err2
  77. }
  78. recruitStrategysIDs = append(recruitStrategysIDs, recruitStrategys.RecruitStrategyID)
  79. }
  80. return recruitStrategysIDs, nil
  81. }
  82. func ChangeSpecialTaskStatus(ctx context.Context, taskIds []string, taskStatus string, taskStage string) error {
  83. db := GetReadDB(ctx)
  84. status, err := strconv.Atoi(taskStatus)
  85. stage, err := strconv.Atoi(taskStage)
  86. if err != nil {
  87. logrus.WithContext(ctx).Errorf("[ChangeTaskStatus]1 error query mysql total, err:%+v", err)
  88. return err
  89. }
  90. err = db.Transaction(func(tx *gorm.DB) error {
  91. if err := tx.Debug().Model(&gorm_model.YoungeeTaskInfo{}).Where("task_id IN ?", taskIds).
  92. Updates(gorm_model.YoungeeTaskInfo{TaskStatus: status, TaskStage: stage, SelectDate: time.Now()}).Error; err != nil {
  93. logrus.WithContext(ctx).Errorf("[ChangeTaskStatus]2 error query mysql total, err:%+v", err)
  94. return err
  95. }
  96. return nil
  97. })
  98. if err != nil {
  99. return err
  100. }
  101. //if err := db.Debug().Model(&gorm_model.YoungeeTaskInfo{}).Where("task_id IN ?", taskIds).
  102. // Updates(gorm_model.YoungeeTaskInfo{TaskStatus: status, TaskStage: stage, SelectDate: time.Now()}).Error; err != nil {
  103. // logrus.WithContext(ctx).Errorf("[ChangeTaskStatus]2 error query mysql total, err:%+v", err)
  104. // return err
  105. //}
  106. return nil
  107. }
  108. func UpdateTaskStage(ctx context.Context, projectID string, taskStatus int64, taskStage int64) error {
  109. db := GetReadDB(ctx)
  110. err := db.Model(gorm_model.YoungeeTaskInfo{}).Where("project_id=? and task_status = ?", projectID, taskStatus).Update("task_stage", taskStage).Error
  111. if err != nil {
  112. logrus.WithContext(ctx).Errorf("[UpdateTaskStatusPaying]2 error query mysql total, err:%+v", err)
  113. return err
  114. }
  115. return nil
  116. }
  117. func UpdateTaskSelectAtByProjectId(ctx context.Context, projectID string, taskStatus int64) error {
  118. db := GetReadDB(ctx)
  119. err := db.Model(gorm_model.YoungeeTaskInfo{}).Where("project_id=? and task_status = ?", projectID, taskStatus).Update("select_date", time.Now()).Error
  120. if err != nil {
  121. logrus.WithContext(ctx).Errorf("[UpdateTaskStage]2 error query mysql total, err:%+v", err)
  122. return err
  123. }
  124. return nil
  125. }
  126. func UpdateTaskStageByProjectId(ctx context.Context, projectID string, taskStatus int64, taskStage int64) error {
  127. db := GetReadDB(ctx)
  128. err := db.Model(gorm_model.YoungeeTaskInfo{}).Where("project_id=? and task_status = ?", projectID, taskStatus).Update("task_stage", taskStage).Error
  129. if err != nil {
  130. logrus.WithContext(ctx).Errorf("[UpdateTaskStage]2 error query mysql total, err:%+v", err)
  131. return err
  132. }
  133. return nil
  134. }
  135. func GetSpecialTaskInviteList(ctx context.Context, projectID string, pageSize, pageNum int64, conditions *common_model.TalentConditions) ([]*http_model.SpecialTaskInviteInfo, int64, error) {
  136. db := GetReadDB(ctx)
  137. // 查询task表信息
  138. db = db.Debug().Model(gorm_model.YoungeeTaskInfo{}).Where("task_stage != 3")
  139. // 根据Project条件过滤
  140. conditionType := reflect.TypeOf(conditions).Elem()
  141. conditionValue := reflect.ValueOf(conditions).Elem()
  142. var platform_nickname string = ""
  143. for i := 0; i < conditionType.NumField(); i++ {
  144. field := conditionType.Field(i)
  145. tag := field.Tag.Get("condition")
  146. value := conditionValue.FieldByName(field.Name)
  147. if tag == "task_status" {
  148. fmt.Printf("link %+v", value.Interface() == int64(0))
  149. if value.Interface() == int64(0) {
  150. db = db.Where("task_status <> 2")
  151. } else {
  152. db = db.Where("task_status = 2")
  153. }
  154. continue
  155. } else if !util.IsBlank(value) {
  156. if tag == "platform_nickname" {
  157. platform_nickname = fmt.Sprintf("%v", value.Interface())
  158. continue
  159. } else if tag == "project_id" {
  160. db = db.Where(fmt.Sprintf("%s = ?", tag), value.Interface())
  161. }
  162. }
  163. }
  164. var taskInfos []gorm_model.YoungeeTaskInfo
  165. db = db.Model(gorm_model.YoungeeTaskInfo{})
  166. // 查询总数
  167. var totalTask int64
  168. if err := db.Count(&totalTask).Error; err != nil {
  169. logrus.WithContext(ctx).Errorf("[GetProjectTaskList] error query mysql total, err:%+v", err)
  170. return nil, 0, err
  171. }
  172. db.Order("task_id").Find(&taskInfos)
  173. // 查询该页数据
  174. limit := pageSize
  175. offset := pageSize * pageNum // assert pageNum start with 0
  176. err := db.Order("task_id").Limit(int(limit)).Offset(int(offset)).Error
  177. if err != nil {
  178. logrus.WithContext(ctx).Errorf("[GetProjectTaskList] error query mysql total, err:%+v", err)
  179. return nil, 0, err
  180. }
  181. var taskDatas []*http_model.SpecialTaskInviteInfo
  182. var newTaskDatas []*http_model.SpecialTaskInviteInfo
  183. taskDatas = pack.YoungeeTaskInfoToSpecialTaskInviteInfo(taskInfos)
  184. for _, v := range taskDatas {
  185. if platform_nickname == "" {
  186. newTaskDatas = append(newTaskDatas, v)
  187. } else if strings.Contains(v.PlatformNickname, platform_nickname) {
  188. newTaskDatas = append(newTaskDatas, v)
  189. } else if strings.Contains(conv.MustString(v.TaskID, ""), platform_nickname) {
  190. newTaskDatas = append(newTaskDatas, v)
  191. } else {
  192. totalTask--
  193. }
  194. }
  195. return newTaskDatas, totalTask, nil
  196. }
  197. //// SetTaskFinish 任务结案
  198. //func SetTaskFinish(ctx context.Context, TaskIDs []string) error {
  199. // db := GetReadDB(ctx)
  200. // // 1. 修改任务表,更新任务阶段为已结案,结案方式为正常结束,数据状态为已通过,
  201. // err := db.Model(gorm_model.YoungeeTaskInfo{}).Where("task_id in ?", TaskIDs).
  202. // Updates(gorm_model.YoungeeTaskInfo{DataStatus: 5, TaskStage: 15, CompleteStatus: 2, WithdrawStatus: 2, CompleteDate: time.Now()}).Error
  203. // if err != nil {
  204. // logrus.WithContext(ctx).Errorf("[Task db] Update YoungeeTaskInfo error,err:%+v", err)
  205. // return err
  206. // }
  207. //
  208. // // 2. 修改招募策略表,更新粉丝量、播放量、点赞数、收藏数、评论数、总支付、结案数量
  209. // for _, v := range TaskIDs {
  210. // // 查询task_info
  211. // db = GetReadDB(ctx)
  212. // taskInfo := gorm_model.YoungeeTaskInfo{}
  213. // err1 := db.Model(gorm_model.YoungeeTaskInfo{}).Where("task_id = ?", v).Scan(&taskInfo).Error
  214. // if err1 != nil {
  215. // logrus.WithContext(ctx).Errorf("[Task db] Find YoungeeTaskInfo error,err:%+v", err)
  216. // return err1
  217. // }
  218. // //查询project_info
  219. // projectInfo := gorm_model.ProjectInfo{}
  220. // err1 = db.Model(gorm_model.ProjectInfo{}).Where("project_id = ?", taskInfo.ProjectId).Scan(&projectInfo).Error
  221. // if err1 != nil {
  222. // logrus.WithContext(ctx).Errorf("[Task db] Find ProjectInfo error,err:%+v", err)
  223. // return err1
  224. // }
  225. // // 查询data_info
  226. // db = GetReadDB(ctx)
  227. // dataInfo := gorm_model.YounggeeDataInfo{}
  228. // err1 = db.Model(gorm_model.YounggeeDataInfo{}).Where("task_id = ? and is_ok = 1", v).Scan(&dataInfo).Error
  229. // if err1 != nil {
  230. // logrus.WithContext(ctx).Errorf("[Task db] Find YounggeeDataInfo error,err:%+v", err)
  231. // return err1
  232. // }
  233. //
  234. // // 2. 创建任务收益
  235. // var productStruct gorm_model.YounggeeProduct
  236. // if err = json.Unmarshal([]byte(projectInfo.ProductSnap), &productStruct); err != nil {
  237. // fmt.Println("Error:", err)
  238. // return err
  239. // }
  240. // t := time.Now()
  241. // income := gorm_model.YounggeeTalentIncome{
  242. // TalentID: taskInfo.TalentId,
  243. // ProjectID: taskInfo.ProjectId,
  244. // SectaskID: taskInfo.TaskId,
  245. // BrandName: productStruct.BrandName,
  246. // TaskName: projectInfo.ProjectName,
  247. // Income: strconv.FormatFloat(taskInfo.SettleAmount, 'f', 10, 32),
  248. // IncomeType: 1,
  249. // WithdrawStatus: 1,
  250. // IncomeAt: &t,
  251. // WithdrawAt: nil,
  252. // }
  253. // err = CreateIncome(ctx, income, nil)
  254. // if err != nil {
  255. // logrus.WithContext(ctx).Errorf("[projectPay service] call SpecialSettlePay error,err:%+v", err)
  256. // return err
  257. // }
  258. //
  259. // // 更新招募策略
  260. // db = GetReadDB(ctx)
  261. // db = db.Model(gorm_model.RecruitStrategy{}).Where("project_id = ? and strategy_id = ?", taskInfo.ProjectId, taskInfo.StrategyId)
  262. // fansCount, _ := strconv.Atoi(conv.MustString(gjson.Get(taskInfo.TalentPlatformInfoSnap, "fans_count"), ""))
  263. // err = db.Updates(map[string]interface{}{
  264. // "fan_number": gorm.Expr("fan_number + ?", fansCount),
  265. // "play_number": gorm.Expr("play_number + ?", dataInfo.PlayNumber),
  266. // "like_number": gorm.Expr("like_number + ?", dataInfo.LikeNumber),
  267. // "collect_number": gorm.Expr("collect_number + ?", dataInfo.CollectNumber),
  268. // "comment_number": gorm.Expr("comment_number + ?", dataInfo.CommentNumber),
  269. // "finish_number": gorm.Expr("finish_number + 1"),
  270. // "total_offer": gorm.Expr("total_offer + ?", taskInfo.RealPayment)}).Error
  271. // if err != nil {
  272. // logrus.WithContext(ctx).Errorf("[Task db] Update YounggeeDataInfo error,err:%+v", err)
  273. // return err
  274. // }
  275. // }
  276. // return nil
  277. //}
  278. // SetTaskFinish 任务结案
  279. func SetTaskFinish(ctx context.Context, TaskIDs []string) error {
  280. db := GetReadDB(ctx)
  281. // 1. 修改任务表,更新任务阶段为已结案,结案方式为正常结束,数据状态为已通过,
  282. err := db.Model(gorm_model.YoungeeTaskInfo{}).Where("task_id in ?", TaskIDs).Updates(gorm_model.YoungeeTaskInfo{DataStatus: 5, TaskStage: 15, CompleteStatus: 2, WithdrawStatus: 2, CompleteDate: time.Now(), SettleStatus: 2}).Error
  283. if err != nil {
  284. logrus.WithContext(ctx).Errorf("[Task db] Update YoungeeTaskInfo error,err:%+v", err)
  285. return err
  286. }
  287. for _, v := range TaskIDs {
  288. // 查询task_info
  289. db = GetReadDB(ctx)
  290. taskInfo := gorm_model.YoungeeTaskInfo{}
  291. err1 := db.Model(gorm_model.YoungeeTaskInfo{}).Where("task_id = ?", v).Scan(&taskInfo).Error
  292. if err1 != nil {
  293. logrus.WithContext(ctx).Errorf("[Task db] Find YoungeeTaskInfo error,err:%+v", err)
  294. return err1
  295. }
  296. //查询project_info
  297. projectInfo := gorm_model.ProjectInfo{}
  298. err1 = db.Model(gorm_model.ProjectInfo{}).Where("project_id = ?", taskInfo.ProjectId).Scan(&projectInfo).Error
  299. if err1 != nil {
  300. logrus.WithContext(ctx).Errorf("[Task db] Find ProjectInfo error,err:%+v", err)
  301. return err1
  302. }
  303. // 查询data_info
  304. db = GetReadDB(ctx)
  305. dataInfo := gorm_model.YounggeeDataInfo{}
  306. err1 = db.Model(gorm_model.YounggeeDataInfo{}).Where("task_id = ? and is_ok = 1", v).Scan(&dataInfo).Error
  307. if err1 != nil {
  308. logrus.WithContext(ctx).Errorf("[Task db] Find YounggeeDataInfo error,err:%+v", err)
  309. return err1
  310. }
  311. t := time.Now()
  312. income := gorm_model.YounggeeTalentIncome{
  313. TalentID: taskInfo.TalentId,
  314. ProjectID: taskInfo.ProjectId,
  315. TaskID: taskInfo.TaskId,
  316. Type: 1,
  317. //BrandName: productStruct.BrandName,
  318. TaskName: projectInfo.ProjectName,
  319. //PhotoUrl: mainPhoto,
  320. Income: strconv.FormatFloat(taskInfo.SettleAmount, 'f', 10, 32),
  321. IncomeType: 1,
  322. WithdrawStatus: 1,
  323. IncomeAt: &t,
  324. WithdrawAt: nil,
  325. }
  326. err = CreateIncome(ctx, income, nil)
  327. if err != nil {
  328. logrus.WithContext(ctx).Errorf("[projectPay service] call SpecialSettlePay error,err:%+v", err)
  329. return err
  330. }
  331. // 3. 修改招募策略表,更新粉丝量、播放量、点赞数、收藏数、评论数、总支付、结案数量
  332. // 更新招募策略
  333. db = GetReadDB(ctx)
  334. db = db.Model(gorm_model.RecruitStrategy{}).Where("project_id = ? and strategy_id = ?", taskInfo.ProjectId, taskInfo.StrategyId)
  335. fansCount, _ := strconv.Atoi(conv.MustString(gjson.Get(taskInfo.TalentPlatformInfoSnap, "fans_count"), ""))
  336. err = db.Updates(map[string]interface{}{
  337. "fan_number": gorm.Expr("fan_number + ?", fansCount),
  338. "play_number": gorm.Expr("play_number + ?", dataInfo.PlayNumber),
  339. "like_number": gorm.Expr("like_number + ?", dataInfo.LikeNumber),
  340. "collect_number": gorm.Expr("collect_number + ?", dataInfo.CollectNumber),
  341. "comment_number": gorm.Expr("comment_number + ?", dataInfo.CommentNumber),
  342. "finish_number": gorm.Expr("finish_number + 1"),
  343. "total_offer": gorm.Expr("total_offer + ?", taskInfo.RealPayment)}).Error
  344. if err != nil {
  345. logrus.WithContext(ctx).Errorf("[Task db] Update YounggeeDataInfo error,err:%+v", err)
  346. return err
  347. }
  348. }
  349. return nil
  350. }
  351. // SetTaskFinish 专项任务结案
  352. func SetSpecialTaskFinish(ctx context.Context, TaskIDs []string) error {
  353. db := GetReadDB(ctx)
  354. // 1. 修改任务表,更新任务阶段为已结案,结案方式为正常结束,数据状态为已通过,
  355. err := db.Model(gorm_model.YoungeeTaskInfo{}).Where("task_id in ?", TaskIDs).Updates(gorm_model.YoungeeTaskInfo{DataStatus: 5, TaskStage: 15, CompleteStatus: 2, WithdrawStatus: 2, CompleteDate: time.Now()}).Error
  356. if err != nil {
  357. logrus.WithContext(ctx).Errorf("[Task db] Update YoungeeTaskInfo error,err:%+v", err)
  358. return err
  359. }
  360. return nil
  361. }
  362. // SetTaskFinish 专项任务结案
  363. func SetSpecialLocalTaskFinish(ctx context.Context, TaskIDs []string) error {
  364. db := GetReadDB(ctx)
  365. // 1. 修改任务表,更新任务阶段为已结案,结案方式为正常结束,数据状态为已通过,
  366. err := db.Model(gorm_model.YoungeeLocalTaskInfo{}).Where("task_id in ?", TaskIDs).Updates(gorm_model.YoungeeLocalTaskInfo{DataStatus: 5, TaskStage: 15, CompleteStatus: 2, WithdrawStatus: 2, CompleteDate: time.Now()}).Error
  367. if err != nil {
  368. logrus.WithContext(ctx).Errorf("[Task db] Update YoungeeTaskInfo error,err:%+v", err)
  369. return err
  370. }
  371. return nil
  372. }
  373. // SetSpecialTaskSettleNum 结案人数+1
  374. func SetSpecialLocalTaskSettleNum(ctx context.Context, TaskIDs []string) error {
  375. db := GetReadDB(ctx)
  376. //4.根据达人来源改变状态、阶段、数目
  377. var tasks []gorm_model.YoungeeLocalTaskInfo
  378. err := db.Model(gorm_model.YoungeeLocalTaskInfo{}).Where("task_id IN ? ", TaskIDs).Find(&tasks).Error
  379. if err != nil {
  380. return err
  381. }
  382. for _, taskInfo := range tasks {
  383. if taskInfo.SupplierId != 0 && taskInfo.SupplierStatus == 2 {
  384. //project招募数+1,预估成本+服务商价格
  385. var projectinfo gorm_model.YounggeeLocalLifeInfo
  386. err = db.Model(gorm_model.YounggeeLocalLifeInfo{}).Where("local_id = ?", taskInfo.LocalId).Find(&projectinfo).Error
  387. if err != nil {
  388. return err
  389. }
  390. projectinfo.SettleNum += 1
  391. err = db.Model(gorm_model.YounggeeLocalLifeInfo{}).Where("local_id = ? ", taskInfo.LocalId).Updates(projectinfo).Error
  392. if err != nil {
  393. return err
  394. }
  395. //服务商s_project已招募人数+1
  396. var sprojectinfo gorm_model.YounggeeSLocalLifeInfo
  397. err = db.Model(gorm_model.YounggeeSLocalLifeInfo{}).Where(" s_local_life_id =?", taskInfo.SLocalLifeId).Find(&sprojectinfo).Error
  398. if err != nil {
  399. return err
  400. }
  401. sprojectinfo.RecruitNum += 1
  402. fmt.Println("......", projectinfo.RecruitNum)
  403. err = db.Model(gorm_model.YounggeeSLocalLifeInfo{}).Where(" s_local_life_id =?", taskInfo.SLocalLifeId).Updates(sprojectinfo).Error
  404. if err != nil {
  405. return err
  406. }
  407. }
  408. if taskInfo.SupplierId == 0 && taskInfo.SupplierStatus == 0 {
  409. //project招募数+1
  410. var projectinfo gorm_model.YounggeeLocalLifeInfo
  411. err = db.Model(gorm_model.YounggeeLocalLifeInfo{}).Where("local_id = ?", taskInfo.LocalId).Find(&projectinfo).Error
  412. if err != nil {
  413. return err
  414. }
  415. projectinfo.SettleNum += 1
  416. err = db.Model(gorm_model.YounggeeLocalLifeInfo{}).Where("local_id = ? ", taskInfo.LocalId).Updates(projectinfo).Error
  417. if err != nil {
  418. return err
  419. }
  420. }
  421. }
  422. return nil
  423. }
  424. func SetTalentIncome(ctx context.Context, TaskIDs []string) error {
  425. db := GetReadDB(ctx)
  426. var TaskInfoList []gorm_model.YoungeeTaskInfo
  427. err := db.Model(gorm_model.YoungeeTaskInfo{}).Where("task_id in ?", TaskIDs).Scan(&TaskInfoList).Error
  428. if err != nil {
  429. logrus.WithContext(ctx).Errorf("[Task db] Update SetTalentIncome error,err:%+v", err)
  430. return err
  431. }
  432. for _, taskInfo := range TaskInfoList {
  433. err := db.Model(gorm_model.YoungeeTalentInfo{}).Where("id = ?", taskInfo.TalentId).Updates(map[string]interface{}{
  434. "income": gorm.Expr("income + ?", taskInfo.SettleAmount),
  435. "canwithdraw": gorm.Expr("canwithdraw + ?", taskInfo.SettleAmount)}).Error
  436. if err != nil {
  437. logrus.WithContext(ctx).Errorf("[Task db] Update SetTalentIncome error,err:%+v", err)
  438. return err
  439. }
  440. }
  441. return nil
  442. }
  443. // SetTaskFinish 任务结案
  444. func SetLocalTaskFinish(ctx context.Context, TaskIDs []string) error {
  445. db := GetReadDB(ctx)
  446. // 1. 修改任务表,更新任务阶段为已结案,结案方式为正常结束,数据状态为已通过,
  447. err := db.Model(gorm_model.YoungeeLocalTaskInfo{}).Where("task_id in ?", TaskIDs).Updates(gorm_model.YoungeeLocalTaskInfo{DataStatus: 5, TaskStage: 15, CompleteStatus: 2, WithdrawStatus: 2, CompleteDate: time.Now(), SettleStatus: 2}).Error
  448. if err != nil {
  449. logrus.WithContext(ctx).Errorf("[Task db] Update YoungeeTaskInfo error,err:%+v", err)
  450. return err
  451. }
  452. for _, v := range TaskIDs {
  453. // 查询task_info
  454. db = GetReadDB(ctx)
  455. taskInfo := gorm_model.YoungeeLocalTaskInfo{}
  456. err1 := db.Model(gorm_model.YoungeeLocalTaskInfo{}).Where("task_id = ?", v).Scan(&taskInfo).Error
  457. if err1 != nil {
  458. logrus.WithContext(ctx).Errorf("[Task db] Find YoungeeTaskInfo error,err:%+v", err)
  459. return err1
  460. }
  461. //查询project_info
  462. projectInfo := gorm_model.YounggeeLocalLifeInfo{}
  463. err1 = db.Model(gorm_model.YounggeeLocalLifeInfo{}).Where("project_id = ?", taskInfo.LocalId).Scan(&projectInfo).Error
  464. if err1 != nil {
  465. logrus.WithContext(ctx).Errorf("[Task db] Find ProjectInfo error,err:%+v", err)
  466. return err1
  467. }
  468. // 查询data_info
  469. db = GetReadDB(ctx)
  470. dataInfo := gorm_model.YounggeeDataInfo{}
  471. err1 = db.Model(gorm_model.YounggeeDataInfo{}).Where("task_id = ? and is_ok = 1", v).Scan(&dataInfo).Error
  472. if err1 != nil {
  473. logrus.WithContext(ctx).Errorf("[Task db] Find YounggeeDataInfo error,err:%+v", err)
  474. return err1
  475. }
  476. // 2. 创建任务收益
  477. //var productStruct gorm_model.YounggeeProduct
  478. //if err = json.Unmarshal([]byte(projectInfo.ProductSnap), &productStruct); err != nil {
  479. // fmt.Println("Error:", err)
  480. // return err
  481. //}
  482. //var productPhotoStruct []gorm_model.YounggeeProductPhoto
  483. //if err = json.Unmarshal([]byte(projectInfo.ProductPhotoSnap), &productPhotoStruct); err != nil {
  484. // fmt.Println("Error:", err)
  485. // return err
  486. //}
  487. //var mainPhoto = ""
  488. //for _, w := range productPhotoStruct {
  489. // if w.Symbol == 1 {
  490. // mainPhoto = w.PhotoUrl
  491. // }
  492. //}
  493. t := time.Now()
  494. income := gorm_model.YounggeeTalentIncome{
  495. TalentID: taskInfo.TalentId,
  496. ProjectID: taskInfo.LocalId,
  497. TaskID: taskInfo.TaskId,
  498. Type: 1,
  499. //BrandName: productStruct.BrandName,
  500. TaskName: projectInfo.LocalName,
  501. //PhotoUrl: mainPhoto,
  502. Income: strconv.FormatFloat(taskInfo.SettleAmount, 'f', 10, 32),
  503. IncomeType: 1,
  504. WithdrawStatus: 1,
  505. IncomeAt: &t,
  506. WithdrawAt: nil,
  507. }
  508. err = CreateIncome(ctx, income, nil)
  509. if err != nil {
  510. logrus.WithContext(ctx).Errorf("[projectPay service] call SpecialSettlePay error,err:%+v", err)
  511. return err
  512. }
  513. // 3. 修改招募策略表,更新粉丝量、播放量、点赞数、收藏数、评论数、总支付、结案数量
  514. // 更新招募策略
  515. db = GetReadDB(ctx)
  516. db = db.Model(gorm_model.RecruitStrategy{}).Where("project_id = ? and strategy_id = ?", taskInfo.LocalId, taskInfo.StrategyId)
  517. fansCount, _ := strconv.Atoi(conv.MustString(gjson.Get(taskInfo.TalentPlatformInfoSnap, "fans_count"), ""))
  518. err = db.Updates(map[string]interface{}{
  519. "fan_number": gorm.Expr("fan_number + ?", fansCount),
  520. "play_number": gorm.Expr("play_number + ?", dataInfo.PlayNumber),
  521. "like_number": gorm.Expr("like_number + ?", dataInfo.LikeNumber),
  522. "collect_number": gorm.Expr("collect_number + ?", dataInfo.CollectNumber),
  523. "comment_number": gorm.Expr("comment_number + ?", dataInfo.CommentNumber),
  524. "finish_number": gorm.Expr("finish_number + 1"),
  525. "total_offer": gorm.Expr("total_offer + ?", taskInfo.RealPayment)}).Error
  526. if err != nil {
  527. logrus.WithContext(ctx).Errorf("[Task db] Update YounggeeDataInfo error,err:%+v", err)
  528. return err
  529. }
  530. }
  531. return nil
  532. }
  533. func SetLocalTalentIncome(ctx context.Context, TaskIDs []string) error {
  534. db := GetReadDB(ctx)
  535. var TaskInfoList []gorm_model.YoungeeLocalTaskInfo
  536. fmt.Println("收入", TaskIDs)
  537. err := db.Model(gorm_model.YoungeeLocalTaskInfo{}).Where("task_id in ?", TaskIDs).Scan(&TaskInfoList).Error
  538. if err != nil {
  539. logrus.WithContext(ctx).Errorf("[Task db] Update SetTalentIncome error,err:%+v", err)
  540. return err
  541. }
  542. for _, taskInfo := range TaskInfoList {
  543. err := db.Model(gorm_model.YoungeeTalentInfo{}).Where("id = ?", taskInfo.TalentId).Updates(map[string]interface{}{
  544. "income": gorm.Expr("income + ?", taskInfo.SettleAmount),
  545. "canwithdraw": gorm.Expr("canwithdraw + ?", taskInfo.SettleAmount)}).Error
  546. if err != nil {
  547. logrus.WithContext(ctx).Errorf("[Task db] Update SetTalentIncome error,err:%+v", err)
  548. return err
  549. }
  550. }
  551. return nil
  552. }
  553. func GetUnfinishedTaskNumber(ctx context.Context, projectID string) (*int64, error) {
  554. var unFinishedTaskNumber int64
  555. db := GetReadDB(ctx)
  556. err := db.Model(gorm_model.YoungeeTaskInfo{}).Where("project_id = ? and task_status = 2 and task_stage < 15", projectID).Count(&unFinishedTaskNumber).Error
  557. if err != nil {
  558. logrus.WithContext(ctx).Errorf("[Data db] Find YounggeeTaskInfo error,err:%+v", err)
  559. return nil, err
  560. }
  561. return &unFinishedTaskNumber, nil
  562. }
  563. func UpdateTaskStageByTaskId(ctx context.Context, taskID string, taskStatus int64, taskStage int64) error {
  564. db := GetReadDB(ctx)
  565. err := db.Model(gorm_model.YoungeeTaskInfo{}).Where("task_id=? and task_status = ?", taskID, taskStatus).Update("task_stage", taskStage).Error
  566. if err != nil {
  567. logrus.WithContext(ctx).Errorf("[UpdateTaskStageByTaskId]2 error query mysql total, err:%+v", err)
  568. return err
  569. }
  570. return nil
  571. }
  572. // 获取任务ids
  573. func GetTaskIds(ctx context.Context, projectId string) ([]string, error) {
  574. db := GetReadDB(ctx)
  575. var taskIds []string
  576. err := db.Model(gorm_model.YoungeeTaskInfo{}).Select("task_id").Where("project_id = ? and task_status = 2", projectId).Find(&taskIds).Error
  577. if err != nil {
  578. logrus.WithContext(ctx).Errorf("[CreateMessageByTask] error read mysql, err:%+v", err)
  579. return nil, err
  580. }
  581. return taskIds, nil
  582. }
  583. func UpdateTask(ctx context.Context, updateData gorm_model.YoungeeTaskInfo, tx *gorm.DB) (bool, error) {
  584. db := GetWriteDB(ctx)
  585. whereCondition := gorm_model.YoungeeTaskInfo{
  586. TaskId: updateData.TaskId,
  587. }
  588. if tx != nil {
  589. err := tx.Where(whereCondition).Updates(&updateData).Error
  590. if err != nil {
  591. return false, err
  592. }
  593. } else {
  594. err := db.Where(whereCondition).Updates(&updateData).Error
  595. if err != nil {
  596. return false, err
  597. }
  598. }
  599. return true, nil
  600. }
  601. // SetSpecialTaskSettleNum 结案人数+1
  602. func SetSpecialTaskSettleNum(ctx context.Context, TaskIDs []string) error {
  603. db := GetReadDB(ctx)
  604. //4.根据达人来源改变状态、阶段、数目
  605. var tasks []gorm_model.YoungeeTaskInfo
  606. err := db.Model(gorm_model.YoungeeTaskInfo{}).Where("task_id IN ? ", TaskIDs).Find(&tasks).Error
  607. if err != nil {
  608. return err
  609. }
  610. for _, taskInfo := range tasks {
  611. if taskInfo.SupplierId != 0 && taskInfo.SupplierStatus == 2 {
  612. //project招募数+1,预估成本+服务商价格
  613. var projectinfo gorm_model.ProjectInfo
  614. err = db.Model(gorm_model.ProjectInfo{}).Where("project_id = ?", taskInfo.ProjectId).Find(&projectinfo).Error
  615. if err != nil {
  616. return err
  617. }
  618. projectinfo.SettleNum += 1
  619. err = db.Model(gorm_model.ProjectInfo{}).Where("project_id = ? ", taskInfo.ProjectId).Updates(projectinfo).Error
  620. if err != nil {
  621. return err
  622. }
  623. //服务商s_project已招募人数+1
  624. var sprojectinfo gorm_model.YounggeeSProjectInfo
  625. err = db.Model(gorm_model.YounggeeSProjectInfo{}).Where(" s_project_id =?", taskInfo.SProjectId).Find(&sprojectinfo).Error
  626. if err != nil {
  627. return err
  628. }
  629. sprojectinfo.RecruitNum += 1
  630. fmt.Println("......", projectinfo.RecruitNum)
  631. err = db.Model(gorm_model.YounggeeSProjectInfo{}).Where(" s_project_id =?", taskInfo.SProjectId).Updates(sprojectinfo).Error
  632. if err != nil {
  633. return err
  634. }
  635. }
  636. if taskInfo.SupplierId == 0 && taskInfo.SupplierStatus == 0 {
  637. //project招募数+1
  638. var projectinfo gorm_model.ProjectInfo
  639. err = db.Model(gorm_model.ProjectInfo{}).Where("project_id = ?", taskInfo.ProjectId).Find(&projectinfo).Error
  640. if err != nil {
  641. return err
  642. }
  643. projectinfo.SettleNum += 1
  644. err = db.Model(gorm_model.ProjectInfo{}).Where("project_id = ? ", taskInfo.ProjectId).Updates(projectinfo).Error
  645. if err != nil {
  646. return err
  647. }
  648. }
  649. }
  650. return nil
  651. }