Files
zzp-server/app/adminapi/logic/user/UserGroupLogic.php
2026-01-19 14:19:22 +08:00

141 lines
3.4 KiB
PHP

<?php
namespace app\adminapi\logic\user;
use app\common\model\user\{User,UserGroup,UserGroupRecord};
use app\common\logic\BaseLogic;
use think\facade\Db;
/**
* 用户分组逻辑
* Class UserGroupLogic
* @package app\adminapi\logic\user
*/
class UserGroupLogic extends BaseLogic
{
/**
* @notes 添加用户分组
* @param array $params
* @return bool
* @author BD
* @date 2024/04/25 01:04
*/
public static function add(array $params): bool
{
Db::startTrans();
try {
UserGroup::create([
'name' => $params['name']
]);
Db::commit();
return true;
} catch (\Exception $e) {
Db::rollback();
self::setError($e->getMessage());
return false;
}
}
/**
* @notes 编辑用户分组
* @param array $params
* @return bool
* @author BD
* @date 2024/04/25 01:04
*/
public static function edit(array $params): bool
{
Db::startTrans();
try {
UserGroup::where('id', $params['id'])->update([
'name' => $params['name']
]);
Db::commit();
return true;
} catch (\Exception $e) {
Db::rollback();
self::setError($e->getMessage());
return false;
}
}
/**
* @notes 删除用户分组
* @param array $params
* @return bool
* @author BD
* @date 2024/04/25 01:04
*/
public static function delete(array $params): bool
{
return UserGroup::destroy($params['id']);
}
/**
* @notes 获取用户分组详情
* @param $params
* @return array
* @author BD
* @date 2024/04/25 01:04
*/
public static function detail($params): array
{
return UserGroup::findOrEmpty($params['id'])->toArray();
}
/**
* @notes 用户分组
* @param array $params
* @return bool
* @author BD
* @date 2024/03/19 02:29
*/
public static function setUserGroup(array $params): bool
{
Db::startTrans();
try {
$user = User::where(['id' => $params['user_id']])->findOrEmpty();
if ($user->isEmpty()) {
throw new \Exception('用户不存在');
}
$group = UserGroup::where(['id' => $params['group_id']])->findOrEmpty();
if ($group->isEmpty() && $params['group_id'] != 0) {
throw new \Exception('分组不存在');
}
$data = [
'user_id' => $params['user_id'],
'group_id' => $params['group_id'],
];
//查询用户分组
$record = UserGroupRecord::where(['user_id' => $params['user_id']])->findOrEmpty();
if($params['group_id'] != 0){
if ($record->isEmpty()) {
UserGroupRecord::create($data);
}else{
$data['id'] = $record['id'];
UserGroupRecord::update($data);
}
}else{
UserGroupRecord::destroy($record['id']);
}
Db::commit();
return true;
} catch (\Exception $e) {
Db::rollback();
self::setError($e->getMessage());
return false;
}
}
}