2FAuth/app/Http/Controllers/Auth/PasswordController.php

38 lines
1.1 KiB
PHP
Raw Normal View History

<?php
2022-03-15 14:47:07 +01:00
namespace App\Http\Controllers\Auth;
use App\Http\Controllers\Controller;
2022-11-22 15:15:52 +01:00
use App\Http\Requests\UserPatchPwdRequest;
use Illuminate\Support\Facades\Auth;
use Illuminate\Support\Facades\Hash;
2022-10-18 17:34:56 +02:00
use Illuminate\Support\Facades\Log;
class PasswordController extends Controller
{
/**
* Update the user's password.
*
2021-11-26 11:18:58 +01:00
* @return \Illuminate\Http\JsonResponse
*/
public function update(UserPatchPwdRequest $request)
{
$validated = $request->validated();
2022-11-22 15:15:52 +01:00
if (! Hash::check($validated['currentPassword'], Auth::user()->password)) {
2022-10-18 17:34:56 +02:00
Log::notice('Password update failed: wrong password provided');
2022-11-22 15:15:52 +01:00
return response()->json(['message' => __('errors.wrong_current_password')], 400);
}
2022-11-22 15:15:52 +01:00
if (! config('2fauth.config.isDemoApp')) {
$request->user()->update([
'password' => bcrypt($validated['password']),
]);
2023-02-27 00:33:42 +01:00
Log::info(sprintf('Password of user ID #%s updated', $request->user()->id));
}
return response()->json(['message' => __('auth.forms.password_successfully_changed')]);
}
2022-11-22 15:15:52 +01:00
}