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::middleware('auth')->prefix('profile')->name('profile.')->group(function () {
|
||||||
Route::get('/', [ProfileController::class, 'show'])->name('show');
|
Route::get('/', [ProfileController::class, 'show'])->name('show');
|
||||||
Route::get('/edit', [ProfileController::class, 'edit'])->name('edit');
|
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::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'])
|
Route::post('logout', [AuthenticatedSessionController::class, 'destroy'])
|
||||||
->name('logout');
|
->name('logout');
|
||||||
});
|
});
|
||||||
|
|||||||
@ -6,6 +6,7 @@ use App\Http\Controllers\Partner\DashboardController;
|
|||||||
use App\Http\Controllers\Partner\ListingController as PartnerListingController;
|
use App\Http\Controllers\Partner\ListingController as PartnerListingController;
|
||||||
|
|
||||||
Route::get('/', [HomeController::class, 'index'])->name('home');
|
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::get('/lang/{locale}', [LanguageController::class, 'switch'])->name('lang.switch');
|
||||||
|
|
||||||
Route::middleware('auth')->prefix('partner')->name('partner.')->group(function () {
|
Route::middleware('auth')->prefix('partner')->name('partner.')->group(function () {
|
||||||
|
|||||||
@ -2,11 +2,13 @@
|
|||||||
|
|
||||||
namespace Tests\Feature;
|
namespace Tests\Feature;
|
||||||
|
|
||||||
// use Illuminate\Foundation\Testing\RefreshDatabase;
|
use Illuminate\Foundation\Testing\RefreshDatabase;
|
||||||
use Tests\TestCase;
|
use Tests\TestCase;
|
||||||
|
|
||||||
class ExampleTest extends TestCase
|
class ExampleTest extends TestCase
|
||||||
{
|
{
|
||||||
|
use RefreshDatabase;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A basic test example.
|
* A basic test example.
|
||||||
*/
|
*/
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user