Admins.php 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333
  1. <?php
  2. /**
  3. * User: nickbai
  4. * Date: 2017/10/23 13:33
  5. * Email: 1902822973@qq.com
  6. */
  7. namespace app\admin\controller;
  8. class Admins extends Base
  9. {
  10. // 管理员列表
  11. public function index()
  12. {
  13. // $token = 'NzgyNTUwIyRAJSFeKi8xNTYxNTQwMzQzLzE=';
  14. // $res = model('Admins')->checktoken($token);
  15. // if($res == -1){
  16. // return $res;
  17. // }
  18. // $admin_id = explode('/',base64_decode($token))['2'];
  19. // $adminInfo = db('admins')->where('id', $admin_id)->find();
  20. if (request()->isAjax()) {
  21. $param = input('param.');
  22. $limit = $param['pageSize'];
  23. $offset = ($param['pageNumber'] - 1) * $limit;
  24. $where = [];
  25. if (!empty($param['searchText'])) {
  26. $where['user_name'] = ['like', '%' . $param['searchText'] . '%'];
  27. }
  28. $result = db('admins')->where($where)->limit($offset, $limit)->select();
  29. $powergroup = db('admingroup')->select();
  30. foreach ($result as $key => $vo) {
  31. for($i=0;$i<count($powergroup);$i++){
  32. if($result[$key]['group_id'] == $powergroup[$i]['group_id']){
  33. $result[$key]['group_name'] = $powergroup[$i]['group_name'];
  34. }
  35. }
  36. // 优化显示状态
  37. if (1 == $vo['status']) {
  38. $result[$key]['status'] = '<span class="label label-primary">启用</span>';
  39. } else {
  40. $result[$key]['status'] = '<span class="label label-danger">禁用</span>';
  41. }
  42. // 上次登录时间
  43. $result[$key]['last_login_time'] = empty($vo['last_login_time']) ? '' : date('Y-m-d H:i:s', $vo['last_login_time']);
  44. // 生成操作按钮
  45. if (1 != $vo['id']) {
  46. $result[$key]['operate'] = $this->makeBtn($vo['id']);
  47. }
  48. }
  49. $return['total'] = db('admins')->where($where)->count(); //总数据
  50. $return['rows'] = $result;
  51. return json($return);
  52. }
  53. //
  54. return $this->fetch();
  55. }
  56. // 添加管理员
  57. public function addAdmin()
  58. {
  59. if (request()->isPost()) {
  60. $param = input('post.');
  61. $has = db('admins')->field('id')->where('user_name', $param['user_name'])->find();
  62. if (!empty($has)) {
  63. return json(['code' => -1, 'data' => '', 'msg' => '该管理员已经存在']);
  64. }
  65. if(empty($param['group_id'])){
  66. return json(['code' => -4, 'data' => '', 'msg' => '请选择权限']);
  67. }
  68. $param['password'] = md5($param['password'] . config('salt'));
  69. try {
  70. db('admins')->insert($param);
  71. } catch (\Exception $e) {
  72. return json(['code' => -2, 'data' => '', 'msg' => $e->getMessage()]);
  73. }
  74. return json(['code' => 1, 'data' => '', 'msg' => '添加管理员成功']);
  75. }
  76. $admingroup = db('admingroup')->select();
  77. $this->assign([
  78. 'admingroup' => $admingroup,
  79. 'status' => config('kf_status')
  80. ]);
  81. return $this->fetch('addadmin');
  82. }
  83. // 编辑管理员
  84. public function editAdmin()
  85. {
  86. if (request()->isAjax()) {
  87. $param = input('post.');
  88. // 检测用户修改的管理员是否重复
  89. $has = db('admins')->where('user_name', $param['user_name'])->where('id', '<>', $param['id'])->find();
  90. if (!empty($has)) {
  91. return json(['code' => -1, 'data' => '', 'msg' => '该管理员已经存在']);
  92. }
  93. // 修改用户密码
  94. if (empty($param['password'])) {
  95. unset($param['password']);
  96. } else {
  97. $param['password'] = md5($param['password'] . config('salt'));
  98. }
  99. try {
  100. db('admins')->where('id', $param['id'])->update($param);
  101. } catch (\Exception $e) {
  102. return json(['code' => -2, 'data' => '', 'msg' => $e->getMessage()]);
  103. }
  104. return json(['code' => 1, 'data' => '', 'msg' => '编辑管理员成功']);
  105. }
  106. $id = input('param.id/d');
  107. $info = db('admins')->where('id', $id)->find();
  108. $this->assign([
  109. 'info' => $info,
  110. 'status' => config('kf_status')
  111. ]);
  112. return $this->fetch('editadmin');
  113. }
  114. // 删除管理员
  115. public function delAdmin()
  116. {
  117. if (request()->isAjax()) {
  118. $id = input('param.id/d');
  119. //return $id;
  120. try {
  121. db('admins')->where('id', $id)->delete();
  122. } catch (\Exception $e) {
  123. return json(['code' => -1, 'data' => '', 'msg' => $e->getMessage()]);
  124. }
  125. return json(['code' => 1, 'data' => '', 'msg' => '删除管理员成功']);
  126. }
  127. }
  128. // 权限组
  129. public function power()
  130. {
  131. if (request()->isAjax()) {
  132. $param = input('param.');
  133. $limit = $param['pageSize'];
  134. $offset = ($param['pageNumber'] - 1) * $limit;
  135. $result = db('admingroup')->limit($offset, $limit)->select();
  136. foreach ($result as $key => $vo) {
  137. // 优化显示状态
  138. if (1 == $vo['status']) {
  139. $result[$key]['status'] = '<span class="label label-primary">启用</span>';
  140. } else {
  141. $result[$key]['status'] = '<span class="label label-danger">禁用</span>';
  142. }
  143. // 上次登录时间
  144. $result[$key]['addtime'] = date('Y-m-d H:i:s', $vo['addtime']);
  145. // 生成操作按钮
  146. if (0 != $vo['group_id']) {
  147. $result[$key]['operate'] = $this->makeBtnPower($vo['group_id']);
  148. }
  149. }
  150. $return['total'] = db('admingroup')->count(); //总数据
  151. $return['rows'] = $result;
  152. return json($return);
  153. }
  154. return $this->fetch();
  155. }
  156. // 添加权限组
  157. public function addpower()
  158. {
  159. if (request()->isPost()) {
  160. $param = input('post.');
  161. $has = db('admingroup')->field('group_id')->where('group_name', $param['group_name'])->find();
  162. if (!empty($has)) {
  163. return json(['code' => -1, 'data' => '', 'msg' => '该权限组已经存在']);
  164. }
  165. try {
  166. db('admingroup')->insert($param);
  167. } catch (\Exception $e) {
  168. return json(['code' => -2, 'data' => '', 'msg' => $e->getMessage()]);
  169. }
  170. return json(['code' => 1, 'data' => '', 'msg' => '添加权限组成功']);
  171. }
  172. $this->assign([
  173. 'status' => config('kf_status')
  174. ]);
  175. return $this->fetch();
  176. }
  177. // 编辑权限组
  178. public function editpower()
  179. {
  180. // 权限组id
  181. $id = input('param.id/d');
  182. if (request()->isAjax()) {
  183. $menu = db('menu')->select();
  184. $param = input('post.');
  185. $data=array();
  186. for($i=0;$i<count($menu);$i++){
  187. if($param[$menu[$i]['name_cn']] != 0){
  188. $data[] = [
  189. 'group_id' => $param['group_id'],
  190. 'menu_id' => $param[$menu[$i]['name_cn']],
  191. ] ;
  192. }
  193. }
  194. if(!empty($data)){
  195. try {
  196. db('admingrouppower')->where('group_id',$param['group_id'])->delete();
  197. db('admingrouppower')->insertAll($data);
  198. } catch (\Exception $e) {
  199. return json(['code' => -2, 'data' => '', 'msg' => $e->getMessage()]);
  200. }
  201. }
  202. return json(['code' => 1, 'data' => '', 'msg' => '编辑权限组成功']);
  203. }
  204. $menu = db('menu')->where('p_id',0)->select();
  205. $menulist = db('menu')->where('p_id','<>',0)->select();
  206. $adminmenu = db('admingrouppower')->where('group_id', $id)->select();
  207. for($i=0;$i<count($menu);$i++){
  208. $n = 0;
  209. for($a=0;$a<count($adminmenu);$a++){
  210. if($menu[$i]['id'] == $adminmenu[$a]['menu_id']){
  211. $n = 1;
  212. }
  213. }
  214. if($n == 1){
  215. $menu[$i]['power'] = 1;
  216. }else{
  217. $menu[$i]['power'] = 0;
  218. }
  219. for($j=0;$j<count($menulist);$j++){
  220. $num = 0;
  221. for($b=0;$b<count($adminmenu);$b++){
  222. if($menulist[$j]['id'] == $adminmenu[$b]['menu_id']){
  223. $num = 1;
  224. }
  225. }
  226. if($num == 1){
  227. $menulist[$j]['power'] = 1;
  228. }else{
  229. $menulist[$j]['power'] = 0;
  230. }
  231. if($menu[$i]['id'] == $menulist[$j]['p_id']){
  232. $menu[$i]['menulist'][$j] = $menulist[$j];
  233. }
  234. }
  235. }
  236. $this->assign([
  237. 'info' => $menu,
  238. 'id' => $id,
  239. 'status' => config('kf_status')
  240. ]);
  241. return $this->fetch();
  242. }
  243. // 删除权限组
  244. public function delPower()
  245. {
  246. if (request()->isAjax()) {
  247. $id = input('param.id/d');
  248. //return $id;
  249. try {
  250. db('admingroup')->where('group_id', $id)->delete();
  251. db('admingrouppower')->where('group_id', $id)->delete();
  252. } catch (\Exception $e) {
  253. return json(['code' => -1, 'data' => '', 'msg' => $e->getMessage()]);
  254. }
  255. return json(['code' => 1, 'data' => '', 'msg' => '删除权限组成功']);
  256. }
  257. }
  258. // 生成管理员操作按钮
  259. private function makeBtn($id)
  260. {
  261. $operate = '<a href="' . url('admins/editadmin', ['id' => $id]) . '">';
  262. $operate .= '<button type="button" class="btn btn-primary btn-sm"><i class="fa fa-paste"></i> 编辑</button></a> ';
  263. $operate .= '<a href="javascript:adminDel(' . $id . ')"><button type="button" class="btn btn-danger btn-sm">';
  264. $operate .= '<i class="fa fa-trash-o"></i> 删除</button></a> ';
  265. return $operate;
  266. }
  267. // 生成权限组操作按钮
  268. private function makeBtnPower($id)
  269. {
  270. $operate = '<a href="' . url('admins/editpower', ['id' => $id]) . '">';
  271. $operate .= '<button type="button" class="btn btn-primary btn-sm"><i class="fa fa-paste"></i> 编辑</button></a> ';
  272. $operate .= '<a href="javascript:powerDel(' . $id . ')"><button type="button" class="btn btn-danger btn-sm">';
  273. $operate .= '<i class="fa fa-trash-o"></i> 删除</button></a> ';
  274. return $operate;
  275. }
  276. }