MIF_E31221225/app/Http/Controllers/Auth/RegisteredUserController.php

79 lines
2.3 KiB
PHP

<?php
namespace App\Http\Controllers\Auth;
use App\Http\Controllers\Controller;
use App\Models\User;
use App\Models\Guru;
use App\Models\Siswa;
use Illuminate\Auth\Events\Registered;
use Illuminate\Http\RedirectResponse;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Auth;
use Illuminate\Support\Facades\Hash;
use Illuminate\Validation\Rules;
use Illuminate\View\View;
class RegisteredUserController extends Controller
{
public function create(): View
{
return view('auth.register');
}
public function store(Request $request): RedirectResponse
{
$request->validate([
'nama' => 'required|string|max:255',
'email' => 'required|string|email|max:255|unique:users',
'password' => ['required', 'confirmed', Rules\Password::defaults()],
'role' => 'required|in:guru,siswa',
]);
// Simpan ke tabel users
$user = User::create([
'name' => $request->nama,
'email' => $request->email,
'password' => Hash::make($request->password),
'role' => $request->role,
'is_active' => 1,
]);
// Hubungkan ke tabel guru jika role = guru
if ($user->role == 'guru') {
$existingGuru = Guru::where('nama', $user->name)->first();
if ($existingGuru) {
// Jika guru sudah ada, hubungkan dengan user
$existingGuru->user_id = $user->id;
$existingGuru->save();
} else {
// Jika belum ada, buat baru
Guru::create([
'user_id' => $user->id,
'nama' => $user->name,
]);
}
}
// Hubungkan ke tabel siswa jika role = siswa
if ($user->role == 'siswa') {
$existingSiswa = Siswa::where('nama', $user->name)->first();
if ($existingSiswa) {
$existingSiswa->user_id = $user->id;
$existingSiswa->save();
} else {
Siswa::create([
'user_id' => $user->id,
'nama' => $user->name,
]);
}
}
Auth::login($user);
return redirect()->route('redirect-dashboard');
}
}