CyberRegister/CyberRegister

View on GitHub
app/Http/Controllers/CyberExpertiseController.php

Summary

Maintainability
A
0 mins
Test Coverage
<?php

namespace App\Http\Controllers;

use App\CyberExpertise;
use App\Http\Requests\CyberExpertiseStoreRequest;
use App\Http\Requests\CyberExpertiseUpdateRequest;
use Illuminate\Auth\Access\AuthorizationException;
use Illuminate\Http\RedirectResponse;
use Illuminate\View\View;

class CyberExpertiseController extends Controller
{
    /**
     * Display a listing of the CyberExpertises.
     *
     * @return View
     */
    public function index(): View
    {
        return view('cyber.index', ['cyberExpertises' => CyberExpertise::all()]);
    }

    /**
     * Show the form for creating a new CyberExpertise.
     *
     * @throws AuthorizationException
     *
     * @return View
     */
    public function create(): View
    {
        $this->authorize('create', CyberExpertise::class);

        return view('cyber.create');
    }

    /**
     * Store a newly created CyberExpertise in storage.
     *
     * @param CyberExpertiseStoreRequest $request
     *
     * @throws AuthorizationException
     *
     * @return RedirectResponse
     */
    public function store(CyberExpertiseStoreRequest $request): RedirectResponse
    {
        $this->authorize('create', CyberExpertise::class);

        try {
            CyberExpertise::create($request->all());
        } catch (\Exception $e) {
            return redirect()->route('cyberExpertise.create')->withInput()->withErrors([$e->getMessage()]);
        }
        // todo notification
        return redirect()->route('cyberExpertise.index');
    }

    /**
     * Display the specified CyberExpertise.
     *
     * @param CyberExpertise $cyberExpertise
     *
     * @return View
     */
    public function show(CyberExpertise $cyberExpertise): View
    {
        return view('cyber.show', ['cyberExpertise' => $cyberExpertise]);
    }

    /**
     * Show the form for editing the specified CyberExpertise.
     *
     * @param CyberExpertise $cyberExpertise
     *
     * @throws AuthorizationException
     *
     * @return View
     */
    public function edit(CyberExpertise $cyberExpertise): View
    {
        $this->authorize('edit', $cyberExpertise);

        return view('cyber.edit', ['cyberExpertise' => $cyberExpertise]);
    }

    /**
     * Update the specified CyberExpertise in storage.
     *
     * @param CyberExpertiseUpdateRequest $request
     * @param CyberExpertise              $cyberExpertise
     *
     * @throws AuthorizationException
     *
     * @return RedirectResponse
     */
    public function update(CyberExpertiseUpdateRequest $request, CyberExpertise $cyberExpertise): RedirectResponse
    {
        $this->authorize('update', $cyberExpertise);

        try {
            $cyberExpertise->update($request->all());
        } catch (\Exception $e) {
            return redirect()->route('cyberExpertise.edit', ['expertise_code' => $cyberExpertise->expertise_code])
                ->withInput()->withErrors([$e->getMessage()]);
        }
        // todo notification
        return redirect()->route('cyberExpertise.index');
    }

    /**
     * Remove the specified CyberExpertise from storage.
     *
     * @param CyberExpertise $cyberExpertise
     *
     * @throws AuthorizationException
     *
     * @return RedirectResponse
     */
    public function destroy(CyberExpertise $cyberExpertise): RedirectResponse
    {
        $this->authorize('delete', $cyberExpertise);

        try {
            $cyberExpertise->delete();
        } catch (\Exception $e) {
            return redirect()->route('cyberExpertise.edit', ['expertise_code' => $cyberExpertise->expertise_code])
                ->withInput()->withErrors([$e->getMessage()]);
        }
        // todo notification
        return redirect()->route('cyberExpertise.index');
    }
}