Database   A
last analyzed

Complexity

Total Complexity 3

Size/Duplication

Total Lines 37
Duplicated Lines 0 %

Test Coverage

Coverage 100%

Importance

Changes 4
Bugs 0 Features 1
Metric Value
eloc 18
c 4
b 0
f 1
dl 0
loc 37
ccs 9
cts 9
cp 1
rs 10
wmc 3

2 Methods

Rating   Name   Duplication   Size   Complexity  
A audit() 0 3 1
A prune() 0 24 2
1
<?php
2
3
namespace OwenIt\Auditing\Drivers;
4
5
use Illuminate\Support\Facades\Config;
6
use OwenIt\Auditing\Contracts\Audit;
7
use OwenIt\Auditing\Contracts\Auditable;
8
use OwenIt\Auditing\Contracts\AuditDriver;
9
10
class Database implements AuditDriver
11
{
12
    /**
13
     * {@inheritdoc}
14
     */
15 15
    public function audit(Auditable $model): ?Audit
16
    {
17 15
        return call_user_func([get_class($model->audits()->getModel()), 'create'], $model->toAudit());
18
    }
19
20
    /**
21
     * {@inheritdoc}
22
     */
23 15
    public function prune(Auditable $model): bool
24
    {
25 15
        if (($threshold = $model->getAuditThreshold()) > 0) {
26 1
            $auditClass = get_class($model->audits()->getModel());
27 1
            $auditModel = new $auditClass;
28 1
29 1
            return $model->audits()
30
                ->leftJoinSub(
31
                    $model->audits()->getQuery()
32 14
                        ->select($auditModel->getKeyName())->limit($threshold)->latest(),
33
                    'audit_threshold',
34
                    function ($join) use ($auditModel) {
35
                        $join->on(
36
                            $auditModel->gettable().'.'.$auditModel->getKeyName(),
37
                            '=',
38
                            'audit_threshold.'.$auditModel->getKeyName()
39
                        );
40
                    }
41
                )
42
                ->whereNull('audit_threshold.'.$auditModel->getKeyName())
43
                ->delete() > 0;
44
        }
45
46
        return false;
47
    }
48
}
49