2019-12-09 16:22:00 +08:00
|
|
|
|
<?php
|
|
|
|
|
namespace catchAdmin\permissions\model;
|
|
|
|
|
|
|
|
|
|
use catchAdmin\user\model\Users;
|
2019-12-11 21:00:14 +08:00
|
|
|
|
use catcher\base\CatchModel;
|
2019-12-09 16:22:00 +08:00
|
|
|
|
|
2019-12-11 21:00:14 +08:00
|
|
|
|
class Roles extends CatchModel
|
2019-12-09 16:22:00 +08:00
|
|
|
|
{
|
|
|
|
|
protected $name = 'roles';
|
|
|
|
|
|
|
|
|
|
protected $field = [
|
|
|
|
|
'id', //
|
2019-12-11 21:00:14 +08:00
|
|
|
|
'role_name', // 角色名
|
2019-12-09 16:22:00 +08:00
|
|
|
|
'parent_id', // 父级ID
|
|
|
|
|
'description', // 角色备注
|
|
|
|
|
'created_at', // 创建时间
|
|
|
|
|
'updated_at', // 更新时间
|
|
|
|
|
'deleted_at', // 删除状态,0未删除 >0 已删除
|
|
|
|
|
|
|
|
|
|
];
|
|
|
|
|
|
2019-12-11 21:00:14 +08:00
|
|
|
|
public function getList($search = [])
|
2019-12-09 16:22:00 +08:00
|
|
|
|
{
|
|
|
|
|
return $this->when($search['name'] ?? false, function ($query) use ($search){
|
2019-12-11 21:00:14 +08:00
|
|
|
|
$query->whereLike('name', $search['name']);
|
|
|
|
|
})
|
|
|
|
|
->when($search['id'] ?? false, function ($query) use ($search){
|
|
|
|
|
$query->where('parent_id', $search['id'])
|
|
|
|
|
->whereOr('id', $search['id']);
|
|
|
|
|
})
|
|
|
|
|
->order('id', 'desc')
|
|
|
|
|
->select()
|
|
|
|
|
->toArray();
|
2019-12-09 16:22:00 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
*
|
|
|
|
|
* @time 2019年12月08日
|
|
|
|
|
* @return \think\model\relation\BelongsToMany
|
|
|
|
|
*/
|
|
|
|
|
public function users(): \think\model\relation\BelongsToMany
|
|
|
|
|
{
|
2019-12-12 09:13:29 +08:00
|
|
|
|
return $this->belongsToMany(Users::class, 'user_has_roles', 'uid', 'role_id');
|
2019-12-09 16:22:00 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
*
|
|
|
|
|
* @time 2019年12月09日
|
|
|
|
|
* @return \think\model\relation\BelongsToMany
|
|
|
|
|
*/
|
|
|
|
|
public function permissions(): \think\model\relation\BelongsToMany
|
|
|
|
|
{
|
2019-12-11 21:00:14 +08:00
|
|
|
|
return $this->belongsToMany(Permissions::class, 'role_has_permissions', 'permission_id', 'role_id');
|
2019-12-09 16:22:00 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
*
|
|
|
|
|
* @time 2019年12月08日
|
2019-12-22 09:37:52 +08:00
|
|
|
|
* @param array $condition
|
|
|
|
|
* @param array $field
|
2019-12-09 16:22:00 +08:00
|
|
|
|
* @return mixed
|
|
|
|
|
*/
|
2019-12-22 09:37:52 +08:00
|
|
|
|
public function getPermissions($condition = [], $field = [])
|
2019-12-09 16:22:00 +08:00
|
|
|
|
{
|
2019-12-22 09:37:52 +08:00
|
|
|
|
return $this->permissions()
|
|
|
|
|
->when(!empty($field), function ($query) use ($field){
|
|
|
|
|
$query->field($field);
|
|
|
|
|
})
|
|
|
|
|
->when(!empty($condition), function ($query) use ($condition){
|
|
|
|
|
$query->where($condition);
|
|
|
|
|
})
|
|
|
|
|
->select();
|
2019-12-09 16:22:00 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
*
|
|
|
|
|
* @time 2019年12月08日
|
2019-12-12 18:52:33 +08:00
|
|
|
|
* @param array $permissions
|
2019-12-09 16:22:00 +08:00
|
|
|
|
* @return mixed
|
2019-12-11 21:00:14 +08:00
|
|
|
|
* @throws \think\db\exception\DbException
|
2019-12-09 16:22:00 +08:00
|
|
|
|
*/
|
2019-12-12 18:52:33 +08:00
|
|
|
|
public function attach(array $permissions)
|
2019-12-09 16:22:00 +08:00
|
|
|
|
{
|
2019-12-12 18:52:33 +08:00
|
|
|
|
if (empty($permissions)) {
|
2019-12-11 21:00:14 +08:00
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
|
2019-12-12 18:52:33 +08:00
|
|
|
|
sort($permissions);
|
|
|
|
|
|
|
|
|
|
return $this->permissions()->attach($permissions);
|
2019-12-09 16:22:00 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
*
|
|
|
|
|
* @time 2019年12月08日
|
|
|
|
|
* @param array $roles
|
|
|
|
|
* @return mixed
|
|
|
|
|
*/
|
2019-12-11 21:00:14 +08:00
|
|
|
|
public function detach(array $roles = [])
|
2019-12-09 16:22:00 +08:00
|
|
|
|
{
|
2019-12-11 21:00:14 +08:00
|
|
|
|
if (empty($roles)) {
|
|
|
|
|
return $this->permissions()->detach();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return $this->permissions()->detach($roles);
|
2019-12-09 16:22:00 +08:00
|
|
|
|
}
|
|
|
|
|
}
|