Core.php 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222
  1. <?php
  2. namespace Score\Lib;
  3. use Dever;
  4. class Core
  5. {
  6. /**
  7. * 增加日志 Dever::load('score/lib/core')->log($uid, $key, $name);
  8. *
  9. * @return mixed
  10. */
  11. public function log($uid, $action_key, $action_name, $callback = '')
  12. {
  13. $action = Dever::db('score/action')->one(array('key' => $action_key));
  14. if (!$action) {
  15. $action = array();
  16. $action['id'] = Dever::db('score/action')->insert(array('key' => $action_key, 'name' => $action_name));
  17. }
  18. if (isset($action['id'])) {
  19. $log_id = Dever::db('score/action_log')->insert(array('uid' => $uid, 'action_id' => $action['id'], 'callback' => $callback));
  20. Dever::daemon('lib/core.oper?log_id='.$log_id, 'score');
  21. //Dever::load('score/lib/core.oper?log_id='.$log_id);
  22. }
  23. }
  24. /**
  25. * 根据用户行为,增加积分
  26. *
  27. * @return mixed
  28. */
  29. public function oper()
  30. {
  31. $log_id = Dever::input('log_id');
  32. $log = Dever::db('score/action_log')->one($log_id);
  33. $this->operAction($log);
  34. }
  35. private function rule($log, $info)
  36. {
  37. if ($info['num'] == 0) {
  38. return;
  39. }
  40. $uid = $log['uid'];
  41. $user = Dever::db('score/user')->one(array('uid' => $uid, 'config_id' => $info['config_id']));
  42. if (!$user) {
  43. $user = array();
  44. $user['id'] = Dever::db('score/user')->insert(array('uid' => $uid, 'config_id' => $info['config_id'], 'score' => 0, 'no_score' => 0));
  45. $user['score'] = 0;
  46. }
  47. $num = $info['num'];
  48. if ($info['upper'] == 2 && $info['upper_limit'] >= 1) {
  49. $upper = $this->upper($uid, $info, $log);
  50. if (!$upper) {
  51. Dever::db('score/action_log')->update(array('where_id' => $log['id'], 'score_type' => 3, 'score' => '0'));
  52. return;
  53. }
  54. Dever::db('score/action_log')->update(array('where_id' => $log['id'], 'score_type' => 2, 'score' => $num));
  55. }
  56. $update = array();
  57. $update['where_id'] = $user['id'];
  58. $update['score'] = $user['score'] + $num;
  59. $insert['uid'] = $uid;
  60. $insert['config_id'] = $info['config_id'];
  61. $insert['action_id'] = $info['action_id'];
  62. $insert['status'] = 1;
  63. $insert['num'] = $num;
  64. $insert['total'] = $update['score'];
  65. $user_log_id = Dever::db('score/user_log')->insert($insert);
  66. Dever::db('score/user')->update($update);
  67. # 提升等级
  68. $this->setLevel($uid);
  69. if ($log['callback']) {
  70. if (strstr($log['callback'], '?')) {
  71. Dever::load($log['callback'] . '&user_log_id=' . $user_log_id);
  72. } else {
  73. Dever::load($log['callback'], $user_log_id);
  74. }
  75. }
  76. }
  77. private function upper($uid, $info)
  78. {
  79. # 有上限限制
  80. $limit = $info['upper_limit'];
  81. # 获取用户最新一次积分变化日志
  82. $time = time();
  83. $where = array();
  84. $where['config_id'] = $info['config_id'];
  85. $where['action_id'] = $info['action_id'];
  86. $where['uid'] = $uid;
  87. $where['status'] = 1;
  88. $user_log = Dever::db('score/user_log')->getNew($where);
  89. if ($user_log) {
  90. if ($info['upper_type'] == 1) {
  91. # 按天
  92. $where['start'] = Dever::maketime(date('Y-m-d 00:00:00', $time));
  93. //$where['end'] = $end;
  94. } elseif ($info['upper_type'] == 2) {
  95. # 按小时
  96. $where['start'] = $time - ($info['upper_time'] * 3600);
  97. //$where['end'] = $end;
  98. } elseif ($info['upper_type'] == 3) {
  99. # 永久
  100. } else {
  101. return true;
  102. }
  103. $user_log_num = Dever::db('score/user_log')->getNewTotal($where);
  104. if ($user_log_num >= $info['upper_limit']) {
  105. return false;
  106. }
  107. }
  108. return true;
  109. }
  110. private function operAction($log)
  111. {
  112. if ($log && $log['score_type'] == 1) {
  113. $where = array();
  114. $where['state'] = 1;
  115. $where['id'] = $log['action_id'];
  116. $action = Dever::db('score/action')->one($where);
  117. if ($action) {
  118. $rule = Dever::db('score/rule')->state(array('action_id' => $action['id']));
  119. if ($rule) {
  120. foreach ($rule as $k => $v) {
  121. $this->rule($log, $v);
  122. }
  123. }
  124. }
  125. }
  126. }
  127. /**
  128. * 根据积分日志和规则,增加积分,这是一个定时任务,暂时不开启了
  129. *
  130. * @return mixed
  131. */
  132. public function cron()
  133. {
  134. $where['score_type'] = 1;
  135. $log = Dever::db('score/action_log')->all($where);
  136. if ($log) {
  137. foreach ($log as $k => $v) {
  138. $this->operAction($v);
  139. }
  140. }
  141. }
  142. /**
  143. * 根据积分算等级
  144. *
  145. * @return mixed
  146. */
  147. public function setLevel($uid)
  148. {
  149. # 获取当前用户的等级
  150. $where['uid'] = $uid;
  151. $user_level = Dever::db('score/user_level')->one($where);
  152. if ($user_level && $user_level['type'] == 2) {
  153. return;
  154. } elseif ($user_level && $user_level['type'] == 1) {
  155. $config = Dever::db('score/level')->one($user_level['level_id']);
  156. $level = $config['level'] + 1;
  157. } else {
  158. $level = 1;
  159. }
  160. $config = Dever::db('score/level')->one(array('level' => $level, 'state' => 1));
  161. if ($config) {
  162. # 是否能升级
  163. $yes = false;
  164. $rule = Dever::array_decode($config['score']);
  165. if ($rule) {
  166. $user_score = Dever::db('score/user')->getScoreByConfig($where);
  167. if ($user_score) {
  168. foreach ($rule as $k => $v) {
  169. $score = $v['config'];
  170. $num = $v['num'];
  171. if (isset($user_score[$score]) && $user_score[$score]['score'] && $user_score[$score]['score'] >= $num) {
  172. $yes = $config['id'];
  173. } else {
  174. $yes = false;
  175. }
  176. }
  177. }
  178. }
  179. if ($yes) {
  180. # 可以升级
  181. if ($user_level) {
  182. Dever::db('score/user_level')->update(array('where_id' => $user_level['id'], 'level_id' => $yes));
  183. } else {
  184. Dever::db('score/user_level')->insert(array('uid' => $uid,'level_id' => $yes, 'type' => 1));
  185. }
  186. }
  187. }
  188. }
  189. }