This repository has been archived by the owner on Sep 27, 2022. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 94
/
LoginController.php
77 lines (66 loc) · 2.21 KB
/
LoginController.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
<?php
namespace Conduit\Controllers\Auth;
use Conduit\Models\User;
use Conduit\Transformers\UserTransformer;
use Interop\Container\ContainerInterface;
use League\Fractal\Resource\Item;
use Slim\Http\Request;
use Slim\Http\Response;
use Respect\Validation\Validator as v;
class LoginController
{
/** @var \Conduit\Validation\Validator */
protected $validator;
/** @var \Illuminate\Database\Capsule\Manager */
protected $db;
/** @var \League\Fractal\Manager */
protected $fractal;
/** @var \Conduit\Services\Auth\Auth */
private $auth;
/**
* RegisterController constructor.
*
* @param \Interop\Container\ContainerInterface $container
*/
public function __construct(ContainerInterface $container)
{
$this->auth = $container->get('auth');
$this->validator = $container->get('validator');
$this->db = $container->get('db');
$this->fractal = $container->get('fractal');
}
/**
* Return token after successful login
*
* @param \Slim\Http\Request $request
* @param \Slim\Http\Response $response
*
* @return \Slim\Http\Response
*/
public function login(Request $request, Response $response)
{
$validation = $this->validateLoginRequest($userParams = $request->getParam('user'));
if ($validation->failed()) {
return $response->withJson(['errors' => ['email or password' => ['is invalid']]], 422);
}
if ($user = $this->auth->attempt($userParams['email'], $userParams['password'])) {
$user->token = $this->auth->generateToken($user);
$data = $this->fractal->createData(new Item($user, new UserTransformer()))->toArray();
return $response->withJson(['user' => $data]);
};
return $response->withJson(['errors' => ['email or password' => ['is invalid']]], 422);
}
/**
* @param array
*
* @return \Conduit\Validation\Validator
*/
protected function validateLoginRequest($values)
{
return $this->validator->validateArray($values,
[
'email' => v::noWhitespace()->notEmpty(),
'password' => v::noWhitespace()->notEmpty(),
]);
}
}