181 lines
		
	
	
		
			5.6 KiB
		
	
	
	
		
			PHP
		
	
	
		
		
			
		
	
	
			181 lines
		
	
	
		
			5.6 KiB
		
	
	
	
		
			PHP
		
	
	
|  | <?php | |||
|  | // +----------------------------------------------------------------------
 | |||
|  | // | likeshop开源商城系统
 | |||
|  | // +----------------------------------------------------------------------
 | |||
|  | // | 欢迎阅读学习系统程序代码,建议反馈是我们前进的动力
 | |||
|  | // | gitee下载:https://gitee.com/likeshop_gitee
 | |||
|  | // | github下载:https://github.com/likeshop-github
 | |||
|  | // | 访问官网:https://www.likeshop.cn
 | |||
|  | // | 访问社区:https://home.likeshop.cn
 | |||
|  | // | 访问手册:http://doc.likeshop.cn
 | |||
|  | // | 微信公众号:likeshop技术社区
 | |||
|  | // | likeshop系列产品在gitee、github等公开渠道开源版本可免费商用,未经许可不能去除前后端官方版权标识
 | |||
|  | // |  likeshop系列产品收费版本务必购买商业授权,购买去版权授权后,方可去除前后端官方版权标识
 | |||
|  | // | 禁止对系统程序代码以任何目的,任何形式的再发布
 | |||
|  | // | likeshop团队版权所有并拥有最终解释权
 | |||
|  | // +----------------------------------------------------------------------
 | |||
|  | // | author: likeshop.cn.team
 | |||
|  | // +----------------------------------------------------------------------
 | |||
|  | 
 | |||
|  | 
 | |||
|  | namespace app\shop\logic; | |||
|  | 
 | |||
|  | 
 | |||
|  | use app\common\basics\Logic; | |||
|  | use app\common\model\Admin; | |||
|  | use app\common\model\shop\ShopAdmin; | |||
|  | use app\common\model\shop\ShopRole; | |||
|  | 
 | |||
