Cron.php 4.1 KB

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