DeleteInverseFriendship::notify()   A
last analyzed

Complexity

Conditions 1
Paths 1

Size

Total Lines 9
Code Lines 5

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
cc 1
eloc 5
nc 1
nop 1
dl 0
loc 9
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\EventSubscribers;
29
30
use Angelov\Donut\Friendships\Events\FriendshipWasDeletedEvent;
31
use Angelov\Donut\Friendships\Repositories\FriendshipsRepositoryInterface;
32
33
class DeleteInverseFriendship
34
{
35
    private $friendships;
36
37
    public function __construct(FriendshipsRepositoryInterface $friendships)
38
    {
39
        $this->friendships = $friendships;
40
    }
41
42
    public function notify(FriendshipWasDeletedEvent $event) : void
43
    {
44
        $friendship = $event->getFriendship();
45
        $user = $friendship->getUser();
46
        $friend = $friendship->getFriend();
47
48
        $inverse = $this->friendships->findBetweenUsers($user, $friend)[0];
49
50
        $this->friendships->destroy($inverse);
51
    }
52
}
53