Admins.php 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388
  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 (strlen($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')->where('status',1)->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')->where('status',1)->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. $menu = db('menu')->select();
  166. $param = input('post.');
  167. $has = db('admingroup')->where('group_name', $param['group_name'])->find();
  168. if (!empty($has)) {
  169. return json(['code' => -1, 'data' => '', 'msg' => '该权限组已经存在']);
  170. }
  171. $info=array();
  172. $info['group_name'] = $param['group_name'];
  173. $info['status'] = $param['status'];
  174. $info['addtime'] = time();
  175. try {
  176. $group_id = db('admingroup')->insertGetId($info);
  177. } catch (\Exception $e) {
  178. return json(['code' => -2, 'data' => '', 'msg' => $e->getMessage()]);
  179. }
  180. $data=array();
  181. for($i=0;$i<count($menu);$i++){
  182. if($param[$menu[$i]['name_cn']] != 0){
  183. $data[] = [
  184. 'group_id' => $group_id,
  185. 'menu_id' => $param[$menu[$i]['name_cn']],
  186. ] ;
  187. }
  188. }
  189. if(!empty($data)){
  190. try {
  191. db('admingrouppower')->where('group_id',$param['group_id'])->delete();
  192. db('admingrouppower')->insertAll($data);
  193. } catch (\Exception $e) {
  194. return json(['code' => -3, 'data' => '', 'msg' => $e->getMessage()]);
  195. }
  196. }
  197. return json(['code' => 1, 'data' => '', 'msg' => '添加权限组成功']);
  198. }
  199. $menu = db('menu')->where('p_id',0)->select();
  200. $menulist = db('menu')->where('p_id','<>',0)->select();
  201. for($i=0;$i<count($menu);$i++){
  202. for($j=0;$j<count($menulist);$j++){
  203. $menulist[$j]['class'] = $menu[$i]['ico'];
  204. if($menu[$i]['id'] == $menulist[$j]['p_id']){
  205. $menu[$i]['menulist'][$j] = $menulist[$j];
  206. }
  207. }
  208. }
  209. $this->assign([
  210. 'info' => $menu,
  211. 'status' => config('kf_status')
  212. ]);
  213. return $this->fetch();
  214. }
  215. // 编辑权限组
  216. public function editpower()
  217. {
  218. // 权限组id
  219. $id = input('param.id/d');
  220. if (request()->isAjax()) {
  221. $menu = db('menu')->select();
  222. $param = input('post.');
  223. $has = db('admingroup')->where('group_name',$param['group_name'])->where('group_id','<>',$param['group_id'])->find();
  224. if (!empty($has)) {
  225. return json(['code' => -1, 'data' => '', 'msg' => '该权限组已经存在']);
  226. }
  227. $info=array();
  228. $info['group_name'] = $param['group_name'];
  229. $info['status'] = $param['status'];
  230. $info['addtime'] = time();
  231. $data=array();
  232. for($i=0;$i<count($menu);$i++){
  233. if($param[$menu[$i]['name_cn']] != 0){
  234. $data[] = [
  235. 'group_id' => $param['group_id'],
  236. 'menu_id' => $param[$menu[$i]['name_cn']],
  237. ] ;
  238. }
  239. }
  240. $admingrouppower = db('admingrouppower')->where('group_id',$param['group_id'])->select();
  241. try {
  242. db('admingroup')->where('group_id',$param['group_id'])->update($info);
  243. if(!empty($admingrouppower)){
  244. db('admingrouppower')->where('group_id',$param['group_id'])->delete();
  245. }
  246. if(!empty($data)){
  247. db('admingrouppower')->insertAll($data);
  248. }
  249. } catch (\Exception $e) {
  250. return json(['code' => -2, 'data' => '', 'msg' => $e->getMessage()]);
  251. }
  252. return json(['code' => 1, 'data' => '', 'msg' => '编辑权限组成功']);
  253. }
  254. $menu = db('menu')->where('p_id',0)->select();
  255. $menulist = db('menu')->where('p_id','<>',0)->select();
  256. $adminmenu = db('admingrouppower')->where('group_id', $id)->select();
  257. for($i=0;$i<count($menu);$i++){
  258. $n = 0;
  259. for($a=0;$a<count($adminmenu);$a++){
  260. if($menu[$i]['id'] == $adminmenu[$a]['menu_id']){
  261. $n = 1;
  262. }
  263. }
  264. if($n == 1){
  265. $menu[$i]['power'] = 1;
  266. }else{
  267. $menu[$i]['power'] = 0;
  268. }
  269. for($j=0;$j<count($menulist);$j++){
  270. $num = 0;
  271. $menulist[$j]['class'] = $menu[$i]['ico'];
  272. for($b=0;$b<count($adminmenu);$b++){
  273. if($menulist[$j]['id'] == $adminmenu[$b]['menu_id']){
  274. $num = 1;
  275. }
  276. }
  277. if($num == 1){
  278. $menulist[$j]['power'] = 1;
  279. }else{
  280. $menulist[$j]['power'] = 0;
  281. }
  282. if($menu[$i]['id'] == $menulist[$j]['p_id']){
  283. $menu[$i]['menulist'][$j] = $menulist[$j];
  284. }
  285. }
  286. }
  287. $admingroup = db('admingroup')->where('group_id',$id)->find();
  288. $this->assign([
  289. 'info' => $menu,
  290. 'id' => $id,
  291. 'admingroup' => $admingroup,
  292. 'status' => config('kf_status')
  293. ]);
  294. return $this->fetch();
  295. }
  296. // 删除权限组
  297. public function delPower()
  298. {
  299. if (request()->isAjax()) {
  300. $id = input('param.id/d');
  301. //return $id;
  302. try {
  303. db('admingroup')->where('group_id', $id)->delete();
  304. db('admingrouppower')->where('group_id', $id)->delete();
  305. } catch (\Exception $e) {
  306. return json(['code' => -1, 'data' => '', 'msg' => $e->getMessage()]);
  307. }
  308. return json(['code' => 1, 'data' => '', 'msg' => '删除权限组成功']);
  309. }
  310. }
  311. // 生成管理员操作按钮
  312. private function makeBtn($id)
  313. {
  314. $operate = '<a href="' . url('admins/editadmin', ['id' => $id]) . '">';
  315. $operate .= '<button type="button" class="btn btn-primary btn-sm"><i class="fa fa-paste"></i> 编辑</button></a> ';
  316. $operate .= '<a href="javascript:adminDel(' . $id . ')"><button type="button" class="btn btn-danger btn-sm">';
  317. $operate .= '<i class="fa fa-trash-o"></i> 删除</button></a> ';
  318. return $operate;
  319. }
  320. // 生成权限组操作按钮
  321. private function makeBtnPower($id)
  322. {
  323. $operate = '<a href="' . url('admins/editpower', ['id' => $id]) . '">';
  324. $operate .= '<button type="button" class="btn btn-primary btn-sm"><i class="fa fa-paste"></i> 编辑</button></a> ';
  325. $operate .= '<a href="javascript:powerDel(' . $id . ')"><button type="button" class="btn btn-danger btn-sm">';
  326. $operate .= '<i class="fa fa-trash-o"></i> 删除</button></a> ';
  327. return $operate;
  328. }
  329. }