Add Session Controller and UserRegisterController to manage login and register

This commit is contained in:
Thuan Bui
2025-03-06 21:46:32 +09:00
parent 1e94cdbc20
commit a88316ead8
5 changed files with 98 additions and 48 deletions
@@ -0,0 +1,41 @@
<?php
namespace App\Http\Controllers;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Auth;
use Illuminate\Validation\ValidationException;
class SessionController extends Controller
{
public function login() {
return view('auth.login');
}
public function store() {
$validatedAtts = request()->validate([
'email' => ['required'],
'password' => ['required']
]);
//dd($validatedAtts);
// Attemp
if (! Auth::attempt($validatedAtts)) {
throw ValidationException::withMessages([
'email' => 'The information does not match'
]);
};
// regenerate the session token
request()->session()->regenerate();
//redirect
return redirect()->route('task.index');
}
public function destroy() {
Auth::logout();
return redirect('/');
}
}
+7 -1
View File
@@ -54,7 +54,7 @@ class TaskController extends Controller
'categories' => $categories
]);
}
public function update(Task $task) {
$validatedAtts = request()->validate([
'name' => ['required'],
@@ -75,4 +75,10 @@ class TaskController extends Controller
return redirect()->route('task.index')->with('success', 'Task deleted successfully');
}
public function toggleComplete(Task $task) {
$task->completed = !$task->completed;
$task->save();
return redirect()->back();
}
}
@@ -0,0 +1,27 @@
<?php
namespace App\Http\Controllers;
use App\Models\User;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Auth;
use Illuminate\Support\Facades\Password;
class UserRegisterController extends Controller
{
public function register() {
return view('auth.register');
}
public function store() {
//validate
$validatedAtts = request()->validate([
'name' => ['required'],
'email' => ['required'],
'password' => ['required', Password::min(2), 'confirmed']
]);
$user = User::create($validatedAtts);
Auth::login($user);
return redirect()->route('task.view');
}
}
+14 -2
View File
@@ -10,9 +10,21 @@ class Task extends Model
{
use HasFactory;
protected $attributes = [
protected static function boot()
{
parent::boot();
static::creating(function ($task) {
if (is_null($task->completed)) {
$task->completed = false; // Ensure completed is false when creating a new task
}
$task->user_id = Auth::id(); // Set user_id automatically
});
}
/* protected $attributes = [
'completed' => false, // Set default value for completed
];
]; */
public function user() {
+9 -45
View File
@@ -1,6 +1,8 @@
<?php
use App\Http\Controllers\SessionController;
use App\Http\Controllers\TaskController;
use App\Http\Controllers\UserRegisterController;
use App\Models\Category;
use App\Models\Task;
use App\Models\User;
@@ -10,6 +12,8 @@ use Illuminate\Validation\Rules\Password;
use Illuminate\Validation\ValidationException;
Route::get('/', [TaskController::class, 'index']);
Route::get('/task', [TaskController::class, 'index'])->name('task.index');
Route::get('/task/create', [TaskController::class, 'create']);
@@ -17,53 +21,13 @@ Route::get('/task/{task}', [TaskController::class, 'show'])->name('task.show');
Route::post('/task/create', [TaskController::class, 'store'])->name('task.create');
Route::delete('/task/{task}', [TaskController::class, 'destroy']);
Route::get('/task/{task}/edit', [TaskController::class, 'edit']);
Route::patch('/task/{task}', [TaskController::class, 'update']);
Route::get('/register', [UserRegisterController::class, 'register']);
Route::post('/register', [UserRegisterController::class, 'store']);
Route::get('/login', [SessionController::class, 'login']);
Route::get('/login', function () {
return view('auth.login');
});
Route::post('/login', [SessionController::class, 'store']);
Route::post('/login', function () {
$validatedAtts = request()->validate([
'email' => ['required'],
'password' => ['required']
]);
//dd($validatedAtts);
// Attemp
if (! Auth::attempt($validatedAtts)) {
throw ValidationException::withMessages([
'email' => 'The information does not match'
]);
};
// regenerate the session token
request()->session()->regenerate();
//redirect
return redirect('/task');
});
Route::get('/register', function () {
return view('auth.register');
});
Route::post('/register', function () {
//validate
$validatedAtts = request()->validate([
'name' => ['required'],
'email' => ['required'],
'password' => ['required', Password::min(2), 'confirmed']
]);
$user = User::create($validatedAtts);
Auth::login($user);
});
Route::post('/logout', function() {
Auth::logout();
return redirect('/');
});
Route::post('/logout', [SessionController::class, 'destroy']);