Subversion-Projekte lars-tiefland.webanos.faltradxxs.de

Revision

Revision 4 | Zur aktuellen Revision | Details | Letzte Änderung | Log anzeigen | RSS feed

Revision Autor Zeilennr. Zeile
3 lars 1
<?php
2
 
3
    namespace App\Http\Controllers;
4
 
5
    use App\Http\Controllers\Controller;
6
    use App\Http\Requests\Auth\LoginRequest;
7
    use App\Providers\RouteServiceProvider;
8
    use Illuminate\Http\RedirectResponse;
9
    use Illuminate\Http\Request;
10
    use Illuminate\Support\Facades\Auth;
11
    use Illuminate\Validation\ValidationException;
12
    use Illuminate\View\View;
13
 
14
    class BackendController extends Controller
15
    {
16
        /**
17
         * Display the login view.
18
         */
19
        public function create(): View
20
        {
21
            return view( 'admin.login' );
22
        }
23
 
24
        private function getUserRechte()
25
        {
26
            $uId = auth( 'admin' )->id();
27
            $user_rechte = UserProperty::where( "user_id", "=", $uId )->get();
28
            return $user_rechte;
29
        }
30
 
31
        /**
32
         * Handle an incoming authentication request.
33
         */
34
        public function store( LoginRequest $request ): RedirectResponse
35
        {
36
            try
37
            {
38
                $request->authenticate();
39
                $_SESSION["admin"]["uid"] = auth( 'admin' )->id();
40
                $_SESSION["admin"]["user"] = auth( 'admin' )->user();
41
                \View::share( "user_rechte", $this->getUserRechte() );
42
                $request->session()->regenerate();
43
 
44
                return redirect()->intended( "/admin/index" );
45
            }
46
            catch ( ValidationException $e )
47
            {
48
                dd( $e->getMessage() );
49
            }
50
 
51
        }
52
 
53
        /**
54
         * Destroy an authenticated session.
55
         */
56
        public function destroy( Request $request ): RedirectResponse
57
        {
58
            Auth::guard( 'admin' )->logout();
59
 
60
            $request->session()->invalidate();
61
 
62
            $request->session()->regenerateToken();
63
 
64
            return redirect( '/admin/index' );
65
        }
66
    }