127 lines
3.0 KiB
PHP
127 lines
3.0 KiB
PHP
|
|
<?php
|
||
|
|
|
||
|
|
namespace Lucent\Http\Controller;
|
||
|
|
|
||
|
|
use App\Http\Controllers\Controller;
|
||
|
|
use Illuminate\Contracts\View\View;
|
||
|
|
use Illuminate\Http\RedirectResponse;
|
||
|
|
use Illuminate\Http\Request;
|
||
|
|
use Illuminate\Http\Response;
|
||
|
|
use Lucent\Account\AuthService;
|
||
|
|
use Lucent\Account\UserRepo;
|
||
|
|
use Lucent\LucentException;
|
||
|
|
use Lucent\Svelte\Svelte;
|
||
|
|
use function Lucent\Response\fail;
|
||
|
|
use function Lucent\Response\ok;
|
||
|
|
|
||
|
|
|
||
|
|
class AuthController extends Controller
|
||
|
|
{
|
||
|
|
public function __construct(
|
||
|
|
private readonly AuthService $authService,
|
||
|
|
private readonly Svelte $svelte,
|
||
|
|
private readonly UserRepo $userRepo,
|
||
|
|
)
|
||
|
|
{
|
||
|
|
|
||
|
|
}
|
||
|
|
|
||
|
|
public function register(Request $request): View
|
||
|
|
{
|
||
|
|
$userCount = $this->userRepo->count();
|
||
|
|
$email = $request->input("email");
|
||
|
|
$token = $request->input("token");
|
||
|
|
|
||
|
|
return svelte(
|
||
|
|
layout: "account",
|
||
|
|
view: "register",
|
||
|
|
title: "Create an account",
|
||
|
|
data: [
|
||
|
|
'email' => $email,
|
||
|
|
'token' => $token,
|
||
|
|
'userCount' => $userCount
|
||
|
|
]
|
||
|
|
);
|
||
|
|
}
|
||
|
|
|
||
|
|
|
||
|
|
public function postRegister(Request $request): Response
|
||
|
|
{
|
||
|
|
|
||
|
|
try {
|
||
|
|
if ($request->input("isAdmin")) {
|
||
|
|
$this->authService->registerAdmin(
|
||
|
|
name: $request->input("name"),
|
||
|
|
password: $request->input("password"),
|
||
|
|
email: $request->input("email"),
|
||
|
|
);
|
||
|
|
} else {
|
||
|
|
$this->authService->register(
|
||
|
|
name: $request->input("name"),
|
||
|
|
password: $request->input("password"),
|
||
|
|
email: $request->input("email"),
|
||
|
|
token: $request->input("token") ?? "",
|
||
|
|
);
|
||
|
|
}
|
||
|
|
|
||
|
|
|
||
|
|
} catch (LucentException $th) {
|
||
|
|
return fail($th);
|
||
|
|
}
|
||
|
|
|
||
|
|
return ok();
|
||
|
|
}
|
||
|
|
|
||
|
|
public function login(): View
|
||
|
|
{
|
||
|
|
return $this->svelte->render(
|
||
|
|
layout: "account",
|
||
|
|
view: "login",
|
||
|
|
title: "Log in"
|
||
|
|
);
|
||
|
|
}
|
||
|
|
|
||
|
|
public function postLogin(Request $request): Response
|
||
|
|
{
|
||
|
|
try {
|
||
|
|
$this->authService->sendLoginEmail($request->input("email"));
|
||
|
|
} catch (LucentException $th) {
|
||
|
|
return fail($th);
|
||
|
|
}
|
||
|
|
|
||
|
|
return ok();
|
||
|
|
}
|
||
|
|
|
||
|
|
public function verify(Request $request): View
|
||
|
|
{
|
||
|
|
return $this->svelte->render(
|
||
|
|
layout: "account",
|
||
|
|
view: "verify",
|
||
|
|
title: "Verify and enter",
|
||
|
|
data: [
|
||
|
|
"email" => $request->input("email"),
|
||
|
|
"token" => $request->input("token"),
|
||
|
|
]
|
||
|
|
);
|
||
|
|
}
|
||
|
|
|
||
|
|
public function postVerify(Request $request): Response
|
||
|
|
{
|
||
|
|
try {
|
||
|
|
$this->authService->login($request->input("email"), $request->input("token"));
|
||
|
|
} catch (LucentException $th) {
|
||
|
|
return fail($th);
|
||
|
|
}
|
||
|
|
return ok();
|
||
|
|
}
|
||
|
|
|
||
|
|
|
||
|
|
public function logout(): RedirectResponse
|
||
|
|
{
|
||
|
|
session()->flush();
|
||
|
|
return redirect("/login");
|
||
|
|
}
|
||
|
|
|
||
|
|
|
||
|
|
}
|