46 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			PHP
		
	
	
	
			
		
		
	
	
			46 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			PHP
		
	
	
	
<?php
 | 
						|
 | 
						|
namespace App\Http\Controllers;
 | 
						|
 | 
						|
use Illuminate\Http\Request;
 | 
						|
use Illuminate\Support\Facades\Auth;
 | 
						|
use Illuminate\Validation\ValidationException;
 | 
						|
use Illuminate\Validation\Rule;
 | 
						|
 | 
						|
class ProfileController extends Controller {
 | 
						|
    public function update(Request $request) {
 | 
						|
        $user = Auth::user();
 | 
						|
        try {
 | 
						|
            $request->validate([
 | 
						|
                'name' => [
 | 
						|
                    'required',
 | 
						|
                    'string',
 | 
						|
                    'max:28',
 | 
						|
                    Rule::unique('users')->ignore($user->id), // Ignore current user
 | 
						|
                ],
 | 
						|
                'email' => [
 | 
						|
                    'required',
 | 
						|
                    'string',
 | 
						|
                    'email',
 | 
						|
                    Rule::unique('users')->ignore($user->id), // Ignore current user
 | 
						|
                ],
 | 
						|
            ]);
 | 
						|
        } catch (ValidationException $e) {
 | 
						|
            return redirect()->back()->withInput($request->input())->withErrors($e->errors());
 | 
						|
        }
 | 
						|
        $user->name = $request->input('name');
 | 
						|
        $user->email = $request->input('email');
 | 
						|
        $user->save();
 | 
						|
        return redirect('profile')->with('success', 'Profile updated successfully');
 | 
						|
    }
 | 
						|
 | 
						|
    public function updatePassword(Request $request) {
 | 
						|
        $user = Auth::user();
 | 
						|
        $request->validate([
 | 
						|
            'password' => 'required|string|min:8|confirmed'
 | 
						|
        ]);
 | 
						|
        $user->password = bcrypt($request->input('password'));
 | 
						|
        $user->save();
 | 
						|
        return redirect('profile')->with('success', 'Password updated successfully');
 | 
						|
    }
 | 
						|
} |