Proprietor.php 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342
  1. <?php
  2. /**
  3. * @copyright Copyright (c) 2021 勾股工作室
  4. * @license https://opensource.org/licenses/Apache-2.0
  5. * @link https://www.gougucms.com
  6. */
  7. declare (strict_types = 1);
  8. namespace app\admin\controller;
  9. use app\admin\BaseController;
  10. use app\admin\model\Admin as AdminList;
  11. use app\admin\validate\AdminCheck;
  12. use avatars\MDAvatars;
  13. use think\exception\ValidateException;
  14. use think\facade\Db;
  15. use think\facade\View;
  16. use think\facade\Session;
  17. use think\App;
  18. use think\facade\Cache;
  19. use app\admin\controller\Role;
  20. use app\admin\model\Department as DepartmentModel;
  21. class Proprietor extends BaseController
  22. {
  23. public function __construct(App $app)
  24. {
  25. parent::__construct($app);
  26. $this->Role = new Role($this->app);
  27. $this->Department = new DepartmentModel();
  28. }
  29. public function index()
  30. {
  31. if (request()->isAjax()) {
  32. // 获取单位名称
  33. $session_admin = get_config('app.session_admin');
  34. $id = Session::get($session_admin)['id'];
  35. $unit_name = Db::name('admin')->where('id', $id)->value('unit_name');
  36. $param = get_params();
  37. // $proprietorDepartmentIds = Db::name("department")
  38. // ->where([
  39. // ["delete_time", "=", 0],
  40. // ["pid", "=", 0],
  41. // ["type", "=", 1], //1表示业主
  42. // ["entrust_unit", "=", $unit_name] // 确保只获取当前财评所属单位关联的业主单位
  43. // ])->column('id');//
  44. $where = [
  45. ['status', '>=', 0],
  46. ['unit_name', '=', $unit_name]
  47. ];
  48. if (!empty($param['keywords'])) {
  49. $keywordWhere = ['id|username|nickname|desc|mobile', 'like', '%'. $param['keywords']. '%'];
  50. $where = array_merge($where, [$keywordWhere]);
  51. }
  52. $rows = empty($param['limit']) ? get_config('app.page_size') : $param['limit'];
  53. $proprietor = AdminList::where($where)->with('Department')
  54. ->order('create_time asc')
  55. ->paginate($rows, false, ['query' => $param])
  56. ->each(function ($item, $key) {
  57. $groupId = Db::name('AdminGroupAccess')->where(['uid' => $item->id])->column('group_id');
  58. $groupName = Db::name('AdminGroup')->where('id', 'in', $groupId)->column('title');
  59. $item->groupName = implode(',', $groupName);
  60. $item->last_login_time = empty($item->last_login_time) ? '-' : date('Y-m-d H:i', $item->last_login_time);
  61. })->toArray();
  62. return table_assign(0, '', $proprietor);
  63. } else {
  64. return view();
  65. }
  66. }
  67. //添加/编辑
  68. public function add()
  69. {
  70. if (request()->isAjax()) {
  71. $param = get_params();
  72. if (!empty($param['id']) && $param['id'] > 0) { //对已存在账号的编辑
  73. try {//验证编辑信息
  74. validate(AdminCheck::class)->scene('edit')->check($param);
  75. } catch (ValidateException $e) {
  76. // 验证失败 输出错误信息
  77. return to_assign(1, $e->getError());
  78. }
  79. if (!empty($param['edit_pwd'])) {
  80. //修改密码
  81. if (empty($param['edit_pwd_confirm']) or $param['edit_pwd_confirm'] !== $param['edit_pwd']) {
  82. return to_assign(1, '两次密码不一致');
  83. }
  84. $param['salt'] = set_salt(20);
  85. $param['pwd'] = set_password($param['edit_pwd'], $param['salt']);
  86. }
  87. // 启动事务
  88. Db::startTrans();
  89. try {
  90. Db::name('Admin')->where(['id' => $param['id']])->strict(false)->field(true)->update($param); //更新密码
  91. if (!isset($param['thumb']) || $param['thumb'] == '') {//头像更新
  92. $char = mb_substr($param['nickname'], 0, 1, 'utf-8');
  93. Db::name('Admin')->where('id', $param['id'])->update(['thumb' => $this->to_avatars($char)]);
  94. }
  95. // 获取单位名称
  96. $unit_name = self::get_unitName($param['id']);
  97. $data = [
  98. 'unit_name' => $unit_name,//更新用户信息的所属部门
  99. 'user_type' => Db::name('Department')->where('id', $unit_name)->value('type'),
  100. 'admin_group_id' => $param['admin_group_id'],//更新用户角色
  101. ];
  102. Db::name('admin')->where('id', $param['id'])->data($data)->update();
  103. add_log('edit', $param['id'], $param);
  104. //清除菜单\权限缓存
  105. clear_cache('adminMenu');
  106. clear_cache('adminRules');
  107. // 提交事务
  108. Db::commit();
  109. } catch (\Exception $e) {
  110. // 回滚事务
  111. Db::rollback();
  112. return to_assign(1, '提交失败:' . $e->getMessage());
  113. }
  114. } else { //新增账号
  115. try {//验证信息
  116. validate(AdminCheck::class)->scene('add')->check($param);
  117. } catch (ValidateException $e) {
  118. // 验证失败 输出错误信息
  119. return to_assign(1, $e->getError());
  120. }
  121. //加密
  122. $param['salt'] = set_salt(20);
  123. $param['pwd'] = set_password($param['pwd'], $param['salt']);
  124. // 启动事务
  125. Db::startTrans();
  126. try {
  127. foreach ($param['group_id'] as $k => $v) {//用户角色
  128. $param['admin_group_id'] = $v;
  129. }
  130. //插入用户并返回插入的id
  131. unset($param["department"]);
  132. $uid = Db::name('Admin')->strict(false)->field(true)->insertGetId($param);
  133. unset($param['admin_group_id']);
  134. if($param['is_principal'] == 1){//是部门负责人
  135. Db::name('department')->where('id', $param['did'])->data(['leader_id' => $uid])->update();
  136. }
  137. if (!isset($param['thumb']) || $param['thumb'] == '') {//头像处理
  138. $char = mb_substr($param['nickname'], 0, 1, 'utf-8');
  139. Db::name('Admin')->where('id', $uid)->update(['thumb' => $this->to_avatars($char)]);
  140. }
  141. // 获取业主单位名称
  142. $unit_name = get_login_admin("unit_name");
  143. $data = [
  144. 'unit_name' => $unit_name,
  145. 'user_type' => Db::name('Department')->where('id', $unit_name)->value('type'),
  146. ];
  147. Db::name('admin')->where('id', $uid)->data($data)->update();
  148. add_log('add', $uid, $param);
  149. // 提交事务
  150. Db::commit();
  151. } catch (\Exception $e) {
  152. // 回滚事务,回到最初
  153. Db::rollback();
  154. return to_assign(1, '提交失败:' . $e->getMessage());
  155. }
  156. }
  157. return to_assign(0,"操作成功");
  158. }else{
  159. $id = empty(get_params('id')) ? 0 : get_params('id');
  160. // dump($id);
  161. $permission = Db::name('admin')->where('id', get_login_admin('id'))->value('permission');
  162. $unit_name = Db::name('admin')->where('id', get_login_admin('id'))->value('unit_name');
  163. $where_d = array();
  164. //$where_g = array();
  165. if($permission == 0){
  166. //业主部门找在他委托下的
  167. //$where_d[] =["entrust_unit", "=", $unit_name];
  168. $where_d[]=["unit_name","=",get_login_admin('unit_name')];
  169. $where_g1 = [
  170. ["pid","=",Db::name("admin_group")->where( 'title', "业主")->value("id")],
  171. ];
  172. $where_g2 = [
  173. ["title","=","业主"],
  174. ];
  175. }
  176. $department = Db::name('Department')
  177. ->where('status', '>=', 0)//正常
  178. ->where($where_d)
  179. ->find();
  180. $group = Db::name('AdminGroup')
  181. ->whereOr([$where_g2,$where_g1])
  182. ->select()->toarray();
  183. if ($id > 0) {//编辑时
  184. $admin = get_admin(get_params('id'));
  185. $leader_id = Db::name('Department')->where('id', $admin['did'])->value('leader_id');
  186. if($leader_id == $id){
  187. $is_principal = 1;
  188. }else{
  189. $is_principal = 0;
  190. }
  191. View::assign('is_principal', $is_principal);
  192. View::assign('admin', $admin);
  193. }
  194. View::assign('permission', $permission);
  195. View::assign('department', $department);
  196. View::assign('group', $group);
  197. View::assign('id', $id);
  198. return view();
  199. }
  200. }
  201. public function to_avatars($char)
  202. {
  203. $defaultData = array('A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N',
  204. 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'S', 'Y', 'Z',
  205. '0', '1', '2', '3', '4', '5', '6', '7', '8', '9',
  206. '零', '壹', '贰', '叁', '肆', '伍', '陆', '柒', '捌', '玖', '拾',
  207. '一', '二', '三', '四', '五', '六', '七', '八', '九', '十');
  208. if (isset($char)) {
  209. $Char = $char;
  210. } else {
  211. $Char = $defaultData[mt_rand(0, count($defaultData) - 1)];
  212. }
  213. $OutputSize = min(512, empty($_GET['size']) ? 36 : intval($_GET['size']));
  214. $Avatar = new MDAvatars($Char, 256, 1);
  215. $avatar_name = '/avatars/avatar_256_' . set_salt(10) . time() . '.png';
  216. $path = get_config('filesystem.disks.public.url') . $avatar_name;
  217. $res = $Avatar->Save('.' . $path, 256);
  218. $Avatar->Free();
  219. return $path;
  220. }
  221. //查看
  222. public function view()
  223. {
  224. $id = get_params('id');
  225. $rule = get_admin_rule();
  226. $user_groups = Db::name('AdminGroupAccess')
  227. ->alias('a')
  228. ->join("AdminGroup g", "a.group_id=g.id", 'LEFT')
  229. ->where("a.uid='{$id}' and g.status='1'")
  230. ->select()
  231. ->toArray();
  232. $groups = $user_groups ?: [];
  233. $rules = [];
  234. foreach ($groups as $g) {
  235. $rules = array_merge($rules, explode(',', trim($g['rules'], ',')));
  236. }
  237. $rules = array_unique($rules);
  238. $role_rule = create_tree_list(0, $rule, $rules);
  239. $role_rule = $this->Role->remove_checked_false($role_rule);
  240. $department = get_department();
  241. // dump($department);
  242. $position = Db::name('Position')->where('status', '>=', 0)->order('create_time asc')->select();
  243. View::assign('department', $department);
  244. View::assign('position', $position);
  245. View::assign('role_rule', $role_rule);
  246. View::assign('admin', get_admin($id));
  247. add_log('view', get_params('id'));
  248. return view('', ['admin' => get_admin(get_params('id'))]);
  249. }
  250. //删除
  251. public function delete()
  252. {
  253. $id = get_params("id");
  254. if($id == 1){
  255. return to_assign(0, "超级管理员,不能删除");
  256. }
  257. $data['status'] = '-1';//改为已被删除,但是不会在admin里消失
  258. $data['id'] = $id;
  259. $data['update_time'] = time();
  260. if (Db::name('Admin')->update($data) !== false) {
  261. add_log('delete', $id);
  262. return to_assign(0, "删除业主成功");
  263. } else {
  264. return to_assign(1, "删除失败");
  265. }
  266. }
  267. public function get_unitName($id){
  268. $did = Db::name('Admin')->where('id', $id)->value('did');
  269. $pid = $did;
  270. while($pid != 0){
  271. $value = Db::name('department')->where('id', $pid)->column('id,pid,title')[0];
  272. $id = $value['id'];
  273. $pid = $value['pid'];
  274. $title = $value['title'];
  275. }
  276. return $id;
  277. }
  278. }