Optchannels.php 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177
  1. <?php
  2. namespace app\admin\controller\general;
  3. use app\common\controller\Backend;
  4. use app\common\library\Redis;
  5. use app\main\constants\AdminConstants;
  6. use app\main\constants\CacheConstants;
  7. use think\Controller;
  8. use think\Request;
  9. /**
  10. * aaa
  11. *
  12. * @icon fa fa-circle-o
  13. */
  14. class Optchannels extends Backend
  15. {
  16. protected $noNeedRight = ['clearblackuser'];
  17. /**
  18. * Optchannels模型对象
  19. */
  20. protected $model = null;
  21. public function _initialize()
  22. {
  23. parent::_initialize();
  24. $this->model = model('Admin');
  25. }
  26. /**
  27. * 默认生成的控制器所继承的父类中有index/add/edit/del/multi五个方法
  28. * 因此在当前控制器中可不用编写增删改查的代码,如果需要自己控制这部分逻辑
  29. * 需要将application/admin/library/traits/Backend.php中对应的方法复制到当前控制器,然后进行修改
  30. */
  31. /**
  32. * 查看
  33. */
  34. public function index()
  35. {
  36. //设置过滤方法
  37. $this->request->filter(['strip_tags']);
  38. if ($this->request->isAjax())
  39. {
  40. //如果发送的来源是Selectpage,则转发到Selectpage
  41. if ($this->request->request('pkey_name'))
  42. {
  43. return $this->selectpage();
  44. }
  45. list($where, $sort, $order, $offset, $limit) = $this->buildparams();
  46. $total = $this->model->join('admin_extend a','admin.id= a.admin_id')
  47. ->join('admin_config c','c.admin_id = admin.id')
  48. ->join('auth_group_access g','admin.id = g.uid')
  49. ->field('admin.id as id,admin.username as username,admin.nickname as nickname,a.benefit as benefit,c.normal_num as normal_count,c.vip_num as vip_count,c.is_blacklist as is_blacklist')
  50. ->where($where)
  51. ->where('g.group_id',3)
  52. ->order($sort, 'ASC')
  53. ->count();
  54. $list = $this->model->join('admin_extend a','admin.id= a.admin_id')
  55. ->join('admin_config c','c.admin_id = admin.id')
  56. ->join('auth_group_access g','admin.id = g.uid')
  57. ->field('admin.id as id,admin.username as username,admin.nickname as nickname,a.benefit as benefit,c.normal_num as normal_count,c.normal_num as normal_num,c.vip_num as vip_count,c.vip_num as vip_num,c.is_blacklist as is_blacklist,extend')
  58. ->where($where)
  59. ->where('g.group_id',3)
  60. ->order($sort, 'ASC')
  61. ->limit($offset, $limit)
  62. ->select();
  63. foreach ($list as $index => $item) {
  64. $list[$index] = array_merge($list[$index]->getData(), ['clear' => AdminConstants::ADMIN_EXTEND_CLEAR_NO]);
  65. if ($item->extend != 'null') {
  66. $list[$index] = array_merge($list[$index], json_decode($item->extend, true) ?? []);
  67. }
  68. }
  69. $result = array("total" => $total, "rows" => $list);
  70. return json($result);
  71. }
  72. return $this->view->fetch();
  73. }
  74. public function clearblackuser($id)
  75. {
  76. $res = model('AdminConfig')->where('admin_id', $id)->find();
  77. if (!$res) {
  78. $this->error('账号信息不存在');
  79. }
  80. if ($res->extend != 'null') {
  81. $extend = json_decode($res->extend, true);
  82. $extend['clear'] = AdminConstants::ADMIN_EXTEND_CLEAR_WAITING;
  83. } else {
  84. $extend = ['clear' => AdminConstants::ADMIN_EXTEND_CLEAR_WAITING];
  85. }
  86. model('AdminConfig')->where('admin_id', $id)->update(['extend' => json_encode($extend, JSON_UNESCAPED_UNICODE)]);
  87. $this->success();
  88. }
  89. /**
  90. * 编辑
  91. */
  92. public function edit($ids = NULL)
  93. {
  94. if($this->request->isAjax()){
  95. $params = $this->request->post("row/a");
  96. $update = [];
  97. if ($params['is_blacklist']) {
  98. $res = model('AdminConfig')->where('admin_id', $ids)->find();
  99. if ($res->extend != 'null') {
  100. $extend = json_decode($res->extend, true);
  101. $extend['clear'] = AdminConstants::ADMIN_EXTEND_CLEAR_NO;
  102. } else {
  103. $extend = ['clear' => AdminConstants::ADMIN_EXTEND_CLEAR_NO];
  104. }
  105. $update['extend'] = json_encode($extend, JSON_UNESCAPED_UNICODE);
  106. }
  107. $admin_id =$params['cid'];
  108. $update['normal_num'] = $params['normal_count'] ?? 0;
  109. $update['vip_num'] = $params['vip_count'] ?? 0;
  110. $update['is_blacklist'] = $params['is_blacklist'];
  111. $update['kl_rate'] = $params['kl_rate'] ?? 0.00;
  112. if($admin_id){
  113. $res =model('AdminConfig')->update($update,['admin_id'=>$admin_id]);
  114. if($res){
  115. model('AdminConfig')->delAdminInfoAllCache($admin_id);
  116. $this->success();
  117. }else{
  118. $this->error($res->getError());
  119. }
  120. }
  121. }
  122. $row = model('AdminConfig')->get($ids);
  123. if (!$row){
  124. $this->error(__('No Results were found'));
  125. }
  126. $this->assign('row',$row);
  127. return $this->view->fetch();
  128. }
  129. public function bw_list(){
  130. if($this->request->isAjax()){
  131. $params = $this->request->post();
  132. $ids = $params['ids'];
  133. $is_blacklist = $params['is_blacklist'];
  134. if ($is_blacklist) {
  135. $adminList = model('AdminConfig')->whereIn('admin_id', $ids)->select();
  136. foreach ($adminList as $admin) {
  137. if ($admin->extend != 'null') {
  138. $extend = json_decode($admin->extend, true);
  139. $extend['clear'] = AdminConstants::ADMIN_EXTEND_CLEAR_NO;
  140. } else {
  141. $extend = ['clear' => AdminConstants::ADMIN_EXTEND_CLEAR_NO];
  142. }
  143. $extend = json_encode($extend, JSON_UNESCAPED_UNICODE);
  144. model('AdminConfig')->update(['extend' => $extend], ['admin_id' => $admin['admin_id']]);
  145. }
  146. }
  147. $result = model('AdminConfig')->whereIn('admin_id', $ids)->update(['is_blacklist' => $is_blacklist]);
  148. if($result){
  149. if($ids){
  150. foreach($ids as $admin_id){
  151. model('AdminConfig')->delAdminInfoAllCache($admin_id);
  152. }
  153. }
  154. $this->success('设置成功');
  155. }else{
  156. $this->error('设置失败');
  157. }
  158. }
  159. }
  160. }