Database::audit()   A
last analyzed

Complexity

Conditions 1
Paths 1

Size

Total Lines 3
Code Lines 1

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 2
CRAP Score 1

Importance

Changes 2
Bugs 0 Features 1
Metric Value
cc 1
eloc 1
c 2
b 0
f 1
nc 1
nop 1
dl 0
loc 3
ccs 2
cts 2
cp 1
crap 1
rs 10
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