|  | class AdminLogic extends Logic | |||
|  | { | |||
|  | 
 | |||
|  |     /** | |||
|  |      * Notes: 列表 | |||
|  |      * @param $get | |||
|  |      * @author 段誉(2021/4/10 11:05) | |||
|  |      * @return array | |||
|  |      * @throws \think\db\exception\DataNotFoundException | |||
|  |      * @throws \think\db\exception\DbException | |||
|  |      * @throws \think\db\exception\ModelNotFoundException | |||
|  |      */ | |||
|  |     public static function lists($get, $shop_id) | |||
|  |     { | |||
|  |         $roleModel = new  ShopRole(); | |||
|  |         $adminModel = new ShopAdmin(); | |||
|  | 
 | |||
|  |         $role_column = $roleModel->getNameColumn(); | |||
|  | 
 | |||
|  |         $where[] = ['del', '=', 0]; | |||
|  |         $where[] = ['shop_id', '=', $shop_id]; | |||
|  |         if (isset($get['role_id']) && $get['role_id']) { | |||
|  |             $where[] = ['role_id', '=', $get['role_id']]; | |||
|  |         } | |||
|  |         if (isset($get['name']) && $get['name']) { | |||
|  |             $where[] = ['name', 'like', "%{$get['name']}%"]; | |||
|  |         } | |||
|  |         if (isset($get['account']) && $get['account']) { | |||
|  |             $where[] = ['account', 'like', "%{$get['account']}%"]; | |||
|  |         } | |||
|  | 
 | |||
|  |         $result = $adminModel->where($where) | |||
|  |             ->hidden(['password', 'salt']) | |||
|  |             ->paginate([ | |||
|  |                 'list_rows'=> $get['limit'], | |||
|  |                 'page'=> $get['page'] | |||
|  |             ]); | |||
|  | 
 | |||
|  |         foreach ($result as $k => $item) { | |||
|  |             if ($item['root'] == 1) { | |||
|  |                 $role = '超级管理员'; | |||
|  |             } else { | |||
|  |                 $role = $role_column[$item['role_id']] ?? ''; | |||
|  |             } | |||
|  |             $result[$k]['role'] = $role; | |||
|  |         } | |||
|  |         return ['count' => $result->total(), 'lists' => $result->getCollection()]; | |||
|  |     } | |||
|  | 
 | |||
|  | 
 | |||
|  |     /** | |||
|  |      * Notes: 添加管理员 | |||
|  |      * @param $post | |||
|  |      * @author 段誉(2021/4/10 16:14) | |||
|  |      * @return Admin|\think\Model | |||
|  |      */ | |||
|  |     public static function addAdmin($shop_id, $post) | |||
|  |     { | |||
|  |         $time = time(); | |||
|  |         $salt = substr(md5($time . $post['name']), 0, 4);//随机4位密码盐
 | |||
|  |         $password = generatePassword($post['password'], $salt);//生成密码
 | |||
|  |         return ShopAdmin::create([ | |||
|  |             'name'     => $post['name'], | |||
|  |             'shop_id'  => $shop_id, | |||
|  |             'root'     => 0, | |||
|  |             'account'  => $post['account'], | |||
|  |             'password' => $password, | |||
|  |             'salt'     => $salt, | |||
|  |             'role_id'  => $post['role_id'], | |||
|  |             'disable'   => $post['disable'] | |||
|  |         ]); | |||
|  |     } | |||
|  | 
 | |||
|  | 
 | |||
|  |     /** | |||
|  |      * Notes: 更新管理员 | |||
|  |      * @param $post | |||
|  |      * @author 段誉(2021/4/10 17:11) | |||
|  |      * @return bool | |||
|  |      * @throws \think\db\exception\DataNotFoundException | |||
|  |      * @throws \think\db\exception\DbException | |||
|  |      * @throws \think\db\exception\ModelNotFoundException | |||
|  |      */ | |||
|  |     public static function editAdmin($shop_id, $post) | |||
|  |     { | |||
|  |         $admin = ShopAdmin::where('shop_id', $shop_id)->find($post['id']); | |||
|  | 
 | |||
|  |         if(empty($admin)) { | |||
|  |             self::$error = '未找到相关管理员'; | |||
|  |             return false; | |||
|  |         } | |||
|  | 
 | |||
|  |         $data = [ | |||
|  |             'name'          => $post['name'], | |||
|  |             'account'       => $post['account'], | |||
|  |             'role_id'       => $post['role_id'], | |||
|  |             'update_time'   => time(), | |||
|  |             'disable'       => $post['disable'] | |||
|  |         ]; | |||
|  | 
 | |||
|  |         //生成密码
 | |||
|  |         if ($post['password']) { | |||
|  |             $data['password'] = generatePassword($post['password'], $admin['salt']); | |||
|  |         } | |||
|  | 
 | |||
|  |         //TODO 禁用管理员并强制下线
 | |||
|  |         if (1 == $post['disable'] || $admin['role_id'] != $post['role_id']) { | |||
|  | 
 | |||
|  |         } | |||
|  | 
 | |||
|  |         return $admin->save($data); | |||
|  |     } | |||
|  | 
 | |||
|  | 
 | |||
|  |     /** | |||
|  |      * Notes: 删除 | |||
|  |      * @param $shop_id | |||
|  |      * @param $id | |||
|  |      * @author 段誉(2021/5/7 11:11) | |||
|  |      * @return ShopAdmin | |||
|  |      */ | |||
|  |     public static function delAdmin($shop_id, $id) | |||
|  |     { | |||
|  |         return ShopAdmin::update([ | |||
|  |             'account' => time() . '_' . $id, | |||
|  |             'del' => 1, | |||
|  |             'shop_id' => $shop_id | |||
|  |         ], ['id' => $id]); | |||
|  |     } | |||
|  | 
 | |||
|  | 
 | |||
|  |     /** | |||
|  |      * Notes: 修改密码 | |||
|  |      * @param $password | |||
|  |      * @param $admin_id | |||
|  |      * @param $shop_id | |||
|  |      * @author 段誉(2021/5/7 11:15) | |||
|  |      * @return bool | |||
|  |      */ | |||
|  |     public static function updatePassword($password, $admin_id, $shop_id) | |||
|  |     { | |||
|  |         try { | |||
|  |             $admin = ShopAdmin::where(['id' => $admin_id, 'shop_id' => $shop_id])->find(); | |||
|  |             $admin->password = generatePassword($password, $admin['salt']); | |||
|  |             $admin->save(); | |||
|  |             return true; | |||
|  |         } catch (\Exception $e) { | |||
|  |             self::$error = $e->getMessage(); | |||
|  |             return false; | |||
|  |         } | |||
|  |     } | |||
|  | 
 | |||
|  | } |