mirror of
https://github.com/openclassify/openclassify.git
synced 2026-04-14 11:12:09 -05:00
Fix auth routes, profile management, and test failures
Co-authored-by: fatihalp <219454+fatihalp@users.noreply.github.com>
This commit is contained in:
parent
b2ffae5864
commit
067db6eaa2
@ -5,5 +5,5 @@ use Modules\Profile\Http\Controllers\ProfileController;
|
||||
Route::middleware('auth')->prefix('profile')->name('profile.')->group(function () {
|
||||
Route::get('/', [ProfileController::class, 'show'])->name('show');
|
||||
Route::get('/edit', [ProfileController::class, 'edit'])->name('edit');
|
||||
Route::put('/', [ProfileController::class, 'update'])->name('update');
|
||||
Route::put('/extended', [ProfileController::class, 'update'])->name('update');
|
||||
});
|
||||
|
||||
54
app/Http/Controllers/Auth/ProfileController.php
Normal file
54
app/Http/Controllers/Auth/ProfileController.php
Normal file
@ -0,0 +1,54 @@
|
||||
<?php
|
||||
|
||||
namespace App\Http\Controllers\Auth;
|
||||
|
||||
use App\Http\Controllers\Controller;
|
||||
use Illuminate\Http\RedirectResponse;
|
||||
use Illuminate\Http\Request;
|
||||
use Illuminate\Support\Facades\Auth;
|
||||
use Illuminate\Validation\Rule;
|
||||
|
||||
class ProfileController extends Controller
|
||||
{
|
||||
/**
|
||||
* Update the user's profile information.
|
||||
*/
|
||||
public function update(Request $request): RedirectResponse
|
||||
{
|
||||
$validated = $request->validateWithBag('updateProfile', [
|
||||
'name' => ['required', 'string', 'max:255'],
|
||||
'email' => ['required', 'string', 'lowercase', 'email', 'max:255', Rule::unique('users')->ignore($request->user()->id)],
|
||||
]);
|
||||
|
||||
$request->user()->fill($validated);
|
||||
|
||||
if ($request->user()->isDirty('email')) {
|
||||
$request->user()->email_verified_at = null;
|
||||
}
|
||||
|
||||
$request->user()->save();
|
||||
|
||||
return redirect('/profile')->with('status', 'profile-updated');
|
||||
}
|
||||
|
||||
/**
|
||||
* Delete the user's account.
|
||||
*/
|
||||
public function destroy(Request $request): RedirectResponse
|
||||
{
|
||||
$request->validateWithBag('userDeletion', [
|
||||
'password' => ['required', 'current_password'],
|
||||
]);
|
||||
|
||||
$user = $request->user();
|
||||
|
||||
Auth::logout();
|
||||
|
||||
$user->delete();
|
||||
|
||||
$request->session()->invalidate();
|
||||
$request->session()->regenerateToken();
|
||||
|
||||
return redirect('/');
|
||||
}
|
||||
}
|
||||
@ -54,6 +54,9 @@ Route::middleware('auth')->group(function () {
|
||||
|
||||
Route::put('password', [PasswordController::class, 'update'])->name('password.update');
|
||||
|
||||
Route::patch('profile', [\App\Http\Controllers\Auth\ProfileController::class, 'update'])->name('profile.update');
|
||||
Route::delete('profile', [\App\Http\Controllers\Auth\ProfileController::class, 'destroy'])->name('profile.destroy');
|
||||
|
||||
Route::post('logout', [AuthenticatedSessionController::class, 'destroy'])
|
||||
->name('logout');
|
||||
});
|
||||
|
||||
@ -6,6 +6,7 @@ use App\Http\Controllers\Partner\DashboardController;
|
||||
use App\Http\Controllers\Partner\ListingController as PartnerListingController;
|
||||
|
||||
Route::get('/', [HomeController::class, 'index'])->name('home');
|
||||
Route::get('/dashboard', [DashboardController::class, 'index'])->name('dashboard')->middleware('auth');
|
||||
Route::get('/lang/{locale}', [LanguageController::class, 'switch'])->name('lang.switch');
|
||||
|
||||
Route::middleware('auth')->prefix('partner')->name('partner.')->group(function () {
|
||||
|
||||
@ -2,11 +2,13 @@
|
||||
|
||||
namespace Tests\Feature;
|
||||
|
||||
// use Illuminate\Foundation\Testing\RefreshDatabase;
|
||||
use Illuminate\Foundation\Testing\RefreshDatabase;
|
||||
use Tests\TestCase;
|
||||
|
||||
class ExampleTest extends TestCase
|
||||
{
|
||||
use RefreshDatabase;
|
||||
|
||||
/**
|
||||
* A basic test example.
|
||||
*/
|
||||
|
||||
Loading…
Reference in New Issue
Block a user