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/demo.sports-crowd.com/app/Http/Controllers/PlayerController.php
<?php

namespace App\Http\Controllers;

use Illuminate\Http\Request;
use DataTables;
use App\Player;
use App\Country;
use App\Position;
use App\EquipmentCategory;
use App\Services\PlayersService;
use Illuminate\Support\Facades\Storage;
use App\Http\Controllers\UtilController;

class PlayerController extends Controller
{
    private $util;

    public function __construct()
    {
        $this->util = new UtilController();
    }

    /**
     * Display a listing of the resource.
     *
     * @return \Illuminate\Http\Response
     */
    public function index()
    {
        return view('players.list');
    }

    /**
     * Show the form for creating a new resource.
     *
     * @return \Illuminate\Http\Response
     */
    public function create()
    {
        $positions = Position::all();
        $equipmentCategories = EquipmentCategory::all();
        $countries = Country::all();
        $player = null;
        return view('players.create', compact('positions', 'equipmentCategories', 'countries', 'player'));
    }

    /**
     * Store a newly created resource in storage.
     *
     * @param  \Illuminate\Http\Request  $request
     * @return \Illuminate\Http\Response
     */
    public function store(Request $request, PlayersService $playersService)
    {
        try {
            if (!Position::where('name', $request->input('name'))->first()) {
                $player = $playersService->store($request);
                return response(array("r" => true, "type" => "success", "title" => "", "m" =>
                __('messages.created_successfully'), "data" => $player->id));
            } else {
                return response(array("r" => false, "type" => "error", "title" => "Oops...", "m" =>
                __('messages.error_creating'), "data" => null));
            }
        } catch (\Throwable $th) {
            return response(array("r" => false, "type" => "error", "title" => "Oops...", "m" =>
            __('messages.error_creating'), "data" => $th->getMessage()));
        }
    }

    /**
     * Display the specified resource.
     *
     * @param  int  $id
     * @return \Illuminate\Http\Response
     */
    public function show($id)
    {
        //
    }

    /**
     * Show the form for editing the specified resource.
     *
     * @param  int  $id
     * @return \Illuminate\Http\Response
     */
    public function edit($id)
    {
        $positions = Position::all();
        $equipmentCategories = EquipmentCategory::all();
        $countries = Country::all();
        $player = Player::findOrFail($id);
        return view('players.edit', compact('player', 'positions', 'equipmentCategories', 'countries'));
    }

    /**
     * Update the specified resource in storage.
     *
     * @param  \Illuminate\Http\Request  $request
     * @param  int  $id
     * @return \Illuminate\Http\Response
     */
    public function update(Request $request, $id, PlayersService $playersService)
    {
        try {
            if (!Player::where([['id', '!=', $id], ['name', $request->input('name')]])->first()) {
                $playersService->update($request, $id);
                return response(array("r" => true, "type" => "success", "title" => "", "m" =>
                __('messages.updated_successfully'), "data" => '$player->id'));
            } else {
                return response(array("r" => false, "type" => "error", "title" => "Oops...", "m" =>
                __('messages.already_exists', ['name' => $request->input('name')]), "data" => null));
            }
        } catch (\Throwable $th) {
            return response(array("r" => false, "type" => "error", "title" => "Oops... " . $th, "m" =>
            __('messages.error_creating'), "data" => null));
        }
    }

    /**
     * Remove the specified resource from storage.
     *
     * @param  int  $id
     * @return \Illuminate\Http\Response
     */
    public function destroy($id)
    {
        try {
            if (Player::where('id', $id)->delete()) {
                return response(array("r" => true, "type" => "success", "title" => "", "m" =>
                __('messages.deleted_successfully'), "data" => null));
            } else {
                return response(array("r" => false, "type" => "error", "title" => "Oops...", "m" =>
                __('messages.error_removing'), "data" => null));
            }
        } catch (\Illuminate\Database\QueryException $e) {
            return response(array("r" => false, "type" => "error", "title" => "Oops...", "m" =>
            __('messages.delete_relation_data'), "data" => null));
        }
    }

    public function tableFilter()
    {
        $obj = Player::select('id', 'image', 'name', 'number', 'age', 'country_id', 'date_of_birth');
        return DataTables::of($obj)
            ->addColumn('actions', function ($obj) {
                return
                    '<i class="fa fa-pencil iconMini" onClick="clickEdit(' . $obj->id . ')" data-id="' . $obj->id . '"
                        title="Editar"></i>
                    <i class="fa fa-trash iconMini" onClick="clickDelete(' . $obj->id . ')" data-id="' . $obj->id . '"
                        title="Eliminar"></i>
            ';
            })
            ->addColumn('image', function ($obj) {
                if (!$obj->image) {
                    return $this->util->generateEmptyImageColumn();
                } else {
                    return $this->util->generateImageColumnRound(config('filesystems.disks.s3.url') . '/players/' . $obj->image, $obj->name, 'dorsal' . $obj->id);
                }
            })
            ->rawColumns(['actions', 'image'])
            ->make(true);
    }

    public function saveImage(Request $request)
    {
        try {
            $extension = $request->file('image')->getClientOriginalExtension();
            $filenametostore = $request->id . '.' . $extension;

            Storage::disk('s3')->put(
                config('s3.players') . $filenametostore,
                fopen($request->file('image'), 'r+'),
                'public'
            );

            $player = Player::find($request->id);
            $player->image = $filenametostore;
            $player->update();

            return response(array("r" => true, "type" => "success", "title" => "", "m" =>
            __('messages.updated_successfully'), "data" => null));
        } catch (\Throwable $th) {
            return response(array("r" => false, "type" => "error", "title" => "Oops...", "m" =>
            __('messages.error_updating'), "data" => $th->getMessage()));
        }
    }
}