Cron.php 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171
  1. <?php
  2. namespace Task\Lib;
  3. use Dever;
  4. class Cron
  5. {
  6. /**
  7. * 将过期的任务,置为已结束,建议一天运行一次
  8. *
  9. * @return mixed
  10. */
  11. public function clearTask_api()
  12. {
  13. echo 11;die;
  14. }
  15. /**
  16. * 资料认证审核后的操作
  17. *
  18. * @return mixed
  19. */
  20. public function submit_commit()
  21. {
  22. }
  23. /**
  24. * 任务报告完成后的操作
  25. *
  26. * @return mixed
  27. */
  28. public function task_commit_api()
  29. {
  30. # 审核成功 入账
  31. $where['status'] = 2;
  32. $where['score_status'] = 1;
  33. $data = Dever::db('task/user_report')->state($where);
  34. if ($data) {
  35. foreach ($data as $k => $v) {
  36. $update['where_id'] = $v['id'];
  37. $update['score_status'] = 2;
  38. Dever::db('task/user_report')->update($update);
  39. $this->updateUserScore($v['uid'], $v['score']);
  40. $this->updateScoreLog($v['uid'], $v['score'], 4, 2, $v['task_id'], $v['id']);
  41. $this->group($v['uid'], $v['group_score'], $v['task_id'], $v['id']);
  42. }
  43. }
  44. return 'yes';
  45. }
  46. /**
  47. * 兑现审核完成后的操作
  48. *
  49. * @return mixed
  50. */
  51. public function cash_commit()
  52. {
  53. # 成功
  54. $where['status'] = 3;
  55. $where['cron'] = 1;
  56. $data = Dever::db('task/user_cash')->state($where);
  57. if ($data) {
  58. foreach ($data as $k => $v) {
  59. $update['where_id'] = $v['id'];
  60. $update['cron'] = 2;
  61. Dever::db('task/user_cash')->update($update);
  62. $this->updateScoreLog($v['uid'], $v['score'], 2, 1, -1, -1, $v['type'], $v['cash'], $v['cdate']);
  63. }
  64. }
  65. # 失败
  66. $where['status'] = 4;
  67. $where['cron'] = 1;
  68. $data = Dever::db('task/user_cash')->state($where);
  69. if ($data) {
  70. foreach ($data as $k => $v) {
  71. $update['where_id'] = $v['id'];
  72. $update['cron'] = 2;
  73. Dever::db('task/user_cash')->update($update);
  74. # 失败了就把积分再加回去吧
  75. $this->updateUserScore($v['uid'], $v['score']);
  76. $this->updateScoreLog($v['uid'], $v['score'], 3, 1, -1, -1, $v['type'], $v['cash'], $v['cdate'], $v['status_desc']);
  77. # 记录日志
  78. $insert = array();
  79. $insert['type'] = 3;
  80. $insert['status'] = 1;
  81. $insert['cash_type'] = $v['type'];
  82. $insert['cash'] = $v['cash'];
  83. $insert['score'] = $v['score'];
  84. $insert['uid'] = $v['uid'];
  85. $insert['cash_date'] = $v['cdate'];
  86. Dever::db('task/user_score_log')->insert($insert);
  87. }
  88. }
  89. return 'yes';
  90. }
  91. /**
  92. * 寻找这个用户的上线 给上线带来收益
  93. *
  94. * @return mixed
  95. */
  96. private function group($uid, $score, $task_id, $report_id)
  97. {
  98. $group_member = Dever::db('task/user_group_member')->one(array('uid' => $uid));
  99. if ($group_member) {
  100. $group_info = Dever::db('task/user_group')->one($group_member['group_id']);
  101. if ($group_info && $group_info['state'] == 1 && $group_info['uid'] > 0 && $group_info['uid'] != $uid) {
  102. $this->updateUserScore($group_info['uid'], $score);
  103. $this->updateScoreLog($group_info['uid'], $score, 5, 2, $task_id, $report_id);
  104. }
  105. }
  106. }
  107. /**
  108. * 更新用户积分数量
  109. *
  110. * @return mixed
  111. */
  112. private function updateUserScore($uid, $score)
  113. {
  114. $update['where_uid'] = $uid;
  115. $update['score'] = $score;
  116. Dever::db('task/user_score')->updateScore($update);
  117. }
  118. /**
  119. * 日志记录
  120. *
  121. * @return mixed
  122. */
  123. private function updateScoreLog($uid, $score, $type, $status, $task_id = -1, $report_id = -1, $cash_type = 1, $cash = 0, $cash_date = 0, $type_desc = '')
  124. {
  125. $insert = array();
  126. $insert['type'] = $type;
  127. $insert['status'] = $status;
  128. $insert['score'] = $score;
  129. $insert['uid'] = $uid;
  130. $insert['task_id'] = $task_id;
  131. $insert['report_id'] = $report_id;
  132. $insert['cash_type'] = $cash_type;
  133. $insert['cash'] = $cash;
  134. if ($cash_date) {
  135. $insert['cash_date'] = $cash_date;
  136. }
  137. $insert['type_desc'] = $type_desc;
  138. Dever::db('task/user_score_log')->insert($insert);
  139. }
  140. }