|
1
|
|
|
<?php |
|
2
|
|
|
declare(strict_types=1); |
|
3
|
|
|
|
|
4
|
|
|
namespace BrenoRoosevelt\OAuth2\Client\Example; |
|
5
|
|
|
|
|
6
|
|
|
use BrenoRoosevelt\OAuth2\Client\GovBr; |
|
7
|
|
|
use Laminas\Diactoros\Response\JsonResponse as Json; |
|
8
|
|
|
use Laminas\Diactoros\Response\RedirectResponse as Redirect; |
|
9
|
|
|
use League\OAuth2\Client\Grant\AuthorizationCode; |
|
10
|
|
|
use Psr\Http\Message\ResponseInterface as Response; |
|
11
|
|
|
use Psr\Http\Message\ServerRequestInterface as Request; |
|
12
|
|
|
use Throwable; |
|
13
|
|
|
|
|
14
|
|
|
/** |
|
15
|
|
|
* Exemplo do fluxo Authorization Code. |
|
16
|
|
|
*/ |
|
17
|
|
|
final class AuthorizationCodeFlow |
|
18
|
|
|
{ |
|
19
|
|
|
private $govBr; |
|
20
|
|
|
private $stateStorage; |
|
21
|
|
|
|
|
22
|
|
|
public function __construct(GovBr $govBr, StateStorage $stateStorage) |
|
23
|
|
|
{ |
|
24
|
|
|
$this->govBr = $govBr; |
|
25
|
|
|
$this->stateStorage = $stateStorage; |
|
26
|
|
|
} |
|
27
|
|
|
|
|
28
|
|
|
public function __invoke(Request $request): Response |
|
29
|
|
|
{ |
|
30
|
|
|
$authorizationCode = $request->getQueryParams()['code'] ?? null; |
|
31
|
|
|
if (empty($authorizationCode)) { // Se não temos um código de autorização, vamos obter um |
|
32
|
|
|
$url = $this->govBr->getAuthorizationUrl(); |
|
33
|
|
|
$this->stateStorage->store($this->govBr->getState()); |
|
34
|
|
|
return new Redirect($url); // redireciona o usuário para obter a autorização |
|
35
|
|
|
} |
|
36
|
|
|
|
|
37
|
|
|
$state = $request->getQueryParams()['state'] ?? null; |
|
38
|
|
|
if (empty($state) || !$this->stateStorage->has($state)) { // Possível ataque CSRF em andamento |
|
39
|
|
|
$this->stateStorage->clear(); |
|
40
|
|
|
return new Json(['error' => 'Invalid state'], 401); |
|
41
|
|
|
} |
|
42
|
|
|
|
|
43
|
|
|
// Obtém o Access Token usando o Authorization Code |
|
44
|
|
|
try { |
|
45
|
|
|
$accessToken = $this->govBr->getAccessToken(new AuthorizationCode(), ['code' => $authorizationCode]); |
|
46
|
|
|
} catch (Throwable $e) { |
|
47
|
|
|
return new Json(['error' => $e->getMessage()], 401); // Erro ao obter o Access Token |
|
48
|
|
|
} |
|
49
|
|
|
|
|
50
|
|
|
// \o/ ... Já temos o Access Token ===> $accessToken |
|
51
|
|
|
|
|
52
|
|
|
// Opcionalmente você pode requisitar mais informações do usuário |
|
53
|
|
|
$userGovBr = $this->govBr->getResourceOwner($accessToken); |
|
54
|
|
|
|
|
55
|
|
|
// Você pode ainda solicitar o avatar (foto) |
|
56
|
|
|
// $avatar = $this->govBr->getAvatar($userGovBr); |
|
57
|
|
|
|
|
58
|
|
|
return new Json($userGovBr->toArray()); // Sua aplicação decide o que fazer com os dados obtidos |
|
59
|
|
|
} |
|
60
|
|
|
} |
|
61
|
|
|
|