DbLogListener::handle()   A
last analyzed

Complexity

Conditions 1
Paths 1

Size

Total Lines 3
Code Lines 1

Duplication

Lines 0
Ratio 0 %

Importance

Changes 1
Bugs 0 Features 0
Metric Value
cc 1
eloc 1
c 1
b 0
f 0
nc 1
nop 1
dl 0
loc 3
rs 10
1
<?php
2
3
namespace HoomanMirghasemi\Sms\Listeners;
4
5
use HoomanMirghasemi\Sms\Abstracts\Driver;
6
use HoomanMirghasemi\Sms\Contracts\SmsEvent;
7
use HoomanMirghasemi\Sms\Models\SmsReport;
8
9
class DbLogListener
10
{
11
    /**
12
     * Handle the event.
13
     *
14
     * @param object $event
15
     *
16
     * @return void
17
     */
18
    public function handle(SmsEvent $event): void
19
    {
20
        $this->saveLogInDb($event->smsDriver);
0 ignored issues
show
Bug introduced by
Accessing smsDriver on the interface HoomanMirghasemi\Sms\Contracts\SmsEvent suggest that you code against a concrete implementation. How about adding an instanceof check?
Loading history...
21
    }
22
23
    /**
24
     * This method should call in all driver send method in last line.
25
     *
26
     * @return void
27
     */
28
    protected function saveLogInDb(Driver $smsDriver): void
29
    {
30
        $sendSmsReport = new SmsReport();
31
        $sendSmsReport->mobile = $smsDriver->getRecipient();
32
        $sendSmsReport->message = $smsDriver->getMessage();
33
        $reflect = new \ReflectionClass($smsDriver);
34
        $sendSmsReport->from = strtolower($reflect->getShortName());
35
        $sendSmsReport->number = $smsDriver->getSenderNumber();
36
        $sendSmsReport->web_service_response = $smsDriver->getWebServiceResponce();
37
        $sendSmsReport->success = $smsDriver->getResult();
38
        $sendSmsReport->save();
39
    }
40
}
41