Passed
Push — master ( 3d8258...4067fa )
by Mike
04:04
created

AbstractLogQueueListener::handleMessage()   A

Complexity

Conditions 3
Paths 3

Size

Total Lines 10
Code Lines 4

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 5
CRAP Score 3

Importance

Changes 0
Metric Value
eloc 4
dl 0
loc 10
ccs 5
cts 5
cp 1
rs 10
c 0
b 0
f 0
cc 3
nc 3
nop 2
crap 3
1
<?php
2
3
4
namespace Xervice\LogRabbitMq\Business\Plugin\Queue;
5
6
7
use DataProvider\LogMessageDataProvider;
8
use DataProvider\RabbitMqMessageCollectionDataProvider;
9
use PhpAmqpLib\Channel\AMQPChannel;
10
use Xervice\RabbitMQ\Business\Model\Worker\Listener\AbstractListener;
11
12
/**
13
 * @method \Xervice\LogRabbitMq\Business\LogRabbitMqBusinessFactory getFactory()
14
 */
15
abstract class AbstractLogQueueListener extends AbstractListener
16
{
17
    /**
18
     * @param \DataProvider\RabbitMqMessageCollectionDataProvider $collectionDataProvider
19
     * @param \PhpAmqpLib\Channel\AMQPChannel $channel
20
     */
21 1
    public function handleMessage(
22
        RabbitMqMessageCollectionDataProvider $collectionDataProvider,
23
        AMQPChannel $channel
24
    ): void {
25 1
        foreach ($collectionDataProvider->getMessages() as $message) {
26 1
            if ($message->getMessage() instanceof LogMessageDataProvider) {
27 1
                $this->handleLog($message->getMessage());
28
            }
29
30 1
            $this->sendAck($channel, $message);
31
        }
32 1
    }
33
34
    abstract public function handleLog(LogMessageDataProvider $dataProvider);
35
36
    /**
37
     * @return string
38
     */
39 1
    public function getQueueName(): string
40
    {
41 1
        return $this->getFactory()->createLogQueue()->getName();
42
    }
43
44
}