����JFIF��x�x����'
| Server IP : 78.140.185.180 / Your IP : 216.73.216.170 Web Server : LiteSpeed System : Linux cpanel13.v.fozzy.com 4.18.0-513.11.1.lve.el8.x86_64 #1 SMP Thu Jan 18 16:21:02 UTC 2024 x86_64 User : builderbox ( 1072) PHP Version : 7.3.33 Disable Function : NONE MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : OFF | Pkexec : OFF Directory : /proc/thread-self/root/home/builderbox/././public_html/common/Auth/Controllers/ |
Upload File : |
<?php namespace Common\Auth\Controllers;
use App\User;
use Auth;
use Common\Auth\Actions\PaginateUsers;
use Common\Settings\Settings;
use Illuminate\Http\JsonResponse;
use Illuminate\Http\Request;
use Common\Auth\UserRepository;
use Common\Core\BaseController;
use Common\Auth\Requests\ModifyUsers;
class UserController extends BaseController
{
/**
* @var User
*/
private $user;
/**
* @var UserRepository
*/
private $userRepository;
/**
* @var Request
*/
private $request;
/**
* @var Settings
*/
private $settings;
public function __construct(
User $user,
UserRepository $userRepository,
Request $request,
Settings $settings
) {
$this->user = $user;
$this->request = $request;
$this->userRepository = $userRepository;
$this->middleware('auth', ['except' => ['show']]);
$this->settings = $settings;
}
public function index()
{
$this->authorize('index', User::class);
$pagination = app(PaginateUsers::class)->execute($this->request->all());
return $this->success(['pagination' => $pagination]);
}
public function show(User $user)
{
$relations = array_filter(
explode(',', $this->request->get('with', '')),
);
$relations = array_merge(['roles', 'social_profiles'], $relations);
if ($this->settings->get('envato.enable')) {
$relations[] = 'purchase_codes';
}
if (Auth::id() === $user->id) {
// TODO: remove after sanctum is added to all projects
if (method_exists($user, 'tokens')) {
$relations[] = 'tokens';
}
}
$user->load($relations);
$this->authorize('show', $user);
return $this->success(['user' => $user]);
}
public function store(ModifyUsers $request)
{
$this->authorize('store', User::class);
$user = $this->userRepository->create($request->all());
return $this->success(['user' => $user], 201);
}
/**
* @param User $user
* @param ModifyUsers $request
*
* @return JsonResponse
*/
public function update(User $user, ModifyUsers $request)
{
$this->authorize('update', $user);
$user = $this->userRepository->update($user, $request->all());
return $this->success(['user' => $user]);
}
public function destroy(string $ids)
{
$userIds = explode(',', $ids);
$shouldDeleteCurrentUser = $this->request->get('deleteCurrentUser');
$this->authorize('destroy', [User::class, $userIds]);
$users = $this->user->whereIn('id', $userIds)->get();
// guard against current user or admin user deletion
foreach ($users as $user) {
if (!$shouldDeleteCurrentUser && $user->id === Auth::id()) {
return $this->error(
"Could not delete currently logged in user: {$user->email}",
);
}
if ($user->is_admin) {
return $this->error(
"Could not delete admin user: {$user->email}",
);
}
}
$this->userRepository->deleteMultiple($users->pluck('id'));
return $this->success();
}
}