first commit
This commit is contained in:
127
app/Services/Auth/DepartmentService.php
Normal file
127
app/Services/Auth/DepartmentService.php
Normal file
@@ -0,0 +1,127 @@
|
||||
<?php
|
||||
// +----------------------------------------------------------------------
|
||||
// | SentCMS [ WE CAN DO IT JUST THINK IT ]
|
||||
// +----------------------------------------------------------------------
|
||||
// | Copyright (c) 2024 http://www.tensent.cn All rights reserved.
|
||||
// +----------------------------------------------------------------------
|
||||
// | Author: molong <molong@tensent.cn> <http://www.tensent.cn>
|
||||
// +----------------------------------------------------------------------
|
||||
namespace App\Services\Auth;
|
||||
|
||||
use App\Models\Auth\Department;
|
||||
use App\Support\Tree;
|
||||
|
||||
class DepartmentService {
|
||||
|
||||
/**
|
||||
* @title 获取部门列表
|
||||
*
|
||||
* @param [type] $request
|
||||
* @return void
|
||||
*/
|
||||
public function getDataList($request) {
|
||||
$map = [];
|
||||
|
||||
if ($request->filled('title')) {
|
||||
$map[] = ['title', 'like', '%' . $request->input('title') . '%'];
|
||||
}
|
||||
if ($request->filled('name')) {
|
||||
$map[] = ['name', 'like', '%' . $request->input('name') . '%'];
|
||||
}
|
||||
if ($request->filled('pid')) {
|
||||
$map[] = ['parent_id', '=', $request->input('pid')];
|
||||
}
|
||||
|
||||
$query = Department::where($map)->orderBy('id', 'desc');
|
||||
|
||||
if($request->filled('is_tree') && $request->filled('is_tree') == 1){
|
||||
$query = $query->get()->toArray();
|
||||
$tree = new Tree();
|
||||
$data = $tree->list_to_tree($query, 0, 'id', 'parent_id');
|
||||
}else{
|
||||
$data = [
|
||||
'total' => $query->count(),
|
||||
'page' => $request->input('page', 1),
|
||||
'data' => $query->offset($request->input('offset', 0))->limit($request->input('limit', 10))->get(),
|
||||
];
|
||||
}
|
||||
return $data;
|
||||
}
|
||||
|
||||
/**
|
||||
* @title 添加部门
|
||||
*
|
||||
* @param [type] $request
|
||||
* @return void
|
||||
*/
|
||||
public function create($request) {
|
||||
$request->validate([
|
||||
'title' => 'required|unique:auth_departments',
|
||||
'name' => 'required|unique:auth_departments',
|
||||
]);
|
||||
$data = $request->all();
|
||||
$data['status'] = 1;
|
||||
|
||||
return Department::create($data);
|
||||
}
|
||||
|
||||
/**
|
||||
* @title 修改部门
|
||||
*
|
||||
* @param [type] $request
|
||||
* @return void
|
||||
*/
|
||||
public function update($request) {
|
||||
try {
|
||||
$department = Department::findOrFail($request->input('id'));
|
||||
} catch (\Throwable $th) {
|
||||
throw new \Exception("部门不存在!", 1);
|
||||
}
|
||||
|
||||
if ($request->filled('title')) {
|
||||
$department->title = $request->input('title');
|
||||
}
|
||||
if ($request->filled('name')) {
|
||||
$department->name = $request->input('name');
|
||||
}
|
||||
if ($request->filled('parent_id')) {
|
||||
$department->parent_id = $request->input('parent_id');
|
||||
}
|
||||
if ($request->filled('status')) {
|
||||
$department->status = $request->input('status');
|
||||
}
|
||||
if ($request->filled('sort')) {
|
||||
$department->sort = $request->input('sort');
|
||||
}
|
||||
|
||||
$department->save();
|
||||
return $department;
|
||||
}
|
||||
|
||||
/**
|
||||
* @title 删除部门
|
||||
*
|
||||
* @param [type] $request
|
||||
* @return void
|
||||
*/
|
||||
public function delete($request) {
|
||||
if($request->filled('id')){
|
||||
try {
|
||||
$department = Department::findOrFail($request->input('id'));
|
||||
} catch (\Throwable $th) {
|
||||
throw new \Exception("角色不存在!", 1);
|
||||
}
|
||||
$department->delete();
|
||||
}
|
||||
if($request->filled('ids')){
|
||||
try {
|
||||
$ids = $request->input('ids');
|
||||
$department = Department::whereIn('id', $ids)->delete();
|
||||
} catch (\Throwable $th) {
|
||||
throw new \Exception($th->getMessage(), 1);
|
||||
}
|
||||
}
|
||||
|
||||
return $department;
|
||||
}
|
||||
}
|
||||
193
app/Services/Auth/MenuService.php
Normal file
193
app/Services/Auth/MenuService.php
Normal file
@@ -0,0 +1,193 @@
|
||||
<?php
|
||||
// +----------------------------------------------------------------------
|
||||
// | SentCMS [ WE CAN DO IT JUST THINK IT ]
|
||||
// +----------------------------------------------------------------------
|
||||
// | Copyright (c) 2024 http://www.tensent.cn All rights reserved.
|
||||
// +----------------------------------------------------------------------
|
||||
// | Author: molong <molong@tensent.cn> <http://www.tensent.cn>
|
||||
// +----------------------------------------------------------------------
|
||||
namespace App\Services\Auth;
|
||||
|
||||
use App\Models\Auth\Permission;
|
||||
use App\Models\Auth\Admin;
|
||||
use App\Support\Tree;
|
||||
|
||||
class MenuService {
|
||||
|
||||
/**
|
||||
* @title 获取权限节点列表
|
||||
*
|
||||
* @param [type] $request
|
||||
* @return void
|
||||
*/
|
||||
public function getDataList($request) {
|
||||
$map = [];
|
||||
|
||||
if ($request->filled('title')) {
|
||||
$map[] = ['title', 'like', '%' . $request->input('title') . '%'];
|
||||
}
|
||||
if ($request->filled('name')) {
|
||||
$map[] = ['name', 'like', '%' . $request->input('name') . '%'];
|
||||
}
|
||||
if ($request->filled('pid')) {
|
||||
$map[] = ['parent_id', '=', $request->input('pid')];
|
||||
}
|
||||
|
||||
$query = Permission::where($map)->orderBy('sort', 'asc')->orderBy('id', 'desc');
|
||||
|
||||
|
||||
if($request->filled('is_tree') && $request->filled('is_tree') == 1){
|
||||
$query = $query->get()->toArray();
|
||||
$tree = new Tree();
|
||||
$data = $tree->list_to_tree($query, 0, 'id', 'parent_id');
|
||||
}else{
|
||||
$data = [
|
||||
'total' => $query->count(),
|
||||
'page' => $request->input('page', 1),
|
||||
'data' => $query->offset($request->input('offset', 0))->limit($request->input('limit', 10))->get(),
|
||||
];
|
||||
}
|
||||
return $data;
|
||||
}
|
||||
|
||||
/**
|
||||
* @title 获取我的权限节点
|
||||
*
|
||||
* @param [type] $request
|
||||
* @return void
|
||||
*/
|
||||
public function getMyMenuList($request){
|
||||
$map = [];
|
||||
$data = [];
|
||||
$uid = auth('admin')->user()['uid'];
|
||||
|
||||
$tree = new Tree();
|
||||
if($uid != env('ADMIN_ID', 1)){
|
||||
$map[] = ['uid', '=', $uid];
|
||||
|
||||
$admin = Admin::with(['roles'])->where($map)->first();
|
||||
$permission = [];
|
||||
$menu = [];
|
||||
foreach ($admin->roles as $key => $role) {
|
||||
$menu = array_merge($menu, $role->permissions->append(['meta'])->toArray());
|
||||
$permission = array_merge($permission, $role->permissions->pluck('name')->toArray());
|
||||
}
|
||||
$data = [
|
||||
'menu' => $tree->list_to_tree($menu, 0, 'id', 'parent_id'),
|
||||
'permissions' => $permission
|
||||
];
|
||||
}else{
|
||||
$query = Permission::where($map)->orderBy('sort', 'asc');
|
||||
|
||||
$data = [
|
||||
'menu' => $tree->list_to_tree($query->where('type', '=', 'menu')->get()->append(['meta'])->toArray(), 0, 'id', 'parent_id'),
|
||||
'permissions' => $query->pluck('name')
|
||||
];
|
||||
}
|
||||
|
||||
return $data;
|
||||
}
|
||||
|
||||
/**
|
||||
* @title 添加权限节点
|
||||
*
|
||||
* @param [type] $request
|
||||
* @return void
|
||||
*/
|
||||
public function create($request) {
|
||||
$request->validate([
|
||||
'title' => 'required|unique:auth_permissions',
|
||||
'name' => 'required|unique:auth_permissions',
|
||||
]);
|
||||
$data = $request->all();
|
||||
$data['status'] = 1;
|
||||
|
||||
return Permission::create($data);
|
||||
}
|
||||
|
||||
/**
|
||||
* @title 修改权限节点
|
||||
*
|
||||
* @param [type] $request
|
||||
* @return void
|
||||
*/
|
||||
public function update($request) {
|
||||
try {
|
||||
$permission = Permission::findOrFail($request->input('id'));
|
||||
} catch (\Throwable $th) {
|
||||
throw new \Exception("权限节点不存在!", 1);
|
||||
}
|
||||
|
||||
$data = $request->all();
|
||||
foreach ($data as $key => $value) {
|
||||
if (in_array($key, ['affix', 'color', 'component', 'fullpage', 'hidden', 'hiddenBreadcrumb', 'icon', 'name', 'parent_id', 'redirect', 'sort', 'title', 'type', 'path', 'status'])) {
|
||||
$permission->$key = $value;
|
||||
}
|
||||
}
|
||||
|
||||
$permission->save();
|
||||
return $permission;
|
||||
}
|
||||
|
||||
/**
|
||||
* @title 删除权限节点
|
||||
*
|
||||
* @param [type] $request
|
||||
* @return void
|
||||
*/
|
||||
public function delete($request) {
|
||||
if($request->filled('id')){
|
||||
try {
|
||||
$permission = Permission::findOrFail($request->input('id'));
|
||||
} catch (\Throwable $th) {
|
||||
throw new \Exception("权限节点不存在!", 1);
|
||||
}
|
||||
|
||||
$permission->roles()->detach();
|
||||
$permission->delete();
|
||||
}
|
||||
if($request->filled('ids')){
|
||||
try {
|
||||
$permission = Permission::whereIn('id', $request->input('ids'));
|
||||
foreach ($permission->get() as $item) {
|
||||
$item->roles()->detach();
|
||||
}
|
||||
$permission->delete();
|
||||
} catch (\Throwable $th) {
|
||||
throw new \Exception($th->getMessage(), 1);
|
||||
}
|
||||
}
|
||||
|
||||
return $permission;
|
||||
}
|
||||
|
||||
/**
|
||||
* @title 批量导入
|
||||
*
|
||||
* @param [array] $data
|
||||
* @return void
|
||||
*/
|
||||
public function importMenu($data, $parent_id = 0){
|
||||
foreach ($data as $key => $value) {
|
||||
$save = [
|
||||
'title' => $value['title'],
|
||||
'name' => $value['name'],
|
||||
'path' => $value['path'],
|
||||
'component' => $value['component'],
|
||||
'type' => $value['type'],
|
||||
'affix' => isset($value['affix']) ? $value['affix'] : 0,
|
||||
'parent_id' => $parent_id,
|
||||
'status' => 1,
|
||||
'sort' => isset($value['sort']) ? $value['sort'] : $key,
|
||||
'icon' => isset($value['icon']) ? $value['icon'] : '',
|
||||
'hidden' => isset($value['hidden']) ? $value['hidden'] : 0,
|
||||
'created_at' => date('Y-m-d H:i:s'),
|
||||
'updated_at' => date('Y-m-d H:i:s'),
|
||||
];
|
||||
$res = Permission::insertGetId($save);
|
||||
if (isset($value['children']) && !empty($value['children'])) {
|
||||
$this->importMenu($value['children'], $res);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
159
app/Services/Auth/RoleService.php
Normal file
159
app/Services/Auth/RoleService.php
Normal file
@@ -0,0 +1,159 @@
|
||||
<?php
|
||||
// +----------------------------------------------------------------------
|
||||
// | SentCMS [ WE CAN DO IT JUST THINK IT ]
|
||||
// +----------------------------------------------------------------------
|
||||
// | Copyright (c) 2024 http://www.tensent.cn All rights reserved.
|
||||
// +----------------------------------------------------------------------
|
||||
// | Author: molong <molong@tensent.cn> <http://www.tensent.cn>
|
||||
// +----------------------------------------------------------------------
|
||||
namespace App\Services\Auth;
|
||||
|
||||
use App\Models\Auth\Role;
|
||||
use App\Support\Tree;
|
||||
|
||||
class RoleService {
|
||||
|
||||
/**
|
||||
* @title 获取角色列表
|
||||
*
|
||||
* @param [type] $request
|
||||
* @return void
|
||||
*/
|
||||
public function getDataList($request) {
|
||||
$map = [];
|
||||
|
||||
if ($request->filled('title')) {
|
||||
$map[] = ['title', 'like', '%' . $request->input('title') . '%'];
|
||||
}
|
||||
if ($request->filled('name')) {
|
||||
$map[] = ['name', 'like', '%' . $request->input('name') . '%'];
|
||||
}
|
||||
|
||||
$query = Role::with(['permissions'])->where($map)->orderBy('id', 'desc');
|
||||
|
||||
if($request->filled('is_tree') && $request->filled('is_tree') == 1){
|
||||
$query = $query->get()->toArray();
|
||||
$tree = new Tree();
|
||||
$data = $tree->list_to_tree($query, 0, 'id', 'parent_id');
|
||||
}else{
|
||||
if ($request->filled('page')){
|
||||
$data = [
|
||||
'total' => $query->count(),
|
||||
'page' => $request->input('page', 1),
|
||||
'data' => $query->offset($request->input('offset', 0))->limit($request->input('limit', 10))->get(),
|
||||
];
|
||||
}else{
|
||||
$data = $query->get();
|
||||
}
|
||||
}
|
||||
return $data;
|
||||
}
|
||||
|
||||
/**
|
||||
* @title 添加角色
|
||||
*
|
||||
* @param [type] $request
|
||||
* @return void
|
||||
*/
|
||||
public function create($request) {
|
||||
$request->validate([
|
||||
'title' => 'required|unique:auth_roles',
|
||||
'name' => 'required|alpha_dash:ascii|unique:auth_roles',
|
||||
]);
|
||||
$data = $request->all();
|
||||
$data['status'] = 1;
|
||||
|
||||
return Role::create($data);
|
||||
}
|
||||
|
||||
/**
|
||||
* @title 修改角色
|
||||
*
|
||||
* @param [type] $request
|
||||
* @return void
|
||||
*/
|
||||
public function update($request) {
|
||||
$request->validate([
|
||||
'title' => 'required|unique:auth_roles,title,' . $request->input('id'),
|
||||
'name' => 'required|alpha_dash:ascii|unique:auth_roles,name,' . $request->input('id'),
|
||||
]);
|
||||
try {
|
||||
$role = Role::findOrFail($request->input('id'));
|
||||
} catch (\Throwable $th) {
|
||||
throw new \Exception("角色不存在!", 1);
|
||||
}
|
||||
|
||||
if ($request->filled('title')) {
|
||||
$role->title = $request->input('title');
|
||||
}
|
||||
if ($request->filled('name')) {
|
||||
$role->name = $request->input('name');
|
||||
}
|
||||
if ($request->filled('status')) {
|
||||
$role->status = $request->input('status');
|
||||
}
|
||||
if ($request->filled('sort')) {
|
||||
$role->sort = $request->input('sort');
|
||||
}
|
||||
|
||||
$role->save();
|
||||
return $role;
|
||||
}
|
||||
|
||||
/**
|
||||
* @title 删除角色
|
||||
*
|
||||
* @param [type] $request
|
||||
* @return void
|
||||
*/
|
||||
public function delete($request) {
|
||||
if($request->filled('id')){
|
||||
try {
|
||||
$role = Role::findOrFail($request->input('id'));
|
||||
} catch (\Throwable $th) {
|
||||
throw new \Exception("角色不存在!", 1);
|
||||
}
|
||||
$role->permissions()->detach();
|
||||
$role->admins()->detach();
|
||||
$role->delete();
|
||||
}
|
||||
if($request->filled('ids')){
|
||||
try {
|
||||
$role = Role::whereIn('id', $request->input('ids'));
|
||||
foreach ($role->get() as $item) {
|
||||
$item->permissions()->detach(); //删除关联
|
||||
$item->admins()->detach(); //删除关联
|
||||
}
|
||||
|
||||
$role->delete();
|
||||
} catch (\Throwable $th) {
|
||||
throw new \Exception($th->getMessage(), 1);
|
||||
}
|
||||
}
|
||||
|
||||
return $role;
|
||||
}
|
||||
|
||||
/**
|
||||
* @title 角色授权
|
||||
*
|
||||
* @param [type] $request
|
||||
* @return void
|
||||
*/
|
||||
public function auth($request){
|
||||
try {
|
||||
$role = Role::with(['permissions'])->findOrFail($request->input('id'));
|
||||
} catch (\Throwable $th) {
|
||||
throw new \Exception("角色不存在!", 1);
|
||||
}
|
||||
|
||||
|
||||
if($request->filled('data_range')){
|
||||
$role->data_range = $request->input('data_range');
|
||||
}
|
||||
|
||||
$role->permissions()->sync($request->input('permissions'));
|
||||
$role->save();
|
||||
return $role;
|
||||
}
|
||||
}
|
||||
194
app/Services/Auth/UsersService.php
Normal file
194
app/Services/Auth/UsersService.php
Normal file
@@ -0,0 +1,194 @@
|
||||
<?php
|
||||
// +----------------------------------------------------------------------
|
||||
// | SentCMS [ WE CAN DO IT JUST THINK IT ]
|
||||
// +----------------------------------------------------------------------
|
||||
// | Copyright (c) 2024 http://www.tensent.cn All rights reserved.
|
||||
// +----------------------------------------------------------------------
|
||||
// | Author: molong <molong@tensent.cn> <http://www.tensent.cn>
|
||||
// +----------------------------------------------------------------------
|
||||
namespace App\Services\Auth;
|
||||
|
||||
use App\Models\Auth\Admin;
|
||||
|
||||
class UsersService {
|
||||
|
||||
/**
|
||||
* @title 获取用户列表
|
||||
*
|
||||
* @param [type] $request
|
||||
* @return void
|
||||
*/
|
||||
public function getDataList($request) {
|
||||
$map = [];
|
||||
|
||||
if ($request->filled('username')) {
|
||||
$map[] = ['username', 'like', '%' . $request->input('username') . '%'];
|
||||
}
|
||||
if ($request->filled('mobile')) {
|
||||
$map[] = ['mobile', 'like', '%' . $request->input('mobile') . '%'];
|
||||
}
|
||||
if ($request->filled('email')) {
|
||||
$map[] = ['email', 'like', '%' . $request->input('email') . '%'];
|
||||
}
|
||||
if ($request->filled('department_id')) {
|
||||
$map[] = ['department_id', '=', $request->input('department_id')];
|
||||
}
|
||||
|
||||
$query = Admin::where($map)->orderBy('uid', 'desc');
|
||||
|
||||
$data = [
|
||||
'total' => $query->count(),
|
||||
'page' => $request->input('page', 1),
|
||||
'data' => $query->offset($request->input('offset', 0))->limit($request->input('limit', 10))->get(),
|
||||
];
|
||||
return $data;
|
||||
}
|
||||
|
||||
/**
|
||||
* @title 添加用户
|
||||
*
|
||||
* @param [type] $request
|
||||
* @return void
|
||||
*/
|
||||
public function create($request) {
|
||||
$request->validate([
|
||||
'username' => 'required|unique:auth_admins,username',
|
||||
// 'email' => 'required|unique:auth_admins',
|
||||
// 'mobile' => 'required|unique:auth_admins',
|
||||
'password' => 'required|min:8',
|
||||
]);
|
||||
|
||||
$data = $request->all();
|
||||
$data['status'] = 1;
|
||||
$data['last_login_at'] = date('Y-m-d H:i:s');
|
||||
$data['last_login_ip'] = $request->ip();
|
||||
|
||||
$admins = Admin::create($data);
|
||||
$request->whenFilled('roles_id', function ($value) use ($admins) {
|
||||
$admins->roles()->sync($value);
|
||||
});
|
||||
return $admins;
|
||||
}
|
||||
|
||||
/**
|
||||
* @title 修改用户
|
||||
*
|
||||
* @param [type] $request
|
||||
* @return void
|
||||
*/
|
||||
public function update($request) {
|
||||
$request->validate([
|
||||
'username' => 'required|unique:auth_admins,username,' . $request->input('uid').',uid',
|
||||
]);
|
||||
try {
|
||||
$admins = Admin::findOrFail($request->input('uid'));
|
||||
} catch (\Throwable $th) {
|
||||
throw new \Exception("用户不存在!", 1);
|
||||
}
|
||||
|
||||
if ($request->filled('username')) {
|
||||
$admins->username = $request->input('username');
|
||||
}
|
||||
if ($request->filled('email')) {
|
||||
$admins->email = $request->input('email');
|
||||
}
|
||||
if ($request->filled('mobile')) {
|
||||
$admins->mobile = $request->input('mobile');
|
||||
}
|
||||
if ($request->filled('nickname')) {
|
||||
$admins->nickname = $request->input('nickname');
|
||||
}
|
||||
if ($request->filled('department_id')) {
|
||||
$admins->department_id = $request->input('department_id');
|
||||
}
|
||||
if ($request->filled('avatar')) {
|
||||
$admins->avatar = $request->input('avatar');
|
||||
}
|
||||
if ($request->filled('remark')) {
|
||||
$admins->remark = $request->input('remark');
|
||||
}
|
||||
if ($request->filled('status')) {
|
||||
$admins->status = $request->input('status');
|
||||
}
|
||||
if ($request->filled('password')) {
|
||||
$admins->password = $request->input('password');
|
||||
}
|
||||
$request->whenFilled('roles_id', function ($value) use ($admins) {
|
||||
$admins->roles()->sync($value);
|
||||
});
|
||||
|
||||
$admins->save();
|
||||
return $admins;
|
||||
}
|
||||
|
||||
/**
|
||||
* @title 删除用户
|
||||
*
|
||||
* @param [type] $request
|
||||
* @return void
|
||||
*/
|
||||
public function delete($request) {
|
||||
if($request->filled('id')){
|
||||
if($request->input('id') == env('ADMIN_ID', 1)){
|
||||
throw new \Exception("超级管理员不能删除!", 1);
|
||||
}
|
||||
try {
|
||||
$admins = Admin::findOrFail($request->input('id'));
|
||||
} catch (\Throwable $th) {
|
||||
throw new \Exception("角色不存在!", 1);
|
||||
}
|
||||
$admins->roles()->detach();
|
||||
$admins->delete();
|
||||
}
|
||||
if($request->filled('ids')){
|
||||
if(in_array(env('ADMIN_ID', 1), $request->input('ids'))){
|
||||
throw new \Exception("超级管理员不能删除!", 1);
|
||||
}
|
||||
try {
|
||||
$admins = Admin::whereIn('uid', $request->input('ids'));
|
||||
foreach ($admins->get() as $item) {
|
||||
$item->roles()->detach(); //删除关联
|
||||
}
|
||||
$admins = $admins->delete();
|
||||
} catch (\Throwable $th) {
|
||||
throw new \Exception($th->getMessage(), 1);
|
||||
}
|
||||
}
|
||||
return $admins;
|
||||
}
|
||||
|
||||
/**
|
||||
* @title 修改密码
|
||||
*
|
||||
* @param [type] $request
|
||||
* @return void
|
||||
*/
|
||||
public function upPassword($request) {
|
||||
try {
|
||||
$admins = Admin::findOrFail($request->input('uid'));
|
||||
} catch (\Throwable $th) {
|
||||
throw new \Exception("用户不存在!", 1);
|
||||
}
|
||||
|
||||
$admins->password = $request->input('password');
|
||||
$admins->save();
|
||||
return $admins;
|
||||
}
|
||||
|
||||
/**
|
||||
* @title 设置角色
|
||||
*
|
||||
* @param [type] $request
|
||||
* @return void
|
||||
*/
|
||||
public function uprole($request){
|
||||
try {
|
||||
$admins = Admin::with(['roles'])->findOrFail($request->input('uid'));
|
||||
} catch (\Illuminate\Database\Eloquent\ModelNotFoundException $th) {
|
||||
throw new \Exception($th->getMessage(), 1);
|
||||
}
|
||||
|
||||
$admins->roles()->sync($request->input('roles'));
|
||||
return $admins;
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user