Admins.php 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339
  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. if ($param['group_id'] == 0) {
  94. return json(['code' => -2, 'data' => '', 'msg' => '请选择分组']);
  95. }
  96. // 修改用户密码
  97. if (empty($param['password'])) {
  98. unset($param['password']);
  99. } else {
  100. $param['password'] = md5($param['password'] . config('salt'));
  101. }
  102. try {
  103. db('admins')->where('id', $param['id'])->update($param);
  104. } catch (\Exception $e) {
  105. return json(['code' => -3, 'data' => '', 'msg' => $e->getMessage()]);
  106. }
  107. return json(['code' => 1, 'data' => '', 'msg' => '编辑管理员成功']);
  108. }
  109. $id = input('param.id/d');
  110. $info = db('admins')->where('id', $id)->find();
  111. $admingroup = db('admingroup')->select();
  112. $this->assign([
  113. 'info' => $info,
  114. 'admingroup' => $admingroup,
  115. 'status' => config('kf_status')
  116. ]);
  117. return $this->fetch('editadmin');
  118. }
  119. // 删除管理员
  120. public function delAdmin()
  121. {
  122. if (request()->isAjax()) {
  123. $id = input('param.id/d');
  124. //return $id;
  125. try {
  126. db('admins')->where('id', $id)->delete();
  127. } catch (\Exception $e) {
  128. return json(['code' => -1, 'data' => '', 'msg' => $e->getMessage()]);
  129. }
  130. return json(['code' => 1, 'data' => '', 'msg' => '删除管理员成功']);
  131. }
  132. }
  133. // 权限组
  134. public function power()
  135. {
  136. if (request()->isAjax()) {
  137. $param = input('param.');
  138. $limit = $param['pageSize'];
  139. $offset = ($param['pageNumber'] - 1) * $limit;
  140. $result = db('admingroup')->limit($offset, $limit)->select();
  141. foreach ($result as $key => $vo) {
  142. // 优化显示状态
  143. if (1 == $vo['status']) {
  144. $result[$key]['status'] = '<span class="label label-primary">启用</span>';
  145. } else {
  146. $result[$key]['status'] = '<span class="label label-danger">禁用</span>';
  147. }
  148. // 上次登录时间
  149. $result[$key]['addtime'] = date('Y-m-d H:i:s', $vo['addtime']);
  150. // 生成操作按钮
  151. if (1 != $vo['group_id']) {
  152. $result[$key]['operate'] = $this->makeBtnPower($vo['group_id']);
  153. }
  154. }
  155. $return['total'] = db('admingroup')->count(); //总数据
  156. $return['rows'] = $result;
  157. return json($return);
  158. }
  159. return $this->fetch();
  160. }
  161. // 添加权限组
  162. public function addpower()
  163. {
  164. if (request()->isPost()) {
  165. $param = input('post.');
  166. $has = db('admingroup')->field('group_id')->where('group_name', $param['group_name'])->find();
  167. if (!empty($has)) {
  168. return json(['code' => -1, 'data' => '', 'msg' => '该权限组已经存在']);
  169. }
  170. try {
  171. db('admingroup')->insert($param);
  172. } catch (\Exception $e) {
  173. return json(['code' => -2, 'data' => '', 'msg' => $e->getMessage()]);
  174. }
  175. return json(['code' => 1, 'data' => '', 'msg' => '添加权限组成功']);
  176. }
  177. $this->assign([
  178. 'status' => config('kf_status')
  179. ]);
  180. return $this->fetch();
  181. }
  182. // 编辑权限组
  183. public function editpower()
  184. {
  185. // 权限组id
  186. $id = input('param.id/d');
  187. if (request()->isAjax()) {
  188. $menu = db('menu')->select();
  189. $param = input('post.');
  190. $data=array();
  191. for($i=0;$i<count($menu);$i++){
  192. if($param[$menu[$i]['name_cn']] != 0){
  193. $data[] = [
  194. 'group_id' => $param['group_id'],
  195. 'menu_id' => $param[$menu[$i]['name_cn']],
  196. ] ;
  197. }
  198. }
  199. if(!empty($data)){
  200. try {
  201. db('admingrouppower')->where('group_id',$param['group_id'])->delete();
  202. db('admingrouppower')->insertAll($data);
  203. } catch (\Exception $e) {
  204. return json(['code' => -2, 'data' => '', 'msg' => $e->getMessage()]);
  205. }
  206. }
  207. return json(['code' => 1, 'data' => '', 'msg' => '编辑权限组成功']);
  208. }
  209. $menu = db('menu')->where('p_id',0)->select();
  210. $menulist = db('menu')->where('p_id','<>',0)->select();
  211. $adminmenu = db('admingrouppower')->where('group_id', $id)->select();
  212. for($i=0;$i<count($menu);$i++){
  213. $n = 0;
  214. for($a=0;$a<count($adminmenu);$a++){
  215. if($menu[$i]['id'] == $adminmenu[$a]['menu_id']){
  216. $n = 1;
  217. }
  218. }
  219. if($n == 1){
  220. $menu[$i]['power'] = 1;
  221. }else{
  222. $menu[$i]['power'] = 0;
  223. }
  224. for($j=0;$j<count($menulist);$j++){
  225. $num = 0;
  226. for($b=0;$b<count($adminmenu);$b++){
  227. if($menulist[$j]['id'] == $adminmenu[$b]['menu_id']){
  228. $num = 1;
  229. }
  230. }
  231. if($num == 1){
  232. $menulist[$j]['power'] = 1;
  233. }else{
  234. $menulist[$j]['power'] = 0;
  235. }
  236. if($menu[$i]['id'] == $menulist[$j]['p_id']){
  237. $menu[$i]['menulist'][$j] = $menulist[$j];
  238. }
  239. }
  240. }
  241. $this->assign([
  242. 'info' => $menu,
  243. 'id' => $id,
  244. 'status' => config('kf_status')
  245. ]);
  246. return $this->fetch();
  247. }
  248. // 删除权限组
  249. public function delPower()
  250. {
  251. if (request()->isAjax()) {
  252. $id = input('param.id/d');
  253. //return $id;
  254. try {
  255. db('admingroup')->where('group_id', $id)->delete();
  256. db('admingrouppower')->where('group_id', $id)->delete();
  257. } catch (\Exception $e) {
  258. return json(['code' => -1, 'data' => '', 'msg' => $e->getMessage()]);
  259. }
  260. return json(['code' => 1, 'data' => '', 'msg' => '删除权限组成功']);
  261. }
  262. }
  263. // 生成管理员操作按钮
  264. private function makeBtn($id)
  265. {
  266. $operate = '<a href="' . url('admins/editadmin', ['id' => $id]) . '">';
  267. $operate .= '<button type="button" class="btn btn-primary btn-sm"><i class="fa fa-paste"></i> 编辑</button></a> ';
  268. $operate .= '<a href="javascript:adminDel(' . $id . ')"><button type="button" class="btn btn-danger btn-sm">';
  269. $operate .= '<i class="fa fa-trash-o"></i> 删除</button></a> ';
  270. return $operate;
  271. }
  272. // 生成权限组操作按钮
  273. private function makeBtnPower($id)
  274. {
  275. $operate = '<a href="' . url('admins/editpower', ['id' => $id]) . '">';
  276. $operate .= '<button type="button" class="btn btn-primary btn-sm"><i class="fa fa-paste"></i> 编辑</button></a> ';
  277. $operate .= '<a href="javascript:powerDel(' . $id . ')"><button type="button" class="btn btn-danger btn-sm">';
  278. $operate .= '<i class="fa fa-trash-o"></i> 删除</button></a> ';
  279. return $operate;
  280. }
  281. }