123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172 |
- <?php
- namespace Task\Lib;
- use Dever;
- class Cron
- {
- /**
- * 将过期的任务,置为已结束,建议一天运行一次
- *
- * @return mixed
- */
- public function task()
- {
-
- }
- /**
- * 资料认证审核后的操作
- *
- * @return mixed
- */
- public function submit_commit()
- {
- }
- /**
- * 任务报告完成后的操作
- *
- * @return mixed
- */
- public function task_commit()
- {
- # 审核成功 入账
- $where['status'] = 2;
- $where['score_status'] = 1;
- $data = Dever::db('task/user_report')->state($where);
- if ($data) {
- foreach ($data as $k => $v) {
- $update['where_id'] = $v['id'];
- $update['score_status'] = 2;
- Dever::db('task/user_report')->update($update);
- $this->updateUserScore($v['uid'], $v['score']);
- $this->updateScoreLog($v['uid'], $v['score'], 4, 2, $v['task_id'], $v['id']);
- $this->group($v['uid'], $v['group_score'], $v['task_id'], $v['id']);
-
- }
- }
- return 'yes';
- }
- /**
- * 兑现审核完成后的操作
- *
- * @return mixed
- */
- public function cash_commit()
- {
- # 成功
- $where['status'] = 3;
- $where['cron'] = 1;
- $data = Dever::db('task/user_cash')->state($where);
- if ($data) {
- foreach ($data as $k => $v) {
- $update['where_id'] = $v['id'];
- $update['cron'] = 2;
- Dever::db('task/user_cash')->update($update);
- $this->updateScoreLog($v['uid'], $v['score'], 2, 1, -1, -1, $v['type'], $v['cash'], $v['cdate']);
- }
- }
- # 失败
- $where['status'] = 4;
- $where['cron'] = 1;
- $data = Dever::db('task/user_cash')->state($where);
- if ($data) {
- foreach ($data as $k => $v) {
- $update['where_id'] = $v['id'];
- $update['cron'] = 2;
- Dever::db('task/user_cash')->update($update);
- # 失败了就把积分再加回去吧
- $this->updateUserScore($v['uid'], $v['score']);
- $this->updateScoreLog($v['uid'], $v['score'], 3, 1, -1, -1, $v['type'], $v['cash'], $v['cdate'], $v['status_desc']);
- # 记录日志
- $insert = array();
- $insert['type'] = 3;
- $insert['status'] = 1;
- $insert['cash_type'] = $v['type'];
- $insert['cash'] = $v['cash'];
- $insert['score'] = $v['score'];
- $insert['uid'] = $v['uid'];
-
- $insert['cash_date'] = $v['cdate'];
- Dever::db('task/user_score_log')->insert($insert);
- }
- }
- return 'yes';
- }
- /**
- * 寻找这个用户的上线 给上线带来收益
- *
- * @return mixed
- */
- private function group($uid, $score, $task_id, $report_id)
- {
- $group_member = Dever::db('task/user_group_member')->one(array('uid' => $uid));
- if ($group_member) {
- $group_info = Dever::db('task/user_group')->one($group_member['group_id']);
- if ($group_info && $group_info['state'] == 1 && $group_info['uid'] > 0 && $group_info['uid'] != $uid) {
-
- $this->updateUserScore($group_info['uid'], $score);
- $this->updateScoreLog($group_info['uid'], $score, 5, 2, $task_id, $report_id);
- }
- }
- }
- /**
- * 更新用户积分数量
- *
- * @return mixed
- */
- private function updateUserScore($uid, $score)
- {
- $update['uid'] = $uid;
- $update['score'] = $score;
- Dever::db('task/user_score')->updateScore($update);
- }
- /**
- * 日志记录
- *
- * @return mixed
- */
- private function updateScoreLog($uid, $score, $type, $status, $task_id = -1, $report_id = -1, $cash_type = 1, $cash = 0, $cash_date = 0, $type_desc = '')
- {
- $insert = array();
- $insert['type'] = $type;
- $insert['status'] = $status;
- $insert['score'] = $score;
- $insert['uid'] = $uid;
- $insert['task_id'] = $task_id;
- $insert['report_id'] = $report_id;
- $insert['cash_type'] = $cash_type;
- $insert['cash'] = $cash;
- if ($cash_date) {
- $insert['cash_date'] = $cash_date;
- }
- $insert['type_desc'] = $type_desc;
- Dever::db('task/user_score_log')->insert($insert);
- }
- }
|