You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
131 lines
3.3 KiB
131 lines
3.3 KiB
<?php
|
|
|
|
namespace App\Http\Controllers;
|
|
|
|
use App\Entities\Users\User;
|
|
use App\Http\Requests\Accounts\ChangePasswordRequest;
|
|
use App\Http\Requests\Accounts\LoginRequest;
|
|
use App\Http\Requests\Accounts\RegisterRequest;
|
|
use Auth;
|
|
use Illuminate\Contracts\Auth\Guard;
|
|
use Illuminate\Contracts\Auth\PasswordBroker;
|
|
use Illuminate\Foundation\Auth\ResetsPasswords;
|
|
use Illuminate\Foundation\Auth\ThrottlesLogins;
|
|
use Illuminate\Http\Request;
|
|
|
|
class AuthController extends Controller
|
|
{
|
|
use ResetsPasswords, ThrottlesLogins;
|
|
|
|
public function __construct(Guard $auth, PasswordBroker $passwords)
|
|
{
|
|
$this->auth = $auth;
|
|
$this->passwords = $passwords;
|
|
|
|
$this->middleware('guest', ['only' => [
|
|
'getLogin', 'postLogin', 'getRegister', 'postRegister',
|
|
'getActivate'
|
|
]
|
|
]);
|
|
$this->middleware('auth', ['only' => [
|
|
'getLogout', 'getChangePassword', 'postChangePassword',
|
|
'getProfile', 'patchProfile'
|
|
]
|
|
]);
|
|
}
|
|
|
|
public function getLogin()
|
|
{
|
|
return view('auth.login');
|
|
}
|
|
|
|
public function postLogin(Request $request)
|
|
{
|
|
$loginData = $request->validate([
|
|
'email' => 'required|email',
|
|
'password' => 'required',
|
|
]);
|
|
|
|
if (Auth::attempt($loginData)) {
|
|
flash()->success(trans('auth.welcome', ['name' => Auth::user()->name]));
|
|
return redirect()->intended('home');
|
|
}
|
|
|
|
flash()->error(trans('auth.failed'));
|
|
return redirect()->back()->withInput();
|
|
}
|
|
|
|
public function getLogout()
|
|
{
|
|
Auth::logout();
|
|
flash()->success('Anda telah logout.');
|
|
return redirect()->route('auth.login');
|
|
}
|
|
|
|
public function getRegister()
|
|
{
|
|
return view('auth.register');
|
|
}
|
|
|
|
public function postRegister(RegisterRequest $request)
|
|
{
|
|
$registerData = $request->only('name', 'email', 'password');
|
|
|
|
$user = User::create($registerData);
|
|
$user->assignRole('customer');
|
|
Auth::login($user);
|
|
|
|
flash()->success(trans('auth.welcome', ['name' => $user->name]));
|
|
return redirect()->route('home');
|
|
}
|
|
|
|
public function getActivate($code)
|
|
{
|
|
}
|
|
|
|
public function getChangePassword()
|
|
{
|
|
return view('auth.change-password');
|
|
}
|
|
|
|
public function postChangePassword(ChangePasswordRequest $request)
|
|
{
|
|
$input = $request->except('_token');
|
|
|
|
$user = auth()->user();
|
|
|
|
if (app('hash')->check($input['old_password'], $user->password)) {
|
|
$user->password = $input['password'];
|
|
$user->save();
|
|
|
|
flash()->success(trans('auth.password_changed'));
|
|
return redirect()->back();
|
|
}
|
|
|
|
flash()->error('Password lama tidak cocok!');
|
|
return redirect()->back();
|
|
}
|
|
|
|
public function getProfile()
|
|
{
|
|
$user = Auth::user();
|
|
return view('auth.profile', compact('user'));
|
|
}
|
|
|
|
public function patchProfile(Request $request)
|
|
{
|
|
$profileData = $request->validate([
|
|
'name' => 'required|max:60',
|
|
'email' => 'required|email',
|
|
]);
|
|
|
|
$user = auth()->user();
|
|
|
|
$user->name = $profileData['name'];
|
|
$user->email = $profileData['email'];
|
|
$user->save();
|
|
|
|
flash()->success(trans('auth.profile_updated'));
|
|
return back();
|
|
}
|
|
}
|