mirror of
https://github.com/10h30/MoveMate.git
synced 2026-06-05 15:07:35 +09:00
Add Session Controller and UserRegisterController to manage login and register
This commit is contained in:
@@ -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('/');
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -54,7 +54,7 @@ class TaskController extends Controller
|
|||||||
'categories' => $categories
|
'categories' => $categories
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function update(Task $task) {
|
public function update(Task $task) {
|
||||||
$validatedAtts = request()->validate([
|
$validatedAtts = request()->validate([
|
||||||
'name' => ['required'],
|
'name' => ['required'],
|
||||||
@@ -75,4 +75,10 @@ class TaskController extends Controller
|
|||||||
return redirect()->route('task.index')->with('success', 'Task deleted successfully');
|
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
@@ -10,9 +10,21 @@ class Task extends Model
|
|||||||
{
|
{
|
||||||
use HasFactory;
|
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
|
'completed' => false, // Set default value for completed
|
||||||
];
|
]; */
|
||||||
|
|
||||||
|
|
||||||
public function user() {
|
public function user() {
|
||||||
|
|||||||
+9
-45
@@ -1,6 +1,8 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
|
use App\Http\Controllers\SessionController;
|
||||||
use App\Http\Controllers\TaskController;
|
use App\Http\Controllers\TaskController;
|
||||||
|
use App\Http\Controllers\UserRegisterController;
|
||||||
use App\Models\Category;
|
use App\Models\Category;
|
||||||
use App\Models\Task;
|
use App\Models\Task;
|
||||||
use App\Models\User;
|
use App\Models\User;
|
||||||
@@ -10,6 +12,8 @@ use Illuminate\Validation\Rules\Password;
|
|||||||
use Illuminate\Validation\ValidationException;
|
use Illuminate\Validation\ValidationException;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
Route::get('/', [TaskController::class, 'index']);
|
Route::get('/', [TaskController::class, 'index']);
|
||||||
Route::get('/task', [TaskController::class, 'index'])->name('task.index');
|
Route::get('/task', [TaskController::class, 'index'])->name('task.index');
|
||||||
Route::get('/task/create', [TaskController::class, 'create']);
|
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::post('/task/create', [TaskController::class, 'store'])->name('task.create');
|
||||||
Route::delete('/task/{task}', [TaskController::class, 'destroy']);
|
Route::delete('/task/{task}', [TaskController::class, 'destroy']);
|
||||||
Route::get('/task/{task}/edit', [TaskController::class, 'edit']);
|
Route::get('/task/{task}/edit', [TaskController::class, 'edit']);
|
||||||
|
|
||||||
Route::patch('/task/{task}', [TaskController::class, 'update']);
|
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 () {
|
Route::post('/login', [SessionController::class, 'store']);
|
||||||
return view('auth.login');
|
|
||||||
});
|
|
||||||
|
|
||||||
Route::post('/login', function () {
|
Route::post('/logout', [SessionController::class, 'destroy']);
|
||||||
$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('/');
|
|
||||||
});
|
|
||||||
Reference in New Issue
Block a user