Added possiblity to register

This commit is contained in:
Jeroen De Meerleer 2023-08-16 15:14:19 +02:00
parent 677eba19b5
commit 653cdffcae
Signed by: JeroenED
GPG Key ID: 28CCCB8F62BFADD6
4 changed files with 740 additions and 534 deletions

View File

@ -4,6 +4,7 @@ namespace App\Http\Controllers\Auth;
use App\Http\Controllers\Controller;
use App\Http\Requests\Auth\LoginRequest;
use App\Models\User;
use Illuminate\Http\JsonResponse;
use Illuminate\Http\Request;
use Illuminate\Http\Response;
@ -25,4 +26,5 @@ class AuthenticatedSessionController extends Controller
return response()->json(['Success' => true, 'Authorization' => $authid]);
}
}

View File

@ -5,11 +5,13 @@ namespace App\Http\Controllers\Auth;
use App\Http\Controllers\Controller;
use App\Models\User;
use Illuminate\Auth\Events\Registered;
use Illuminate\Http\JsonResponse;
use Illuminate\Http\Request;
use Illuminate\Http\Response;
use Illuminate\Support\Facades\Auth;
use Illuminate\Support\Facades\Hash;
use Illuminate\Validation\Rules;
use Illuminate\Validation\ValidationException;
class RegisteredUserController extends Controller
{
@ -18,13 +20,17 @@ class RegisteredUserController extends Controller
*
* @throws \Illuminate\Validation\ValidationException
*/
public function store(Request $request): Response
public function store(Request $request): JsonResponse
{
$request->validate([
'name' => ['required', 'string', 'max:255'],
'email' => ['required', 'string', 'email', 'max:255', 'unique:'.User::class],
'password' => ['required', Rules\Password::defaults()],
]);
try {
$request->validate([
'name' => ['required', 'string', 'max:255'],
'email' => ['required', 'string', 'email', 'max:255', 'unique:'.User::class],
'password' => ['required', Rules\Password::defaults()],
]);
} catch (ValidationException $e) {
return new JsonResponse(['success'=> false, 'message' => $e->getMessage()], Response::HTTP_BAD_REQUEST);
}
$user = User::create([
'name' => $request->name,
@ -34,8 +40,21 @@ class RegisteredUserController extends Controller
event(new Registered($user));
Auth::login($user);
return new JsonResponse(['success'=> true, 'message' => 'User ' . $user->getAttribute('name') . ' Registered']);
}
return response()->noContent();
public function checkUserTaken(Request $request): JsonResponse
{
$return = [];
if ($request->request->has('email')) {
$user = User::where('email', $request->request->get('email'))->first();
if ($user !== NULL) $return['email'] = 'taken';
}
if ($request->request->has('name')) {
$user = User::where('name', $request->request->get('name'))->first();
if ($user !== NULL) $return['name'] = 'taken';
}
return new JsonResponse($return);
}
}

1235
composer.lock generated

File diff suppressed because it is too large Load Diff

View File

@ -14,6 +14,8 @@ use Illuminate\Support\Facades\Route;
|
*/
Route::get('/capabilities', [App\Http\Controllers\InfoController::class, 'capabilities']);
Route::post('/register/checkusertaken', [App\Http\Controllers\Auth\RegisteredUserController::class, 'checkUserTaken']);
Route::get('/register/checkusertaken', [App\Http\Controllers\Auth\RegisteredUserController::class, 'checkUserTaken']);
Route::middleware(['auth:sanctum'])->get('/user', function (Request $request) {
return $request->user();