add login user use case
This commit is contained in:
parent
3e259ee5e8
commit
b76355018e
1 changed files with 19 additions and 0 deletions
|
|
@ -2,12 +2,18 @@
|
||||||
|
|
||||||
namespace FreightQuote\User;
|
namespace FreightQuote\User;
|
||||||
|
|
||||||
|
use FreightQuote\User\UseCases\LoginUser;
|
||||||
|
use FreightQuote\User\UseCases\LoginUserRequest;
|
||||||
use Psr\Http\Message\ResponseInterface as Response;
|
use Psr\Http\Message\ResponseInterface as Response;
|
||||||
use Psr\Http\Message\ServerRequestInterface as Request;
|
use Psr\Http\Message\ServerRequestInterface as Request;
|
||||||
use Slim\Views\Twig;
|
use Slim\Views\Twig;
|
||||||
|
|
||||||
class UserController
|
class UserController
|
||||||
{
|
{
|
||||||
|
public function __construct(
|
||||||
|
private UserRepository $userRepo,
|
||||||
|
) {}
|
||||||
|
|
||||||
public function home(Request $request, Response $response): Response
|
public function home(Request $request, Response $response): Response
|
||||||
{
|
{
|
||||||
$view = Twig::fromRequest($request);
|
$view = Twig::fromRequest($request);
|
||||||
|
|
@ -26,6 +32,19 @@ class UserController
|
||||||
|
|
||||||
public function doLogin(Request $request, Response $response): Response
|
public function doLogin(Request $request, Response $response): Response
|
||||||
{
|
{
|
||||||
|
$view = Twig::fromRequest($request);
|
||||||
|
$body = $request->getParsedBody();
|
||||||
|
$email = $body['email'];
|
||||||
|
$password = $body['password'];
|
||||||
|
$useCase = new LoginUser(
|
||||||
|
new LoginUserRequest($email, $password),
|
||||||
|
$this->userRepo,
|
||||||
|
);
|
||||||
|
$result = $useCase->execute();
|
||||||
|
if (!$result) {
|
||||||
|
return $view->render($response, 'login.html.twig')
|
||||||
|
->withStatus(401);
|
||||||
|
}
|
||||||
$_SESSION['user_id'] = 1;
|
$_SESSION['user_id'] = 1;
|
||||||
$_SESSION['user'] = ['id' => 1, 'email' => 'email@email.com'];
|
$_SESSION['user'] = ['id' => 1, 'email' => 'email@email.com'];
|
||||||
$location = '/dashboard';
|
$location = '/dashboard';
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue