Sh3ll
OdayForums


Server : Apache
System : Linux 145.162.205.92.host.secureserver.net 5.14.0-611.45.1.el9_7.x86_64 #1 SMP PREEMPT_DYNAMIC Wed Apr 1 05:56:53 EDT 2026 x86_64
User : tradze ( 1001)
PHP Version : 8.1.34
Disable Function : NONE
Directory :  /home/tradze/public_html/app/Modules/Accounts/Http/Controllers/Admin/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Current File : /home/tradze/public_html/app/Modules/Accounts/Http/Controllers/Admin/AccountsController.php
<?php
namespace App\Modules\Accounts\Http\Controllers\Admin;

use App\Http\Controllers\AdminController;
use App\Http\Requests;
use App\Modules\Accounts\Http\Requests\CompanyRequest;
use App\Modules\Accounts\Models\Account;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Storage;
use Laracasts\Flash\Flash;
use Yajra\Datatables\Datatables;
use Illuminate\Support\Facades\Auth;
use Illuminate\Support\Str;

class AccountsController extends AdminController
{

    /**
     * Display a listing of the resource.
     *
     * @return Response
     */
    public function index()
    {
        $this->data['page_title'] = trans('accounts::companies.page_title');
        return view('accounts::admin.companies.index', $this->data);
    }

    /**
     * Show a list of all companies
     *
     * @return mixed
     */
    public function data(Request $request)
    {
        //create object contact
        $obj = $this->getData($request);

        //create array with contacts permissions access
        $this->data['can'] = [
            'edit'   => $this->data['user']->roles()->pluck('slug')[0] === 'developer',
            'delete' => $this->data['user']->roles()->pluck('slug')[0] === 'developer',
        ];

        //return datatables data
        return Datatables::of($obj)
            ->addColumn('actions', function ($o) {
                $this->data['o']=$o;
                return view('accounts::admin.companies.list_actions',$this->data)->render();
            })
            ->rawColumns(['actions']) 
            ->removeColumn('id')
            ->removeColumn('updated_at')
            ->make(true);
    }

    /**
     * Get object entries
     * @param Request $request
     */
    protected function getData(Request $request)
    {
        if(Auth::user()->hasRole('salon')) {
            $obj = Account::where('user_id', Auth::user()->id)->get();
        } else {
            $obj = Account::where('user_id', 0)->get();
        }

        //return object
        return $obj;
    }

    /**
     * Show the form for creating a new resource.
     *
     * @return Response
     */
    public function create()
    {
        $this->data['page_title'] = trans('accounts::companies.page_title');

        //show page
        return view('accounts::admin.companies.create_edit', $this->data);
    }

    /**
     * Store a newly created resource in storage.
     *
     * @return Response
     */
    public function store(CompanyRequest $request)
    {
        if(Auth::user()->hasRole('salon')) {
            //save new service type
            $data = $request->except('file_logo');
            $data['user_id'] = Auth::user()->id;
            $obj = Account::create($data);
        } else {
            //save new service type
            $data = $request->except('file_logo');
            $obj = Account::create($data);
        }

        //save image
        if ($request->file('file_logo'))
            $this->save_file($request, $obj);

        //redirect
        if ($request->save) {
            return redirect(route('admin.accounts.companies.edit', ['id' => $obj->id]));
        } elseif ($request->save_exit) {
            return redirect(route('admin.accounts.companies.index'));
        }
    }

    /**
     * Edit Service Type
     *
     * @param $label
     * @return \BladeView|bool|\Illuminate\Contracts\View\Factory|\Illuminate\View\View
     */
    public function edit(Account $company)
    {
        $obj = $company;
        $this->data['page_title'] = trans('accounts::companies.page_title');
        $this->data['obj'] = $obj;

        //show page
        return view('accounts::admin.companies.create_edit', $this->data);
    }

    /**
     * Update the specified resource in storage.
     *
     * @param  int $id
     * @return Response
     */
    public function update(CompanyRequest $request, Account $companies)
    {
        $obj = $companies;

        //fields to be updated
        $fillable = $obj->getFillable();

        $fields = array();
        foreach ($request->all() as $field => $f) {
            if (in_array($field, $fillable)) {
                $fields[$field] = $f;
            }
        } //end foreach

        //update label
        Account::where('id', $obj->id)->update($fields);

        //update image
        if ($request->file('file_logo')){
            $this->save_file($request, $obj);
        }


        //redirect
        if ($request->save) {
            return redirect(route('admin.accounts.companies.edit', ['id' => $obj->id]));
        } elseif ($request->save_exit) {
            return redirect(route('admin.accounts.companies.index'));
        }
    }

    /**
     * Save image file
     * @param Request $request
     * @param $obj
     */
    protected function save_file(Request $request,$obj)
    {
        $file = $request->file('file_logo');
        $filename = strtolower(Str::random(20)).'-'.Str::slug(str_replace($file->getClientOriginalExtension(),'',$file->getClientOriginalName()));
        $extension = ($file->getClientOriginalExtension())?:'jpg';

        $path_file = 'companies/'.$filename.".".$extension;

        //upload file
        $upload = Storage::disk('public_images')->put(
            $path_file,
            file_get_contents($file->getRealPath())
        );

        $obj->file_logo = $path_file;
        $obj->save();
    }

    /**
     * Delete page
     *
     * @param  int $id
     * @return \Illuminate\Http\Response
     */
    public function delete(Account $companies)
    {
        $this->data['obj'] = $companies;

        return view('accounts::admin.companies.delete', $this->data);
    }

    /**
     * Remove the specified resource from storage.
     *
     * @param  int $id
     * @return \Illuminate\Http\Response
     */
    public function destroy(Account $companies)
    {
        $obj = $companies;

        //set object name
        $obj_name = $companies->company;

        //delete contact
        $obj->delete();

        //set success message
        Flash::info(trans('accounts::companies.message_confirm_delete', ['name' => $obj->company]));

        //redirect to contacts list
        return redirect(route('admin.accounts.companies.index'));
    }

}

ZeroDay Forums Mini