1
|
|
|
<?php |
2
|
|
|
|
3
|
|
|
declare(strict_types=1); |
4
|
|
|
|
5
|
|
|
/* |
6
|
|
|
* This file is part of Zenify |
7
|
|
|
* Copyright (c) 2012 Tomas Votruba (http://tomasvotruba.cz) |
8
|
|
|
*/ |
9
|
|
|
|
10
|
|
|
namespace Zenify\DoctrineBehaviors\DI; |
11
|
|
|
|
12
|
|
|
use Kdyby\Events\DI\EventsExtension; |
13
|
|
|
use Knp\DoctrineBehaviors\Model\Blameable\Blameable; |
14
|
|
|
use Knp\DoctrineBehaviors\ORM\Blameable\BlameableSubscriber; |
15
|
|
|
use Nette\Utils\AssertionException; |
16
|
|
|
use Nette\Utils\Validators; |
17
|
|
|
use Zenify\DoctrineBehaviors\Blameable\UserCallable; |
18
|
|
|
|
19
|
|
|
|
20
|
|
|
final class BlameableExtension extends AbstractBehaviorExtension |
21
|
|
|
{ |
22
|
|
|
|
23
|
|
|
/** |
24
|
|
|
* @var array |
25
|
|
|
*/ |
26
|
|
|
private $default = [ |
27
|
|
|
'isRecursive' => TRUE, |
28
|
|
|
'trait' => Blameable::class, |
29
|
|
|
'userCallable' => UserCallable::class, |
30
|
|
|
'userEntity' => NULL |
31
|
|
|
]; |
32
|
|
|
|
33
|
|
|
|
34
|
1 |
View Code Duplication |
public function loadConfiguration() |
35
|
|
|
{ |
36
|
1 |
|
$config = $this->getConfig($this->default); |
37
|
1 |
|
$this->validateConfigTypes($config); |
|
|
|
|
38
|
1 |
|
$builder = $this->getContainerBuilder(); |
39
|
|
|
|
40
|
1 |
|
$userCallable = $this->buildDefinitionFromCallable($config['userCallable']); |
41
|
|
|
|
42
|
1 |
|
$builder->addDefinition($this->prefix('listener')) |
43
|
1 |
|
->setClass(BlameableSubscriber::class, [ |
44
|
1 |
|
'@' . $this->getClassAnalyzer()->getClass(), |
45
|
1 |
|
$config['isRecursive'], |
46
|
1 |
|
$config['trait'], |
47
|
1 |
|
'@' . $userCallable->getClass(), |
48
|
1 |
|
$config['userEntity'] |
49
|
|
|
]) |
50
|
1 |
|
->setAutowired(FALSE) |
51
|
1 |
|
->addTag(EventsExtension::TAG_SUBSCRIBER); |
52
|
1 |
|
} |
53
|
|
|
|
54
|
|
|
|
55
|
|
|
/** |
56
|
|
|
* @throws AssertionException |
57
|
|
|
*/ |
58
|
1 |
|
private function validateConfigTypes(array $config) |
59
|
|
|
{ |
60
|
1 |
|
Validators::assertField($config, 'isRecursive', 'bool'); |
61
|
1 |
|
Validators::assertField($config, 'trait', 'type'); |
62
|
1 |
|
Validators::assertField($config, 'userCallable', 'string'); |
63
|
1 |
|
Validators::assertField($config, 'userEntity', 'null|string'); |
64
|
1 |
|
} |
65
|
|
|
|
66
|
|
|
} |
67
|
|
|
|
If a method or function can return multiple different values and unless you are sure that you only can receive a single value in this context, we recommend to add an additional type check:
If this a common case that PHP Analyzer should handle natively, please let us know by opening an issue.