User.php 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304
  1. <?php
  2. namespace app\admin\controller;
  3. use think\Db;
  4. class User extends Base
  5. {
  6. public function __construct()
  7. {
  8. parent::__construct();
  9. }
  10. public function data()
  11. {
  12. $param = input();
  13. $param['page'] = intval($param['page']) <1 ? 1 : $param['page'];
  14. $param['limit'] = intval($param['limit']) <1 ? $this->_pagesize : $param['limit'];
  15. if($param['page'] ==1){
  16. model('User')->expire();
  17. }
  18. $where=[];
  19. if(in_array($param['status'],['0','1'],true)){
  20. $where['user_status'] = $param['status'];
  21. }
  22. if(!empty($param['group'])){
  23. $where['group_id'] = $param['group'];
  24. }
  25. if(!empty($param['wd'])){
  26. $param['wd'] = htmlspecialchars(urldecode($param['wd']));
  27. $where['user_name'] = ['like','%'.$param['wd'].'%'];
  28. }
  29. $order='user_id desc';
  30. $res = model('User')->listData($where,$order,$param['page'],$param['limit']);
  31. $group_list = model('Group')->getCache('group_list');
  32. foreach($res['list'] as $k=>$v){
  33. $group_ids = explode(',', $v['group_id']);
  34. $names = [];
  35. foreach($group_ids as $gid){
  36. if(isset($group_list[$gid])){
  37. $names[] = $group_list[$gid]['group_name'];
  38. }
  39. }
  40. $res['list'][$k]['group_name'] = implode(',', $names);
  41. }
  42. $this->assign('list',$res['list']);
  43. $this->assign('total',$res['total']);
  44. $this->assign('page',$res['page']);
  45. $this->assign('limit',$res['limit']);
  46. $param['page'] = '{page}';
  47. $param['limit'] = '{limit}';
  48. $this->assign('param',$param);
  49. $this->assign('group_list',$group_list);
  50. $this->assign('title',lang('admin/user/title'));
  51. return $this->fetch('admin@user/index');
  52. }
  53. public function reward()
  54. {
  55. $param = input();
  56. $param['page'] = intval($param['page']) <1 ? 1 : $param['page'];
  57. $param['limit'] = intval($param['limit']) <1 ? $this->_pagesize : $param['limit'];
  58. $param['uid'] = intval($param['uid']);
  59. $where=[];
  60. if(!empty($param['level'])){
  61. if($param['level']=='1'){
  62. $where['user_pid'] = ['eq', $param['uid']];
  63. }
  64. elseif($param['level']=='2'){
  65. $where['user_pid_2'] = ['eq', $param['uid']];
  66. }
  67. elseif($param['level']=='3'){
  68. $where['user_pid_3'] = ['eq', $param['uid']];
  69. }
  70. }
  71. else{
  72. $where['user_pid|user_pid_2|user_pid_3'] = ['eq', intval($param['uid']) ];
  73. }
  74. if(!empty($param['wd'])){
  75. $param['wd'] = htmlspecialchars(urldecode($param['wd']));
  76. $where['user_name'] = ['like','%'.$param['wd'].'%'];
  77. }
  78. $order='user_id desc';
  79. $res = model('User')->listData($where,$order,$param['page'],$param['limit']);
  80. $group_list = model('Group')->getCache('group_list');
  81. foreach($res['list'] as $k=>$v){
  82. $res['list'][$k]['group_name'] = $group_list[$v['group_id']]['group_name'];
  83. }
  84. $where2=[];
  85. $where2['user_pid'] = ['eq', $param['uid']];
  86. $level_cc_1 = Db::name('User')->where($where2)->count();
  87. $where3 = [];
  88. $where3['user_id'] = $param['uid'];
  89. $where3['plog_type'] = 4;
  90. $points_cc_1 = Db::name('Plog')->where($where3)->sum('plog_points');
  91. $where2=[];
  92. $where2['user_pid_2'] = ['eq', $param['uid']];
  93. $level_cc_2 = Db::name('User')->where($where2)->count();
  94. $where3 = [];
  95. $where3['user_id'] = $param['uid'];
  96. $where3['plog_type'] = 5;
  97. $points_cc_2 = Db::name('Plog')->where($where3)->sum('plog_points');
  98. $where2=[];
  99. $where2['user_pid_3'] = ['eq', $param['uid']];
  100. $level_cc_3 = Db::name('User')->where($where2)->count();
  101. $where3 = [];
  102. $where3['user_id'] = $param['uid'];
  103. $where3['plog_type'] = 6;
  104. $points_cc_3 = Db::name('Plog')->where($where3)->sum('plog_points');
  105. $data=[];
  106. $data['level_cc_1'] = intval($level_cc_1);
  107. $data['level_cc_2'] = intval($level_cc_2);
  108. $data['level_cc_3'] = intval($level_cc_3);
  109. $data['points_cc_1'] = intval($points_cc_1);
  110. $data['points_cc_2'] = intval($points_cc_2);
  111. $data['points_cc_3'] = intval($points_cc_3);
  112. $this->assign('data',$data);
  113. $this->assign('list',$res['list']);
  114. $this->assign('total',$res['total']);
  115. $this->assign('page',$res['page']);
  116. $this->assign('limit',$res['limit']);
  117. $param['page'] = '{page}';
  118. $param['limit'] = '{limit}';
  119. $this->assign('param',$param);
  120. $this->assign('title',lang('admin/user/title'));
  121. return $this->fetch('admin@user/reward');
  122. }
  123. public function invite()
  124. {
  125. $param = input();
  126. $param['page'] = intval($param['page']) <1 ? 1 : $param['page'];
  127. $param['limit'] = intval($param['limit']) <1 ? $this->_pagesize : $param['limit'];
  128. $where = [];
  129. $where['user_invite_count'] = ['gt', 0];
  130. if(!empty($param['wd'])){
  131. $wd = htmlspecialchars(urldecode($param['wd']));
  132. $wd = str_replace(['%', '_'], ['\\%', '\\_'], $wd);
  133. $where['user_name'] = ['like','%'.$wd.'%'];
  134. }
  135. $order='user_invite_count desc, user_id desc';
  136. $res = model('User')->listData($where,$order,$param['page'],$param['limit']);
  137. $group_list = model('Group')->getCache('group_list');
  138. $user_ids = array_column($res['list'], 'user_id');
  139. $invited_users_map = [];
  140. if (!empty($user_ids)) {
  141. $invited_list = Db::name('User')
  142. ->field('user_id,user_name,user_reg_time,user_invite_code,user_pid')
  143. ->where('user_pid', 'in', $user_ids)
  144. ->select();
  145. foreach ($invited_list as $invited) {
  146. $invited_users_map[$invited['user_pid']][] = $invited;
  147. }
  148. }
  149. foreach($res['list'] as $k=>$v){
  150. $group_ids = explode(',', $v['group_id']);
  151. $names = [];
  152. foreach($group_ids as $gid){
  153. if(isset($group_list[$gid])){
  154. $names[] = $group_list[$gid]['group_name'];
  155. }
  156. }
  157. $res['list'][$k]['group_name'] = implode(',', $names);
  158. $res['list'][$k]['invited_users'] = isset($invited_users_map[$v['user_id']])
  159. ? array_slice($invited_users_map[$v['user_id']], 0, 5)
  160. : [];
  161. }
  162. $total_invite_count = Db::name('User')->sum('user_invite_count');
  163. $total_invite_users = Db::name('User')->where('user_invite_count', 'gt', 0)->count();
  164. $this->assign('total_invite_count', intval($total_invite_count));
  165. $this->assign('total_invite_users', intval($total_invite_users));
  166. $this->assign('list',$res['list']);
  167. $this->assign('total',$res['total']);
  168. $this->assign('page',$res['page']);
  169. $this->assign('limit',$res['limit']);
  170. $param['page'] = '{page}';
  171. $param['limit'] = '{limit}';
  172. $this->assign('param',$param);
  173. $this->assign('title','邀请统计');
  174. return $this->fetch('admin@user/invite');
  175. }
  176. public function info()
  177. {
  178. if (Request()->isPost()) {
  179. $param = input('post.');
  180. if(isset($param['group_id']) && is_array($param['group_id'])) {
  181. $param['group_id'] = implode(',', $param['group_id']);
  182. }
  183. $res = model('User')->saveData($param);
  184. if($res['code']>1){
  185. return $this->error($res['msg']);
  186. }
  187. return $this->success($res['msg']);
  188. }
  189. $id = input('id/d');
  190. $where=[];
  191. $where['user_id'] = ['eq',$id];
  192. $res = model('User')->infoData($where);
  193. $info = $res['info'];
  194. $group_list = model('Group')->getCache('group_list');
  195. $group_ids = isset($info['group_id']) ? explode(',', $info['group_id']) : [];
  196. $has_vip_group = false;
  197. foreach($group_ids as $gid){
  198. if(intval($gid) > 2){
  199. $has_vip_group = true;
  200. break;
  201. }
  202. }
  203. $this->assign('info', $info);
  204. $this->assign('group_list', $group_list);
  205. $this->assign('has_vip_group', $has_vip_group);
  206. return $this->fetch('admin@user/info');
  207. }
  208. public function del()
  209. {
  210. $param = input();
  211. $ids = $param['ids'];
  212. if(!empty($ids)){
  213. $where=[];
  214. $where['user_id'] = ['in',$ids];
  215. $res = model('User')->delData($where);
  216. if($res['code']>1){
  217. return $this->error($res['msg']);
  218. }
  219. return $this->success($res['msg']);
  220. }
  221. return $this->error(lang('param_err'));
  222. }
  223. public function field()
  224. {
  225. $param = input();
  226. $ids = $param['ids'];
  227. $col = $param['col'];
  228. $val = $param['val'];
  229. if(!empty($ids) && in_array($col,['user_status']) && in_array($val,['0','1'])){
  230. $where=[];
  231. $where['user_id'] = ['in',$ids];
  232. $res = model('User')->fieldData($where,$col,$val);
  233. if($res['code']>1){
  234. return $this->error($res['msg']);
  235. }
  236. return $this->success($res['msg']);
  237. }
  238. return $this->error(lang('param_err'));
  239. }
  240. public function generateInviteCode()
  241. {
  242. $count = 0;
  243. $model = model('User');
  244. \think\Db::name('User')
  245. ->where('user_invite_code', '=', '')
  246. ->chunk(500, function ($users) use ($model, &$count) {
  247. foreach ($users as $user) {
  248. $invite_code = $model->generateUniqueInviteCode($user['user_id']);
  249. \think\Db::name('User')
  250. ->where('user_id', $user['user_id'])
  251. ->update(['user_invite_code' => $invite_code]);
  252. $count++;
  253. }
  254. });
  255. return $this->success('共为 ' . $count . ' 个会员生成了邀请码');
  256. }
  257. }