2021-10-01 13:40:37 +02:00
|
|
|
<?php
|
|
|
|
|
2022-03-15 14:47:07 +01:00
|
|
|
namespace App\Http\Controllers\Auth;
|
2021-10-01 13:40:37 +02:00
|
|
|
|
2022-03-15 14:47:07 +01:00
|
|
|
use App\Http\Requests\UserUpdateRequest;
|
2021-11-07 21:57:22 +01:00
|
|
|
use App\Api\v1\Resources\UserResource;
|
2021-10-01 13:40:37 +02:00
|
|
|
use App\Http\Controllers\Controller;
|
|
|
|
use Illuminate\Support\Facades\Auth;
|
|
|
|
use Illuminate\Support\Facades\Hash;
|
2022-03-24 14:58:30 +01:00
|
|
|
use App\Exceptions\UnsupportedWithReverseProxyException;
|
2021-10-01 13:40:37 +02:00
|
|
|
|
|
|
|
class UserController extends Controller
|
|
|
|
{
|
2022-03-24 14:58:30 +01:00
|
|
|
/**
|
|
|
|
* Create a new controller instance.
|
|
|
|
*/
|
|
|
|
public function __construct()
|
|
|
|
{
|
|
|
|
$authGuard = config('auth.defaults.guard');
|
|
|
|
|
|
|
|
if ($authGuard === 'reverse-proxy-guard') {
|
|
|
|
throw new UnsupportedWithReverseProxyException();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2021-10-01 13:40:37 +02:00
|
|
|
/**
|
|
|
|
* Update the user's profile information.
|
|
|
|
*
|
2021-11-26 11:18:58 +01:00
|
|
|
* @param \App\Api\v1\Requests\UserUpdateRequest $request
|
|
|
|
* @return \App\Api\v1\Resources\UserResource
|
2021-10-01 13:40:37 +02:00
|
|
|
*/
|
|
|
|
public function update(UserUpdateRequest $request)
|
|
|
|
{
|
|
|
|
$user = $request->user();
|
|
|
|
$validated = $request->validated();
|
|
|
|
|
|
|
|
if (!Hash::check( $request->password, Auth::user()->password) ) {
|
|
|
|
return response()->json(['message' => __('errors.wrong_current_password')], 400);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!config('2fauth.config.isDemoApp') ) {
|
|
|
|
tap($user)->update([
|
|
|
|
'name' => $validated['name'],
|
|
|
|
'email' => $validated['email'],
|
|
|
|
]);
|
|
|
|
}
|
|
|
|
|
|
|
|
return new UserResource($user);
|
|
|
|
}
|
|
|
|
}
|