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;
|
||
}
|
||
}
|
||
|
||
} |