1
|
|
|
<?php declare(strict_types=1); |
2
|
|
|
|
3
|
|
|
namespace ApiClients\Client\Travis\CommandBus\Handler; |
4
|
|
|
|
5
|
|
|
use ApiClients\Client\Travis\CommandBus\Command\RepositoryCommand; |
6
|
|
|
use ApiClients\Client\Travis\Resource\RepositoryInterface; |
7
|
|
|
use ApiClients\Foundation\Hydrator\Hydrator; |
8
|
|
|
use ApiClients\Foundation\Transport\Service\RequestService; |
9
|
|
|
use Psr\Http\Message\ResponseInterface; |
10
|
|
|
use React\Promise\PromiseInterface; |
11
|
|
|
use RingCentral\Psr7\Request; |
12
|
|
|
use function React\Promise\resolve; |
13
|
|
|
use function WyriHaximus\React\futureFunctionPromise; |
14
|
|
|
|
15
|
|
|
final class RepositoryHandler |
16
|
|
|
{ |
17
|
|
|
/** |
18
|
|
|
* @var RequestService |
19
|
|
|
*/ |
20
|
|
|
private $requestService; |
21
|
|
|
|
22
|
|
|
/** |
23
|
|
|
* @var Hydrator |
24
|
|
|
*/ |
25
|
|
|
private $hydrator; |
26
|
|
|
|
27
|
|
|
/** |
28
|
|
|
* @param RequestService $requestService |
29
|
|
|
* @param Hydrator $hydrator |
30
|
|
|
*/ |
31
|
1 |
|
public function __construct(RequestService $requestService, Hydrator $hydrator) |
32
|
|
|
{ |
33
|
1 |
|
$this->requestService = $requestService; |
34
|
1 |
|
$this->hydrator = $hydrator; |
35
|
1 |
|
} |
36
|
|
|
|
37
|
|
|
/** |
38
|
|
|
* Fetch the given repository and hydrate it |
39
|
|
|
* |
40
|
|
|
* @param RepositoryCommand $command |
41
|
|
|
* @return PromiseInterface |
42
|
|
|
*/ |
43
|
1 |
|
public function handle(RepositoryCommand $command): PromiseInterface |
44
|
|
|
{ |
45
|
1 |
|
return $this->requestService->handle( |
46
|
1 |
|
new Request('GET', 'repos/' . $command->getRepository()) |
47
|
1 |
|
)->then(function (ResponseInterface $response) { |
48
|
1 |
|
return resolve($this->hydrator->hydrate( |
49
|
1 |
|
RepositoryInterface::HYDRATE_CLASS, |
50
|
1 |
|
$response->getBody()->getJson()['repo'] |
|
|
|
|
51
|
|
|
)); |
52
|
1 |
|
}); |
53
|
|
|
} |
54
|
|
|
} |
55
|
|
|
|
Let’s take a look at an example:
In the above example, the authenticate() method works fine as long as you just pass instances of MyUser. However, if you now also want to pass a different implementation of User which does not have a getDisplayName() method, the code will break.
Available Fixes
Change the type-hint for the parameter:
Add an additional type-check:
Add the method to the interface: