IdsResolver::__construct()   A
last analyzed

Complexity

Conditions 1
Paths 1

Size

Total Lines 3
Code Lines 1

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
cc 1
eloc 1
nc 1
nop 1
dl 0
loc 3
rs 10
c 0
b 0
f 0
1
<?php
2
3
/**
4
 * Donut Social Network - Yet another experimental social network.
5
 * Copyright (C) 2016-2017, Dejan Angelov <[email protected]>
6
 *
7
 * This file is part of Donut Social Network.
8
 *
9
 * Donut Social Network is free software: you can redistribute it and/or modify
10
 * it under the terms of the GNU General Public License as published by
11
 * the Free Software Foundation, either version 3 of the License, or
12
 * (at your option) any later version.
13
 *
14
 * Donut Social Network is distributed in the hope that it will be useful,
15
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17
 * GNU General Public License for more details.
18
 *
19
 * You should have received a copy of the GNU General Public License
20
 * along with Donut Social Network.  If not, see <http://www.gnu.org/licenses/>.
21
 *
22
 * @package Donut Social Network
23
 * @copyright Copyright (C) 2016-2017, Dejan Angelov <[email protected]>
24
 * @license https://github.com/angelov/donut/blob/master/LICENSE
25
 * @author Dejan Angelov <[email protected]>
26
 */
27
28
namespace Angelov\Donut\Friendships\MutualFriendsResolver\Neo4jMutualFriendsResolver;
29
30
use GraphAware\Neo4j\Client\Client;
31
32
class IdsResolver
33
{
34
    private $client;
35
36
    public function __construct(Client $client)
37
    {
38
        $this->client = $client;
39
    }
40
41
    /**
42
     * @return string[] array of ids of the mutual friends
43
     */
44
    public function findMutualFriends(string $firstId, string $secondId) : array
45
    {
46
        $query = '
47
            MATCH
48
                (first:User {id: {first}}),
49
                (second:User {id: {second}}),
50
                (y:User),
51
                (first)-[:FRIEND]->(y),
52
                (y)<-[:FRIEND]-(second)
53
            RETURN
54
                y.id
55
        ';
56
57
        $result = $this->client->run($query, [
58
            'first' => $firstId,
59
            'second' => $secondId
60
        ]);
61
62
        $ids = [];
63
64
        foreach ($result->records() as $record) {
65
            $ids[] = (string) $record->get('y.id');
66
        }
67
68
        return $ids;
69
    }
70
}
71