1 | <?php |
||
2 | declare(strict_types=1); |
||
3 | namespace Phauthentic\Authentication\Identifier\Resolver; |
||
4 | |||
5 | use ArrayAccess; |
||
6 | use Phauthentic\Authentication\Identifier\Resolver\ResolverInterface; |
||
7 | use Cake\Core\InstanceConfigTrait; |
||
8 | use Cake\ORM\Locator\LocatorAwareTrait; |
||
9 | |||
10 | class OrmResolver implements ResolverInterface |
||
11 | { |
||
12 | |||
13 | use InstanceConfigTrait; |
||
14 | use LocatorAwareTrait; |
||
15 | |||
16 | /** |
||
17 | * Default configuration. |
||
18 | * - `userModel` The alias for users table, defaults to Users. |
||
19 | * - `finder` The finder method to use to fetch user record. Defaults to 'all'. |
||
20 | * You can set finder name as string or an array where key is finder name and value |
||
21 | * is an array passed to `Table::find()` options. |
||
22 | * E.g. ['finderName' => ['some_finder_option' => 'some_value']] |
||
23 | * |
||
24 | * @var array |
||
25 | */ |
||
26 | protected $_defaultConfig = [ |
||
27 | 'userModel' => 'Users', |
||
28 | 'finder' => 'all', |
||
29 | ]; |
||
30 | |||
31 | /** |
||
32 | * Constructor. |
||
33 | * |
||
34 | * @param array $config Config array. |
||
35 | */ |
||
36 | 25 | public function __construct(array $config = []) |
|
37 | { |
||
38 | 25 | $this->setConfig($config); |
|
39 | 25 | } |
|
40 | |||
41 | /** |
||
42 | * {@inheritDoc} |
||
43 | */ |
||
44 | 9 | public function find(array $conditions): ?ArrayAccess |
|
45 | { |
||
46 | 9 | $table = $this->getTableLocator()->get($this->getConfig('userModel')); |
|
47 | |||
48 | 9 | $query = $table->query(); |
|
49 | 9 | $finders = (array)$this->getConfig('finder'); |
|
50 | 9 | foreach ($finders as $finder => $options) { |
|
51 | 9 | if (is_string($options)) { |
|
52 | 9 | $query->find($options); |
|
53 | } else { |
||
54 | 9 | $query->find($finder, $options); |
|
55 | } |
||
56 | } |
||
57 | |||
58 | 9 | $where = []; |
|
59 | 9 | foreach ($conditions as $field => $value) { |
|
60 | 9 | $field = $table->aliasField($field); |
|
61 | 9 | if (is_array($value)) { |
|
62 | 1 | $field = $field . ' IN'; |
|
63 | } |
||
64 | 9 | $where[$field] = $value; |
|
65 | } |
||
66 | |||
67 | 9 | return $query->where($where)->first(); |
|
0 ignored issues
–
show
Bug
Best Practice
introduced
by
Loading history...
|
|||
68 | } |
||
69 | } |
||
70 |