HEX
Server: Apache/2.4.41 (Ubuntu)
System: Linux ip-172-31-42-149 5.15.0-1084-aws #91~20.04.1-Ubuntu SMP Fri May 2 07:00:04 UTC 2025 aarch64
User: ubuntu (1000)
PHP: 7.4.33
Disabled: pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare,
Upload Files
File: /var/www/vhost/disk-apps/dev-beg.teky.com.co/app/Http/Controllers/UsersController.php
<?php

namespace App\Http\Controllers;

use App\Role;
use App\User;
use App\Gender;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Auth;
use Illuminate\Support\Facades\Hash;
use Illuminate\Support\Facades\Storage;

class UsersController extends Controller
{
    /**
     * Display a listing of the resource.
     *
     * @return \Illuminate\Http\Response
     */
    public function index()
    {
        abort_unless(\Gate::allows('user_access'), 403);
        $users = User::with(['gender','roles'])->orderBy('id', 'desc')->get();
        return view('users.list', compact('users'));
    }

    /**
     * Show the form for creating a new resource.
     *
     * @return \Illuminate\Http\Response
     */
    public function create()
    {
        abort_unless(\Gate::allows('user_create'), 403);
        $genders = Gender::where('active', 1)->get();
        $roles = Role::where('active', 1)->get();
        return view('users.create', compact('genders','roles'));
    }

    /**
     * Store a newly created resource in storage.
     *
     * @param  \Illuminate\Http\Request  $request
     * @return \Illuminate\Http\Response
     */
    public function store(Request $request)
    {
        abort_unless(\Gate::allows('user_create'), 403);

        if($request->input('email') && $request->input('email') != "" && User::where([['email', $request->input('email')]])->first()){
            return response(array("status" => false, "type" => "error", "title" => "Oops...", "message" => __('already_exists', ['name' => $request->input('email')]), "username" => null));
        }

        if (!User::where('username', $request->input('username'))->first()) {
            if (in_array("1", $request->input('user_roles')) && \Gate::allows('user_seeInfoRoot') || !in_array("1", $request->input('user_roles')) && \Gate::allows('user_create')) {
                if ($user = User::create(array_slice($request->all(), 2))) {
                    $user->roles()->attach($request->input('user_roles'));
                    $this->registerLogData(json_encode(array_slice($request->all(), 1)), $user->id, 2, 1, Auth::user()->id);
                    return response(array("status" => true, "type" => "success", "title" => "", "message" => __('created_successfully'), "data" => array("user_id" => $user->id)));
                } else {
                    return response(array("status" => false, "type" => "error", "title" => "Oops...", "message" => __('error_creating'), "data" => null));
                }
            }else{
                return response(array("status" => false, "type" => "warning", "title" => __('title_403'), "message" => __('text2_403'), "data" => null));
            }
        } else {
            return response(array("status" => false, "type" => "error", "title" => "Oops...", "message" => __('already_exists', ['name' => $request->input('username')]), "data" => null));
        }
    }

    /**
     * Display the specified resource.
     *
     * @param  int  $id
     * @return \Illuminate\Http\Response
     */
    public function show($id)
    {
        abort_unless(\Gate::allows('user_show'), 403);
        return redirect()->back();
    }

    /**
     * Show the form for editing the specified resource.
     *
     * @param  int  $id
     * @return \Illuminate\Http\Response
     */
    public function edit($id)
    {
        abort_unless(\Gate::allows('user_edit'), 403);
        $user = User::findOrFail($id);
        if($user->roles->pluck('name')->contains('root') && !\Gate::check('user_seeInfoRoot')){
            abort_unless(\Gate::allows('user_seeInfoRoot'), 403);
        }
        $genders = Gender::where('active', 1)->get();
        $roles = Role::where('active', 1)->get();
        if ($user) {
            return view('users.edit', compact('user','genders','roles'));
        } else {
            return redirect()->back();
        }
    }

    /**
     * Update the specified resource in storage.
     *
     * @param  \Illuminate\Http\Request  $request
     * @param  int  $id
     * @return \Illuminate\Http\Response
     */
    public function update(Request $request, $id)
    {
        abort_unless(\Gate::allows('user_edit'), 403);
        $user = User::findOrFail($id);

        if($user->roles->pluck('name')->contains('root') && !\Gate::check('user_seeInfoRoot')){
            return response(array("status" => false, "type" => "warning", "title" => __('title_403'), "message" => __('text2_403'), "data" => null));
        }

        if($request->input('email') && $request->input('email') != "" && User::where([['id', '!=', $id], ['email', $request->input('email')]])->first()){
            return response(array("status" => false, "type" => "error", "title" => "Oops...", "message" => __('already_exists', ['name' => $request->input('email')]), "username" => null));
        }

        if (!User::where([['id', '!=', $id], ['username', $request->input('username')]])->first()) {
            if (in_array("1", $request->input('user_roles')) && \Gate::allows('user_seeInfoRoot') || !in_array("1", $request->input('user_roles')) && \Gate::allows('user_create')) {
                if (User::where('id', $id)->update(array_slice($request->all(), 3))) {
                    $user = User::findOrFail($id);
                    if(isset($request->password)){
                        $user->fill([
                            'password' => $request->password
                        ])->save();
                    }
                    $user->roles()->sync($request->input('user_roles'));
                    $this->registerLogData(json_encode(array_slice($request->all(), 2)), $id, 2, 3, Auth::user()->id);
                    return response(array("status" => true, "type" => "success", "title" => "", "message" => __('updated_successfully'), "data" => null));
                } else {
                    return response(array("status" => false, "type" => "error", "title" => "Oops...", "message" => __('error_updating'), "data" => null));
                }
            }else{
                return response(array("status" => false, "type" => "warning", "title" => __('title_403'), "message" => __('text2_403'), "data" => null));
            }
        } else {
            return response(array("status" => false, "type" => "error", "title" => "Oops...", "message" => __('already_exists', ['name' => $request->input('username')]), "username" => null));
        }
    }

    /**
     * Remove the specified resource from storage.
     *
     * @param  int  $id
     * @return \Illuminate\Http\Response
     */
    public function destroy($id)
    {
        abort_unless(\Gate::allows('user_destroy'), 403);
        if (User::where('id', $id)->delete()) {
            $this->registerLogData('', $id, 2, 4, Auth::user()->id);
            return response(array("status" => true, "type" => "success", "title" => "", "message" => __('deleted_successfully'), "data" => null));
        } else {
            return response(array("status" => false, "type" => "error", "title" => "Oops...", "message" => __('error_removing'), "data" => null));
        }
    }

    public function saveImage(Request $request)
    {
        $filenametostore = $request->id . env('IMAGE_EXTENSION');
        Storage::disk('s3')->put(env('S3_USERS_PATH') . $filenametostore, fopen($request->file('image'), 'r+'), 'public');

        $status = User::where('id', $request->id)->update(['image_url' => $filenametostore]);
        $this->registerLogData('Image', $request->id, 2, 5, Auth::user()->id);
        if ($status) {
            return response(array("status" => true, "type" => "error", "title" => "" ,"message" => null, "data" => null));
        } else {
            return response(array("status" => false, "type" => "error", "title" => "" ,"message" => null, "data" => null));
        }
    }
}