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
|
||||
]);
|
||||
}
|
||||
|
||||
|
||||
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
@@ -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
@@ -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']);
|
||||
Reference in New Issue
Block a user